From 76c30727c77065c808b1c0fb3146080e423e5fe6 Mon Sep 17 00:00:00 2001
From: WXL <1785969728@qq.com>
Date: 星期四, 27 六月 2024 09:45:30 +0800
Subject: [PATCH] 测试完成

---
 src/views/knowledge/questionnaire/compilequer/index.vue |  255 +++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 209 insertions(+), 46 deletions(-)

diff --git a/src/views/knowledge/questionnaire/compilequer/index.vue b/src/views/knowledge/questionnaire/compilequer/index.vue
index 524e8af..bcfe6f8 100644
--- a/src/views/knowledge/questionnaire/compilequer/index.vue
+++ b/src/views/knowledge/questionnaire/compilequer/index.vue
@@ -320,8 +320,8 @@
                 <el-table-column
                   label="搴忓彿"
                   align="center"
-                  key="guid"
-                  prop="guid"
+                  key="sort"
+                  prop="sort"
                 />
                 <el-table-column
                   label="棰樼洰鏍囬"
@@ -433,26 +433,37 @@
                   v-for="item in topicobj.svyLibTemplateTargetoptions"
                 >
                   <el-row :gutter="10">
-                    <el-col :span="11"
-                      ><el-form-item label="棰樺彿">
+                    <el-col :span="11">
+                      <el-form-item v-if="topicobj.scoretype == 1" label="鍒嗗��">
                         <el-input
                           type="text"
-                          placeholder="璇疯緭鍏�"
-                          v-model="item.id"
-                          show-word-limit
-                        >
-                        </el-input> </el-form-item
-                    ></el-col>
-                    <el-col :span="11"
-                      ><el-form-item label="鍒嗗��">
-                        <el-input
-                          type="text"
-                          placeholder="璇疯緭鍏�"
+                          placeholder="璇疯緭鍏ラ�夐」鍒嗗��"
                           v-model="item.score"
                           show-word-limit
                         >
-                        </el-input> </el-form-item
-                    ></el-col>
+                        </el-input>
+                      </el-form-item>
+                      <el-form-item
+                        v-else-if="topicobj.scoretype == 2"
+                        label="ABC绛夌骇"
+                      >
+                        <el-radio-group v-model="item.score">
+                          <el-radio label="A">A</el-radio>
+                          <el-radio label="B">B</el-radio>
+                          <el-radio label="C">C</el-radio>
+                        </el-radio-group>
+                      </el-form-item>
+                      <el-form-item
+                        v-else-if="topicobj.scoretype == 3"
+                        label="浼樿壇绛夌骇"
+                      >
+                        <el-radio-group v-model="item.score">
+                          <el-radio label="浼�">浼�</el-radio>
+                          <el-radio label="鑹�">鑹�</el-radio>
+                          <el-radio label="宸�">宸�</el-radio>
+                        </el-radio-group>
+                      </el-form-item>
+                    </el-col>
                   </el-row>
                   <el-row :gutter="10">
                     <el-col :span="11"
@@ -470,19 +481,19 @@
                         <el-input
                           type="text"
                           placeholder="璇疯緭鍏ラ鍙�"
-                          v-model="item.jump"
+                          v-model="item.nextQuestion"
                           show-word-limit
                         >
                         </el-input> </el-form-item
                     ></el-col>
-                    <el-col :span="2">
+                    <!-- <el-col :span="2">
                       <el-button
                         type="danger"
                         icon="el-icon-delete"
                         circle
                         @click="deletexuanx(item)"
                       ></el-button>
-                    </el-col>
+                    </el-col> -->
                   </el-row>
                   <el-row :gutter="10">
                     <el-form-item label="閫変腑鎻愮ず">
@@ -686,7 +697,7 @@
       topicobj: {},
       // 鎬绘潯鏁�
       total: 1,
-      ruleForm: {},
+      ruleForm: { svyLibScripts: [], tempDetpRelevances: [] },
       rules: {},
       rulesa: {},
       optionsclass: [], //鍒嗙被鍒楄〃
@@ -746,14 +757,38 @@
       tempDetpRelevanceslist: [],
       optionstag: [],
       valuetype: [],
-      usable: [],
-      required: [],
+      usable: [
+        { value: "0", label: "鍙敤" },
+        { value: "1", label: "鍋滅敤" },
+      ],
+      required: [
+        { value: "1", label: "蹇呭~" },
+        { value: "2", label: "涓嶅繀濉�" },
+      ],
       mode: [], //鏂瑰紡
       // 鏌ヨ鍙傛暟
       queryParams: {
         pageNum: 1,
         pageSize: 10,
       },
