From 6d1c826ab6bb3f2cc7cd598a8317b40e403d898f Mon Sep 17 00:00:00 2001
From: WXL (wul) <wl_5969728@163.com>
Date: 星期三, 27 八月 2025 09:23:24 +0800
Subject: [PATCH] 测试完成
---
 src/views/patient/propaganda/index.vue |  311 ++++++++++++++++++++++++++++++---------------------
 1 files changed, 184 insertions(+), 127 deletions(-)
diff --git a/src/views/patient/propaganda/index.vue b/src/views/patient/propaganda/index.vue
index 4f2c6bb..46575a2 100644
--- a/src/views/patient/propaganda/index.vue
+++ b/src/views/patient/propaganda/index.vue
@@ -11,7 +11,10 @@
         label-width="98px"
       >
         <el-form-item label="浠诲姟鍚嶇О">
-          <el-input v-model="topqueryParams.taskName" placeholder="璇烽�夋嫨浠诲姟鍚嶇О"></el-input>
+          <el-input
+            v-model="topqueryParams.taskName"
+            placeholder="璇烽�夋嫨浠诲姟鍚嶇О"
+          ></el-input>
         </el-form-item>
         <!-- <el-form-item label="鍙戣捣浜�">
           <el-input v-model="topqueryParams.createBy"></el-input>
@@ -47,6 +50,15 @@
             >
             </el-option>
           </el-select>
+        </el-form-item>
+        <el-form-item label="鎮h�呰寖鍥�" prop="status">
+          <el-cascader
+            v-model="topqueryParams.scopetype"
+            placeholder="榛樿鍏ㄩ儴"
+            :options="sourcetype"
+            :props="{ expandTrigger: 'hover' }"
+            @change="handleChange"
+          ></el-cascader>
         </el-form-item>
 
         <el-form-item label="瀹f暀鐘舵��" prop="status">
@@ -105,7 +117,6 @@
                 icon="el-icon-upload2"
                 size="medium"
                 @click="handleExport"
-                v-hasPermi="['system:user:export']"
                 >瀵煎嚭</el-button
               >
             </div>
@@ -143,10 +154,9 @@
       <el-table
         v-loading="loading"
         :data="userList"
-         height="660"
+        height="560"
         @selection-change="handleSelectionChange"
       >
-        <el-table-column type="selection" width="50" align="center" />
         <el-table-column
           label="浠诲姟鍚嶇О"
           fixed
@@ -158,60 +168,61 @@
         <!-- <el-table-column label="搴忓彿" fixed align="center" key="id" prop="id" /> -->
         <el-table-column
           label="濮撳悕"
+          width="100"
           fixed
           align="center"
           key="sendname"
           prop="sendname"
         />
         <el-table-column
-        label="瀹f暀鐘舵��"
-        align="center"
-        key="sendstate"
-        prop="sendstate"
-        width="120"
+          label="瀹f暀鐘舵��"
+          align="center"
+          key="sendstate"
+          prop="sendstate"
+          width="120"
         >
-        <template slot-scope="scope">
-          <div v-if="scope.row.sendstate == 1">
-            <el-tag type="primary" :disable-transitions="false"
-                >琚鍙�</el-tag
-                >
-              </div>
-              <div v-if="scope.row.sendstate == 2">
-                <el-tag type="primary" :disable-transitions="false"
-                >寰呭彂閫�</el-tag
-                >
-              </div>
-              <div v-if="scope.row.sendstate == 3">
-                <el-tag type="success" :disable-transitions="false"
-                >宸插彂閫佹湭棰嗗彇</el-tag
-                >
-              </div>
-              <div v-if="scope.row.sendstate == 4">
-                <el-tag type="info" :disable-transitions="false">涓嶆墽琛�</el-tag>
-              </div>
-              <div v-if="scope.row.sendstate == 5">
-                <el-tag type="danger" :disable-transitions="false"
+          <template slot-scope="scope">
+            <div v-if="scope.row.sendstate == 1">
+              <el-tag type="primary" :disable-transitions="false"
+                >琛ㄥ崟宸查鍙�</el-tag
+              >
+            </div>
+            <div v-if="scope.row.sendstate == 2">
+              <el-tag type="primary" :disable-transitions="false"
+                >寰呴殢璁�</el-tag
+              >
+            </div>
+            <div v-if="scope.row.sendstate == 3">
+              <el-tag type="success" :disable-transitions="false"
+                >琛ㄥ崟宸插彂閫�</el-tag
+              >
+            </div>
+            <div v-if="scope.row.sendstate == 4">
+              <el-tag type="info" :disable-transitions="false">涓嶆墽琛�</el-tag>
+            </div>
+            <div v-if="scope.row.sendstate == 5">
+              <el-tag type="danger" :disable-transitions="false"
                 >鍙戦�佸け璐�</el-tag
