seimin vor 2 Jahren
Ursprung
Commit
994d00e491

+ 1 - 1
components/seiminModel/seiminModel.vue

@@ -74,7 +74,7 @@
74 74
       };
75 75
     },
76 76
     computed: {
77
-      ...mapState(["nurseDeptSwitchTip"]),
77
+      ...mapState('other', ["nurseDeptSwitchTip"]),
78 78
       ...mapState("user", ["loginInfo"]),
79 79
     },
80 80
     methods: {

+ 1 - 1
components/seiminPicker/seiminPicker.vue

@@ -26,7 +26,7 @@
26 26
   export default {
27 27
     name: 'seiminPicker',
28 28
     computed: {
29
-      ...mapState(["deptDisplay"]),
29
+      ...mapState('other', ["deptDisplay"]),
30 30
     },
31 31
     props: {
32 32
       title: { //标题文字

+ 9 - 1
filters/index.js

@@ -1,6 +1,14 @@
1
-import Vue from 'vue'
1
+import Vue from 'vue';
2
+import {
3
+  format
4
+} from 'date-fns'
2 5
 // 首页标本数量过滤
3 6
 // 数量大于999则显示999+
4 7
 Vue.filter('specimenNum', function(value) {
5 8
   return value > 999 ? '999+' : value;
6 9
 })
10
+// 格式化日期
11
+// YYYY-MM-DD HH:mm:ss
12
+Vue.filter('formatDate', function(value, ruleText) {
13
+  return format(new Date(value), ruleText);
14
+})

+ 12 - 1
package-lock.json

@@ -11,7 +11,8 @@
11 11
       "dependencies": {
12 12
         "animate.css": "^4.1.1",
13 13
         "crypto-js": "^4.1.1",
14
-        "date-fns": "^2.28.0"
14
+        "date-fns": "^2.28.0",
15
+        "lodash": "^4.17.21"
15 16
       }
16 17
     },
17 18
     "node_modules/animate.css": {
@@ -31,6 +32,11 @@
31 32
       "engines": {
32 33
         "node": ">=0.11"
33 34
       }
35
+    },
36
+    "node_modules/lodash": {
37
+      "version": "4.17.21",
38
+      "resolved": "https://registry.npmmirror.com/lodash/-/lodash-4.17.21.tgz",
39
+      "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg=="
34 40
     }
35 41
   },
36 42
   "dependencies": {
@@ -48,6 +54,11 @@
48 54
       "version": "2.28.0",
49 55
       "resolved": "https://registry.npmmirror.com/date-fns/-/date-fns-2.28.0.tgz",
50 56
       "integrity": "sha512-8d35hViGYx/QH0icHYCeLmsLmMUheMmTyV9Fcm6gvNwdw31yXXH+O85sOBJ+OLnLQMKZowvpKb6FgMIQjcpvQw=="
57
+    },
58
+    "lodash": {
59
+      "version": "4.17.21",
60
+      "resolved": "https://registry.npmmirror.com/lodash/-/lodash-4.17.21.tgz",
61
+      "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg=="
51 62
     }
52 63
   }
53 64
 }

+ 2 - 1
package.json

@@ -16,6 +16,7 @@
16 16
   "dependencies": {
17 17
     "animate.css": "^4.1.1",
18 18
     "crypto-js": "^4.1.1",
19
-    "date-fns": "^2.28.0"
19
+    "date-fns": "^2.28.0",
20
+    "lodash": "^4.17.21"
20 21
   }
21 22
 }

+ 26 - 31
pages/index/index.vue

@@ -39,10 +39,13 @@
39 39
       <view class="newOrders">
40 40
         <view class="newOrders_header">
41 41
           <text class="newOrders_header_title">最新工单</text>
42
-          <text class="newOrders_header_more">更多&gt;&gt;</text>
42
+          <text class="newOrders_header_more" @click="goToMore">更多&gt;&gt;</text>
43 43
         </view>
44 44
         <view class="newOrders_item" v-for="newOrder in newOrderList" :key="newOrder.id">
