From 84d9de8968ea6675ecb57fa7c59a7bf2fede8f4d Mon Sep 17 00:00:00 2001
From: zuozhengqing <a13193816592@163.com>
Date: 星期三, 06 十二月 2023 16:45:44 +0800
Subject: [PATCH] 采购管理新增和编辑时供应商是否可以提供当前产品提示优化

---
 src/views/purchaseManage/purchase/components/AddPurchase.vue |  170 +++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 142 insertions(+), 28 deletions(-)

diff --git a/src/views/purchaseManage/purchase/components/AddPurchase.vue b/src/views/purchaseManage/purchase/components/AddPurchase.vue
index b29c0e1..a69d2d1 100644
--- a/src/views/purchaseManage/purchase/components/AddPurchase.vue
+++ b/src/views/purchaseManage/purchase/components/AddPurchase.vue
@@ -125,6 +125,8 @@
                     :disabled="editConfig.isDisabled"
                     v-model="editConfig.infomation.phone"
                     placeholder="璇峰~鍐�"
+                    maxlength="11"
+                    show-word-limit
                     clearable
                   ></el-input>
                 </el-form-item>
@@ -185,6 +187,8 @@
               @addProductClick="addProductClick"
               @emptyProductClick="emptyProductClick"
               @clearupProduct="clearupProduct"
+              @rowClick="rowClick"
+              @handleProduct="handleProduct"
             />
           </div>
           <div class="table-bottom">
@@ -251,10 +255,10 @@
       </el-form>
       <div slot="footer" class="dialog-footer">
         <!-- <el-button type="primary" size="small" @click="editConfig.visible = false">淇濆苟鎻愪氦瀹℃壒</el-button> -->
-        <el-button type="primary" size="small" @click="saveClick('form')"
+        <el-button type="primary" v-if="this.editConfig.title != '鏌ョ湅'" size="small" @click="saveClick('form')"
           >淇濆瓨</el-button
         >
-        <el-button size="small" @click="editConfig.visible = false"
+        <el-button size="small" v-if="this.editConfig.title != '鏌ョ湅'" @click="editConfig.visible = false"
           >鍙栨秷</el-button
         >
       </div>
@@ -289,6 +293,7 @@
 } from "@/api/purchaseManage/purchase";
 
 import SelectSupplierDialog from "@/views/purchaseManage/purchase/components/SelectSupplierDialog";
+// import { formToJSON } from "axios";
 export default {
   name: "QuotationDialog",
   components: { SelectSupplierDialog, CommonFormTableView,BomDialog },
@@ -361,7 +366,8 @@
       },
       supplierId: this.editCommonConfig.infomation.supplierId,
       tableData: [],
-      productId: 1,
+      productIndex: 0,
+      productId:'',
       isNoProduct: true,
       clientList: [],
       plcBrandList:[],
@@ -370,6 +376,8 @@
       },
       total:0,
       totalTwo:0,
+      productListIdx:0,
+      lacks:[],
     };
   },
   created() {
@@ -511,22 +519,93 @@
             this.$message.error("浜у搧鍚嶇О涓嶈兘涓虹┖");
           } else {
             const params = this.saveParams();
+            //鏂板缓
             if (this.editConfig.title === "鍒涘缓") {
-              addPurchase(params).then((res) => {
-                this.editConfig.visible = false;
-                if (res.code === 200) {
-                  this.$message.success("娣诲姞鎴愬姛");
-                  this.$parent.getData();
+              this.lacks=[]
+              this.tableData.forEach((item)=>{
+                if(this.productTableList.tableProductList.map(obj => obj.number).includes(item.number)) {  
+                    console.log(`${item.name} 鍦ㄦ暟缁勪腑瀛樺湪`);  
+                } else {
+                  this.lacks.push(item.name)
                 }
-              });
+              })
+              if(this.lacks.length>0){
+                this.$confirm(`褰撳墠渚涘簲鍟嗕笉鑳芥彁渚涙偍閫夋嫨鐨勪骇鍝�:${this.lacks},    鏄惁缁х画鍒涘缓閲囪喘鍗�?`, '鎻愮ず', {
+                  confirmButtonText: '纭畾',
+                  cancelButtonText: '鍙栨秷',
+                  type: 'warning'
+                }).then(() => {
+                  console.log("纭畾鍒涘缓")
+                  //鍒涘缓閲囪喘鍗�
+                  addPurchase(params).then((res) => {
+                    this.editConfig.visible = false;
+                    if (res.code === 200) {
+                      this.$message.success("鍒涘缓鎴愬姛");
+                      this.$parent.getData();
+                    }
+                  });
+                }).catch(() => {
+                  console.log("鍙栨秷鍒涘缓")
+                });
+              }else{
+                addPurchase(params).then((res) => {
+                  this.editConfig.visible = false;
+                  if (res.code === 200) {
+                    this.$message.success("鍒涘缓鎴愬姛");
+                    this.$parent.getData();
+                  }
+                });
+              }
             } else {
-              updatePurchase(params).then((res) => {
-                this.editConfig.visible = false;
-                if (res.code === 200) {
-                  this.$message.success("缂栬緫鎴愬姛");
-                  this.$parent.getData();
+              // 缂栬緫
+              getProductList({
+                supplierId:this.editConfig.infomation.supplierId,
+                page:1,
+                pageSize:100
+              }).then((res)=>{
+                if(res.code===200){
+                  this.lacks=[]
+                  // 缂栬緫鍓嶅厛鐪嬬湅褰撳墠渚涘簲鍟嗗搴旂殑浜у搧鍒楄〃
+                  this.productTableList.tableProductList = res.data.list
+                  //褰撳墠浜у搧鏄惁鍦ㄥ綋鍓嶄緵搴斿晢涓嬪瓨鍦�
+                  this.tableData.forEach((item)=>{
+                    if(this.productTableList.tableProductList.map(obj => obj.number).includes(item.number)) {  
+                      console.log(`${item.name} 鍦ㄦ暟缁勪腑瀛樺湪`);  
+                    } else {
+                      this.lacks.push(item.name)
+                    }
+                  })
+                  // 涓嶅瓨鍦ㄧ殑浜у搧淇℃伅
+                  if(this.lacks.length>0){
+                    this.$confirm(`褰撳墠渚涘簲鍟嗕笉鑳芥彁渚涙偍閫夋嫨鐨勪骇鍝�:${this.lacks},    鏄惁缁х画鏇存柊閲囪喘鍗�?`, '鎻愮ず', {
+                      confirmButtonText: '纭畾',
+                      cancelButtonText: '鍙栨秷',
+                      type: 'warning'
+                    }).then(() => {
+                      console.log("纭畾鏇存柊")
+                      //鏇存柊閲囪喘鍗�
+                      updatePurchase(params).then((res) => {
+                        this.editConfig.visible = false;
+                        if (res.code === 200) {
+                          this.$message.success("鏇存柊鎴愬姛");
+                          this.$parent.getData();
+                        }
+                      });
+                    }).catch(() => {
+                      console.log("鍙栨秷鏇存柊")
+                    });
+                  }else {
+                    updatePurchase(params).then((res) => {
+                      this.editConfig.visible = false;
+                      if (res.code === 200) {
+                        this.$message.success("鏇存柊鎴愬姛");
+                        this.$parent.getData();
+                      }
+                    });
+                  }
                 }
-              });
+              })
+              
             }
           }
         } else {
@@ -562,6 +641,8 @@
           priceAdjustment:data.priceAdjustment?Number(data.priceAdjustment):0,
           realTotalPrice:this.total?Number(this.total):0,
           totalPrice:this.totalTwo?Number(this.totalTwo):0,
+          status:data.status,
+          quantity:data.quantity, // 閲囪喘鏁伴噺
         }
       };
       if(data.ID){
@@ -591,6 +672,7 @@
         );
       };
     },
