From 32477dff99d0ed1d8acee453861be96428d8befc Mon Sep 17 00:00:00 2001
From: YLouie <929705085@qq.com>
Date: 星期日, 28 九月 2025 14:03:50 +0800
Subject: [PATCH] 销售订单plm同步

---
 src/views/plan/customerorder/index.vue |  649 +++++++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 520 insertions(+), 129 deletions(-)

diff --git a/src/views/plan/customerorder/index.vue b/src/views/plan/customerorder/index.vue
index d376ddf..86ef8e4 100644
--- a/src/views/plan/customerorder/index.vue
+++ b/src/views/plan/customerorder/index.vue
@@ -8,6 +8,7 @@
         :prelang="prelang"
         :options="options"
         :ajaxFun="ajaxFun"
+        :toolbarMaxLength="4"
         :paramArr="type"
         ref="customerOrderTable"
       >
@@ -17,15 +18,16 @@
             @command="documentHandle"
             style="margin-left: 10px"
           >
-            <el-button>
+            <el-button style="padding: 9px 14px;">
               宸ヨ壓鏂囦欢<i class="el-icon-arrow-down el-icon--right"></i>
             </el-button>
             <el-dropdown-menu slot="dropdown">
               <el-dropdown-item
                 :key="index"
                 :command="item.command"
-                v-for="(item,index) in documentTagArr"
-                :disabled="item.disabled">
+                v-for="(item, index) in documentTagArr"
+                :disabled="item.disabled"
+              >
                 {{ item.label }}
               </el-dropdown-item>
             </el-dropdown-menu>
@@ -36,24 +38,45 @@
             @command="handleCommitCommand"
             style="margin-left: 10px"
           >
-            <el-button>
+            <el-button style="padding: 9px 14px;">
               瀹℃牳鐘舵�佹敼鍙�<i class="el-icon-arrow-down el-icon--right"></i>
             </el-button>
             <el-dropdown-menu slot="dropdown">
               <el-dropdown-item
                 :key="index"
                 :command="item.command"
-                v-for="(item,index) in commitStateTagArr"
+                v-for="(item, index) in commitStateTagArr"
                 :disabled="item.disabled"
                 >{{ item.label }}</el-dropdown-item
               >
             </el-dropdown-menu>
           </el-dropdown>
           <el-button
-            style="margin-left:10px;"
+            style="margin-left: 10px;padding: 9px 14px;"
             type="primary"
-            @click="()=>exportDialogVisible=true"
-            >瀵煎嚭鍙拌处</el-button>
+            @click="() => (exportDialogVisible = true)"
+            >瀵煎嚭鍙拌处</el-button
+          >
+          <el-button
+            style="margin-left: 10px;padding: 9px 14px;"
+            type="primary"
+            v-if="permissions.plan_customerorder_check"
+            @click="handleCheck"
+            >瀹℃牳</el-button
+          >
+          <el-button
+            style="margin-left: 10px;padding: 9px 14px;"
+            type="primary"
+            v-if="permissions.plan_customerorder_check"
+            @click="syncPLM"
+            >鍚屾PLM</el-button
+          >
+          <!-- <el-button
+            style="margin-left: 10px"
+            type="primary"
+            @click="() => ($refs.technology.init())"
+            >缂栧啓鎶�鏈氦搴曞崟</el-button
+          > -->
         </template>
       </ttable>
       <!-- 寮圭獥, 鏃ユ湡閫夋嫨 -->
@@ -119,7 +142,7 @@
           <div>
             <div>
               <el-upload
-                style="margin-left:8px;display: inline;"
+                style="margin-left: 8px; display: inline"
                 class="upload-demo"
                 drag
                 :headers="headers"
@@ -140,7 +163,7 @@
                 <div class="el-upload__tip" slot="tip">
                   鍙兘涓婁紶xlsx/xls鏂囦欢锛屼笖涓嶈秴杩�10M<el-button
                     type="text"
-                    style="font-size:12px;"
+                    style="font-size: 12px"
                     @click="downDataTemplate"
                     >涓嬭浇妯℃澘</el-button
                   >
@@ -153,25 +176,36 @@
         <span slot="footer" class="dialog-footer"> </span>
       </el-dialog>
       <!-- 瀵煎嚭 -->
