From 510b43356f18aa5be351a0990c7cdc1d4478b5e7 Mon Sep 17 00:00:00 2001
From: WXL <1785969728@qq.com>
Date: 星期三, 09 七月 2025 14:27:00 +0800
Subject: [PATCH] 测试完成
---
 src/views/knowledge/questionnaire/index.vue |  329 ++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 218 insertions(+), 111 deletions(-)
diff --git a/src/views/knowledge/questionnaire/index.vue b/src/views/knowledge/questionnaire/index.vue
index 68dbafc..317ed99 100644
--- a/src/views/knowledge/questionnaire/index.vue
+++ b/src/views/knowledge/questionnaire/index.vue
@@ -3,8 +3,8 @@
     <!-- 宸︿晶鏍� -->
     <div class="sidecolumn">
       <div class="sidecolumn-top">
-        <div class="top-wj">闂嵎绫诲瀷</div>
-        <div class="top-tj" @click="dialogFormVisible = true">+娣诲姞</div>
+        <div class="top-wj">闂嵎鍒嗙被</div>
+        <div class="top-tj" @click="Newcategory">+娣诲姞</div>
       </div>
       <div class="center-ss">
         <el-input
@@ -29,7 +29,7 @@
         >
           <span class="custom-tree-node" slot-scope="{ node, data }">
             <span>{{ node.label }}</span>
-            <span v-if="node.id > 0">
+            <span v-if="data.id > 0">
               <el-button
                 type="text"
                 icon="el-icon-delete"
@@ -37,6 +37,17 @@
                 size="mini"
                 @click="() => remove(node, data)"
               >
+              </el-button>
+            </span>
+            <span v-if="data.id > 0">
+              <el-button
+                type="text"
+                circle
+                size="mini"
+                @click="() => altertag(node, data)"
+                ><span class="button-textxg"
+                  ><i class="el-icon-edit-outline"></i
+                ></span>
               </el-button>
             </span>
           </span>
@@ -57,75 +68,60 @@
               v-show="showSearch"
               label-width="98px"
             >
-              <el-form-item label="闂嵎鍚嶇О" prop="userName">
+              <el-form-item label="闂嵎鍚嶇О" prop="svyname">
                 <el-input
-                  v-model="queryParams.userName"
+                  v-model="queryParams.svyname"
                   placeholder="璇疯緭鍏�"
                   clearable
                   style="width: 200px"
                   @keyup.enter.native="handleQuery"
                 />
               </el-form-item>
-              <el-form-item label="閫傜敤绉戝" prop="region">
-                <el-cascader
-                  v-model="queryParams.administrative"
-                  :options="deptList"
-                  :props="props"
-                  :show-all-levels="false"
-                  clearable
-                >
-                  <template slot-scope="{ node, data }">
-                    <span>{{ data.deptName }}</span>
-                    <span v-if="!node.isLeaf">
-                      ({{ data.children.length }})
-                    </span>
-                  </template>
-                </el-cascader>
-              </el-form-item>
-              <el-form-item label="閫氱煡鍐呭" prop="userName">
-                <el-input
-                  v-model="queryParams.userNamevalue"
-                  placeholder="璇疯緭鍏�"
-                  clearable
-                  style="width: 200px"
-                  @keyup.enter.native="handleQuery"
-                />
-              </el-form-item>
-              <el-form-item label="閫傜敤鏂瑰紡" prop="shape">
-                <el-cascader
-                  v-model="queryParams.shapevalue"
-                  :options="editableTabs"
-                  :props="propss"
-                  clearable
-                ></el-cascader>
-              </el-form-item>
-              <el-form-item label="鍐呭褰㈠紡" prop="classify">
+              <el-form-item label="閫傜敤闄㈠尯" prop="region">
                 <el-select
-                  v-model="queryParams.classifyvalue"
-                  placeholder="璇烽�夋嫨"
+                  v-model="campus"
+                  size="medium"
+                  multiple
+                  filterable
+                  placeholder="璇烽�夋嫨鍒嗙被"
                 >
                   <el-option
