From d54ac083e2992a5613f5cb22849db9742dbe9a9b Mon Sep 17 00:00:00 2001
From: WXL (wul) <wl_5969728@163.com>
Date: 星期三, 22 十月 2025 11:06:14 +0800
Subject: [PATCH] 问卷联调
---
 src/views/repositoryai/templateku/index.vue |  306 ++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 231 insertions(+), 75 deletions(-)
diff --git a/src/views/repositoryai/templateku/index.vue b/src/views/repositoryai/templateku/index.vue
index 0cca167..bc38fb5 100644
--- a/src/views/repositoryai/templateku/index.vue
+++ b/src/views/repositoryai/templateku/index.vue
@@ -1,10 +1,10 @@
 <template>
   <div class="Questionnairemanagement">
     <!-- 宸︿晶鏍� -->
-    <div class="sidecolumn" v-show="topactiveName == 'Local'">
+    <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>
+            <span v-if="data.id > 0">
               <el-button
                 type="text"
                 icon="el-icon-delete"
@@ -39,12 +39,23 @@
               >
               </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>
         </el-tree>
       </div>
     </div>
     <!-- 鍙充晶鏁版嵁 -->
-    <div :class="topactiveName == 'Local' ? 'leftvlue' : 'leftvlues'">
+    <div class="leftvlue">
       <div class="leftvlue-bg">
         <el-row :gutter="20">
           <!--鐢ㄦ埛鏁版嵁-->
@@ -57,50 +68,35 @@
               v-show="showSearch"
               label-width="98px"
             >
-              <el-form-item label="妯$増鏍囬" prop="userName">
+              <el-form-item label="妯℃澘鏍囬" prop="templateName">
                 <el-input
-                  v-model="queryParams.userName"
+                  v-model="queryParams.templateName"
                   placeholder="璇疯緭鍏�"
                   clearable
                   style="width: 200px"
                   @keyup.enter.native="handleQuery"
                 />
               </el-form-item>
-              <el-form-item label="閫傜敤绉戝" prop="status">
-                <el-select v-model="queryParams.status" placeholder="璇烽�夋嫨">
+              <el-form-item label="閫傜敤闄㈠尯" prop="region">
+                <el-select
+                  v-model="campus"
+                  size="medium"
+                  multiple
+                  filterable
+                  placeholder="璇烽�夋嫨鍒嗙被"
+                >
                   <el-option
-                    v-for="item in languagelist"
-                    :key="item.value"
+                    class="ruleFormaa"
+                    v-for="item in courtyardlist"
+                    :key="item.label"
                     :label="item.label"
-                    :value="item.value"
+                    :value="item.label"
                   >
                   </el-option>
                 </el-select>
               </el-form-item>
-              <el-form-item label="鍙敤鐘舵��" prop="status">
-                <el-select v-model="queryParams.status" placeholder="璇烽�夋嫨">
-                  <el-option
-                    v-for="item in qyoptions"
-                    :key="item.value"
-                    :label="item.label"
-                    :value="item.value"
-                  >
-                  </el-option>
-                </el-select>
-              </el-form-item>
-              <el-form-item label="閫傜敤鏂瑰紡" prop="status">
-                <el-select v-model="queryParams.status" placeholder="璇烽�夋嫨">
-                  <el-option
-                    v-for="item in languagelist"
-                    :key="item.value"
-                    :label="item.label"
-                    :value="item.value"
-                  >
-                  </el-option>
-                </el-select>
-              </el-form-item>
-              <el-form-item label="鍐呭褰㈠紡" prop="status">
-                <el-select v-model="queryParams.status" placeholder="璇烽�夋嫨">
+              <el-form-item label="鍙敤鐘舵��" prop="usestate">
+                <el-select v-model="queryParams.usestate" placeholder="璇烽�夋嫨">
                   <el-option
                     v-for="item in qyoptions"
                     :key="item.value"
@@ -155,18 +151,24 @@
               </el-col>
               <!-- <el-col :span="1.5"> </el-col> -->
             </el-row>
-            <!-- 鏍囧噯妯$増 -->
+            <!-- 鏍囧噯妯℃澘 -->
             <el-table
