ソースを参照

标本巡检优化

seimin 2 年 前
コミット
e5d6f81ee9

+ 32 - 0
pages.json

@@ -246,6 +246,38 @@
246 246
         "enablePullDownRefresh": false
247 247
       }
248 248
 
249
+    }, {
250
+      "path": "pages/scannedDepartmentSpecimens/scannedDepartmentSpecimens",
251
+      "style": {
252
+        "h5": {
253
+          "titleNView": false
254
+        },
255
+        "enablePullDownRefresh": true
256
+      }
257
+    }, {
258
+      "path": "pages/specimenCheckingEnd/specimenCheckingEnd",
259
+      "style": {
260
+        "h5": {
261
+          "titleNView": false
262
+        },
263
+        "enablePullDownRefresh": true
264
+      }
265
+
266
+    }, {
267
+      "path": "pages/scannedDepartmentSpecimensDetail/scannedDepartmentSpecimensDetail",
268
+      "style": {
269
+        "h5": {
270
+          "titleNView": false
271
+        }
272
+      }
273
+    }, {
274
+      "path": "pages/specimenCheckingEndDetail/specimenCheckingEndDetail",
275
+      "style": {
276
+        "h5": {
277
+          "titleNView": false
278
+        }
279
+      }
280
+
249 281
     }
250 282
   ],
251 283
   "globalStyle": {

+ 8 - 4
pages/my_list/my_list.vue

@@ -112,8 +112,8 @@
112 112
               <text class="text1">完成时间</text>&nbsp;&nbsp;
113 113
               <text class="text1">{{ infoDATA.completeTime || '' }}</text>
114 114
             </view>
115
-            <view class="page_item_foot_text" @click.stop="goToDetail(infoDATA.id)">
116
-              <text class="text1">扫描接收数量</text>&nbsp;&nbsp;
115
+            <view class="page_item_foot_text" @click.stop="goToDetail(infoDATA)" v-if="infoDATA.taskType.associationType.value==='specimen' || infoDATA.taskType.associationType.value==='specimenPlan'">
116
+              <text class="text1">{{infoDATA.taskType.associationType.value==='specimen' ? '扫描接收数量' : '扫描送达数量'}}</text>&nbsp;&nbsp;
117 117
               <text class="text1 b">{{ infoDATA.actualReceiveNum || 0 }}</text>
118 118
             </view>
119 119
           </view>
@@ -173,9 +173,13 @@
173 173
       showModel,
174 174
     },
175 175
     methods: {
176
-      goToDetail(id){
176
+      goToDetail(order){
177
+        console.log(order)
178
+        let data = {
179
+          uuid: order.id,
180
+        }
177 181
         uni.navigateTo({
178
-          url: `../noScanSpecimen/noScanSpecimen?workOrderId=${encodeURIComponent(JSON.stringify([id]))}&isScan=1&specimensCheck=1&noScan=1`,
182
+          url: `../scannedDepartmentSpecimens/scannedDepartmentSpecimens?infoDATA=${encodeURIComponent(JSON.stringify(data))}`,
179 183
         });
180 184
       },
181 185
       //滚动距离

+ 46 - 33
pages/receiptpage/receiptpage.vue

@@ -83,8 +83,9 @@
83 83
               </view>
84 84
               <view class="page_item_conts" v-if="item.taskType.associationType.value == 'specimen'">
85 85
                 <view>扫描标本数量 : {{ item.actualReceiveNum || '无'}}</view>
86
+                <view class="line"></view>
86 87
               </view>
87
-              <view class="page_item_conts" v-if="item.taskType.associationType.value == 'inspect'">
88
+              <view class="page_item_conts" v-else-if="item.taskType.associationType.value == 'inspect'">
88 89
                 <view>
89 90
                   预约时间 : {{ item.yyTime | yyTimeFilter
90 91
                   }}<text v-if="item.reservationNumber">({{ item.reservationNumber }})</text>
@@ -121,8 +122,9 @@
121 122
                     item.isAccompany === 1 ? "需要医护陪同" : "无需医护陪同"
122 123
                   }}</text>
123 124
                 </view>
125
+                <view class="line"></view>
124 126
               </view>
125
-              <view class="page_item_conts" v-if="item.taskType.associationType.value == 'patientTransport'">
127
+              <view class="page_item_conts" v-else-if="item.taskType.associationType.value == 'patientTransport'">
126 128
                 <view>
127 129
                   预约时间 : {{ item.yyjdTime | yyTimeFilter
128 130
                   }}<text v-if="item.reservationNumber">({{ item.reservationNumber }})</text>
@@ -159,19 +161,24 @@
159 161
                     item.isAccompany === 1 ? "需要医护陪同" : "无需医护陪同"
160 162
                   }}</text>
161 163
                 </view>
164
+                <view class="line"></view>
162 165
               </view>
163
-              <view class="page_item_conts" v-if="item.taskType.associationType.value == 'drugsBag'">
166
+              <view class="page_item_conts" v-else-if="item.taskType.associationType.value == 'drugsBag'">
164 167
                 <view>
165 168
                   药包编码 : {{ item.drugs ? item.drugs.packid : "无" }}
166 169
                 </view>
170
+                <view class="line"></view>
167 171
               </view>
168
-              <view class="page_item_conts" v-if="item.taskType.associationType.value == 'jPBag'">
172
+              <view class="page_item_conts" v-else-if="item.taskType.associationType.value == 'jPBag'">
169 173
                 <view>
170 174
                   药包编码 :
171 175
                   {{ item.staticDistri ? item.staticDistri.packid : "无" }}
172 176
                 </view>
177
+                <view class="line"></view>
178
+              </view>
179
+              <view class="page_item_conts" v-else>
180
+                <view class="line"></view>
173 181
               </view>
174
-              <view class="line"></view>
175 182
               <view class="page_item_cont_B">
176 183
                 <view class="page_item_cont_title" v-if="item.taskType.associationType.value != 'inspect'">
177 184
                   <text> <text class="End">终</text> 点科室 </text>
@@ -182,21 +189,20 @@
182 189
                   <text class="text_big" v-for="(dept, i) of item.middleDept" :key="i">{{ dept.dept }}</text>
183 190
                 </view>
184 191
               </view>
185
-              <view v-if="
186
-                  item.taskType.associationType.value == 'inspect' ||
187
-                  item.taskType.associationType.value == 'patientTransport'
188
-                ">
189
-                <!-- 待抢单 -->
190
-                <text class="red" v-if="item.gdState.value == 2">请扫描患者腕带,或者请扫描科室码</text>
191
-                <!-- 待到达 -->
192
-                <text class="red" v-if="item.gdState.value == 4">请扫描患者腕带</text>
193
-                <!-- 执行中 -->
194
-                <text class="red" v-if="item.gdState.value == 8">请扫描检查科室码,并扫描患者腕带</text>
195
-                <!-- 待送达 -->
196
-                <text class="red" v-if="item.gdState.value == 5">请扫描终点科室码,并扫描患者腕带</text>
197
-              </view>
198 192
             </view>
199
-
193
+            <view v-if="
194
+                item.taskType.associationType.value == 'inspect' ||
195
+                item.taskType.associationType.value == 'patientTransport'
196
+              ">
197
+              <!-- 待抢单 -->
198
+              <text class="red" v-if="item.gdState.value == 2">请扫描患者腕带,或者请扫描科室码</text>
199
+              <!-- 待到达 -->
200
+              <text class="red" v-if="item.gdState.value == 4">请扫描患者腕带</text>
201
+              <!-- 执行中 -->
202
+              <text class="red" v-if="item.gdState.value == 8">请扫描检查科室码,并扫描患者腕带</text>
203
+              <!-- 待送达 -->
204
+              <text class="red" v-if="item.gdState.value == 5">请扫描终点科室码,并扫描患者腕带</text>
205
+            </view>
200 206
             <!-- 如果不是患者陪检或患者转运或其他 -->
201 207
             <view class="page_item_btn" v-if="
202 208
                 selectedLabelSlots == '执行中' &&
@@ -1119,6 +1125,9 @@
1119 1125
               padding: 0 16rpx;
1120 1126
               text-align: left;
1121 1127
               position: relative;
1128
+              display: flex;
1129
+              flex-direction: column;
1130
+              justify-content: space-between;
1122 1131
 
1123 1132
               .text_big {
1124 1133
                 font-size: 32rpx;
@@ -1127,12 +1136,14 @@
1127 1136
               }
1128 1137
 
1129 1138
               .line {
1130
-                height: 40rpx;
1139
+                height: 100%;
1131 1140
                 width: 2rpx;
1132 1141
                 border-left: 2rpx solid #e5e9ed;
1133 1142
                 position: absolute;
1134
-                top: 70rpx;
1135
-                left: 36rpx;
1143
+                // top: 70rpx;
1144
+                top: 50%;
1145
+                left: 20rpx;
1146
+                transform: translateY(-50%);
1136 1147
               }
1137 1148
 
1138 1149
               .lines {
@@ -1158,19 +1169,21 @@
1158 1169
               }
1159 1170
 
1160 1171
               .page_item_cont_T {
1161
-                min-height: 80rpx;
1162
-                max-height: 324rpx;
1172
+                // min-height: 80rpx;
1173
+                // max-height: 324rpx;
1163 1174
                 font-size: 28rpx;
1164 1175
                 margin-top: 16rpx;
1176
+                display: flex;
1177
+                justify-content: space-between;
1165 1178
 
1166 1179
                 .page_item_cont_title {
1167 1180
                   height: 100%;
1168
-                  float: left;
1181
+                  // float: left;
1169 1182
                 }
1170 1183
 
1171 1184
                 .page_item_cont_start {
1172 1185
                   text-align: center;
1173
-                  float: right;
1186
+                  // float: right;
1174 1187
                   height: 44rpx;
1175 1188
                   width: 104rpx;
1176 1189
                   line-height: 44rpx;
@@ -1188,27 +1201,27 @@
1188 1201
               }
1189 1202
 
1190 1203
               .page_item_conts {
1204
+                min-height: 30rpx;
1191 1205
                 color: rgb(102, 102, 102);
1192 1206
                 padding-left: 50rpx;
1193 1207
                 font-size: 28rpx;
1208
+                margin: 16rpx 0;
1209
+                position: relative;
1194 1210
 
1195
-                view {
1196
-                  margin-bottom: 10rpx;
1211
+                view:not(.line) {
1212
+                  line-height: 1.2;
1197 1213
                 }
1198 1214
 
1199 1215
                 text {
1200 1216
                   color: #49b856;
1201 1217
                 }
1202
-
1203
-                .num {
1204
-                  float: right;
1205
-                }
1206 1218
               }
1207 1219
 
1208 1220
               .page_item_cont_B {
1209 1221
                 // padding-top: 20rpx;
1210 1222
                 font-size: 28rpx;
1211
-                overflow: hidden;
1223
+                // overflow: hidden;
1224
+                margin-bottom: 16rpx;
1212 1225
 
1213 1226
                 .page_item_cont_title {
1214 1227
                   height: 100%;

+ 368 - 0
pages/scannedDepartmentSpecimens/scannedDepartmentSpecimens.vue

@@ -0,0 +1,368 @@
1
+<template>
2
+  <view class="specimenChecking">
3
+    <view class="page_item_wrap" v-for="item in list" :key="item.deptId" @click="gotoDetail(item)">
4
+      <view class="page_item">
5
+        <view class="page_item_top">
6
+          <view class="page_item_top-inner">
7
+            <view class="page_item_top_L">
8
+              <view class="L_text">{{item.deptName}}</view>
9
+            </view>
10
+            <view class="page_item_top_R">
11
+              <view class="L_iocn">{{item.count}}</view>
12
+            </view>
13
+          </view>
14
+        </view>
15
+      </view>
16
+    </view>
17
+    <view class="foot_btn2">
18
+      <view class="btn2" @click="goBack()">返回</view>
19
+    </view>
20
+  </view>
21
+</template>
22
+<script>
23
+  import {
24
+    get,
25
+    post,
26
+    webHandle
27
+  } from "../../http/http.js";
28
+  export default {
29
+    data() {
30
+      return {
31
+        list: [],
32
+        msg: {}, //页面展示信息
33
+      };
34
+    },
35
+    methods: {
36
+      // 返回
37
+      goBack() {
38
+        uni.navigateBack();
39
+      },
40
+      // 获取列表
41
+      getList() {
42
+        uni.showLoading({
43
+          mask: true,
44
+          title: '加载中'
45
+        })
46
+        let postData = {
47
+          gdId: this.msg.uuid
48
+        };
49
+        post(`/api/receiveSpecimensDeptNum`, postData).then((res) => {
50
+          uni.hideLoading();
51
+          uni.stopPullDownRefresh();
52
+          if (res.status == 200) {
53
+            this.list = res.data;
54
+          } else {
55
+            uni.showToast({
56
+              icon: "none",
57
+              title: "请求失败!",
58
+            });
59
+          }
60
+        });
61
+      },
62
+      // 跳转到详情页
63
+      gotoDetail(item) {
64
+        console.log(item);
65
+        uni.navigateTo({
66
+          url: `../scannedDepartmentSpecimensDetail/scannedDepartmentSpecimensDetail?workOrderId=${this.msg.uuid}&endDeptId=${item.deptId}`,
67
+        });
68
+      },
69
+    },
70
+    onLoad(options) {
71
+      console.log(options);
72
+      this.msg = JSON.parse(options.infoDATA);
73
+      this.getList();
74
+      // #ifdef APP-PLUS
75
+      webHandle("no", "app");
76
+      // #endif
77
+      // #ifdef H5
78
+      webHandle("no", "wx");
79
+      // #endif
80
+    },
81
+    onPullDownRefresh() {
82
+      this.getList();
83
+    },
84
+  };
85
+</script>
86
+<style lang="less" scoped>
87
+  .specimenChecking {
88
+    padding-bottom: 100rpx;
89
+
90
+    .title {
91
+      font-size: 48rpx;
92
+      margin-top: 24rpx;
93
+      margin-bottom: 24rpx;
94
+      text-align: center;
95
+    }
96
+
97
+    .page_item_wrap {
98
+      width: 100%;
99
+      height: auto;
100
+      box-sizing: border-box;
101
+      position: relative;
102
+      margin-bottom: 16rpx;
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
+        .starting {
139
+          width: 50rpx;
140
+          height: 50rpx;
141
+          color: #fff;
142
+          background: #49b856;
143
+          display: inline-block;
144
+          border-radius: 50%;
145
+          text-align: center;
146
+          line-height: 46rpx;
147
+          font-size: 32rpx;
148
+          margin-right: 6rpx;
149
+        }
150
+
151
+        .End {
152
+          width: 50rpx;
153
+          height: 50rpx;
154
+          color: #fff;
155
+          background: #39b199;
156
+          display: inline-block;
157
+          border-radius: 50%;
158
+          text-align: center;
159
+          line-height: 46rpx;
160
+          font-size: 32rpx;
161
+          margin-right: 6rpx;
162
+        }
163
+
164
+        .page_item_top {
165
+          height: 88rpx;
166
+          // border-bottom: 2rpx dashed #e5e9ed;
167
+          padding: 0 16rpx;
168
+
169
+          .page_item_top-inner {
170
+            display: flex;
171
+            justify-content: space-between;
172
+            align-items: center;
173
+            height: 100%;
174
+
175
+            .page_item_top_L {
176
+              .emergencys {
177
+                background: #ff3b53 !important;
178
+                width: 124rpx !important;
179
+              }
180
+
181
+              .emergency {
182
+                background: #ff3b53 !important;
183
+              }
184
+
185
+              .emergency1 {
186
+                background: #49b856 !important;
187
+              }
188
+
189
+              .page_item_cont_start {
190
+                text-align: center;
191
+                height: 44rpx;
192
+                width: 104rpx;
193
+                line-height: 44rpx;
194
+                border-radius: 8rpx;
195
+                background: #49b856;
196
+                color: #fff;
197
+                display: inline-block;
198
+              }
199
+
200
+              .L_time {
201
+                color: #6cc076;
202
+                font-size: 32rpx;
203
+              }
204
+
205
+              .L_text {
206
+                font-size: 32rpx;
207
+                font-weight: 700;
208
+              }
209
+            }
210
+
211
+            .page_item_top_R {
212
+              font-size: 32rpx;
213
+
214
+              .L_iocn {
215
+                color: rgb(7, 134, 60);
216
+                font-size: 36rpx;
217
+                font-weight: 700;
218
+              }
219
+            }
220
+          }
221
+        }
222
+
223
+        .page_item_cont {
224
+          min-height: 90rpx;
225
+          padding: 0 16rpx;
226
+          text-align: left;
227
+          position: relative;
228
+
229
+          .text_big {
230
+            font-size: 32rpx;
231
+            font-weight: 700;
232
+            margin-top: 10rpx;
233
+
234
+            p {
235
+              font-weight: 700;
236
+              line-height: 1.5;
237
+            }
238
+          }
239
+
240
+          .page_item_cont_T {
241
+            padding-top: 28rpx;
242
+            font-size: 28rpx;
243
+
244
+            .page_item_cont_title {
245
+              height: 100%;
246
+              font-size: 32rpx;
247
+              display: flex;
248
+              justify-content: space-between;
249
+            }
250
+          }
251
+
252
+          .page_item_cont_B {
253
+            padding-top: 28rpx;
254
+            margin-bottom: 28rpx;
255
+
256
+            .page_item_cont_title {
257
+              font-size: 32rpx;
258
+              display: flex;
259
+              justify-content: space-between;
260
+            }
261
+
262
+            .page_item_cont_title1 {
263
+              height: 60rpx;
264
+              line-height: 60rpx;
265
+              font-size: 32rpx;
266
+              padding-left: 64rpx;
267
+            }
268
+          }
269
+        }
270
+
271
+        .page_item_foot {
272
+          border-top: 2rpx dashed #e5e9ed;
273
+          border-bottom: 2rpx dashed #e5e9ed;
274
+          padding: 28rpx 16rpx;
275
+          text-align: left;
276
+
277
+          .page_item_foot_text {
278
+            font-size: 32rpx;
279
+            margin-bottom: 20rpx;
280
+
281
+            .text1 {
282
+              color: rgb(102, 102, 102);
283
+            }
284
+
285
+            .text2 {
286
+              float: right;
287
+              font-weight: 700;
288
+            }
289
+          }
290
+        }
291
+
292
+        #infos {
293
+          display: none;
294
+        }
295
+
296
+        .page_item_infos {
297
+          padding-bottom: 20rpx;
298
+          border-bottom: 2rpx dashed #e5e9ed;
299
+
300
+          .page_item_info2 {
301
+            text-align: left;
302
+            line-height: 60rpx;
303
+            font-size: 32rpx;
304
+            padding-left: 16rpx;
305
+
306
+            .page_item_foot_text {
307
+              font-size: 32rpx;
308
+              margin-bottom: 20rpx;
309
+
310
+              .text1 {
311
+                color: rgb(102, 102, 102);
312
+              }
313
+
314
+              .text2 {
315
+                float: right;
316
+                font-weight: 700;
317
+              }
318
+            }
319
+          }
320
+        }
321
+      }
322
+
323
+      .L-l {
324
+        width: 2rpx;
325
+        height: 40rpx;
326
+        background: #f9fafb;
327
+        position: absolute;
328
+        left: 20rpx;
329
+        top: 72rpx;
330
+      }
331
+
332
+      .R-l {
333
+        width: 2rpx;
334
+        height: 40rpx;
335
+        background: #f9fafb;
336
+        position: absolute;
337
+        right: 20rpx;
338
+        top: 72rpx;
339
+      }
340
+    }
341
+
342
+    .foot_btn2 {
343
+      position: fixed;
344
+      bottom: 0;
345
+      width: 100vw;
346
+      padding: 0 20rpx;
347
+      box-sizing: border-box;
348
+      line-height: 66rpx;
349
+      height: 100rpx;
350
+      border-top: 2rpx solid #e5e9ed;
351
+      background: #f9fafb;
352
+      text-align: center;
353
+      display: flex;
354
+      justify-content: center;
355
+      align-items: center;
356
+
357
+      .btn2 {
358
+        height: 66rpx;
359
+        flex: 1;
360
+        margin: 16rpx 16rpx 0;
361
+        background-image: linear-gradient(to right, #72c172, #3bb197);
362
+        color: #fff;
363
+        border-radius: 8rpx;
364
+        font-size: 32rpx;
365
+      }
366
+    }
367
+  }
368
+</style>

+ 426 - 0
pages/scannedDepartmentSpecimensDetail/scannedDepartmentSpecimensDetail.vue

@@ -0,0 +1,426 @@
1
+<template>
2
+  <view class="pharmacyDetails">
3
+    <view class="page_item footerOtherMargin">
4
+      <view class="page_header" v-for="(item, index) in resultList" :key="item.bindId">
5
+        <view class="page_header_item" v-if="item.modifyReason">
6
+          <view class="page_header_title"> 修改原因: </view>
7
+          <view class="page_header_content">
8
+            {{ item.modifyReason }}
9
+          </view>
10
+        </view>
11
+        <view class="page_header_item" v-if="item.imgs && item.imgs.length">
12
+          <view class="page_header_title"> 图片列表: </view>
13
+          <view class="page_header_content">
14
+            <image v-for="(item, i) in item.imgs" :key="i" :src="item" @click="previewImage(index, i)" mode="widthFix"
15
+              @error="close(index, i)"></image>
16
+          </view>
17
+        </view>
18
+      </view>
19
+      <view class="page_item_wrap" v-for="spe in specimens" :key="spe.id">
20
+        <view class="page_item">
21
+          <view class="page_item_top">
22
+            <view class="page_item_top-inner">
23
+              <view class="page_item_top_L">
24
+                <view class="L_text">{{ spe.scode }}<text v-if="spe.stype">({{spe.stype.name}})</text></view>
25
+              </view>
26
+              <view class="page_item_top_R">
27
+                <text :style="{color:spe.urgent == 1?'red':'green'}">{{spe.urgent == 1 ? "急" : "普"}}</text>
28
+              </view>
29
+            </view>
30
+          </view>
31
+          <view class="page_item_cont">
32
+            <view class="page_item_cont_T">
33
+              <view class="page_item_cont_title">
34
+                <view> 检验项目 </view>
35
+                <view class="text_big">{{ spe.specimenDesc || "无" }}</view>
36
+              </view>
37
+              <view class="page_item_cont_title">
38
+                <view> 患者姓名 </view>
39
+                <view class="text_big">{{ spe.patientName }}<text v-if="spe.bedNum">({{spe.bedNum}})</text></view>
40
+              </view>
41
+              <view class="page_item_cont_title">
42
+                <view> 住院号 </view>
43
+                <view class="text_big">{{spe.residenceNo||'无'}}</text></view>
44
+              </view>
45
+              <view class="page_item_cont_title">
46
+                <view class="text_big">{{
47
+                  spe.sickRoom ? spe.sickRoom.dept : "无"
48
+                }}</view>
49
+                <text style="width: 4em;text-align: center;" class="icon_transport transport-arrow-right-full"></text>
50
+                <view class="text_big">{{
51
+                  spe.checkDept ? spe.checkDept.dept : "无"
52
+                }}</view>
53
+              </view>
54
+            </view>
55
+          </view>
56
+          <view class="L"></view>
57
+          <view class="R"></view>
58
+        </view>
59
+        <view class="L-l"></view>
60
+        <view class="R-l"></view>
61
+      </view>
62
+    </view>
63
+    <view class="foot_btn2 footerPadding">
64
+      <view class="btn2" @click="goBack">返回</view>
65
+    </view>
66
+  </view>
67
+</template>
68
+<script>
69
+  import {
70
+    post,
71
+    get,
72
+    webHandle
73
+  } from "../../http/http.js";
74
+  export default {
75
+    data() {
76
+      return {
77
+        resultList: [],
78
+        imgs: [],
79
+        queryObj: {}, //路由传递过来的数据
80
+        specimens: [],
81
+        modifyReason: '',
82
+      };
83
+    },
84
+    methods: {
85
+      previewImage(index, i) {
86
+        //uniapp预览轮播图
87
+        uni.previewImage({
88
+          current: i, //预览图片的下标
89
+          urls: this.resultList[index].imgs, //预览图片的地址,必须要数组形式,如果不是数组形式就转换成数组形式就可以
90
+        });
91
+      },
92
+      close(index, i) {
93
+        this.resultList[index].imgs.splice(i, 1);
94
+      },
95
+      getInfo() {
96
+        let postData = {
97
+          deptId: this.queryObj.endDeptId,
98
+          gdId: this.queryObj.workOrderId,
99
+        };
100
+        post(`/api/getStartDeptSpecimensNum`, postData).then((res) => {
101
+          if (res.status == 200) {
102
+            for (let i = 0; i < res.data.length; i++) {
103
+              get(
104
+                `/common/common/listAttachment/specimenPhotos/${res.data[i].bindId}`
105
+              ).then((result) => {
106
+                if (result.status == 200) {
107
+                  res.data[i].imgs = result.data.map((v) => v.previewUrl);
108
+                } else {
109
+                  res.data[i].imgs = [];
110
+                }
111
+                this.resultList = res.data;
112
+              });
113
+            }
114
+          }
115
+        });
116
+      },
117
+      // 返回
118
+      goBack() {
119
+        uni.navigateBack();
120
+      },
121
+      // 获取标本信息
122
+      getDetail() {
123
+        let postData = {
124
+          gdId: this.queryObj.workOrderId,
125
+          endDeptId: this.queryObj.endDeptId,
126
+        };
127
+        
128
+        uni.showLoading({
129
+          title: "加载中",
130
+          mask: true,
131
+        });
132
+        post("/api/endDeptReceiveSpecimens", postData).then((res) => {
133
+          uni.hideLoading();
134
+          if (res.status == 200) {
135
+            this.specimens = res.data;
136
+          } else {
137
+            uni.showToast({
138
+              icon: "none",
139
+              title: "请求失败!",
140
+            });
141
+          }
142
+        });
143
+      },
144
+    },
145
+    onLoad(options) {
146
+      console.log(options);
147
+      this.queryObj = options;
148
+      this.getDetail();
149
+      this.getInfo();
150
+      // #ifdef APP-PLUS
151
+      webHandle("no", "app");
152
+      // #endif
153
+      // #ifdef H5
154
+      webHandle("no", "wx");
155
+      // #endif
156
+    },
157
+  };
158
+</script>
159
+<style lang="less" scoped>
160
+  .pharmacyDetails {
161
+    background-color: rgb(249, 250, 251);
162
+    padding-top: 50rpx;
163
+    height: 100%;
164
+    box-sizing: border-box;
165
+    
166
+    .page_header {
167
+      margin: 20rpx;
168
+      padding: 16rpx;
169
+      border: 2rpx solid #e5e9ed;
170
+      background: #fff;
171
+      border-radius: 8rpx;
172
+    
173
+      .page_header_item {
174
+        margin-bottom: 16rpx;
175
+    
176
+        .page_header_title {
177
+          margin-bottom: 8rpx;
178
+          font-weight: bold;
179
+        }
180
+    
181
+        .page_header_content {
182
+          display: flex;
183
+    
184
+          image {
185
+            height: 100rpx;
186
+            width: 30%;
187
+            margin: 0 8rpx;
188
+          }
189
+        }
190
+      }
191
+    }
192
+
193
+    .pharmacyDetails_title {
194
+      font-size: 46rpx;
195
+      font-weight: 550;
196
+      text-align: center;
197
+    }
198
+
199
+    .page_item_wrap {
200
+      position: relative;
201
+      margin-top: 32rpx;
202
+
203
+      .page_item {
204
+        margin-top: 16rpx;
205
+        margin-bottom: 124rpx;
206
+        background: #fff;
207
+        border-radius: 8rpx;
208
+        margin: 0 20rpx;
209
+        border: 2rpx solid #e5e9ed;
210
+        position: relative;
211
+        overflow: hidden;
212
+        padding: 0 16rpx;
213
+
214
+        .L {
215
+          width: 40rpx;
216
+          height: 40rpx;
217
+          border-radius: 50%;
218
+          background: #f9fafb;
219
+          position: absolute;
220
+          left: -20rpx;
221
+          top: 68rpx;
222
+          border: 2rpx solid #e5e9ed;
223
+        }
224
+
225
+        .R {
226
+          width: 40rpx;
227
+          height: 40rpx;
228
+          border-radius: 50%;
229
+          background: #f9fafb;
230
+          position: absolute;
231
+          float: right;
232
+          right: -20rpx;
233
+          top: 68rpx;
234
+          border: 2rpx solid #e5e9ed;
235
+        }
236
+
237
+        .page_item_top {
238
+          height: 88rpx;
239
+          border-bottom: 2rpx dashed #e5e9ed;
240
+          padding: 0 16rpx;
241
+
242
+          .page_item_top-inner {
243
+            display: flex;
244
+            justify-content: space-between;
245
+            align-items: center;
246
+            height: 100%;
247
+
248
+            .page_item_top_L {
249
+              .L_text {
250
+                font-size: 32rpx;
251
+                font-weight: 700;
252
+              }
253
+            }
254
+
255
+            .page_item_top_R {
256
+              font-size: 32rpx;
257
+
258
+              .L_iocn {
259
+                color: rgb(7, 134, 60);
260
+                font-size: 36rpx;
261
+                font-weight: 700;
262
+              }
263
+            }
264
+          }
265
+        }
266
+
267
+        .page_item_cont {
268
+          min-height: 90rpx;
269
+          padding: 0 16rpx;
270
+          text-align: left;
271
+          position: relative;
272
+
273
+          .text_big {
274
+            font-size: 32rpx;
275
+            font-weight: 700;
276
+            margin-top: 10rpx;
277
+          
278
+            p {
279
+              font-weight: 700;
280
+              line-height: 1.5;
281
+            }
282
+          }
283
+
284
+          .line {
285
+            height: 20rpx;
286
+            width: 2rpx;
287
+            border-left: 2rpx solid #e5e9ed;
288
+            position: absolute;
289
+            top: 82rpx;
290
+            left: 40rpx;
291
+          }
292
+
293
+          .page_item_cont_T {
294
+            padding-top: 28rpx;
295
+            padding-bottom: 28rpx;
296
+            font-size: 28rpx;
297
+
298
+            .page_item_cont_title {
299
+              height: 100%;
300
+              font-size: 32rpx;
301
+              display: flex;
302
+              justify-content: space-between;
303
+              align-items: center;
304
+            }
305
+          }
306
+
307
+          .page_item_cont_B {
308
+            padding-top: 28rpx;
309
+            margin-bottom: 28rpx;
310
+
311
+            .page_item_cont_title {
312
+              font-size: 32rpx;
313
+              display: flex;
314
+              justify-content: space-between;
315
+              align-items: center;
316
+            }
317
+          }
318
+
319
+          .page_item_cont_C {
320
+            margin-bottom: 28rpx;
321
+
322
+            .page_item_cont_title_C {
323
+              font-size: 32rpx;
324
+              display: flex;
325
+              justify-content: space-between;
326
+              align-items: center;
327
+            }
328
+          }
329
+
330
+          #infos {
331
+            display: none;
332
+          }
333
+        }
334
+      }
335
+
336
+      .L-l {
337
+        width: 2rpx;
338
+        height: 40rpx;
339
+        background: #f9fafb;
340
+        position: absolute;
341
+        left: 20rpx;
342
+        top: 72rpx;
343
+      }
344
+
345
+      .R-l {
346
+        width: 2rpx;
347
+        height: 40rpx;
348
+        background: #f9fafb;
349
+        position: absolute;
350
+        right: 20rpx;
351
+        top: 72rpx;
352
+      }
353
+    }
354
+
355
+    .cube-toolbar-item {
356
+      width: 710rpx;
357
+      height: 68rpx;
358
+      line-height: 68rpx;
359
+      position: fixed;
360
+      left: 20rpx;
361
+      bottom: 160rpx;
362
+      border-radius: 8rpx;
363
+      background: linear-gradient(to right, #72c172, #3bb197);
364
+      font-size: 36rpx;
365
+      color: #fff;
366
+      text-align: center;
367
+    }
368
+
369
+    .btn-wrap {
370
+      display: flex;
371
+      justify-content: space-between;
372
+      position: fixed;
373
+      left: 20rpx;
374
+      bottom: 160rpx;
375
+    }
376
+
377
+    .cube-toolbar-item1 {
378
+      width: 350rpx;
379
+      height: 68rpx;
380
+      line-height: 68rpx;
381
+      border-radius: 8rpx;
382
+      margin: 0 5rpx;
383
+      background: linear-gradient(to right, #72c172, #3bb197);
384
+      font-size: 36rpx;
385
+      color: #fff;
386
+      text-align: center;
387
+    }
388
+
389
+    .foot_btn2 {
390
+      position: fixed;
391
+      bottom: 0;
392
+      right: 20rpx;
393
+      left: 20rpx;
394
+      line-height: 66rpx;
395
+      height: 100rpx;
396
+      border-top: 2rpx solid #e5e9ed;
397
+      background: #f9fafb;
398
+      display: flex;
399
+      justify-content: space-between;
400
+
401
+      .btn2 {
402
+        height: 66rpx;
403
+        width: 100%;
404
+        margin: 0 1%;
405
+        background-image: linear-gradient(to right, #72c172, #3bb197);
406
+        color: #fff;
407
+        border-radius: 8rpx;
408
+        font-size: 32rpx;
409
+        margin-top: 16rpx;
410
+        text-align: center;
411
+      }
412
+
413
+      .btn3 {
414
+        height: 66rpx;
415
+        width: 48%;
416
+        margin: 0 1%;
417
+        background-image: linear-gradient(to right, #72c172, #3bb197);
418
+        color: #fff;
419
+        border-radius: 8rpx;
420
+        font-size: 32rpx;
421
+        margin-top: 16rpx;
422
+        text-align: center;
423
+      }
424
+    }
425
+  }
426
+</style>

+ 8 - 8
pages/scanning/scanning.vue

@@ -43,12 +43,12 @@
43 43
               <td>数量</td>
44 44
               <td>状态</td>
45 45
             </tr>
46
-            <tr v-for="spe in infoList" :key="spe[0]">
47
-              <td class="maxWidth">{{spe[1]}}</td>
48
-              <td>{{spe[2]}}</td>
46
+            <tr v-for="spe in infoList" :key="spe.deptId">
47
+              <td class="maxWidth">{{spe.deptName}}</td>
48
+              <td>{{spe.speNum}}</td>
49 49
               <td>
50
-                <text v-if="spe[3] === 'ysd'" class="green">已到达</text>
51
-                <text v-if="spe[3] === 'wsd'" class="red">未到达</text>
50
+                <text v-if="spe.deptState=== 'ysd'" class="green">已到达</text>
51
+                <text v-if="spe.deptState=== 'wsd'" class="red">未到达</text>
52 52
               </td>
53 53
             </tr>
54 54
           </table>
@@ -116,8 +116,6 @@
116 116
           mask: true,
117 117
         });
118 118
         let postData = {
119
-          startDept: this.queryObj.startDeptId,
120
-          targetDept: this.queryObj.targetDeptId,
121 119
           uuid: this.dataId[0]
122 120
         };
123 121
         post(`/api/getDeptSpecimensNum`, postData).then((res) => {
@@ -258,7 +256,9 @@
258 256
       if (options.speNum) {
259 257
         this.speNum = options.speNum;
260 258
       }
261
-      this.getInfo();
259
+      if(this.queryObj.type === 'specimenPlan'){
260
+        this.getInfo();
261
+      }
262 262
       // #ifdef APP-PLUS
263 263
       webHandle("no", "app");
264 264
       // #endif

+ 8 - 1
pages/scanning_Result/scanning_Result.vue

@@ -690,8 +690,15 @@
690 690
       },
691 691
       // 跳转完成工单页面
692 692
       gotoOver() {
693
+        // uni.navigateTo({
694
+        //   url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
695
+        //     this.queryObj.type1
696
+        //   }&id=${encodeURIComponent(JSON.stringify([this.wcId]))}&deptCode=${
697
+        //     this.queryObj.deptCode
698
+        //   }&dept=${this.queryObj.dept}&speNum=${this.speNum}&content=${this.content}`,
699
+        // });
693 700
         uni.navigateTo({
694
-          url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
701
+          url: `../specimenCheckingEnd/specimenCheckingEnd?type=${this.queryObj.type}&type1=${
695 702
             this.queryObj.type1
696 703
           }&id=${encodeURIComponent(JSON.stringify([this.wcId]))}&deptCode=${
697 704
             this.queryObj.deptCode

+ 6 - 6
pages/scanning_code/scanning_code.vue

@@ -482,7 +482,7 @@
482 482
                       res.type1
483 483
                     }&id=${encodeURIComponent(
484 484
                       JSON.stringify([res.gdid])
485
-                    )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
485
+                    )}&content=${content}`,
486 486
                     });
487 487
                   }
488 488
                 }
@@ -511,7 +511,7 @@
511 511
                         res.type1
512 512
                       }&id=${encodeURIComponent(
513 513
                         JSON.stringify([res.gdid])
514
-                      )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
514
+                      )}&content=${content}`,
515 515
                       });
516 516
                     }
517 517
                   }
@@ -576,7 +576,7 @@
576 576
                                 res.type1
577 577
                               }&id=${encodeURIComponent(
578 578
                                 JSON.stringify([res.gdid])
579
-                              )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
579
+                              )}&content=${content}`,
580 580
                               });
581 581
                             }
582 582
                           }
@@ -605,7 +605,7 @@
605 605
                                   res.type1
606 606
                                 }&id=${encodeURIComponent(
607 607
                                   JSON.stringify([res.gdid])
608
-                                )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
608
+                                )}&content=${content}`,
609 609
                                 });
610 610
                               }
611 611
                             }
@@ -662,8 +662,8 @@
662 662
         post(`/api/getStartDeptSpecimensNum`, postData).then((res) => {
663 663
           uni.hideLoading();
664 664
           if (res.status == 200) {
665
-            this.speNumChange = res.deptSpecimensNum;
666
-            this.modifyReason = res.modifyReason;
665
+            this.speNumChange = res.data[0].deptSpecimensNum;
666
+            this.modifyReason = res.data[0].modifyReason;
667 667
             this.changeSpeModels = {
668 668
               title: "修改标本数量",
669 669
               content: `您已到达<span class="red">${this.DEPT}</span>本科室标本数量为<span class="red">${this.speNumChange}</span>,请确认标本数量`,

+ 16 - 7
pages/scanning_djEnd/scanning_djEnd.vue

@@ -319,7 +319,7 @@
319 319
                       res.type1
320 320
                     }&id=${encodeURIComponent(
321 321
                       JSON.stringify([res.gdid])
322
-                    )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
322
+                    )}&content=${content}`,
323 323
                     });
324 324
                   }
325 325
                 }
@@ -348,7 +348,7 @@
348 348
                         res.type1
349 349
                       }&id=${encodeURIComponent(
350 350
                         JSON.stringify([res.gdid])
351
-                      )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
351
+                      )}&content=${content}`,
352 352
                       });
353 353
                     }
354 354
                   }
@@ -420,7 +420,7 @@
420 420
                                       res.type1
421 421
                                     }&id=${encodeURIComponent(
422 422
                                       JSON.stringify([res.gdid])
423
-                                    )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
423
+                                    )}&content=${content}`,
424 424
                                     });
425 425
                                   }
426 426
                                 }
@@ -449,7 +449,7 @@
449 449
                                         res.type1
450 450
                                       }&id=${encodeURIComponent(
451 451
                                         JSON.stringify([res.gdid])
452
-                                      )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
452
+                                      )}&content=${content}`,
453 453
                                       });
454 454
                                     }
455 455
                                   }
@@ -511,8 +511,8 @@
511 511
         post(`/api/getStartDeptSpecimensNum`, postData).then((res) => {
512 512
           uni.hideLoading();
513 513
           if (res.status == 200) {
514
-            this.speNumChange = res.deptSpecimensNum;
515
-            this.modifyReason = res.modifyReason;
514
+            this.speNumChange = res.data[0].deptSpecimensNum;
515
+            this.modifyReason = res.data[0].modifyReason;
516 516
             this.changeSpeModels = {
517 517
               title: "修改标本数量",
518 518
               content: `您已到达<span class="red">${this.queryObj.dept}</span>本科室标本数量为<span class="red">${this.speNumChange}</span>,请确认标本数量`,
@@ -960,8 +960,17 @@
960 960
       },
961 961
       // 跳转完成工单页面
962 962
       gotoOver() {
963
+        // uni.navigateTo({
964
+        //   url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
965
+        //   this.queryObj.type1
966
+        // }&deptCode=${this.queryObj.code}&dept=${
967
+        //   this.queryObj.dept
968
+        // }&id=${encodeURIComponent(JSON.stringify(this.wcId))}&content=${
969
+        //   this.content
970
+        // }`,
971
+        // });
963 972
         uni.navigateTo({
964
-          url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
973
+          url: `../specimenCheckingEnd/specimenCheckingEnd?type=${this.queryObj.type}&type1=${
965 974
           this.queryObj.type1
966 975
         }&deptCode=${this.queryObj.code}&dept=${
967 976
           this.queryObj.dept

+ 28 - 4
pages/scanning_djInfo/scanning_djInfo.vue

@@ -2,7 +2,10 @@
2 2
   <view class="Scanning_djInfo">
3 3
     <view class="Scanning_top" v-if="res.status == 200">
4 4
       <view class="Scanning_top_icon">
5
-        <text class="cubeic-ok icon_transport transport-duigou"></text>
5
+        <view v-if="type == 'specimenPlan' || type == 'specimen'">
6
+          <view class="fweight speNum" style="color: red;"> {{ speNum }} </view>
7
+        </view>
8
+        <text v-else class="cubeic-ok icon_transport transport-duigou"></text>
6 9
       </view>
7 10
       <view class="Scanning_top_text">
8 11
         <view class="text1">操作成功</view>
@@ -34,7 +37,16 @@
34 37
         (res.status == 200 && type == 'specimenPlan') ||
35 38
         (res.status == 200 && type == 'specimen')
36 39
       ">
37
-      <view>标本类型 : {{ infoDATA.data.stype.name || "-" }}</view>
40
+      <view>{{ infoDATA.data.stype.name }}({{infoDATA.data.scode}})</view>
41
+      <view>检验项目 : {{ infoDATA.data.specimenDesc || "-" }}</view>
42
+      <view>
43
+        {{ infoDATA.data.sickRoom ? infoDATA.data.sickRoom.dept : "" }}
44
+        <text style="width: 4em;text-align: center;margin-left: 1em;margin-right: 1em;" class="icon_transport transport-arrow-right-full"></text>
45
+        {{ infoDATA.data.checkDept ? infoDATA.data.checkDept.dept : "" }}
46
+      </view>
47
+      <view>患者姓名 : {{ infoDATA.data.patientName}}({{infoDATA.data.bedNum}})</view>
48
+      <view>住院号 : {{ infoDATA.data.residenceNo || '-' }}</view>
49
+      <!-- <view>标本类型 : {{ infoDATA.data.stype.name || "-" }}</view>
38 50
       <view>标本编号 : {{ infoDATA.data.scode || "-" }}</view>
39 51
       <view>检验科室 : {{ infoDATA.data.checkDept ? infoDATA.data.checkDept.dept : "-" }}</view>
40 52
       <view>检验项目 : {{ infoDATA.data.specimenDesc || "-" }}</view>
@@ -50,7 +62,7 @@
50 62
         ">
51 63
         交接人姓名 : {{ accountObj.accountName }}
52 64
       </view>
53
-      <view>已扫描 : {{ speNum }}</view>
65
+      <view>已扫描 : {{ speNum }}</view> -->
54 66
     </view>
55 67
     <view class="Scanning_cont" v-if="
56 68
         (res.status == 200 && type == 'inspect') || type == 'patientTransport'
@@ -607,8 +619,15 @@
607 619
       },
608 620
       // 跳转完成工单页面
609 621
       gotoOver() {
622
+        // uni.navigateTo({
623
+        //   url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
624
+        //   this.queryObj.type1
625
+        // }&id=${encodeURIComponent(JSON.stringify(this.wcId))}&deptCode=${
626
+        //   this.queryObj.deptCode
627
+        // }&dept=${this.queryObj.dept}&content=${this.content}`,
628
+        // });
610 629
         uni.navigateTo({
611
-          url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
630
+          url: `../specimenCheckingEnd/specimenCheckingEnd?type=${this.queryObj.type}&type1=${
612 631
           this.queryObj.type1
613 632
         }&id=${encodeURIComponent(JSON.stringify(this.wcId))}&deptCode=${
614 633
           this.queryObj.deptCode
@@ -708,6 +727,11 @@
708 727
         margin-top: 116rpx;
709 728
         border-radius: 50%;
710 729
         line-height: 140rpx;
730
+        
731
+        .speNum{
732
+          text-align: center;
733
+          font-size: 140rpx;
734
+        }
711 735
 
712 736
         .cubeic-ok {
713 737
           font-size: 140rpx;

+ 10 - 10
pages/specimenChecking/specimenChecking.vue

@@ -1,15 +1,15 @@
1 1
 <template>
2 2
   <view class="specimenChecking">
3 3
     <view class="title">请您确认一下科室标本数量!</view>
4
-    <view class="page_item_wrap" v-for="item in list" :key="item[0]" @click="gotoDetail(item)">
4
+    <view class="page_item_wrap" v-for="item in list" :key="item.deptId" @click="gotoDetail(item)">
5 5
       <view class="page_item">
6 6
         <view class="page_item_top">
7 7
           <view class="page_item_top-inner">
8 8
             <view class="page_item_top_L">
9
-              <view class="L_text">{{item[1]}}</view>
9
+              <view class="L_text">{{item.deptName}}</view>
10 10
             </view>
11 11
             <view class="page_item_top_R">
12
-              <view class="L_iocn">{{item[2]}}</view>
12
+              <view class="L_iocn">{{item.speNum}}</view>
13 13
             </view>
14 14
           </view>
15 15
         </view>
@@ -114,7 +114,7 @@
114 114
                       res.type1
115 115
                     }&id=${encodeURIComponent(
116 116
                       JSON.stringify([res.gdid])
117
-                    )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
117
+                    )}&content=${content}`,
118 118
                     });
119 119
                   }
120 120
                 }
@@ -143,7 +143,7 @@
143 143
                         res.type1
144 144
                       }&id=${encodeURIComponent(
145 145
                         JSON.stringify([res.gdid])
146
-                      )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
146
+                      )}&content=${content}`,
147 147
                       });
148 148
                     }
149 149
                   }
@@ -215,7 +215,7 @@
215 215
                                       res.type1
216 216
                                     }&id=${encodeURIComponent(
217 217
                                       JSON.stringify([res.gdid])
218
-                                    )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
218
+                                    )}&content=${content}`,
219 219
                                     });
220 220
                                   }
221 221
                                 }
@@ -244,7 +244,7 @@
244 244
                                         res.type1
245 245
                                       }&id=${encodeURIComponent(
246 246
                                         JSON.stringify([res.gdid])
247
-                                      )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
247
+                                      )}&content=${content}`,
248 248
                                       });
249 249
                                     }
250 250
                                   }
@@ -327,10 +327,10 @@
327 327
       },
328 328
       // 跳转到详情页
329 329
       gotoDetail(item) {
330
-        this.speNumChange = item[2];
330
+        this.speNumChange = item.speNum;
331 331
         this.changeSpeObj = {
332 332
           infoDATA: this.msg,
333
-          id: item[0],
333
+          id: item.deptId,
334 334
           endDepts:this.msg.targetDept,
335 335
         }
336 336
         this.showChangeSpe();
@@ -360,7 +360,7 @@
360 360
                   if (res.type === 'plan-spe-ddd-2') {
361 361
                     //需要扫描标本
362 362
                     uni.navigateTo({
363
-                      url: `../../pages/scanning_code/scanning_code?type=${res.associationTypeName}&type1=${res.type}&id=${res.id}&deptCode=${res.deptCode}&dept=${res.deptName}&accountObj=undefined&endDepts=${this.msg.targetDept}`,
363
+                      url: `../../pages/scanning_code/scanning_code?type=${res.associationTypeName}&type1=${res.type}&id=${res.id}&deptCode=${res.deptCode}&dept=${res.deptName}&accountObj=undefined&endDepts=${this.msg.targetDept}&deptId=${res.deptId}`,
364 364
                     });
365 365
                   } else {
366 366
                     uni.navigateTo({

+ 7 - 7
pages/specimenCheckingDetail/specimenCheckingDetail.vue

@@ -313,10 +313,10 @@
313 313
         post(`/api/getStartDeptSpecimensNum`, postData).then((res) => {
314 314
           uni.hideLoading();
315 315
           if (res.status == 200) {
316
-            this.speNum = res.deptSpecimensNum;
317
-            this.modifyReason = res.modifyReason;
316
+            this.speNum = res.data[0].deptSpecimensNum;
317
+            this.modifyReason = res.data[0].modifyReason;
318 318
             get(
319
-              `/common/common/listAttachment/specimenPhotos/${res.bindId}`
319
+              `/common/common/listAttachment/specimenPhotos/${res.data[0].bindId}`
320 320
             ).then((result) => {
321 321
               if (result.status == 200) {
322 322
                 this.imgs = result.data.map((v) => v.previewUrl);
@@ -423,7 +423,7 @@
423 423
                       res.type1
424 424
                     }&id=${encodeURIComponent(
425 425
                       JSON.stringify([res.gdid])
426
-                    )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
426
+                    )}&content=${content}`,
427 427
                     });
