From d68b036a3b3c67273b8effa3c9925ef3869a91ba Mon Sep 17 00:00:00 2001
From: haoxuan <haoxuan>
Date: 星期三, 07 二月 2024 13:56:50 +0800
Subject: [PATCH] wms项目 wms系统参数设置的页面开发+路由+是否显示表头配置

---
 src/views/productManage/product/AddProductDialog.vue |  330 +++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 259 insertions(+), 71 deletions(-)

diff --git a/src/views/productManage/product/AddProductDialog.vue b/src/views/productManage/product/AddProductDialog.vue
index 8be8160..a6ded80 100644
--- a/src/views/productManage/product/AddProductDialog.vue
+++ b/src/views/productManage/product/AddProductDialog.vue
@@ -44,6 +44,7 @@
             :countObject="statisticsMap"
             :show-sale="showSale"
             @listingRulesClick="listingRulesClick"
+            @reorderRulesClick="reorderRulesClick"
           />
           <div class="bottom">
             <el-tabs v-model="activeName" type="card">
@@ -63,6 +64,30 @@
                       placeholder=""
                       :disabled="!showFooter"
                       style="width: 85%"
+                    ></el-input>
+                  </el-form-item>
+                  <el-form-item label="浜у搧缂栫爜" prop="id">
+                    <el-input
+                      style="width: 85%"
+                      v-if="
+                        editConfig.title == '缂栬緫' ||
+                        (editConfig.title == '鏂板缓' && codenumer && (explain != '' || isIdDisabled))
+                      "
+                      :disabled="editConfig.title != '鏂板缓'"
+                      v-model="editConfig.infomation.id"
+                      placeholder="璇疯緭鍏ョ紪鐮�"
+                    >
+                    </el-input>
+                    <span v-else-if="editConfig.title == '鏂板缓'" style="color: #f56c6c; width: 85%"
+                      >璇蜂紭鍏堥厤缃紪鐮佽鑼� <el-button type="text" @click="numberClick"> 閰嶇疆瑙勮寖 </el-button></span
+                    >
+                  </el-form-item>
+                  <el-form-item label="浜у搧瑙勬牸" prop="specs">
+                    <el-input
+                      style="width: 85%"
+                      :disabled="!showFooter"
+                      v-model="editConfig.infomation.specs"
+                      placeholder="璇疯緭鍏�"
                     ></el-input>
                   </el-form-item>
                   <el-form-item label="浜у搧绫诲瀷" prop="productType">
@@ -105,7 +130,7 @@
                       </el-option>
                     </el-select>
                   </el-form-item>
-                  <el-form-item label="鍗曚綅" prop="unit">
+                  <el-form-item label="鍗曚綅old" prop="unit">
                     <el-input
                       v-model="editConfig.infomation.unit"
                       placeholder="璇疯緭鍏�"
@@ -113,6 +138,29 @@
                       :disabled="!showFooter"
                     ></el-input>
                   </el-form-item>
+
+                  <el-form-item label="鍗曚綅" prop="unit">
+                    <el-select
+                      v-model="editConfig.infomation.unit"
+                      placeholder="鍗曚綅"
+                      filterable
+                      @change="$forceUpdate()"
+                      style="width: calc(100% - 30px)"
+                    >
+                      <el-option
+                        v-for="ele in unitList"
+                        :key="ele.id"
+                        :label="ele.name"
+                        :value="ele.name"
+                      ></el-option>
+                    </el-select>
+                    <i
+                      class="el-icon-setting margin_left_10px cursor_pointer"
+                      style="font-size: 20px; color: gray"
+                      @click="handleUnitShow"
+                    ></i>
+                  </el-form-item>
+                  
                   <el-form-item label="浜у搧鏍囩" prop="productTagName">
                     <el-input
                       v-model="editConfig.infomation.productTagName"
@@ -120,6 +168,14 @@
                       style="width: 85%"
                       :disabled="!showFooter"
                     ></el-input>