-              v-if="topactiveName == 'Local'"
               v-loading="loading"
               :data="userList"
               :border="true"
               @selection-change="handleSelectionChange"
             >
               <el-table-column type="selection" width="50" align="center" />
-              <el-table-column label="搴忓彿" align="center" key="id" prop="id" />
               <el-table-column
-                label="妯$増鍚嶇О"
+                label="搴忓彿"
+                fixed
+                align="center"
+                key="id"
+                prop="id"
+              />
+              <el-table-column
+                label="妯℃澘鍚嶇О"
+                fixed
                 align="center"
                 key="templateName"
                 prop="templateName"
@@ -202,22 +204,6 @@
               </el-table-column>
 
               <el-table-column
-                label="閫傜敤绉戝"
-                align="center"
-                key="deptNames"
-                prop="deptNames"
-                width="120"
-              >
-                <template slot-scope="scope">
-                  <div v-if="scope.row.deptNames">
-                    <span v-for="item in scope.row.deptNames.split(",")"
-                      >{{ item }}
-                    </span>
-                  </div>
-                  <div v-else>''</div>
-                </template>
-              </el-table-column>
-              <el-table-column
                 label="鏍囩"
                 align="center"
                 key="labelInfo"
@@ -225,15 +211,15 @@
                 width="160"
                 :show-overflow-tooltip="true"
               >
-                <template slot-scope="scope" >
+                <template slot-scope="scope">
                   <div v-if="scope.row.labelInfo">
-                    <span v-for="item in JSON.parse(scope.row.labelInfo)"
-                      >{{ item.tagname }}</span>
+                    <span v-for="item in JSON.parse(scope.row.labelInfo)">{{
+                      item.tagname
+                    }}</span>
                   </div>
                   <div v-else>
                     <span>鏃�</span>
                   </div>
-                  </span>
                 </template>
               </el-table-column>
               <el-table-column
@@ -244,9 +230,11 @@
                 width="160"
                 :show-overflow-tooltip="true"
               >
-                <template slot-scope="scope"  >
+                <template slot-scope="scope">
                   <div v-if="scope.row.campus">
-                    <span v-for="item in JSON.parse(scope.row.campus)">{{ item.label }} </span>
+                    <span v-for="item in scope.row.campus.split(',')"
+                      >{{ item }}銆�
+                    </span>
                   </div>
                   <div v-else>
                     <span>鏃�</span>
@@ -290,6 +278,7 @@
 
               <el-table-column
                 label="鎿嶄綔"
+                fixed="right"
                 align="center"
                 width="200"
                 class-name="small-padding fixed-width"
@@ -324,7 +313,7 @@
                 </template>
               </el-table-column>
             </el-table>
-            <!-- 閫氱敤妯$増 -->
+            <!-- 閫氱敤妯℃澘 -->
 
             <!-- 搴曢儴鍒嗛〉 -->
             <pagination
@@ -339,11 +328,16 @@
       </div>
     </div>
     <!-- 娣诲姞绫诲埆寮规 -->
-    <el-dialog title="鏂板绫诲埆" width="30%" :visible.sync="dialogFormVisible">
+    <el-dialog
+      :title="title"
+      width="30%"
+      :close-on-click-modal="false"
+      :visible.sync="dialogFormVisible"
+    >
       <div style="text-align: center; margin-bottom: 20px">
         <el-radio-group v-model="radio">
-          <el-radio-button label="涓诲垎绫�"></el-radio-button>
-          <el-radio-button label="瀛愬垎绫�"></el-radio-button>
+          <el-radio-button label="涓诲垎绫�" v-show="zifon"></el-radio-button>
+          <el-radio-button label="瀛愬垎绫�" v-show="zufon"></el-radio-button>
         </el-radio-group>
       </div>
       <el-divider></el-divider>
@@ -367,7 +361,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>
@@ -419,6 +413,68 @@
         <el-button type="primary" @click="confirmillness">纭� 瀹�</el-button>
       </span>
     </el-dialog>