-                >
-              </div>
-              <div v-if="scope.row.sendstate == 6">
-                <el-tag type="danger" :disable-transitions="false">宸插畬鎴�</el-tag>
-              </div>
-            </template>
-          </el-table-column>
+              >
+            </div>
+            <div v-if="scope.row.sendstate == 6">
+              <el-tag type="danger" :disable-transitions="false">宸插畬鎴�</el-tag>
+            </div>
+          </template>
+        </el-table-column>
 
-          <el-table-column
+        <el-table-column
           label="缁撴灉鐘舵��"
           align="center"
           key="excep"
           prop="excep"
           width="120"
-          >
+        >
           <template slot-scope="scope">
             <div v-if="scope.row.sendstate == 6">
               <dict-tag
-              :options="dict.type.sys_yujing"
-              :value="scope.row.excep"
+                :options="dict.type.sys_yujing"
+                :value="scope.row.excep"
               />
             </div>
             <div v-else>
@@ -220,52 +231,51 @@
           </template>
         </el-table-column>
         <el-table-column
-        label="澶勭悊鎰忚"
-        align="center"
-        key="suggest"
-        prop="suggest"
-        width="120"
+          label="澶勭悊鎰忚"
+          align="center"
+          key="suggest"
+          prop="suggest"
+          width="120"
         >
-        <template slot-scope="scope">
-          <dict-tag
-          :options="dict.type.sys_suggest"
-          :value="scope.row.suggest"
-          />
+          <template slot-scope="scope">
+            <dict-tag
+              :options="dict.type.sys_suggest"
+              :value="scope.row.suggest"
+            />
           </template>
         </el-table-column>
+
         <el-table-column
-        label="鍑洪櫌鏃ユ湡"
-        width="200"
-        align="center"
-        key="endtime"
-        prop="endtime"
+          label="鍑洪櫌鏃ユ湡"
+          width="200"
+          align="center"
+          key="endtime"
+          prop="endtime"
         >
-        <template slot-scope="scope">
-          <span>{{ formatTime(scope.row.endtime) }}</span>
-        </template></el-table-column
-        >
-        <el-table-column
-        label="搴斿鏁欐棩鏈�"
-        width="200"
-        align="center"
-        key="longSendTime"
-        prop="longSendTime"
-        >
-        <template slot-scope="scope">
-          <span>{{ formatTime(scope.row.longSendTime) }}</span>
+          <template slot-scope="scope">
+            <span>{{ formatTime(scope.row.endtime) }}</span>
           </template></el-table-column
-          >
-          <el-table-column
+        >
+        <el-table-column
+          label="搴斿鏁欐棩鏈�"
+          width="200"
+          align="center"
+          key="longSendTime"
+          prop="longSendTime"
+        >
+          <template slot-scope="scope">
+            <span>{{ formatTime(scope.row.longSendTime) }}</span>
+          </template></el-table-column
+        >
+        <el-table-column
           label="鍑洪櫌澶╂暟"
           width="120"
           align="center"
           key="endDay"
           prop="endDay"
-          >
+        >
           <template slot-scope="scope">
-            <span>{{
-              scope.row.endDay ? scope.row.endDay + "澶�" : "鏃ユ湡缂哄け"
-            }}</span>
+            <span>{{ scope.row.endDay ? scope.row.endDay + "澶�" : "" }}</span>
           </template>
         </el-table-column>
         <el-table-column
@@ -289,13 +299,6 @@
           key="drname"
           prop="drname"
         />
-        <el-table-column
-          label="瀹f暀寮傚父璁板綍"
-          width="120"
-          align="center"
-          key="remark"
-          prop="remark"
-        />
 
         <!-- <el-table-column
           label="鐥呭巻鍙�"