+                  </el-form-item>
+                  <el-form-item label="鍥剧墖涓婁紶锛�" prop="imageUrl">
+                    <IconCropper
+                      :isView="isView"
+                      :image-url="editConfig.infomation.imageSrc"
+                      @getImageData="getImageData"
+                      style="width: 85%"
+                    />
                   </el-form-item>
                 </div>
                 <div class="right">
@@ -131,7 +187,7 @@
                       :min="0"
                       :controls="false"
                       size="mini"
-                      style="width: 81%"
+                      style="width: 85%"
                       :disabled="!showFooter"
                     ></el-input-number>
                   </el-form-item>
@@ -153,7 +209,7 @@
                       :min="0"
                       :controls="false"
                       size="mini"
-                      style="width: 81%"
+                      style="width: 85%"
                       :disabled="!showFooter"
                     ></el-input-number>
                   </el-form-item>
@@ -173,6 +229,21 @@
                       >
                       </el-option>
                     </el-select>
+                  </el-form-item>
+                  <el-form-item label="浜у搧鍨嬪彿" prop="type">
+                    <el-input
+                      style="width: 85%"
+                      :disabled="!showFooter"
+                      v-model="editConfig.infomation.type"
+                      placeholder="璇疯緭鍏�"
+                    ></el-input>
+                  </el-form-item>
+                  <el-form-item label="閲囪喘绫诲瀷" prop="purchaseType">
+                    <el-radio-group :disabled="!showFooter" v-model="editConfig.infomation.purchaseType">
+                      <el-radio v-for="item in purchaseTypeList" :key="item.id" :label="item.id">{{
+                        item.name
+                      }}</el-radio>
+                    </el-radio-group>
                   </el-form-item>
                   <el-form-item label="鍐呴儴缂栫爜" prop="internalReference">
                     <el-input
@@ -196,9 +267,9 @@
               </div>
               <div class="all">
                 <!-- <div class="second-label">澶囨敞</div> -->
-                <el-form-item label="澶囨敞" prop="internalNotes">
+                <el-form-item label="澶囨敞" prop="note">
                   <el-input
-                    v-model.trim="editConfig.infomation.internalNotes"
+                    v-model.trim="editConfig.infomation.note"
                     placeholder="璇疯緭鍏�"
                     size="mini"
                     type="textarea"
@@ -234,9 +305,14 @@
                       placeholder="璇烽�夋嫨"
                       size="mini"
                       style="width: 85%"
-                      :disabled="!showFooter"
+                      disabled
                     >
-                      <el-option v-for="item in memberOptions" :key="item.id" :label="item.name" :value="item.name">
+                      <el-option
+                        v-for="(item, index) in memberOptions"
+                        :key="index"
+                        :label="item.userName"
+                        :value="item.userName"
+                      >
                       </el-option>
                     </el-select>
                   </el-form-item>
@@ -457,16 +533,29 @@
         <el-button size="small" @click="editConfig.visible = false">鍙栨秷</el-button>
       </div>
     </el-dialog>
+    <BomDialog
+      ref="editDialog"
+      @sucessSet="handleGetBomKindDictList"
+      @handleConfirmSave="handleConfirmSave"
+      :workList="unitList"
+      title="璁¢噺鍗曚綅"
+    ></BomDialog>
   </div>
 </template>
 
 <script>
-// import CommonFormTableView from "@/components/makepager/CommonFormTableView"
+import IconCropper from "./IconCropper"
 import { getProductCategoryList } from "@/api/product/productCategory"
 import { getProductList, addProduct, updateProduct } from "@/api/product/product"
+import { uploadFiles, getUserInfo } from "@/api/common/other"
+import codeMixin from "@/components/mixin/codeMixin"
+import { getDataByType } from "@/api/data"
+import BomDialog from "./components/bomDialog";
+// import { postGetSaveSUnitDict  } from "@/api/basic/standard";
 
-let inputElement = null
+
 export default {
+  mixins: [codeMixin],
   name: "AddProductDialog",
   props: {
     editCommonConfig: {
@@ -481,7 +570,10 @@
       }
     }
   },