+    <!-- 闅忚棰樼洰棰勮 -->
+    <el-dialog title="闅忚棰樼洰棰勮" :visible.sync="topicVisible" width="50%">
+      <div class="preview-left">
+        <div v-for="item in topicform.ivrLibaTemplateScriptVOList">
+          <!-- 鍗曢�� -->
+          <div
+            class="scriptTopic-dev"
+            :key="item.targetid"
+            v-if="item.valueType == 1"
+          >
+            <div class="dev-text">
+              {{ item.targetid }}銆乕鍗曢�塢<span>{{ item.scriptContent }}</span>
+            </div>
+            <div class="dev-xx">
+              <el-radio-group v-model="item.remark">
+                <el-radio
+                  v-for="(items, index) in item.ivrLibaScriptTargetoptionList"
+                  :key="index"
+                  :label="index"
+                  >{{ items.targetvalue }}</el-radio
+                >
+              </el-radio-group>
+            </div>
+          </div>
+          <!-- 澶氶�� -->
+          <div
+            class="scriptTopic-dev"
+            :key="item.targetid"
+            v-if="item.valueType == 2"
+          >
+            <div class="dev-text">
+              {{ item.targetid }}銆乕澶氶�塢<span>{{ item.scriptContent }}</span>
+            </div>
+            <div class="dev-xx">
+              <el-checkbox-group v-model="item.remark">
+                <el-checkbox
+                  v-for="(items, index) in item.ivrLibaScriptTargetoptionList"
+                  :key="index"
+                  :label="index"
+                >
+                  {{ items.targetvalue }}
+                </el-checkbox>
+              </el-checkbox-group>
+            </div>
+          </div>
+          <!-- 濉┖ -->
+          <div
+            class="scriptTopic-dev"
+            :key="item.targetid"
+            v-if="item.valueType == 3"
+          >
+            <div class="dev-text">
+              {{ item.targetid }}銆乕濉┖]<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>
 </template>
 
@@ -429,16 +485,19 @@
   getFollowupclassify,
   delFollowupclassify,
   addFollowupclassify,
+  editFollowupclassify,
   addtargetillness,
   getvFollowup,
   compileFollowup,
   delFollowupinfo,
+  getverbaltricklist,
   Followupinfo,
   getFollowuplist,
   getillnesslist,
   illnesslistget,
   getillness,
 } from "@/api/AiCentre/index";
+import { listDept } from "@/api/system/dept";
 export default {
   name: "templateku",
   data() {
@@ -458,6 +517,8 @@
       total: 0,
       namequestionnaire: "",
       haoquestionnaire: "",
+      topicform: {},
+      topicVisible: false,
       idds: "",
       amendtag: false, //鏄惁淇敼绫诲埆
       dialogFormVisible: false, //淇敼娣诲姞绫诲埆寮规
@@ -469,7 +530,7 @@
       // 琛ㄦ牸鏁版嵁
       userList: [],
       // 寮瑰嚭灞傛爣棰�
-      title: "",
+      title: "绫诲埆缂栬緫",
       // 鏄惁鏄剧ず寮瑰嚭灞�
       open: false,
       // 鏃ユ湡鑼冨洿
@@ -495,11 +556,14 @@
         pageNum: 1,
         pageSize: 10,
       },
+      campus: [],
       // 琛ㄥ崟鏍¢獙
       rules: {},
       indexid: null,
       inputValue: "",
       radio: "涓诲垎绫�",
+      zufon: true,
+      zifon: true,
       inputVisible: false,
       illnessVisible: false, //鎸囨爣鐤剧梾寮规
       deptOptions: [],
@@ -510,9 +574,12 @@
         children: "ivrLibaTemplateAssortList",
         label: "indexAssortName",
       },
+      deptList: [],
+      props: { multiple: true, value: "deptId", label: "deptName" },
       mode: [],
       languagelist: [],
       qyoptions: [],