+      arr: [
+        [
+          { id: 1, grade: "5" },
+          { id: 2, grade: "5" },
+          { id: 3, grade: "5" },
+          { id: 4, grade: "5" },
+        ],
+        [
+          { id: 1, grade: "5" },
+          { id: 3, grade: "5" },
+          { id: 4, grade: "5" },
+        ],
+        [
+          { id: 1, grade: "5" },
+          { id: 2, grade: "5" },
+          { id: 4, grade: "5" },
+        ],
+      ],
     };
   },
 
@@ -766,6 +801,7 @@
     this.required = store.getters.required;
     this.valuetype = store.getters.valuetype;
     this.courtyardlist = store.getters.courtyardlist;
+    this.test();
   },
 
   methods: {
@@ -791,21 +827,23 @@
     // 鑾峰彇鏁版嵁
     getissueinfo() {
       this.id = this.$route.query.id;
-      getQtemplatelist({ svyid: this.id }).then((res) => {
-        this.ruleForm = res.rows[0];
-        this.dynamicTags = this.ruleForm.labelInfo.split(",");
-        this.tempDetpRelevanceslist = JSON.parse(this.ruleForm.deptNames);
-        this.ruleForm.suitway = this.ruleForm.suitway.split(",");
-        console.log(this.tempDetpRelevanceslist);
-      });
+      if (this.id) {
+        getQtemplatelist({ svyid: this.id }).then((res) => {
+          this.ruleForm = res.rows[0];
+          this.dynamicTags = this.ruleForm.labelInfo.split(",");
+          this.tempDetpRelevanceslist = JSON.parse(this.ruleForm.deptNames);
+          this.ruleForm.suitway = this.ruleForm.suitway.split(",");
+          console.log(this.tempDetpRelevanceslist);
+        });
+        getillness({ outid: this.id, type: 5 }).then((res) => {
+          this.illnesslist = res.rows;
+        });
+      }
       getillnesslist({
         pageNum: 1,
         pageSize: 100,
       }).then((response) => {
         this.optionsillness = response.rows;
-      });
-      getillness({ outid: this.id, type: 5 }).then((res) => {
-        this.illnesslist = res.rows;
       });
       listDept(this.queryParams).then((response) => {
         this.deptList = this.handleTree(response.data, "deptId");
@@ -824,16 +862,19 @@
 
       if (this.id) {
         this.ruleForm.isoperation = 2;
-        compileQtemplate(this.ruleForm).then((response) => {
+        compileQtemplate(this.ruleForm).then((res) => {
           this.$modal.msgSuccess("淇敼鎴愬姛");
+          this.confirmillness();
           this.$modal.closeLoading();
 
           this.$router.go(-1);
         });
       } else {
         this.ruleForm.isoperation = 1;
-        compileQtemplate(this.ruleForm).then((response) => {
+        compileQtemplate(this.ruleForm).then((res) => {
           this.$modal.msgSuccess("鏂板鎴愬姛");
+          this.confirmillness(res.data);
+
           this.$modal.closeLoading();
 
           this.$router.go(-1);
@@ -847,6 +888,7 @@
       this.ruleForm.svyLibScripts = this.ruleForm.svyLibScripts.concat(
         this.delScriptVOList
       );
+      console.log(this.tempDetpRelevanceslist, "this.tempDetpRelevanceslist");
       const result = this.tempDetpRelevanceslist.map(
         (subArr) => subArr[subArr.length - 1]
       );
@@ -906,6 +948,7 @@
     // 鑾峰彇棰樼洰鍒楄〃
     getaddtopiclist() {
       this.drawer = true;
+      this.queryParams.scoretype = this.ruleForm.scoreType;
       getissuelist(this.queryParams).then((res) => {
         this.loading = false;
         this.userList = res.rows;
@@ -919,6 +962,7 @@
       row.svyLibScriptOptions.forEach((item) => {
         item.isoperation = 1;
       });
+      row.svyLibTemplateTargetoptions = row.svyLibScriptOptions;
       this.ruleForm.svyLibScripts.push(row);
       this.$modal.msgSuccess("鏂板鎴愬姛");
     },
@@ -948,16 +992,9 @@
       this.sortFn();
     },
     sortFn() {
-      this.ruleForm.svyLibScripts = this.ruleForm.svyLibScripts.map(
-        (item, index) => {
-          return {
-            guid: index + 1,
-            svyid: item.svyid,
-            script: item.script,
-            script: item.script,
-          };
-        }
-      );
+      this.ruleForm.svyLibScripts.forEach((item, index) => {
+        item.sort = index + 1;
+      });
       console.log(this.ruleForm.svyLibScripts);
     },
 
@@ -1086,8 +1123,11 @@
       this.inputValueillness = "";
     },
     // 淇濆瓨
-    confirmillness() {
+    confirmillness(guid) {
       this.illnesslist.forEach((item, index) => {
+        if (guid) {
+          item.outid = guid;
+        }
         if (!item.id) {
           addtargetillness(item).then((res) => {});
         }
@@ -1106,6 +1146,129 @@
     resetForm(formName) {
       this.$refs[formName].resetFields();
     },
+    // 闂嵎鍒嗘暟闄愬埗绠楁硶
+    // 娣峰悎璺嚎
+    generateCombinations(arrays, currentIndex = 0, currentCombination = []) {
+      if (currentIndex === arrays.length) {
+        return [currentCombination];
+      }
+
+      const currentArray = arrays[currentIndex];
+      const newCombinations = [];
+
+      for (const item of currentArray) {
+        const newCombination = [...currentCombination, item];
+        const combinations = this.generateCombinations(
+          arrays,
+          currentIndex + 1,
+          newCombination
+        );
+        newCombinations.push(...combinations);
+      }
+      return newCombinations;
+    },
+    // 鎵ц
+    test() {
+      const arrays = [
+        ["2", "3", "4", "5"],
+        ["1", "2", "5", "6"],
+        ["3", "4", "5", "3"],
+        ["3", "2", "5", "7"],
+      ];
+      const arraysa = [
+        {
+          id: 1,
+          grade: "5",
+          arr: [
+            { name: "涓嶉敊", skip: 2 },
+            { name: "涓�鑸�", skip: 2 },
+            { name: "杩樹笉閿�", skip: 2 },
+            { name: "寰堟", skip: 3 },
+          ],
+        },
+
+        {
+          id: 2,
+          grade: "5",
+          arr: [
+            { name: "浼樼", skip: 3 },
+            { name: "鑹ソ", skip: 3 },
+            { name: "涓�鑸�", skip: 3 },
+            { name: "杈冨樊", skip: 4 },
+          ],
+        },
+        {
+          id: 3,
+          grade: "5",
+          arr: [
+            { name: "鏄殑", skip: 4 },
+            { name: "涓嶆竻妤�", skip: 4 },
+            { name: "杩樺彲", skip: 4 },
+            { name: "涓�鑸�", skip: 4 },
+          ],
+        },
+        {
+          id: 4,
+          grade: "5",
+          arr: [
+            { name: "鐪熶笉閿�", skip: null },
+            { name: "杩樺彲浠�", skip: null },
+            { name: "涓�鑸埇", skip: null },
+            { name: "涓嶆竻妤�", skip: null },
+          ],
+        },
+      ];
+
+      // const newMixArray = this.generateCombinations(arrays);
+      const newMixArray = this.getExecutionOrders(arraysa);
+
+      console.log(newMixArray, "鍏ㄩ儴璺嚎");
+      this.screen(newMixArray);
+    },
+    getExecutionOrders(data) {
+      let orders = [];
+
+      const explore = (currentOrder, id) => {
+        console.log(currentOrder, "currentOrder", id);
+        const currentQuestion = data[currentOrder[currentOrder.length - 1]];
+        if (
+          currentQuestion.arr.some(
+            (option) =>
+              option.skip !== null && !currentOrder.includes(option.skip)
+          )
+        ) {
+          currentQuestion.arr.forEach((option) => {
+            if (option.skip !== null && !currentOrder.includes(option.skip)) {
+              explore([...currentOrder, option.skip]);
+            }
+          });
+        } else {
+          orders.push(
+            currentOrder.map((id) => ({
+              id: data[id].id,
+              grade: data[id].grade,
+            }))
+          );
+        }
+      };
+      console.log(data, "data");
+      data.forEach((entry) => {
+        explore([entry.id], entry.id);
+      });
+
+      return orders;
+    },
+
+    // 鏁扮粍姹傚拰
+    sumArray(arr) {
+      return arr.reduce((acc, curr) => acc + parseInt(curr), 0);
+    },
+    // 绛涢�夐敊璇矾绾�
+    screen(data) {
+      const arraysGreaterThan10 = data.filter((arr) => this.sumArray(arr) > 21);
+
+      console.log(arraysGreaterThan10, "绛涢�夐敊璇矾绾垮ぇ浜�13鍒�");
+    },
   },
 };
 </script>

--
Gitblit v1.9.3