428 428
                   }
429 429
                 }
@@ -452,7 +452,7 @@
452 452
                         res.type1
453 453
                       }&id=${encodeURIComponent(
454 454
                         JSON.stringify([res.gdid])
455
-                      )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
455
+                      )}&content=${content}`,
456 456
                       });
457 457
                     }
458 458
                   }
@@ -524,7 +524,7 @@
524 524
                                       res.type1
525 525
                                     }&id=${encodeURIComponent(
526 526
                                       JSON.stringify([res.gdid])
527
-                                    )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
527
+                                    )}&content=${content}`,
528 528
                                     });
529 529
                                   }
530 530
                                 }
@@ -553,7 +553,7 @@
553 553
                                         res.type1
554 554
                                       }&id=${encodeURIComponent(
555 555
                                         JSON.stringify([res.gdid])
556
-                                      )}&content=${content}&startDeptId=${postData.transDeptId}&targetDeptId=${postData.checkDept}`,
556
+                                      )}&content=${content}`,
557 557
                                       });
558 558
                                     }
559 559
                                   }

+ 405 - 0
pages/specimenCheckingEnd/specimenCheckingEnd.vue

@@ -0,0 +1,405 @@
1
+<template>
2
+  <view class="specimenChecking">
3
+    <view class="title" @click="gotoDetail()">签到标本总数:{{num}}</view>
4
+    <view class="page_item_wrap" v-for="item in list" :key="item.patientId" @click="gotoDetail(item)">
5
+      <view class="page_item">
6
+        <view class="page_item_top">
7
+          <view class="page_item_top-inner">
8
+            <view class="page_item_top_L">
9
+              <view class="L_text">{{item.patientName}}</view>
10
+            </view>
11
+            <view class="page_item_top_R">
12
+              <view class="L_iocn">{{item.count}}</view>
13
+            </view>
14
+          </view>
15
+        </view>
16
+      </view>
17
+    </view>
18
+    <view class="foot_btn2">
19
+      <view class="btn2" @click="checkComplete()">核对完成</view>
20
+      <view class="btn2" @click="goBack()">返回</view>
21
+    </view>
22
+  </view>
23
+</template>
24
+<script>
25
+  import {
26
+    get,
27
+    post,
28
+    webHandle
29
+  } from "../../http/http.js";
30
+  export default {
31
+    data() {
32
+      return {
33
+        list: [],
34
+        num: 0,
35
+        msg: {}, //页面展示信息
36
+        // 修改标本数量弹窗model
37
+        changeSpeModels: {
38
+          disjunctor: false,
39
+        },
40
+        speNumChange: 0,
41
+      };
42
+    },
43
+    methods: {
44
+      // 跳转到详情页
45
+      gotoDetail(item) {
46
+        console.log(item);
47
+        if(item){
48
+          uni.navigateTo({
49
+            url: `../../pages/specimenCheckingEndDetail/specimenCheckingEndDetail?gdId=${this.msg.id}&deptQrCode=${this.msg.deptCode}&patientId=${item.patientId}`,
50
+          });
51
+        }else{
52
+          uni.navigateTo({
53
+            url: `../../pages/specimenCheckingEndDetail/specimenCheckingEndDetail?gdId=${this.msg.id}&deptQrCode=${this.msg.deptCode}`,
54
+          });
55
+        }
56
+      },
57
+      checkComplete(){
58
+        uni.showModal({
59
+          title: '提示',
60
+          content: '是否核对完成?',
61
+          success: (result) => {
62
+            if (result.confirm) {
63
+              console.log('用户点击确定');
64
+              uni.navigateTo({
65
+                url: `../scanning/scanning?type=${this.msg.type}&type1=${
66
+                  this.msg.type1
67
+                }&id=${encodeURIComponent(JSON.stringify([this.msg.id]))}&deptCode=${
68
+                  this.msg.deptCode
69
+                }&dept=${this.msg.dept}&speNum=${this.msg.speNum}&content=${this.msg.content}`,
70
+              });
71
+            } else if (result.cancel) {
72
+              console.log('用户点击取消');
73
+            }
74
+          }
75
+        });
76
+      },
77
+      // 获取列表
78
+      getList() {
79
+        uni.showLoading({
80
+          mask: true,
81
+          title: '加载中'
82
+        })
83
+        let postData = {
84
+          gdId: this.msg.id,
85
+          deptQrCode: this.msg.deptCode,
86
+        }; //起点科室id,选择的科室ids
87
+        post(`/api/patientSpecimensNm`, postData).then((res) => {
88
+          uni.hideLoading();
89
+          uni.stopPullDownRefresh();
90
+          if (res.status == 200) {
91
+            this.num = res.num;
92
+            this.list = res.data;
93
+          } else {
94
+            uni.showToast({
95
+              icon: "none",
96
+              title: "请求失败!",
97
+            });
98
+          }
99
+        });
100
+      },
101
+      // 返回
102
+      goBack() {
103
+        uni.navigateBack();
104
+      },
105
+    },
106
+    onLoad(options) {
107
+      console.log(options);
108
+      options.id = JSON.parse(options.id)[0]
109
+      this.msg = options;
110
+      this.getList();
111
+      // #ifdef APP-PLUS
112
+      webHandle("no", "app");
113
+      // #endif
114
+      // #ifdef H5
115
+      webHandle("no", "wx");
116
+      // #endif
117
+    },
118
+    onPullDownRefresh() {
119
+      this.getList();
120
+    },
121
+  };
122
+</script>
123
+<style lang="less" scoped>
124
+  .specimenChecking {
125
+    padding-bottom: 100rpx;
126
+
127
+    .title {
128
+      font-size: 48rpx;
129
+      margin-top: 24rpx;
130
+      margin-bottom: 24rpx;
131
+      text-align: center;
132
+    }
133
+
134
+    .page_item_wrap {
135
+      width: 100%;
136
+      height: auto;
137
+      box-sizing: border-box;
138
+      position: relative;
139
+      margin-bottom: 16rpx;
140
+
141
+      .page_item {
142
+        margin-top: 16rpx;
143
+        margin-bottom: 124rpx;
144
+        background: #fff;
145
+        border-radius: 8rpx;
146
+        margin: 0 20rpx;
147
+        border: 2rpx solid #e5e9ed;
148
+        position: relative;
149
+        overflow: hidden;
150
+        padding: 0 16rpx;
151
+
152
+        .L {
153
+          width: 40rpx;
154
+          height: 40rpx;
155
+          border-radius: 50%;
156
+          background: #f9fafb;
157
+          position: absolute;
158
+          left: -20rpx;
159
+          top: 68rpx;
160
+          border: 2rpx solid #e5e9ed;
161
+        }
162
+
163
+        .R {
164
+          width: 40rpx;
165
+          height: 40rpx;
166
+          border-radius: 50%;
167
+          background: #f9fafb;
168
+          position: absolute;
169
+          float: right;
170
+          right: -20rpx;
171
+          top: 68rpx;
172
+          border: 2rpx solid #e5e9ed;
173
+        }
174
+
175
+        .starting {
176
+          width: 50rpx;
177
+          height: 50rpx;
178
+          color: #fff;
179
+          background: #49b856;
180
+          display: inline-block;
181
+          border-radius: 50%;
182
+          text-align: center;
183
+          line-height: 46rpx;
184
+          font-size: 32rpx;
185
+          margin-right: 6rpx;
186
+        }
187
+
188
+        .End {
189
+          width: 50rpx;
190
+          height: 50rpx;
191
+          color: #fff;
192
+          background: #39b199;
193
+          display: inline-block;
194
+          border-radius: 50%;
195
+          text-align: center;
196
+          line-height: 46rpx;
197
+          font-size: 32rpx;
198
+          margin-right: 6rpx;
199
+        }
200
+
201
+        .page_item_top {
202
+          height: 88rpx;
203
+          // border-bottom: 2rpx dashed #e5e9ed;
204
+          padding: 0 16rpx;
205
+
206
+          .page_item_top-inner {
207
+            display: flex;
208
+            justify-content: space-between;
209
+            align-items: center;
210
+            height: 100%;
211
+
212
+            .page_item_top_L {
213
+              .emergencys {
214
+                background: #ff3b53 !important;
215
+                width: 124rpx !important;
216
+              }
217
+
218
+              .emergency {
219
+                background: #ff3b53 !important;
220
+              }
221
+
222
+              .emergency1 {
223
+                background: #49b856 !important;
224
+              }
225
+
226
+              .page_item_cont_start {
227
+                text-align: center;
228
+                height: 44rpx;
229
+                width: 104rpx;
230
+                line-height: 44rpx;
231
+                border-radius: 8rpx;
232
+                background: #49b856;
233
+                color: #fff;
234
+                display: inline-block;
235
+              }
236
+
237
+              .L_time {
238
+                color: #6cc076;
239
+                font-size: 32rpx;
240
+              }
241
+
242
+              .L_text {
243
+                font-size: 32rpx;
244
+                font-weight: 700;
245
+              }
246
+            }
247
+
248
+            .page_item_top_R {
249
+              font-size: 32rpx;
250
+
251
+              .L_iocn {
252
+                color: rgb(7, 134, 60);
253
+                font-size: 36rpx;
254
+                font-weight: 700;
255
+              }
256
+            }
257
+          }
258
+        }
259
+
260
+        .page_item_cont {
261
+          min-height: 90rpx;
262
+          padding: 0 16rpx;
263
+          text-align: left;
264
+          position: relative;
265
+
266
+          .text_big {
267
+            font-size: 32rpx;
268
+            font-weight: 700;
269
+            margin-top: 10rpx;
270
+
271
+            p {
272
+              font-weight: 700;
273
+              line-height: 1.5;
274
+            }
275
+          }
276
+
277
+          .page_item_cont_T {
278
+            padding-top: 28rpx;
279
+            font-size: 28rpx;
280
+
281
+            .page_item_cont_title {
282
+              height: 100%;
283
+              font-size: 32rpx;
284
+              display: flex;
285
+              justify-content: space-between;
286
+            }
287
+          }
288
+
289
+          .page_item_cont_B {
290
+            padding-top: 28rpx;
291
+            margin-bottom: 28rpx;
292
+
293
+            .page_item_cont_title {
294
+              font-size: 32rpx;
295
+              display: flex;
296
+              justify-content: space-between;
297
+            }
298
+
299
+            .page_item_cont_title1 {
300
+              height: 60rpx;
301
+              line-height: 60rpx;
302
+              font-size: 32rpx;
303
+              padding-left: 64rpx;
304
+            }
305
+          }
306
+        }
307
+
308
+        .page_item_foot {
309
+          border-top: 2rpx dashed #e5e9ed;
310
+          border-bottom: 2rpx dashed #e5e9ed;
311
+          padding: 28rpx 16rpx;
312
+          text-align: left;
313
+
314
+          .page_item_foot_text {
315
+            font-size: 32rpx;
316
+            margin-bottom: 20rpx;
317
+
318
+            .text1 {
319
+              color: rgb(102, 102, 102);
320
+            }
321
+
322
+            .text2 {
323
+              float: right;
324
+              font-weight: 700;
325
+            }
326
+          }
327
+        }
328
+
329
+        #infos {
330
+          display: none;
331
+        }
332
+
333
+        .page_item_infos {
334
+          padding-bottom: 20rpx;
335
+          border-bottom: 2rpx dashed #e5e9ed;
336
+
337
+          .page_item_info2 {
338
+            text-align: left;
339
+            line-height: 60rpx;
340
+            font-size: 32rpx;
341
+            padding-left: 16rpx;
342
+
343
+            .page_item_foot_text {
344
+              font-size: 32rpx;
345
+              margin-bottom: 20rpx;
346
+
347
+              .text1 {
348
+                color: rgb(102, 102, 102);
349
+              }
350
+
351
+              .text2 {
352
+                float: right;
353
+                font-weight: 700;
354
+              }
355
+            }
356
+          }
357
+        }
358
+      }
359
+
360
+      .L-l {
361
+        width: 2rpx;
362
+        height: 40rpx;
363
+        background: #f9fafb;
364
+        position: absolute;
365
+        left: 20rpx;
366
+        top: 72rpx;
367
+      }
368
+
369
+      .R-l {
370
+        width: 2rpx;
371
+        height: 40rpx;
372
+        background: #f9fafb;
373
+        position: absolute;
374
+        right: 20rpx;
375
+        top: 72rpx;
376
+      }
377
+    }
378
+
379
+    .foot_btn2 {
380
+      position: fixed;
381
+      bottom: 0;
382
+      width: 100vw;
383
+      padding: 0 20rpx;
384
+      box-sizing: border-box;
385
+      line-height: 66rpx;
386
+      height: 100rpx;
387
+      border-top: 2rpx solid #e5e9ed;
388
+      background: #f9fafb;
389
+      text-align: center;
390
+      display: flex;
391
+      justify-content: center;
392
+      align-items: center;
393
+
394
+      .btn2 {
395
+        height: 66rpx;
396
+        flex: 1;
397
+        margin: 16rpx 16rpx 0;
398
+        background-image: linear-gradient(to right, #72c172, #3bb197);
399
+        color: #fff;
400
+        border-radius: 8rpx;
401
+        font-size: 32rpx;
402
+      }
403
+    }
404
+  }
405
+</style>

