From a3304021d69b1c9bcb56ccaf9c556edaebc5e5e7 Mon Sep 17 00:00:00 2001
From: gaoluyang <gaoluyang@rengu.cc>
Date: 星期二, 09 七月 2024 15:51:48 +0800
Subject: [PATCH] 模版导出功能开发

---
 src/components/do/b1-inspect-order-plan/Inspection.vue |   98 ++++++++++++++++++++++++++++++-------------------
 1 files changed, 60 insertions(+), 38 deletions(-)

diff --git a/src/components/do/b1-inspect-order-plan/Inspection.vue b/src/components/do/b1-inspect-order-plan/Inspection.vue
index 97a30d6..2769482 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>
+                    <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>
@@ -397,7 +397,7 @@
       </div>
       <div class="center-box" v-loading="tableLoading" v-else>
         <el-divider></el-divider>
-        <h4 style="margin-bottom: 20px;">娓╁害寰幆妫�楠屽師濮嬭褰�</h4>
+        <h4 style="margin-bottom: 20px;font-size: 24px;font-weight: 400;">娓╁害寰幆妫�楠屽師濮嬭褰�</h4>
         <el-form :inline="true" :model="wareForm" class="form-inline" label-width="100px" style="justify-content: flex-start;display: flex;align-items: center;width: 100%;">
         <el-form-item label="鍨嬪彿:" style="margin-bottom: 0;">
           <el-input clearable v-model="wareForm0.model" disabled size="small" placeholder=""></el-input>
@@ -445,7 +445,7 @@
               </el-option>
             </el-select>
           </el-form-item>
-          <el-form-item label="浠櫒鍚嶇О:" style="margin-left: 80px;">
+          <el-form-item label="浠櫒鍚嶇О:" >
             <el-input clearable v-model="equipForm.value1" disabled size="small" placeholder=""></el-input>
           </el-form-item>
           <el-form-item label="浠櫒缂栧彿:">
@@ -524,14 +524,14 @@
             prop="resValue"
             label="琛板噺宸�"
             align="center"
-            v-if="wareForm.inspectionItemSubclass!=20"
+            v-if="wareForm.inspectionItemSubclass!='20(甯告俯)'"
             min-width="150">
           </el-table-column>
           <el-table-column
             prop="insResult"
             label="缁撹"
             align="center"
-            min-width="150" v-if="wareForm.inspectionItemSubclass!=20">
+            min-width="150" v-if="wareForm.inspectionItemSubclass!='20(甯告俯)'">
             <template slot-scope="scope">
               <span v-if="scope.row.insResult===1" style="color: green;">鍚堟牸</span>
               <span v-else-if="scope.row.insResult===0" style="color: red;">涓嶅悎鏍�</span>
@@ -793,7 +793,7 @@
         currentTab:null,
         wareForm:{
           inspectionItem:1,
-          inspectionItemSubclass:20,
+          inspectionItemSubclass:'20(甯告俯)',
         },
         wareForm0:{},
         numOptions:[],
@@ -953,7 +953,7 @@
     methods: {
       changeItem(row){
         if(row.value0&&row.value1){
-          this.$set(row,'comValue',((Number(row.value0)+Number(row.value1))/2).toFixed(5))
+          this.$set(row,'comValue',((Number(row.value0)+Number(row.value1))/2).toFixed(3))
         }else{
           return
         }
@@ -977,8 +977,8 @@
               v:row.comValue
             }
           }]
