Commit 6185d54e authored by honghy's avatar honghy Committed by wux

短信模块实作

parent fbe9d15a
import request from '@/utils/request'
// 创建短信节点
export function createSmsNode(data) {
return request({
url: '/system/sms-node/create',
method: 'post',
data: data
})
}
// 更新短信节点
export function updateSmsNode(data) {
return request({
url: '/system/sms-node/update',
method: 'put',
data: data
})
}
// 删除短信节点
export function deleteSmsNode(id) {
return request({
url: '/system/sms-node/delete?id=' + id,
method: 'delete'
})
}
// 获得短信节点
export function getSmsNode(id) {
return request({
url: '/system/sms-node/get?id=' + id,
method: 'get'
})
}
// 获得短信节点分页
export function getSmsNodePage(query) {
return request({
url: '/system/sms-node/page',
method: 'get',
params: query
})
}
// 导出短信节点 Excel
export function exportSmsNodeExcel(query) {
return request({
url: '/system/sms-node/export-excel',
method: 'get',
params: query,
responseType: 'blob'
})
}
...@@ -62,3 +62,11 @@ export function exportSmsTemplateExcel(query) { ...@@ -62,3 +62,11 @@ export function exportSmsTemplateExcel(query) {
}) })
} }
// 获得短信模板列表
export function getSmsTemplateList(query) {
return request({
url: '/system/sms-template/list',
method: 'get',
params: query
})
}
...@@ -27,6 +27,9 @@ export const DICT_TYPE = { ...@@ -27,6 +27,9 @@ export const DICT_TYPE = {
SYSTEM_SMS_TEMPLATE_TYPE: "system_sms_template_type", SYSTEM_SMS_TEMPLATE_TYPE: "system_sms_template_type",
SYSTEM_SMS_SEND_STATUS: "system_sms_send_status", SYSTEM_SMS_SEND_STATUS: "system_sms_send_status",
SYSTEM_SMS_RECEIVE_STATUS: "system_sms_receive_status", SYSTEM_SMS_RECEIVE_STATUS: "system_sms_receive_status",
SYSTEM_SMS_NODE_NODE: 'system_sms_node_node',//节点
SYSTEM_SMS_TEMPLATE_MESSAGE_TYPE: 'system_sms_template_message_type',//发送类型
SYSTEM_SMS_TEMPLATE_LANGUAGE: 'system_sms_template_language',//节点
SYSTEM_MAIL_SEND_STATUS: "mail_send_status", SYSTEM_MAIL_SEND_STATUS: "mail_send_status",
SYSTEM_ERROR_CODE_TYPE: "system_error_code_type", SYSTEM_ERROR_CODE_TYPE: "system_error_code_type",
INTERNAL_MESSAGE_TYPE: "internal_message_type", INTERNAL_MESSAGE_TYPE: "internal_message_type",
......
...@@ -28,13 +28,22 @@ ...@@ -28,13 +28,22 @@
<el-form-item :label="$t('上传凭证')"> <el-form-item :label="$t('上传凭证')">
<image-upload v-model="formData.voucher" /> <image-upload v-model="formData.voucher" />
</el-form-item> </el-form-item>
<el-form-item :label="$t('控货手机号')"> <el-form-item :label="$t('控货手机号')">
+{{detail.dialCode}} {{detail.phone}} +{{detail.dialCode}} {{detail.phone}}
</el-form-item> </el-form-item>
<el-form-item :label="$t('手机验证码')"> <el-form-item :label="$t('手机验证码')">
<el-input v-model="formData.code" placeholder="" style="width: 100px; margin-right:10px"></el-input> <el-input v-model="formData.code" placeholder="" style="width: 100px; margin-right:10px"></el-input>
<send-sms-code :order-id="order.orderId" :scene="5" /> <send-sms-code
:form="{
orderId: order.orderId,
nodeValue: 'delivery-verification-sms',
isTransport: 0,
transportId: 0,
isOrders: 0,
messageType: ''
}"
/>
</el-form-item> </el-form-item>
<div class="title">{{$t('审批流程')}}</div> <div class="title">{{$t('审批流程')}}</div>
...@@ -125,4 +134,4 @@ export default { ...@@ -125,4 +134,4 @@ export default {
margin-right:10px; margin-right:10px;
} }
} }
</style> </style>
\ No newline at end of file
...@@ -38,7 +38,16 @@ ...@@ -38,7 +38,16 @@
</el-form-item> </el-form-item>
<el-form-item :label="$t('手机验证码')" prop="field106"> <el-form-item :label="$t('手机验证码')" prop="field106">
<el-input v-model="formData.code" placeholder="" style="width: 100px; margin-right:10px"></el-input> <el-input v-model="formData.code" placeholder="" style="width: 100px; margin-right:10px"></el-input>
<send-sms-code :order-id="order.orderId" :scene="5" /> <send-sms-code
:form="{
orderId: order.orderId,
nodeValue: 'delivery-verification-sms',
isTransport: 0,
transportId: 0,
isOrders: 0,
messageType: ''
}"
/>
</el-form-item> </el-form-item>
<div class="title">{{$t('审批流程')}}</div> <div class="title">{{$t('审批流程')}}</div>
<work-flow xmlkey="release_goods" v-model="ccIdArr" /> <work-flow xmlkey="release_goods" v-model="ccIdArr" />
...@@ -109,7 +118,7 @@ export default { ...@@ -109,7 +118,7 @@ export default {
submit(){ submit(){
let data = Object.assign({}, this.formData, { let data = Object.assign({}, this.formData, {
cargoControlPickId: this.info.id, cargoControlPickId: this.info.id,
orderId: this.order.orderId, orderId: this.order.orderId,
orderNo: this.order.orderNo orderNo: this.order.orderNo
}) })
......
...@@ -29,8 +29,8 @@ ...@@ -29,8 +29,8 @@
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<el-form-item :label="$t('反复核原因')" prop="recurrentNuclearType"> <el-form-item :label="$t('反复核原因')" prop="recurrentNuclearType">
<dict-selector :type="DICT_TYPE.ECW_PICK_RECURRENT_NUCLEAR_TYPE" v-model="formData.recurrentNuclearType" form-type="radio" /> <dict-selector :type="DICT_TYPE.ECW_PICK_RECURRENT_NUCLEAR_TYPE" v-model="formData.recurrentNuclearType" form-type="radio" />
...@@ -43,11 +43,20 @@ ...@@ -43,11 +43,20 @@
<template v-else> <template v-else>
+{{order.cargoControlCountryCode}} {{order.cargoControlPhone}} +{{order.cargoControlCountryCode}} {{order.cargoControlPhone}}
</template> </template>
</el-form-item> </el-form-item>
<el-form-item :label="$t('手机验证码')" prop="code"> <el-form-item :label="$t('手机验证码')" prop="code">
<el-input v-model="formData.code" placeholder="" style="width: 100px; margin-right:10px"></el-input> <el-input v-model="formData.code" placeholder="" style="width: 100px; margin-right:10px"></el-input>
<send-sms-code :order-id="order.orderId" :scene="5" /> <send-sms-code
:form="{
orderId: order.orderId,
nodeValue: 'delivery-verification-sms',
isTransport: 0,
transportId: 0,
isOrders: 0,
messageType: ''
}"
/>
</el-form-item> </el-form-item>
<div class="title">{{$t('审批流程')}}</div> <div class="title">{{$t('审批流程')}}</div>
<work-flow xmlkey="release_goods" v-model="ccIdArr" /> <work-flow xmlkey="release_goods" v-model="ccIdArr" />
...@@ -114,7 +123,7 @@ export default { ...@@ -114,7 +123,7 @@ export default {
this.$refs.form.validate().then(res => { this.$refs.form.validate().then(res => {
let data = Object.assign({}, this.formData, { let data = Object.assign({}, this.formData, {
cargoControlPickId: this.info.id, cargoControlPickId: this.info.id,
orderId: this.order.orderId, orderId: this.order.orderId,
orderNo: this.order.orderNo orderNo: this.order.orderNo
}) })
......
<template> <template>
<el-dialog :title="title" visible :before-close="closeDialog" :close-on-click-modal="false" width="1000px"> <el-dialog :title="title" visible :before-close="closeDialog" :close-on-click-modal="false" width="1000px">
<el-form v-if="agreement" ref="form" :model="formData" :rules="rules" size="small" label-width="140px"> <el-form v-if="agreement" ref="form" :model="formData" :rules="rules" size="small" label-width="140px" >
<el-row> <el-row>
<el-col :span="8"> <el-col :span="8">
<el-form-item :label="$t('订单号')"> <el-form-item :label="$t('订单号')">
{{ detail.orderNo }} {{detail.orderNo}}
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item :label="$t('体积')"> <el-form-item :label="$t('体积')">
{{ detail.sumVolume }} {{detail.sumVolume }}
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item :label="$t('重量')"> <el-form-item :label="$t('重量')">
{{ detail.sumWeight }}kg {{detail.sumWeight }}kg
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item :label="$t('总箱数')"> <el-form-item :label="$t('总箱数')">
{{ detail.sumNum }} {{detail.sumNum }}
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item :label="$t('总控货箱数')"> <el-form-item :label="$t('总控货箱数')">
{{ detail.sumNum }} {{detail.sumNum}}
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item :label="$t('剩余放货箱数')"> <el-form-item :label="$t('剩余放货箱数')">
{{ detail.sumNum - detail.releaseNum }} {{ detail.sumNum - detail.releaseNum }}
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item :label="$t('到仓日期/卸柜日期')"> <el-form-item :label="$t('到仓日期/卸柜日期')">
{{ detail.unloadTime || '-'}} {{detail.unloadTime|| '-'}}
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item :label="$t('放货锁定收货人到期')"> <el-form-item :label="$t('放货锁定收货人到期')">
{{ detail.lockConsigneeTime || '-' }} {{ detail.lockConsigneeTime || '-' }}
</el-form-item> </el-form-item>
...@@ -131,13 +131,20 @@ ...@@ -131,13 +131,20 @@
<el-input v-model="formData.code" :placeholder="$t('请输入手机验证码')" clearable <el-input v-model="formData.code" :placeholder="$t('请输入手机验证码')" clearable
class="w-150 mr-10"></el-input> class="w-150 mr-10"></el-input>
<!-- <el-button type="success">{{ $t('获取验证码') }}</el-button> --> <!-- <el-button type="success">{{ $t('获取验证码') }}</el-button> -->
<send-sms-code :order-id="detail.orderId" scene="5"/> <send-sms-code :form="{
</el-form-item> orderId: detail.orderId,
<el-form-item label="" style="margin-top:20px"> nodeValue: 'delivery-verification-sms',
<el-button type="success" @click="submit">{{ $t('确认提货') }}</el-button> isTransport: 0,
<el-button type="default" @click="closeDialog">{{ $t('关闭') }}</el-button> transportId: 0,
</el-form-item> isOrders: 0,
</el-form> }"
/>
</el-form-item>
<el-form-item label="" style="margin-top:20px">
<el-button type="success" @click="submit">{{$t('确认提货')}}</el-button>
<el-button type="default" @click="closeDialog">{{$t('关闭')}}</el-button>
</el-form-item>
</el-form>
<div v-else> <div v-else>
<!-- <release-agreement /> --> <!-- <release-agreement /> -->
......
<template> <template>
<el-button @click="send" :disabled="leftTime > 0 && leftTime < 60">{{text}}</el-button> <el-dropdown @command="send" :disabled="leftTime > 0 && leftTime < 60">
<el-button type="primary">
{{ text }}<i class="el-icon-arrow-down el-icon--right"></i>
</el-button>
<el-dropdown-menu slot="dropdown">
<el-dropdown-item command="1">SMS</el-dropdown-item>
<el-dropdown-item command="2">WhatsApp</el-dropdown-item>
</el-dropdown-menu>
</el-dropdown>
</template> </template>
<script> <script>
import {sendSmsCode} from '@/api/ecw/orderCargoControl' import {sendSmsCode} from '@/api/ecw/orderCargoControl'
let timeout = null let timeout = null
export default { export default {
props:{ props:{
orderId: [String, Number], form: Object
scene: [String, Number]
}, },
data(){ data(){
return { return {
...@@ -30,13 +37,11 @@ export default { ...@@ -30,13 +37,11 @@ export default {
if(timeout)clearTimeout(timeout) if(timeout)clearTimeout(timeout)
}, },
methods:{ methods:{
send(){ send(messageType){
if(this.loading || (this.leftTime > 0 && this.leftTime < 60)) return false if(this.loading || (this.leftTime > 0 && this.leftTime < 60)) return false
this.loading = true this.loading = true
sendSmsCode({ this.form['messageType'] = messageType
orderId: this.orderId, sendSmsCode(this.form).then(res => {
scene: this.scene
}).then(res => {
this.$message.success(this.$t('发送成功')) this.$message.success(this.$t('发送成功'))
this.countDown() this.countDown()
}).finally(res => { }).finally(res => {
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
<el-form-item :label="$t('原控货手机号')"> <el-form-item :label="$t('原控货手机号')">
<el-input :value="'+' + cargoControlCountryCode + ' ' + cargoControlPhone" disabled></el-input> <el-input :value="'+' + cargoControlCountryCode + ' ' + cargoControlPhone" disabled></el-input>
</el-form-item> </el-form-item>
<el-form-item :label="$t('新控货人')" prop="name"> <el-form-item :label="$t('新控货人')" prop="name">
<el-input v-model="form.name"></el-input> <el-input v-model="form.name"></el-input>
</el-form-item> </el-form-item>
...@@ -21,7 +21,15 @@ ...@@ -21,7 +21,15 @@
</el-form-item> </el-form-item>
<el-form-item :label="$t('手机验证码')" prop="code"> <el-form-item :label="$t('手机验证码')" prop="code">
<el-input v-model.number="form.code" type="number" class="w-200 mr-10"></el-input> <el-input v-model.number="form.code" type="number" class="w-200 mr-10"></el-input>
<send-sms-code :order-id="orderId" scene="4" /> <send-sms-code
:form="{
orderId: orderId,
nodeValue: 'transfer-control-goods',
isTransport: 0,
transportId: 0,
isOrders: 0,
}"
/>
</el-form-item> </el-form-item>
<el-form-item label=""> <el-form-item label="">
<el-button type="primary" @click="submit">{{$t('确定转移')}}</el-button> <el-button type="primary" @click="submit">{{$t('确定转移')}}</el-button>
...@@ -111,8 +119,8 @@ export default { ...@@ -111,8 +119,8 @@ export default {
this.closeDialog() this.closeDialog()
}) })
}) })
} }
} }
} }
</script> </script>
\ No newline at end of file
...@@ -63,7 +63,16 @@ ...@@ -63,7 +63,16 @@
</el-form-item> </el-form-item>
<el-form-item :label="$t('手机验证码')" prop="code"> <el-form-item :label="$t('手机验证码')" prop="code">
<el-input v-model="formData.code" :placeholder="$t('请输入手机验证码')" clearable class="w-150 mr-10"></el-input> <el-input v-model="formData.code" :placeholder="$t('请输入手机验证码')" clearable class="w-150 mr-10"></el-input>
<send-sms-code :order-id="detail.orderId" scene="5" /> <send-sms-code
:form="{
orderId: detail.orderId,
nodeValue: 'delivery-verification-sms',
isTransport: 0,
transportId: 0,
isOrders: 0,
messageType: ''
}"
/>
</el-form-item> </el-form-item>
<div class="page-title">{{$t('审批流程')}}</div> <div class="page-title">{{$t('审批流程')}}</div>
<work-flow v-model="ccIdArr" xmlkey="transfer_goods" /> <work-flow v-model="ccIdArr" xmlkey="transfer_goods" />
......
...@@ -178,6 +178,11 @@ ...@@ -178,6 +178,11 @@
<el-form-item label="API 接收结果:">{{ form.apiReceiveCode }} | {{ form.apiReceiveMsg }} <el-form-item label="API 接收结果:">{{ form.apiReceiveCode }} | {{ form.apiReceiveMsg }}
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24">
<el-form-item label="节点模板序列号:">
{{ form.nodeTemplateSn }}
</el-form-item>
</el-col>
</el-row> </el-row>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
......
This diff is collapsed.
This diff is collapsed.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment