From 9dd3964e34f08bbb04a82f2e05f1b41de7425c48 Mon Sep 17 00:00:00 2001
From: WXL <1785969728@qq.com>
Date: 星期五, 20 六月 2025 15:30:16 +0800
Subject: [PATCH] 测试完成

---
 src/views/followvisit/tasklist/index.vue |  240 +++++++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 156 insertions(+), 84 deletions(-)

diff --git a/src/views/followvisit/tasklist/index.vue b/src/views/followvisit/tasklist/index.vue
index 1ebd6f8..3a1d415 100644
--- a/src/views/followvisit/tasklist/index.vue
+++ b/src/views/followvisit/tasklist/index.vue
@@ -23,7 +23,7 @@
             @keyup.enter.native="handleQuery"
           ></el-input>
         </el-form-item>
-        <el-form-item label="鍒涘缓鏃堕棿">
+        <el-form-item label="鍙戦�佹椂闂�">
           <el-date-picker
             v-model="dateRange"
             style="width: 240px"
@@ -35,7 +35,7 @@
           ></el-date-picker>
         </el-form-item>
 
-        <el-form-item label="鏈嶅姟椤圭洰" prop="status">
+        <el-form-item label="浠诲姟妯℃澘" prop="status">
           <el-input
             v-model="topqueryParams.templatename"
             @keyup.enter.native="handleQuery"
@@ -69,12 +69,27 @@
       <el-row :gutter="10" class="mb8">
         <el-col :span="1.5">
           <el-select
-            @change="handleQuery"
+            @change="handleQuerytask"
             v-model="tasktopic"
-            placeholder="璇烽�夋嫨鏂板绫诲瀷"
+            placeholder="璇烽�夋嫨鏈嶅姟绫诲瀷"
           >
             <el-option
               v-for="item in taskoptions"
+              :key="item.value"
+              :label="item.label"
+              :value="item.value"
+            >
+            </el-option>
+          </el-select>
+        </el-col>
+        <el-col :span="1.5">
+          <el-select
+            @change="handleQuery"
+            v-model="topqueryParams.type"
+            placeholder="璇烽�夋嫨鎵ц绫诲瀷"
+          >
+            <el-option
+              v-for="item in longtermlist"
               :key="item.value"
               :label="item.label"
               :value="item.value"
@@ -89,11 +104,11 @@
             size="medium"
             @click="handleAdd"
             :disabled="!tasktopic"
-            >鏂板</el-button
+            >鏂板缓浠诲姟</el-button
           >
         </el-col>
 
-        <el-col :span="19">
+        <!-- <el-col :span="19">
           <div class="documentf">
             <div class="document">
               <el-button
@@ -107,7 +122,7 @@
               >
             </div>
           </div>
-        </el-col>
+        </el-col> -->
         <!-- <el-col :span="1.5"> </el-col> -->
       </el-row>
       <!-- <right-toolbar
@@ -127,6 +142,7 @@
         <el-table-column
           label="浠诲姟鍚嶇О"
           fixed
+          width="120"
           align="center"
           key="taskName"
           prop="taskName"
@@ -134,15 +150,19 @@
         />
         <el-table-column
           label="浠诲姟鎻忚堪"
+          width="280"
           align="center"
           key="taskDesc"
           prop="taskDesc"
+          :show-overflow-tooltip="true"
         />
         <el-table-column
           label="鏈嶅姟椤圭洰"
+          width="120"
           align="center"
           key="templatename"
           prop="templatename"
+          :show-overflow-tooltip="true"
         />
         <el-table-column
           label="寰呮墽琛�/鎬讳换鍔�"
@@ -152,6 +172,17 @@
         >
           <template slot-scope="scope">
             <span>{{ scope.row.wfs }}/{{ scope.row.yfs }}</span>
+          </template>
+        </el-table-column>
+        <el-table-column
+          label="鏄惁闀挎湡浠诲姟"
+          align="center"
+          key="longTask"
+          prop="longTask"
+          width="120"
+        >
+          <template slot-scope="scope">
+            <span>{{ scope.row.longTask ? "闀挎湡浠诲姟" : "闈為暱鏈�" }}</span>
           </template>
         </el-table-column>
 