+      courtyardlist: [],
     };
   },
   watch: {
@@ -524,31 +591,41 @@
   created() {
     this.getList();
     this.getDeptTree();
+    this.zufon = true;
+    this.zifon = true;
     this.mode = store.getters.mode;
     this.languagelist = store.getters.languagelist;
     this.qyoptions = store.getters.usable;
     this.precedencetype = store.getters.precedencetype;
+    this.courtyardlist = store.getters.courtyardlist;
   },
 
   methods: {
     /** 鏌ヨ淇℃伅 */
     getList() {
+      this.queryParams.campus = this.campus.join(",");
       getFollowuplist(this.queryParams).then((res) => {
         console.log(res);
         console.log(this.userList);
         this.userList = res.rows;
         this.total = res.total;
+
+        console.log(this.userList[0].campus.split(","));
+      });
+      listDept({ pageNum: 1, pageSize: 10 }).then((response) => {
+        this.deptList = this.handleTree(response.data, "deptId");
       });
     },
 
-    // 澶嶅埗妯$増
+    // 澶嶅埗妯℃澘
     copyfn() {},
-    // 涓嬭浇妯$増
+    // 涓嬭浇妯℃澘
     downloadfn() {},
     // 璺宠浆缂栬緫璇濇湳椤甸潰
     compileUpdate(row) {
+      // this.$router.replace("/tpuconfigurat");
       this.$router.push({
-        path: "/knowledge/templateku/configurat/",
+        path: "/knowledge/tpuconfigurat/",
         query: { id: row.id },
       });
     },
@@ -602,7 +679,12 @@
       this.multiple = !selection.length;
     },
     /** 鏂板鎸夐挳鎿嶄綔 */
-    handleAdd() {},
+    handleAdd() {
+      this.$router.push({
+        path: "/knowledge/tpuconfigurat/",
+        query: { id: null, assortid: this.queryParams.assortid },
+      });
+    },
 
     /** 鍒犻櫎鎸夐挳鎿嶄綔 */
     handleDelete(row) {
@@ -629,12 +711,21 @@
     getDeptTree() {
       getFollowupclassify({}).then((res) => {
         this.deptOptions = res.rows;
-        console.log(res);
+        this.dialogFormVisible = false;
       });
     },
 
     // 娣诲姞绫诲埆鏍�
     submitsidecolumn() {
+      if (this.classifyform.id) {
+        editFollowupclassify(this.classifyform).then((res) => {
+          this.getDeptTree();
+          this.$modal.msgSuccess("淇敼鎴愬姛");
+          this.classifyform = {};
+          this.dialogFormVisible = false;
+        });
+        return;
+      }
       let calssvalue = {};
       if (
         this.classifyform.pid &&
@@ -655,6 +746,8 @@
       addFollowupclassify(this.classifyform).then((res) => {
         this.getDeptTree();
         this.$modal.msgSuccess("鏂板鎴愬姛");
+        this.classifyform = {};
+        this.dialogFormVisible = false;
       });
     },
     remove(a, b) {
@@ -685,6 +778,35 @@
           })
           .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;
+    },
+    // 棰勮
+    preview(row) {
+      getvFollowup({ id: row.id }).then((res) => {
+        this.topicform = res.data;
+        console.log(this.topicform);
+        this.topicVisible = true;
+      });
     },
 
     // 绛涢�夎妭鐐�
@@ -783,8 +905,8 @@
   //   display: flex;
   margin-top: 20px;
   margin: 20px;
-  padding: 30px;
-  background: #edf1f7;
+  padding: 20px;
+  background: #fff;
   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);
@@ -918,6 +1040,22 @@
     font-size: 20px;
   }
 }
+.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;
   display: -ms-flexbox;
@@ -929,6 +1067,24 @@
   font-size: 20px;
   cursor: pointer;
 }
+::v-deep .el-tree {
+  position: relative;
+  cursor: default;
+  border-radius: 5px;
+  background: #eff8fe;
+  color: #606266;
+  border: 1px solid #bbe1fa;
+  // 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);
+}
+::v-deep
+  .el-tree--highlight-current
+  .el-tree-node.is-current
+  > .el-tree-node__content {
+  background-color: #7799fb;
+  color: #fff;
+}
 ::v-deep .el-button--mini.is-circle {
   padding: 7px;
   margin: 0;
--
Gitblit v1.9.3