@@ -307,7 +310,7 @@
         /> -->
 
         <!-- <el-table-column label="骞撮緞" align="center" key="age" prop="age" /> -->
-        <!-- <el-table-column label="鎬у埆" align="center" key="sex" prop="sex" /> -->
+        <!-- <el-table-column label="鎬у埆"width="100" align="center" key="sex" prop="sex" /> -->
         <!-- <el-table-column label="搴婂彿" align="center" key="badNo" prop="badNo" /> -->
         <el-table-column
           label="绉戝"
@@ -341,6 +344,7 @@
           align="center"
           key="templatename"
           prop="templatename"
+          :show-overflow-tooltip="true"
           width="200"
         />
 
@@ -351,40 +355,45 @@
           prop="createBy"
           width="120"
         />
-        <!-- <el-table-column
-          label="璐d换鍖诲笀"
-          align="center"
-          key="drname"
-          prop="drname"
-          width="120"
-        /> -->
 
         <!-- <el-table-column
-          label="鍑洪櫌鏃堕棿"
-          sortable
+        fixed="right"
+          label="浠诲姟鍙戦�佹祦绋�"
           align="center"
-          prop="createTime"
+          key="serviceSubtaskRecordList"
+          prop="serviceSubtaskRecordList"
           width="160"
+          :show-overflow-tooltip="true"
         >
           <template slot-scope="scope">
-            <span>{{ formatTime(scope.row.createTime) }}</span>
-          </template>
-        </el-table-column> -->
-        <!-- <el-table-column
-          label="瀹f暀鏃堕棿"
-          sortable
-          align="center"
-          prop="createTime"
-          width="160"
-        >
-          <template slot-scope="scope">
-            <span v-if="scope.row.sendType != 3">{{
-              formatTime(scope.row.createTime)
-            }}</span>
-            <span v-else>鍗冲埢鍙戦��</span>
+            <span v-for="item in scope.row.serviceSubtaskRecordList"
+              >{{ item.remark }}銆�
+            </span>
           </template>
         </el-table-column> -->
         <el-table-column
+          fixed="right"
+          label="浠诲姟缁撴灉璁板綍"
+          width="120"
+          align="center"
+          key="remark"
+          prop="remark"
+        >
+          <template slot-scope="scope" v-if="scope.row.remark">
+            <el-tag
+              type="success"
+              v-if="
+                scope.row.sendstate != 5 &&
+                scope.row.sendstate != 4 &&
+                scope.row.remark
+              "
+              >{{ scope.row.remark }}</el-tag
+            >
+            <el-tag type="warning" v-else>{{ scope.row.remark }}</el-tag>
+          </template>
+        </el-table-column>
+        <el-table-column
+          fixed="right"
           label="瀹f暀鏃堕棿"
           sortable
           align="center"
@@ -408,7 +417,6 @@
             <dict-tag :options="serviceState" :value="scope.row.sendstate" />
           </template>
         </el-table-column> -->
-
       </el-table>
 
       <pagination
@@ -603,6 +611,22 @@
       ruleForm: {
         type: [],
       },
+      sourcetype: [
+        {
+          value: 1,
+          label: "绉戝",
+          children: [],
+        },
+        {
+          value: 2,
+          label: "鐥呭尯",
+          children: [],
+        },
+        {
+          value: 3,
+          label: "鍏ㄩ儴",
+        },
+      ],
       dynamicTags: ["閫夐」涓�", "閫夐」浜�", "閫夐」涓�"], //閫夐」
       inputVisible: false,
       inputValue: "",
@@ -728,7 +752,8 @@
         pageNum: 1,
         pageSize: 10,
         serviceType: 4,
-        searchscope:2,
+        searchscope: 2,
+        sendstate: 2,
       },
       propss: { multiple: true },
       options: [],
@@ -736,15 +761,15 @@
       topicoptions: [
         {
           value: 1,
-          label: "琚鍙�",
+          label: "琛ㄥ崟宸查鍙�",
         },
         {
           value: 2,
-          label: "寰呭彂閫�",
+          label: "寰呴殢璁�",
         },
         {
           value: 3,
-          label: "宸插彂閫佹湭棰嗗彇",
+          label: "琛ㄥ崟宸插彂閫�",
         },
         {
           value: 4,
@@ -777,6 +802,19 @@
   watch: {},
   created() {
     this.serviceState = store.getters.serviceState;
+    this.sourcetype[0].children = store.getters.belongDepts.map((dept) => {
+      return {
+        label: dept.deptName,
+        value: dept.deptCode,
+      };
+    });
+    this.sourcetype[1].children = store.getters.belongWards.map((dept) => {
+      return {
+        label: dept.districtName,
+        value: dept.districtCode,
+      };
+    });
+
     this.getList();
     this.getConfigKey("sys.user.initPassword").then((response) => {
       this.initPassword = response.msg;
@@ -794,16 +832,7 @@
   methods: {
     /** 鏌ヨ闂ㄨ瘖瀹f暀鏈嶅姟鍒楄〃 */
     getList() {
-      if (this.topqueryParams.searchscope == 1) {
-        this.topqueryParams.leaveldeptcodes = store.getters.belongDepts.map(
-          (obj) => obj.deptCode
-        );
-        this.topqueryParams.leavehospitaldistrictcodes = null;
-      } else if (this.topqueryParams.searchscope == 2) {
-        this.topqueryParams.leavehospitaldistrictcodes =
-          store.getters.belongWards.map((obj) => obj.districtCode);
-        this.topqueryParams.leaveldeptcodes = null;
-      } else {
+       if (this.topqueryParams.searchscope == 3) {
         this.topqueryParams.leaveldeptcodes = store.getters.belongDepts.map(
           (obj) => obj.deptCode
         );
@@ -811,6 +840,15 @@
           store.getters.belongWards.map((obj) => obj.districtCode);
       }
       this.loading = true;
+
+      if (
+        this.topqueryParams.leavehospitaldistrictcodes[0] &&
+        this.topqueryParams.leaveldeptcodes[0]
+      ) {
+        this.topqueryParams.deptOrDistrict = 2;
+      } else {
+        this.topqueryParams.deptOrDistrict = 1;
+      }
       getTaskservelist(this.topqueryParams).then((response) => {
         this.userList = response.rows[0].serviceSubtaskList;
         this.userList.forEach((item) => {
@@ -838,6 +876,24 @@
         }, 200);
       } else {
         this.options = [];
+      }
+    },
+    // 鎮h�呰寖鍥村鐞�
+    handleChange(value) {
+      let type = value[0];
+      let code = value.slice(-1)[0];
+      this.topqueryParams.leavehospitaldistrictcodes = [];
+      this.topqueryParams.leaveldeptcodes = [];
+      if (type == 1) {
+        this.topqueryParams.leaveldeptcodes.push(code);
+        this.topqueryParams.leavehospitaldistrictcodes = [];
+        this.topqueryParams.searchscope = 1;
+      } else if (type == 2) {
+        this.topqueryParams.leavehospitaldistrictcodes.push(code);
+        this.topqueryParams.leaveldeptcodes = [];
+        this.topqueryParams.searchscope = 2;
+      } else {
+        this.topqueryParams.searchscope = 3;
       }
     },
     // 闂ㄨ瘖瀹f暀鐘舵�佷慨鏀�
@@ -909,6 +965,7 @@
         pageNum: 1,
         pageSize: 10,
         serviceType: 4,
+        sendstate: 2,
       };
       this.handleQuery();
     },
@@ -1005,17 +1062,17 @@
     // 渚挎嵎鎸夐挳
     toleadExport(too) {
       if (too == 1) {
-        this.topqueryParams.sendstate=4;
-        this.topqueryParams.excep=null;
+        this.topqueryParams.sendstate = 4;
+        this.topqueryParams.excep = null;
       } else if (too == 2) {
-        this.topqueryParams.excep=1;
+        this.topqueryParams.excep = 1;
       }
       this.handleQuery();
     },
     /** 瀵煎嚭鎸夐挳鎿嶄綔 */
     handleExport() {
       this.download(
-        "system/user/export",
+        "smartor/serviceSubtask/patItemExport",
         {
           ...this.topqueryParams,
         },
--
Gitblit v1.9.3