Browse Source

增加万能交接服务得血制品

seimin 2 years ago
parent
commit
a97c4fc612

+ 6 - 1
components/bigScreen/bigScreen.vue

@@ -266,7 +266,7 @@
266 266
                           uni.navigateTo({
267 267
                             url: `../scanning_all/scanning_all?infoDATA=${encodeURIComponent(
268 268
                             JSON.stringify(infoDATA)
269
-                          )}&code=${data.code}`,
269
+                          )}&code=${data.code}&deptName=${res.deptName}`,
270 270
                           });
271 271
                         }
272 272
                       } else if (res.type == 'drugsBag') {
@@ -279,6 +279,11 @@
279 279
                         uni.navigateTo({
280 280
                           url: `/pages/scanning_nucleicAcid/scanning_nucleicAcid?qrcode=${data.code}`,
281 281
                         });
282
+                      } else if (res.type == 'blood') {
283
+                        //扫血制品
284
+                        uni.navigateTo({
285
+                          url: `/pages/scanning_blood/scanning_blood?qrcode=${data.code}`,
286
+                        });
282 287
                       }
283 288
                     } else {
284 289
                       uni.navigateTo({

+ 370 - 0
components/handViewBlood/handViewBlood.vue

@@ -0,0 +1,370 @@
1
+<template>
2
+  <view class="changeHospital" v-show="disjunctor">
3
+    <view class="changeHospital__wrap">
4
+      <view class="changeHospital__header" v-if="title">
5
+        {{ title }}
6
+      </view>
7
+      <view class="changeHospital__article">
8
+        <view class="uni-list-cell">
9
+          <view class="uni-list-cell-left">
10
+            {{name}}:
11
+          </view>
12
+          <view class="uni-list-cell-db">
13
+            <input class="uni-input" auto-focus="true" :placeholder="'请填写'+name" v-model="account"
14
+              @input="bindPickerChange($event)" />
15
+          </view>
16
+        </view>
17
+        <view class="uni-list-cell">
18
+          <view class="uni-list-cell-left">
19
+            血液类型:
20
+          </view>
21
+          <view class="uni-list-cell-db-text">
22
+            <text v-show="!loading">{{spe.type?spe.type.name:'无'}}</text>
23
+            <view class="sk-circle" v-show="loading">
24
+              <view class="sk-circle-dot"></view>
25
+              <view class="sk-circle-dot"></view>
26
+              <view class="sk-circle-dot"></view>
27
+              <view class="sk-circle-dot"></view>
28
+              <view class="sk-circle-dot"></view>
29
+              <view class="sk-circle-dot"></view>
30
+              <view class="sk-circle-dot"></view>
31
+              <view class="sk-circle-dot"></view>
32
+              <view class="sk-circle-dot"></view>
33
+              <view class="sk-circle-dot"></view>
34
+              <view class="sk-circle-dot"></view>
35
+              <view class="sk-circle-dot"></view>
36
+            </view>
37
+          </view>
38
+        </view>
39
+        <view class="uni-list-cell">
40
+          <view class="uni-list-cell-left">
41
+            血量:
42
+          </view>
43
+          <view class="uni-list-cell-db-text">
44
+            <text v-show="!loading">{{ spe.volume?spe.volume+'ML':'无' }}</text>
45
+            <view class="sk-circle" v-show="loading">
46
+              <view class="sk-circle-dot"></view>
47
+              <view class="sk-circle-dot"></view>
48
+              <view class="sk-circle-dot"></view>
49
+              <view class="sk-circle-dot"></view>
50
+              <view class="sk-circle-dot"></view>
51
+              <view class="sk-circle-dot"></view>
52
+              <view class="sk-circle-dot"></view>
53
+              <view class="sk-circle-dot"></view>
54
+              <view class="sk-circle-dot"></view>
55
+              <view class="sk-circle-dot"></view>
56
+              <view class="sk-circle-dot"></view>
57
+              <view class="sk-circle-dot"></view>
58
+            </view>
59
+          </view>
60
+        </view>
61
+        <view class="uni-list-cell">
62
+          <view class="uni-list-cell-left">
63
+            患者姓名:
64
+          </view>
65
+          <view class="uni-list-cell-db-text">
66
+            <text v-show="!loading">{{spe.patientName || '无'}}</text>
67
+            <view class="sk-circle" v-show="loading">
68
+              <view class="sk-circle-dot"></view>
69
+              <view class="sk-circle-dot"></view>
70
+              <view class="sk-circle-dot"></view>
71
+              <view class="sk-circle-dot"></view>
72
+              <view class="sk-circle-dot"></view>
73
+              <view class="sk-circle-dot"></view>
74
+              <view class="sk-circle-dot"></view>
75
+              <view class="sk-circle-dot"></view>
76
+              <view class="sk-circle-dot"></view>
77
+              <view class="sk-circle-dot"></view>
78
+              <view class="sk-circle-dot"></view>
79
+              <view class="sk-circle-dot"></view>
80
+            </view>
81
+          </view>
82
+        </view>
83
+      </view>
84
+      <view class="changeHospital__footer">
85
+        <view v-if="operate.ok" class="changeHospital__ok" @click="ok" hover-class="seimin-btn-hover">
86
+          {{ operate.ok || "" }}
87
+        </view>
88
+        <view v-if="operate.cancel" class="changeHospital__cancel" @click="cancel" hover-class="seimin-btn-hover">
89
+          {{ operate.cancel || "" }}
90
+        </view>
91
+      </view>
92
+    </view>
93
+  </view>
94
+</template>
95
+
96
+<script>
97
+  import {
98
+    post
99
+  } from "../../http/http.js";
100
+  export default {
101
+    data() {
102
+      return {
103
+        cValue: '', //当前输入的标本编码
104
+        loading: false,
105
+        userData: null,
106
+        hosId: null,
107
+        timer: null,
108
+        spe: {}, //标本对象
109
+        account: '', //交接人账号
110
+        accountName: '', //交接人姓名
111
+        accountId: '' //交接人ID
112
+      };
113
+    },
114
+    watch: {
115
+      disjunctor(newValue) {
116
+        if (newValue && this.operate.know == "知道了") {
117
+          this.time = 5;
118
+          this.timer = setInterval(() => {
119
+            this.time--;
120
+            if (this.time <= 0) {
121
+              clearInterval(this.timer);
122
+              this.know();
123
+            }
124
+          }, 1000);
125
+        }
126
+      },
127
+    },
128
+    props: {
129
+      // 显示隐藏
130
+      disjunctor: {
131
+        type: Boolean,
132
+        default: false,
133
+      },
134
+      // 标题
135
+      title: {
136
+        type: String,
137
+        default: "提示",
138
+      },
139
+      // 操作按钮文字
140
+      operate: {
141
+        type: Object,
142
+        default: () => {
143
+          return {
144
+            ok: "确认",
145
+            cancel: "取消",
146
+          };
147
+        },
148
+      },
149
+      name: {
150
+        type: String,
151
+        default: '血袋号'
152
+      }
153
+    },
154
+    methods: {
155
+      //修改picker的值
156
+      bindPickerChange(e) {
157
+        console.log(e)
158
+        this.spe = {};
159
+        this.loading = true;
160
+        this.cValue = e.target.value;
161
+        clearTimeout(this.timer);
162
+        if (this.cValue.length <= 4) {
163
+          this.spe = {};
164
+          this.loading = false;
165
+          return;
166
+        }
167
+        this.timer = setTimeout(() => {
168
+          let nAccount = e.target.value;
169
+          post("/transflow/scanInfo", {
170
+            type: 'blood',
171
+            code: nAccount,
172
+          }).then(result => {
173
+            if (result.state == 200) {
174
+              if (this.cValue === nAccount) {
175
+                if (result.data) {
176
+                  //有值
177
+                  this.spe = result.data.dto;
178
+                } else {
179
+                  // 没值
180
+                  this.spe = {};
181
+                }
182
+                this.loading = false;
183
+              }
184
+            } else {
185
+              this.spe = {};
186
+              this.loading = false;
187
+            }
188
+          }).catch(err => {
189
+            this.spe = {};
190
+            this.loading = false;
191
+          })
192
+        }, 500)
193
+      },
194
+      // 确定
195
+      ok() {
196
+        this.$emit("ok", this.spe);
197
+      },
198
+      // 取消
199
+      cancel() {
200
+        this.$emit("cancel");
201
+      },
202
+    },
203
+    created() {
204
+      this.hosId = uni.getStorageSync('userData').user.currentHospital.id;
205
+    }
206
+  };
207
+</script>
208
+
209
+<style lang="less" scoped>
210
+  .changeHospital {
211
+    position: fixed;
212
+    left: 0;
213
+    right: 0;
214
+    top: 0;
215
+    bottom: 0;
216
+    background-color: rgba(0, 0, 0, 0.2);
217
+    z-index: 999;
218
+
219
+    .uni-list-cell {
220
+      width: 90%;
221
+      display: flex;
222
+      flex-direction: row;
223
+      justify-content: space-evenly;
224
+      align-items: center;
225
+      text-align: center;
226
+      margin-top: 32rpx;
227
+
228
+      .uni-list-cell-left {
229
+        flex: 3;
230
+        font-size: 32rpx;
231
+        color: #666;
232
+      }
233
+
234
+      .uni-list-cell-db {
235
+        border: 1px solid #e5e9ed;
236
+        background-color: #fff;
237
+        padding: 16rpx 0;
238
+        flex: 5;
239
+      }
240
+
241
+      .uni-list-cell-db-text {
242
+        flex: 5;
243
+        text-align: left;
244
+      }
245
+    }
246
+
247
+    .changeHospital__wrap {
248
+      width: 90vw;
249
+      position: absolute;
250
+      left: 50%;
251
+      top: 50%;
252
+      transform: translate(-50%, -50%);
253
+      background-color: #fff;
254
+      border-radius: 12rpx;
255
+      color: #666;
256
+
257
+      .changeHospital__header {
258
+        font-size: 36rpx;
259
+        color: #000;
260
+        height: 84rpx;
261
+        display: flex;
262
+        justify-content: center;
263
+        align-items: center;
264
+      }
265
+
266
+      .changeHospital__article {
267
+        width: 90%;
268
+        margin: 0 auto 25rpx;
269
+        padding: 48rpx 0;
270
+        background-color: rgb(249, 250, 251);
271
+        border: 2rpx solid rgb(229, 233, 237);
272
+        border-radius: 12rpx;
273
+        box-sizing: border-box;
274
+        display: flex;
275
+        flex-direction: column;
276
+        justify-content: center;
277
+        align-items: center;
278
+
279
+        &.p0 {
280
+          padding: 0;
281
+        }
282
+
283
+        .changeHospital__icon {
284
+          font-size: 138rpx;
285
+          margin-bottom: 32rpx;
286
+
287
+          &.changeHospital__icon--success {
288
+            color: rgb(52, 179, 73);
289
+          }
290
+
291
+          &.changeHospital__icon--warn {
292
+            color: rgb(245, 165, 35);
293
+          }
294
+
295
+          &.changeHospital__icon--error {
296
+            color: rgb(255, 58, 82);
297
+          }
298
+        }
299
+
300
+        .changeHospital__content {
301
+          font-size: 36rpx;
302
+        }
303
+
304
+        .changeHospital__info {
305
+          font-size: 32rpx;
306
+          color: rgb(102, 102, 102);
307
+        }
308
+
309
+        .specialCloseFlag {
310
+          width: 90%;
311
+          height: 100%;
312
+          padding: 16rpx;
313
+        }
314
+
315
+        .radio-wrap {
316
+          .radio-item {
317
+            margin-top: 16rpx;
318
+
319
+            /deep/ .uni-radio-input-checked {
320
+              background-color: #49b856 !important;
321
+              border-color: #49b856 !important;
322
+            }
323
+          }
324
+        }
325
+      }
326
+
327
+      .changeHospital__footer {
328
+        box-sizing: border-box;
329
+        height: 100rpx;
330
+        border-top: 2rpx solid rgb(229, 233, 237);
331
+        display: flex;
332
+        align-items: center;
333
+
334
+        view {
335
+          height: 100%;
336
+          display: flex;
337
+          align-items: center;
338
+          justify-content: center;
339
+          font-size: 36rpx;
340
+          color: rgb(102, 102, 102);
341
+          position: relative;
342
+
343
+          &:nth-of-type(2)::before {
344
+            content: "";
345
+            position: absolute;
346
+            left: 0;
347
+            bottom: 0;
348
+            width: 2rpx;
349
+            height: 87rpx;
350
+            background-color: rgb(229, 233, 237);
351
+          }
352
+        }
353
+
354
+        .changeHospital__ok {
355
+          flex: 1;
356
+          color: rgb(73, 184, 86);
357
+        }
358
+
359
+        .changeHospital__cancel {
360
+          flex: 1;
361
+        }
362
+
363
+        .changeHospital__know {
364
+          flex: 1;
365
+          color: rgb(73, 184, 86);
366
+        }
367
+      }
368
+    }
369
+  }
370
+</style>

+ 7 - 1
main.js

@@ -4,7 +4,7 @@ import App from './App'
4 4
 import wx from 'weixin-jsapi'
5 5
 // import VConsole from 'vconsole';
6 6
 // new VConsole();
7
-console.info('v2.4.15');
7
+console.info('v2.4.16');
8 8
 Vue.prototype.wx = wx //声明扫码
9 9
 Vue.prototype.audios = [] //待播放的语音集合
10 10
 // #endif
@@ -12,6 +12,7 @@ Vue.prototype.audios = [] //待播放的语音集合
12 12
 Vue.prototype.$ws = null//websocket
13 13
 // #endif
14 14
 Vue.config.productionTip = false
15
+
15 16
 Date.prototype.Format = function (fmt) {
16 17
     var o = {
17 18
         "M+": this.getMonth() + 1, //月份
@@ -37,6 +38,11 @@ Date.prototype.Format = function (fmt) {
37 38
             );
38 39
     return fmt;
39 40
 };
41
+// 日期过滤器
42
+Vue.filter('formatDate', function(timestamp, format){
43
+  console.log(timestamp, format);
44
+  return new Date(timestamp).Format(format);
45
+})
40 46
 App.mpType = 'app'
41 47
 
42 48
 const app = new Vue({

+ 370 - 335
pages.json

@@ -1,337 +1,372 @@
1 1
 {
2
-	"pages": [
3
-		//pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages
4
-		{
5
-			"path": "pages/homePage/homePage", //上班和登录页面
6
-			"style": {
7
-				"h5": {
8
-					"titleNView": false
9
-				}
10
-			}
11
-		},
12
-		{
13
-			"path": "pages/bindUser/bindUser", //绑定账号页面
14
-			"style": {
15
-				"h5": {
16
-					"titleNView": false
17
-				}
18
-			}
19
-		},
20
-		{
21
-			"path": "pages/setDept/setDept", //设置科室界面
22
-			"style": {
23
-				"h5": {
24
-					"titleNView": false
25
-				}
26
-			}
27
-		},
28
-		{
29
-			"path": "pages/receiptpage/receiptpage", //列表
30
-			"style": {
31
-				"h5": {
32
-					"titleNView": false
33
-				}
34
-			}
35
-		},
36
-		{
37
-			"path": "pages/receipt_infopage/receipt_infopage", //列表详情
38
-			"style": {
39
-				"h5": {
40
-					"titleNView": false
41
-				}
42
-			}
43
-		},
44
-		{
45
-			"path": "pages/scanning_code/scanning_code",
46
-			"style": {
47
-				"h5": {
48
-					"titleNView": false
49
-				}
50
-			}
51
-		},
52
-		{
53
-			"path": "pages/scanning_Result/scanning_Result", //大扫描结果->错误
54
-			"style": {
55
-				"h5": {
56
-					"titleNView": false
57
-				}
58
-			}
59
-		},
60
-		{
61
-			"path": "pages/scanning_result_seimin/scanning_result_seimin", //药包扫描----知道了
62
-			"style": {
63
-				"h5": {
64
-					"titleNView": false
65
-				}
66
-			}
67
-		},
68
-		{
69
-			"path": "pages/scanning_B/scanning_B", //大扫描->标本结果->正确,错误
70
-			"style": {
71
-				"h5": {
72
-					"titleNView": false
73
-				}
74
-			}
75
-		},
76
-		{
77
-			"path": "pages/scanning_ins/scanning_ins", //大扫描->患者(陪检,转运)
78
-			"style": {
79
-				"h5": {
80
-					"titleNView": false
81
-				}
82
-			}
83
-		},
84
-		{
85
-			"path": "pages/shortcutbuildOrders/shortcutbuildOrders",
86
-			"style": {
87
-				"h5": {
88
-					"titleNView": false
89
-				}
90
-			}
91
-		},
92
-		{
93
-			"path": "pages/specimenChecking/specimenChecking",
94
-			"style": {
95
-				"h5": {
96
-					"titleNView": false
97
-				},
98
-				"enablePullDownRefresh": true
99
-			}
100
-		},
101
-		{
102
-			"path": "pages/scanning_all/scanning_all", //大扫描->科室->正确
103
-			"style": {
104
-				"h5": {
105
-					"titleNView": false
106
-				}
107
-			}
108
-		},
109
-		{
110
-			"path": "pages/scanning_djInfo/scanning_djInfo",
111
-			"style": {
112
-				"h5": {
113
-					"titleNView": false
114
-				}
115
-			}
116
-		},
117
-		{
118
-			"path": "pages/scanning_djEnd/scanning_djEnd",
119
-			"style": {
120
-				"h5": {
121
-					"titleNView": false
122
-				}
123
-			}
124
-		},
125
-		{
126
-			"path": "pages/scanning/scanning",
127
-			"style": {
128
-				"h5": {
129
-					"titleNView": false
130
-				}
131
-			}
132
-		},
133
-		{
134
-			"path": "pages/scanning_orderSign/scanning_orderSign",
135
-			"style": {
136
-				"h5": {
137
-					"titleNView": false
138
-				}
139
-			}
140
-		},
141
-		{
142
-			"path": "pages/scanning_insEnd/scanning_insEnd",
143
-			"style": {
144
-				"h5": {
145
-					"titleNView": false
146
-				}
147
-			}
148
-		},
149
-		{
150
-			"path": "pages/my_list/my_list", //我的页面列表
151
-			"style": {
152
-				"h5": {
153
-					"titleNView": false
154
-				}
155
-			}
156
-		},
157
-		{
158
-			"path": "pages/mypage/mypage", //我的页面
159
-			"style": {
160
-				"h5": {
161
-					"titleNView": false
162
-				}
163
-			}
164
-		},
165
-		{
166
-			"path": "pages/pharmacy/pharmacy",
167
-			"style": {
168
-				"h5": {
169
-					"titleNView": false
170
-				}
171
-			}
172
-		},
173
-		{
174
-			"path": "pages/patientInformationList/patientInformationList", //患者信息列表
175
-			"style": {
176
-				"h5": {
177
-					"titleNView": false
178
-				}
179
-			}
180
-		},
181
-		{
182
-			"path": "pages/patientInformationInfo/patientInformationInfo", //患者信息详情
183
-			"style": {
184
-				"h5": {
185
-					"titleNView": false
186
-				}
187
-			}
188
-		},
189
-		{
190
-			"path": "pages/inspectList/inspectList", //检查信息列表
191
-			"style": {
192
-				"h5": {
193
-					"titleNView": false
194
-				}
195
-			}
196
-		},
197
-		{
198
-			"path": "pages/search/search", //搜索
199
-			"style": {
200
-				"h5": {
201
-					"titleNView": false
202
-				}
203
-			}
204
-		},
205
-		{
206
-			"path": "pages/pharmacyDetails/pharmacyDetails",
207
-			"style": {
208
-				"h5": {
209
-					"titleNView": false
210
-				}
211
-			}
212
-		},
213
-		{
214
-			"path": "pages/settingCode/settingCode",
215
-			"style": {
216
-				"h5": {
217
-					"titleNView": false
218
-				}
219
-			}
220
-		},
221
-		{
222
-			"path": "pages/noScanSpecimen/noScanSpecimen",
223
-			"style": {
224
-				"h5": {
225
-					"titleNView": false
226
-				}
227
-			}
228
-		},
229
-		{
230
-			"path": "pages/scanning_drug/scanning_drug",
231
-			"style": {
232
-				"h5": {
233
-					"titleNView": false
234
-				}
235
-			}
236
-		},
237
-		{
238
-			"path": "components/footTool/footTool",
239
-			"style": {
240
-				"navigationBarTitleText": "",
241
-				"enablePullDownRefresh": false
242
-			}
243
-		},
244
-		{
245
-			"path": "pages/specimenCheckingDetail/specimenCheckingDetail",
246
-			"style": {
247
-				"h5": {
248
-					"titleNView": false
249
-				},
250
-				"enablePullDownRefresh": true
251
-			}
252
-		},
253
-		{
254
-			"path": "pages/specimenDetail/specimenDetail",
255
-			"style": {
256
-				"h5": {
257
-					"titleNView": false
258
-				},
259
-				"enablePullDownRefresh": true
260
-			}
261
-		},
262
-		{
263
-			"path": "pages/checkAfterScanning/checkAfterScanning",
264
-			"style": {
265
-				"h5": {
266
-					"titleNView": false
267
-				},
268
-				"enablePullDownRefresh": false
269
-			}
270
-		},
271
-		{
272
-			"path": "pages/checkAfterBigScreen/checkAfterBigScreen",
273
-			"style": {
274
-				"h5": {
275
-					"titleNView": false
276
-				},
277
-				"enablePullDownRefresh": false
278
-			}
279
-		},
280
-		{
281
-			"path": "pages/scannedDepartmentSpecimens/scannedDepartmentSpecimens",
282
-			"style": {
283
-				"h5": {
284
-					"titleNView": false
285
-				},
286
-				"enablePullDownRefresh": true
287
-			}
288
-		},
289
-		{
290
-			"path": "pages/specimenCheckingEnd/specimenCheckingEnd",
291
-			"style": {
292
-				"h5": {
293
-					"titleNView": false
294
-				},
295
-				"enablePullDownRefresh": true
296
-			}
297
-		},
298
-		{
299
-			"path": "pages/scannedDepartmentSpecimensDetail/scannedDepartmentSpecimensDetail",
300
-			"style": {
301
-				"h5": {
302
-					"titleNView": false
303
-				}
304
-			}
305
-		},
306
-		{
307
-			"path": "pages/specimenCheckingEndDetail/specimenCheckingEndDetail",
308
-			"style": {
309
-				"h5": {
310
-					"titleNView": false
311
-				}
312
-			}
313
-		},
314
-		{
315
-			"path": "pages/scanning_nucleicAcid/scanning_nucleicAcid",
316
-			"style": {
317
-				"h5": {
318
-					"titleNView": false
319
-				}
320
-			}
321
-		},
322
-		{
323
-			"path": "pages/promptPage/promptPage",
324
-			"style": {
325
-				"h5": {
326
-					"titleNView": false
327
-				}
328
-			}
329
-		}
330
-	],
331
-	"globalStyle": {
332
-		"navigationBarTextStyle": "black",
333
-		"navigationBarTitleText": "医疗服务中心转运系统",
334
-		"navigationBarBackgroundColor": "#F8F8F8",
335
-		"backgroundColor": "#F8F8F8"
336
-	}
2
+  "pages": [
3
+    //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages
4
+    {
5
+      "path": "pages/homePage/homePage", //上班和登录页面
6
+      "style": {
7
+        "h5": {
8
+          "titleNView": false
9
+        }
10
+      }
11
+    },
12
+    {
13
+      "path": "pages/bindUser/bindUser", //绑定账号页面
14
+      "style": {
15
+        "h5": {
16
+          "titleNView": false
17
+        }
18
+      }
19
+    },
20
+    {
21
+      "path": "pages/setDept/setDept", //设置科室界面
22
+      "style": {
23
+        "h5": {
24
+          "titleNView": false
25
+        }
26
+      }
27
+    },
28
+    {
29
+      "path": "pages/receiptpage/receiptpage", //列表
30
+      "style": {
31
+        "h5": {
32
+          "titleNView": false
33
+        }
34
+      }
35
+    },
36
+    {
37
+      "path": "pages/receipt_infopage/receipt_infopage", //列表详情
38
+      "style": {
39
+        "h5": {
40
+          "titleNView": false
41
+        }
42
+      }
43
+    },
44
+    {
45
+      "path": "pages/scanning_code/scanning_code",
46
+      "style": {
47
+        "h5": {
48
+          "titleNView": false
49
+        }
50
+      }
51
+    },
52
+    {
53
+      "path": "pages/scanning_Result/scanning_Result", //大扫描结果->错误
54
+      "style": {
55
+        "h5": {
56
+          "titleNView": false
57
+        }
58
+      }
59
+    },
60
+    {
61
+      "path": "pages/scanning_result_seimin/scanning_result_seimin", //药包扫描----知道了
62
+      "style": {
63
+        "h5": {
64
+          "titleNView": false
65
+        }
66
+      }
67
+    },
68
+    {
69
+      "path": "pages/scanning_B/scanning_B", //大扫描->标本结果->正确,错误
70
+      "style": {
71
+        "h5": {
72
+          "titleNView": false
73
+        }
74
+      }
75
+    },
76
+    {
77
+      "path": "pages/scanning_ins/scanning_ins", //大扫描->患者(陪检,转运)
78
+      "style": {
79
+        "h5": {
80
+          "titleNView": false
81
+        }
82
+      }
83
+    },
84
+    {
85
+      "path": "pages/shortcutbuildOrders/shortcutbuildOrders",
86
+      "style": {
87
+        "h5": {
88
+          "titleNView": false
89
+        }
90
+      }
91
+    },
92
+    {
93
+      "path": "pages/specimenChecking/specimenChecking",
94
+      "style": {
95
+        "h5": {
96
+          "titleNView": false
97
+        },
98
+        "enablePullDownRefresh": true
99
+      }
100
+    },
101
+    {
102
+      "path": "pages/scanning_all/scanning_all", //大扫描->科室->正确
103
+      "style": {
104
+        "h5": {
105
+          "titleNView": false
106
+        }
107
+      }
108
+    },
109
+    {
110
+      "path": "pages/scanning_djInfo/scanning_djInfo",
111
+      "style": {
112
+        "h5": {
113
+          "titleNView": false
114
+        }
115
+      }
116
+    },
117
+    {
118
+      "path": "pages/scanning_djEnd/scanning_djEnd",
119
+      "style": {
120
+        "h5": {
121
+          "titleNView": false
122
+        }
123
+      }
124
+    },
125
+    {
126
+      "path": "pages/scanning/scanning",
127
+      "style": {
128
+        "h5": {
129
+          "titleNView": false
130
+        }
131
+      }
132
+    },
133
+    {
134
+      "path": "pages/scanning_orderSign/scanning_orderSign",
135
+      "style": {
136
+        "h5": {
137
+          "titleNView": false
138
+        }
139
+      }
140
+    },
141
+    {
142
+      "path": "pages/scanning_insEnd/scanning_insEnd",
143
+      "style": {
144
+        "h5": {
145
+          "titleNView": false
146
+        }
147
+      }
148
+    },
149
+    {
150
+      "path": "pages/my_list/my_list", //我的页面列表
151
+      "style": {
152
+        "h5": {
153
+          "titleNView": false
154
+        }
155
+      }
156
+    },
157
+    {
158
+      "path": "pages/mypage/mypage", //我的页面
159
+      "style": {
160
+        "h5": {
161
+          "titleNView": false
162
+        }
163
+      }
164
+    },
165
+    {
166
+      "path": "pages/pharmacy/pharmacy",
167
+      "style": {
168
+        "h5": {
169
+          "titleNView": false
170
+        }
171
+      }
172
+    },
173
+    {
174
+      "path": "pages/patientInformationList/patientInformationList", //患者信息列表
175
+      "style": {
176
+        "h5": {
177
+          "titleNView": false
178
+        }
179
+      }
180
+    },
181
+    {
182
+      "path": "pages/patientInformationInfo/patientInformationInfo", //患者信息详情
183
+      "style": {
184
+        "h5": {
185
+          "titleNView": false
186
+        }
187
+      }
188
+    },
189
+    {
190
+      "path": "pages/inspectList/inspectList", //检查信息列表
191
+      "style": {
192
+        "h5": {
193
+          "titleNView": false
194
+        }
195
+      }
196
+    },
197
+    {
198
+      "path": "pages/search/search", //搜索
199
+      "style": {
200
+        "h5": {
201
+          "titleNView": false
202
+        }
203
+      }
204
+    },
205
+    {
206
+      "path": "pages/pharmacyDetails/pharmacyDetails",
207
+      "style": {
208
+        "h5": {
209
+          "titleNView": false
210
+        }
211
+      }
212
+    },
213
+    {
214
+      "path": "pages/settingCode/settingCode",
215
+      "style": {
216
+        "h5": {
217
+          "titleNView": false
218
+        }
219
+      }
220
+    },
221
+    {
222
+      "path": "pages/noScanSpecimen/noScanSpecimen",
223
+      "style": {
224
+        "h5": {
225
+          "titleNView": false
226
+        }
227
+      }
228
+    },
229
+    {
230
+      "path": "pages/scanning_drug/scanning_drug",
231
+      "style": {
232
+        "h5": {
233
+          "titleNView": false
234
+        }
235
+      }
236
+    },
237
+    {
238
+      "path": "components/footTool/footTool",
239
+      "style": {
240
+        "navigationBarTitleText": "",
241
+        "enablePullDownRefresh": false
242
+      }
243
+    },
244
+    {
245
+      "path": "pages/specimenCheckingDetail/specimenCheckingDetail",
246
+      "style": {
247
+        "h5": {
248
+          "titleNView": false
249
+        },
250
+        "enablePullDownRefresh": true
251
+      }
252
+    },
253
+    {
254
+      "path": "pages/specimenDetail/specimenDetail",
255
+      "style": {
256
+        "h5": {
257
+          "titleNView": false
258
+        },
259
+        "enablePullDownRefresh": true
260
+      }
261
+    },
262
+    {
263
+      "path": "pages/checkAfterScanning/checkAfterScanning",
264
+      "style": {
265
+        "h5": {
266
+          "titleNView": false
267
+        },
268
+        "enablePullDownRefresh": false
269
+      }
270
+    },
271
+    {
272
+      "path": "pages/checkAfterBigScreen/checkAfterBigScreen",
273
+      "style": {
274
+        "h5": {
275
+          "titleNView": false
276
+        },
277
+        "enablePullDownRefresh": false
278
+      }
279
+    },
280
+    {
281
+      "path": "pages/scannedDepartmentSpecimens/scannedDepartmentSpecimens",
282
+      "style": {
283
+        "h5": {
284
+          "titleNView": false
285
+        },
286
+        "enablePullDownRefresh": true
287
+      }
288
+    },
289
+    {
290
+      "path": "pages/specimenCheckingEnd/specimenCheckingEnd",
291
+      "style": {
292
+        "h5": {
293
+          "titleNView": false
294
+        },
295
+        "enablePullDownRefresh": true
296
+      }
297
+    },
298
+    {
299
+      "path": "pages/scannedDepartmentSpecimensDetail/scannedDepartmentSpecimensDetail",
300
+      "style": {
301
+        "h5": {
302
+          "titleNView": false
303
+        }
304
+      }
305
+    },
306
+    {
307
+      "path": "pages/specimenCheckingEndDetail/specimenCheckingEndDetail",
308
+      "style": {
309
+        "h5": {
310
+          "titleNView": false
311
+        }
312
+      }
313
+    },
314
+    {
315
+      "path": "pages/scanning_nucleicAcid/scanning_nucleicAcid",
316
+      "style": {
317
+        "h5": {
318
+          "titleNView": false
319
+        }
320
+      }
321
+    },
322
+    {
323
+      "path": "pages/promptPage/promptPage",
324
+      "style": {
325
+        "h5": {
326
+          "titleNView": false
327
+        }
328
+      }
329
+    }, {
330
+      "path": "pages/scanning_blood/scanning_blood",
331
+      "style": {
332
+        "h5": {
333
+          "titleNView": false
334
+        }
335
+      }
336
+    }, {
337
+      "path": "pages/scanning_blood_process/scanning_blood_process",
338
+      "style": {
339
+        "h5": {
340
+          "titleNView": false
341
+        }
342
+      }
343
+    }, {
344
+      "path": "pages/check_blood/check_blood",
345
+      "style": {
346
+        "h5": {
347
+          "titleNView": false
348
+        }
349
+      }
350
+    }, {
351
+      "path": "pages/blood_list/blood_list",
352
+      "style": {
353
+        "h5": {
354
+          "titleNView": false
355
+        }
356
+      }
357
+    }, {
358
+      "path": "pages/signIn_blood/signIn_blood",
359
+      "style": {
360
+        "h5": {
361
+          "titleNView": false
362
+        }
363
+      }
364
+    }
365
+  ],
366
+  "globalStyle": {
367
+    "navigationBarTextStyle": "black",
368
+    "navigationBarTitleText": "医疗服务中心转运系统",
369
+    "navigationBarBackgroundColor": "#F8F8F8",
370
+    "backgroundColor": "#F8F8F8"
371
+  }
337 372
 }

+ 327 - 0
pages/blood_list/blood_list.vue

@@ -0,0 +1,327 @@
1
+<template>
2
+  <view class="pharmacyDetails">
3
+    <view class="pharmacyDetails_title">血制品信息</view>
4
+    <view class="page_item footerOtherMargin">
5
+      <view class="page_item_wrap" v-for="bloodDTO in bloods" :key="bloodDTO.id">
6
+        <view class="page_item">
7
+          <view class="page_item_top">
8
+            <view class="page_item_top-inner">
9
+              <view class="page_item_top_L">
10
+                <view class="L_text">{{bloodDTO.type ? bloodDTO.type.name : "无"}}<text v-if="bloodDTO.type">({{bloodDTO.bloodCode||'无'}}) {{ bloodDTO.volume?bloodDTO.volume+'ML':'无' }}</text></view>
11
+              </view>
12
+              <view class="page_item_top_R">
13
+                <text></text>
14
+              </view>
15
+            </view>
16
+          </view>
17
+          <view class="page_item_cont">
18
+            <view class="page_item_cont_T">
19
+              <view class="page_item_cont_title">
20
+                <view class="text_big"><text v-if="bloodDTO.printDate">{{bloodDTO.printDate | formatDate('yyyy-MM-dd hh:mm')}}</text><text v-else>无</text></view>
21
+                <text style="width: 4em;text-align: center;" class="icon_transport transport-arrow-right-full"></text>
22
+                <view class="text_big">{{ bloodDTO.overDate||'无' }}</view>
23
+              </view>
24
+              <view class="page_item_cont_title">
25
+                <view>
26
+                  血型:{{ bloodDTO.aboType||'无' }}
27
+                  &emsp;&emsp;
28
+                  RH(D):<text v-if="bloodDTO.rhType === '1'">+</text><text v-else-if="bloodDTO.rhType === '0'">-</text><text v-else>无</text>
29
+                </view>
30
+                <view class="text_big"></view>
31
+              </view>
32
+              <view class="page_item_cont_title">
33
+                <view> 患者:<text>{{ bloodDTO.patientName }}<text v-if="bloodDTO.hosNum">({{ bloodDTO.hosNum }})</text></text> </view>
34
+                <view class="text_big"></view>
35
+              </view>
36
+              <view class="page_item_cont_title">
37
+                <view> {{ bloodDTO.applyDeptDTO?bloodDTO.applyDeptDTO.dept:'无' }} </view>
38
+                <view class="text_big">{{ bloodDTO.state?bloodDTO.state.name:'无' }}</text></view>
39
+              </view>
40
+            </view>
41
+          </view>
42
+          <view class="L"></view>
43
+          <view class="R"></view>
44
+        </view>
45
+        <view class="L-l"></view>
46
+        <view class="R-l"></view>
47
+      </view>
48
+    </view>
49
+    <view class="foot_btn2 footerPadding">
50
+      <view class="btn2" @click="goBack">返回</view>
51
+    </view>
52
+  </view>
53
+</template>
54
+<script>
55
+  import {
56
+    post,
57
+    webHandle
58
+  } from "../../http/http.js";
59
+  export default {
60
+    data() {
61
+      return {
62
+        queryObj: {}, //路由传递过来的数据
63
+        bloods: [],
64
+      };
65
+    },
66
+    methods: {
67
+      // 返回
68
+      goBack() {
69
+        uni.navigateBack();
70
+      },
71
+    },
72
+    onLoad(options) {
73
+      console.log(options);
74
+      this.queryObj = options;
75
+      if (options.bloods) {
76
+        this.bloods = JSON.parse(options.bloods);
77
+      }
78
+      // #ifdef APP-PLUS
79
+      webHandle("no", "app");
80
+      // #endif
81
+      // #ifdef H5
82
+      webHandle("no", "wx");
83
+      // #endif
84
+    },
85
+  };
86
+</script>
87
+<style lang="less" scoped>
88
+  .pharmacyDetails {
89
+    background-color: rgb(249, 250, 251);
90
+    padding-top: 50rpx;
91
+    height: 100%;
92
+    box-sizing: border-box;
93
+
94
+    .pharmacyDetails_title {
95
+      font-size: 46rpx;
96
+      font-weight: 550;
97
+      text-align: center;
98
+    }
99
+
100
+    .page_item_wrap {
101
+      position: relative;
102
+      margin-top: 32rpx;
103
+
104
+      .page_item {
105
+        margin-top: 16rpx;
106
+        margin-bottom: 124rpx;
107
+        background: #fff;
108
+        border-radius: 8rpx;
109
+        margin: 0 20rpx;
110
+        border: 2rpx solid #e5e9ed;
111
+        position: relative;
112
+        overflow: hidden;
113
+        padding: 0 16rpx;
114
+
115
+        .L {
116
+          width: 40rpx;
117
+          height: 40rpx;
118
+          border-radius: 50%;
119
+          background: #f9fafb;
120
+          position: absolute;
121
+          left: -20rpx;
122
+          top: 68rpx;
123
+          border: 2rpx solid #e5e9ed;
124
+        }
125
+
126
+        .R {
127
+          width: 40rpx;
128
+          height: 40rpx;
129
+          border-radius: 50%;
130
+          background: #f9fafb;
131
+          position: absolute;
132
+          float: right;
133
+          right: -20rpx;
134
+          top: 68rpx;
135
+          border: 2rpx solid #e5e9ed;
136
+        }
137
+
138
+        .page_item_top {
139
+          height: 88rpx;
140
+          border-bottom: 2rpx dashed #e5e9ed;
141
+          padding: 0 16rpx;
142
+
143
+          .page_item_top-inner {
144
+            display: flex;
145
+            justify-content: space-between;
146
+            align-items: center;
147
+            height: 100%;
148
+
149
+            .page_item_top_L {
150
+              .L_text {
151
+                font-size: 32rpx;
152
+                font-weight: 700;
153
+              }
154
+            }
155
+
156
+            .page_item_top_R {
157
+              font-size: 32rpx;
158
+
159
+              .L_iocn {
160
+                color: rgb(7, 134, 60);
161
+                font-size: 36rpx;
162
+                font-weight: 700;
163
+              }
164
+            }
165
+          }
166
+        }
167
+
168
+        .page_item_cont {
169
+          min-height: 90rpx;
170
+          padding: 0 16rpx;
171
+          text-align: left;
172
+          position: relative;
173
+
174
+          .text_big {
175
+            font-size: 32rpx;
176
+            font-weight: 700;
177
+            // margin-top: 10rpx;
178
+          
179
+            p {
180
+              font-weight: 700;
181
+              line-height: 1.5;
182
+            }
183
+          }
184
+
185
+          .line {
186
+            height: 20rpx;
187
+            width: 2rpx;
188
+            border-left: 2rpx solid #e5e9ed;
189
+            position: absolute;
190
+            top: 82rpx;
191
+            left: 40rpx;
192
+          }
193
+
194
+          .page_item_cont_T {
195
+            padding-top: 28rpx;
196
+            padding-bottom: 28rpx;
197
+            font-size: 28rpx;
198
+
199
+            .page_item_cont_title {
200
+              height: 100%;
201
+              font-size: 32rpx;
202
+              display: flex;
203
+              justify-content: space-between;
204
+              align-items: center;
205
+            }
206
+          }
207
+
208
+          .page_item_cont_B {
209
+            padding-top: 28rpx;
210
+            margin-bottom: 28rpx;
211
+
212
+            .page_item_cont_title {
213
+              font-size: 32rpx;
214
+              display: flex;
215
+              justify-content: space-between;
216
+              align-items: center;
217
+            }
218
+          }
219
+
220
+          .page_item_cont_C {
221
+            margin-bottom: 28rpx;
222
+
223
+            .page_item_cont_title_C {
224
+              font-size: 32rpx;
225
+              display: flex;
226
+              justify-content: space-between;
227
+              align-items: center;
228
+            }
229
+          }
230
+
231
+          #infos {
232
+            display: none;
233
+          }
234
+        }
235
+      }
236
+
237
+      .L-l {
238
+        width: 2rpx;
239
+        height: 40rpx;
240
+        background: #f9fafb;
241
+        position: absolute;
242
+        left: 20rpx;
243
+        top: 72rpx;
244
+      }
245
+
246
+      .R-l {
247
+        width: 2rpx;
248
+        height: 40rpx;
249
+        background: #f9fafb;
250
+        position: absolute;
251
+        right: 20rpx;
252
+        top: 72rpx;
253
+      }
254
+    }
255
+
256
+    .cube-toolbar-item {
257
+      width: 710rpx;
258
+      height: 68rpx;
259
+      line-height: 68rpx;
260
+      position: fixed;
261
+      left: 20rpx;
262
+      bottom: 160rpx;
263
+      border-radius: 8rpx;
264
+      background: linear-gradient(to right, #72c172, #3bb197);
265
+      font-size: 36rpx;
266
+      color: #fff;
267
+      text-align: center;
268
+    }
269
+
270
+    .btn-wrap {
271
+      display: flex;
272
+      justify-content: space-between;
273
+      position: fixed;
274
+      left: 20rpx;
275
+      bottom: 160rpx;
276
+    }
277
+
278
+    .cube-toolbar-item1 {
279
+      width: 350rpx;
280
+      height: 68rpx;
281
+      line-height: 68rpx;
282
+      border-radius: 8rpx;
283
+      margin: 0 5rpx;
284
+      background: linear-gradient(to right, #72c172, #3bb197);
285
+      font-size: 36rpx;
286
+      color: #fff;
287
+      text-align: center;
288
+    }
289
+
290
+    .foot_btn2 {
291
+      position: fixed;
292
+      bottom: 0;
293
+      right: 20rpx;
294
+      left: 20rpx;
295
+      line-height: 66rpx;
296
+      height: 100rpx;
297
+      border-top: 2rpx solid #e5e9ed;
298
+      background: #f9fafb;
299
+      display: flex;
300
+      justify-content: space-between;
301
+
302
+      .btn2 {
303
+        height: 66rpx;
304
+        width: 100%;
305
+        margin: 0 1%;
306
+        background-image: linear-gradient(to right, #72c172, #3bb197);
307
+        color: #fff;
308
+        border-radius: 8rpx;
309
+        font-size: 32rpx;
310
+        margin-top: 16rpx;
311
+        text-align: center;
312
+      }
313
+
314
+      .btn3 {
315
+        height: 66rpx;
316
+        width: 48%;
317
+        margin: 0 1%;
318
+        background-image: linear-gradient(to right, #72c172, #3bb197);
319
+        color: #fff;
320
+        border-radius: 8rpx;
321
+        font-size: 32rpx;
322
+        margin-top: 16rpx;
323
+        text-align: center;
324
+      }
325
+    }
326
+  }
327
+</style>

+ 357 - 0
pages/check_blood/check_blood.vue

@@ -0,0 +1,357 @@
1
+<template>
2
+  <view class="checkBlood">
3
+    <view class="page_tab">
4
+      <view class="page_tab_bar" :class="{ active: item.value === selectedLabelSlots }" v-for="item in tabs"
5
+        :key="item.value" @click="clickHandler(item.value)">
6
+        {{ item.label }}
7
+        <text class="tab_num" v-if="item.value == 1">( {{ item.num }} )</text>
8
+      </view>
9
+    </view>
10
+    <block v-if="selectedLabelSlots == 1">
11
+      <view class="bloodType">
12
+        <view class="bloodTypeItem" v-for="(item, key, index) in unComplete" :key="index">
13
+          {{key}}:<text class="link" @click="goToList(item)">{{item.length}}</text>
14
+        </view>
15
+      </view>
16
+    </block>
17
+    <block v-if="selectedLabelSlots == 2">
18
+      <view class="title">
19
+        血制品核对
20
+      </view>
21
+      <view class="order">
22
+        <view class="">
23
+          工单号:{{order.gdcode||'无'}}
24
+        </view>
25
+        <view class="">
26
+          所属科室:{{order.startDept?order.startDept.dept:'无'}}
27
+        </view>
28
+        <view class="">
29
+          接收数量:{{receiveNum}}
30
+        </view>
31
+      </view>
32
+      <view class="bloodType">
33
+        <view class="bloodTypeItem" v-for="(item, key, index) in complete" :key="index">
34
+          {{key}}:<text class="link" @click="goToList(item)">{{item.length}}</text>
35
+        </view>
36
+      </view>
37
+    </block>
38
+    <view class="foot_btn_spe">
39
+      <view class="btn1" @click="Scanning_again()"> 继续扫描 </view>
40
+      <view class="btn3" @click="checkComplete()">核对完成</view>
41
+    </view>
42
+  </view>
43
+</template>
44
+
45
+<script>
46
+  import {
47
+    get,
48
+    post,
49
+    SM,
50
+    webHandle
51
+  } from "../../http/http.js";
52
+  export default {
53
+    data() {
54
+      return {
55
+        queryObj: {},
56
+        SMFlag: true,
57
+        // 接收数量
58
+        receiveNum: 0,
59
+        // 未扫描
60
+        unComplete:{},
61
+        // 已扫描
62
+        complete:{},
63
+        // 工单
64
+        order: {},
65
+        // 工单ID
66
+        orderId: null,
67
+        // 血液类型
68
+        bloodTypes:[],
69
+        // 当前选中tab页名称
70
+        selectedLabelSlots: '2',
71
+        // tab页信息
72
+        tabs: [{
73
+            label: "未扫描", //tab页名称
74
+            value: "1", //值
75
+            num: 0, //数量
76
+          },
77
+          {
78
+            label: "已扫描",
79
+            value: "2",
80
+          },
81
+        ],
82
+      };
83
+    },
84
+    methods:{
85
+      // 跳转血制品列表
86
+      goToList(bloods){
87
+        uni.navigateTo({
88
+          url: `../blood_list/blood_list?bloods=${encodeURIComponent(JSON.stringify(bloods))}`,
89
+        });
90
+      },
91
+      // 点击tab页切换
92
+      clickHandler(value) {
93
+        this.selectedLabelSlots = value;
94
+      },
95
+      //获取血液类型
96
+      getBloodTypes(){
97
+        uni.showLoading({
98
+          title: "加载中",
99
+          mask: true,
100
+        });
101
+        post('/common/common/getDictionary', {
102
+          "type": "list",
103
+          "key": "blood_trans_type"
104
+        }).then(res => {
105
+          this.bloodTypes = res;
106
+          this.getInfo();
107
+        })
108
+      },
109
+      //获取页面信息
110
+      getInfo(){
111
+        post('/transflow/checkData', {
112
+          "type": "blood",
113
+          "orderId": this.orderId
114
+        }).then(res => {
115
+          uni.hideLoading();
116
+          if(res.state == 200){
117
+            console.log(res);
118
+            this.order = res.data.dto;
119
+            this.complete = res.data.complete;
120
+            this.unComplete = res.data.unComplete;
121
+            this.receiveNum = 0;
122
+            for (let key in this.unComplete) {
123
+              this.tabs[0].num += this.unComplete[key].length;
124
+            }
125
+            for (let key in this.complete) {
126
+              this.receiveNum += this.complete[key].length;
127
+            }
128
+          }else{
129
+            uni.showToast({
130
+              icon: "none",
131
+              title: "请求失败!",
132
+            });
133
+          }
134
+        })
135
+      },
136
+      // 继续扫描
137
+      Scanning_again() {
138
+        if (!this.SMFlag) {
139
+          return;
140
+        }
141
+        this.SMFlag = false;
142
+        SM().then((ress1) => {
143
+          this.hand_scanning_common(ress1, 'scan');
144
+        }).catch(err => {
145
+          this.SMFlag = true;
146
+        });
147
+      },
148
+      // 手动输入和扫码公共方法
149
+      hand_scanning_common(ress1, type) {
150
+        uni.showLoading({
151
+          title: "加载中",
152
+          mask: true,
153
+        });
154
+        //检验二维码的有效性
155
+        post("/dept/scanning", {
156
+          content: ress1,
157
+        }).then((result) => {
158
+          this.SMFlag = true;
159
+          if (result.state == 200 || result.state == 201) {
160
+            let codes = result.code;
161
+            if (codes) {
162
+              post("/transflow/scanBind", {type: 'blood',orderId: this.queryObj.orderId, code: ress1}).then((ress) => {
163
+                uni.hideLoading();
164
+                if (ress.state == 200) {
165
+                  //扫描标本后会自动调用摄像头,继续扫描,直到status不是200
166
+                  setTimeout(()=>{
167
+                    if (type === 'scan') {
168
+                      this.Scanning_again();
169
+                    }
170
+                  },500)
171
+                  //todo
172
+                  uni.redirectTo({
173
+                    url: `../scanning_blood_process/scanning_blood_process?orderId=${this.queryObj.orderId}&bloodDTO=${encodeURIComponent(JSON.stringify(ress.data.dto))}&scanCount=${ress.data.scanCount}&status=${ress.state}&scanOrHand=${type}`,
174
+                  });
175
+                } else {
176
+                  uni.redirectTo({
177
+                    url: `../scanning_blood_process/scanning_blood_process?orderId=${this.queryObj.orderId}&status=${ress.state}&scanOrHand=${type}&qrcode=${ress1}`,
178
+                  });
179
+                }
180
+              });
181
+            } else {
182
+              uni.hideLoading();
183
+            }
184
+          } else {
185
+            uni.hideLoading();
186
+            uni.showToast({
187
+              icon: "none",
188
+              title: "请求失败!",
189
+            });
190
+          }
191
+        });
192
+        // ------------------------------
193
+      },
194
+      // 核对完成
195
+      checkComplete(){
196
+        uni.showModal({
197
+          title: "提示",
198
+          content: "请确认是否核对完成?",
199
+          success: (result) => {
200
+            if (result.confirm) {
201
+              console.log("用户点击确定");
202
+              let postData = {
203
+                "type": "blood",
204
+                "orderId": this.orderId
205
+              };
206
+              uni.showLoading({
207
+                title: "加载中",
208
+                mask: true,
209
+              });
210
+              post("/transflow/checkComplete", postData).then((ress) => {
211
+                uni.hideLoading();
212
+                if (ress.state == 200) {
213
+                  uni.navigateTo({
214
+                    url: `../receiptpage/receiptpage`,
215
+                  });
216
+                } else {
217
+                  uni.showToast({
218
+                    icon: "none",
219
+                    title: "请求失败!",
220
+                  });
221
+                }
222
+              });
223
+            } else if (result.cancel) {
224
+              console.log("用户点击取消");
225
+            }
226
+          },
227
+        });
228
+      }
229
+    },
230
+    onLoad(options) {
231
+      console.log(options, 'options');
232
+      this.queryObj = options;
233
+      this.orderId = options.orderId;
234
+      this.getBloodTypes();
235
+    },
236
+    onShow() {
237
+      this.SMFlag = true;
238
+    },
239
+  }
240
+</script>
241
+
242
+<style lang="less" scoped>
243
+.checkBlood{
244
+  width: 100%;
245
+  height: 100%;
246
+  position: relative;
247
+  padding-top: 96rpx;
248
+  .page_tab {
249
+    width: 100%;
250
+    height: 96rpx;
251
+    display: flex;
252
+    position: fixed;
253
+    left: 0;
254
+    top: 0;
255
+    z-index: 999;
256
+  
257
+    .page_tab_bar {
258
+      flex: 1;
259
+      font-size: 36rpx;
260
+      background: #fff;
261
+      display: flex;
262
+      justify-content: center;
263
+      align-items: center;
264
+      position: relative;
265
+  
266
+      &:after {
267
+        content: "";
268
+        position: absolute;
269
+        left: 0;
270
+        bottom: 0;
271
+        height: 2rpx;
272
+        width: 100%;
273
+        background-color: transparent;
274
+      }
275
+  
276
+      .tab_num {
277
+        color: #ff3b53;
278
+        margin-left: 8rpx;
279
+      }
280
+  
281
+      .more {
282
+        position: absolute;
283
+        right: 20rpx;
284
+        width: 40rpx;
285
+        height: 4rpx;
286
+        border-top: 2px solid #49b856;
287
+        border-bottom: 2px solid #49b856;
288
+        background-color: #49b856;
289
+        padding: 5px 0;
290
+        background-clip: content-box;
291
+      }
292
+  
293
+      .more_picker {
294
+        position: absolute;
295
+        right: 0;
296
+        height: 100%;
297
+        opacity: 0;
298
+      }
299
+  
300
+      &.active {
301
+        color: #49b856;
302
+  
303
+        &:after {
304
+          background-color: #49b856;
305
+        }
306
+      }
307
+    }
308
+  }
309
+  .title{
310
+    text-align: center;
311
+    padding: 20rpx 0;
312
+    border: 2rpx solid #e5e9ed;
313
+  }
314
+  .order{
315
+    text-indent: 2em;
316
+    padding: 20rpx 0;
317
+  }
318
+  .bloodType{
319
+    width: 90%;
320
+    border: 2rpx solid #e5e9ed;
321
+    margin: 0 auto;
322
+    margin-top: 40rpx;
323
+    .bloodTypeItem{
324
+      padding: 20rpx 0;
325
+      text-indent: 2em;
326
+      .link{
327
+        text-decoration: underline;
328
+      }
329
+    }
330
+  }
331
+  .foot_btn_spe {
332
+    line-height: 88rpx;
333
+    height: 100rpx;
334
+    margin-top: 40rpx;
335
+    text-align: center;
336
+    display: flex;
337
+    justify-content: space-between;
338
+    flex-wrap: wrap;
339
+  
340
+    &::after {
341
+      content: '';
342
+      flex: 1;
343
+    }
344
+  
345
+    view {
346
+      height: 88rpx;
347
+      width: 48%;
348
+      margin: 0 1%;
349
+      background-image: linear-gradient(to right, #72c172, #3bb197);
350
+      color: #fff;
351
+      border-radius: 8rpx;
352
+      font-size: 32rpx;
353
+      margin-top: 16rpx;
354
+    }
355
+  }
356
+}
357
+</style>

+ 94 - 51
pages/receipt_infopage/receipt_infopage.vue

@@ -273,9 +273,9 @@
273 273
                 v-show="item.inspectState.value==1||item.inspectState.value==2||item.inspectState.value==4">
274 274
                 <view class="btn" @click.stop="remove(item)">移除</view>
275 275
               </view> -->
276
-							<view class="page_item_foot_text">
277
-							  <view class="btn" @click.stop="remove(item)">移除</view>
278
-							</view>
276
+              <view class="page_item_foot_text">
277
+                <view class="btn" @click.stop="remove(item)">移除</view>
278
+              </view>
279 279
             </view>
280 280
           </view>
281 281
         </view>
@@ -291,7 +291,7 @@
291 291
     </view>
292 292
     <view class="foot_btn2 footerPadding">
293 293
       <view class="btn2" @click="showAlert" v-if="infoDATA.gdState.value == 2">接单</view>
294
-      <!-- 如果不是静配,药配,标本配送,标本轮巡 -->
294
+      <!-- 如果不是静配,药配,标本配送,标本轮巡,万能交接 -->
295 295
       <template
296 296
         v-if="((!infoDATA.worker)||(infoDATA.worker&&infoDATA.worker.id == currentUserId))&&infoDATA.gdState.value != 6&&infoDATA.gdState.value != 7&&infoDATA.gdState.value != 11">
297 297
         <view :class="[infoDATA.taskType.specialCloseButton == 1 ? 'btn3' : 'btn2']" v-if="
@@ -299,7 +299,8 @@
299 299
           infoDATA.taskType.associationType.value != 'jPBag' &&
300 300
           infoDATA.taskType.associationType.value != 'drugsBag' &&
301 301
           infoDATA.taskType.associationType.value != 'specimen' &&
302
-          infoDATA.taskType.associationType.value != 'specimenPlan'
302
+          infoDATA.taskType.associationType.value != 'specimenPlan' &&
303
+          infoDATA.taskType.associationType.value != 'ordinary'
303 304
         " hover-class="seimin-btn-hover">
304 305
           <smallScreen :sData="infoDATA" :sType="1">扫码</smallScreen>
305 306
         </view>
@@ -310,6 +311,7 @@
310 311
           infoDATA.taskType.associationType.value != 'specimen' &&
311 312
           infoDATA.taskType.associationType.value != 'specimenPlan' &&
312 313
           infoDATA.taskType.associationType.value != 'other' &&
314
+          infoDATA.taskType.associationType.value != 'ordinary' &&
313 315
           infoDATA.gdState.value == 4
314 316
         " hover-class="seimin-btn-hover">拍照</view>
315 317
         <view class="btn3" @click="specialCloseClick()" v-if="
@@ -318,18 +320,26 @@
318 320
           infoDATA.taskType.associationType.value != 'drugsBag' &&
319 321
           infoDATA.taskType.associationType.value != 'specimen' &&
320 322
           infoDATA.taskType.associationType.value != 'specimenPlan' &&
323
+          infoDATA.taskType.associationType.value != 'ordinary' &&
321 324
           infoDATA.taskType.specialCloseButton == 1
322 325
         " hover-class="seimin-btn-hover">特殊情况关闭</view>
323 326
       </template>
324
-      <!-- 如果不是患者陪检或患者转运或其他 -->
327
+      <!-- 如果不是患者陪检或患者转运或其他,万能交接 -->
325 328
       <view :class="[infoDATA.taskType.specialCloseButton == 1 ? 'btn3' : 'btn2']" v-if="
326 329
           infoDATA.gdState.value != 2 &&
327 330
           infoDATA.taskType.associationType.value != 'patientTransport' &&
328 331
           infoDATA.taskType.associationType.value != 'inspect' &&
329
-          infoDATA.taskType.associationType.value != 'other'
332
+          infoDATA.taskType.associationType.value != 'other' &&
333
+          infoDATA.taskType.associationType.value != 'ordinary'
330 334
         " hover-class="seimin-btn-hover">
331 335
         <smallScreen :sData="infoDATA" :sType="2">扫码</smallScreen>
332 336
       </view>
337
+      <!-- 如果是万能交接 -->
338
+      <view :class="[infoDATA.taskType.specialCloseButton == 1 ? 'btn3' : 'btn2']"
339
+        v-if="infoDATA.taskType.associationType.value == 'ordinary'"
340
+        hover-class="seimin-btn-hover" @click="goBack()">
341
+        知道了
342
+      </view>
333 343
       <view class="btn3" @click="specialCloseClick()" v-if="
334 344
           infoDATA.gdState.value != 2 &&
335 345
           infoDATA.taskType.associationType.value != 'patientTransport' &&
@@ -341,14 +351,16 @@
341 351
           infoDATA.taskType.associationType.value == 'specimen' ||
342 352
           infoDATA.taskType.associationType.value == 'specimenPlan'
343 353
         " hover-class="seimin-btn-hover">查看标本</view>
354
+      <view class="btn3" @click="viewBlood(infoDATA)" v-if="infoDATA.taskType.associationType.value == 'ordinary' && infoDATA.taskType.ordinaryField.value == 'blood'" hover-class="seimin-btn-hover">查看血制品</view>
344 355
     </view>
345 356
     <!-- 弹窗 -->
346 357
     <showModel :title="models.title" :icon="models.icon" :disjunctor="models.disjunctor" :content="models.content"
347 358
       @know="know" :operate="models.operate" @ok="ok" @cancel="cancel" :textareaFlag="textareaFlag"
348 359
       @textareaInput="textareaInput"></showModel>
349 360
     <!-- 弹窗 -->
350
-    <inspectRemoveModel :title="models1.title" :icon="models1.icon" :disjunctor="models1.disjunctor" :content="models1.content"
351
-      @know="know1" :operate="models1.operate" @ok="ok1" @cancel="cancel1" :remove="true"></inspectRemoveModel>
361
+    <inspectRemoveModel :title="models1.title" :icon="models1.icon" :disjunctor="models1.disjunctor"
362
+      :content="models1.content" @know="know1" :operate="models1.operate" @ok="ok1" @cancel="cancel1" :remove="true">
363
+    </inspectRemoveModel>
352 364
   </view>
353 365
 </template>
354 366
 <script>
@@ -414,12 +426,40 @@
414 426
       },
415 427
     },
416 428
     methods: {
429
+      goBack() {
430
+        uni.navigateTo({
431
+          url: "../receiptpage/receiptpage",
432
+        });
433
+      },
417 434
       // 查看标本
418 435
       viewSpecimen(workOrder) {
419 436
         uni.navigateTo({
420 437
           url: `../specimenDetail/specimenDetail?workOrderId=${workOrder.id}&associationTypeValue=${workOrder.taskType.associationType.value}`,
421 438
         });
422 439
       },
440
+      // 查看血制品
441
+      viewBlood(workOrder) {
442
+        uni.showLoading({
443
+          title: "加载中",
444
+          mask: true,
445
+        });
446
+        post('/transflow/checkData', {
447
+          "type": "blood",
448
+          "orderId": workOrder.id
449
+        }).then(res => {
450
+          uni.hideLoading();
451
+          if(res.state == 200){
452
+            uni.navigateTo({
453
+              url: `../blood_list/blood_list?bloods=${encodeURIComponent(JSON.stringify(res.data.all))}`,
454
+            });
455
+          }else{
456
+            uni.showToast({
457
+              icon: "none",
458
+              title: "请求失败!",
459
+            });
460
+          }
461
+        })
462
+      },
423 463
       // 移除检查->知道了
424 464
       know1() {
425 465
         this.models1.disjunctor = false;
@@ -430,45 +470,48 @@
430 470
       },
431 471
       // 移除检查->确定
432 472
       ok1(data) {
433
-				console.log(data);
434
-				const { value, yyTime} = data;
435
-				if (!value) {
436
-				  //没有选择移除原因
437
-				  uni.showModal({
438
-				    title: "提示",
439
-				    content: "请选择移除原因!",
440
-				    showCancel: false,
441
-				    success: function(res) {
442
-				      if (res.confirm) {
443
-				        console.log("用户点击确定");
444
-				      } else if (res.cancel) {
445
-				        console.log("用户点击取消");
446
-				      }
447
-				    },
448
-				  });
449
-				  return;
450
-				}else if (value == 2 && !yyTime) {
451
-				  //没有填写预约时间
452
-				  uni.showModal({
453
-				    title: "提示",
454
-				    content: "请填写预约时间!",
455
-				    showCancel: false,
456
-				    success: function(res) {
457
-				      if (res.confirm) {
458
-				        console.log("用户点击确定");
459
-				      } else if (res.cancel) {
460
-				        console.log("用户点击取消");
461
-				      }
462
-				    },
463
-				  });
464
-				  return;
465
-				}
473
+        console.log(data);
474
+        const {
475
+          value,
476
+          yyTime
477
+        } = data;
478
+        if (!value) {
479
+          //没有选择移除原因
480
+          uni.showModal({
481
+            title: "提示",
482
+            content: "请选择移除原因!",
483
+            showCancel: false,
484
+            success: function(res) {
485
+              if (res.confirm) {
486
+                console.log("用户点击确定");
487
+              } else if (res.cancel) {
488
+                console.log("用户点击取消");
489
+              }
490
+            },
491
+          });
492
+          return;
493
+        } else if (value == 2 && !yyTime) {
494
+          //没有填写预约时间
495
+          uni.showModal({
496
+            title: "提示",
497
+            content: "请填写预约时间!",
498
+            showCancel: false,
499
+            success: function(res) {
500
+              if (res.confirm) {
501
+                console.log("用户点击确定");
502
+              } else if (res.cancel) {
503
+                console.log("用户点击取消");
504
+              }
505
+            },
506
+          });
507
+          return;
508
+        }
466 509
         this.models1.disjunctor = false;
467 510
         let postData = {
468 511
           gdId: this.infoDATA.id,
469 512
           inspectId: this.currentInspect.id,
470
-					reason: value == 1 ? 'checkDone' : 'modificationTime',
471
-					yyTime: value == 1 ? undefined : yyTime,
513
+          reason: value == 1 ? 'checkDone' : 'modificationTime',
514
+          yyTime: value == 1 ? undefined : yyTime,
472 515
         };
473 516
         uni.showLoading({
474 517
           title: '移除中',
@@ -480,13 +523,13 @@
480 523
             uni.showToast({
481 524
               icon: 'none',
482 525
               title: '移除成功!',
483
-							success() {
484
-								setTimeout(() => {
485
-										uni.navigateTo({
486
-										  url: '../receiptpage/receiptpage',
487
-										});
488
-								}, 1500)
489
-							}
526
+              success() {
527
+                setTimeout(() => {
528
+                  uni.navigateTo({
529
+                    url: '../receiptpage/receiptpage',
530
+                  });
531
+                }, 1500)
532
+              }
490 533
             })
491 534
           } else {
492 535
             uni.showToast({

+ 119 - 56
pages/receiptpage/receiptpage.vue

@@ -26,7 +26,7 @@
26 26
             <view class="R"></view>
27 27
             <view class="page_item_top">
28 28
               <view class="page_item_top_L">
29
-                <text class="L_iocn" v-if="item.taskType.associationType.value == 'specimen'">标</text>
29
+                <!-- <text class="L_iocn" v-if="item.taskType.associationType.value == 'specimen'">标</text>
30 30
                 <text class="L_iocn" v-if="item.taskType.associationType.value == 'drugsBag'">药</text>
31 31
                 <text class="L_iocn" v-if="item.taskType.associationType.value == 'specimenPlan'">巡</text>
32 32
                 <text class="L_iocn" v-if="item.taskType.associationType.value == 'jPBag'">静</text>
@@ -34,8 +34,28 @@
34 34
                 <text class="L_iocn" v-if="
35 35
                     item.taskType.associationType.value == 'patientTransport'
36 36
                   ">病</text>
37
-                <text class="L_iocn" v-if="item.taskType.associationType.value == 'other'">其</text>
38
-                <text class="L_time" v-if="item.overdueTime">{{ item.overdueTime }}前送达</text>
37
+                <text class="L_iocn" v-if="item.taskType.associationType.value == 'other'">其</text> -->
38
+                <view class="page_item_cont_start emergency1" v-if="item.emergencyType.value == 1">
39
+                  <image mode="widthFix" class="page_item_cont_start-img" src="../../static/img/icon_shandian.png">
40
+                  </image>
41
+                  {{ item.emergencyType.name }}
42
+                </view>
43
+                <view class="page_item_cont_start emergency" v-if="item.emergencyType.value == 2">
44
+                  <image mode="widthFix" class="page_item_cont_start-img" src="../../static/img/icon_shandian.png">
45
+                  </image>
46
+                  {{ item.emergencyType.name }}
47
+                </view>
48
+                <view class="page_item_cont_start emergencys" v-if="item.emergencyType.value == 3">
49
+                  <image mode="widthFix" class="page_item_cont_start-img" src="../../static/img/icon_shandian.png">
50
+                  </image>
51
+                  {{ item.emergencyType.name }}
52
+                </view>
53
+                <view class="page_item_top_R type" style="margin-left: 16rpx;">
54
+                  {{
55
+                    item.isHalfInspect === 1 ? "半程陪检" : item.taskType.taskName
56
+                  }}<template v-if="item.goodsRemark">-{{item.goodsRemark}}</template>
57
+                </view>
58
+                <!-- <text class="L_time" v-if="item.overdueTime">{{ item.overdueTime }}前送达</text> -->
39 59
               </view>
40 60
               <view class="page_item_top_R" v-if="
41 61
                   !(
@@ -44,20 +64,18 @@
44 64
                   )
45 65
                 ">
46 66
                 {{ item.gdState.name }}
47
-                <!-- 待取货 -->
48 67
               </view>
49 68
               <view class="page_item_top_R" v-if="
50 69
                   item.taskType.associationType.value == 'inspect' &&
51 70
                   item.gdState.value == 5
52 71
                 ">
53 72
                 待送回
54
-                <!-- 待取货 -->
55 73
               </view>
56
-              <view class="page_item_top_R type">
74
+              <!-- <view class="page_item_top_R type">
57 75
                 {{
58 76
                   item.isHalfInspect === 1 ? "半程陪检" : item.taskType.taskName
59 77
                 }}<template v-if="item.goodsRemark">-{{item.goodsRemark}}</template>
60
-              </view>
78
+              </view> -->
61 79
             </view>
62 80
             <view class="page_item_cont" @click="itemInfo(item)">
63 81
               <view class="page_item_cont_T">
@@ -65,7 +83,7 @@
65 83
                   <text> <text class="starting">起</text> 点科室 </text>
66 84
                   <text class="text_big">{{ item.startDept.dept }}</text>
67 85
                 </view>
68
-                <view class="page_item_cont_start emergency1" v-if="item.emergencyType.value == 1">
86
+                <!-- <view class="page_item_cont_start emergency1" v-if="item.emergencyType.value == 1">
69 87
                   <image mode="widthFix" class="page_item_cont_start-img" src="../../static/img/icon_shandian.png">
70 88
                   </image>
71 89
                   {{ item.emergencyType.name }}
@@ -79,13 +97,20 @@
79 97
                   <image mode="widthFix" class="page_item_cont_start-img" src="../../static/img/icon_shandian.png">
80 98
                   </image>
81 99
                   {{ item.emergencyType.name }}
82
-                </view>
100
+                </view> -->
83 101
               </view>
84 102
               <view class="page_item_conts" v-if="item.taskType.associationType.value == 'specimen'">
103
+                <view v-if="item.overdueTime">{{ item.overdueTime }}前送达</view>
85 104
                 <view>扫描标本数量 : {{ item.actualReceiveNum || '无'}}</view>
86 105
                 <view class="line"></view>
87 106
               </view>
107
+              <view class="page_item_conts" v-else-if="item.taskType.associationType.value == 'ordinary' && item.taskType.ordinaryField.value == 'blood'">
108
+                <view v-if="item.overdueTime">{{ item.overdueTime }}前送达</view>
109
+                <view>接收数量 : {{ item.actualReceiveNum || '无'}}</view>
110
+                <view class="line"></view>
111
+              </view>
88 112
               <view class="page_item_conts" v-else-if="item.taskType.associationType.value == 'inspect'">
113
+                <view v-if="item.overdueTime">{{ item.overdueTime }}前送达</view>
89 114
                 <view>
90 115
                   预约时间 : {{ item.yyTime | yyTimeFilter
91 116
                   }}<text v-if="item.reservationNumber">({{ item.reservationNumber }})</text>
@@ -125,6 +150,7 @@
125 150
                 <view class="line"></view>
126 151
               </view>
127 152
               <view class="page_item_conts" v-else-if="item.taskType.associationType.value == 'patientTransport'">
153
+                <view v-if="item.overdueTime">{{ item.overdueTime }}前送达</view>
128 154
                 <view>
129 155
                   预约时间 : {{ item.yyjdTime | yyTimeFilter
130 156
                   }}<text v-if="item.reservationNumber">({{ item.reservationNumber }})</text>
@@ -164,12 +190,14 @@
164 190
                 <view class="line"></view>
165 191
               </view>
166 192
               <view class="page_item_conts" v-else-if="item.taskType.associationType.value == 'drugsBag'">
193
+                <view v-if="item.overdueTime">{{ item.overdueTime }}前送达</view>
167 194
                 <view>
168 195
                   药包编码 : {{ item.drugs ? item.drugs.packid : "无" }}
169 196
                 </view>
170 197
                 <view class="line"></view>
171 198
               </view>
172 199
               <view class="page_item_conts" v-else-if="item.taskType.associationType.value == 'jPBag'">
200
+                <view v-if="item.overdueTime">{{ item.overdueTime }}前送达</view>
173 201
                 <view>
174 202
                   药包编码 :
175 203
                   {{ item.staticDistri ? item.staticDistri.packid : "无" }}
@@ -177,6 +205,7 @@
177 205
                 <view class="line"></view>
178 206
               </view>
179 207
               <view class="page_item_conts" v-else>
208
+                <view v-if="item.overdueTime">{{ item.overdueTime }}前送达</view>
180 209
                 <view class="line"></view>
181 210
               </view>
182 211
               <view class="page_item_cont_B">
@@ -203,22 +232,24 @@
203 232
               <!-- 待送达 -->
204 233
               <text class="red" v-if="item.gdState.value == 5">请扫描终点科室码,并扫描患者腕带</text>
205 234
             </view>
206
-            <!-- 如果不是患者陪检或患者转运或其他 -->
235
+            <!-- 如果不是患者陪检或患者转运或其他,万能交接 -->
207 236
             <view class="page_item_btn" v-if="
208 237
                 selectedLabelSlots == '执行中' &&
209 238
                 item.taskType.associationType.value != 'patientTransport' &&
210 239
                 item.taskType.associationType.value != 'inspect' &&
211
-                item.taskType.associationType.value != 'other'
240
+                item.taskType.associationType.value != 'other' &&
241
+                item.taskType.associationType.value != 'ordinary'
212 242
               " hover-class="seimin-btn-hover">
213 243
               <smallScreen :sData="item" :sType="2">扫码</smallScreen>
214 244
             </view>
215
-            <!-- 如果不是静配,药配,标本配送,标本轮巡 -->
245
+            <!-- 如果不是静配,药配,标本配送,标本轮巡,万能交接 -->
216 246
             <view class="page_item_btn_wrap" v-if="
217 247
                 selectedLabelSlots == '执行中' &&
218 248
                 item.taskType.associationType.value != 'jPBag' &&
219 249
                 item.taskType.associationType.value != 'drugsBag' &&
220 250
                 item.taskType.associationType.value != 'specimen' &&
221
-                item.taskType.associationType.value != 'specimenPlan'
251
+                item.taskType.associationType.value != 'specimenPlan' &&
252
+                item.taskType.associationType.value != 'ordinary'
222 253
               ">
223 254
               <view class="page_item_btn" :style="{
224 255
                   width:
@@ -254,8 +285,8 @@
254 285
       @ok="speOk" @cancel="speCancel">
255 286
     </handViewSpecimen>
256 287
     <!-- 手动查询药品弹窗 -->
257
-    <handViewDrugsBag v-if="drugbagModels.disjunctor" :title="drugbagModels.title" :disjunctor="drugbagModels.disjunctor"
258
-      @ok="drugbagOk" @cancel="drugbagCancel">
288
+    <handViewDrugsBag v-if="drugbagModels.disjunctor" :title="drugbagModels.title"
289
+      :disjunctor="drugbagModels.disjunctor" @ok="drugbagOk" @cancel="drugbagCancel">
259 290
     </handViewDrugsBag>
260 291
   </view>
261 292
 </template>
@@ -278,7 +309,7 @@
278 309
   export default {
279 310
     data() {
280 311
       return {
281
-				SMFlag: true,
312
+        SMFlag: true,
282 313
         // 手动查询标本弹窗model
283 314
         speModels: {
284 315
           disjunctor: false,
@@ -356,7 +387,7 @@
356 387
       yyTimeFilter: function(data) {
357 388
         if (data) {
358 389
           let nDate = null;
359
-          if(typeof data == 'string'){
390
+          if (typeof data == 'string') {
360 391
             let arr = data.split(/[-:\s]/);
361 392
             nDate = new Date(
362 393
               arr[0] - 0,
@@ -366,7 +397,7 @@
366 397
               arr[4] - 0,
367 398
               0
368 399
             );
369
-          }else if(typeof data == 'number'){
400
+          } else if (typeof data == 'number') {
370 401
             nDate = new Date(data);
371 402
           }
372 403
           const month = (nDate.getMonth() + 1).toString().padStart(2, 0);
@@ -617,42 +648,42 @@
617 648
           this.handleTakeMedicine()
618 649
         }
619 650
       },
620
-			// 摆药取药
621
-			handleTakeMedicine() {
622
-			  if (!this.SMFlag) {
623
-			    return;
624
-			  }
625
-			  this.SMFlag = false;
626
-			  SM().then((content) => {
627
-			    uni.showLoading({
628
-			      title: "加载中",
629
-			      mask: true,
630
-			    });
631
-			    //检验二维码的有效性(扫码前必须验证)
632
-			    post("/dept/scanning", {
633
-			        content,
634
-			      })
635
-			      .then((result) => {
636
-			        this.currentCode = result.code;
637
-			        this.SMFlag = true;
638
-			        // 200检测通过,201没有有效期也通过。
639
-			        if (result.state == 200 || result.state == 201) {
640
-								uni.hideLoading();
641
-								uni.navigateTo({
642
-								  url: `../promptPage/promptPage?code=${result.code}`,
643
-								});
644
-			        } else {
645
-			          uni.hideLoading();
646
-			          uni.showToast({
647
-			            icon: "none",
648
-			            title: '请求失败',
649
-			          });
650
-			        }
651
-			      })
652
-			  }).catch(err => {
653
-			    this.SMFlag = true;
654
-			  });
655
-			},
651
+      // 摆药取药
652
+      handleTakeMedicine() {
653
+        if (!this.SMFlag) {
654
+          return;
655
+        }
656
+        this.SMFlag = false;
657
+        SM().then((content) => {
658
+          uni.showLoading({
659
+            title: "加载中",
660
+            mask: true,
661
+          });
662
+          //检验二维码的有效性(扫码前必须验证)
663
+          post("/dept/scanning", {
664
+              content,
665
+            })
666
+            .then((result) => {
667
+              this.currentCode = result.code;
668
+              this.SMFlag = true;
669
+              // 200检测通过,201没有有效期也通过。
670
+              if (result.state == 200 || result.state == 201) {
671
+                uni.hideLoading();
672
+                uni.navigateTo({
673
+                  url: `../promptPage/promptPage?code=${result.code}`,
674
+                });
675
+              } else {
676
+                uni.hideLoading();
677
+                uni.showToast({
678
+                  icon: "none",
679
+                  title: '请求失败',
680
+                });
681
+              }
682
+            })
683
+        }).catch(err => {
684
+          this.SMFlag = true;
685
+        });
686
+      },
656 687
       // 点击tab页切换
657 688
       clickHandler(key) {
658 689
         this.selectedLabelSlots = key;
@@ -938,7 +969,7 @@
938 969
       // #endif
939 970
     },
940 971
     onShow() {
941
-			this.SMFlag = true;
972
+      this.SMFlag = true;
942 973
       // #ifdef H5
943 974
       document.body.addEventListener("touchmove", this.stop, {
944 975
         passive: false,
@@ -1060,7 +1091,7 @@
1060 1091
 
1061 1092
           .page_item {
1062 1093
             margin-bottom: 16rpx;
1063
-            min-height: 356rpx;
1094
+            // min-height: 356rpx;
1064 1095
             background: #fff;
1065 1096
             border-radius: 8rpx;
1066 1097
             overflow: hidden;
@@ -1122,6 +1153,38 @@
1122 1153
                 height: 100%;
1123 1154
                 float: left;
1124 1155
                 line-height: 88rpx;
1156
+                display: flex;
1157
+                align-items: center;
1158
+                
1159
+                .emergencys {
1160
+                  background: #ff3b53 !important;
1161
+                  width: 124rpx !important;
1162
+                }
1163
+                
1164
+                .emergency {
1165
+                  background: #ff3b53 !important;
1166
+                }
1167
+                
1168
+                .emergency1 {
1169
+                  background: #49b856 !important;
1170
+                }
1171
+                
1172
+                .page_item_cont_start {
1173
+                  text-align: center;
1174
+                  height: 44rpx;
1175
+                  width: 104rpx;
1176
+                  line-height: 44rpx;
1177
+                  border-radius: 8rpx;
1178
+                  background: #49b856;
1179
+                  color: #fff;
1180
+                
1181
+                  .page_item_cont_start-img {
1182
+                    width: 22rpx;
1183
+                    position: relative;
1184
+                    top: 6rpx;
1185
+                    margin-right: 8rpx;
1186
+                  }
1187
+                }
1125 1188
 
1126 1189
                 .L_iocn {
1127 1190
                   display: inline-block;

+ 32 - 7
pages/scanning_all/scanning_all.vue

@@ -42,6 +42,9 @@
42 42
           <view @click="act('other')" v-if="infoDATA['other']">
43 43
             <view id="40" :class="{ acts: tabType == 'other' }">其他({{ infoDATA.other.length }})</view>
44 44
           </view>
45
+          <view @click="act('blood')" v-if="infoDATA['blood']">
46
+            <view id="40" :class="{ acts: tabType == 'blood' }">血制品({{ infoDATA.blood.length }})</view>
47
+          </view>
45 48
         </view>
46 49
       </view>
47 50
       <view class="page_items" v-if="!workData" style="font-size: 18px; margin-top: 15%">
@@ -89,6 +92,7 @@
89 92
                   infoDATA.taskType.associationType.value == 'patientTransport'
90 93
                 ">患者转运</text>
91 94
               <text class="L_iocn" v-if="infoDATA.taskType.associationType.value == 'other'">其他</text>
95
+              <text class="L_iocn" v-if="infoDATA.taskType.associationType.value == 'ordinary' && infoDATA.taskType.ordinaryField.value == 'blood'">血制品</text>
92 96
             </view>
93 97
             <view class="L"></view>
94 98
             <view class="R"></view>
@@ -133,16 +137,16 @@
133 137
             </view>
134 138
             <view class="page_item_foot_text" v-if="infoDATA.gdState.value == '2'">
135 139
               <text class="text1">预计响应时间</text>
136
-              <text class="text2">{{ infoDATA.estimeResponseTime || 0 }}</text>
140
+              <text class="text2">{{ infoDATA.estimeResponseTime || '无' }}</text>
137 141
             </view>
138 142
             <view class="page_item_foot_text" v-if="infoDATA.gdState.value == '5'">
139 143
               <text class="text1" v-if="!(infoDATA.taskType.associationType.value == 'inspect')">预计送达时间</text>
140 144
               <text class="text1" v-if="infoDATA.taskType.associationType.value == 'inspect'">预计送回时间</text>
141
-              <text class="text2">{{ infoDATA.estimeCompleteTime || 0 }}</text>
145
+              <text class="text2">{{ infoDATA.estimeCompleteTime || '无' }}</text>
142 146
             </view>
143 147
             <view class="page_item_foot_text" v-if="infoDATA.gdState.value == '4'">
144 148
               <text class="text1">预计到达时间</text>
145
-              <text class="text2">{{ infoDATA.estimateArriveTime || 0 }}</text>
149
+              <text class="text2">{{ infoDATA.estimateArriveTime || '无' }}</text>
146 150
             </view>
147 151
             <view class="page_item_foot_text">
148 152
               <text class="text1">创建时间</text>
@@ -199,6 +203,7 @@
199 203
         typeData: [],
200 204
         types: false,
201 205
         code: "",
206
+        deptName: '',
202 207
         flag: true, //一键操作,禁止多次
203 208
         flagTimer: null,
204 209
         selectArr: [], //选中项
@@ -382,9 +387,14 @@
382 387
           this.flag = false;
383 388
           let list = {};
384 389
           let type = "";
385
-
390
+          console.log(this.userId)
386 391
           if (this.userId.ids.length > 0) {
387
-            if (
392
+            if (this.tabType == "blood") {
393
+              // 万能交接服务的血制品
394
+              uni.navigateTo({
395
+                url: `../signIn_blood/signIn_blood?deptName=${this.deptName}&orderId=${this.userId.ids[0]}`,
396
+              });
397
+            }else if (
388 398
               this.tabType == "drugsBag" ||
389 399
               this.tabType == "jPBag" ||
390 400
               this.tabType == "other" ||
@@ -638,10 +648,25 @@
638 648
       this.infoDATA = JSON.parse(options.infoDATA); //扫描科室码返回的信息
639 649
       console.log(this.infoDATA);
640 650
       this.code = options.code; //扫描科室码返回的二维码信息
651
+      this.deptName = options.deptName; //扫描科室码返回的科室名称
641 652
       let arr = [];
642
-      for (var key in this.infoDATA) {
643
-        arr.push(key);
653
+      for (let key in this.infoDATA) {
654
+        if(key === 'ordinary'){
655
+          // 如果是万能交接服务,key值要从关联业务区分
656
+          this.infoDATA['ordinary'].forEach(v => {
657
+            arr.push(v.taskType.ordinaryField.value);
658
+            if(this.infoDATA[v.taskType.ordinaryField.value]){
659
+              this.infoDATA[v.taskType.ordinaryField.value].push(v);
660
+            }else{
661
+              this.infoDATA[v.taskType.ordinaryField.value] = [v];
662
+            }
663
+          })
664
+          delete this.infoDATA['ordinary'];
665
+        }else{
666
+          arr.push(key);
667
+        }
644 668
       }
669
+      console.log(this.infoDATA);
645 670
       this.workData = this.infoDATA[arr[0]];
646 671
       this.tabType = arr[0];
647 672
       // #ifdef APP-PLUS

+ 505 - 0
pages/scanning_blood/scanning_blood.vue

@@ -0,0 +1,505 @@
1
+<template>
2
+  <view class="bloodDetails">
3
+    <view class="Scanning_top">
4
+      <view class="Scanning_top_icon">
5
+        <text class="cubeic-ok icon_transport transport-duigou"></text>
6
+      </view>
7
+      <view class="Scanning_top_text">
8
+        <view class="text1">扫描成功</view>
9
+      </view>
10
+    </view>
11
+    <view class="page_item_wrap">
12
+      <view class="page_item">
13
+        <view class="page_item_top">
14
+          <view class="page_item_top-inner">
15
+            <view class="page_item_top_L">
16
+              <text class="L_text">血袋号:{{ bloodDTO.bloodCode||'无' }}</text>
17
+            </view>
18
+            <view class="page_item_top_R">
19
+              <text class="L_iocn"></text>
20
+            </view>
21
+          </view>
22
+        </view>
23
+        <view class="page_item_cont">
24
+          <view class="page_item_cont_C">
25
+            <view class="page_item_cont_title_C">
26
+              <text>血液类型</text>
27
+              <text class="text_big">
28
+                <text>
29
+                  {{bloodDTO.type ? bloodDTO.type.name : "无"}}
30
+                </text>
31
+              </text>
32
+            </view>
33
+          </view>
34
+          <view class="page_item_cont_C">
35
+            <view class="page_item_cont_title_C">
36
+              <text>血量</text>
37
+              <text class="text_big">
38
+                <text>{{ bloodDTO.volume?bloodDTO.volume+'ML':'无' }}</text>
39
+              </text>
40
+            </view>
41
+          </view>
42
+          <view class="page_item_cont_C">
43
+            <view class="page_item_cont_title_C">
44
+              <text>采血日期</text>
45
+              <text class="text_big">
46
+                <text v-if="bloodDTO.printDate">{{bloodDTO.printDate | formatDate('yyyy-MM-dd hh:mm')}}</text>
47
+                <text v-else>无</text>
48
+              </text>
49
+            </view>
50
+          </view>
51
+          <view class="page_item_cont_C">
52
+            <view class="page_item_cont_title_C">
53
+              <text>有效期至</text>
54
+              <text class="text_big">
55
+                <text>{{ bloodDTO.overDate||'无' }}</text>
56
+              </text>
57
+            </view>
58
+          </view>
59
+          <view class="page_item_cont_C">
60
+            <view class="page_item_cont_title_C">
61
+              <text>血型</text>
62
+              <text class="text_big">
63
+                <text>{{ bloodDTO.aboType||'无' }}</text>
64
+              </text>
65
+            </view>
66
+          </view>
67
+          <view class="page_item_cont_C">
68
+            <view class="page_item_cont_title_C">
69
+              <text>RH(D)</text>
70
+              <text class="text_big">
71
+                <text v-if="bloodDTO.rhType === '1'">+</text>
72
+                <text v-else-if="bloodDTO.rhType === '0'">-</text>
73
+                <text v-else>无</text>
74
+              </text>
75
+            </view>
76
+          </view>
77
+          <view class="page_item_cont_C">
78
+            <view class="page_item_cont_title_C">
79
+              <text>患者</text>
80
+              <text class="text_big">
81
+                <text>{{ bloodDTO.patientName }}<text v-if="bloodDTO.hosNum">({{ bloodDTO.hosNum }})</text></text>
82
+              </text>
83
+            </view>
84
+          </view>
85
+          <view class="page_item_cont_C">
86
+            <view class="page_item_cont_title_C">
87
+              <text>申请科室</text>
88
+              <text class="text_big">
89
+                <text>{{ bloodDTO.applyDeptDTO?bloodDTO.applyDeptDTO.dept:'无' }}</text>
90
+              </text>
91
+            </view>
92
+          </view>
93
+        </view>
94
+        <view class="L"></view>
95
+        <view class="R"></view>
96
+      </view>
97
+      <view class="L-l"></view>
98
+      <view class="R-l"></view>
99
+    </view>
100
+    <view class="cube-toolbar-item-wrap" v-show="bloodDTO.id">
101
+      <button class="cube-toolbar-item" v-show="orderId && receiveOrder" @click="receiveOrderAndSign()">
102
+        接单并签到
103
+      </button>
104
+      <button class="cube-toolbar-item" v-show="!orderId && buildOrder" @click="buildOrderAndSign()">
105
+        建单并签到
106
+      </button>
107
+      <button class="cube-toolbar-item" @click="goBack()">
108
+        知道了
109
+      </button>
110
+    </view>
111
+  </view>
112
+</template>
113
+<script>
114
+  import {
115
+    webHandle,
116
+    post
117
+  } from "../../http/http.js";
118
+  export default {
119
+    data() {
120
+      return {
121
+        receiveOrder: false,
122
+        buildOrder: false,
123
+        bloodDTO: {}, //血制品信息
124
+        taskTypeConfig: {}, //血制品配置信息
125
+        orderId:'',//工单id
126
+        gotoFlag: true,
127
+      };
128
+    },
129
+    methods: {
130
+      goBack() {
131
+        uni.navigateTo({
132
+          url: "../receiptpage/receiptpage",
133
+        });
134
+      },
135
+      // 接单并签到
136
+      receiveOrderAndSign() {
137
+        if (!this.gotoFlag) {
138
+          return;
139
+        }
140
+        this.gotoFlag = false;
141
+        uni.showModal({
142
+          title: "提示",
143
+          content: "请确认是否接单并签到?",
144
+          success: (result) => {
145
+            if (result.confirm) {
146
+              console.log("用户点击确定");
147
+              let postData = {
148
+                type: 'blood',
149
+                id: this.bloodDTO.id,
150
+                orderId: this.orderId
151
+              };
152
+              uni.showLoading({
153
+                title: "加载中",
154
+                mask: true,
155
+              });
156
+              post("/transflow/createOrTakeOrder", postData).then((ress) => {
157
+                uni.hideLoading();
158
+                if (ress.state == 200) {
159
+                  uni.navigateTo({
160
+                    url: `../scanning_blood_process/scanning_blood_process?orderId=${ress.data.orderId}&bloodDTO=${encodeURIComponent(JSON.stringify(this.bloodDTO))}&scanCount=${ress.data.scanCount}&status=${ress.state}`,
161
+                  });
162
+                } else {
163
+                  uni.showToast({
164
+                    icon: "none",
165
+                    title: "请求失败!",
166
+                  });
167
+                }
168
+              });
169
+            } else if (result.cancel) {
170
+              console.log("用户点击取消");
171
+            }
172
+          },
173
+        });
174
+      },
175
+      // 建单并签到
176
+      buildOrderAndSign() {
177
+        if (!this.gotoFlag) {
178
+          return;
179
+        }
180
+        this.gotoFlag = false;
181
+        uni.showModal({
182
+          title: "提示",
183
+          content: "请确认是否建单并签到?",
184
+          success: (result) => {
185
+            if (result.confirm) {
186
+              console.log("用户点击确定");
187
+              let postData = {
188
+                type: 'blood',
189
+                id: this.bloodDTO.id,
190
+              };
191
+              uni.showLoading({
192
+                title: "加载中",
193
+                mask: true,
194
+              });
195
+              post("/transflow/createOrTakeOrder", postData).then((ress) => {
196
+                uni.hideLoading();
197
+                if (ress.state == 200) {
198
+                  uni.navigateTo({
199
+                    url: `../scanning_blood_process/scanning_blood_process?orderId=${ress.data.orderId}&bloodDTO=${encodeURIComponent(JSON.stringify(this.bloodDTO))}&scanCount=${ress.data.scanCount}&status=${ress.state}`,
200
+                  });
201
+                } else {
202
+                  uni.showToast({
203
+                    icon: "none",
204
+                    title: "请求失败!",
205
+                  });
206
+                }
207
+              });
208
+            } else if (result.cancel) {
209
+              console.log("用户点击取消");
210
+            }
211
+          },
212
+        });
213
+      },
214
+      //获取血制品信息及其关联的工单信息
215
+      scanInfo(qrcode) {
216
+        uni.showLoading({
217
+          title: "加载中",
218
+          mask: true,
219
+        });
220
+        post("/common/common/getDictionary", {"type":"list","key":"ttconfig_sign_type"}).then((res1) => {
221
+          post("/transflow/scanInfo", {
222
+            type: 'blood',
223
+            code: qrcode,
224
+          }).then((res) => {
225
+            uni.hideLoading();
226
+            if (res.state == 200) {
227
+              this.bloodDTO = res.data.dto || {};
228
+              this.orderId = res.data.orderId;
229
+              console.log(this.orderId);
230
+              this.taskTypeConfig = res.data.taskTypeConfig;
231
+              let sign_ids = this.taskTypeConfig.signTypeIds?this.taskTypeConfig.signTypeIds.split(','):[];
232
+              console.log(sign_ids);
233
+              this.receiveOrder = false;
234
+              this.buildOrder = false;
235
+              sign_ids.forEach(v => {
236
+                let obj = res1.find(vv => vv.id == v);
237
+                console.log(obj);
238
+                if(obj && obj.value == 1){
239
+                  this.receiveOrder = true;
240
+                }
241
+                if(obj && obj.value == 2){
242
+                  this.buildOrder = true;
243
+                }
244
+              })
245
+            } else {
246
+              uni.showToast({
247
+                icon: "none",
248
+                title: "请求失败",
249
+              });
250
+            }
251
+          });
252
+        });
253
+      },
254
+    },
255
+    onShow() {
256
+      this.gotoFlag = true;
257
+    },
258
+    onLoad(options) {
259
+      console.log(options);
260
+      let {
261
+        qrcode
262
+      } = options;
263
+      if (qrcode) {
264
+        this.scanInfo(qrcode);
265
+      }
266
+      // #ifdef APP-PLUS
267
+      webHandle("no", "app");
268
+      // #endif
269
+      // #ifdef H5
270
+      webHandle("no", "wx");
271
+      // #endif
272
+    },
273
+  };
274
+</script>
275
+<style lang="less" scoped>
276
+  .bloodDetails {
277
+    background-color: rgb(249, 250, 251);
278
+    .Scanning_top {
279
+    
280
+      .Scanning_top_icon {
281
+        width: 140rpx;
282
+        height: 140rpx;
283
+        margin: 0 auto;
284
+        border-radius: 50%;
285
+        line-height: 140rpx;
286
+        text-align: center;
287
+    
288
+        .cubeic-ok {
289
+          font-size: 140rpx;
290
+          color: #35b34a;
291
+        }
292
+    
293
+        .cubeic-close {
294
+          font-size: 140rpx;
295
+          color: #ff3b53;
296
+        }
297
+      }
298
+    
299
+      .Scanning_top_text {
300
+        .text1 {
301
+          margin-top: 40rpx;
302
+          font-size: 48rpx;
303
+          text-align: center;
304
+        }
305
+      }
306
+    }
307
+
308
+    .page_item_wrap {
309
+      position: relative;
310
+      margin-top: 32rpx;
311
+
312
+      .page_item {
313
+        margin-top: 16rpx;
314
+        margin-bottom: 124rpx;
315
+        background: #fff;
316
+        border-radius: 8rpx;
317
+        margin: 0 20rpx;
318
+        border: 2rpx solid #e5e9ed;
319
+        position: relative;
320
+        overflow: hidden;
321
+        padding: 0 16rpx;
322
+
323
+        .L {
324
+          width: 40rpx;
325
+          height: 40rpx;
326
+          border-radius: 50%;
327
+          background: #f9fafb;
328
+          position: absolute;
329
+          left: -20rpx;
330
+          top: 68rpx;
331
+          border: 2rpx solid #e5e9ed;
332
+        }
333
+
334
+        .R {
335
+          width: 40rpx;
336
+          height: 40rpx;
337
+          border-radius: 50%;
338
+          background: #f9fafb;
339
+          position: absolute;
340
+          float: right;
341
+          right: -20rpx;
342
+          top: 68rpx;
343
+          border: 2rpx solid #e5e9ed;
344
+        }
345
+
346
+        .page_item_top {
347
+          height: 88rpx;
348
+          border-bottom: 2rpx dashed #e5e9ed;
349
+          padding: 0 16rpx;
350
+
351
+          .page_item_top-inner {
352
+            display: flex;
353
+            justify-content: space-between;
354
+            align-items: center;
355
+            height: 100%;
356
+
357
+            .page_item_top_L {
358
+              .L_text {
359
+                font-size: 32rpx;
360
+                font-weight: 700;
361
+              }
362
+            }
363
+
364
+            .page_item_top_R {
365
+              font-size: 32rpx;
366
+
367
+              .L_iocn {
368
+                color: rgb(7, 134, 60);
369
+                font-size: 36rpx;
370
+                font-weight: 700;
371
+              }
372
+            }
373
+          }
374
+        }
375
+
376
+        .page_item_cont {
377
+          min-height: 180rpx;
378
+          padding: 0 16rpx;
379
+          text-align: left;
380
+          position: relative;
381
+
382
+          .text_big {
383
+            width: 50%;
384
+            text-align: right;
385
+            font-size: 32rpx;
386
+            font-weight: 700;
387
+
388
+            text {
389
+              font-weight: 700;
390
+              line-height: 1.5;
391
+            }
392
+          }
393
+
394
+          .line {
395
+            height: 20rpx;
396
+            width: 2rpx;
397
+            border-left: 2rpx solid #e5e9ed;
398
+            position: absolute;
399
+            top: 82rpx;
400
+            left: 40rpx;
401
+          }
402
+
403
+          .page_item_cont_T {
404
+            padding-top: 28rpx;
405
+            font-size: 28rpx;
406
+
407
+            .page_item_cont_title {
408
+              height: 100%;
409
+              font-size: 32rpx;
410
+              display: flex;
411
+              justify-content: space-between;
412
+            }
413
+          }
414
+
415
+          .page_item_cont_B {
416
+            padding-top: 28rpx;
417
+            margin-bottom: 28rpx;
418
+
419
+            .page_item_cont_title {
420
+              font-size: 32rpx;
421
+              display: flex;
422
+              justify-content: space-between;
423
+              align-items: center;
424
+            }
425
+          }
426
+
427
+          .page_item_cont_C {
428
+            margin-bottom: 28rpx;
429
+
430
+            .page_item_cont_title_C {
431
+              font-size: 32rpx;
432
+              display: flex;
433
+              justify-content: space-between;
434
+              align-items: center;
435
+              &>text{
436
+                flex-shrink: 0;
437
+              }
438
+            }
439
+          }
440
+
441
+          #infos {
442
+            display: none;
443
+          }
444
+        }
445
+      }
446
+
447
+      .L-l {
448
+        width: 2rpx;
449
+        height: 40rpx;
450
+        background: #f9fafb;
451
+        position: absolute;
452
+        left: 20rpx;
453
+        top: 72rpx;
454
+      }
455
+
456
+      .R-l {
457
+        width: 2rpx;
458
+        height: 40rpx;
459
+        background: #f9fafb;
460
+        position: absolute;
461
+        right: 20rpx;
462
+        top: 72rpx;
463
+      }
464
+    }
465
+
466
+    .cube-toolbar-item-wrap {
467
+      display: flex;
468
+      position: fixed;
469
+      left: 0;
470
+      bottom: 20rpx;
471
+      width: 100%;
472
+      .cube-toolbar-item {
473
+        flex: 1;
474
+        margin: 0 18rpx;
475
+        height: 68rpx;
476
+        line-height: 68rpx;
477
+        border-radius: 8rpx;
478
+        background: linear-gradient(to right, #72c172, #3bb197);
479
+        font-size: 36rpx;
480
+        color: #fff;
481
+        text-align: center;
482
+      }
483
+    }
484
+
485
+    .btn-wrap {
486
+      display: flex;
487
+      justify-content: space-between;
488
+      position: fixed;
489
+      left: 20rpx;
490
+      bottom: 160rpx;
491
+    }
492
+
493
+    .cube-toolbar-item1 {
494
+      width: 350rpx;
495
+      height: 68rpx;
496
+      line-height: 68rpx;
497
+      border-radius: 8rpx;
498
+      margin: 0 5rpx;
499
+      background: linear-gradient(to right, #72c172, #3bb197);
500
+      font-size: 36rpx;
501
+      color: #fff;
502
+      text-align: center;
503
+    }
504
+  }
505
+</style>

+ 308 - 0
pages/scanning_blood_process/scanning_blood_process.vue

@@ -0,0 +1,308 @@
1
+<template>
2
+  <view class="Scanning_Result">
3
+    <view class="Scanning_top" v-if="status == 200">
4
+      <view class="Scanning_top_icon">
5
+        <view>
6
+          <view class="red fweight speNum"> {{ speNum }} </view>
7
+        </view>
8
+      </view>
9
+      <view class="Scanning_top_text">
10
+        <view class="text1"> 操作成功 </view>
11
+      </view>
12
+    </view>
13
+
14
+    <view class="Scanning_top" v-if="status != 200">
15
+      <view class="Scanning_top_icon">
16
+        <text class="cubeic-close icon_transport transport-shibai"></text>
17
+      </view>
18
+      <view class="Scanning_top_text">
19
+        <view class="text1"> 操作失败 </view>
20
+        <view class="text1 f30" v-if="queryObj.qrcode"> 扫描内容:{{queryObj.qrcode}} </view>
21
+      </view>
22
+    </view>
23
+
24
+    <view class="Scanning_cont" v-if="status == 200">
25
+      <view>{{bloodDTO.type ? bloodDTO.type.name : "无"}}<text v-if="bloodDTO.type">({{bloodDTO.bloodCode||'无'}}) {{ bloodDTO.volume?bloodDTO.volume+'ML':'无' }}</text></view>
26
+      <view>采血日期:<text v-if="bloodDTO.printDate">{{bloodDTO.printDate | formatDate('yyyy-MM-dd hh:mm')}}</text><text v-else>无</text></view>
27
+      <view>有效期至:{{ bloodDTO.overDate||'无' }}</view>
28
+      <view>
29
+        血型:{{ bloodDTO.aboType||'无' }}
30
+        &emsp;&emsp;
31
+        RH(D):<text v-if="bloodDTO.rhType === '1'">+</text><text v-else-if="bloodDTO.rhType === '0'">-</text><text v-else>无</text>
32
+      </view>
33
+      <view>患者:<text>{{ bloodDTO.patientName }}<text v-if="bloodDTO.hosNum">({{ bloodDTO.hosNum }})</text></text></view>
34
+      <view>申请科室:{{ bloodDTO.applyDeptDTO?bloodDTO.applyDeptDTO.dept:'无' }}</view>
35
+    </view>
36
+
37
+    <view class="foot_btn_spe">
38
+      <view class="btn1" @click="Scanning_again()"> 继续扫描 </view>
39
+      <view class="btn3" @click="hand_again()">手动录入</view>
40
+      <view class="btn2" style="width: 98%;" @click="countAndCheck()"> 清点核对 </view>
41
+    </view>
42
+
43
+    <!-- 手动查询弹窗 -->
44
+    <handViewBlood v-if="speModels.disjunctor" :title="speModels.title" :disjunctor="speModels.disjunctor"
45
+      @ok="speOk" @cancel="speCancel">
46
+    </handViewBlood>
47
+  </view>
48
+</template>
49
+<script>
50
+  import {
51
+    get,
52
+    post,
53
+    SM,
54
+    webHandle
55
+  } from "../../http/http.js";
56
+  export default {
57
+    data() {
58
+      return {
59
+        bloodDTO:{},
60
+        status: 200,
61
+        speNum: 0,
62
+        // 手动查询弹窗model
63
+        speModels: {
64
+          disjunctor: false,
65
+        },
66
+        SMFlag: true,
67
+        queryObj: {}, //路由传递过来的数据
68
+      };
69
+    },
70
+    methods: {
71
+      // 手动查询-确认
72
+      speOk(data) {
73
+        console.log(data);
74
+        if (!data.id) {
75
+          //没有查询到
76
+          uni.showModal({
77
+            title: '提示',
78
+            content: "没有查询到标本!",
79
+            showCancel: false,
80
+            success: function(res) {
81
+              if (res.confirm) {
82
+                console.log('用户点击确定');
83
+              } else if (res.cancel) {
84
+                console.log('用户点击取消');
85
+              }
86
+            }
87
+          });
88
+          return;
89
+        }
90
+        this.speModels.disjunctor = false;
91
+        this.hand_scanning_common(data.bloodCode, 'hand');
92
+      },
93
+      // 手动查询-取消
94
+      speCancel() {
95
+        this.speModels.disjunctor = false;
96
+      },
97
+      // 手动查询弹窗
98
+      showHandViewSpecimen() {
99
+        this.speModels = {
100
+          title: '填写血袋号',
101
+          disjunctor: true,
102
+        }
103
+      },
104
+      // 手动录入
105
+      hand_again() {
106
+        this.showHandViewSpecimen();
107
+      },
108
+      // 手动输入和扫码公共方法
109
+      hand_scanning_common(ress1, type) {
110
+        // ----------------
111
+        uni.showLoading({
112
+          title: "加载中",
113
+          mask: true,
114
+        });
115
+        //检验二维码的有效性
116
+        post("/dept/scanning", {
117
+          content: ress1,
118
+        }).then((result) => {
119
+          this.SMFlag = true;
120
+          if (result.state == 200 || result.state == 201) {
121
+            let codes = result.code;
122
+            if (codes) {
123
+              post("/transflow/scanBind", {type: 'blood',orderId: this.queryObj.orderId, code: ress1}).then((ress) => {
124
+                uni.hideLoading();
125
+                if (ress.state == 200) {
126
+                  //扫描标本后会自动调用摄像头,继续扫描,直到status不是200
127
+                  setTimeout(()=>{
128
+                    if (type === 'scan') {
129
+                      this.Scanning_again();
130
+                    }
131
+                  },500)
132
+                  //todo
133
+                  uni.redirectTo({
134
+                    url: `../scanning_blood_process/scanning_blood_process?orderId=${this.queryObj.orderId}&bloodDTO=${encodeURIComponent(JSON.stringify(ress.data.dto))}&scanCount=${ress.data.scanCount}&status=${ress.state}&scanOrHand=${type}`,
135
+                  });
136
+                } else {
137
+                  uni.redirectTo({
138
+                    url: `../scanning_blood_process/scanning_blood_process?orderId=${this.queryObj.orderId}&status=${ress.state}&scanOrHand=${type}&qrcode=${ress1}`,
139
+                  });
140
+                }
141
+              });
142
+            } else {
143
+              uni.hideLoading();
144
+            }
145
+          } else {
146
+            uni.hideLoading();
147
+            uni.showToast({
148
+              icon: "none",
149
+              title: "请求失败!",
150
+            });
151
+          }
152
+        });
153
+        // ------------------------------
154
+      },
155
+      // 继续扫描
156
+      Scanning_again() {
157
+        if (!this.SMFlag) {
158
+          return;
159
+        }
160
+        this.SMFlag = false;
161
+        SM().then((ress1) => {
162
+          this.hand_scanning_common(ress1, 'scan');
163
+        }).catch(err => {
164
+          this.SMFlag = true;
165
+        });
166
+      },
167
+      // 清点核对
168
+      countAndCheck() {
169
+        uni.navigateTo({
170
+          url: `../check_blood/check_blood?orderId=${this.queryObj.orderId}`,
171
+        });
172
+      },
173
+    },
174
+    onShow() {
175
+      this.SMFlag = true;
176
+    },
177
+    onLoad(options) {
178
+      console.log(options, "result");
179
+      if (options.status == 200&&options.scanOrHand === 'hand') {
180
+        this.hand_again();
181
+      }
182
+      this.queryObj = options;
183
+      if (options.bloodDTO) {
184
+        this.bloodDTO = JSON.parse(options.bloodDTO);
185
+      }
186
+      this.status = options.status;
187
+      this.speNum = options.scanCount;
188
+      // #ifdef APP-PLUS
189
+      webHandle("no", "app");
190
+      // #endif
191
+      // #ifdef H5
192
+      webHandle("no", "wx");
193
+      // #endif
194
+    },
195
+  };
196
+</script>
197
+<style lang="less">
198
+  .Scanning_Result {
199
+    padding: 0 20rpx;
200
+
201
+    .Scanning_top {
202
+      .Scanning_top_icon {
203
+        width: 140rpx;
204
+        height: 140rpx;
205
+        margin: 0 auto;
206
+        border-radius: 50%;
207
+        line-height: 140rpx;
208
+        
209
+        .speNum{
210
+          text-align: center;
211
+          font-size: 140rpx;
212
+        }
213
+
214
+        .cubeic-ok {
215
+          font-size: 140rpx;
216
+          color: #35b34a;
217
+        }
218
+
219
+        .cubeic-close {
220
+          font-size: 140rpx;
221
+          color: #ff3b53;
222
+        }
223
+      }
224
+
225
+      .Scanning_top_text {
226
+        .text1 {
227
+          font-size: 48rpx;
228
+          text-align: center;
229
+        }
230
+
231
+        .success_tips {
232
+          color: red;
233
+          font-size: 30rpx;
234
+        }
235
+      }
236
+    }
237
+
238
+    .Scanning_cont {
239
+      font-size: 32rpx;
240
+      text-align: center;
241
+
242
+      view {
243
+        margin-bottom: 16rpx;
244
+      }
245
+
246
+      .Scanning_cont_center {
247
+        text-align: center;
248
+      }
249
+
250
+      .text {
251
+        margin-top: 24rpx;
252
+        color: #35b34a;
253
+      }
254
+
255
+      .text1 {
256
+        margin-top: 24rpx;
257
+        color: #ff3b53;
258
+      }
259
+    }
260
+
261
+    .foot_btn {
262
+      line-height: 88rpx;
263
+      height: 100rpx;
264
+      margin-top: 40rpx;
265
+      display: flex;
266
+      justify-content: center;
267
+
268
+      .btn1,
269
+      .btn2,
270
+      .btn3 {
271
+        height: 88rpx;
272
+        flex: 1;
273
+        margin: 0 1%;
274
+        background-image: linear-gradient(to right, #72c172, #3bb197);
275
+        color: #fff;
276
+        border-radius: 8rpx;
277
+        font-size: 32rpx;
278
+        margin-top: 16rpx;
279
+        text-align: center;
280
+      }
281
+    }
282
+    .foot_btn_spe {
283
+      line-height: 88rpx;
284
+      height: 100rpx;
285
+      margin-top: 40rpx;
286
+      text-align: center;
287
+      display: flex;
288
+      justify-content: space-between;
289
+      flex-wrap: wrap;
290
+    
291
+      &::after {
292
+        content: '';
293
+        flex: 1;
294
+      }
295
+    
296
+      view {
297
+        height: 88rpx;
298
+        width: 48%;
299
+        margin: 0 1%;
300
+        background-image: linear-gradient(to right, #72c172, #3bb197);
301
+        color: #fff;
302
+        border-radius: 8rpx;
303
+        font-size: 32rpx;
304
+        margin-top: 16rpx;
305
+      }
306
+    }
307
+  }
308
+</style>

+ 312 - 0
pages/signIn_blood/signIn_blood.vue

@@ -0,0 +1,312 @@
1
+<template>
2
+  <view class="Scanning_Result">
3
+    <view class="Scanning_top">
4
+      <view class="Scanning_top_icon">
5
+        <text class="cubeic-ok icon_transport transport-duigou"></text>
6
+      </view>
7
+      <view class="Scanning_top_text">
8
+        <view class="text1"> 签到成功 </view>
9
+      </view>
10
+    </view>
11
+
12
+    <view class="Scanning_cont">
13
+      <view>您已到达{{queryObj.deptName}},您需要交接血制品数量为{{receiveNum}}</view>
14
+      <view v-for="(item, key, index) in bloods" :key="index">
15
+        {{key}}:<text class="link" @click="goToList(item)">{{item.length}}</text>
16
+      </view>
17
+    </view>
18
+
19
+    <view class="foot_btn_spe">
20
+      <view class="btn1" @click="Scanning_again()"> 继续扫描 </view>
21
+      <view class="btn3" @click="hand_again()">手动录入</view>
22
+    </view>
23
+
24
+    <!-- 手动查询弹窗 -->
25
+    <handViewBlood v-if="speModels.disjunctor" :title="speModels.title" :disjunctor="speModels.disjunctor"
26
+      @ok="speOk" @cancel="speCancel">
27
+    </handViewBlood>
28
+  </view>
29
+</template>
30
+<script>
31
+  import {
32
+    get,
33
+    post,
34
+    SM,
35
+    webHandle
36
+  } from "../../http/http.js";
37
+  export default {
38
+    data() {
39
+      return {
40
+        receiveNum: 0,
41
+        order: {},
42
+        bloods: [],
43
+        // 手动查询弹窗model
44
+        speModels: {
45
+          disjunctor: false,
46
+        },
47
+        SMFlag: true,
48
+        queryObj: {}, //路由传递过来的数据
49
+      };
50
+    },
51
+    methods: {
52
+      // 跳转血制品列表
53
+      goToList(bloods){
54
+        uni.navigateTo({
55
+          url: `../blood_list/blood_list?bloods=${encodeURIComponent(JSON.stringify(bloods))}`,
56
+        });
57
+      },
58
+      //获取页面信息
59
+      getInfo(){
60
+        uni.showLoading({
61
+          title: "加载中",
62
+          mask: true,
63
+        });
64
+        post('/transflow/checkData', {
65
+          "type": "blood",
66
+          "orderId": this.queryObj.orderId
67
+        }).then(res => {
68
+          uni.hideLoading();
69
+          if(res.state == 200){
70
+            console.log(res);
71
+            this.order = res.data.dto;
72
+            this.bloods = {...res.data.complete, ...res.data.unComplete};
73
+            this.receiveNum = 0;
74
+            for (let key in this.bloods) {
75
+              this.receiveNum += this.bloods[key].length;
76
+            }
77
+          }else{
78
+            uni.showToast({
79
+              icon: "none",
80
+              title: "请求失败!",
81
+            });
82
+          }
83
+        })
84
+      },
85
+      // 手动查询-确认
86
+      speOk(data) {
87
+        console.log(data);
88
+        if (!data.id) {
89
+          //没有查询到
90
+          uni.showModal({
91
+            title: '提示',
92
+            content: "没有查询到标本!",
93
+            showCancel: false,
94
+            success: function(res) {
95
+              if (res.confirm) {
96
+                console.log('用户点击确定');
97
+              } else if (res.cancel) {
98
+                console.log('用户点击取消');
99
+              }
100
+            }
101
+          });
102
+          return;
103
+        }
104
+        this.speModels.disjunctor = false;
105
+        this.hand_scanning_common(data.bloodCode, 'hand');
106
+      },
107
+      // 手动查询-取消
108
+      speCancel() {
109
+        this.speModels.disjunctor = false;
110
+      },
111
+      // 手动查询弹窗
112
+      showHandViewSpecimen() {
113
+        this.speModels = {
114
+          title: '填写血袋号',
115
+          disjunctor: true,
116
+        }
117
+      },
118
+      // 手动录入
119
+      hand_again() {
120
+        this.showHandViewSpecimen();
121
+      },
122
+      // 手动输入和扫码公共方法
123
+      hand_scanning_common(ress1, type) {
124
+        // ----------------
125
+        uni.showLoading({
126
+          title: "加载中",
127
+          mask: true,
128
+        });
129
+        //检验二维码的有效性
130
+        post("/dept/scanning", {
131
+          content: ress1,
132
+        }).then((result) => {
133
+          this.SMFlag = true;
134
+          if (result.state == 200 || result.state == 201) {
135
+            let codes = result.code;
136
+            if (codes) {
137
+              post("/transflow/scanBind", {type: 'blood',orderId: this.queryObj.orderId, code: ress1}).then((ress) => {
138
+                uni.hideLoading();
139
+                if (ress.state == 200) {
140
+                  //扫描标本后会自动调用摄像头,继续扫描,直到status不是200
141
+                  setTimeout(()=>{
142
+                    if (type === 'scan') {
143
+                      this.Scanning_again();
144
+                    }
145
+                  },500)
146
+                  //todo
147
+                  uni.redirectTo({
148
+                    url: `../scanning_blood_process/scanning_blood_process?orderId=${this.queryObj.orderId}&bloodDTO=${encodeURIComponent(JSON.stringify(ress.data.dto))}&scanCount=${ress.data.scanCount}&status=${ress.state}&scanOrHand=${type}`,
149
+                  });
150
+                } else {
151
+                  uni.redirectTo({
152
+                    url: `../scanning_blood_process/scanning_blood_process?orderId=${this.queryObj.orderId}&status=${ress.state}&scanOrHand=${type}&qrcode=${ress1}`,
153
+                  });
154
+                }
155
+              });
156
+            } else {
157
+              uni.hideLoading();
158
+            }
159
+          } else {
160
+            uni.hideLoading();
161
+            uni.showToast({
162
+              icon: "none",
163
+              title: "请求失败!",
164
+            });
165
+          }
166
+        });
167
+        // ------------------------------
168
+      },
169
+      // 继续扫描
170
+      Scanning_again() {
171
+        if (!this.SMFlag) {
172
+          return;
173
+        }
174
+        this.SMFlag = false;
175
+        SM().then((ress1) => {
176
+          this.hand_scanning_common(ress1, 'scan');
177
+        }).catch(err => {
178
+          this.SMFlag = true;
179
+        });
180
+      },
181
+    },
182
+    onShow() {
183
+      this.SMFlag = true;
184
+    },
185
+    onLoad(options) {
186
+      console.log(options, "result");
187
+      this.queryObj = options;
188
+      this.getInfo();
189
+      // #ifdef APP-PLUS
190
+      webHandle("no", "app");
191
+      // #endif
192
+      // #ifdef H5
193
+      webHandle("no", "wx");
194
+      // #endif
195
+    },
196
+  };
197
+</script>
198
+<style lang="less">
199
+  .Scanning_Result {
200
+    padding: 0 20rpx;
201
+
202
+    .Scanning_top {
203
+      .Scanning_top_icon {
204
+        width: 140rpx;
205
+        height: 140rpx;
206
+        margin: 0 auto;
207
+        border-radius: 50%;
208
+        line-height: 140rpx;
209
+        
210
+        .speNum{
211
+          text-align: center;
212
+          font-size: 140rpx;
213
+        }
214
+
215
+        .cubeic-ok {
216
+          font-size: 140rpx;
217
+          color: #35b34a;
218
+        }
219
+
220
+        .cubeic-close {
221
+          font-size: 140rpx;
222
+          color: #ff3b53;
223
+        }
224
+      }
225
+
226
+      .Scanning_top_text {
227
+        .text1 {
228
+          font-size: 48rpx;
229
+          text-align: center;
230
+        }
231
+
232
+        .success_tips {
233
+          color: red;
234
+          font-size: 30rpx;
235
+        }
236
+      }
237
+    }
238
+
239
+    .Scanning_cont {
240
+      font-size: 32rpx;
241
+      text-align: center;
242
+      .link{
243
+        text-decoration: underline;
244
+      }
245
+
246
+      view {
247
+        margin-bottom: 16rpx;
248
+      }
249
+
250
+      .Scanning_cont_center {
251
+        text-align: center;
252
+      }
253
+
254
+      .text {
255
+        margin-top: 24rpx;
256
+        color: #35b34a;
257
+      }
258
+
259
+      .text1 {
260
+        margin-top: 24rpx;
261
+        color: #ff3b53;
262
+      }
263
+    }
264
+
265
+    .foot_btn {
266
+      line-height: 88rpx;
267
+      height: 100rpx;
268
+      margin-top: 40rpx;
269
+      display: flex;
270
+      justify-content: center;
271
+
272
+      .btn1,
273
+      .btn2,
274
+      .btn3 {
275
+        height: 88rpx;
276
+        flex: 1;
277
+        margin: 0 1%;
278
+        background-image: linear-gradient(to right, #72c172, #3bb197);
279
+        color: #fff;
280
+        border-radius: 8rpx;
281
+        font-size: 32rpx;
282
+        margin-top: 16rpx;
283
+        text-align: center;
284
+      }
285
+    }
286
+    .foot_btn_spe {
287
+      line-height: 88rpx;
288
+      height: 100rpx;
289
+      margin-top: 40rpx;
290
+      text-align: center;
291
+      display: flex;
292
+      justify-content: space-between;
293
+      flex-wrap: wrap;
294
+    
295
+      &::after {
296
+        content: '';
297
+        flex: 1;
298
+      }
299
+    
300
+      view {
301
+        height: 88rpx;
302
+        width: 48%;
303
+        margin: 0 1%;
304
+        background-image: linear-gradient(to right, #72c172, #3bb197);
305
+        color: #fff;
306
+        border-radius: 8rpx;
307
+        font-size: 32rpx;
308
+        margin-top: 16rpx;
309
+      }
310
+    }
311
+  }
312
+</style>