45
-          <view class="newOrders_item_time">{{ newOrder.showCreateTime }}</view>
45
+          <view class="newOrders_item_time" v-if="newOrder.showCreateTime">{{ newOrder.showCreateTime }}</view>
46
+          <view class="newOrders_item_time" v-else-if="newOrder.yyjdTime && newOrder.gdState.value == 11">
47
+            {{newOrder.yyjdTime | formatDate('MM-dd HH:mm')}}
48
+          </view>
46 49
           <text class="newOrders_item_taskType">{{
47 50
             newOrder.isHalfInspect === 1
48 51
               ? "半程陪检"
@@ -81,7 +84,8 @@
81 84
 <script>
82 85
   import {
83 86
     mapState,
84
-    mapMutations
87
+    mapMutations,
88
+    mapActions
85 89
   } from "vuex";
86 90
   import {
87 91
     reqSpecimenWorkOrderMsg,
@@ -103,30 +107,13 @@
103 107
         newOrderList: [], //最新工单列表
104 108
         quickOtherList: [], //快捷工单列表
105 109
         hospitalList: [], //当前用户权限中的院区列表
106
-        // list: [{
107
-        //     value: '1',
108
-        //     label: '身份证'
109
-        //   },
110
-        //   {
111
-        //     value: '2',
112
-        //     label: '驾驶证'
113
-        //   },
114
-        //   {
115
-        //     value: '3',
116
-        //     label: '护照'
117
-        //   },
118
-        //   {
119
-        //     value: '4',
120
-        //     label: '其他证件'
121
-        //   },
122
-        // ],
123 110
         pickerTitle: "", //选择院区picker的title
124 111
         specimenTaskTypeId: undefined, //标本任务类型id
125 112
       };
126 113
     },
127 114
     computed: {
128 115
       ...mapState("user", ["loginInfo"]),
129
-      ...mapState([
116
+      ...mapState('other', [
130 117
         "isShowSeiminModel",
131 118
         "deptDisplay",
132 119
         "specimenButton",
@@ -134,7 +121,7 @@
134 121
       ]),
135 122
     },
136 123
     methods: {
137
-      ...mapMutations([
124
+      ...mapMutations('other', [
138 125
         "changeSeiminModel",
139 126
         "changeQucikCreateOrderType",
140 127
         "changeDeptDisplay",
@@ -143,8 +130,19 @@
143 130
         "changeNurseDeptSwitchTip",
144 131
         "changeSearchDeptParams",
145 132
       ]),
133
+      ...mapActions('system', ["vxSystem"]),
134
+      // 跳转到工单列表页面
135
+      goToMore() {
136
+        uni.navigateTo({
137
+          url: '/pages/orderList/orderList'
138
+        })
139
+      },
146 140
       // 获取页面数据
147 141
       init() {
142
+        uni.showLoading({
143
+          title: "加载中",
144
+          mask: true,
145
+        });
148 146
         Promise.all([
149 147
           this.querySpecimenNumRequest(), //查询急标和普标数量
150 148
           this.queryWorkOrdersRequest(), //查询最新工单列表
@@ -265,7 +263,7 @@
265 263
       },
266 264
       // 护士端科室显示选择(名称还是别名)
267 265
       queryDeptDisplayRequest() {
268
-        return reqFetchDataList("simple/data", "systemConfiguration", {
266
+        return this.vxSystem({
269 267
           idx: 0,
270 268
           sum: 1,
271 269
           systemConfiguration: {
@@ -298,7 +296,7 @@
298 296
       },
299 297
       // 护士端更新提示
300 298
       queryUpdateTipsForNursesRequest() {
301
-        return reqFetchDataList("simple/data", "systemConfiguration", {
299
+        return this.vxSystem({
302 300
           idx: 0,
303 301
           sum: 1,
304 302
           systemConfiguration: {
@@ -331,7 +329,7 @@
331 329
       },
332 330
       // 标本按钮文字
333 331
       querySpecimenButtonRequest() {
334
-        return reqFetchDataList("simple/data", "systemConfiguration", {
332
+        return this.vxSystem({
335 333
           idx: 0,
336 334
           sum: 1,
337 335
           systemConfiguration: {
@@ -364,7 +362,7 @@
364 362
       },
365 363
       // 护士科室切换提示自动关闭设置
366 364
       queryNurseDeptSwitchTipRequest() {
367
-        return reqFetchDataList("simple/data", "systemConfiguration", {
365
+        return this.vxSystem({
368 366
           idx: 0,
369 367
           sum: 1,
370 368
           systemConfiguration: {
@@ -481,10 +479,6 @@
481 479
         value: v.id,
482 480
         label: v.hosName,
483 481
       }));
484
-      uni.showLoading({
485
-        title: "加载中",
486
-        mask: true,
487
-      });
488 482
       this.init();
489 483
     },
490 484
     onPullDownRefresh() {
@@ -661,7 +655,8 @@
661 655
           }
662 656
 
663 657
           .newOrders_item_time {
664
-            width: 140rpx;
658
+            width: 88rpx;
659
+            text-align: center;
665 660
           }
666 661
 
667 662
           .newOrders_item_taskType {

+ 15 - 2
pages/login/login.vue

@@ -46,7 +46,17 @@
46 46
     },
47 47
     methods: {
48 48
       ...mapActions("user", ["vxLogin"]),
49
-      ...mapMutations(["changeSeiminModel"]),
49
+      ...mapMutations('other', ["changeSeiminModel", 'resetVxOther']),
50
+      ...mapMutations('dictionary', ["resetVxDictionary"]),
51
+      ...mapMutations('user', ["resetVxLogin"]),
52
+      ...mapMutations('system', ["resetVxSystem"]),
53
+      // 重置vuex数据
54
+      resetVuex() {
55
+        this.resetVxOther();
56
+        this.resetVxDictionary();
57
+        this.resetVxLogin();
58
+        this.resetVxSystem();
59
+      },
50 60
       // 登录
51 61
       login(e) {
52 62
         let {
@@ -96,6 +106,7 @@
96 106
               });
97 107
               return;
98 108
             }
109
+
99 110
             // 如果记住密码,则缓存到本地
100 111
             if (savePassword) {
101 112
               //记住密码
@@ -108,7 +119,7 @@
108 119
               uni.removeStorageSync("savePasswordObj");
109 120
             }
110 121
             // 跳转到首页(isShowSeiminModel,是否显示切换科室弹窗)
111
-            uni.navigateTo({
122
+            uni.redirectTo({
112 123
               url: "/pages/index/index",
113 124
             });
114 125
             this.changeSeiminModel(true);
@@ -124,6 +135,8 @@
124 135
       },
125 136
     },
126 137
     onLoad() {
138
+      // 清除缓存vuexStorage
139
+      uni.removeStorageSync('vuexStorage');
127 140
       // 是否记住密码
128 141
       let savePasswordObj = uni.getStorageSync("savePasswordObj");
129 142
       if (savePasswordObj) {

+ 112 - 12
pages/orderList/orderList.vue

@@ -2,12 +2,12 @@
2 2
   <view class="orderList">
3 3
     <!-- 头部筛选 -->
4 4
     <view class="orderList_header">
5
-      <view class="orderList_header_item">
5
+      <view class="orderList_header_item" @click="openPicker('gdState')">
6 6
         <text class="orderList_header_itemText">全部</text>
7 7
         <text class="pda pda-xiala"></text>
8 8
       </view>
9 9
       <view class="orderList_header_item">
10
-        <text class="orderList_header_itemText">全部</text>
10
+        <text class="orderList_header_itemText" @click="openPicker('associationType')">全部</text>
11 11
         <text class="pda pda-xiala"></text>
12 12
       </view>
13 13
     </view>
@@ -16,15 +16,38 @@
16 16
       <view class="orderList_listItem" v-for="newOrder in newOrderList" :key="newOrder.id">
17 17
         <view class="orderList_listItem_header">
18 18
           <view class="orderList_listItem_header_title">
19
-            <view class="associationType_icon"> 标 </view>
20
-            半程陪检-张三
19
+            <view class="associationType_icon" v-if="newOrder.isHalfInspect === 1"> 半 </view>
20
+            <view class="associationType_icon" v-else-if="newOrder.taskType.associationType.value == 'specimen'">标
21
+            </view>
22
+            <view class="associationType_icon" v-else-if="newOrder.taskType.associationType.value == 'drugsBag'"> 药
23
+            </view>
24
+            <view class="associationType_icon" v-else-if="newOrder.taskType.associationType.value == 'specimenPlan'"> 巡
25
+            </view>
26
+            <view class="associationType_icon" v-else-if="newOrder.taskType.associationType.value == 'jPBag'"> 静 </view>
27
+            <view class="associationType_icon" v-else-if="newOrder.taskType.associationType.value == 'inspect'"> 病
28
+            </view>
29
+            <view class="associationType_icon"
30
+              v-else-if="newOrder.taskType.associationType.value == 'patientTransport'"> 病
31
+            </view>
32
+            <view class="associationType_icon" v-else-if="newOrder.taskType.associationType.value == 'other'"> 其
33
+            </view>
34
+            <view class="taskNameAndWorkerName">
35
+              <text class="taskName">{{newOrder.isHalfInspect === 1? "半程陪检": newOrder.taskType.taskName}}</text>
36
+              <text class="workerName"
37
+                v-if="newOrder.patient &&(newOrder.taskType.associationType.value =='patientTransport' ||newOrder.taskType.associationType.value =='inspect')">-{{newOrder.patient.patientName}}</text>
38
+            </view>
21 39
           </view>
22
-          <text class="orderList_listItem_header_more">待接单</text>
40
+          <text class="orderList_listItem_header_more"
41
+            :class="newOrder.stateTextClass">{{newOrder.gdState.name }}</text>
23 42
         </view>
24 43
         <view class="orderList_listItem_item">
25 44
           <view class="orderList_listItem_item_content">
26
-            <text class="orderList_listItem_item_name">李四-6322285</text>
27
-            <text class="orderList_listItem_item_time">10:20</text>
45
+            <text class="orderList_listItem_item_name"
46
+              v-if="newOrder.worker">{{newOrder.worker.name}}{{newOrder.worker.phone? "-" + newOrder.worker.phone: ""}}</text>
47
+            <text class="orderList_listItem_item_name" v-else>暂未接单</text>
48
+            <text class="orderList_listItem_item_time" v-if="newOrder.showCreateTime">{{newOrder.showCreateTime}}</text>
49
+            <text class="orderList_listItem_item_time"
50
+              v-else-if="newOrder.yyjdTime && newOrder.gdState.value == 11">{{newOrder.yyjdTime | formatDate('MM-dd HH:mm')}}</text>
28 51
           </view>
29 52
           <view class="orderList_listItem_item_btns">
30 53
             <button type="primary" class="btn">撤销</button>
@@ -35,12 +58,17 @@
35 58
     </view>
36 59
     <seiminFooterNav></seiminFooterNav>
37 60
     <seiminModel ref="seiminModel"></seiminModel>
61
+    <seiminPicker ref="sPicker" titleColor="#808080" titleFontSize="28rpx" confirmColor="#333" confirmFontSize="38rpx"
62
+      confirmFontWeight="500" itemFontSize="28rpx" @onClose="closePicker" @onConfirm="confirmPicker"
63
+      :pickerList="pickerList">
64
+    </seiminPicker>
38 65
   </view>
39 66
 </template>
40 67
 
41 68
 <script>
42 69
   import {
43
-    mapState
70
+    mapState,
71
+    mapActions
44 72
   } from "vuex";
45 73
   import {
46 74
     reqFetchDataList
@@ -52,14 +80,61 @@
52 80
     name: 'orderList',
53 81
     data() {
54 82
       return {
83
+        gdStates: [{
84
+            value: -1,
85
+            label: '全部'
86
+          },
87
+          {
88
+            value: 1,
89
+            label: '执行中'
90
+          },
91
+          {
92
+            value: 2,
93
+            label: '待评价'
94
+          },
95
+        ], //工单状态筛选列表
96
+        associationTypes: [], //关联类型筛选列表
55 97
         newOrderList: [], //工单列表
98
+        totalNum: 0, //工单总数量
56 99
         idx: 0, //页码
100
+        pageNum: 20, //每页的工单数量
101
+        pickerList: [], //picker列表
57 102
       };
58 103
     },
59 104
     computed: {
60 105
       ...mapState("user", ["loginInfo"]),
61 106
     },
62 107
     methods: {
108
+      ...mapActions("dictionary", ["vxDictionary"]),
109
+      // 获取数据字典
110
+      getDictionary(key) {
111
+        let postData = {
112
+          "type": "list",
113
+          key
114
+        };
115
+        this.vxDictionary(postData).then(res => {
116
+          console.log(res);
117
+        })
118
+      },
119
+      //关闭
120
+      closePicker() {
121
+        this.$refs.sPicker._close();
122
+      },
123
+      //打开
124
+      openPicker() {
125
+        this.$refs.sPicker._open();
126
+      },
127
+      //确定:接收子组件传来的参数
128
+      confirmPicker(checkedObj) {
129
+        // this.changeSearchDeptParams({
130
+        //   backUrl: "/pages/index/index", //返回的url
131
+        //   type: "changeDept_index", //首页切换科室
132
+        //   hospital: checkedObj, //先选择院区
133
+        // });
134
+        // uni.navigateTo({
135
+        //   url: "/pages/searchDept/searchDept",
136
+        // });
137
+      },
63 138
       // 获取页面数据
64 139
       init() {
65 140
         uni.showLoading({
@@ -76,6 +151,14 @@
76 151
       },
77 152
       // 查询最新工单列表(上拉)
78 153
       reachBottom() {
154
+        //没有更多
155
+        if (this.newOrderList.length == this.totalNum) {
156
+          uni.showToast({
157
+            icon: 'none',
158
+            title: '没有更多工单了'
159
+          })
160
+          return;
161
+        }
79 162
         uni.showLoading({
80 163
           title: "加载中",
81 164
           mask: true,
@@ -84,7 +167,6 @@
84 167
           this.queryWorkOrdersRequest(true), //查询最新工单列表
85 168
         ]).then((values) => {
86 169
           uni.hideLoading();
87
-          uni.stopPullDownRefresh();
88 170
           this.queryWorkOrdersResponse(values[0], true);
89 171
         });
90 172
       },
@@ -103,13 +185,14 @@
103 185
             searchDays: 2,
104 186
           },
105 187
           idx: this.idx,
106
-          sum: 10,
188
+          sum: this.pageNum,
107 189
         });
108 190
       },
109 191
       // 查询最新工单列表
110 192
       queryWorkOrdersResponse(res, idxPlus = false) {
111 193
         if (res.status == 200) {
112 194
           res.list = res.list || [];
195
+          this.totalNum = res.totalNum || 0;
113 196
           let newOrderList = res.list.map((v) => {
114 197
             if (v.gdState) {
115 198
               if (
@@ -130,7 +213,7 @@
130 213
           });
131 214
           if (idxPlus) {
132 215
             //累加
133
-            this.newOrderList.push(newOrderList)
216
+            this.newOrderList = this.newOrderList.concat(newOrderList);
134 217
           } else {
135 218
             this.newOrderList = newOrderList;
136 219
           }
@@ -145,6 +228,7 @@
145 228
       },
146 229
     },
147 230
     mounted() {
231
+      this.getDictionary('association_types');
148 232
       this.init();
149 233
     },
150 234
     onPullDownRefresh() {
@@ -219,19 +303,35 @@
219 303
 
220 304
           .orderList_listItem_header_title {
221 305
             color: #333;
306
+            flex: 1;
222 307
             @include flex(flex-start, center);
223 308
 
224 309
             .associationType_icon {
225 310
               width: 48rpx;
226 311
               height: 48rpx;
227 312
               border-radius: 50%;
228
-              background-color: rgba(57, 177, 153, 0.3);
313
+              background-color: #F0F6ED;
229 314
               border: 1px solid #39b199;
230 315
               font-size: 24rpx;
231 316
               color: #39b199;
232 317
               margin-right: 8rpx;
233 318
               @include flex(center, center);
234 319
             }
320
+
321
+            .taskNameAndWorkerName {
322
+              flex: 1;
323
+              @include flex;
324
+
325
+              .taskName {
326
+                max-width: 10em;
327
+                @include clamp;
328
+              }
329
+
330
+              .workerName {
331
+                flex: 1;
332
+                @include clamp;
333
+              }
334
+            }
235 335
           }
236 336
 
237 337
           .orderList_listItem_header_more {

+ 2 - 2
pages/quickCreateOrder/quickCreateOrder.vue

@@ -134,7 +134,7 @@
134 134
     },
135 135
     computed: {
136 136
       ...mapState('user', ['loginInfo']),
137
-      ...mapState([
137
+      ...mapState('other', [
138 138
         "qucikCreateOrderType",
139 139
         "qucikCreateOrderTypeId",
140 140
         "deptDisplay",
@@ -143,7 +143,7 @@
143 143
       ]),
144 144
     },
145 145
     methods: {
146
-      ...mapMutations(['changeSearchDeptParams', 'changeSearchDeptResultList']),
146
+      ...mapMutations('other', ['changeSearchDeptParams', 'changeSearchDeptResultList']),
147 147
       // 添加备注
148 148
       addRemarks(customRemark) {
149 149
         this.remarksFocus = false;

+ 2 - 2
pages/searchDept/searchDept.vue

@@ -62,7 +62,7 @@
62 62
     },
63 63
     computed: {
64 64
       ...mapState("user", ["loginInfo"]),
65
-      ...mapState([
65
+      ...mapState('other', [
66 66
         "deptDisplay",
67 67
         "searchDeptParams",
68 68
         "searchDeptResult",
@@ -79,7 +79,7 @@
79 79
       this.init();
80 80
     },
81 81
     methods: {
82
-      ...mapMutations([
82
+      ...mapMutations('other', [
83 83
         "changeSearchDeptResult",
84 84
         "changeSeiminModel",
85 85
         "changeSearchDeptResultList",

+ 6 - 6
request/api.js

@@ -3,12 +3,12 @@ import {
3 3
 } from "./index.js";
4 4
 
5 5
 // 数据字典查询
6
-// export const reqDictionary = (postData) =>
7
-//   request({
8
-//     url: "/common/common/getDictionary",
9
-//     data: postData,
10
-//     method: 'POST'
11
-//   });
6
+export const reqDictionary = (postData) =>
7
+  request({
8
+    url: "/common/common/getDictionary",
9
+    data: postData,
10
+    method: 'POST'
11
+  });
12 12
 
13 13
 // 用户登录接口
14 14
 export const reqLogin = (postData) =>

+ 15 - 62
store/index.js

@@ -2,21 +2,29 @@
2 2
  * @Author: 廖明明
3 3
  * @Date: 2022-03-31 16:36:19
4 4
  * @LastEditors: 廖明明
5
- * @LastEditTime: 2022-04-01 17:45:03
5
+ * @LastEditTime: 2022-04-22 10:16:40
6 6
  * @Description:vuex入口文件
7 7
  */
8 8
 import Vue from "vue";
9 9
 import Vuex from "vuex";
10 10
 
11
-import user from "@/store/modules/user";
11
+import other from "./modules/other";
12
+import user from "./modules/user";
13
+import dictionary from "./modules/dictionary";
14
+import system from "./modules/system";
12 15
 
13 16
 Vue.use(Vuex);
14 17
 
15 18
 const myPlugin = (store) => {
16 19
   // 当 store 初始化后调用
17 20
   let vuexStorage = uni.getStorageSync("vuexStorage");
18
-  if (vuexStorage) {
19
-    console.log(vuexStorage)
21
+  if (
22
+    vuexStorage &&
23
+    vuexStorage.user &&
24
+    vuexStorage.dictionary &&
25
+    vuexStorage.system &&
26
+    vuexStorage.other
27
+  ) {
20 28
     store.replaceState(vuexStorage);
21 29
   }
22 30
   store.subscribe((mutation, state) => {
@@ -25,66 +33,11 @@ const myPlugin = (store) => {
25 33
 };
26 34
 
27 35
 export default new Vuex.Store({
28
-  state: {
29
-    isShowSeiminModel: false, //是否显示切换科室弹窗
30
-    qucikCreateOrderType: '', //快捷建单类型
31
-    qucikCreateOrderTypeId: '', //快捷建单类型id
32
-    deptDisplay: 1, //护士端科室显示选择(名称还是别名)1是名称,2是别名
33
-    updateTipsForNurses: '', //护士端更新提示
34
-    specimenButton: '', //标本按钮文字
35
-    //护士科室切换提示自动关闭设置
36
-    // (1)	当用户设置为正数时,用户必须查看此窗体指定秒数。
37
-    // (2)	当用户设置为负数时,用户可点击知道了也可倒计时自动关闭。
38
-    // (3)	如果用户填写0则为无自动关闭和强制查看时间。
39
-    nurseDeptSwitchTip: 0,
40
-    // 搜索到的科室-searchDept
41
-    searchDeptResult: {},
42
-    // 搜索到的科室集合-searchDept-选起点科室并且需要选终点科室
43
-    searchDeptResultList: {},
44
-    // 搜索科室需要传递的参数
45
-    searchDeptParams: {},
46
-  },
47
-  mutations: {
48
-    //是否显示切换科室弹窗
49
-    changeSeiminModel(state, args) {
50
-      state.isShowSeiminModel = args;
51
-    },
52
-    //快捷建单类型
53
-    changeQucikCreateOrderType(state, args) {
54
-      state.qucikCreateOrderType = args.type;
55
-      state.qucikCreateOrderTypeId = args.taskTypeId;
56
-    },
57
-    //护士端科室显示选择(名称还是别名)1是名称,2是别名
58
-    changeDeptDisplay(state, args) {
59
-      state.deptDisplay = args;
60
-    },
61
-    //护士端更新提示
62
-    changeUpdateTipsForNurses(state, args) {
63
-      state.updateTipsForNurses = args;
64
-    },
65
-    //标本按钮文字
66
-    changeSpecimenButton(state, args) {
67
-      state.specimenButton = args;
68
-    },
69
-    //护士科室切换提示自动关闭设置
70
-    changeNurseDeptSwitchTip(state, args) {
71
-      state.nurseDeptSwitchTip = args;
72
-    },
73
-    //搜索到的科室-searchDept
74
-    changeSearchDeptResult(state, args) {
75
-      state.searchDeptResult = args || {};
76
-    },
77
-    //搜索到的科室集合-searchDept-选起点科室并且需要选终点科室
78
-    changeSearchDeptResultList(state, args) {
79
-      state.searchDeptResultList = args || {};
80
-    },
81
-    //搜索科室需要传递的参数
82
-    changeSearchDeptParams(state, args) {
83
-      state.searchDeptParams = args;
84
-    },
85
-  },
86 36
   modules: {
87 37
     user,
38
+    dictionary,
39
+    system,
40
+    other,
88 41
   },
89 42
   plugins: [myPlugin],
90 43
 });

+ 45 - 27
store/modules/dictionary.js

@@ -1,27 +1,45 @@
1
-// import {
2
-//   reqDictionary
3
-// } from "@/request/api.js";
4
-// const state = {
5
-//   dictionary: {},
6
-// };
7
-// const getters = {};
8
-// const mutations = {
9
-//   vxDictionary(state, args) {
10
-//     state.dictionary = args;
11
-//   },
12
-// };
13
-// const actions = {
14
-//   async vxDictionary({
15
-//     commit
16
-//   }, args) {
17
-//     let result = await reqDictionary(args);
18
-//     commit("vxDictionary", result.user);
19
-//   },
20
-// };
21
-// export default {
22
-//   namespaced: true,
23
-//   state,
24
-//   getters,
25
-//   mutations,
26
-//   actions,
27
-// };
1
+import {
2
+  reqDictionary
3
+} from "@/request/api.js";
4
+import cloneDeep from 'lodash/cloneDeep'
5
+const stateReset = {
6
+  dictionaryInfo: {},
7
+};
8
+const state = cloneDeep(stateReset);
9
+const getters = {};
10
+const mutations = {
11
+  // 重置字典数据
12
+  resetVxDictionary(state) {
13
+    Object.assign(state, cloneDeep(stateReset))
14
+  },
15
+  // 获取数据
16
+  vxDictionary(state, args) {
17
+    state.dictionaryInfo[args.key] = args.data;
18
+  },
19
+};
20
+const actions = {
21
+  // 获取字典数据
22
+  async vxDictionary({
23
+    commit,
24
+    state
25
+  }, args) {
26
+    if (state.dictionaryInfo[args.key]) {
27
+      //如果存在
28
+      return await Promise.resolve(state.dictionaryInfo[args.key]);
29
+    } else {
30
+      let result = await reqDictionary(args);
31
+      commit("vxDictionary", {
32
+        key: args.key,
33
+        data: result
34
+      });
35
+      return result;
36
+    }
37
+  },
38
+};
39
+export default {
40
+  namespaced: true,
41
+  state,
42
+  getters,
43
+  mutations,
44
+  actions,
45
+};

+ 75 - 0
store/modules/other.js

@@ -0,0 +1,75 @@
1
+import cloneDeep from 'lodash/cloneDeep'
2
+const stateReset = {
3
+  isShowSeiminModel: false, //是否显示切换科室弹窗
4
+  qucikCreateOrderType: "", //快捷建单类型
5
+  qucikCreateOrderTypeId: "", //快捷建单类型id
6
+  deptDisplay: 1, //护士端科室显示选择(名称还是别名)1是名称,2是别名
7
+  updateTipsForNurses: "", //护士端更新提示
8
+  specimenButton: "", //标本按钮文字
9
+  //护士科室切换提示自动关闭设置
10
+  // (1)	当用户设置为正数时,用户必须查看此窗体指定秒数。
11
+  // (2)	当用户设置为负数时,用户可点击知道了也可倒计时自动关闭。
12
+  // (3)	如果用户填写0则为无自动关闭和强制查看时间。
13
+  nurseDeptSwitchTip: 0,
14
+  // 搜索到的科室-searchDept
15
+  searchDeptResult: {},
16
+  // 搜索到的科室集合-searchDept-选起点科室并且需要选终点科室
17
+  searchDeptResultList: {},
18
+  // 搜索科室需要传递的参数
19
+  searchDeptParams: {},
20
+};
21
+const state = cloneDeep(stateReset);
22
+const getters = {};
23
+const mutations = {
24
+  // 重置数据
25
+  resetVxOther(state) {
26
+    Object.assign(state, cloneDeep(stateReset));
27
+  },
28
+  //是否显示切换科室弹窗
29
+  changeSeiminModel(state, args) {
30
+    state.isShowSeiminModel = args;
31
+  },
32
+  //快捷建单类型
33
+  changeQucikCreateOrderType(state, args) {
34
+    state.qucikCreateOrderType = args.type;
35
+    state.qucikCreateOrderTypeId = args.taskTypeId;
36
+  },
37
+  //护士端科室显示选择(名称还是别名)1是名称,2是别名
38
+  changeDeptDisplay(state, args) {
39
+    state.deptDisplay = args;
40
+  },
41
+  //护士端更新提示
42
+  changeUpdateTipsForNurses(state, args) {
43
+    state.updateTipsForNurses = args;
44
+  },
45
+  //标本按钮文字
46
+  changeSpecimenButton(state, args) {
47
+    state.specimenButton = args;
48
+  },
49
+  //护士科室切换提示自动关闭设置
50
+  changeNurseDeptSwitchTip(state, args) {
51
+    state.nurseDeptSwitchTip = args;
52
+  },
53
+  //搜索到的科室-searchDept
54
+  changeSearchDeptResult(state, args) {
55
+    state.searchDeptResult = args || {};
56
+  },
57
+  //搜索到的科室集合-searchDept-选起点科室并且需要选终点科室
58
+  changeSearchDeptResultList(state, args) {
59
+    state.searchDeptResultList = args || {};
60
+  },
61
+  //搜索科室需要传递的参数
62
+  changeSearchDeptParams(state, args) {
63
+    state.searchDeptParams = args;
64
+  },
65
+};
66
+const actions = {
67
+
68
+};
69
+export default {
70
+  namespaced: true,
71
+  state,
72
+  getters,
73
+  mutations,
74
+  actions,
75
+};

+ 47 - 0
store/modules/system.js

@@ -0,0 +1,47 @@
1
+import {
2
+  reqFetchDataList
3
+} from "@/request/api.js";
4
+import cloneDeep from 'lodash/cloneDeep'
5
+const stateReset = {
6
+  systemInfo: {},
7
+};
8
+const state = cloneDeep(stateReset);
9
+const getters = {};
10
+const mutations = {
11
+  // 重置字典数据
12
+  resetVxSystem(state) {
13
+    Object.assign(state, cloneDeep(stateReset))
14
+  },
15
+  // 获取数据
16
+  vxSystem(state, args) {
17
+    state.systemInfo[args.key] = args.data;
18
+  },
19
+};
20
+const actions = {
21
+  // 获取字典数据
22
+  async vxSystem({
23
+    commit,
24
+    state
25
+  }, args) {
26
+    if (state.systemInfo[args.systemConfiguration.keyconfig]) {
27
+      //如果存在
28
+      return await Promise.resolve(state.systemInfo[args.systemConfiguration.keyconfig]);
29
+    } else {
30
+      let result = await reqFetchDataList('simple/data', 'systemConfiguration', args);
31
+      if (result.status == 200) {
32
+        commit("vxSystem", {
33
+          key: args.systemConfiguration.keyconfig,
34
+          data: result
35
+        });
36
+      }
37
+      return result;
38
+    }
39
+  },
40
+};
41
+export default {
42
+  namespaced: true,
43
+  state,
44
+  getters,
45
+  mutations,
46
+  actions,
47
+};

+ 7 - 1
store/modules/user.js

@@ -1,11 +1,17 @@
1 1
 import {
2 2
   reqLogin
3 3
 } from "@/request/api.js";
4
-const state = {
4
+import cloneDeep from 'lodash/cloneDeep'
5
+const stateReset = {
5 6
   loginInfo: {}, //当前登录用户信息
6 7
 };
8
+const state = cloneDeep(stateReset);
7 9
 const getters = {};
8 10
 const mutations = {
11
+  // 重置数据
12
+  resetVxLogin(state) {
13
+    Object.assign(state, cloneDeep(stateReset))
14
+  },
9 15
   // 登录
10 16
   vxLogin(state, args) {
11 17
     state.loginInfo = args || {};

+ 4 - 4
uni.scss

@@ -89,16 +89,16 @@ $textColorYellow: #F5A623;
89 89
 // --------------------------华丽的分割线---------------------------------------
90 90
 // 全局样式
91 91
 .w100{
92
-  width: 100%;
92
+  width: 100%!important;
93 93
 }
94 94
 .red {
95
-  color: $textColorRed;
95
+  color: $textColorRed!important;
96 96
 }
97 97
 .yellow {
98
-  color: $textColorYellow;
98
+  color: $textColorYellow!important;
99 99
 }
100 100
 .green {
101
-  color: $defaultColor;
101
+  color: $defaultColor!important;
102 102
 }
103 103
 // 内置复选框 start
104 104
 .uni-label-pointer{