-                    v-for="(item, index) in editableTabs"
-                    :key="index++"
-                    :label="item.title"
-                    :value="index++"
+                    v-for="item in courtyardlist"
+                    :key="item.label"
+                    :label="item.label"
+                    :value="item.label"
                   >
                   </el-option>
                 </el-select>
               </el-form-item>
+              <el-form-item label="闂嵎鎻忚堪" prop="userName">
+                <el-input
+                  v-model="queryParams.description"
+                  placeholder="璇疯緭鍏�"
+                  clearable
+                  style="width: 200px"
+                  @keyup.enter.native="handleQuery"
+                />
+              </el-form-item>
+
               <el-form-item label="鍙敤鐘舵��" prop="classify">
-                <el-select
-                  v-model="queryParams.classifyvalue"
-                  placeholder="璇烽�夋嫨"
-                >
+                <el-select v-model="queryParams.isenable" placeholder="璇烽�夋嫨">
                   <el-option
-                    v-for="(item, index) in editableTabs"
-                    :key="index++"
-                    :label="item.title"
-                    :value="index++"
+                    v-for="(item, index) in qyoptions"
+                    :key="item.value"
+                    :label="item.label"
+                    :value="item.value"
                   >
                   </el-option>
                 </el-select>
+              </el-form-item>
+              <el-form-item label="鎮h�呮爣绛�" prop="tagname">
+                <el-input
+                  v-model="queryParams.tagname"
+                  placeholder="杈撳叆杩涜妯$硦鏌ヨ"
+                  maxlength="30"
+                  @keyup.enter.native="handleQuery"
+                />
               </el-form-item>
 
               <el-form-item>
@@ -153,7 +149,7 @@
                   icon="el-icon-plus"
                   size="medium"
                   @click="handleAdd"
-                  v-hasPermi="['system:user:add']"
+
                   >鏂板</el-button
                 >
               </el-col>
@@ -166,7 +162,6 @@
                   size="medium"
                   :disabled="multiple"
                   @click="handleDelete"
-                  v-hasPermi="['system:user:remove']"
                   >鍒犻櫎</el-button
                 >
               </el-col>
@@ -178,15 +173,15 @@
               @selection-change="handleSelectionChange"
             >
               <el-table-column type="selection" width="50" align="center" />
-              <el-table-column
+              <!-- <el-table-column
                 label="搴忓彿"
                 fixed
                 align="center"
                 key="svyid"
                 prop="svyid"
-              />
+              /> -->
               <el-table-column
-                label="闂嵎鏍囬"
+                label="闂嵎鍚嶇О"
                 fixed
                 align="center"
                 key="svyname"
@@ -194,16 +189,9 @@
                 width="160"
                 :show-overflow-tooltip="true"
               />
-              <el-table-column
-                label="鐗堟湰"
-                align="center"
-                key="version"
-                prop="version"
-                :show-overflow-tooltip="true"
-              />
 
               <el-table-column
-                label="涓昏鍐呭"
+                label="闂嵎鎻忚堪"
                 align="center"
                 key="description"
                 prop="description"
@@ -219,7 +207,6 @@
                     size="medium"
                     type="text"
                     @click="illnessUpdate(scope.row)"
-                    v-hasPermi="['system:user:edit']"
                     ><span class="button-textxg"
                       ><i class="el-icon-date"></i>璇︽儏</span
                     ></el-button
@@ -228,22 +215,16 @@
               </el-table-column>
 
               <el-table-column
-                label="鏍囩"
-                align="center"
-                key="labelInfo"
-                prop="labelInfo"
-                width="160"
-                :show-overflow-tooltip="true"
-              >
-                <template slot-scope="scope">
-                  <span v-for="item in scope.row.labelInfo.split(',')"
-                    >{{ item }}銆�
-                  </span>
-                </template>
-              </el-table-column>
+            label="鏍囩"
+            align="center"
+            key="tagname"
+            prop="tagname"
+            show-overflow-tooltip
+            width="180"
+          />
 
               <el-table-column