-      <el-dialog title="瀵煎嚭鍙拌处" :visible.sync="exportDialogVisible" width="20%">
-        <div style="display: flex;justify-content: center">
-          <el-form :model="dataForm" :inline="true" :rules="dataRule" ref="exportForm" class="l-mes">
+      <el-dialog
+        title="瀵煎嚭鍙拌处"
+        :visible.sync="exportDialogVisible"
+        width="20%"
+      >
+        <div style="display: flex; justify-content: center">
+          <el-form
+            :model="dataForm"
+            :inline="true"
+            :rules="dataRule"
+            ref="exportForm"
+            class="l-mes"
+          >
             <el-form-item label="鏃ユ湡" prop="exportTime">
               <el-date-picker
                 v-model="dataForm.exportTime"
                 type="datetime"
-                style="width:100%"
+                style="width: 100%"
                 placeholder="閫夋嫨鏃ユ湡鏃堕棿"
-                value-format="yyyy-MM-dd HH:mm:ss">
+                value-format="yyyy-MM-dd HH:mm:ss"
+              >
               </el-date-picker>
             </el-form-item>
           </el-form>
-      </div>
-      <span slot="footer" class="dialog-footer">
-        <el-button @click="exportDialogVisible=false">鍙� 娑�</el-button>
-        <el-button type="primary" @click="exportStandBook">纭� 瀹�</el-button>
-      </span>
-    </el-dialog>
+        </div>
+        <span slot="footer" class="dialog-footer">
+          <el-button @click="exportDialogVisible = false">鍙� 娑�</el-button>
+          <el-button type="primary" @click="exportStandBook">纭� 瀹�</el-button>
+        </span>
+      </el-dialog>
       <!-- 绠辩爜淇℃伅瀵煎嚭 -->
       <el-dialog
         title="绠辩爜淇℃伅瀵煎嚭"
@@ -184,7 +218,7 @@
           ref="packageExportForm"
           label-width="70px"
           class="l-mes"
-          style="padding:0 20px"
+          style="padding: 0 20px"
         >
           <el-form-item label="璁㈠崟鍙�">
             <el-input v-model="packageExport.form.customerOrderNo" disabled />
@@ -224,14 +258,21 @@
     </basic-container>
 
     <el-dialog title="閫夋嫨鍚屾鏃ユ湡" :visible.sync="syncDateVisible" width="20%">
-      <div style="display: flex;justify-content: center">
-        <el-form :model="dataForm" :inline="true" :rules="dataRule" ref="dataForm" class="l-mes">
+      <div style="display: flex; justify-content: center">
+        <el-form
+          :model="dataForm"
+          :inline="true"
+          :rules="dataRule"
+          ref="dataForm"
+          class="l-mes"
+        >
           <el-form-item label="鏃ユ湡">
             <el-date-picker
               v-model="dataForm.selectTime"
               type="datetime"
               placeholder="閫夋嫨鏃ユ湡鏃堕棿"
-              value-format="yyyy-MM-dd HH:mm:ss">
+              value-format="yyyy-MM-dd HH:mm:ss"
+            >
             </el-date-picker>
           </el-form-item>
         </el-form>
@@ -241,12 +282,104 @@
         <el-button type="primary" @click="startSync">纭� 瀹�</el-button>
       </span>
     </el-dialog>