@@ -183,10 +214,10 @@
           sortable
           align="center"
           prop="createTime"
-          width="160"
+          width="180"
         >
           <template slot-scope="scope">
-            <span>{{ formatTime(scope.row.createTime) }}</span>
+            <span>{{ parseTime(scope.row.createTime) }}</span>
           </template>
         </el-table-column>
 
@@ -199,7 +230,10 @@
         >
           <template slot-scope="scope">
             <el-button
-              v-if="scope.row.sendState == 1 || scope.row.sendState == 3"
+              v-if="
+                (scope.row.sendState == 1 || scope.row.sendState == 3) &&
+                !scope.row.longTask
+              "
               size="medium"
               type="text"
               @click="sponsor(scope.row)"
@@ -207,10 +241,17 @@
                 ><i class="el-icon-s-promotion"></i>鍙戣捣</span
               ></el-button
             >
-
-            <el-button size="medium" type="text" @click="newAdd(scope.row)"
+            <!-- <el-button size="medium" type="text" @click="newAdd(scope.row)"
               ><span class="button-xj"
                 ><i class="el-icon-circle-plus-outline"></i>缁堟</span
+              ></el-button
+            > -->
+            <el-button
+              size="medium"
+              type="text"
+              @click="handleUpdate(scope.row, 1)"
+              ><span class="button-xj"
+                ><i class="el-icon-circle-plus-outline"></i>渚濈収鏂板</span
               ></el-button
             >
             <el-button
