From 09ee2efd8bc38d82aa01e2c0d77b84d398f606b2 Mon Sep 17 00:00:00 2001
From: licp <lichunping@guanfang.com.cn>
Date: 星期四, 04 七月 2024 16:26:03 +0800
Subject: [PATCH] 要求值是分数

---
 src/components/do/b1-inspect-order-plan/Inspection.vue |   49 +++++++++++++++++++++++++++----------------------
 1 files changed, 27 insertions(+), 22 deletions(-)

diff --git a/src/components/do/b1-inspect-order-plan/Inspection.vue b/src/components/do/b1-inspect-order-plan/Inspection.vue
index b3646f8..7e56d4e 100644
--- a/src/components/do/b1-inspect-order-plan/Inspection.vue
+++ b/src/components/do/b1-inspect-order-plan/Inspection.vue
@@ -324,7 +324,7 @@
                       <el-option label="鍚堟牸" :value="1"></el-option>
                       <el-option label="涓嶅悎鏍�" :value="0"></el-option>
                     </el-select>
-                    <template v-if="PROJECT=='妫�娴嬩腑蹇�'||PROJECT=='瑁呭鐢电紗'&&((!getInspectionValueType(n.i) == 2 && !getInspectionValueType(n.i) == 5))||state!=1">
+                    <template v-if="PROJECT=='妫�娴嬩腑蹇�'||PROJECT=='瑁呭鐢电紗'&&getInspectionValueType(n.i) != 2 ">
                       <span v-if="n.v.v===1" :style="`font-family:${n.v.ff} !important;color: green;`">鍚堟牸</span>
                       <span v-else-if="n.v.v===0" :style="`font-family:${n.v.ff} !important;color: red;`">涓嶅悎鏍�</span>
                       <span v-else :style="`font-family:${n.v.ff} !important;`">寰呭畾</span>
@@ -1676,14 +1676,8 @@
                           break
                         }
                       }
-                      if(this.getInspectionValueType(item.i)==1){
-                        if (!isNaN(parseFloat(c.v.v))) {
-                          if(c.v.v.includes('^') || c.v.v.includes('/')){
-                            comValue[(tableCode + (c.r + 1))] = c.v.v
-                          }else{
-                            comValue[(tableCode + (c.r + 1))] = parseFloat(c.v.v)
-                          }
-                        }
+                      if(this.getInspectionValueType(item.i)==1&&!isNaN(parseFloat(c.v.v))){
+                        comValue[(tableCode + (c.r + 1))] = parseFloat(c.v.v)
                       }else{
                         comValue[(tableCode + (c.r + 1))] = c.v.v
                       }
@@ -1704,35 +1698,39 @@
                   if(ask){
                     comp = ask.map((m, i) => {
                       if (m.includes('=')) {
-                        let str = m.split('=')[1]
-                        console.log(res,str)
+                        let str = this.handleFraction(m.split('=')[1])
                         if(typeof res == 'string'&&typeof str == 'string'){
-                          console.log(res,str)
                           return  res.trim() == str.trim()
                         }else{
                           return  eval(res) == eval(str)
                         }
                       } else if (m.includes('鈮�')) {
-                        return eval(res) >= eval(m.split('鈮�')[1])
+                        let str = this.handleFraction(m.split('鈮�')[1])
+                        return eval(res) >= eval(str)
                       }else if (m.includes('鈮�')) {
-                        return eval(res) <= eval(m.split('鈮�')[1])
+                        let str = this.handleFraction(m.split('鈮�')[1])
+                        return eval(res) <= eval(str)
                       }else if (m.includes('<')) {
-                        return  eval(res) < eval(m.split('<')[1])
+                        let str = this.handleFraction(m.split('<')[1])
+                        return  eval(res) < eval(str)
                       }else if (m.includes('>')) {
-                        return  eval(res) > eval(m.split('>')[1])
+                        let str = this.handleFraction(m.split('>')[1])
+                        return  eval(res) > eval(str)
                       }else if (m.includes('~')) {
                         let k = m.split('~')
-                        return  eval(res) >= eval(k[0]) && eval(res) <= eval(k[1])
+                        return  eval(res) >= eval(this.handleFraction((k[0]))) && eval(res) <= eval(this.handleFraction(k[1]))
                       }else if(m.includes('-')){
                         let k = m.split('-')
-                        return  eval(res) >= eval(k[0]) && eval(res) <= eval(k[1])
+                        return  eval(res) >= eval(this.handleFraction(k[0])) && eval(res) <= eval(this.handleFraction(k[1]))
                       }else if(m.includes('卤')){
                         let k = m.split('卤')
-                        return  eval(res) >= eval((k[0] - k[1])) && eval(res) <= eval((k[0] + k[1]))
+                        return  eval(res) >= eval((this.handleFraction(k[0]) - this.handleFraction(k[1]))) && eval(res) <= eval((this.handleFraction(k[0]) + this.handleFraction(k[1])))
                       }else if(m.includes('锛�')){
-                        return  eval(res) > eval(m.split('锛�')[1])
+                        let str = this.handleFraction(m.split('锛�')[1])
+                        return  eval(res) > eval(str)
                       }else if(m.includes('锛�')){
-                        return  eval(res) < eval(m.split('锛�')[1])
+                        let str = this.handleFraction(m.split('锛�')[1])
+                        return  eval(res) < eval(str)
                       }
                     })
                   }
@@ -1806,6 +1804,13 @@
           this.getCurrentInsProduct(pId)
         } catch (error) {
 
+        }
+      },
+      handleFraction(str){
+        if(str&&typeof(str)=='string'&&str.includes('/')){
+          return eval(str.split('/')[0]/str.split('/')[1])
+        }else{
+          return str
         }
       },
       getCurrentInsProduct(pId) {
@@ -1926,7 +1931,7 @@
         return sum
       },
       handleInput (n) {
-        n.v.v = n.v.v.replace(/[^\d.^e\-/]/g, '');
+        n.v.v = n.v.v.replace(/[^\d.^e\-/+]/g, '');
       },
       bigNum (n) {
         if (n.v.v > 10000 && this.PROJECT === '瑁呭鐢电紗') {

--
Gitblit v1.9.3