|
|
<template> <div class="global-width"> <div class="container"> <!--当前位置--> <div class="hc-breadcrumb"> <span class="hc-color4">{{$t('法币订单管理')}}</span> <i class="hc-breadcrumb-icon"></i> <span class="margin0" v-if="orderDetails.dealType == 'E_I_D_T_BUY'">{{$t('购买')}} {{orderDetails.inCoin}}</span> <span class="margin0" v-if="orderDetails.dealType == 'E_I_D_T_SELL'">{{$t('出售')}} {{orderDetails.outCoin}}</span> </div>
<div class="hc-breadcrumb trade-center-top"> <span>{{$t('订单详情')}}</span> </div>
<div class="trade-detail-warp purchase-warp"> <div class="trade-detail-left"> <router-link to="/" class="trade-detail-left-div1"> <div class="trade-detail-left-top"> <img src="../../assets/images/user-head-img.png" class="trade-detail-left-headimg"> </div>
<div class="trade-detail-left-top"> <div class="trade-detail-left-nickname">{{orderDetails.dealUserIdentity}}</div> <div class="merchants-tag"> <img src="../../assets/images/trade/icon-authentication.png"> <span class="hc-color">{{($t('认证商家'))}}</span> </div> </div> </router-link>
<div class="trade-detail-left-div2"> <div class="trade-detail-left-div3"> <div class="hc-color">{{$t('交易次数')}}</div> <div class="div2-d1">{{dealerInfo.sumOfFinishedFlow || 0}}</div> </div>
<div class="trade-detail-left-div4"> <div class="hc-color">{{$t('完成率')}}</div> <div class="div2-d1">{{dealerInfo.finishedRate || 0}}%</div> </div>
<div class="trade-detail-left-div5"> <div class="hc-color">{{$t('平均放行')}}</div> <div class="div2-d1">{{dealerInfo.avgReleaseMinus || 0}}分钟</div> </div> </div>
<div class="trade-detail-explain"> <h3>{{$t('广告说明')}}:</h3> <p class="hc-color">{{$t('1.订单有效期为15分钟,请您及时在有效期内付款并点击「标记付款已完成」按钮,我才可以释放数字币给您。')}}</p> <p class="hc-color">{{$t('2.开始交易后数字币由系统锁定托管,请安心下单。')}}</p> </div> <div class="trade-detail-explain"> <h3>{{$t('交易备注')}}:</h3> <p class="hc-color">{{$t('请勿在汇款备注内填写比特币、BTC、OTC等任何数字币有关字眼,防止您的汇款被银行拦截。')}}</p> <p class="hc-color">{{$t('银行帐号:')}}xxxx xxxx xxxx xxxx</p> <p class="hc-color">{{$t('支付宝帐号:')}}xxxxxxx</p> <p class="hc-color">{{$t('单后可以直接加我微信跟我联系,我会尽快回复。')}}</p> </div> </div>
<div class="trade-detail-right"> <div class="top-price"> <span class="hc-color2" v-if="orderDetails.dealType == 'E_I_D_T_BUY'">{{$t('购买')}} {{orderDetails.inCoin}}</span> <span class="hc-color1" v-if="orderDetails.dealType == 'E_I_D_T_SELL'">{{$t('出售')}} {{orderDetails.outCoin}}</span>
<div class="top-price-r">{{$t('订单编号')}}:{{id}}</div> <div class="top-price-r top-price-rm">{{$t('时间')}}: {{orderDetails.createDatetime | dateFormat('YYYY-MM-DD HH:mm:ss')}}</div> </div>
<ul class="ul-information"> <li class="li-1"> <div class="div1-d1">{{$t('价格')}}</div> <p v-if="orderDetails.dealType == 'E_I_D_T_BUY'">¥{{orderDetails.amount}}/{{orderDetails.outCoin}}</p> <p v-if="orderDetails.dealType == 'E_I_D_T_SELL'">¥{{orderDetails.amount}}/{{orderDetails.inCoin}}</p> </li> <li class="li-2"> <div class="div1-d1">{{$t('数量')}}</div> <p v-if="orderDetails.dealType == 'E_I_D_T_BUY'">{{orderDetails.inAmount}}{{orderDetails.inCoin}}</p> <p v-if="orderDetails.dealType == 'E_I_D_T_SELL'">{{orderDetails.outAmount}}{{orderDetails.outCoin}}</p> </li> <li class="li-3"> <div class="div1-d1">{{$t('交易金额')}}</div> <p v-if="orderDetails.dealType == 'E_I_D_T_BUY'">¥{{orderDetails.outAmount}}</p> <p v-if="orderDetails.dealType == 'E_I_D_T_SELL'">¥{{orderDetails.inAmount}}</p> </li> <!-- <li class="li-4"> <div class="div1-d1">{{$t('交易方式')}}</div> <p> <img src="../../theme/images/trade/icon-alipay.png" /> </p> </li> --> <li class="li-5"> <div class="div1-d1">{{$t('付款期限')}}</div> <p>15分钟</p> </li> <li class="li-6"> <div class="div1-d1">{{$t('状态')}}</div> <p v-if="orderDetails.statusStr == '待付款'">{{$t('请付款')}}</p> <p v-else-if="orderDetails.status == 'M_O_F_S_CANCEL'">{{$t('已取消')}}</p> <p v-else-if="orderDetails.statusStr == '完成'">{{$t('已完成')}}</p> <p v-else-if="orderDetails.appeal">{{$t('申诉中')}}</p> <p v-else>{{orderDetails.statusStr}}</p> </li> </ul>
<div class="order-list-total"> <div class="order-list-notice-one"> <span class="list-notice-title">{{$t('手续费')}}:</span><span>¥2</span> <div class="question-box"> <img class="fa-question" src="../../assets/images/icon-question.png" /> <div class="free-explanation"> <h3>{{$t('手续费说明')}}:</h3> <p>{{$t('交易手续费扣除百分之零点一')}}</p> </div> </div> </div>
<div class="order-list-notice-two"> <p> <span class="list-notice-title">{{$t('总额:')}}</span> <span class="list-notice-detail" v-if="orderDetails.dealType == 'E_I_D_T_BUY'">¥{{orderDetails.outAmount}}</span> <span class="list-notice-detail" v-if="orderDetails.dealType == 'E_I_D_T_SELL'">¥{{orderDetails.inAmount}}</span> </p>
<p> <span class="list-notice-title">{{$t('兑换:')}}</span> <span v-if="orderDetails.dealType == 'E_I_D_T_BUY'">{{orderDetails.inAmount}}{{orderDetails.inCoin}}</span> <span v-if="orderDetails.dealType == 'E_I_D_T_SELL'">{{orderDetails.outAmount}}{{orderDetails.outCoin}}</span> </p> </div> </div>
<div class="order-person-info"> <div class="person-info-left"> <!-- 买家 待付款 --> <div class="info-left-one" v-if="orderDetails.dealType == 'E_I_D_T_BUY' && orderDetails.status == 'M_O_F_S_WAIT_PAY' && !orderDetails.appeal"> <div class="one-title">{{$t('商家收款账号')}}</div>
<div class="one-body"> <button type="button" class="el-popover_reference" @click="showPaymentInfo(item)" v-for="item of memberPayWayList" :key="item.paymentType"> <span> <img src="../../assets/images/trade/icon-wechat2.png" v-if="item.paymentType == 1"> <img src="../../assets/images/trade/icon-alipay2.png" v-if="item.paymentType == 2"> <img src="../../assets/images/trade/icon-bankpayicon2.png" v-if="item.paymentType == 3"> <span class="one-body-bank">{{item.paymentTypeStr}}</span> </span> </button>
<!--收款信息--> <div class="collection-information" v-if="showPayment"> <!--银行卡--> <div class="bank-card"> <div class="account_info"> <span class="account_info_span">{{$t('姓名')}}:</span> <span>{{paymentInfo.realName}}</span> <div class="account-copy" v-clipboard:copy="paymentInfo.realName" v-clipboard:success="copySuccess">{{$t('复制')}}</div> </div> <div class="account_info" v-if="paymentInfo.paymentType == 3"> <span class="account_info_span">{{$t('开户行')}}:</span> <span>{{paymentInfo.remark}}</span> <div class="account-copy" v-clipboard:copy="paymentInfo.remark" v-clipboard:success="copySuccess">{{$t('复制')}}</div> </div> <div class="account_info" v-if="paymentInfo.paymentType == 3"> <span class="account_info_span">{{$t('银行卡号')}}:</span> <span>{{paymentInfo.account}}</span> <div class="account-copy" v-clipboard:copy="paymentInfo.account" v-clipboard:success="copySuccess">{{$t('复制')}}</div> </div> <div class="account_info" v-if="paymentInfo.paymentType != 3"> <span class="account_info_span">{{$t('账号')}}:</span> <span>{{paymentInfo.account}}</span> <div class="account-copy" v-clipboard:copy="paymentInfo.account" v-clipboard:success="copySuccess">{{$t('复制')}}</div> </div> <div class="account_info" v-if="paymentInfo.paymentType != 3"> <span class="account_info_span">{{$t('付款二维码')}}:</span> <span><img :src="paymentInfo.img" style="width: 100%;"></span> <a :href="paymentInfo.img" target="_blank" class="account-copy">{{$t('看大图')}}</a> </div> </div> </div>
<div class="one-body-notice">※ {{$t('使用微信、支付宝、银行卡转账时,请不要添加任何备注内容! 否则可能会被支付系统拦截')}}</div> </div> </div>
<div class="info-left-one" v-if="orderDetails.dealType == 'E_I_D_T_SELL' && orderDetails.status == 'M_O_F_S_WAIT_PASS' && !orderDetails.appeal"> <div class="chat-title"> <span class="chat-m">{{$t('买家')}}:</span> <img class="chat-title-headimg" src="../../assets/images/user-head-img.png"> <span class="chat-title-nickname co-nickname">{{orderDetails.dealUserIdentity}}</span> <div class="merchants-tag"> <img src="../../assets/images/trade/icon-authentication.png"> <span class="hc-color">{{($t('认证商家'))}}</span> </div> </div> <div class="confirm-price"> <div class="confirm-price-t"> <span>{{$t('查收买家付款')}}</span> <h1 class="hc-color1">¥{{orderDetails.inAmount}}</h1> </div> <div class="confirm-price-t"> <div class="confirm-price-text"> <ul> <li> <span>{{$t('付款留言:')}}</span>{{payMessage ? payMessage : '无'}} </li> </ul> </div> </div> <div class="one-body-notice">※ 请务必登录收款账户确认到账明细,避免因错误点击放行造成财产损失。</div> </div> </div> <div class="info-left-two"> <div class="two-title"> <div class="order-title-seven order-title" v-if="!orderDetails.appeal"> <!-- 已取消 --> <p class="is-center" v-if="orderDetails.dealType == 'E_I_D_T_BUY' && orderDetails.status == 'M_O_F_S_CANCEL'">{{$t('该订单已经取消,请勿再执行任何转帐行为')}}</p> <p class="is-center" v-if="orderDetails.dealType == 'E_I_D_T_SELL' && orderDetails.status == 'M_O_F_S_CANCEL'">{{$t('该订单已经取消')}}</p>
<!-- 买家 待付款 --> <p v-if="orderDetails.dealType == 'E_I_D_T_BUY' && orderDetails.status == 'M_O_F_S_WAIT_PAY'"> {{$t('付款时间剩余')}}<span>{{countDown | countDown}}</span>{{$t(',逾期订单将自动取消,请及时付款并点击标记付款')}} </p> <!-- 卖家 待付款 --> <p v-if="orderDetails.dealType == 'E_I_D_T_SELL' && orderDetails.status == 'M_O_F_S_WAIT_PAY'"> {{$t('付款时间剩余')}}<span>{{countDown | countDown}}</span>{{$t(',逾期订单将自动取消,等待买家付款')}} </p> <!-- 买家 待放行 --> <p class="is-center" v-if="orderDetails.dealType == 'E_I_D_T_BUY' && orderDetails.status == 'M_O_F_S_WAIT_PASS'"> {{orderDetails.inCoin}} {{$t('将持续由系统锁定托管')}}<br>{{$t('待放行剩余时间')}}<span>{{countDown | countDown}}</span> </p> <!-- 卖家 待放行 --> <p class="is-center" v-if="orderDetails.dealType == 'E_I_D_T_SELL' && orderDetails.status == 'M_O_F_S_WAIT_PASS'"> {{$t('请务必查收到账账户再确认收款')}}<br>{{$t('待放行剩余时间')}}<span>{{countDown | countDown}}</span> </p> <!-- 已完成 --> <p class="is-center" v-if="orderDetails.status == 'M_O_F_S_FINISH'">{{$t('已完成交易')}}</p> </div> <div class="order-title-seven order-title" v-if="orderDetails.appeal"> <p class="is-center">{{$t('此订单已经入申诉状态,请耐心等待客服介入处理')}}</p> </div> </div>
<div class="tips two-body"> <div class="tips-seven" v-if="!orderDetails.appeal"> <!-- 已取消 --> <div class="tips-body" v-if="orderDetails.status == 'M_O_F_S_CANCEL'"> <button class="el-button el-button3 cursor-no"> <span>{{$t('订单已取消')}}</span> </button> </div>
<!-- 买家 待付款 --> <div class="tips-body" v-if="orderDetails.dealType == 'E_I_D_T_BUY' && orderDetails.status == 'M_O_F_S_WAIT_PAY'"> <button type="button" class="el-button el-button2" @click="confirmPay"> <span>{{$t('标记付款已完成')}}</span> </button> <button type="button" class="el-button complete" @click="cancleOrder"> <span>{{$t('取消交易')}}</span> </button> </div> <!-- 卖家 待付款 --> <div class="tips-body" v-if="orderDetails.dealType == 'E_I_D_T_SELL' && orderDetails.status == 'M_O_F_S_WAIT_PAY'"> <button type="button" class="el-button el-button2 cursor-no"> <span>{{$t('等待买家付款')}}</span> </button> <button type="button" class="el-button complete" @click="cancleOrder"> <span>{{$t('取消交易')}}</span> </button> </div> <!-- 买家 待放行 --> <div class="tips-body" v-if="orderDetails.dealType == 'E_I_D_T_BUY' && orderDetails.status == 'M_O_F_S_WAIT_PASS'"> <button type="button" class="el-button el-button3 cursor-no"> <span>{{$t('已标记付款,请等待卖家核实后释放数字币')}}</span> </button> <button type="button" class="el-button complete" @click="openAppeal"> <span>{{$t('我要申诉')}}</span> </button> </div> <!-- 卖家 待放行 --> <div class="tips-body" v-if="orderDetails.dealType == 'E_I_D_T_SELL' && orderDetails.status == 'M_O_F_S_WAIT_PASS'"> <button type="button" @click="confirmPass" class="el-button el-button3 hc-color4"> <span>{{$t('确认收款并放行')}}</span> </button> <button type="button" class="el-button complete" @click="openAppeal"> <span>{{$t('我要申诉')}}</span> </button> </div> <!-- 买家 已完成 --> <div class="tips-body" v-if="orderDetails.dealType == 'E_I_D_T_BUY' && orderDetails.status == 'M_O_F_S_FINISH'"> <button type="button" class="el-button el-button3 cursor-no"> <span>{{$t('数字货币已转到你的账户')}}</span> </button> <button type="button" class="el-button complete"> <span>{{$t('查看账户')}}</span> </button> </div> <!-- 买家 已完成 --> <div class="tips-body" v-if="orderDetails.dealType == 'E_I_D_T_SELL' && orderDetails.status == 'M_O_F_S_FINISH'"> <button type="button" class="el-button el-button3 cursor-no"> <span>{{$t('数字货币已转到买家的账户')}}</span> </button> <button type="button" class="el-button complete"> <span>{{$t('查看账户')}}</span> </button> </div> </div> <div class="tips-text" v-if="orderDetails.appeal"> <h3 class="apeal-text">{{$t('申诉订单处理中')}}...</h3> </div> </div> </div> </div> <!-- 买家 待付款 --> <div class="person-info-right" v-if="orderDetails.dealType == 'E_I_D_T_BUY' && orderDetails.status == 'M_O_F_S_WAIT_PAY' && !orderDetails.appeal"> <div class="chat"> <div class="chat-title"> <span class="chat-title-nickname co-nickname">{{$t('上传付款截图')}}</span> </div> <div class="chat-body-div"> <div class="title-tips">{{$t('选择付款方式')}}</div> <div class="address-form-input choose-payment"> <el-select v-model="payTypeText" @change="choosePayment"> <el-option v-for="(item, index) in paymentList" :key="index" :label="item.label" :value="item.value"> </el-option> </el-select> </div> <div class="title-tips">{{$t('备注')}}</div> <div class="address-form-input"> <el-input :placeholder="$t('请输入备注')" v-model="payRemark" type="text" clearable autocomplete="off" @keyup.enter.native="submitPay"> </el-input> </div> <div class="title-tips">{{$t('请上传付款凭证')}}</div> <div class="upload-photo" :class="{'hide': payImage}"> <el-upload :action="this.common.baseURL+'/user/api/file/image'" :headers="{'Authorization': 'Bearer '+this.common.getItem(common.tokenKey)}" list-type="picture-card" accept="image/jpeg,image/gif,image/png" :file-list="fileList" :on-success="uploadSuccess" :on-error="uploadError" :on-remove="uploadDelete" > <i class="el-icon-plus"></i> </el-upload> </div> <div class="pay-submit"> <el-button type="primary" :loading="true" v-if="upload">{{$t('提交中...')}}</el-button> <el-button type="primary" @click="submitPay" v-else>{{$t('提交')}}</el-button> </div> </div>
</div> </div> <!-- 买家 待放行 --> <div class="person-info-right" v-if="orderDetails.dealType == 'E_I_D_T_SELL' && orderDetails.status == 'M_O_F_S_WAIT_PASS' && !orderDetails.appeal"> <div class="chat"> <div class="chat-title"> <span class="chat-title-nickname co-nickname">买家付款截图</span> </div> <div class="chat-body-div"> <a :href="payVoucher" target="_blank"> <img :src="payVoucher" style="max-width: 100%;"> </a> </div> </div> </div> </div> </div> </div> </div> <!-- 申诉的弹窗 --> <el-dialog class="user-dialog" :title="$t('订单申诉')" :visible.sync="showAppeal" :before-close="closeAppeal"> <div class="title-tips">{{$t('申诉理由')}}</div> <div class="address-form-input choose-payment"> <el-select v-model="reasonCodeText" @change="chooseReason"> <el-option v-for="(item, index) in reasonList" :key="index" :label="item.label" :value="item.value"> </el-option> </el-select> </div> <div class="title-tips">{{$t('申诉内容')}}</div> <div class="address-form-input"> <el-input :placeholder="$t('请输入申诉内容')" v-model="appealContent" type="text" clearable autocomplete="off" @keyup.enter.native="submitAppeal"> </el-input> </div> <div class="title-tips">{{$t('上传问题截图')}}</div> <div class="upload-photo"> <el-upload :action="this.common.baseURL+'/user/api/file/image'" :headers="{'Authorization': 'Bearer '+this.common.getItem(common.tokenKey)}" list-type="picture-card" accept="image/jpeg,image/gif,image/png" :file-list="fileList" :on-success="uploadSuccess2" :on-error="uploadError" :on-remove="uploadDelete2" > <i class="el-icon-plus"></i> </el-upload> </div> <span slot="footer" class="dialog-footer"> <el-button type="primary" :loading="true" v-if="appealLoading">{{$t('提交中...')}}</el-button> <el-button type="primary" @click="submitAppeal" v-else>{{$t('确定')}}</el-button> </span> </el-dialog> </div></template>
<script> let count; //全局定义倒计时
export default { name: 'currencyOrderDetails', data() { return { id: '', //订单id
orderDetails: {}, //订单详情
dealerInfo: {}, //交易方信息
memberPayWayList: [], //支付方式
showPayment: false, paymentInfo: {}, payVoucher: '', //付款凭证
payMessage: '', //付款留言
fileList: [], //上传插件 上传图片列表
payTypeText: '选择付款方式', //付款方式
payType: '', //付款方式
payImage: '', //付款截图
payRemark: '', //付款留言
upload: false, //上传按钮
showAppeal: false, //申诉弹窗
reasonList: [], //申诉理由列表
reasonCodeText: '请选择理由', reasonCode: '', //申诉选择的理由
appealContent: '', //申诉内容
fileIds: [], //上传图片列表
appealLoading: '', //提交申诉按钮
countDown: 0, //倒计时时间
} }, computed: { paymentList() { let list = []; this.memberPayWayList.forEach(item => { list.push({ value: item.paymentType, label: item.paymentTypeStr }) }); return list; } }, methods: { getDetails() { //获取订单详情
this.getAxios('/api/market/order/flow/detail/' + this.id) .then(data => { if (data.data.cancel) { //取消
this.orderDetails = data.data.cancel.flowBaseInfo; }
if (data.data.obligation) { //待付款
this.orderDetails = data.data.obligation.flowBaseInfo; this.timer(data.data.obligation.seconds);
let list = data.data.obligation.userPaymentVoList; this.memberPayWayList = list; }
if (data.data.release) { //待放行
this.orderDetails = data.data.release.flowBaseInfo; if (data.data.release.paymentVoucherImg) { this.payVoucher = data.data.release.paymentVoucherImg; } this.payMessage = data.data.release.remark; this.timer(data.data.release.seconds); }
if (data.data.complaining) { //申诉中
this.orderDetails = data.data.complaining.flowBaseInfo; }
if (data.data.finish) { //已完成
this.orderDetails = data.data.finish.flowBaseInfo; }
setTimeout(() => { this.getDealerInfo(this.orderDetails.dealUserId); }, 300) }) }, getDealerInfo(id) { //获取交易对象的信息
this.postAxios('/api/market/order/business/info/' + id) .then(data => { this.dealerInfo = data.data; }) }, getReasonList() { //获取申诉理由
this.getAxios('/api/user/appeal/reason/list') .then(data => { let list = data.data; list.forEach(item => { this.reasonList.push({ value: item.reasonCode, label: item.reasonStr }) }); }) }, timer(seconds) { //倒计时
//剩余时间(秒)
this.countDown = seconds; //倒计时时间
count = setInterval(() => { //开始倒计时
this.countDown--; if (this.countDown == 0) { clearInterval(count); setTimeout(() => { this.getDetails(); }, 1000); } }, 1000); },
showPaymentInfo(item) { //查看支付方式
this.showPayment = !this.showPayment; console.log(this.showPayment) this.paymentInfo = item; }, copySuccess() { this.$message.success(this.$t('复制成功!')); }, choosePayment(value) { //选择付款方式
this.payType = value; }, chooseReason(value) { //选择申诉理由
this.reasonCode = value; }, //图片组件
uploadSuccess(res) { this.payImage = res.data }, uploadSuccess2(res) { this.fileIds.push(res.data); }, uploadDelete() { this.payImage = ''; }, uploadDelete2() { }, uploadError(err) { //上传失败
console.log(JSON.stringify(err)) },
//订单操作
submitPay() { //上传付款凭证
if(this.upload) { return; } if(!this.payType) { this.$message.error(this.$t('请选择付款方式!')); return; } if(!this.payImage) { this.$message.error(this.$t('请上传付款凭证!')); return; } this.upload = true; let params = { flowId: this.id, paymentType: this.payType, fileImg: this.payImage, remark: this.payRemark } this.postAxios('/api/market/order/upload/payment', params) .then(() => { this.$message.success(this.$t('支付凭证上传成功,请点击确认付款按钮完成支付!')); this.upload = false; }) .catch(() => { this.upload = false; }) }, confirmPay() { //标记为已支付
this.$confirm(this.$t('恶意点击将冻结帐户!您确定要标记为已支付吗?'), this.$t('提示'), { cancelButtonText: this.$t('取消'), confirmButtonText: this.$t('确定'), type: 'warning' }) .then(() => { this.putAxios('/api/market/order/confirm/play/' + this.id) .then(() => { this.$message.success('成功标记订单为已支付!'); setTimeout(() => { this.getDetails(); }, 800); }) }) }, confirmPass() { //确认放行
this.$confirm(this.$t('请务必登录收款账户确认到账明细,避免因错误点击放行造成财产损失。'), this.$t('提示'), { cancelButtonText: this.$t('取消'), confirmButtonText: this.$t('确定放行'), type: 'warning' }) .then(() => { this.putAxios('/api/market/order/confirm/release/' + this.id) .then(() => { this.$message.success('放行成功!'); setTimeout(() => { this.getDetails(); }, 800); }) }) }, cancleOrder() { //取消订单
this.$confirm(this.$t('您是否确定取消订单?取消的订单无法恢复!'), this.$t('提示'), { cancelButtonText: this.$t('取消'), confirmButtonText: this.$t('确定'), type: 'warning' }) .then(() => { this.putAxios('/api/market/order/cancel/' + this.id) .then(() => { this.$message.success('订单取消成功!'); setTimeout(() => { this.getDetails(); }, 800); }) }) }, openAppeal() { //打开申诉
this.getReasonList(); this.showAppeal = true; }, submitAppeal() { //提交申诉
if(this.appealLoading) { return; } if(!this.reasonCode) { this.$message.error(this.$t('请选择申诉理由!')); return; } if(!this.appealContent) { this.$message.error(this.$t('请输入申诉内容!')); return; } this.appealLoading = true; let params = { flowId: this.id, reasonCode: this.reasonCode, content: this.appealContent, fileIds: this.fileIds } this.postAxios('/api/user/appeal/submit', params) .then(() => { this.$message.success('申诉成功,请耐心等待申诉结果!'); setTimeout(() => { this.closeAppeal(); this.getDetails(); }, 800) }) .catch(() => { this.loading = false; }) }, closeAppeal() { //关闭申诉
this.showAppeal = false; //清除数据
this.appealContent = ''; this.reasonCode = ''; this.fileIds = []; this.fileList = []; }, }, created() { this.id = this.$route.params.id; this.getDetails(); } }</script>
<style scoped> .pay-submit{ width: 100%; clear: both; padding-top: 20px; } .apeal-text { font-size: 14px; color: #8488f5; text-align: center; padding: 30px 0; }</style>
|