From 39b5aa730edf14c9215935a5fc836be8e8345e1c Mon Sep 17 00:00:00 2001
From: 935090232@qq.com <ak473600000>
Date: Tue, 26 Jan 2021 21:20:54 +0800
Subject: [PATCH] 划扣bug
---
 zq-erp/src/main/resources/templates/views/admin/hive/beautySalon/order-form.html |  208 +++++++++++++++++++++++++++++++++------------------
 1 files changed, 135 insertions(+), 73 deletions(-)
diff --git a/zq-erp/src/main/resources/templates/views/admin/hive/beautySalon/order-form.html b/zq-erp/src/main/resources/templates/views/admin/hive/beautySalon/order-form.html
index b4928db..5d91b37 100644
--- a/zq-erp/src/main/resources/templates/views/admin/hive/beautySalon/order-form.html
+++ b/zq-erp/src/main/resources/templates/views/admin/hive/beautySalon/order-form.html
@@ -382,7 +382,7 @@
             title="业绩设置"
             :visible.sync="drawer"
             :direction="direction"
-            size="50%"
+            size="90%"
     >
         <el-row>
             <el-col :span="24">
@@ -516,7 +516,7 @@
                 <el-row style="line-height: 50px;" v-for="(item, index) in payMoneys">
                     <el-col :span="6" style="text-align: right; padding-right: 10px; font-size: 12px;">{{item.value}}</el-col>
                     <el-col :span="8"><el-input v-model="item.money"></el-input></el-col>
-                    <el-col :span="6" style="margin-left: 10px;" v-if="item.type == '储值卡'">{{item.isGift == 1 ? '赠送余额' : '余额' }}:<span class="arrears">¥ {{item.balance}}</span></el-col>
+                    <el-col :span="8" style="margin-left: 10px;" v-if="item.type == '储值卡'">{{item.isGift == 1 ? '赠送余额' : '余额' }}:<span class="arrears">¥ {{item.balance}}</span></el-col>
                 </el-row>
             </el-col>
         </el-row>
@@ -558,6 +558,7 @@
             direction: 'rtl',
             //当前登录用户
             loginUser: {},
+            staffUser:{},
             //业绩用户列表
             userList: [],
             order: {
@@ -655,64 +656,7 @@
         created: function () {
             let _this = this;
 
-            //获取登录用户信息
-            AjaxProxy.requst({
-                app: _this,
-                url: basePath + '/admin/getLoginUser',
-                callback: function (data) {
-                    _this.loginUser = data.mapInfo.user;
-
-                    if (id) {
-                        //加载订单信息
-                        AjaxProxy.requst({
-                            app: _this,
-                            url: basePath + '/admin/order/findOrderById/' + id,
-                            callback: function (data) {
-                                _this.order = data.rows[0];
-                                //修改支付金额
-                                _this.changeVip(_this.order.vipId);
-                                let items = _this.order.items;
-                                let orderPayMoney = 0;
-                                //设置欠款订单设置欠款金额等于支付金额,非欠款订单设置折扣金额等于支付金额
-                                items.forEach(item => {
-                                    if (item.arrears > 0) {
-                                        item.payMoney = item.arrears;
-                                    } else {
-                                        item.payMoney = item.zkPrice;
-                                    }
-                                    orderPayMoney += item.payMoney;
-                                    item.uuid = MTools.uuid();
-                                    //业绩设置
-                                    _this.achieveList.push({
-                                        orderItem: item,
-                                        staff: _this.loginUser,
-                                        saleId: _this.loginUser.suId,
-                                        achieveMoney: item.payMoney,
-                                        commission : 0,
-                                        t3 : '现金业绩',
-                                        isShare: false,
-                                    });
-                                });
-                                _this.order.payMoney = orderPayMoney;
-                            }
-                        });
-
-                    } else {
-                        //获取门店信息
-                        AjaxProxy.requst({
-                            app: _this,
-                            url: basePath + '/admin/shopInfo/findUserShop',
-                            callback: function (data) {
-                                _this.order.shopName = data.rows[0].shopName;
-
-                            }
-                        });
-                    }
-
-
-                }
-            });
-
+            _this.initMethod()
             if (vipId) {
                 _this.changeVip(vipId);
             }
@@ -728,6 +672,76 @@
         },
 
         methods: {
+            initMethod() {
+                let _this = this;
+
+                //获取登录用户信息
+                AjaxProxy.requst({
+                    app: _this,
+                    url: basePath +  '/admin/getLoginUser',
+                    callback: function (data) {
+                        _this.loginUser = data.mapInfo.user;
+
+                        if (id) {
+                            //加载订单信息
+                            AjaxProxy.requst({
+                                app: _this,
+                                url: basePath + '/admin/order/findOrderById/' + id,
+                                callback: function (data) {
+                                    _this.order = data.rows[0];
+                                    //修改支付金额
+                                    _this.changeVip(_this.order.vipId);
+
+                                    AjaxProxy.requst({
+                                        app: _this,
+                                        url: basePath + '/admin/getUserById?id='+_this.order.staffId,
+                                        callback: function (data) {
+                                            _this.staffUser = data.mapInfo.user;
+
+                                            let items = _this.order.items;
+                                            let orderPayMoney = 0;
+                                            //设置欠款订单设置欠款金额等于支付金额,非欠款订单设置折扣金额等于支付金额
+                                            items.forEach(item => {
+                                                if (item.arrears > 0) {
+                                                    item.payMoney = item.arrears;
+                                                } else {
+                                                    item.payMoney = item.zkPrice;
+                                                }
+                                                orderPayMoney += item.payMoney;
+                                                item.uuid = MTools.uuid();
+                                                //业绩设置
+                                                _this.achieveList.push({
+                                                    orderItem: item,
+                                                    staff: _this.staffUser,
+                                                    saleId: _this.staffUser.suId,
+                                                    achieveMoney: item.payMoney,
+                                                    commission : 0,
+                                                    t3 : '现金业绩',
+                                                    isShare: false,
+                                                });
+                                            });
+                                            _this.order.payMoney = orderPayMoney;
+                                        }
+                                    });
+                                }
+                            });
+
+                        } else {
+                            //获取门店信息
+                            AjaxProxy.requst({
+                                app: _this,
+                                url: basePath + '/admin/shopInfo/findUserShop',
+                                callback: function (data) {
+                                    _this.order.shopName = data.rows[0].shopName;
+
+                                }
+                            });
+                        }
+
+
+                    }
+                });
+            },
 
             //取消订单
             closeFram() {
@@ -821,17 +835,29 @@
                     }
                     item.count = 1;
 
-
-                    //加入业绩
-                    this.achieveList.push({
-                        orderItem: item,
-                        staff: this.loginUser,
-                        saleId: this.loginUser.suId,
-                        achieveMoney: item.payMoney,
-                        t3 : '现金业绩',
-                        commission : 0,
-                        isShare: false,
-                    });
+                    if (this.staffUser.suId) {
+                        //加入业绩
+                        this.achieveList.push({
+                            orderItem: item,
+                            staff: this.staffUser,
+                            saleId: this.staffUser.suId,
+                            achieveMoney: item.payMoney,
+                            t3: '现金业绩',
+                            commission: 0,
+                            isShare: false,
+                        });
+                    } else {
+                        //加入业绩
+                        this.achieveList.push({
+                            orderItem: item,
+                            staff: this.loginUser,
+                            saleId: this.loginUser.suId,
+                            achieveMoney: item.payMoney,
+                            t3: '现金业绩',
+                            commission: 0,
+                            isShare: false,
+                        });
+                    }
                     this.order.items.push(item);
                 }
 
@@ -873,7 +899,14 @@
                                     item.payMoney = zkPrice * count;
                                 }
                                 _this.order.payMoney += parseFloat(item.payMoney);