+    <el-dialog
+      title="宸插叧鑱旈攢鍞鍗�"
+      :visible.sync="showInterrelatedOrderDialog"
+      width="60%"
+    >
+      <el-table border height="100" :data="interrelatedOrderData">
+        <el-table-column
+          type="index"
+          align="center"
+          label="搴忓彿"
+        ></el-table-column>
+        <el-table-column
+          prop="contractNo"
+          show-overflow-tooltip
+          align="center"
+          label="鍚堝悓缂栧彿"
+        ></el-table-column>
+        <el-table-column
+          prop="entityName"
+          show-overflow-tooltip
+          align="center"
+          label="宸ョ▼鍚嶇О"
+        ></el-table-column>
+        <el-table-column
+          prop="sourceId"
+          show-overflow-tooltip
+          align="center"
+          label="娣诲姞鏉ユ簮"
+        >
+          <template scope="scope">
+            <el-tag v-if="scope.row.sourceId == 0" type="success">鍚屾</el-tag>
+            <el-tag v-if="scope.row.sourceId == 1" type="info">鎵嬪姩</el-tag>
+          </template>
+        </el-table-column>
+        <el-table-column
+          prop="placeOrderDate"
+          show-overflow-tooltip
+          align="center"
+          label="涓嬪崟鏃ユ湡"
+        ></el-table-column>
+        <el-table-column
+          prop="customerName"
+          show-overflow-tooltip
+          align="center"
+          label="瀹㈡埛鍚嶇О"
+        ></el-table-column>
+        <el-table-column
+          prop="coState"
+          min-width="100"
+          show-overflow-tooltip
+          align="center"
+          label="閿�鍞鍗曠姸鎬�"
+        ></el-table-column>
+        <el-table-column
+          prop="partNo"
+          show-overflow-tooltip
+          align="center"
+          label="浜у搧缂栧彿"
+        ></el-table-column>
+        <el-table-column
+          prop="productName"
+          show-overflow-tooltip
+          align="center"
+          label="浜у搧鍚嶇О"
+        ></el-table-column>
+        <el-table-column
+          prop="productType"
+          show-overflow-tooltip
+          align="center"
+          label="闅跺睘鍝佺墝"
+        ></el-table-column>
+        <el-table-column
+          prop="otcUnit"
+          show-overflow-tooltip
+          align="center"
+          label="鍗曚綅"
+        ></el-table-column>
+        <el-table-column
+          prop="buyQtyDue"
+          show-overflow-tooltip
+          align="center"
+          label="鏁伴噺"
+        ></el-table-column>
+      </el-table>
+    </el-dialog>
+    <technology-form ref="technology"></technology-form>
   </div>
 </template>
 
 <script>
+import {
+  interrelatedOrder,
+  getInterrelatedOrder,
+  checkHanderOrder
+} from '@/api/plan/customerOrderInterrelated'
 import ConfirmPullCustomerorder from './confirm-pull-customerorder'
 import TableForm from './customerorder-form'
+import TechnologyForm from './technology-form.vue'
 import TableFormDEesc from './customerorder-form-desc'
 import SampleTableForm from './sample-customerorder-form'
 import { mapGetters } from 'vuex'
@@ -273,7 +406,9 @@
   exportCustomerOrderSplit,
   syncOrder,
   dropByContractNo,
-  downloadWordFile
+  downloadProduct,
+  downloadWordFile,
+  syncPlm
 } from '../../../api/plan/customerorder'
 import DocumentTable from '@/views/common/document.vue'
 import { remote } from '@/api/admin/dict'