+    // 閫夋嫨渚涘簲鍟�
     async handleSelectClient(value, item) {
       this.productTableList.supplierId=item.ID
       if (value === "client") {
@@ -611,15 +693,23 @@
     selClientClick() {
       this.editSelectSupplierConfig.editVisible = true;
     },
-    selClient(row) {
+    async selClient(row) {
+      await getProductList({
+        supplierId:row.ID,
+        page:1,
+        pageSize:100
+      }).then((res)=>{
+        if(res.code===200){
+          this.productTableList.tableProductList = res.data.list
+        }
+      })
       this.$set(this.editConfig.infomation,'supplierName',row.name)
       this.editConfig.infomation.contact = row.contact;
       this.editConfig.infomation.phone = row.phone;
-      this.supplierId = row.ID;
+      this.editConfig.infomation.supplierId = row.ID;
     },
     // 娓呴櫎宸查�夋嫨鐢ㄦ埛
     clearupClient(value) {
-      this.emptyProductClick()
       if (value == "client") {
         this.$set(this.editConfig.infomation, "supplierName", "");
         this.supplierId = null;
@@ -633,14 +723,21 @@
       ) {
         this.tableData = [
           {
+            purchaseId:0,
             productId: this.productId,
-            id: 0,
+            productIndex:this.productIndex,
             amount: 0,
-            desc: "",
             name: "",
             number: "",
             price: 0,
             total: 0,
+            remark:'',
+            unit:'',
+            purchasePrice:'',
+            deliveryTime:"",
+            shippingDuration:"",
+            specifications:"",
+            modelNumber:"",
           },
         ];
       } else {
@@ -683,13 +780,18 @@
     },
     // 浜у搧鍒楄〃杈撳叆
     inputContent(val, prop, row) {
-      this.productId = row.productId;
+      // this.productId = row.productId;
+      this.productIndex=row.productIndex;
+      let num=0
       this.tableData.map((item) => {
-        if (item.productId === row.productId) {
+        num+=item.amount
+        if (item.productIndex === row.productIndex) {
           item[prop] = val;
         }
       });
-     
+      if(prop==="amount"){
+        this.editConfig.infomation.quantity=num
+      }
     },
     getSummaries(total){
       this.totalTwo= JSON.parse(JSON.stringify(total));
@@ -717,9 +819,10 @@
     },
     // 浜у搧鏂板
     addProductClick() {
-      this.productId++;
+      this.productIndex++;
       this.tableData.push({
-        productId: this.productId,
+        productIndex: this.productIndex,
+        productId:'',
         id: 0,
         amount: 0,
         desc: "",
@@ -732,12 +835,13 @@
     },
     //  浜у搧娓呯┖
     emptyProductClick() {
-      this.productId = 1;
+      this.productIndex = 1;
       this.tableData = [
         {
-          productId: this.productId,
+          productId: '',
+          productIndex:this.productIndex,
           id: 0,
-          amount: 0,
+          amount: "0",
           desc: "",
           name: "",
           number: "",
@@ -751,6 +855,16 @@
       this.tableData = data;
       this.productTableList.tableData = this.tableData;
     },
+    //閫夋嫨琛�
+    rowClick(row){
+      console.log(row,"xuanze")
+      this.productListIdx=row.productIndex
+    },
+    //閫変腑浜у搧
+    handleProduct(item){
+      this.tableData[this.productListIdx].productId=item.ID
+      console.log(item,"閫変腑浜у搧",this.tableData)
+    }
   },
 };
 </script>

--
Gitblit v1.8.0