From b50917f4bdf0b05c028d76d8cdbde44a85ec8b91 Mon Sep 17 00:00:00 2001
From: WXL <1785969728@qq.com>
Date: 星期二, 27 八月 2024 16:02:53 +0800
Subject: [PATCH] 测试完成

---
 src/views/knowledge/questionnaire/compilequer/index.vue |  423 +++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 284 insertions(+), 139 deletions(-)

diff --git a/src/views/knowledge/questionnaire/compilequer/index.vue b/src/views/knowledge/questionnaire/compilequer/index.vue
index 6d02685..85d3a9c 100644
--- a/src/views/knowledge/questionnaire/compilequer/index.vue
+++ b/src/views/knowledge/questionnaire/compilequer/index.vue
@@ -242,7 +242,18 @@
       </div>
       <!-- 闂嵎璁剧疆 -->
       <div v-if="Editprogress == 2">
-        <div class="leftvlue-jbxx">闂嵎棰樼洰璁剧疆</div>
+        <div class="leftvlue-jbxx">
+          闂嵎棰樼洰璁剧疆
+          <span style=""
+            ><el-button
+              type="warning"
+              icon="el-icon-finished"
+              round
+              @click="test"
+              >棰樼洰瑙勫垯鏁堥獙</el-button
+            ></span
+          >
+        </div>
         <el-divider></el-divider>
         <div style="display: flex; justify-content: space-between">
           <div>
@@ -349,7 +360,15 @@
                   key="nextScriptno"
                   prop="nextScriptno"
                   :show-overflow-tooltip="true"
-                />
+                >
+                  <template slot-scope="scope">
+                    <span>{{
+                      scope.row.nextScriptno == 0
+                        ? "宸叉槸鏈�鍚庝竴棰�"
+                        : scope.row.nextScriptno
+                    }}</span>
+                  </template>
+                </el-table-column>
 
                 <el-table-column
                   v-if="Operateit"
@@ -405,7 +424,7 @@
                       ></el-input> </el-form-item
                   ></el-col>
                   <el-col :span="12">
-                    <el-form-item label="涓嬮璺宠浆" v-if="!topicobj.branchFlag">
+                    <el-form-item label="涓嬮璺宠浆">
                       <el-input
                         v-model="topicobj.nextScriptno"
                         placeholder="璇疯緭鍏ラ鍙�"
@@ -433,12 +452,16 @@
                         </el-option> </el-select></el-form-item
                   ></el-col>
                   <el-col :span="12">
-                    <el-form-item label="棰樼洰鍒嗘暟">
+                    <el-form-item
+                      label="棰樼洰鍒嗗��"
+                      v-if="topicobj.scoretype == 1"
+                    >
                       <el-input
-                        v-model="topicobj.scriptTopic"
-                        placeholder="璇疯緭鍏ユ爣棰�"
-                      ></el-input> </el-form-item
-                  ></el-col>
+                        v-model="topicobj.score"
+                        placeholder="璇疯緭鍏ラ鍙�"
+                      ></el-input>
+                    </el-form-item>
+                  </el-col>
                 </el-row>
 
                 <el-row :gutter="10">
@@ -465,20 +488,10 @@
                     </el-form-item></el-col
                   >
                 </el-row>
-                <el-row>
-                  <el-col :span="12">
-                    <el-form-item
-                      label="棰樼洰鍒嗗��"
-                      v-if="topicobj.scoretype == 1"
-                    >
-                      <el-input
-                        v-model="topicobj.score"
-                        placeholder="璇疯緭鍏ラ鍙�"
-                      ></el-input>
-                    </el-form-item>
-                  </el-col>
-                </el-row>
-                <el-form-item label="鏄惁鐢遍�夐」閰嶇疆璺宠浆">
+                <el-form-item
+                  label="鏄惁鐢遍�夐」閰嶇疆璺宠浆"
+                  v-if="topicobj.scriptType == 1"
+                >
                   <el-radio-group v-model="topicobj.branchFlag">
                     <el-radio :label="1">鏄�</el-radio>
                     <el-radio :label="0">鍚�</el-radio>
@@ -506,7 +519,7 @@
                       <el-col :span="8">
                         <el-form-item
                           v-if="topicobj.scoretype == 1"
