Browse Source

标本配送优化

seimin 3 years ago
parent
commit
df14d2b395

+ 2 - 2
main.js

@@ -2,8 +2,8 @@ import Vue from 'vue'
2 2
 import App from './App'
3 3
 // #ifdef H5
4 4
 import wx from 'weixin-jsapi'
5
-// import VConsole from 'vconsole';
6
-// new VConsole();
5
+import VConsole from 'vconsole';
6
+new VConsole();
7 7
 Vue.prototype.wx = wx //声明扫码
8 8
 Vue.prototype.audios = [] //待播放的语音集合
9 9
 // #endif

+ 405 - 420
pages/scanning/scanning.vue

@@ -6,28 +6,20 @@
6 6
       </view>
7 7
       <view class="Scanning_top_text">
8 8
         <view class="text1"> 扫描完成 </view>
9
-        <view class="text2">
9
+        <view class="text2" v-if="queryObj.content" v-html="queryObj.content"></view>
10
+        <view class="text2" v-if="!queryObj.content">
10 11
           您已在
11
-          <text
12
-            style="font-weight: 600; color: rgb(73, 184, 86)"
13
-            v-if="
12
+          <text style="font-weight: 600; color: rgb(73, 184, 86)" v-if="
14 13
               infoType == 'plan-spe-ddd-1' ||
15 14
               infoType == 'plan-spe-ddd-2' ||
16 15
               infoType == 'spe-ddd-1' ||
17 16
               infoType == 'spe-ddd-2' ||
18 17
               infoType == 'drug-ddd-2' ||
19 18
               infoType == 'jp-ddd-2'
20
-            "
21
-            >{{ infoDATA.startDept.dept }}</text
22
-          >
23
-          <text
24
-            style="font-weight: 600; color: rgb(73, 184, 86)"
25
-            v-if="infoType == 'drug-dsd-2' || infoType == 'jp-dsd-2'"
26
-            >{{ infoDATA.endDepts[0].dept }}</text
27
-          >
28
-          <text
29
-            style="font-weight: 600; color: rgb(73, 184, 86)"
30
-            v-if="
19
+            ">{{ infoDATA.startDept.dept }}</text>
20
+          <text style="font-weight: 600; color: rgb(73, 184, 86)"
21
+            v-if="infoType == 'drug-dsd-2' || infoType == 'jp-dsd-2'">{{ infoDATA.endDepts[0].dept }}</text>
22
+          <text style="font-weight: 600; color: rgb(73, 184, 86)" v-if="
31 23
               infoType == 'plan-spe-dsd-2' ||
32 24
               infoType == 'plan-spe-dsd-3' ||
33 25
               infoType == 'plan-spe-dsd-1' ||
@@ -40,122 +32,135 @@
40 32
               (infoType == 'qt-ddd-1' && infoDATA.gdState.value == '5') ||
41 33
               infoDATA.gdState.value == '6' ||
42 34
               infoDATA.gdState.value == '8'
43
-            "
44
-            >{{ DEPT }}</text
45
-          >
46
-          <text
47
-            >扫描<text style="color: #ff3b53">{{ speNum }}</text> 个标本,
48
-            确认是否继续配送或是完成工单。</text
49
-          >
35
+            ">{{ DEPT }}</text>
36
+          <text>扫描<text style="color: #ff3b53">{{ speNum }}</text> 个标本,
37
+            确认是否继续配送或是完成工单。</text>
50 38
         </view>
51 39
       </view>
52 40
     </view>
53 41
     <view class="foot_btn1 footerPadding">
54 42
       <view class="btn1" @click="Scanning_again()"> 继续配送 </view>
55
-      <view
56
-        class="btn2"
57
-        @click="Scanning_complete(dataId)"
58
-        v-if="
43
+      <view class="btn2" @click="Scanning_complete(dataId)" v-if="
59 44
           infoType == 'plan-spe-ddd-1' ||
60 45
           infoType == 'plan-spe-dsd-1' ||
61 46
           infoType == 'spe-ddd-1' ||
62 47
           infoType == 'spe-dsd-1'
63
-        "
64
-      >
48
+        ">
65 49
         完成工单
66 50
       </view>
67
-      <view
68
-        class="btn2"
69
-        @click="Scanning_complete1(dataId)"
70
-        v-if="
51
+      <view class="btn2" @click="Scanning_complete1(dataId)" v-if="
71 52
           infoType == 'plan-spe-ddd-2' ||
72 53
           infoType == 'plan-spe-dsd-2' ||
73 54
           infoType == 'plan-spe-dsd-3' ||
74 55
           infoType == 'spe-ddd-2' ||
75 56
           infoType == 'spe-dsd-2' ||
76 57
           infoType == 'spe-dsd-3'
77
-        "
78
-      >
58
+        ">
79 59
         完成工单
80 60
       </view>
81 61
     </view>
82 62
     <!-- 弹窗 -->
83
-    <showModel
84
-      :title="models.title"
85
-      :icon="models.icon"
86
-      :disjunctor="models.disjunctor"
87
-      :content="models.content"
88
-      @ok="ok"
89
-      @cancel="cancel"
90
-      :operate="models.operate"
91
-    ></showModel>
63
+    <showModel :title="models.title" :icon="models.icon" :disjunctor="models.disjunctor" :content="models.content"
64
+      @ok="ok" @cancel="cancel" :operate="models.operate"></showModel>
92 65
   </view>
93 66
 </template>
94 67
 <script>