-                label="鍙敤"
+                label="鏄惁鍙敤"
                 align="center"
                 key="isenable"
                 prop="isenable"
@@ -273,26 +254,23 @@
                     size="medium"
                     type="text"
                     @click="goQRCode(scope.row)"
-                    v-hasPermi="['system:user:edit']"
                   >
                     <span class="button-text"
-                      ><i class="el-icon-edit"></i>浜岀淮鐮�</span
+                      ><i class="el-icon-edit"></i>棰勮</span
                     ></el-button
                   >
-                  <el-button
+                  <!-- <el-button
                     size="medium"
                     type="text"
                     @click="ViewQuestionnaire(scope.row)"
-                    v-hasPermi="['system:user:edit']"
                     ><span class="button-textck"
                       ><i class="el-icon-edit"></i>鏌ョ湅</span
                     ></el-button
-                  >
+                  > -->
                   <el-button
                     size="medium"
                     type="text"
                     @click="handleUpdate(scope.row)"
-                    v-hasPermi="['system:user:edit']"
                     ><span class="button-textxg"
                       ><i class="el-icon-edit"></i>淇敼</span
                     ></el-button
@@ -301,7 +279,6 @@
                     size="medium"
                     type="text"
                     @click="handleDelete(scope.row)"
-                    v-hasPermi="['system:user:remove']"
                     ><span class="button-textsc"
                       ><i class="el-icon-edit"></i>鍒犻櫎</span
                     ></el-button
@@ -347,7 +324,7 @@
         </el-form-item>
       </el-form>
       <div slot="footer" class="dialog-footer">
-        <el-button @click="dialogFormVisible = false">鍙� 娑�</el-button>
+        <el-button @click="getDeptTree()">鍙� 娑�</el-button>
         <el-button type="primary" @click="submitsidecolumn">纭� 瀹�</el-button>
       </div>
     </el-dialog>
@@ -400,12 +377,79 @@
       </span>
     </el-dialog>
     <!-- 浜岀淮鐮佸睍绀哄脊妗� -->
-    <el-dialog width="30%" :visible.sync="goQRCodeVisible">
+    <!-- <el-dialog width="30%" :visible.sync="goQRCodeVisible">
       <div class="qrcode-dialo">
         <div class="qrcode-text">
           {{ namequestionnaire }}<span>{{ haoquestionnaire }}</span>
         </div>
-        <div class="qrcode-img"></div>
+        <div class="qrcode-img">
+          <el-image
+            src="D:/qrcode/fc9a1fa37e394ac3ac606bf6b77b17c3"
+            fit="cover"
+          ></el-image>
+        </div>
+      </div>
+    </el-dialog> -->
+    <!-- 闂嵎妯℃澘棰勮 -->
+    <el-dialog title="闅忚棰樼洰棰勮" :visible.sync="topicVisible" width="50%">
+      <div class="preview-left">
+        <!-- 鍗曢�� -->
+        <div v-for="item in topicform.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="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
+            class="scriptTopic-dev"
+            :key="item.sort"
+            v-if="item.scriptType == 4"
+          >
+            <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>
     </el-dialog>
   </div>
@@ -418,8 +462,9 @@
   getQtemplateclassify,
   delQtemplateclassify,
   addQtemplateclassify,
+  editQtemplateclassify,
   getQtemplatelist,
-  issueinfo,
+  getQtemplateobj,
   compileissue,
   delQtemplateinfo,
   Followupinfo,
@@ -428,6 +473,7 @@
   getillnesslist,
   illnesslistget,
   getillness,
+  getQRcode,
 } from "@/api/AiCentre/index";
 import { listDept } from "@/api/system/dept";
 
@@ -444,6 +490,7 @@
       loading: false,
       // 閫変腑鏁扮粍
       ids: [],
+      qremark: [],
       // 闈炲崟涓鐢�
       single: true,
       // 闈炲涓鐢�
@@ -454,9 +501,11 @@
       total: 0,
       namequestionnaire: "",
       haoquestionnaire: "",
+      QRcodeurl: "",
+      courtyardlist: "",
       // 鐢ㄦ埛琛ㄦ牸鏁版嵁
       userList: [],
-
+      campus: [],
       // 鏃ユ湡鑼冨洿
       dateRange: [],
       // 宀椾綅閫夐」
@@ -465,7 +514,7 @@
       roleOptions: [],
       // 琛ㄥ崟鍙傛暟
       form: {},
-
+      title: "鏂板绫诲埆",
       sidecolumnform: {}, //娣诲姞绫诲埆琛ㄥ崟
       goQRCodeVisible: false, //浜岀淮鐮佸脊妗�
       sidecolumnval: "", //绫诲埆鎼滅储
@@ -473,10 +522,14 @@
       idds: "",
       amendtag: false, //鏄惁淇敼绫诲埆
       dialogFormVisible: false, //淇敼娣诲姞绫诲埆寮规
+      topicVisible: false, //
+      topicform: {},
       classifyform: {}, //绫诲埆琛ㄥ崟
       indexid: null,
       inputValue: "",
       radio: "涓诲垎绫�",
+      zufon: true,
+      zifon: true,
       inputVisible: false,
       illnessVisible: false, //鎸囨爣鐤剧梾寮规
       deptOptions: [],
@@ -484,7 +537,7 @@
       illnesslistapi: [],
       illnesslist: [],
       defaultProps: {
-        children: "svyLibTitleCategoryList",
+        children: "svyLibTemplateCategoryList",
         label: "name",
       },
       deptList: [],
@@ -511,6 +564,7 @@
     this.languagelist = store.getters.languagelist;
     this.qyoptions = store.getters.usable;
     this.editableTabs = store.getters.editableTabs;
+    this.courtyardlist = store.getters.courtyardlist;
   },
 
   methods: {
@@ -528,9 +582,20 @@
     },
 
     goQRCode(row) {
-      this.goQRCodeVisible = true;
-      this.namequestionnaire = row.userName;
-      this.haoquestionnaire = row.nickName;
+      getQtemplateobj({ svyid: row.svyid }).then((res) => {
+        this.topicform = res.rows[0];
+        console.log(this.topicform);
+        this.topicVisible = true;
+      });
+      // getQRcode({
+      //   url: "/outsideChain?param1=KHRYDSSuTpwGWDhAS6OnpfxObRZf8fd/TIagYWPvDuyku+MjtrWt1efC1htoBDc+G4QP2UOWPNitAO4TwH4oIQ==¶m2=CP/xYqwqDhWACt2aQ/HOwhgRM62Lh4/1upwYDl7dmKSuiaa4zRzMgu7rmRztiwQj2YvJ1KAX1zBTpUAIdxPvUA==",
+      // }).then((res) => {
+      //   console.log(res);
+      //   this.QRcodeurl = "D:/qrcode/fc9a1fa37e394ac3ac606bf6b77b17c3";
+      // });
+      // this.goQRCodeVisible = true;
+      // this.namequestionnaire = row.userName;
+      // this.haoquestionnaire = row.nickName;
     },
     // 琛ㄥ崟閲嶇疆
     reset() {
@@ -553,6 +618,7 @@
     /** 鎼滅储鎸夐挳鎿嶄綔 */
     handleQuery() {
       this.queryParams.pageNum = 1;
+      this.queryParams.campus = this.campus.join(",");
       this.getList();
     },
     /** 閲嶇疆鎸夐挳鎿嶄綔 */
@@ -572,13 +638,14 @@
     /** 鏂板鎸夐挳鎿嶄綔 */
     handleAdd() {
       this.$router.push({
-        path: "/knowledge/questionnaire/compilequer/",
+        path: "/knowledge/questionnaireinfo/",
+        query: { categoryid: this.queryParams.categoryid },
       });
     },
     /** 淇敼鎸夐挳鎿嶄綔 */
     handleUpdate(row) {
       this.$router.push({
-        path: "/knowledge/questionnaire/compilequer/",
+        path: "/knowledge/questionnaireinfo/",
         query: { id: row.svyid },
       });
     },
@@ -670,12 +737,21 @@
     getDeptTree() {
       getQtemplateclassify({}).then((res) => {
         this.deptOptions = res.rows;
-        console.log(res);
+        this.dialogFormVisible = false;
       });
     },
 
     // 娣诲姞绫诲埆鏍�
     submitsidecolumn() {
+      if (this.classifyform.id) {
+        editQtemplateclassify(this.classifyform).then((res) => {
+          this.getDeptTree();
+          this.$modal.msgSuccess("淇敼鎴愬姛");
+          this.classifyform = {};
+          this.dialogFormVisible = false;
+        });
+        return;
+      }
       let calssvalue = {};
       if (
         this.classifyform.pid &&
@@ -685,11 +761,12 @@
         const index = this.deptOptions.findIndex(
           (obj) => obj.id == this.classifyform.pid
         );
+        console.log(this.deptOptions[index]);
         calssvalue = this.deptOptions[index];
-        calssvalue.svyLibTitleCategoryList.push(this.classifyform);
+        calssvalue.svyLibTemplateCategoryList.push(this.classifyform);
       } else if (this.radio == "涓诲垎绫�" && this.classifyform.name) {
         this.classifyform.pid = null;
-        this.classifyform.svyLibTitleCategoryList = [];
+        this.classifyform.svyLibTemplateCategoryList = [];
       } else {
         return this.$modal.msgError("璇峰~鍐欏畬鏁翠俊鎭�");
       }
@@ -727,6 +804,27 @@
           .catch(() => {});
       }
     },