-                          label="鍒嗗��"
+                          label="閫夐」鍒嗗��"
                         >
                           <el-input
                             class="custom-width"
@@ -539,11 +552,12 @@
                         </el-form-item>
                       </el-col>
                     </el-row>
-                    <el-row :gutter="10">
+                    <el-row :gutter="10" v-if="topicobj.branchFlag == 1">
                       <el-col :span="20"
                         ><el-form-item label="涓嬮璺宠浆(搴忓彿)">
                           <el-input
                             type="text"
+                            @blur="branchFlagfn"
                             placeholder="璇疯緭鍏ラ鍙�"
                             v-model="item.nextQuestion"
                             show-word-limit
@@ -635,62 +649,61 @@
         <div class="leftvlue-jbxx">闂嵎棰勮</div>
         <el-divider></el-divider>
         <div class="preview-left">
-          <!-- 鍗曢�� -->
-          <div
-            class="scriptTopic-dev"
-            v-for="item in ruleForm.svyTemplateLibScripts"
-            :key="item.sort"
-            v-if="item.scriptType == 1"
-          >
-            <div class="dev-text">
-              {{ item.sort }}銆乕鍗曢�塢<span>{{ item.scriptContent }}</span>
+          <div v-for="item in ruleForm.svyTemplateLibScripts">
+            <!-- 鍗曢�� -->
+            <div
+              class="scriptTopic-dev"
+              :key="item.sort"
+              v-if="item.scriptType == 1"
+            >
+              <div class="dev-text">
+                {{ item.sort }}銆乕鍗曢�塢<span>{{ item.scriptContent }}</span>
+              </div>
+              <div class="dev-xx">
+                <el-radio-group v-model="item.remark">
+                  <el-radio
+                    v-for="(items, index) in item.svyLibTemplateTargetoptions"
+                    :key="index"
+                    :label="index"
+                    >{{ items.optioncontent }}</el-radio
+                  >
+                </el-radio-group>
+              </div>
             </div>
-            <div class="dev-xx">
-              <el-radio-group v-model="item.remark">
-                <el-radio
-                  v-for="(items, index) in item.svyLibTemplateTargetoptions"
-                  :key="index"
-                  :label="index"
-                  >{{ items.optioncontent }}</el-radio
-                >
-              </el-radio-group>
+            <!-- 澶氶�� -->
+            <div
+              class="scriptTopic-dev"
+              :key="item.sort"
+              v-if="item.scriptType == 2"
+            >
+              <div class="dev-text">
+                {{ item.sort }}銆乕澶氶�塢<span>{{ item.scriptContent }}</span>
+              </div>
+              <div class="dev-xx">
+                <el-checkbox-group v-model="qremark">
+                  <el-checkbox
+                    v-for="(items, index) in item.svyLibTemplateTargetoptions"
+                    :key="index"
+                    :label="index"
+                  >
+                    {{ items.optioncontent }}
+                  </el-checkbox>
+                </el-checkbox-group>
+              </div>
             </div>
-          </div>
-          <!-- 澶氶�� -->
-          <div
-            class="scriptTopic-dev"
-            v-for="item in ruleForm.svyTemplateLibScripts"
-            :key="item.sort"
-            v-if="item.scriptType == 2"
-          >
-            <div class="dev-text">
-              {{ item.sort }}銆乕澶氶�塢<span>{{ item.scriptContent }}</span>
-            </div>
-            <div class="dev-xx">
-              <el-checkbox-group v-model="qremark">
-                <el-checkbox
-                  v-for="(items, index) in item.svyLibTemplateTargetoptions"
-                  :key="index"
-                  :label="index"
-                >
-                  {{ items.optioncontent }}
-                </el-checkbox>
-              </el-checkbox-group>
-            </div>
-          </div>
-          <!-- 濉┖ -->
-          <div
-            class="scriptTopic-dev"
-            v-for="item in ruleForm.svyTemplateLibScripts"
-            :key="item.sort"
-            v-if="item.scriptType == 3"
-          >
-            <div class="dev-text">
-              {{ item.sort }}銆乕濉┖]<span>{{ item.scriptContent }}</span>
-            </div>
-            <div class="dev-xx">
-              <el-input placeholder="璇疯緭鍏ョ瓟妗�" v-model="radioas" clearable>
-              </el-input>
+            <!-- 濉┖ -->
+            <div
+              class="scriptTopic-dev"
+              :key="item.sort"
+              v-if="item.scriptType == 3"
+            >
+              <div class="dev-text">
+                {{ item.sort }}銆乕濉┖]<span>{{ item.scriptContent }}</span>
+              </div>
+              <div class="dev-xx">
+                <el-input placeholder="璇疯緭鍏ョ瓟妗�" v-model="radioas" clearable>
+                </el-input>
+              </div>
             </div>
           </div>
         </div>