@@ -360,7 +401,7 @@
 import "@riophae/vue-treeselect/dist/vue-treeselect.css";
 
 export default {
-  name: "User",
+  name: "Tasklist",
   dicts: ["sys_normal_disable", "sys_user_sex", "task_status"],
   components: { Treeselect },
   data() {
@@ -393,6 +434,7 @@
       postOptions: [],
       // 瑙掕壊閫夐」
       roleOptions: [],
+      longTask: 0,
       taskform: {
         showDate: [],
         showTimeMorn: [],
@@ -414,6 +456,20 @@
       previewvalue: {
         username: "杩欎釜鍖荤敓瀵逛綘鎬庝箞鏍�",
       },
+      longtermlist: [
+        {
+          value: 1,
+          label: "璇煶闅忚",
+        },
+        {
+          value: 2,
+          label: "闂嵎闅忚",
+        },
+        {
+          value: 3,
+          label: "瀹f暀鍏虫��",
+        },
+      ],
       taskoptions: [
         {
           value: "1",
@@ -441,9 +497,12 @@
         },
         {
           value: "7",
-          label: "鎮h�呮姤鍛�",
+          label: "鎮h�呮棩甯告姤鍛�",
         },
-
+        {
+          value: "9",
+          label: "鎮h�呭紓甯告姤鍛�",
+        },
         {
           value: "8",
           label: "鍏朵粬閫氱煡",
@@ -548,32 +607,14 @@
       topqueryParams: {
         pageNum: 1,
         pageSize: 10,
-        type: 3,
+        type: 2,
         userName: undefined,
         tagid: undefined,
         topic: undefined,
       },
       propss: { multiple: true },
       options: [],
-
-      topicoptions: [
-        {
-          value: 1,
-          label: "寰呭鏍�",
-        },
-        {
-          value: 2,
-          label: "鎵ц涓�",
-        },
-        {
-          value: 3,
-          label: "鎵ц瀹屾垚",
-        },
-        {
-          value: 4,
-          label: "宸插仠姝�",
-        },
-      ],
+      checkboxlist: [],
       // 琛ㄥ崟鏍¢獙
       rules: {
         userName: [
@@ -624,6 +665,11 @@
   },
   watch: {},
   created() {
+    this.topqueryParams.leaveldeptcodes = store.getters.belongDepts.map(
+      (obj) => obj.deptCode
+    );
+    this.topqueryParams.leavehospitaldistrictcodes =
+      store.getters.belongWards.map((obj) => obj.districtCode);
     this.tasktopic = this.$route.query.tasktopic
       ? this.$route.query.tasktopic
       : this.tasktopic;
@@ -631,7 +677,10 @@
     this.getConfigKey("sys.user.initPassword").then((response) => {
       this.initPassword = response.msg;
     });
-    // this.taskoptions = store.getters.Serviceauthority;
+    this.checkboxlist = store.getters.checkboxlist;
+  },
+  activated() {
+    this.getList();
   },
   // 鎼滅储
   mounted() {
@@ -643,10 +692,9 @@
     /** 鏌ヨ浠诲姟鍒楄〃 */
     getList() {
       this.loading = true;
-      let type = this.$route.query.type;
+      console.log(this.topqueryParams.type);
 
       this.topqueryParams.serviceType = Number(this.tasktopic);
-      this.topqueryParams.type = Number(this.type);
       if (
         this.tasktopic == 2 ||
         this.tasktopic == 3 ||
@@ -654,27 +702,50 @@
         this.tasktopic == 7 ||
         this.tasktopic == 6
       ) {
-        this.topqueryParams.type = 2;
-        this.TaskOperation.taskType = 2;
+        if (!this.topqueryParams.type) this.topqueryParams.type = "2";
+        this.longtermlist = [
+          {
+            value: 1,
+            label: "璇煶闅忚",
+          },
+          {
+            value: 2,
+            label: "闂嵎闅忚",
+          },
+        ];
       } else if (this.tasktopic == 4 || this.tasktopic == 8) {
-        this.topqueryParams.type = 3;
-        this.TaskOperation.taskType = 3;
+        if (!this.topqueryParams.type) this.topqueryParams.type = "3";
+        this.longtermlist = [
+          {
+            value: 3,
+            label: "瀹f暀鍏虫��",
+          },
+        ];
       } else if (this.tasktopic == 5) {
-        this.topqueryParams.type = 1;
-        this.TaskOperation.taskType = 1;
+        if (!this.topqueryParams.type) this.topqueryParams.type = "1";
+        this.longtermlist = [
+          {
+            value: 1,
+            label: "璇煶闅忚",
+          },
+          {
+            value: 2,
+            label: "闂嵎闅忚",
+          },
+        ];
       }
       // this.topqueryParams.typename = this.findLabelByValue(
       //   this.taskoptions,
       //   this.tasktopic
       // );
-      getTasklist(this.addDateRange(this.topqueryParams, this.dateRange)).then(
-        (response) => {
-          this.userList = response.rows;
-          this.total = response.total;
-          this.$forceUpdate();
-          this.loading = false;
-        }
-      );
+      this.topqueryParams.startOutHospTime = this.dateRange[0];
+      this.topqueryParams.endOutHospTime = this.dateRange[1];
+      getTasklist(this.topqueryParams).then((response) => {
+        this.userList = response.rows;
+        this.total = response.total;
+        this.$forceUpdate();
+        this.loading = false;
+      });
     },
     // 鏌ョ湅闂ㄨ瘖闅忚璇︽儏
     Referencequestion(row) {
@@ -714,6 +785,11 @@
       this.resetForm("form");
     },
     /** 鎼滅储鎸夐挳鎿嶄綔 */
+    handleQuerytask() {
+      this.topqueryParams.pageNum = 1;
+      // this.topqueryParams.type = '';
+      this.getList();
+    },
     handleQuery() {
       this.topqueryParams.pageNum = 1;
       this.getList();
@@ -721,9 +797,16 @@
     /** 閲嶇疆鎸夐挳鎿嶄綔 */
     resetQuery() {
       this.dateRange = [];
-      this.resetForm("queryForm");
-      this.topqueryParams.deptId = undefined;
-      this.$refs.tree.setCurrentKey(null);
+      this.topqueryParams = {
+        pageNum: 1,
+        pageSize: 10,
+        type: 2,
+      };
+      this.topqueryParams.leaveldeptcodes = store.getters.belongDepts.map(
+        (obj) => obj.deptCode
+      );
+      this.topqueryParams.leavehospitaldistrictcodes =
+        store.getters.belongWards.map((obj) => obj.districtCode);
       this.handleQuery();
     },
     // 澶氶�夋閫変腑鏁版嵁
@@ -781,7 +864,7 @@
       }
     },
     /** 淇敼鎸夐挳鎿嶄綔 */
-    handleUpdate(row) {
+    handleUpdate(row, newadd) {
       if (this.topqueryParams.type == 1) {
         this.$router.push({
           path: "/followvisit/particty",
@@ -789,6 +872,7 @@
             id: row.taskid,
             type: this.topqueryParams.type,
             serviceType: this.tasktopic,
+            newadd: newadd, //鏄惁渚濈収鏂板缓
           },
         });
       } else if (this.topqueryParams.type == 2) {
@@ -798,6 +882,7 @@
             id: row.taskid,
             type: this.topqueryParams.type,
             serviceType: this.tasktopic,
+            newadd: newadd,
           },
         });
       } else if (this.topqueryParams.type == 3) {
@@ -807,6 +892,7 @@
             id: row.taskid,
             type: this.topqueryParams.type,
             serviceType: this.tasktopic,
+            newadd: newadd,
           },
         });
       }
@@ -855,8 +941,20 @@
         this.taskformVisible = true;
       } else if (this.taskform.sendState != 2 && this.taskform.sendType == 2) {
         this.TaskOperation.taskId = row.taskid;
+        this.TaskOperation.taskType = this.topqueryParams.type;
         this.TaskOperation.sendState = 2;
         this.TaskOperation.sendType = 2;
+        this.$modal.confirm({
+        title: '纭鎿嶄綔',
+        text: '浣犵‘瀹氳鎵ц杩欎釜鎿嶄綔鍚楋紵',
+        showCancelButton: true,
+        confirmButtonText: '纭畾',
+        cancelButtonText: '鍙栨秷'
+      }).then((result) => {
+        if (result.value) {
+          console.log('鐢ㄦ埛鐐瑰嚮浜嗙‘瀹氭寜閽�');
+        }
+      });
         this.$modal
           .confirm(
             '褰撳墠閫変腑浠诲姟鍚嶇О涓�"' +
@@ -880,6 +978,7 @@
     confirmSponsor(row) {
       if (this.activname == 0) {
         this.TaskOperation.taskId = row.taskid;
+        this.TaskOperation.taskType = this.topqueryParams.type;
         this.TaskOperation.sendState = 2;
         TaskTemplateSendExecution(this.TaskOperation).then((res) => {
           if (res.code == 200) {
@@ -897,6 +996,7 @@
     immediateExecution(row) {
       console.log(row, "浠诲姟淇℃伅");
       if (row.sendState != 2) {
+        this.TaskOperation.taskType = this.topqueryParams.type;
         this.TaskOperation.taskId = row.taskid;
         this.TaskOperation.sendState = 2;
         this.TaskOperation.sendType = 2;
@@ -919,34 +1019,6 @@
       }
     },
 
-    // 渚濈収鏂板
-    newAdd(row) {
-      this.$modal
-        .confirm("鏄惁渚濈収褰撳墠浠诲姟鍒涘缓鏂颁换鍔★紵")
-        .then(() => {
-          if (this.tasktopic == 5) {
-            this.$router.push({
-              path: "/followvisit/particty",
-              query: { type: 1, id: row.taskid, nhh: 1 },
-            });
-          } else if (
-            this.tasktopic == 2 ||
-            this.tasktopic == 3 ||
-            this.tasktopic == 6
-          ) {
-            this.$router.push({
-              path: "/followvisit/QuestionnaireTask",
-              query: { type: 2, id: row.taskid, nhh: 1 },
-            });
-          } else if (this.tasktopic == 8 || this.tasktopic == 4) {
-            this.$router.push({
-              path: "/followvisit/Missioncreation",
-              query: { type: 3, id: row.taskid, nhh: 1 },
-            });
-          }
-        })
-        .catch(() => {});
-    },
     // 鏆傚仠
     stop(row) {
       console.log(row);

--
Gitblit v1.9.3