|  |  |  | 
|---|
|  |  |  | .ibox-content { | 
|---|
|  |  |  | background-color: rgba(240, 242, 245, 1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | label { | 
|---|
|  |  |  | .aside label { | 
|---|
|  |  |  | width: 100%; | 
|---|
|  |  |  | margin: 5px 0 !important; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | </head> | 
|---|
|  |  |  | <div class="ibox-content" id="app"> | 
|---|
|  |  |  | <el-container> | 
|---|
|  |  |  | <el-aside style="width: 300px; background-color: white; padding: 10px;"> | 
|---|
|  |  |  | <el-aside class="aside" style="width: 300px; background-color: white; padding: 10px;"> | 
|---|
|  |  |  | <el-row style="border-bottom: #E4E7ED 1px solid;"> | 
|---|
|  |  |  | <el-col :span="20" style="padding: 10px;"> | 
|---|
|  |  |  | <el-row type="flex" align="middle"> | 
|---|
|  |  |  | 
|---|
|  |  |  | <label style="font-size: 14px;">应收金额</label> | 
|---|
|  |  |  | <label>欠款</label> | 
|---|
|  |  |  | <label>已还</label> | 
|---|
|  |  |  | <label>退款</label> | 
|---|
|  |  |  | <label v-if="order.refund != 0">退款</label> | 
|---|
|  |  |  | </el-col> | 
|---|
|  |  |  | <el-col :span="14" style="text-align: right;"> | 
|---|
|  |  |  | <label>¥ {{order.total}}</label> | 
|---|
|  |  |  | 
|---|
|  |  |  | <label>¥ {{order.zkTotal}}</label> | 
|---|
|  |  |  | <label>¥ {{order.arrears}}</label> | 
|---|
|  |  |  | <label>¥ {{order.repay}}</label> | 
|---|
|  |  |  | <label>¥ {{order.refund}}</label> | 
|---|
|  |  |  | <label v-if="order.refund != 0">¥ {{order.refund}}</label> | 
|---|
|  |  |  | </el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | </el-col> | 
|---|
|  |  |  | 
|---|
|  |  |  | <el-tabs v-model="activeName" @tab-click="handleClick"> | 
|---|
|  |  |  | <el-tab-pane label="订单明细" name="first"> | 
|---|
|  |  |  | <el-row> | 
|---|
|  |  |  | <el-button size="mini" type="primary" @click="openPayMoneyDialog" v-if="isRefund">提交退款</el-button> | 
|---|
|  |  |  | <el-button size="mini" type="primary" @click="openPayMoneyDialog" v-if="isRefund">提交退款<span v-if="totalRefund"> ¥ {{totalRefund}}</span></el-button> | 
|---|
|  |  |  | <el-button size="mini" type="danger" @click="isRefund = false" v-if="isRefund">取消</el-button> | 
|---|
|  |  |  | <el-button size="mini" type="primary" @click="isRefund = true" v-if="order.statu == '已付款' && !isRefund">退款</el-button> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column label="退款单价"> | 
|---|
|  |  |  | <template slot-scope="scope"> | 
|---|
|  |  |  | <el-input v-model="scope.row.refundPrice" v-if="scope.row.count > 0"></el-input> | 
|---|
|  |  |  | <el-input @change="calRefund" v-model="scope.row.refundPrice" v-if="scope.row.count > 0"></el-input> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column label="退款数量"> | 
|---|
|  |  |  | <template slot-scope="scope"> | 
|---|
|  |  |  | <el-input v-model.number="scope.row.refundCount" v-if="scope.row.count > 0"></el-input> | 
|---|
|  |  |  | <el-input @change="calRefund" v-model.number="scope.row.refundCount" v-if="scope.row.count > 0"></el-input> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column label="是否退库存" align="center"> | 
|---|
|  |  |  | 
|---|
|  |  |  | width="300"> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | prop="createTime" | 
|---|
|  |  |  | label="交易时间"> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | prop="flowType" | 
|---|
|  |  |  | label="交易类型"> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | 
|---|
|  |  |  | @check="(click, checked,$item)=>{handleCheckChange(click, checked,$item)}" | 
|---|
|  |  |  | :props="defaultProps"> | 
|---|
|  |  |  | </el-tree> | 
|---|
|  |  |  | <li :class="{active : item.isActive}" slot="reference" @click="payMethodSelect(item, index)"><div style="line-height: 30px;"><img style="width: 25px; height: 25px;" :src="item.img"><span style="line-height: 30px; margin-left: 5px;">{{item.value}}</span></div></li> | 
|---|
|  |  |  | <li :class="{active : item.isActive}" slot="reference" @click="payMethodSelect(item, index)"><div style=" height:30px; line-height: 30px; display: flex; align-items: center"><img style="width: 25px; height: 25px; align-items: center;" :src="item.img"><span style="margin-left: 5px;">{{item.value}}</span></div></li> | 
|---|
|  |  |  | </el-popover> | 
|---|
|  |  |  | </span> | 
|---|
|  |  |  | </ul> | 
|---|
|  |  |  | 
|---|
|  |  |  | payMethodItems : [], | 
|---|
|  |  |  | isRefund : false, | 
|---|
|  |  |  | isReturnAchieve : false, | 
|---|
|  |  |  | totalRefund : "", | 
|---|
|  |  |  | payMethods: [{ | 
|---|
|  |  |  | value: '现金支付', | 
|---|
|  |  |  | img: '/images/pay/cash.png', | 
|---|
|  |  |  | 
|---|
|  |  |  | type: '储值卡' | 
|---|
|  |  |  | }, ], | 
|---|
|  |  |  |  | 
|---|
|  |  |  | dialogSettleVisible : true, | 
|---|
|  |  |  | dialogSettleVisible : false, | 
|---|
|  |  |  | moneyCards: [], | 
|---|
|  |  |  | defaultProps: { | 
|---|
|  |  |  | children: 'children', | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | methods : { | 
|---|
|  |  |  | calRefund() { | 
|---|
|  |  |  | let _this = this; | 
|---|
|  |  |  | var total = 0; | 
|---|
|  |  |  | _this.orderItems.forEach(item => { | 
|---|
|  |  |  | if (item.refundPrice && item.refundCount) { | 
|---|
|  |  |  | total += parseFloat(item.refundPrice * item.refundCount); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _this.totalRefund = total; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | queryOrderDetailData(param) { | 
|---|
|  |  |  | let _this = this; | 
|---|
|  |  |  | AjaxProxy.requst({ | 
|---|
|  |  |  | 
|---|
|  |  |  | this.$message.warning("输入付款总金额与应付金额不符"); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(_this.order.zkTotal - _this.order.refund - _this.order.arrears < total) { | 
|---|
|  |  |  | this.$message.warning("退款金额不能超过收款金额"); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | _this.data.flows = flows; | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | Vue.set(item,'isActive',true); | 
|---|
|  |  |  | var hasAmount = 0; | 
|---|
|  |  |  | for(var i = 0; i < payMoneys.length; i++) { | 
|---|
|  |  |  | hasAmount += parseFloat(payMoneys[i].money); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (_this.refundMoney - hasAmount > 0) { | 
|---|
|  |  |  | Vue.set(item, 'money', _this.refundMoney - hasAmount); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | _this.payMoneys.push(item); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|