+    altertag(a, b) {
+      this.dialogFormVisible = true;
+      if (!b.pid) {
+        this.radio = "涓诲垎绫�";
+        this.title = "淇敼涓诲垎绫�";
+        this.zufon = false;
+      } else {
+        this.radio = "瀛愬垎绫�";
+        this.title = "淇敼瀛愬垎绫�";
+        this.zifon = false;
+      }
+      this.classifyform = b;
+      this.dialogFormVisible = true;
+    },
+    Newcategory(){
+      this.classifyform= {}, //绫诲埆琛ㄥ崟
+      this.radio = "涓诲垎绫�";
+     this.dialogFormVisible = true
+     this.zifon = true;
+      this.zufon = true;
+    },
 
     // 绛涢�夎妭鐐�
     filterNode(value, data) {
@@ -734,7 +832,7 @@
       return data.name.indexOf(value) !== -1;
     },
     handleNodeClick(data) {
-      this.queryParams.assortid = data.id;
+      this.queryParams.categoryid = data.id;
       this.getList();
     },
 
@@ -774,13 +872,6 @@
       this.ids = selection.map((item) => item.svyid);
       this.single = selection.length != 1;
       this.multiple = !selection.length;
-    },
-    /** 鏂板鎸夐挳鎿嶄綔 */
-    handleAdd() {
-      this.$router.push({
-        path: "/knowledge/verbaltrick/particulars/",
-        query: { id: "1" },
-      });
     },
 
     /** 鍒犻櫎鎸夐挳鎿嶄綔 */
@@ -917,6 +1008,22 @@
     vertical-align: bottom;
   }
 }
+.preview-left {
+  margin: 20px;
+  //   margin: 20px;
+  padding: 30px;
+  background: #ffff;
+  border: 1px solid #dcdfe6;
+  -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12),
+    0 0 6px 0 rgba(0, 0, 0, 0.04);
+  .scriptTopic-dev {
+    margin-bottom: 25px;
+    font-size: 20px !important;
+    .dev-text {
+      margin-bottom: 10px;
+    }
+  }
+}
 
 ::v-deep .el-tree-node__content {
   display: -webkit-box;
--
Gitblit v1.9.3