@@ -285,13 +420,19 @@
 export default {
   data() {
     return {
+      interrelatedOrderId: null,
+      interrelatedOrderData: [],
+      showInterrelatedOrderDialog: false,
+      technologyDialog: true,
       uniqueStateArr: [],
       dataForm: {
         selectTime: null,
         exportTime: null
       },
       dataRule: {
-        exportTime:[{required:true,message:'瀵煎嚭鏃ユ湡涓嶈兘涓虹┖',trigger:'change'}]
+        exportTime: [
+          { required: true, message: '瀵煎嚭鏃ユ湡涓嶈兘涓虹┖', trigger: 'change' }
+        ]
       },
       pickerOptions: {
         onPick: ({ maxDate, minDate }) => {
@@ -400,8 +541,9 @@
         isRefresh: true, // 鏄惁鏄剧ず鍒锋柊鎸夐挳
         isShowHide: true, // 鏄惁鏄剧ず鏄惧奖鎸夐挳H
         isSearch: true, // 楂樼骇鏌ヨ鎸夐挳
-        defaultOrderBy: { column: 'createTime', direction: 'desc' },
-        cancelRunCreated: true
+        defaultOrderBy: { column: 'placeOrderDate', direction: 'desc' },
+        cancelRunCreated: true,
+        reserveSelection: true // 鏄惁淇濈暀涔嬪墠閫夋嫨鐨勬暟鎹�
       },
       table: {
         total: 0,
@@ -469,7 +611,7 @@
             sort: true,
             isTrue: true,
             isSearch: true,
-            searchInfoType: 'text',
+            searchInfoType: 'datetimerange',
             formatter: this.formatDutyDate
           },
           {
@@ -497,7 +639,7 @@
           {
             minWidth: '120',
             prop: 'isAudit',
-            label: '瀹℃牳鐘舵��',
+            label: 'PLM瀹℃牳鐘舵��',
             sort: true,
             isTrue: true,
             isSearch: true,
@@ -507,15 +649,32 @@
               return this.isAuditList
             }
           },
-          // {
-          //   minWidth: '80',
-          //   prop: 'sourceId',
-          //   label: '璁㈠崟鏉ユ簮',
-          //   sort: true,
-          //   isTrue: true,
-          //   isSearch: true,
-          //   searchInfoType: 'text'
-          // },
+          {
+            minWidth: '120',
+            prop: 'isPass',
+            label: '瀹℃牳閫氳繃鐘舵��',
+            sort: true,
+            isTrue: true,
+            isSearch: true,
+            searchInfoType: 'select',
+            formatter: this.checkIsPass,
+            optList: () => {
+              return this.isPassList
+            }
+          },
+          {
+            minWidth: '120',
+            prop: 'isOa',
+            label: '鏄惁鎻愪氦oa',
+            sort: true,
+            isTrue: true,
+            isSearch: true,
+            searchInfoType: 'select',
+            formatter: this.checkIsOa,
+            optList: () => {
+              return this.isOaList
+            }
+          },
           {
             minWidth: '120',
             width: '100px',
@@ -632,7 +791,7 @@
             isSearch: true,
             searchInfoType: 'datetimerange',
             formatter: this.formatDutyDate
-          },
+          }
         ],
         toolbar: [],
         operator: [
@@ -654,6 +813,25 @@
           //   size: 'small',
           //   fun: this.packageExportHandle
           // },
+          //   {
+          //     text: '瀹℃牳',
+          //     type: 'text',
+          //     size: 'small',
+          //     fun: this.checkHandOrder,
+          //     showFun: (row) => {
+          //       return row.sourceId === '1'
+          //     },
+          //     show: {
+          //       val: [false],
+          //       key: 'isPass',
+          //     },
+          //   },
+          {
+            text: '宸插叧鑱旇鍗�',
+            type: 'text',
+            size: 'small',
+            fun: this.showInterrelatedOrder
+          },
           {
             text: '鍒犻櫎',
             type: 'text',
@@ -673,8 +851,8 @@
         operatorConfig: {
           fixed: 'right',
           label: '鎿嶄綔',
-          width: 100,
-          minWidth: 100
+          width: 200,
+          minWidth: 200
         }
       },
       addOrUpdateVisible: false,
@@ -704,16 +882,20 @@
           label: '璁㈠崟缂栬緫'
         }
       ],
-      manufactureAttrList: [{
-        label: '鏅��',
-        value: 'N'
-      },{
-        label: '鏍峰搧',
-        value: 'S'
-      },{
-        label: '鐮斿彂',
-        value: 'D'
-      }],
+      manufactureAttrList: [
+        {
+          label: '鏅��',
+          value: 'N'
+        },
+        {
+          label: '鏍峰搧',
+          value: 'S'
+        },
+        {
+          label: '鐮斿彂',
+          value: 'D'
+        }
+      ],
       isAuditList: [
         {
           value: '01draft',
@@ -732,13 +914,16 @@
           label: '閫�鍥�'
         }
       ],
-      sourceIdList: [{
-        label: '鍚屾',
-        value: "0"
-      },{
-        label: '鎵嬪姩',
-        value: "1"
-      }],
+      sourceIdList: [
+        {
+          label: '鍚屾',
+          value: '0'
+        },
+        {
+          label: '鎵嬪姩',
+          value: '1'
+        }
+      ],
       stockVisible: false,
       partName: null,
       showPullCustomerOrderVisible: false,
@@ -780,7 +965,15 @@
         }
       ],
       showSalesPartBatch: false,