-  components: {},
+  components: { 
+    IconCropper,
+    BomDialog, 
+  },
   computed: {
     modalTitle() {
       if (this.editConfig.title === "缂栬緫" && this.editConfig.autoEdit) {
@@ -499,11 +591,14 @@
       editConfig: this.editCommonConfig,
       rules: {
         name: [{ required: true, message: "璇疯緭鍏ヤ骇鍝佸悕绉�", trigger: "blur" }],
+        id: [{ required: true, validator: this.validateCheckCode, trigger: ["change", "blur"] }],
         model: [{ required: true, message: "璇烽�夋嫨鐗╂枡绫诲瀷", trigger: "change" }],
         // salePrice: [{ required: true, message: "璇疯緭鍏ラ攢鍞环鏍�", trigger: "blur" }],
-        unit: [{ required: true, message: "璇疯緭鍏ュ崟浣�", trigger: "blur" }]
+        unit: [{ required: true, message: "璇疯緭鍏ュ崟浣�", trigger: ["change", "blur"] }],
+        // 閲囪喘绫诲瀷
+        purchaseType: [{ required: true, message: "璇烽�夋嫨", trigger: "blur" }]
       },
-      memberOptions: [{ name: "绠$悊鍛�", id: 1 }],
+      memberOptions: [],
       productCategoryOptions: [], // 浜у搧绫诲埆
       productTypeOptions: [
         { name: "鑳芥秷鑰�", id: 1 },
@@ -540,22 +635,105 @@
         { name: "鍏朵粬", id: "鍏朵粬" }
       ],
       statisticsMap: {
-        inLibrary: 0 // 鍦ㄥ簱
-      }
+        amount: this.editCommonConfig.infomation.amount ? this.editCommonConfig.infomation.amount : 0, // 鍦ㄥ簱
+        predictionAmount: this.editCommonConfig.infomation.predictionAmount
+          ? this.editCommonConfig.infomation.predictionAmount
+          : 0, //棰勬祴
+        inputAmount: this.editCommonConfig.infomation.inputAmount ? this.editCommonConfig.infomation.inputAmount : 0, //杩�
+        outputAmount: this.editCommonConfig.infomation.outputAmount ? this.editCommonConfig.infomation.outputAmount : 0, //鍑�
+        reorderRuleNum: this.editCommonConfig.infomation.reorderRuleNum
+          ? this.editCommonConfig.infomation.reorderRuleNum
+          : 0, //閲嶈璐ц鍒欐暟閲�
+        minInventoryRule: this.editCommonConfig.infomation.minInventoryRule
+          ? this.editCommonConfig.infomation.minInventoryRule
+          : 0, //鏈�灏忛噸璁㈣揣
+        maxInventoryRule: this.editCommonConfig.infomation.maxInventoryRule
+          ? this.editCommonConfig.infomation.maxInventoryRule
+          : 0 //鏈�澶ч噸璁㈣揣
+      },
+      isView: false,
+      fileFormdata: null, // 涓婁紶鍥剧墖鍏ュ弬
+      purchaseTypeList: getDataByType("purchaseType"),
+      unitList: [],
     }
   },
   created() {
+    if (this.editConfig.title === "缂栬緫" && !this.editConfig.autoEdit) {
+      this.isView = true
+    }
     this.getProductCategoryList()
     this.getProductList()
     this.setTableForm()
     this.setBottonView()
     this.statisticsMap.inLibrary = this.editConfig?.infomation?.amount ?? 0
+    // 杩涘嚭鍙g殑浜у搧 鏁伴噺 杩樻病鏈�
+    this.statisticsMap.enter = this.editConfig?.infomation?.amount ?? 0
+    this.statisticsMap.exit = this.editConfig?.infomation?.amount ?? 0
     if (this.editConfig.autoEdit) {
       this.editClick()
     }
     this.setOptionalFieldsToEmpty()
+    this.formInfo()
+    this.getUserInfo()
   },
   methods: {
+    // 鍗曚綅
+    handleUnitShow() {
+      this.handleGetBomKindDictList();
+      this.$refs.editDialog.editDialogVisible = true;
+    },
+    //  鍗曚綅
+    handleGetBomKindDictList(val) {
+      console.log(val)
+      // postGetUnitDictList().then((res) => {
+      //   this.unitList = res.data;
+      //   if (val) {
+      //     for (let i in this.unitList) {
+      //       if (this.unitList[i].isDefault) {
+      //         this.form.unit = this.form.unit
+      //           ? this.form.unit
+      //           : this.unitList[i].name;
+      //         // this.$set(this.form, "unit", this.form.unit);
+      //         break;
+      //       }
+      //     }
+      //   }
+      // });
+    },
+    handleConfirmSave(data) {
+      console.log(data)
+      // postGetSaveSUnitDict({ data: data }).then((res) => {
+      //   if (res.code == 200) {
+      //     this.$message({
+      //       message: "鎿嶄綔鎴愬姛锛�",
+      //       type: "success",
+      //     });
+      //     this.$refs.editDialog.editDialogVisible = false;
+      //     this.handleGetBomKindDictList();
+      //   }
+      // });
+      this.$refs.editDialog.editDialogVisible = false;
+
+    },
+    // 鑾峰彇鐧诲綍鐢ㄦ埛淇℃伅
+    getUserInfo() {
+      getUserInfo().then((res) => {
+        console.log(res)
+        if (res.code == 200) {
+          this.editConfig.infomation.principal = res.data.userName
+          this.memberOptions.push(res.data)
+        }
+        console.log(this.memberOptions)
+      })
+    },
+    formInfo() {
+      this.objCode.type = "鐗╂枡缂栫爜"
+      this.objCode.codeStandID = ""
+      if (this.editConfig.infomation.codeStandardID) {
+        this.objCode.codeStandID = this.editConfig.infomation.codeStandardID
+      }
+      this.getRCodeStandardList()
+    },
     /**
      * 闈炲繀濉」鍚庣杩斿洖鐨勬槸鏁板瓧 0,琛ㄥ崟闇�瑕佺┖涓叉墠鑳借涓烘湭閫夋嫨鍥炴樉
      */
@@ -630,6 +808,7 @@
       this.showEdit = false
       this.showButton = false
       this.showFooter = true
+      this.isView = false
       this.setTableForm()
     },
     // 淇濆瓨