95
-import showModel from "../../components/showModel/showModel.vue";
96
-import { get, post, SM, webHandle } from "../../http/http.js";
97
-export default {
98
-  data() {
99
-    return {
100
-      // 弹窗model
101
-      models: {
102
-        disjunctor: false,
103
-      },
104
-      wcId: [], //完成工单id
105
-      modelFlag: "", //弹窗标识
106
-      infoDATA: [],
107
-      infoType: "",
108
-      DEPTCode: "",
109
-      DEPT: "",
110
-      dataId: "",
111
-      speNum: 0,
112
-      queryObj: {}, //路由传递过来的参数
113
-    };
114
-  },
115
-  methods: {
116
-    // 继续配送
117
-    Scanning_again(id) {
118
-      uni.navigateTo({
119
-        url: "../receiptpage/receiptpage",
120
-      });
68
+  import showModel from "../../components/showModel/showModel.vue";
69
+  import {
70
+    get,
71
+    post,
72
+    SM,
73
+    webHandle
74
+  } from "../../http/http.js";
75
+  export default {
76
+    data() {
77
+      return {
78
+        // 弹窗model
79
+        models: {
80
+          disjunctor: false,
81
+        },
82
+        wcId: [], //完成工单id
83
+        modelFlag: "", //弹窗标识
84
+        infoDATA: [],
85
+        infoType: "",
86
+        DEPTCode: "",
87
+        DEPT: "",
88
+        dataId: "",
89
+        speNum: 0,
90
+        queryObj: {}, //路由传递过来的参数
91
+      };
121 92
     },
122
-    // 确定
123
-    ok() {
124
-      this.models.disjunctor = false;
125
-      if (this.modelFlag == "complete1") {
126
-        //一对多、多对多完成工单
127
-        let data = {
128
-          type: this.infoType,
129
-          ids: this.wcId,
130
-        };
131
-        let id = this.wcId;
132
-        if (this.queryObj.type === "specimenPlan") {
133
-          //标本轮巡
134
-          post("/workerOrder/finishPlanSpes", data).then((res) => {
135
-            if (res.status == 200) {
136
-              uni.navigateTo({
137
-                url: `../scanning_orderSign/scanning_orderSign?type=${
93
+    methods: {
94
+      // 继续配送
95
+      Scanning_again(id) {
96
+        uni.navigateTo({
97
+          url: "../receiptpage/receiptpage",
98
+        });
99
+      },
100
+      // 确定
101
+      ok() {
102
+        this.models.disjunctor = false;
103
+        uni.showLoading({
104
+          title: "加载中",
105
+          mask: true,
106
+        });
107
+        if (this.modelFlag == "complete1") {
108
+          //一对多、多对多完成工单
109
+          let data = {
110
+            type: this.infoType,
111
+            ids: this.wcId,
112
+          };
113
+          let id = this.wcId;
114
+          if (this.queryObj.type === "specimenPlan") {
115
+            //标本轮巡
116
+            post("/workerOrder/finishPlanSpes", data).then((res) => {
117
+              uni.hideLoading();
118
+              if (res.status == 200) {
119
+                uni.navigateTo({
120
+                  url: `../scanning_orderSign/scanning_orderSign?type=${
138 121
                   this.queryObj.type
139 122
                 }&type1=${this.queryObj.type1}&deptCode=${
140 123
                   this.queryObj.code
141 124
                 }&id=${encodeURIComponent(JSON.stringify(id))}`,
142
-              });
143
-            } else {
144
-              uni.showToast({
145
-                icon: "none",
146
-                title: "请求失败!",
147
-              });
148
-            }
149
-          });
150
-        } else {
151
-          post("/workerOrder/finishSpes", data).then((res) => {
125
+                });
126
+              } else {
127
+                uni.showToast({
128
+                  icon: "none",
129
+                  title: "请求失败!",
130
+                });
131
+              }
132
+            });
133
+          } else {
134
+            post("/workerOrder/finishSpes", data).then((res) => {
135
+              uni.hideLoading();
136
+              if (res.status == 200) {
137
+                uni.navigateTo({
138
+                  url: `../scanning_orderSign/scanning_orderSign?type=${
139
+                    this.queryObj.type
140
+                  }&type1=${this.queryObj.type1}&deptCode=${
141
+                    this.queryObj.code
142
+                  }&id=${encodeURIComponent(JSON.stringify(id))}`,
143
+                });
144
+              } else {
145
+                uni.showToast({
146
+                  icon: "none",
147
+                  title: "请求失败!",
148
+                });
149
+              }
150
+            });
151
+          }
152
+        } else if (this.modelFlag == "complete") {
153
+          //一对一完成工单
154
+          let id = this.wcId;
155
+          post("/workerOrder/finishSpeOrder", id).then((res) => {
156
+            uni.hideLoading();
152 157
             if (res.status == 200) {
153 158
               uni.navigateTo({
154 159
                 url: `../scanning_orderSign/scanning_orderSign?type=${
155
-                  this.queryObj.type
156
-                }&type1=${this.queryObj.type1}&deptCode=${
157
-                  this.queryObj.code
158
-                }&id=${encodeURIComponent(JSON.stringify(id))}`,
160
+                this.queryObj.type
161
+              }&type1=${this.queryObj.type1}&deptCode=${
162
+                this.queryObj.code
163
+              }&id=${encodeURIComponent(JSON.stringify(id))}`,
159 164
               });
160 165
             } else {
161 166
               uni.showToast({
@@ -165,346 +170,293 @@ export default {
165 170
             }
166 171
           });
167 172
         }
168
-      } else if (this.modelFlag == "complete") {
169
-        //一对一完成工单
170
-        let id = this.wcId;
171
-        post("/workerOrder/finishSpeOrder", id).then((res) => {
172
-          if (res.status == 200) {
173
-            uni.navigateTo({
174
-              url: `../scanning_orderSign/scanning_orderSign?type=${
175
-                this.queryObj.type
176
-              }&type1=${this.queryObj.type1}&deptCode=${
177
-                this.queryObj.code
178
-              }&id=${encodeURIComponent(JSON.stringify(id))}`,
179
-            });
180
-          } else {
181
-            uni.showToast({
182
-              icon: "none",
183
-              title: "请求失败!",
184
-            });
185
-          }
186
-        });
187
-      }
188
-    },
189
-    // 取消
190
-    cancel() {
191
-      this.models.disjunctor = false;
192
-    },
193
-    //一对多、多对多完成工单
194
-    Scanning_complete1(id) {
195
-      this.wcId = id;
196
-      this.modelFlag = "complete1"; //弹窗标识
197
-      this.models = {
198
-        disjunctor: true,
199
-        title: "提示",
200
-        content: "是否确定标本配送完成?",
201
-        icon: "warn",
202
-        operate: {
203
-          ok: "确定",
204
-          cancel: "取消",
205
-        },
206
-      };
173
+      },
174
+      // 取消
175
+      cancel() {
176
+        this.models.disjunctor = false;
177
+      },
178
+      //一对多、多对多完成工单
179
+      Scanning_complete1(id) {
180
+        this.wcId = id;
181
+        this.modelFlag = "complete1"; //弹窗标识
182
+        this.models = {
183
+          disjunctor: true,
184
+          title: "提示",
185
+          content: "是否确定标本配送完成?",
186
+          icon: "warn",
187
+          operate: {
188
+            ok: "确定",
189
+            cancel: "取消",
190
+          },
191
+        };
192
+      },
193
+      //一对一完成工单
194
+      Scanning_complete(id) {
195
+        this.wcId = id;
196
+        this.modelFlag = "complete"; //弹窗标识
197
+        this.models = {
198
+          disjunctor: true,
199
+          title: "提示",
200
+          content: "是否确定标本配送完成?",
201
+          icon: "warn",
202
+          operate: {
203
+            ok: "确定",
204
+            cancel: "取消",
205
+          },
206
+        };
207
+      },
207 208
     },
208
-    //一对一完成工单
209
-    Scanning_complete(id) {
210
-      this.wcId = id;
211
-      this.modelFlag = "complete"; //弹窗标识
212
-      this.models = {
213
-        disjunctor: true,
214
-        title: "提示",
215
-        content: "是否确定标本配送完成?",
216
-        icon: "warn",
217
-        operate: {
218
-          ok: "确定",
219
-          cancel: "取消",
220
-        },
221
-      };
209
+    onLoad(options) {
210
+      console.log(options, 'options')
211
+      this.queryObj = options;
212
+      let id = JSON.parse(options.id);
213
+      this.dataId = id;
214
+      this.infoType = options.type1;
215
+      this.DEPTCode = options.deptCode;
216
+      this.DEPT = options.dept;
217
+      if (options.speNum) {
218
+        this.speNum = options.speNum;
219
+      }
220
+      // #ifdef APP-PLUS
221
+      webHandle("no", "app");
222
+      // #endif
223
+      // #ifdef H5
224
+      webHandle("no", "wx");
225
+      // #endif
222 226
     },
223
-  },
224
-  onLoad(options) {
225
-    console.log(options,'options')
226
-    this.queryObj = options;
227
-    let id = JSON.parse(options.id);
228
-    this.dataId = id;
229
-    this.infoType = options.type1;
230
-    this.DEPTCode = options.deptCode;
231
-    this.DEPT = options.dept;
232
-    if (options.speNum) {
233
-      this.speNum = options.speNum;
234
-    }
235
-    // #ifdef APP-PLUS
236
-    webHandle("no", "app");
237
-    // #endif
238
-    // #ifdef H5
239
-    webHandle("no", "wx");
240
-    // #endif
241
-  },
242
-};
227
+  };
243 228
 </script>
244 229
 <style lang="less">
245
-.Scanning {
246
-  padding: 0 20rpx;
247
-
248
-  .Scanning_top {
249
-    height: 340rpx;
250
-
251
-    .Scanning_top_icon {
252
-      width: 140rpx;
253
-      height: 140rpx;
254
-      margin: 0 auto;
255
-      margin-top: 36rpx;
256
-      border-radius: 50%;
257
-      line-height: 140rpx;
258
-
259
-      .cubeic-ok {
260
-        font-size: 140rpx;
261
-        color: #35b34a;
230
+  .Scanning {
231
+    padding: 0 20rpx;
232
+
233
+    .Scanning_top {
234
+      height: 340rpx;
235
+
236
+      .Scanning_top_icon {
237
+        width: 140rpx;
238
+        height: 140rpx;
239
+        margin: 0 auto;
240
+        margin-top: 36rpx;
241
+        border-radius: 50%;
242
+        line-height: 140rpx;
243
+
244
+        .cubeic-ok {
245
+          font-size: 140rpx;
246
+          color: #35b34a;
247
+        }
262 248
       }
263
-    }
264 249
 
265
-    .Scanning_top_text {
266
-      text-align: center;
250
+      .Scanning_top_text {
251
+        text-align: center;
267 252
 
268
-      .text1 {
269
-        margin-top: 40rpx;
270
-        font-size: 48rpx;
271
-      }
253
+        .text1 {
254
+          margin-top: 40rpx;
255
+          font-size: 48rpx;
256
+        }
272 257
 
273
-      .text2 {
274
-        margin-top: 16rpx;
275
-        font-size: 36rpx;
258
+        .text2 {
259
+          margin-top: 16rpx;
260
+          font-size: 36rpx;
261
+        }
276 262
       }
277 263
     }
278
-  }
279 264
 
280
-  .page_item {
281
-    margin-top: 16rpx;
282
-    margin-bottom: 124rpx;
283
-    min-height: 356rpx;
284
-    background: #fff;
285
-    border-radius: 8rpx;
286
-    overflow: hidden;
287
-    padding: 0 16rpx;
288
-    border: 2rpx solid #e5e9ed;
289
-
290
-    .L {
291
-      width: 40rpx;
292
-      height: 40rpx;
293
-      border-radius: 50%;
294
-      background: #f9fafb;
295
-      position: relative;
296
-      left: -50rpx;
297
-      top: 66rpx;
298
-    }
299
-
300
-    .R {
301
-      width: 40rpx;
302
-      height: 40rpx;
303
-      border-radius: 50%;
304
-      background: #f9fafb;
305
-      position: relative;
306
-      float: right;
307
-      right: -50rpx;
308
-      top: 26rpx;
309
-    }
310
-
311
-    .starting {
312
-      width: 50rpx;
313
-      height: 50rpx;
314
-      color: #fff;
315
-      background: #49b856;
316
-      display: inline-block;
317
-      border-radius: 50%;
318
-      text-align: center;
319
-      line-height: 46rpx;
320
-      font-size: 32rpx;
321
-      margin-right: 6rpx;
322
-    }
323
-
324
-    .End {
325
-      width: 50rpx;
326
-      height: 50rpx;
327
-      color: #fff;
328
-      background: #39b199;
329
-      display: inline-block;
330
-      border-radius: 50%;
331
-      text-align: center;
332
-      line-height: 46rpx;
333
-      font-size: 32rpx;
334
-      margin-right: 6rpx;
335
-    }
336
-
337
-    .page_item_top {
338
-      height: 86rpx;
339
-      border-bottom: 2rpx dashed #e5e9ed;
265
+    .page_item {
266
+      margin-top: 16rpx;
267
+      margin-bottom: 124rpx;
268
+      min-height: 356rpx;
269
+      background: #fff;
270
+      border-radius: 8rpx;
271
+      overflow: hidden;
340 272
       padding: 0 16rpx;
341
-
342
-      .page_item_top_L {
343
-        height: 100%;
344
-        float: left;
345
-        line-height: 88rpx;
346
-
347
-        .emergencys {
348
-          background: #ff3b53 !important;
349
-          width: 124rpx !important;
350
-        }
351
-
352
-        .emergency {
353
-          background: #ff3b53 !important;
354
-        }
355
-
356
-        .emergency1 {
357
-          background: #49b856 !important;
358
-        }
359
-
360
-        .page_item_cont_start {
361
-          text-align: center;
362
-          height: 44rpx;
363
-          width: 104rpx;
364
-          line-height: 44rpx;
365
-          border-radius: 8rpx;
366
-          background: #49b856;
367
-          color: #fff;
368
-          display: inline-block;
369
-        }
370
-
371
-        .L_time {
372
-          color: #6cc076;
373
-          font-size: 32rpx;
374
-        }
375
-
376
-        .L_text {
377
-          font-size: 32rpx;
378
-          display: inline-block;
379
-          font-weight: 700;
380
-        }
273
+      border: 2rpx solid #e5e9ed;
274
+
275
+      .L {
276
+        width: 40rpx;
277
+        height: 40rpx;
278
+        border-radius: 50%;
279
+        background: #f9fafb;
280
+        position: relative;
281
+        left: -50rpx;
282
+        top: 66rpx;
381 283
       }
382 284
 
383
-      .page_item_top_R {
384
-        height: 60rpx;
285
+      .R {
286
+        width: 40rpx;
287
+        height: 40rpx;
288
+        border-radius: 50%;
289
+        background: #f9fafb;
290
+        position: relative;
385 291
         float: right;
386
-        padding-top: 20rpx;
387
-        font-size: 32rpx;
388
-        position: absolute;
389
-        right: 50rpx;
390
-
391
-        .L_iocn {
392
-          display: inline-block;
393
-          height: 52rpx;
394
-          line-height: 48rpx;
395
-          color: rgb(7, 134, 60);
396
-          font-size: 36rpx;
397
-          font-weight: 700;
398
-        }
292
+        right: -50rpx;
293
+        top: 26rpx;
399 294
       }
400
-    }
401
-
402
-    .page_item_cont {
403
-      min-height: 180rpx;
404
-      max-height: 424rpx;
405
-      padding: 0 16rpx;
406
-      text-align: left;
407
-      position: relative;
408 295
 
409
-      .text_big {
296
+      .starting {
297
+        width: 50rpx;
298
+        height: 50rpx;
299
+        color: #fff;
300
+        background: #49b856;
301
+        display: inline-block;
302
+        border-radius: 50%;
303
+        text-align: center;
304
+        line-height: 46rpx;
410 305
         font-size: 32rpx;
411
-        position: absolute;
412
-        right: 16rpx;
413
-        font-weight: 700;
414
-        margin-top: 10rpx;
306
+        margin-right: 6rpx;
415 307
       }
416 308
 
417
-      .text_big2 {
309
+      .End {
310
+        width: 50rpx;
311
+        height: 50rpx;
312
+        color: #fff;
313
+        background: #39b199;
314
+        display: inline-block;
315
+        border-radius: 50%;
316
+        text-align: center;
317
+        line-height: 46rpx;
418 318
         font-size: 32rpx;
419
-        position: absolute;
420
-        right: 16rpx;
421
-        font-weight: 700;
319
+        margin-right: 6rpx;
422 320
       }
423 321
 
424
-      .line {
425
-        height: 20rpx;
426
-        width: 2rpx;
427
-        border-left: 2rpx solid #e5e9ed;
428
-        position: absolute;
429
-        top: 82rpx;
430
-        left: 40rpx;
431
-      }
322
+      .page_item_top {
323
+        height: 86rpx;
324
+        border-bottom: 2rpx dashed #e5e9ed;
325
+        padding: 0 16rpx;
432 326
 
433
-      .lines {
434
-        height: 40%;
435
-        width: 2rpx;
436
-        border-left: 2rpx solid #e5e9ed;
437
-        position: absolute;
438
-        top: 23%;
439
-        left: 36rpx;
440
-      }
327
+        .page_item_top_L {
328
+          height: 100%;
329
+          float: left;
330
+          line-height: 88rpx;
441 331
 
442
-      .page_item_cont_T {
443
-        padding-top: 28rpx;
444
-        font-size: 28rpx;
332
+          .emergencys {
333
+            background: #ff3b53 !important;
334
+            width: 124rpx !important;
335
+          }
445 336
 
446
-        .page_item_cont_title {
447
-          height: 100%;
337
+          .emergency {
338
+            background: #ff3b53 !important;
339
+          }
340
+
341
+          .emergency1 {
342
+            background: #49b856 !important;
343
+          }
344
+
345
+          .page_item_cont_start {
346
+            text-align: center;
347
+            height: 44rpx;
348
+            width: 104rpx;
349
+            line-height: 44rpx;
350
+            border-radius: 8rpx;
351
+            background: #49b856;
352
+            color: #fff;
353
+            display: inline-block;
354
+          }
355
+
356
+          .L_time {
357
+            color: #6cc076;
358
+            font-size: 32rpx;
359
+          }
360
+
361
+          .L_text {
362
+            font-size: 32rpx;
363
+            display: inline-block;
364
+            font-weight: 700;
365
+          }
366
+        }
367
+
368
+        .page_item_top_R {
369
+          height: 60rpx;
370
+          float: right;
371
+          padding-top: 20rpx;
448 372
           font-size: 32rpx;
373
+          position: absolute;
374
+          right: 50rpx;
375
+
376
+          .L_iocn {
377
+            display: inline-block;
378
+            height: 52rpx;
379
+            line-height: 48rpx;
380
+            color: rgb(7, 134, 60);
381
+            font-size: 36rpx;
382
+            font-weight: 700;
383
+          }
449 384
         }
450 385
       }
451 386
 
452
-      .page_item_cont_B {
453
-        padding-top: 28rpx;
454
-        margin-bottom: 28rpx;
387
+      .page_item_cont {
388
+        min-height: 180rpx;
389
+        max-height: 424rpx;
390
+        padding: 0 16rpx;
391
+        text-align: left;
392
+        position: relative;
455 393
 
456
-        .page_item_cont_title {
457
-          height: 60rpx;
394
+        .text_big {
458 395
           font-size: 32rpx;
396
+          position: absolute;
397
+          right: 16rpx;
398
+          font-weight: 700;
399
+          margin-top: 10rpx;
459 400
         }
460 401
 
461
-        .page_item_cont_title1 {
462
-          height: 60rpx;
463
-          line-height: 60rpx;
402
+        .text_big2 {
464 403
           font-size: 32rpx;
465
-          padding-left: 64rpx;
404
+          position: absolute;
405
+          right: 16rpx;
406
+          font-weight: 700;
466 407
         }
467
-      }
468
-    }
469
-
470
-    .page_item_foot {
471
-      border-top: 2rpx dashed #e5e9ed;
472
-      border-bottom: 2rpx dashed #e5e9ed;
473
-      padding: 28rpx 16rpx;
474
-      text-align: left;
475 408
 
476
-      .page_item_foot_text {
477
-        font-size: 32rpx;
478
-        margin-bottom: 20rpx;
409
+        .line {
410
+          height: 20rpx;
411
+          width: 2rpx;
412
+          border-left: 2rpx solid #e5e9ed;
413
+          position: absolute;
414
+          top: 82rpx;
415
+          left: 40rpx;
416
+        }
479 417
 
480
-        .text1 {
481
-          color: rgb(102, 102, 102);
418
+        .lines {
419
+          height: 40%;
420
+          width: 2rpx;
421
+          border-left: 2rpx solid #e5e9ed;
422
+          position: absolute;
423
+          top: 23%;
424
+          left: 36rpx;
482 425
         }
483 426
 
484
-        .text2 {
485
-          float: right;
486
-          font-weight: 700;
427
+        .page_item_cont_T {
428
+          padding-top: 28rpx;
429
+          font-size: 28rpx;
430
+
431
+          .page_item_cont_title {
432
+            height: 100%;
433
+            font-size: 32rpx;
434
+          }
487 435
         }
488
-      }
489 436
 
490
-      .text_padd {
491
-        padding: 0 10% 0 10%;
492
-      }
493
-    }
437
+        .page_item_cont_B {
438
+          padding-top: 28rpx;
439
+          margin-bottom: 28rpx;
494 440
 
495
-    #infos {
496
-      display: none;
497
-    }
441
+          .page_item_cont_title {
442
+            height: 60rpx;
443
+            font-size: 32rpx;
444
+          }
498 445
 
499
-    .page_item_infos {
500
-      padding-bottom: 20rpx;
501
-      border-bottom: 2rpx dashed #e5e9ed;
446
+          .page_item_cont_title1 {
447
+            height: 60rpx;
448
+            line-height: 60rpx;
449
+            font-size: 32rpx;
450
+            padding-left: 64rpx;
451
+          }
452
+        }
453
+      }
502 454
 
503
-      .page_item_info2 {
455
+      .page_item_foot {
456
+        border-top: 2rpx dashed #e5e9ed;
457
+        border-bottom: 2rpx dashed #e5e9ed;
458
+        padding: 28rpx 16rpx;
504 459
         text-align: left;
505
-        line-height: 60rpx;
506
-        font-size: 32rpx;
507
-        padding-left: 16rpx;
508 460
 
509 461
         .page_item_foot_text {
510 462
           font-size: 32rpx;
@@ -519,38 +471,71 @@ export default {
519 471
             font-weight: 700;
520 472
           }
521 473
         }
474
+
475
+        .text_padd {
476
+          padding: 0 10% 0 10%;
477
+        }
522 478
       }
523
-    }
524
-  }
525 479
 
526
-  .foot_btn1 {
527
-    position: fixed;
528
-    bottom: 0;
529
-    right: 20rpx;
530
-    left: 20rpx;
531
-    line-height: 66rpx;
532
-    height: 100rpx;
533
-    border-top: 2rpx solid #e5e9ed;
534
-    background: #f9fafb;
535
-    text-align: center;
536
-
537
-    view {
538
-      height: 66rpx;
539
-      width: 45%;
540
-      background-image: linear-gradient(to right, #72c172, #3bb197);
541
-      color: #fff;
542
-      border-radius: 8rpx;
543
-      font-size: 32rpx;
544
-      margin-top: 16rpx;
545
-    }
480
+      #infos {
481
+        display: none;
482
+      }
483
+
484
+      .page_item_infos {
485
+        padding-bottom: 20rpx;
486
+        border-bottom: 2rpx dashed #e5e9ed;
546 487
 
547
-    .btn1 {
548
-      float: left;
488
+        .page_item_info2 {
489
+          text-align: left;
490
+          line-height: 60rpx;
491
+          font-size: 32rpx;
492
+          padding-left: 16rpx;
493
+
494
+          .page_item_foot_text {
495
+            font-size: 32rpx;
496
+            margin-bottom: 20rpx;
497
+
498
+            .text1 {
499
+              color: rgb(102, 102, 102);
500
+            }
501
+
502
+            .text2 {
503
+              float: right;
504
+              font-weight: 700;
505
+            }
506
+          }
507
+        }
508
+      }
549 509
     }
550 510
 
551
-    .btn2 {
552
-      float: right;
511
+    .foot_btn1 {
512
+      position: fixed;
513
+      bottom: 0;
514
+      right: 20rpx;
515
+      left: 20rpx;
516
+      line-height: 66rpx;
517
+      height: 100rpx;
518
+      border-top: 2rpx solid #e5e9ed;
519
+      background: #f9fafb;
520
+      text-align: center;
521
+
522
+      view {
523
+        height: 66rpx;
524
+        width: 45%;
525
+        background-image: linear-gradient(to right, #72c172, #3bb197);
526
+        color: #fff;
527
+        border-radius: 8rpx;
528
+        font-size: 32rpx;
529
+        margin-top: 16rpx;
530
+      }
531
+
532
+      .btn1 {
533
+        float: left;
534
+      }
535
+
536
+      .btn2 {
537
+        float: right;
538
+      }
553 539
     }
554 540
   }
555
-}
556 541
 </style>

+ 41 - 39
pages/scanning_Result/scanning_Result.vue

@@ -231,12 +231,12 @@
231 231
   export default {
232 232
     data() {
233 233
       return {
234
-        SMFlag:true,
234
+        SMFlag: true,
235 235
         // 交接人信息
236 236
         accountObj: undefined,
237 237
         // 完成扫描的id
238 238
         wcId: "",
239
-        wcFlag:false,
239
+        wcFlag: false,
240 240
         // 弹窗model
241 241
         models: {
242 242
           disjunctor: false,
@@ -262,7 +262,8 @@
262 262
         speNum: 0,
263 263
         queryObj: {}, //路由传递过来的数据
264 264
         selectRadio: [], //单选框选中的数据,第一项是qrcode,第二项是名称
265
-        gotoFlag: true
265
+        gotoFlag: true,
266
+        content:"",
266 267
       };
267 268
     },
268 269
     methods: {
@@ -403,7 +404,7 @@
403 404
             }
404 405
           });
405 406
           // ------------------------------
406
-        }).catch(err=>{
407
+        }).catch(err => {
407 408
           this.SMFlag = true;
408 409
         });
409 410
       },
@@ -462,7 +463,7 @@
462 463
         let postData = {
463 464
           ids: [this.queryObj.id],
464 465
           sign: true,
465
-          deptQrCode:this.queryObj.deptCode
466
+          deptQrCode: this.queryObj.deptCode
466 467
         };
467 468
         uni.showLoading({
468 469
           title: '加载中',
@@ -471,33 +472,34 @@
471 472
         post("/workerOrder/expectedAndActual", postData).then((ress) => {
472 473
           uni.hideLoading();
473 474
           if (ress.status == 200) {
474
-            if (ress.actualReceiveNum === undefined) {
475
-              if(this.wcFlag){
476
-                //正常完成扫描
477
-                this.overFinish()
478
-              }else{
479
-                this.gotoOver();
480
-              }
475
+            if (this.wcFlag) {
476
+              //正常完成扫描
477
+              this.overFinish()
481 478
             } else {
482
-              let content = '';
483
-              if(this.queryObj.type1 === 'spe-ddd-2'||this.queryObj.type1 === 'plan-spe-ddd-2'){
484
-                //待到达
485
-                content = `系统内预计标本<strong class="red">${ress.expectReceiveNum}</strong>只,您扫描收取标本<strong class="red">${ress.actualReceiveNum}</strong>只,其中<strong class="red">${ress.notReceiveNum}</strong>只未扫描;`;
486
-              }else{
487
-                //待送达
488
-                content = `本工单已签到${ress.scanSet?ress.scanSet.join('、'):''},剩余需签到科室${ress.notScanSet?ress.notScanSet.join('、'):''},总签收${ress.totalAcceptance}只,剩余${ress.notAcceptance}只未签收,您确定完成工单吗?`;
489
-              }
490
-              this.models2 = {
491
-                disjunctor: true,
492
-                title: "提示",
493
-                content,
494
-                icon: "warn",
495
-                operate: {
496
-                  ok: "确定",
497
-                  cancel: "取消",
498
-                },
499
-              };
479
+              this.gotoOver();
500 480
             }
481
+          } else if (ress.status == 1000035) {
482
+            let content = '';
483
+            if (this.queryObj.type1 === 'spe-ddd-2' || this.queryObj.type1 === 'plan-spe-ddd-2') {
484
+              //待到达
485
+              content =
486
+                `系统内预计标本<strong class="red">${ress.expectReceiveNum}</strong>只,您扫描收取标本<strong class="red">${ress.actualReceiveNum}</strong>只,其中<strong class="red">${ress.notReceiveNum}</strong>只未扫描;`;
487
+            } else {
488
+              //待送达
489
+              this.content =
490
+                  `本工单已签到<strong class="red">${ress.scanSet?ress.scanSet.join('、'):''}</strong>,剩余需签到科室<strong class="red">${ress.notScanSet?ress.notScanSet.join('、'):''}</strong>,总签收<strong class="red">${ress.totalAcceptance}</strong>只,剩余<strong class="red">${ress.notAcceptance}</strong>只未签收,您确定完成工单吗?`;
491
+              content = `您在<strong class="red">${ress.deptName}</strong>检验科扫描了<strong class="red">${ress.deptScanNum}</strong>个标本,还需扫描<strong class="red">${ress.deptNotScanNum}</strong>标本。`;
492
+            }
493
+            this.models2 = {
494
+              disjunctor: true,
495
+              title: "提示",
496
+              content,
497
+              icon: "warn",
498
+              operate: {
499
+                ok: "确定",
500
+                cancel: "取消",
501
+              },
502
+            };
501 503
           } else {
502 504
             uni.showToast({
503 505
               icon: "none",
@@ -515,7 +517,7 @@
515 517
         this.models2.disjunctor = false;
516 518
         let postData = {
517 519
           ids: [this.queryObj.id],
518
-          deptQrCode:this.queryObj.deptCode
520
+          deptQrCode: this.queryObj.deptCode
519 521
         };
520 522
         uni.showLoading({
521 523
           title: '加载中',
@@ -524,9 +526,9 @@
524 526
         post("/workerOrder/expectedAndActual", postData).then((ress) => {
525 527
           uni.hideLoading();
526 528
           if (ress.status == 200) {
527
-            if(this.wcFlag){
529
+            if (this.wcFlag) {
528 530
               this.overFinish()
529
-            }else{
531
+            } else {
530 532
               this.gotoOver();
531 533
             }
532 534
           } else {
@@ -541,7 +543,7 @@
541 543
       cancel2() {
542 544
         this.models2.disjunctor = false;
543 545
       },
544
-      know2(){
546
+      know2() {
545 547
         this.models2.disjunctor = false;
546 548
         uni.navigateTo({
547 549
           url: "../receiptpage/receiptpage",
@@ -565,7 +567,7 @@
565 567
               cancel: "取消",
566 568
             },
567 569
           };
568
-        }else if (
570
+        } else if (
569 571
           this.queryObj.type1 == "plan-spe-dsd-2" ||
570 572
           this.queryObj.type1 == "plan-spe-dsd-3" ||
571 573
           this.queryObj.type1 == "spe-dsd-2" ||
@@ -587,14 +589,14 @@
587 589
         }
588 590
       },
589 591
       // 跳转完成工单页面
590
-      gotoOver(){
592
+      gotoOver() {
591 593
         uni.navigateTo({
592
-            url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
594
+          url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
593 595
             this.queryObj.type1
594 596
           }&id=${encodeURIComponent(JSON.stringify([this.wcId]))}&deptCode=${
595 597
             this.queryObj.deptCode
596
-          }&dept=${this.queryObj.dept}&speNum=${this.speNum}`,
597
-          });
598
+          }&dept=${this.queryObj.dept}&speNum=${this.speNum}&content=${this.content}`,
599
+        });
598 600
       },
599 601
       // 继续执行工单,当扫错科室码的时候,直接跳过,默默执行正确的科室码
600 602
       goToRight(id) {

File diff suppressed because it is too large
+ 405 - 482
pages/scanning_djEnd/scanning_djEnd.vue


+ 43 - 41
pages/scanning_djInfo/scanning_djInfo.vue

@@ -126,7 +126,7 @@
126 126
   export default {
127 127
     data() {
128 128
       return {
129
-        SMFlag:true,
129
+        SMFlag: true,
130 130
         // 弹窗model
131 131
         models: {
132 132
           disjunctor: false,
@@ -136,7 +136,7 @@
136 136
           disjunctor: false,
137 137
         },
138 138
         wcId: "", //工单完成ID
139
-        wcFlag:false,
139
+        wcFlag: false,
140 140
         infoDATA: [],
141 141
         res: {
142 142
           status: "",
@@ -154,6 +154,7 @@
154 154
         speNum: 0,
155 155
         queryObj: {}, //路由传递过来的参数
156 156
         gotoFlag: true,
157
+        content:'',
157 158
       };
158 159
     },
159 160
     methods: {
@@ -207,7 +208,7 @@
207 208
         let postData = {
208 209
           ids: this.queryObj.ids,
209 210
           sign: true,
210
-          deptQrCode:this.queryObj.deptCode
211
+          deptQrCode: this.queryObj.deptCode
211 212
         };
212 213
         uni.showLoading({
213 214
           title: "加载中",
@@ -216,33 +217,34 @@
216 217
         post("/workerOrder/expectedAndActual", postData).then((ress) => {
217 218
           uni.hideLoading();
218 219
           if (ress.status == 200) {
219
-            if (ress.actualReceiveNum === undefined) {
220
-              if(this.wcFlag){
221
-                //正常完成扫描
222
-                this.overFinish()
223
-              }else{
224
-                this.gotoOver();
225
-              }
220
+            if (this.wcFlag) {
221
+              //正常完成扫描
222
+              this.overFinish()
226 223
             } else {
227
-              let content = '';
228
-              if(this.queryObj.type1 === 'spe-ddd-2'||this.queryObj.type1 === 'plan-spe-ddd-2'){
229
-                //待到达
230
-                content = `系统内预计标本<strong class="red">${ress.expectReceiveNum}</strong>只,您扫描收取标本<strong class="red">${ress.actualReceiveNum}</strong>只,其中<strong class="red">${ress.notReceiveNum}</strong>只未扫描;`;
231
-              }else{
232
-                //待送达
233
-                content = `本工单已签到${ress.scanSet?ress.scanSet.join('、'):''},剩余需签到科室${ress.notScanSet?ress.notScanSet.join('、'):''},总签收${ress.totalAcceptance}只,剩余${ress.notAcceptance}只未签收,您确定完成工单吗?`;
234
-              }
235
-              this.models2 = {
236
-                disjunctor: true,
237
-                title: "提示",
238
-                content,
239
-                icon: "warn",
240
-                operate: {
241
-                  ok: "确定",
242
-                  cancel: "取消",
243
-                },
244
-              };
224
+              this.gotoOver();
245 225
             }
226
+          } else if (ress.status == 1000035) {
227
+            let content = '';
228
+            if (this.queryObj.type1 === 'spe-ddd-2' || this.queryObj.type1 === 'plan-spe-ddd-2') {
229
+              //待到达
230
+              content =
231
+                `系统内预计标本<strong class="red">${ress.expectReceiveNum}</strong>只,您扫描收取标本<strong class="red">${ress.actualReceiveNum}</strong>只,其中<strong class="red">${ress.notReceiveNum}</strong>只未扫描;`;
232
+            } else {
233
+              //待送达
234
+              this.content =
235
+                  `本工单已签到<strong class="red">${ress.scanSet?ress.scanSet.join('、'):''}</strong>,剩余需签到科室<strong class="red">${ress.notScanSet?ress.notScanSet.join('、'):''}</strong>,总签收<strong class="red">${ress.totalAcceptance}</strong>只,剩余<strong class="red">${ress.notAcceptance}</strong>只未签收,您确定完成工单吗?`;
236
+              content = `您在<strong class="red">${ress.deptName}</strong>检验科扫描了<strong class="red">${ress.deptScanNum}</strong>个标本,还需扫描<strong class="red">${ress.deptNotScanNum}</strong>标本。`;
237
+            }
238
+            this.models2 = {
239
+              disjunctor: true,
240
+              title: "提示",
241
+              content,
242
+              icon: "warn",
243
+              operate: {
244
+                ok: "确定",
245
+                cancel: "取消",
246
+              },
247
+            };
246 248
           } else {
247 249
             uni.showToast({
248 250
               icon: "none",
@@ -261,7 +263,7 @@
261 263
         this.models2.disjunctor = false;
262 264
         let postData = {
263 265
           ids: this.queryObj.ids,
264
-          deptQrCode:this.queryObj.deptCode
266
+          deptQrCode: this.queryObj.deptCode
265 267
         };
266 268
         uni.showLoading({
267 269
           title: "加载中",
@@ -270,9 +272,9 @@
270 272
         post("/workerOrder/expectedAndActual", postData).then((ress) => {
271 273
           uni.hideLoading();
272 274
           if (ress.status == 200) {
273
-            if(this.wcFlag){
275
+            if (this.wcFlag) {
274 276
               this.overFinish()
275
-            }else{
277
+            } else {
276 278
               this.gotoOver();
277 279
             }
278 280
           } else {
@@ -287,7 +289,7 @@
287 289
       cancel2() {
288 290
         this.models2.disjunctor = false;
289 291
       },
290
-      know2(){
292
+      know2() {
291 293
         this.models2.disjunctor = false;
292 294
         uni.navigateTo({
293 295
           url: "../receiptpage/receiptpage",
@@ -311,7 +313,7 @@
311 313
               cancel: "取消",
312 314
             },
313 315
           };
314
-        }else if (
316
+        } else if (
315 317
           this.queryObj.type1 == "plan-spe-dsd-2" ||
316 318
           this.queryObj.type1 == "plan-spe-dsd-3" ||
317 319
           this.queryObj.type1 == "spe-dsd-2" ||
@@ -333,14 +335,14 @@
333 335
         }
334 336
       },
335 337
       // 跳转完成工单页面
336
-      gotoOver(){
338
+      gotoOver() {
337 339
         uni.navigateTo({
338
-            url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
340
+          url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
339 341
             this.queryObj.type1
340 342
           }&id=${encodeURIComponent(JSON.stringify(this.wcId))}&deptCode=${
341 343
             this.queryObj.deptCode
342
-          }&dept=${this.queryObj.dept}`,
343
-          });
344
+          }&dept=${this.queryObj.dept}&content=${this.content}`,
345
+        });
344 346
       },
345 347
       // 继续扫描
346 348
       Scanning_again() {
@@ -477,7 +479,7 @@
477 479
             }
478 480
           });
479 481
           // ------------------------------
480
-        }).catch(err=>{
482
+        }).catch(err => {
481 483
           this.SMFlag = true;
482 484
         });
483 485
       },
@@ -488,12 +490,12 @@
488 490
         });
489 491
       },
490 492
     },
491
-    onShow(){
493
+    onShow() {
492 494
       this.SMFlag = true;
493 495
     },
494 496
     onLoad(options) {
495
-      console.log(options,'options')
496
-      if(options.speNum){
497
+      console.log(options, 'options')
498
+      if (options.speNum) {
497 499
         this.speNum = options.speNum;
498 500
       }
499 501
       this.queryObj = options;

+ 0 - 1
pages/scanning_orderSign/scanning_orderSign.vue

@@ -442,7 +442,6 @@ export default {
442 442
 
443 443
     .page_item_cont {
444 444
       min-height: 180rpx;
445
-      max-height: 424rpx;
446 445
       padding: 0 16rpx;
447 446
       text-align: left;
448 447
       position: relative;