-        if(this.wareForm.inspectionItemSubclass!=20){
-          row.resValue = row.comValue?Math.abs(row.comValue-20).toFixed(5):''
+        if(this.wareForm.inspectionItemSubclass!='20(甯告俯)'){
+          row.resValue = row.comValue?Math.abs(row.comValue-20).toFixed(3):''
           this.param[row.id].resValue.v.v = row.resValue
           if(row.ask&&row.resValue){
             if(row.ask.includes('<')){
@@ -1005,10 +1005,14 @@
           return
         }
         if(m&&type){
-          this.wareForm[type] = Number(m)
+          this.wareForm[type] = m
         }
         let wareForm = {...this.wareForm}
-        wareForm.inspectionItemSubclass = wareForm.inspectionItemSubclass+'鈩�'
+        if(this.wareForm.inspectionItemSubclass=='20(甯告俯)'){
+          wareForm.inspectionItemSubclass ='20鈩�(甯告俯)'
+        }else{
+          wareForm.inspectionItemSubclass = wareForm.inspectionItemSubclass+'鈩�'
+        }
         this.wareTableDataLoading = true
         this.$axios.post(this.$api.insOrderPlan.temCycle,{
           sampleId:this.currentSample.id,
@@ -1398,7 +1402,7 @@
           this.temperatureOptions = []
           mySet1.forEach(m => {
             this.temperatureOptions.push({
-              value:m,
+              value:String(m),
               label:m
             })
           })
@@ -1433,7 +1437,6 @@
             count++
           })
         })
-        // 闂寮�濮�
         this.tableList.forEach(a => {
           let dels = new Set()
           let ids = []
@@ -1490,7 +1493,6 @@
               }
             }
           })
-          // return
           ids.forEach(id => {
             for (let b = 0; b < a.template.length; b++) {
               if (a.template[b].r === id.r) {
@@ -1525,7 +1527,6 @@
             }
           })
         })
-        // 闂缁撴潫
         this.tableList.forEach(a => {
           let arrs = []
           let set = new Set()
@@ -1676,14 +1677,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
                       }
@@ -1703,36 +1698,43 @@
                 }else{
                   if(ask){
                     comp = ask.map((m, i) => {
+                      if (m.includes('RTS')) {
+                        m = m.replace('RTS*', '')
+                      }
                       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)
                       }
                     })
                   }
@@ -1752,7 +1754,13 @@
               let comResult = ''
               try {
                 if(this.getInspectionValueType(item.i)==1){
+                  let ask = this.currentSample.insProduct.find(m => m.id == item.i).ask?this.currentSample.insProduct.find(m => m.id == item.i).ask.split('&'):null;
                   comResult = excelFunction.compute(item.v.f.replace(/=/g, ' '),comValue)
+                  // 瑁呭椤圭洰妫�楠屽�艰浆鍖�
+                  if (this.PROJECT === '瑁呭鐢电紗' && ask[0].includes('RTS')) {
+                    let num2 = new this.$Big(comResult)
+                    comResult = num2.toExponential()
+                  }
                 }else{
                   let valueList = [];
                   item.valueList.forEach(a => {
@@ -1762,7 +1770,6 @@
                       value: 0,
                     })
                   })
-                  console.log(comValue)
                   for (var a in comValue) {
                     valueList.forEach(b => {
                       if (b.name == a) {
@@ -1806,6 +1813,20 @@
           this.getCurrentInsProduct(pId)
         } catch (error) {
 
+        }
+      },
+      handleFraction(str){
+        if(str&&typeof(str)=='string'&&str.includes('/')){
+          return eval(str.split('/')[0]/str.split('/')[1])
+        } else if (str && typeof(str) == 'string' && str.includes('*') && str.includes('^')) {
+          const num1 = str.split('*')
+          const num2 = num1[1].split('^')
+          let num3 = new this.$Big(num2[0]);
+          let num4 = new this.$Big(num2[1]);
+          let num5 = Math.pow(num3, num4) // 璁$畻娆℃柟
+          return num1[0] * num5 // 鏈�鍚庤绠椾箻娉�
+        } else{
+          return str
         }
       },
       getCurrentInsProduct(pId) {
@@ -1896,7 +1917,8 @@
           }
       },
       getValue(v){
-        let str = v.v?v.v:(v.ct&&v.ct.s?v.ct.s.length>0&&v.ct.s[0].v:'').replaceAll('\n','<br/>')
+        let str = v.v?v.v:(v.ct&&v.ct.s?v.ct.s.length>0&&v.ct.s[0].v.replace(new RegExp('\n', 'g'), '<br/>'):'')
+        // str.replace(new RegExp(search, 'g'), replace)
         return str
       },
       getInspectionValueType(id) {
@@ -1926,7 +1948,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