@@ -637,20 +816,50 @@
       console.log(this.editConfig.infomation)
       this.$refs[formName].validate((valid) => {
         if (valid) {
-          let requestUrl = this.editConfig.title === "鏂板缓" ? addProduct : updateProduct
-          this.unsetFieldsToNumber()
-          requestUrl({
-            ...this.editConfig.infomation
-          }).then((res) => {
-            console.log(res)
-            this.editConfig.visible = false
-            if (res.code === 200) {
-              this.$message.success("娣诲姞鎴愬姛")
-              this.$parent.getData()
+          console.log(this.fileFormdata == null)
+          let attachmentIDs = []
+          if (this.fileFormdata == null) {
+            if (this.editConfig.infomation.attachmentList?.length > 0) {
+              this.editConfig.infomation.attachmentList.forEach((ele) => {
+                attachmentIDs.push(ele.id)
+              })
+            } else {
+              attachmentIDs = []
             }
-          }, console.error)
+            this.saveEditRequest(attachmentIDs)
+          } else {
+            uploadFiles(this.fileFormdata).then((res) => {
+              if (res.code == 200) {
+                res.data.forEach((ele) => {
+                  attachmentIDs.push(ele.id)
+                })
+              }
+              this.saveEditRequest(attachmentIDs)
+            })
+          }
         }
       })
+    },
+    // 淇濆瓨/缂栬緫鎺ュ彛璇锋眰
+    saveEditRequest(attachmentIDs) {
+      let requestUrl = this.editConfig.title === "鏂板缓" ? addProduct : updateProduct
+      this.unsetFieldsToNumber()
+      let params = {
+        ...this.editConfig.infomation,
+        attachmentIDs
+      }
+      if (this.editConfig.title == "鏂板缓") {
+        params.codeStandardID = this.autoCodeObj.codeStandardID
+        params.autoIncr = this.autoCodeObj.maxAutoIncr
+      }
+      requestUrl(params).then((res) => {
+        console.log(res)
+        this.editConfig.visible = false
+        if (res.code === 200) {
+          this.$message.success(this.editConfig.title === "鏂板缓" ? "娣诲姞" : "缂栬緫" + "鎴愬姛!")
+          this.$parent.getData()
+        }
+      }, console.error)
     },
     // 鍒犻櫎
     delClick() {},