+
+                                _this.achieveList.forEach(achieve=>{
+                                    if(achieve.orderItem==item){
+                                        achieve.achieveMoney=item.payMoney;
+                                    }
+                                })
                             });
+                            _this.order.payMoney = _this.order.payMoney.toFixed(2);
                             //计算欠款
                             // _this.order.arrears = _this.order.zkTotal - _this.order.payMoney;
                             // if (_this.order.arrears < 0) {
@@ -951,17 +984,30 @@
                             }
                             if (item.uuid == achieve.orderItem.uuid) {
                                 let achieveNew = {
+                                    uuid:item.uuid,
                                     beaultId: achieve.saleId,
                                     t1: achieve.achieveMoney,
                                     t3: achieve.t3,
                                     projPercentage: achieve.commission,
                                 };
-                                item.achaeveList.push(achieveNew);
+
+                                var flag = true;
+                                for(var j = 0; j < item.achaeveList.length; j++) {
+                                    if(item.achaeveList[j].uuid == achieveNew.uuid && item.achaeveList[j].beaultId == achieveNew.beaultId) {
+                                        flag = false;
+                                        break;
+                                    }
+                                }
+
+                                if (flag) {
+                                    item.achaeveList.push(achieveNew);
+                                }
                                 break;
                             }
                         }
                     })
 
+                    console.log(_this.order);
                     //校验业绩金额
                     if (_this.checkAchieve()) {
                         let url = basePath + "/admin/order/payOrder";
@@ -981,8 +1027,16 @@
                                 if (submitType == 1) {
                                     if (_this.printPaper) {
                                         _this.print();
+                                    } else {
+                                        _this.$message.success({
+                                            message : data.info,
+                                            duration : 1000,
+                                            onClose() {
+                                                _this.closeFram();
+                                            }
+                                        });
                                     }
-                                    _this.closeFram();
+
                                     // _this.$confirm('结算成功,是否立刻打印小票?', '提示', {
                                     //     confirmButtonText: '打印',
                                     //     cancelButtonText: '取消',
@@ -996,6 +1050,7 @@
                                 } else {
                                     _this.$message.success(data.info);
                                 }
+
                                 if(parent.myGrid) {
                                     parent.myGrid.serchData();
                                 }
@@ -1222,6 +1277,13 @@
                             }
                         } else {
                             Vue.set(item,'isActive',true);
+                            var hasAmount = 0;
+                            for(var i = 0; i < payMoneys.length; i++) {
+                                hasAmount += parseFloat(payMoneys[i].money);
+                            }
+                            if (_this.order.payMoney - hasAmount > 0) {
+                                Vue.set(item, 'money', _this.order.payMoney - hasAmount);
+                            }
                             _this.payMoneys.push(item);
                         }
                     });
--
Gitblit v1.9.1