@@ -1487,13 +1500,10 @@
       this.sortFn();
     },
     sortFn() {
-      console.log(this.ruleForm.svyTemplateLibScripts, "搴忓墠鍊�");
       this.ruleForm.svyTemplateLibScripts.forEach((item, index) => {
         item.sort = Number(index) + 1;
-        console.log(this.ruleForm.svyTemplateLibScripts.length, "length");
-
         if (item.sort == this.ruleForm.svyTemplateLibScripts.length) {
-          item.nextScriptno = "宸叉槸鏈�鍚庝竴棰�";
+          item.nextScriptno = 0;
         } else {
           item.nextScriptno = item.sort + 1;
         }
@@ -1626,14 +1636,12 @@
       this.illnessVisible = false;
       this.$modal.msgSuccess("缂栬緫鎴愬姛");
     },
-    // --------------------------
     resetQuery() {
       this.queryParams = { pageNum: 1, pageSize: 10 };
       this.getaddtopiclist();
     },
-    resetForm(formName) {
-      this.$refs[formName].resetFields();
-    },
+
+    // --------------------------
     // 闂嵎鍒嗘暟闄愬埗绠楁硶
     // 娣峰悎璺嚎
     generateCombinations(arrays, currentIndex = 0, currentCombination = []) {
@@ -1657,16 +1665,13 @@
     },
     // 鎵ц
     test() {
-      const arrays = [
-        ["2", "3", "4", "5"],
-        ["1", "2", "5", "6"],
-        ["3", "4", "5", "3"],
-        ["3", "2", "5", "7"],
-      ];
+      console.log(this.ruleForm.svyTemplateLibScripts);
+
       const arraysa = [
         {
           id: 1,
-          grade: "5",
+          Topicjump: "2",
+          branchFlag: "0",
           arr: [
             { name: "涓嶉敊", skip: 2 },
             { name: "涓�鑸�", skip: 2 },
@@ -1677,86 +1682,217 @@
 
         {
           id: 2,
-          grade: "5",
+          Topicjump: "4",
+          branchFlag: "1",
           arr: [
-            { name: "浼樼", skip: 3 },
+            { name: "浼樼", skip: 4 },
             { name: "鑹ソ", skip: 3 },
             { name: "涓�鑸�", skip: 3 },
-            { name: "杈冨樊", skip: 4 },
+            { name: "杈冨樊", skip: 3 },
           ],
         },
         {
           id: 3,
-          grade: "5",
+          Topicjump: "4",
+          branchFlag: "1",
           arr: [
             { name: "鏄殑", skip: 4 },
-            { name: "涓嶆竻妤�", skip: 4 },
+            { name: "涓嶆竻妤�", skip: 5 },
             { name: "杩樺彲", skip: 4 },
             { name: "涓�鑸�", skip: 4 },
           ],
         },
         {
           id: 4,
-          grade: "5",
+          Topicjump: "5",
+          branchFlag: "0",
+          bac: null,
+        },
+        {
+          id: 5,
+          Topicjump: "0",
+          branchFlag: "0",
           arr: [
-            { name: "鐪熶笉閿�", skip: null },
-            { name: "杩樺彲浠�", skip: null },
-            { name: "涓�鑸埇", skip: null },
-            { name: "涓嶆竻妤�", skip: null },
+            { name: "鐪熶笉閿�", skip: 0 },
+            { name: "杩樺彲浠�", skip: 0 },
+            { name: "涓�鑸埇", skip: 0 },
+            { name: "涓嶆竻妤�", skip: 0 },
           ],
         },
       ];
 
-      // const newMixArray = this.generateCombinations(arrays);
-      const newMixArray = this.getExecutionOrders(arraysa);
-
+      const csnewMixArray = this.csgetExecutionOrders(arraysa);
+      console.log(csnewMixArray, "娴嬭瘯鍏ㄩ儴璺嚎");
+      const newMixArray = this.getExecutionOrders(
+        this.ruleForm.svyTemplateLibScripts
+      );
       console.log(newMixArray, "鍏ㄩ儴璺嚎");
-      this.screen(newMixArray);
+      this.sumArray(newMixArray);
     },
-    getExecutionOrders(data) {
-      let orders = [];
+    // 閬嶅巻鏂规硶
+    csgetExecutionOrders(arrays) {
+      const allPaths = [];
+      const findPath = (currentId, path) => {
+        const current = arrays.find((item) => item.id.toString() === currentId);
+        if (!current) return;
+        path.push(current);
 
-      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]);
-            }
+        if (current.branchFlag === "1") {
+          current.arr.forEach((option) => {
+            findPath(option.skip.toString(), path.slice());
           });
         } else {
-          orders.push(
-            currentOrder.map((id) => ({
-              id: data[id].id,
-              grade: data[id].grade,
-            }))
-          );
+          const nextId = parseInt(current.Topicjump);
+          if (nextId !== 0) {
+            findPath(nextId.toString(), path.slice());
+          } else {
+            allPaths.push(path.slice());
+          }
         }
       };
-      console.log(data, "data");
-      data.forEach((entry) => {
-        explore([entry.id], entry.id);
-      });
 
-      return orders;
+      findPath("1", []);
+      return allPaths;
+    },
+    // 閬嶅巻鏂规硶
+    getExecutionOrders(arrays) {
+      const allPaths = [];
+      const findPath = (currentId, path) => {
+        const current = arrays.find(
+          (item) => item.sort.toString() === currentId
+        );
+        if (!current) return;
+        path.push(current);
+
+        if (current.branchFlag == "1") {
+          current.svyLibTemplateTargetoptions.forEach((option) => {
+            findPath(option.nextQuestion.toString(), path.slice());
+          });
+        } else {
+          const nextId = parseInt(current.nextScriptno);
+          if (nextId !== 0) {
+            findPath(nextId.toString(), path.slice());
+          } else {
+            allPaths.push(path.slice());
+          }
+        }
+      };
+
+      findPath("1", []);
+      return allPaths;
     },
 
     // 鏁扮粍姹傚拰
     sumArray(arr) {
-      return arr.reduce((acc, curr) => acc + parseInt(curr), 0);
-    },
-    // 绛涢�夐敊璇矾绾�
-    screen(data) {
-      const arraysGreaterThan10 = data.filter((arr) => this.sumArray(arr) > 21);
+      // const arrsum = arr;
+      // arrsum.forEach((item) => {
+      //   // 鍒ゆ柇棰樼洰鍜屾ā鐗堝眰绾�
+      //   console.log(item, "涓�鏉¢摼璺�");
 
-      console.log(arraysGreaterThan10, "绛涢�夐敊璇矾绾垮ぇ浜�13鍒�");
+      //   const totalScore = item.reduce((accumulator, current) => {
+      //     return accumulator + Number(current.score);
+      //   }, 0);
+      //   console.log(totalScore);
+      //   console.log(this.ruleForm.scriptScore);
+
+      //   if (totalScore == this.ruleForm.scriptScore) {
+      //     this.ClaimNofn(arr);
+      //     this.$modal.msgSuccess("鍒嗘暟鏍搁獙鎴愬姛");
+      //   }
+      // });
+
+      const allGreaterThanTen = arr.every((array) => {
+        const totalScore = array.reduce((accumulator, current) => {
+          return accumulator + current.score;
+        }, 0);
+        return totalScore == this.ruleForm.scriptScore;
+      });
+      if (allGreaterThanTen) {
+        this.$modal.msgSuccess("棰樼洰鍒嗗�肩疮鍔犲拰妯$増鎬诲垎鐩哥");
+      } else {
+        this.$modal.msgError("棰樼洰鍒嗗�肩疮鍔犲拰妯$増鍒嗗�间笉绗�");
+      }
     },
+
+    // 閬嶅巻鏄惁閲嶅鏄惁閮界敤涓�
+    ClaimNofn(arr) {
+      arr.forEach((item) => {
+        const Aarr = item;
+        const Barr = this.ruleForm.svyTemplateLibScripts;
+        const notInB = A.filter(
+          (itemA) => !B.some((itemB) => itemB.id === itemA.id)
+        );
+
+        if (notInB.length) {
+          this.$modal.msgError("棰樼洰鏈叏閮ㄤ娇鐢�");
+        } else {
+          this.$modal.msgSuccess("棰樼洰鍏ㄩ儴浣跨敤");
+        }
+      });
+      arr.forEach((item) => {
+        const idCount = arr.reduce((acc, item) => {
+          acc[item.id] = (acc[item.id] || 0) + 1;
+          return acc;
+        }, {});
+        const whether = item.values(idCount).some((count) => count > 1); // 濡傛灉鏈変换浣� id 鐨勮鏁板ぇ浜� 1 灏辫繑鍥� true
+        if (!whether) this.$modal.msgError("閰嶇疆椤规湁棰樼洰閲嶅");
+      });
+    },
+    // 棰樼洰鍜岄�夐」闂寸殑鍒嗗�煎垽鏂�
+    Scorejudgment() {
+      let scorearr = this.topicobj.svyLibScriptOptions;
+      let isValid = scorearr.every((score, index) => {
+        if (this.topicobj.scriptType == 1) {
+          if (score.score) {
+            if (
+              Number(score.score) < 0 ||
+              Number(score.score) > Number(this.topicobj.score)
+            ) {
+              console.log(score, "閿欒鍒嗗��");
+              this.$message({
+                message: "閫夐」鍒嗗�煎繀椤诲湪0鍒�" + this.topicobj.score + "鍒嗕箣闂�",
+                type: "warning",
+              });
+              return false;
+            }
+            return true;
+          } else {
+            this.$message({
+              message: "閫夐」鍒嗗�兼湭璁剧疆",
+              type: "warning",
+            });
+            return false;
+          }
+        } else if (this.topicobj.scriptType == 2) {
+          // 绱姞鍒嗗��
+          const totalScore = scorearr.reduce((acc, score) => {
+            if (score.score) {
+              return acc + Number(score.score);
+            }
+            return acc; // 濡傛灉 score.score 涓嶅瓨鍦紝涓嶇疮鍔�
+          }, 0);
+
+          // 妫�鏌ョ疮鍔犵殑鍒嗗�兼槸鍚︾瓑浜� this.topicobj.score
+          if (totalScore !== Number(this.topicobj.score)) {
+            this.$message({
+              message:
+                "澶氶�夐閫夐」鍒嗗�兼�诲拰蹇呴』绛変簬 " + this.topicobj.score + " 鍒�",
+              type: "warning",
+            });
+            return false;
+          }
+          return true; // 濡傛灉鎬诲垎姝g‘锛岃繑鍥� true
+        } else if (this.topicobj.scriptType == 4) {
+          return true;
+        }
+      });
+
+      if (isValid) {
+        this.compileissue();
+      }
+    },
+
+    // ---------------------------------------------------------
     // 鏂伴棶棰樻柊澧�
     addoption() {
       if (!this.indexform.svyLibTemplateTargetoptions) {
@@ -1783,6 +1919,13 @@
         this.$forceUpdate();
       } else {
         this.$message.error("鍥剧墖鎻掑叆澶辫触");
+      }
+    },
+    branchFlagfn(row) {
+      console.log(row);
+      if (this.topicobj.branchFlag == 1 && this.topicobj.nextScriptno != 0) {
+        this.topicobj.nextScriptno =
+          this.topicobj.svyLibTemplateTargetoptions[0].nextQuestion;
       }
     },
   },
@@ -1818,6 +1961,8 @@
     font-size: 20px;
   }
   .leftvlue-jbxx {
+    display: flex; /* 浣跨敤 Flexbox 甯冨眬 */
+    justify-content: space-between;
     font-size: 24px;
     border-left: 5px solid #41a1be;
     padding-left: 5px;

--
Gitblit v1.9.3