@@ -711,57 +920,22 @@
       this.tableData.splice(scope.$index, 1)
     },
     // 涓婁紶鍥剧墖
-    toGetImg() {
-      if (this.showFooter) {
-        if (inputElement === null) {
-          // 鐢熸垚鏂囦欢涓婁紶鐨勬帶浠�
-          inputElement = document.createElement("input")
-          inputElement.setAttribute("type", "file")
-          inputElement.style.display = "none"
-          if (window.addEventListener) {
-            inputElement.addEventListener("change", this.uploadFile, false)
-          } else {
-            inputElement.attachEvent("onchange", this.uploadFile)
-          }
-          document.body.appendChild(inputElement)
-        }
-        inputElement.click()
-      }
-    },
-    uploadFile(el) {
-      if (el && el.target && el.target.files && el.target.files.length > 0) {
-        console.log(el)
-        const files = el.target.files[0]
-        const isLt2M = files.size / 1024 / 1024 < 2
-        const size = files.size / 1024 / 1024
-        console.log(size)
-        // 鍒ゆ柇涓婁紶鏂囦欢鐨勫ぇ灏�
-        if (!isLt2M) {
-          this.$message.error("涓婁紶澶村儚鍥剧墖澶у皬涓嶈兘瓒呰繃 2MB!")
-        } else if (files.type.indexOf("image") === -1) {
-          //濡傛灉涓嶆槸鍥剧墖鏍煎紡
-          this.$message.error("璇烽�夋嫨鍥剧墖鏂囦欢")
-        } else {
-          const that = this
-          const reader = new FileReader() // 鍒涘缓璇诲彇鏂囦欢瀵硅薄
-          reader.readAsDataURL(el.target.files[0]) // 鍙戣捣寮傛璇锋眰锛岃鍙栨枃浠�
-          reader.onload = function () {
-            // 璇诲彇瀹屾垚鍚庯紝灏嗙粨鏋滆祴鍊肩粰img鐨剆rc
-            that.imageSrc = this.result
-            console.log(this.result)
-            // 鏁版嵁浼犲埌鍚庡彴
-            //const formData = new FormData()
-            //formData.append('file', files); // 鍙互浼犲埌鍚庡彴鐨勬暟鎹�
-          }
-        }
-      }
+    getImageData(formdata) {
+      this.fileFormdata = formdata
+      // console.log(formdata, "鍥剧墖鏁版嵁")
     },
     // 杩涘嚭鐐瑰嚮
-    inOutBoundClick() {
+    inOutBoundClick(val) {
       if (this.editConfig.title !== "鏂板缓") {
         console.log(this.editConfig.infomation)
+        let url=''
+        if(val=='杩�'){
+          url='inboundOutboundDetail'
+        }else{
+          url='outboundDetail'
+        }
         this.$router.push({
-          name: "inboundOutboundDetail",
+          name:url,
           params: {
             name: this.editConfig.infomation.name,
             id: this.editConfig.infomation.id
@@ -796,6 +970,20 @@
         }
       })
     },
+    // 閲嶈璐鍒�
+    reorderRulesClick() {
+      this.$refs.form.validate((valid) => {
+        if (valid) {
+          this.$router.push({
+            path: "/productManage/reorderRules",
+            query: {
+              productName: this.editConfig.infomation.name,
+              productId: this.editConfig.title === "鏂板缓" ? "" : this.editConfig.infomation.id
+            }
+          })
+        }
+      })
+    },
     // 鍙攢鍞�/鍙噰璐�
     checkboxChange(val, param) {
       if (val === "閲囪喘") {

--
Gitblit v1.8.0