-      addOrUpdateEescVisible: false
+      addOrUpdateEescVisible: false,
+      isPassList: [
+        { label: '鏈�氳繃', value: false },
+        { label: '閫氳繃', value: true }
+      ],
+      isOaList: [
+        { label: '鏈彁浜�', value: false },
+        { label: '宸叉彁浜�', value: true }
+      ]
     }
   },
   components: {
@@ -794,7 +987,8 @@
     SampleTableForm,
     SalesPartBatchDialog,
     TableFormDEesc,
-    CustomerorderReturnDialog
+    CustomerorderReturnDialog,
+    TechnologyForm
   },
   computed: {
     ...mapGetters(['permissions'])
@@ -812,6 +1006,19 @@
         }
       },
       immediate: true
+    },
+    interrelatedOrderId(newVal) {
+      if (newVal) {
+        getInterrelatedOrder(newVal)
+          .then((res) => {
+            if (res.status === 200) {
+              this.interrelatedOrderData = res.data.data
+            }
+          })
+          .catch((error) => {
+            console.error(error)
+          })
+      }
     }
   },
   mounted() {
@@ -820,13 +1027,15 @@
   created() {
     // this.getManufactureAttrs()
     this.getTitles()
-    this.table.toolbar.push({
-      text: '鏂板閿�鍞鍗�',
-      type: 'primary',
-      fun: this.addSampleCustomerOrder,
-      disabled: false,
-      permitArr: []
-    })
+    if (this.permissions.plan_customerorder_add) {
+      this.table.toolbar.push({
+        text: '鏂板閿�鍞鍗�',
+        type: 'primary',
+        fun: this.addSampleCustomerOrder,
+        disabled: false,
+        permitArr: []
+      })
+    }
     if (this.permissions.customerorder_from_otc) {
       this.table.toolbar.push({
         text: '鑾峰彇閿�鍞鍗�',
@@ -838,7 +1047,7 @@
     }
     if (this.permissions.customerorder_submit_oa) {
       this.table.toolbar.push({
-        text: '鎻愪氦瀹℃牳',
+        text: '鎻愪氦OA',
         type: 'primary',
         fun: this.auditCustomerOrder,
         disabled: false,
@@ -855,6 +1064,33 @@
         permitArr: []
       })
     }
+    if (this.permissions.plan_download_process_file) {
+      this.table.toolbar.push({
+        text: '涓嬭浇宸ヨ壓鏂囦欢',
+        disabled: false,
+        type: 'primary',
+        fun: this.downloadWord,
+        permitArr: ['03plan', '04planed']
+      })
+    }
+    if (this.permissions.plan_download_product_file) {
+      this.table.toolbar.push({
+        text: '涓嬭浇鎺掍骇鍗�',
+        disabled: false,
+        type: 'primary',
+        permitArr: [],
+        fun: this.downloadProductionScheduling
+      })
+    }
+    if (this.permissions.plan_relevance_order) {
+      this.table.toolbar.push({
+        text: '鍏宠仈璁㈠崟',
+        disabled: false,
+        type: 'primary',
+        fun: this.interrelatedOrderFun,
+        permitArr: []
+      })
+    }
     if (this.permissions.customerorder_create_masterplan) {
       this.table.toolbar.push({
         text: '涓荤敓浜ц鍒�',
@@ -863,36 +1099,106 @@
         permitArr: []
       })
     }
-    this.table.toolbar.push({
-        text: '涓嬭浇Word',
-        disabled: false,
-        type: 'primary',
-        fun: this.downloadWord,
-        permitArr: ['03plan','04planed'],
-    })
   },
   methods: {
-    //涓嬭浇word
-    downloadWord(){
-        let ids = this.multipleSelection.map(ele=>ele.id)
-        if(ids.length<1){
-            this.$message.error("璇烽�夋嫨涓�鏉℃暟鎹�")
-            return
+    checkHandOrder(val) {
+      this.$confirm('纭瀹℃牳閫氳繃璇ラ攢鍞鍗曞悧?', '鎻愮ず', {
+        confirmButtonText: '閫氳繃',
+        cancelButtonText: '鍙栨秷',
+        type: 'warning'
+      })
+        .then(() => {
+          checkHanderOrder(val)
+            .then((res) => {
+              if (res.status === 200) {
+                this.$message.success('瀹℃牳閫氳繃')
+                this.getData()
+              }
+            })
+            .catch((error) => {
+              console.error(error)
+            })
+        })
+        .catch(() => {})
+    },
+    interrelatedOrderFun() {
+      if (this.multipleSelection.length != 2) {
+        this.$message.error('璇烽�夋嫨涓ゆ潯閿�鍞鍗�')
+        return
+      }
+      let autoId = null
+      let handId = null
+      this.multipleSelection.forEach((ele) => {
+        if (ele.sourceId == 0) {
+          autoId = ele.id
+        } else if (ele.sourceId == 1) {
+          handId = ele.id
         }
-        downloadWordFile(ids).then(response=>{
+      })
+      if (autoId == null || handId == null) {
+        this.$message.error('娣诲姞鏉ユ簮椤讳负鎵嬪姩鍜屽悓姝�')
+        return
+      }
+      interrelatedOrder({
+        customerOrderAutoId: autoId,
+        customerOrderHandId: handId
+      })
+        .then((res) => {
+          if (res.status === 200) {
+            this.$message.success('鍏宠仈鎴愬姛')
+          }
+        })
+        .catch((error) => {
+          console.error(error)
+        })
+    },
+    // 灞曠ず宸插叧鑱旇鍗�
+    showInterrelatedOrder(currentOrder) {
+      this.interrelatedOrderId = currentOrder.id
+      this.showInterrelatedOrderDialog = true
+    },
+    // 涓嬭浇鎺掍骇閫氱煡鍗�
+    downloadProductionScheduling() {
+      const ids = this.multipleSelection.map((obj) => obj.id)
+      if (ids.length < 1) {
+        this.$message.error('璇烽�夋嫨涓�鏉℃暟鎹�')
+        return
+      }
+      downloadProduct(ids)
+        .then((res) => {
+          if (res.status === 200) {
+            transform(res)
+          }
+        })
+        .catch((error) => {
+          console.error(error)
+        })
+    },
+    // 涓嬭浇宸ヨ壓鏂囦欢
+    downloadWord() {
+      const ids = this.multipleSelection.map((ele) => ele.id)
+      if (ids.length < 1) {
+        this.$message.error('璇烽�夋嫨涓�鏉℃暟鎹�')
+        return
+      }
+      downloadWordFile(ids)
+        .then((response) => {
           // 澶勭悊杩斿洖鐨勬枃浠舵祦
           const blob = response.data
           const link = document.createElement('a')
           link.href = URL.createObjectURL(blob)
-          link.download = '宸ヨ壓鏂囦欢.docx'
+          const disposition = response.headers['content-disposition']
+          const temp = disposition.substring(disposition.lastIndexOf('=') + 1)
+          link.download = decodeURI(temp)
           document.body.appendChild(link)
           link.click()
           window.setTimeout(function() {
             URL.revokeObjectURL(blob)
             document.body.removeChild(link)
           }, 0)
-        }).catch(error=>{
-            console.error(error);
+        })
+        .catch((error) => {
+          console.error(error)
         })
     },
     getOtcPartSyncOptionList() {
@@ -912,8 +1218,9 @@
       this.getData()
     },
 
-    getData() {
-      this.$refs.customerOrderTable.getDataList()
+    async getData() {
+      await this.$refs.customerOrderTable.getDataList()
+      this.$refs.customerOrderTable.toggleRowExpansion()
     },
     // 鑾峰彇鏁版嵁鍒楄〃鍘婚櫎宸插畬鎴愮姸鎬佺殑
     handleDataList(command) {
@@ -959,6 +1266,18 @@
         this.$message.error('璇烽�夋嫨閿�鍞鍗�')
       }
     },
+    checkIsPass(row, column, cellValue) {
+      this.isPassList.forEach((obj) => {
+        if (obj.value === cellValue) {
+          if (obj.value) {
+            cellValue = "<span style='color:#34BD66;'>" + obj.label + '</span>'
+          } else {
+            cellValue = "<span style='color:#E84738;'>" + obj.label + '</span>'
+          }
+        }
+      })
+      return cellValue
+    },
     formatDutyDate(row, column, cellValue) {
       if (cellValue) {
         const dutyDateList = /\d{4}-\d{1,2}-\d{1,2}/g.exec(cellValue)
@@ -970,16 +1289,23 @@
     },
     // 鏂板 / 淇敼
     addOrUpdateHandle(row) {
-      this.addOrUpdateVisible = true
-      this.$nextTick(() => {
-        this.$refs.addOrUpdate.init(row ? row.id : row)
-      })
+      if (row.isPass) {
+        this.addOrUpdateVisible = true
+        this.$nextTick(() => {
+          this.$refs.addOrUpdate.init(row ? row.id : row)
+        })
+      } else {
+        this.addSampleVisible = true
+        this.$nextTick(() => {
+          this.$refs.addSampleForm.init(row ? row.contractNo : null)
+        })
+      }
     },
     // 鏂板鏍峰搧璁㈠崟
     addSampleCustomerOrder() {
       this.addSampleVisible = true
       this.$nextTick(() => {
-        this.$refs.addSampleForm.init(0)
+        this.$refs.addSampleForm.init(null)
       })
     },
     // 鎵撳紑鏃ユ湡閫夋嫨妗�
@@ -1036,45 +1362,34 @@
     // 瀹℃牳閿�鍞鍗�
     auditCustomerOrder() {
       if (this.multipleSelection.length > 0) {
-        if (this.judgeCoState(this.multipleSelection)) {
-          let flag = true
-          const ids = []
-          this.multipleSelection.forEach((item) => {
-            if (item.partNo != null && item.partNo !== '') {
-              ids.push(item.id)
-            } else {
-              flag = false
-            }
-          })
-          if (flag) {
-            checkOA(this.multipleSelection.map((e) => e.id)).then((res) => {
-              if (!res.data.data.success) {
-                this.$confirm(`${res.data.data.message}`, '鎻愮ず', {
-                  confirmButtonText: '纭畾',
-                  cancelButtonText: '鍙栨秷',
-                  closeOnClickModal: false,
-                  type: 'warning'
-                }).then(() => {
-                  this.auditCustomerOrderSure(ids)
-                })
-              } else {
+        let flag = true
+        const ids = []
+        this.multipleSelection.forEach((item) => {
+          if (item.partNo != null && item.partNo !== '') {
+            ids.push(item.id)
+          } else {
+            flag = false
+          }
+        })
+        if (flag) {
+          checkOA(this.multipleSelection.map((e) => e.id))
+            .then((res) => {
+              if (res.data.data.success) {
                 this.auditCustomerOrderSure(ids)
               }
             })
-          } else {
-            this.$message.error('瀛樺湪閿�鍞鍗曟湭缁戝畾閿�鍞欢锛�')
-          }
+            .catch((error) => {
+              this.$message.error(error.message)
+            })
         } else {
-          this.$message.error('閿�鍞鍗曞鏍哥姸鎬佷负浣滃簾锛屼笉鍙繘琛屾搷浣滐紒')
+          this.$message.error('瀛樺湪閿�鍞鍗曟湭缁戝畾闆朵欢鍙凤紒')
         }
       } else {
         this.$message.error('璇峰厛鍕鹃�夐攢鍞鍗曪紒')
       }
     },
     auditCustomerOrderSure(ids) {
-      const toolbar = this.table.toolbar.find(
-        (item) => item.text === '鎻愪氦瀹℃牳'
-      )
+      const toolbar = this.table.toolbar.find((item) => item.text === '鎻愪氦OA')
       if (toolbar) {
         toolbar.loading = true
         auditCustomerOrder(ids)
@@ -1084,7 +1399,7 @@
               this.$message.success(resData.msg)
               this.getData()
             } else {
-              this.$message.error('鎻愪氦瀹℃牳澶辫触锛�')
+              this.$message.error('鎻愪氦OA澶辫触锛�')
             }
             toolbar.loading = false
           })
@@ -1132,13 +1447,13 @@
     },
     // 浣滃簾
     cancelHandle(row) {
-      this.$confirm('纭浣滃簾id涓恒��' + row.id + '銆戠殑鏁版嵁?','鎻愮ず' , {
+      this.$confirm('纭浣滃簾id涓恒��' + row.id + '銆戠殑鏁版嵁?', '鎻愮ず', {
         confirmButtonText: '纭畾',
         cancelButtonText: '鍙栨秷',
         closeOnClickModal: false,
         type: 'warning'
       }).then(() => {
-        dropByContractNo({id:row.id}).then((res) => {
+        dropByContractNo({ id: row.id }).then((res) => {
           if (res.data.code === 0) {
             this.$message.success('浣滃簾鎴愬姛')
             this.getData()
@@ -1278,6 +1593,14 @@
       })
       return cellValue
     },
+    checkIsOa(row, column, cellValue) {
+      this.isOaList.forEach((obj) => {
+        if (obj.value === cellValue) {
+          cellValue = obj.label
+        }
+      })
+      return cellValue
+    },
     // 瀹℃牳鐘舵�佹敼鍙�
     handleCommitCommand(event) {
       if (this.multipleSelection.length > 0) {
@@ -1401,6 +1724,10 @@
       } else {
         if (this.judgeCoState(this.multipleSelection)) {
           if (event == 'RELEVANCE') {
+            if (!this.multipleSelection[0].isPass) {
+              this.$message.error('璇峰厛瀹℃牳閫氳繃锛屽啀鍏宠仈宸ヨ壓鏂囦欢')
+              return
+            }
             const firstPartNo = this.multipleSelection[0].partNo
             this.multipleSelection.forEach((item) => {
               if (item.isDocument) {
@@ -1563,10 +1890,10 @@
       // } else {
       //   this.$message.error('璇烽�夋嫨鑷冲皯涓�鏉¢攢鍞鍗�')
       // }
-      this.$refs['exportForm'].validate(valid => {
-        if(valid){
+      this.$refs.exportForm.validate((valid) => {
+        if (valid) {
           const exportTime = this.dataForm.exportTime
-          let queryParam=this.$refs.customerOrderTable.getQueryParam();
+          const queryParam = this.$refs.customerOrderTable.getQueryParam()
           queryParam.selectTime = exportTime
           exportCustomerOrder(queryParam)
             .then((response) => {
@@ -1636,6 +1963,70 @@
         ).loading = false
         this.$message.error('璇峰厛閫夋嫨鏃ユ湡')
       }
+    },
+    handleCheck() {
+      if (this.multipleSelection.length > 0) {
+        for (let i = 0; i < this.multipleSelection.length; i++) {
+          if (this.multipleSelection[i].sourceId == 0) {
+            this.$message.error('璇烽�夋嫨鎵嬪姩杈撳叆鐨勯攢鍞鍗�')
+            return
+          }
+          if (this.multipleSelection[i].isPass) {
+            this.$message.error('璇烽�夋嫨鏈鏍搁�氳繃鐨勯攢鍞鍗�')
+            return
+          }
+        }
+        this.$confirm('纭瀹℃牳閫氳繃閫変腑鐨勯攢鍞鍗曞悧?', '鎻愮ず', {
+          confirmButtonText: '閫氳繃',
+          cancelButtonText: '鍙栨秷',
+          type: 'warning'
+        })
+          .then(() => {
+            checkHanderOrder(this.multipleSelection)
+              .then((res) => {
+                if (res.status === 200) {
+                  this.$message.success('瀹℃牳閫氳繃')
+                  this.getData()
+                }
+              })
+              .catch((error) => {
+                console.error(error)
+              })
+          })
+          .catch(() => {})
+      } else {
+        this.$message.error('璇烽�夋嫨鑷冲皯涓�鏉¢攢鍞鍗�')
+      }
+    },
+
+    syncPLM() {
+      if (this.multipleSelection.length > 0) {
+        this.$confirm('纭鍚屾閫変腑鐨勯攢鍞鍗曞悧?', '鎻愮ず', {
+          confirmButtonText: '纭畾',
+          cancelButtonText: '鍙栨秷',
+          type: 'warning'
+        })
+          .then(() => {
+            syncPlm(
+              this.multipleSelection.map((item) => ({
+                id: item.id, // 浼犻�抜d瀛楁
+                partNo: item.partNo // 浼犻�抪artNo瀛楁
+              }))
+            )
+              .then((res) => {
+                if (res.status === 200) {
+                  this.$message.success('鍚屾鎴愬姛')
+                  this.getData()
+                }
+              })
+              .catch((error) => {
+                console.error(error)
+              })
+          })
+          .catch(() => {})
+      } else {
+        this.$message.error('璇烽�夋嫨鑷冲皯涓�鏉¢攢鍞鍗�')
+      }
     }
   }
 }

--
Gitblit v1.9.3