From 445c50119ba6133e5e8f929fcd71fff322a37f29 Mon Sep 17 00:00:00 2001
From: zouyu <2723363702@qq.com>
Date: 星期一, 12 八月 2024 10:52:04 +0800
Subject: [PATCH] Merge branch 'master' of http://114.132.189.42:9002/r/center-lims-before

---
 src/components/do/b1-ins-order/fiberoptic-config.vue |  101 +++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 99 insertions(+), 2 deletions(-)

diff --git a/src/components/do/b1-ins-order/fiberoptic-config.vue b/src/components/do/b1-ins-order/fiberoptic-config.vue
index 7ae348a..a48781c 100644
--- a/src/components/do/b1-ins-order/fiberoptic-config.vue
+++ b/src/components/do/b1-ins-order/fiberoptic-config.vue
@@ -95,7 +95,7 @@
               </el-table-column> -->
               <el-table-column prop="ask" label="妫�娴嬭姹�" show-overflow-tooltip width="200px">
                 <template slot-scope="scope">
-                  <el-input v-model="scope.row.ask" placeholder="璇疯緭鍏�" size="small" :disabled="active!=1" v-if="!isAskOnlyRead" @change="changeASk(scope.row)"></el-input>
+                  <el-input v-model="scope.row.ask" placeholder="璇疯緭鍏�" size="small" :disabled="active!=1" v-if="!isAskOnlyRead" @change="changeASk(scope.row,'ask')"></el-input>
                   <span v-else>{{ scope.row.ask }}</span>
                 </template>
               </el-table-column>
@@ -561,7 +561,104 @@
         }
       },
 
-      changeASk(row) {
+      changeASk(row,type) {
+        if(type == 'ask') {
+          // 濡傛灉妫�娴嬭姹傚惈鏈夋璐熷彿
+          if(row.tell.indexOf('卤') != -1) {
+            let left = row.tell.substring(0,row.tell.indexOf('卤'))
+            let right = row.tell.substring(row.tell.indexOf('卤')+1)
+            // 濡傛灉鍙互杞寲涓烘暟鍊�
+           if(!isNaN(Number(left)) && !isNaN(Number(right))) {
+              if(row.ask.indexOf('-') != -1) {
+                  let left1 = row.ask.substring(0,row.ask.indexOf('-'))
+                  let right1 = row.ask.substring(row.ask.indexOf('-')+1)
+                  if(Number(left1) != (Number(left) - Number(right)) || Number(right1) != (Number(left) + Number(right))) {
+                    this.$message.error('妫�娴嬭姹備笉绗﹀悎瑕佹眰鎻忚堪')
+                    row.ask = (Number(left) - Number(right)) + '-' + (Number(left) + Number(right))
+                  }
+              }else {
+                this.$message.error('妫�娴嬭姹備笉绗﹀悎瑙勮寖')
+                row.ask = left + '-' + right
+                return
+              }
+           }
+           // 濡傛灉瑕佹眰鎻忚堪宸﹁竟涓嶈兘杞寲涓烘暟鍊�
+           else if(isNaN(Number(left)) && !isNaN(Number(right))) {
+            const regex = /[~-]/
+            const match = left.match(regex)
+            // 宸﹁竟鍚湁 - ~ 绗﹀彿
+            if(match) {
+              let newLeft = '';
+              if(left.includes('锛�')) {
+               newLeft = left.replace('锛�','(')
+              }
+              if(left.includes('锛�')) {
+                newLeft = newLeft.replace('锛�',')')
+              }
+              const regexTwo = /\((\d+(\.\d+)?)([~-])(\d+(\.\d+)?)\)/;
+              const matchTwo = newLeft.match(regexTwo);
+              let leftTwo = Number(matchTwo[1]) - Number(right)
+              let rightTwo = Number(matchTwo[4]) + Number(right)
+              console.log(matchTwo);
+              console.log(leftTwo,rightTwo);
+
+              console.log(row.ask.indexOf('-'));
+              if(row.ask.indexOf('-') != -1) {
+                  let left1 = row.ask.substring(0,row.ask.indexOf('-'))
+                  let right1 = row.ask.substring(row.ask.indexOf('-')+1)
+                  if(Number(left1) != leftTwo || Number(right1) != rightTwo) {
+                    this.$message.error('妫�娴嬭姹備笉绗﹀悎瑕佹眰鎻忚堪')
+                    row.ask = leftTwo + '-' + rightTwo
+                  }
+              }else {
+                this.$message.error('妫�娴嬭姹備笉绗﹀悎瑙勮寖')
+                row.ask = leftTwo + '-' + rightTwo
+                return
+              }
+            }
+           }
+          }
+          // 濡傛灉妫�娴嬭姹傚惈鏈夆墹 < 鈮� > 绗﹀彿
+          const regex = /[鈮�<鈮�>]/
+          const match = row.tell.match(regex)
+          if(match) {
+            // 绗﹀彿涓嶄竴鑷�
+            if( row.ask.indexOf(match[0]) != 0) {
+                this.$message.error('妫�娴嬭姹備笉绗﹀悎瑕佹眰鎻忚堪')
+                row.ask = match[0]
+                return
+              }else {
+                // 绗﹀彿涓�鑷�
+                const regex = new RegExp(`${match[0]}(\\d+(\\.\\d+)?)`, 'g')
+                const matchTow = row.tell.match(regex);
+              let right =  Number(matchTow[0].split(match[0])[1])
+              let left = row.ask.substring(row.ask.indexOf(match[0])+1)
+              if(Number(left) != Number(right)) {
+                this.$message.error('妫�娴嬭姹備笉绗﹀悎瑕佹眰鎻忚堪')
+                row.ask = match[0] + right
+              }
+              }
+            }
+            // 濡傛灉瑕佹眰鎻忚堪鍚湁鑼冨洿
+            const regexTwo = /[~-]/
+            const matchTwo = row.tell.match(regexTwo)
+            const matchAsk = row.ask.match(regexTwo)
+            if(matchTwo) {
+              let left = row.tell.substring(0,row.tell.indexOf(matchTwo[0]))
+              let right = row.tell.substring(row.tell.indexOf(matchTwo[0])+1)
+
+
+              if(!isNaN(Number(left)) && !isNaN(Number(right))) {
+                let leftAsk = row.ask.substring(0,row.ask.indexOf(matchAsk[0]))
+                let rightAsk = row.ask.substring(row.ask.indexOf(matchAsk[0])+1)
+                if(Number(leftAsk) != Number(left) || Number(rightAsk) != Number(right)) {
+                  this.$message.error('妫�娴嬭姹備笉绗﹀悎瑕佹眰鎻忚堪')
+                  row.ask = left + '-' + right
+                }
+              }
+            }
+          }
+
         // 鍏堝嬀閫夌殑鎯呭喌涓�
           this.detectionSelect.forEach(item => {
             if(item.id == row.id) {

--
Gitblit v1.9.3