+ 374 - 0
pages/specimenCheckingEndDetail/specimenCheckingEndDetail.vue

@@ -0,0 +1,374 @@
1
+<template>
2
+  <view class="pharmacyDetails">
3
+    <view class="page_item footerOtherMargin">
4
+      <view class="page_item_wrap" v-for="spe in specimens" :key="spe.id">
5
+        <view class="page_item">
6
+          <view class="page_item_top">
7
+            <view class="page_item_top-inner">
8
+              <view class="page_item_top_L">
9
+                <view class="L_text">{{ spe.scode }}<text v-if="spe.stype">({{spe.stype.name}})</text></view>
10
+              </view>
11
+              <view class="page_item_top_R">
12
+                <text :style="{color:spe.urgent == 1?'red':'green'}">{{spe.urgent == 1 ? "急" : "普"}}</text>
13
+              </view>
14
+            </view>
15
+          </view>
16
+          <view class="page_item_cont">
17
+            <view class="page_item_cont_T">
18
+              <view class="page_item_cont_title">
19
+                <view> 检验项目 </view>
20
+                <view class="text_big">{{ spe.specimenDesc || "无" }}</view>
21
+              </view>
22
+              <view class="page_item_cont_title">
23
+                <view> 患者姓名 </view>
24
+                <view class="text_big">{{ spe.patientName }}<text v-if="spe.bedNum">({{spe.bedNum}})</text></view>
25
+              </view>
26
+              <view class="page_item_cont_title">
27
+                <view> 住院号 </view>
28
+                <view class="text_big">{{spe.residenceNo||'无'}}</text></view>
29
+              </view>
30
+              <view class="page_item_cont_title">
31
+                <view class="text_big">{{
32
+                  spe.sickRoom ? spe.sickRoom.dept : "无"
33
+                }}</view>
34
+                <text style="width: 4em;text-align: center;" class="icon_transport transport-arrow-right-full"></text>
35
+                <view class="text_big">{{
36
+                  spe.checkDept ? spe.checkDept.dept : "无"
37
+                }}</view>
38
+              </view>
39
+            </view>
40
+          </view>
41
+          <view class="L"></view>
42
+          <view class="R"></view>
43
+        </view>
44
+        <view class="L-l"></view>
45
+        <view class="R-l"></view>
46
+      </view>
47
+    </view>
48
+    <view class="foot_btn2 footerPadding">
49
+      <view class="btn2" @click="goBack">返回</view>
50
+    </view>
51
+  </view>
52
+</template>
53
+<script>
54
+  import {
55
+    post,
56
+    webHandle
57
+  } from "../../http/http.js";
58
+  export default {
59
+    data() {
60
+      return {
61
+        queryObj: {}, //路由传递过来的数据
62
+        specimens: [],
63
+      };
64
+    },
65
+    methods: {
66
+      // 返回
67
+      goBack() {
68
+        uni.navigateBack();
69
+      },
70
+      // 获取标本信息
71
+      getDetail() {
72
+        let postData = {
73
+          gdId: this.queryObj.gdId,
74
+          deptQrCode: this.queryObj.deptQrCode,
75
+          patientId: this.queryObj.patientId || undefined,
76
+        };
77
+        uni.showLoading({
78
+          title: "加载中",
79
+          mask: true,
80
+        });
81
+        post("/api/endDeptPatientSpecimens", postData).then((res) => {
82
+          uni.hideLoading();
83
+          if (res.status == 200) {
84
+            this.specimens = res.data;
85
+          } else {
86
+            uni.showToast({
87
+              icon: "none",
88
+              title: "请求失败!",
89
+            });
90
+          }
91
+        });
92
+      },
93
+    },
94
+    onLoad(options) {
95
+      console.log(options);
96
+      this.queryObj = options;
97
+      this.getDetail();
98
+      // #ifdef APP-PLUS
99
+      webHandle("no", "app");
100
+      // #endif
101
+      // #ifdef H5
102
+      webHandle("no", "wx");
103
+      // #endif
104
+    },
105
+  };
106
+</script>
107
+<style lang="less" scoped>
108
+  .pharmacyDetails {
109
+    background-color: rgb(249, 250, 251);
110
+    padding-top: 50rpx;
111
+    height: 100%;
112
+    box-sizing: border-box;
113
+    
114
+    .page_header {
115
+      margin: 20rpx;
116
+      padding: 16rpx;
117
+      border: 2rpx solid #e5e9ed;
118
+      background: #fff;
119
+      border-radius: 8rpx;
120
+    
121
+      .page_header_item {
122
+        margin-bottom: 16rpx;
123
+    
124
+        .page_header_title {
125
+          margin-bottom: 8rpx;
126
+          font-weight: bold;
127
+        }
128
+    
129
+        .page_header_content {
130
+          display: flex;
131
+    
132
+          image {
133
+            height: 100rpx;
134
+            width: 30%;
135
+            margin: 0 8rpx;
136
+          }
137
+        }
138
+      }
139
+    }
140
+
141
+    .pharmacyDetails_title {
142
+      font-size: 46rpx;
143
+      font-weight: 550;
144
+      text-align: center;
145
+    }
146
+
147
+    .page_item_wrap {
148
+      position: relative;
149
+      margin-top: 32rpx;
150
+
151
+      .page_item {
152
+        margin-top: 16rpx;
153
+        margin-bottom: 124rpx;
154
+        background: #fff;
155
+        border-radius: 8rpx;
156
+        margin: 0 20rpx;
157
+        border: 2rpx solid #e5e9ed;
158
+        position: relative;
159
+        overflow: hidden;
160
+        padding: 0 16rpx;
161
+
162
+        .L {
163
+          width: 40rpx;
164
+          height: 40rpx;
165
+          border-radius: 50%;
166
+          background: #f9fafb;
167
+          position: absolute;
168
+          left: -20rpx;
169
+          top: 68rpx;
170
+          border: 2rpx solid #e5e9ed;
171
+        }
172
+
173
+        .R {
174
+          width: 40rpx;
175
+          height: 40rpx;
176
+          border-radius: 50%;
177
+          background: #f9fafb;
178
+          position: absolute;
179
+          float: right;
180
+          right: -20rpx;
181
+          top: 68rpx;
182
+          border: 2rpx solid #e5e9ed;
183
+        }
184
+
185
+        .page_item_top {
186
+          height: 88rpx;
187
+          border-bottom: 2rpx dashed #e5e9ed;
188
+          padding: 0 16rpx;
189
+
190
+          .page_item_top-inner {
191
+            display: flex;
192
+            justify-content: space-between;
193
+            align-items: center;
194
+            height: 100%;
195
+
196
+            .page_item_top_L {
197
+              .L_text {
198
+                font-size: 32rpx;
199
+                font-weight: 700;
200
+              }
201
+            }
202
+
203
+            .page_item_top_R {
204
+              font-size: 32rpx;
205
+
206
+              .L_iocn {
207
+                color: rgb(7, 134, 60);
208
+                font-size: 36rpx;
209
+                font-weight: 700;
210
+              }
211
+            }
212
+          }
213
+        }
214
+
215
+        .page_item_cont {
216
+          min-height: 90rpx;
217
+          padding: 0 16rpx;
218
+          text-align: left;
219
+          position: relative;
220
+
221
+          .text_big {
222
+            font-size: 32rpx;
223
+            font-weight: 700;
224
+            margin-top: 10rpx;
225
+          
226
+            p {
227
+              font-weight: 700;
228
+              line-height: 1.5;
229
+            }
230
+          }
231
+
232
+          .line {
233
+            height: 20rpx;
234
+            width: 2rpx;
235
+            border-left: 2rpx solid #e5e9ed;
236
+            position: absolute;
237
+            top: 82rpx;
238
+            left: 40rpx;
239
+          }
240
+
241
+          .page_item_cont_T {
242
+            padding-top: 28rpx;
243
+            padding-bottom: 28rpx;
244
+            font-size: 28rpx;
245
+
246
+            .page_item_cont_title {
247
+              height: 100%;
248
+              font-size: 32rpx;
249
+              display: flex;
250
+              justify-content: space-between;
251
+              align-items: center;
252
+            }
253
+          }
254
+
255
+          .page_item_cont_B {
256
+            padding-top: 28rpx;
257
+            margin-bottom: 28rpx;
258
+
259
+            .page_item_cont_title {
260
+              font-size: 32rpx;
261
+              display: flex;
262
+              justify-content: space-between;
263
+              align-items: center;
264
+            }
265
+          }
266
+
267
+          .page_item_cont_C {
268
+            margin-bottom: 28rpx;
269
+
270
+            .page_item_cont_title_C {
271
+              font-size: 32rpx;
272
+              display: flex;
273
+              justify-content: space-between;
274
+              align-items: center;
275
+            }
276
+          }
277
+
278
+          #infos {
279
+            display: none;
280
+          }
281
+        }
282
+      }
283
+
284
+      .L-l {
285
+        width: 2rpx;
286
+        height: 40rpx;
287
+        background: #f9fafb;
288
+        position: absolute;
289
+        left: 20rpx;
290
+        top: 72rpx;
291
+      }
292
+
293
+      .R-l {
294
+        width: 2rpx;
295
+        height: 40rpx;
296
+        background: #f9fafb;
297
+        position: absolute;
298
+        right: 20rpx;
299
+        top: 72rpx;
300
+      }
301
+    }
302
+
303
+    .cube-toolbar-item {
304
+      width: 710rpx;
305
+      height: 68rpx;
306
+      line-height: 68rpx;
307
+      position: fixed;
308
+      left: 20rpx;
309
+      bottom: 160rpx;
310
+      border-radius: 8rpx;
311
+      background: linear-gradient(to right, #72c172, #3bb197);
312
+      font-size: 36rpx;
313
+      color: #fff;
314
+      text-align: center;
315
+    }
316
+
317
+    .btn-wrap {
318
+      display: flex;
319
+      justify-content: space-between;
320
+      position: fixed;
321
+      left: 20rpx;
322
+      bottom: 160rpx;
323
+    }
324
+
325
+    .cube-toolbar-item1 {
326
+      width: 350rpx;
327
+      height: 68rpx;
328
+      line-height: 68rpx;
329
+      border-radius: 8rpx;
330
+      margin: 0 5rpx;
331
+      background: linear-gradient(to right, #72c172, #3bb197);
332
+      font-size: 36rpx;
333
+      color: #fff;
334
+      text-align: center;
335
+    }
336
+
337
+    .foot_btn2 {
338
+      position: fixed;
339
+      bottom: 0;
340
+      right: 20rpx;
341
+      left: 20rpx;
342
+      line-height: 66rpx;
343
+      height: 100rpx;
344
+      border-top: 2rpx solid #e5e9ed;
345
+      background: #f9fafb;
346
+      display: flex;
347
+      justify-content: space-between;
348
+
349
+      .btn2 {
350
+        height: 66rpx;
351
+        width: 100%;
352
+        margin: 0 1%;
353
+        background-image: linear-gradient(to right, #72c172, #3bb197);
354
+        color: #fff;
355
+        border-radius: 8rpx;
356
+        font-size: 32rpx;
357
+        margin-top: 16rpx;
358
+        text-align: center;
359
+      }
360
+
361
+      .btn3 {
362
+        height: 66rpx;
363
+        width: 48%;
364
+        margin: 0 1%;
365
+        background-image: linear-gradient(to right, #72c172, #3bb197);
366
+        color: #fff;
367
+        border-radius: 8rpx;
368
+        font-size: 32rpx;
369
+        margin-top: 16rpx;
370
+        text-align: center;
371
+      }
372
+    }
373
+  }
374
+</style>