Browse Source

医费绑定,医费核对,医费详情

seimin 1 year ago
parent
commit
dfb4b632cf

+ 12 - 1
components/bigScreen/bigScreen.vue

@@ -241,7 +241,7 @@
241 241
                 };
242 242
                 //微信—大扫描(科室码,患者码,标本码,快捷建单码,药包码)
243 243
                 let code = result.code.includes(qrcodePrefix) ? result.code : qrcodePrefix + result.code;
244
-                post("/workerOrder/scanCode", { code })
244
+                post("/workerOrder/scanCode", { code, hosId: this.hosId })
245 245
                   .then((res) => {
246 246
                     uni.hideLoading();
247 247
                     if (res.status == 200) {
@@ -415,6 +415,17 @@
415 415
                             });
416 416
                           }
417 417
                         }
418
+                      } else if(res.type == 'clinicalWaste'){
419
+                        // 医废
420
+                        if(res.wasteDetails){
421
+                          uni.navigateTo({
422
+                            url: `/pages/medicalWaste/medicalWasteDetail/medicalWasteDetail?qrcode=${res.code}`,
423
+                          });
424
+                        }else{
425
+                          uni.navigateTo({
426
+                            url: `/pages/medicalWaste/medicalWasteBind/medicalWasteBind?qrcode=${res.code}`,
427
+                          });
428
+                        }
418 429
                       }
419 430
                     } else {
420 431
                       if(res.bigScanSpecialMsg){

+ 14 - 0
package-lock.json

@@ -9,6 +9,7 @@
9 9
       "version": "1.0.0",
10 10
       "license": "ISC",
11 11
       "dependencies": {
12
+        "big.js": "^6.2.1",
12 13
         "crypto-js": "^4.1.1",
13 14
         "dayjs": "^1.11.10",
14 15
         "js-base64": "^3.7.5",
@@ -45,6 +46,14 @@
45 46
         "tweetnacl": "^0.14.3"
46 47
       }
47 48
     },
49
+    "node_modules/big.js": {
50
+      "version": "6.2.1",
51
+      "resolved": "https://registry.npmmirror.com/big.js/-/big.js-6.2.1.tgz",
52
+      "integrity": "sha512-bCtHMwL9LeDIozFn+oNhhFoq+yQ3BNdnsLSASUxLciOb1vgvpHsIO1dsENiGMgbb4SkP5TrzWzRiLddn8ahVOQ==",
53
+      "engines": {
54
+        "node": "*"
55
+      }
56
+    },
48 57
     "node_modules/brace-expansion": {
49 58
       "version": "1.1.11",
50 59
       "resolved": "https://registry.npmmirror.com/brace-expansion/download/brace-expansion-1.1.11.tgz",
@@ -436,6 +445,11 @@
436 445
         "tweetnacl": "^0.14.3"
437 446
       }
438 447
     },
448
+    "big.js": {
449
+      "version": "6.2.1",
450
+      "resolved": "https://registry.npmmirror.com/big.js/-/big.js-6.2.1.tgz",
451
+      "integrity": "sha512-bCtHMwL9LeDIozFn+oNhhFoq+yQ3BNdnsLSASUxLciOb1vgvpHsIO1dsENiGMgbb4SkP5TrzWzRiLddn8ahVOQ=="
452
+    },
439 453
     "brace-expansion": {
440 454
       "version": "1.1.11",
441 455
       "resolved": "https://registry.npmmirror.com/brace-expansion/download/brace-expansion-1.1.11.tgz",

+ 1 - 0
package.json

@@ -14,6 +14,7 @@
14 14
   "author": "",
15 15
   "license": "ISC",
16 16
   "dependencies": {
17
+    "big.js": "^6.2.1",
17 18
     "crypto-js": "^4.1.1",
18 19
     "dayjs": "^1.11.10",
19 20
     "js-base64": "^3.7.5",

+ 24 - 0
pages.json

@@ -583,6 +583,30 @@
583 583
           "titleNView": false
584 584
         }
585 585
       }
586
+    },
587
+    {
588
+      "path": "pages/medicalWaste/medicalWasteBind/medicalWasteBind",//医废绑定
589
+      "style": {
590
+        "h5": {
591
+          "titleNView": false
592
+        }
593
+      }
594
+    },
595
+    {
596
+      "path": "pages/medicalWaste/medicalWasteBindCheck/medicalWasteBindCheck",//医废绑定-回收核对
597
+      "style": {
598
+        "h5": {
599
+          "titleNView": false
600
+        }
601
+      }
602
+    },
603
+    {
604
+      "path": "pages/medicalWaste/medicalWasteDetail/medicalWasteDetail", //医废详情
605
+      "style": {
606
+        "h5": {
607
+          "titleNView": false
608
+        }
609
+      }
586 610
     }
587 611
   ],
588 612
   "globalStyle": {

+ 511 - 0
pages/medicalWaste/medicalWasteBind/medicalWasteBind.vue

@@ -0,0 +1,511 @@
1
+<template>
2
+  <view class="Scanning_Result">
3
+    <view class="Scanning_top">
4
+      <view class="Scanning_top_icon">
5
+        <text class="cubeic-ok icon_transport transport-duigou"></text>
6
+      </view>
7
+      <view class="Scanning_top_text">
8
+        请填写以下信息绑定条码
9
+      </view>
10
+    </view>
11
+
12
+    <view class="Scanning_cont yf">
13
+      <view class="Scanning_cont_list">
14
+        <view>序号:{{queryObj.qrcode}}</view>
15
+        <view class="red">{{id ? '已修改' : ''}}</view>
16
+      </view>
17
+      <view class="Scanning_cont_list">
18
+        <view class="Scanning_cont_list_title">
19
+          科室:
20
+        </view>
21
+        <view class="Scanning_cont_list_desc" v-if="disabledDept">
22
+          <text>{{deptName}}</text>
23
+        </view>
24
+        <view class="Scanning_cont_list_desc" v-else>
25
+          <input disabled class="deptInput" placeholder="请搜索科室" placeholder-style="color:#C3BFBF;font-size:28rpx;padding:8rpx;line-height:1;" v-model="deptName" />
26
+          <view class="mask" @click="changeDept"></view>
27
+          <text class="icon_transport transport-sousuo"></text>
28
+          <text class="newicon newicon-saoma" @click="scanDept"></text>
29
+        </view>
30
+      </view>
31
+      <view class="Scanning_cont_list">
32
+        <view class="Scanning_cont_list_title">
33
+          医废类型:
34
+        </view>
35
+        <view class="Scanning_cont_list_desc">
36
+          <picker @change="bindMedicalWasteType" :value="medicalWasteTypeIndex" :range="medicalWasteTypes" range-key="typeName">
37
+            <view class="typeInput">{{medicalWasteTypes[medicalWasteTypeIndex] ? medicalWasteTypes[medicalWasteTypeIndex].typeName : ''}}</view>
38
+            <text class="newicon newicon-xiala1"></text>
39
+          </picker>
40
+        </view>
41
+      </view>
42
+      <view class="Scanning_cont_list">
43
+        <view class="Scanning_cont_list_title">
44
+          重量:
45
+        </view>
46
+        <view class="Scanning_cont_list_desc">
47
+          <input class="deptInput" type="digit" placeholder-style="color:#C3BFBF;font-size:28rpx;padding:8rpx;line-height:1;" @blur="blurWeight" v-model="weight" />kg
48
+        </view>
49
+      </view>
50
+      <view class="Scanning_cont_list">
51
+        <view class="Scanning_cont_list_title">
52
+          备注:
53
+        </view>
54
+        <view class="Scanning_cont_list_desc">
55
+          <textarea class="remarkInput" placeholder-style="color:#C3BFBF;font-size:28rpx;padding:8rpx;line-height:normal;" v-model="remark" placeholder="请输入备注信息" />
56
+        </view>
57
+      </view>
58
+    </view>
59
+
60
+    <view class="foot_btn">
61
+      <view class="btn" @click="scanNext(true)"> 继续扫描 </view>
62
+      <view class="btn" @click="scanNext(false)"> 核对回收 </view>
63
+    </view>
64
+  </view>
65
+</template>
66
+<script>
67
+  import {
68
+    get,
69
+    post,
70
+    SM,
71
+    webHandle
72
+  } from "../../../http/http.js";
73
+  export default {
74
+    data() {
75
+      return {
76
+        id: null,
77
+        disabledDept: false,
78
+        SMFlag: true,
79
+        remark: '',
80
+        deptId: null,
81
+        deptName: '',
82
+        weight: 0,
83
+        medicalWasteTypes: [],
84
+        medicalWasteTypeIndex: 0,
85
+        hosId: uni.getStorageSync('userData').user.currentHospital.id,
86
+        queryObj: {}, //路由传递过来的数据
87
+      };
88
+    },
89
+    onShow() {
90
+      this.SMFlag = true;
91
+    },
92
+    methods: {
93
+      // 扫科室
94
+      scanDept() {
95
+        if (!this.SMFlag) {
96
+          return;
97
+        }
98
+        this.SMFlag = false;
99
+        SM().then((content) => {
100
+          uni.showLoading({
101
+            title: "加载中",
102
+            mask: true,
103
+          });
104
+          //检验二维码的有效性(扫码前必须验证)
105
+          post("/dept/scanning", {
106
+              content,
107
+            })
108
+            .then((result) => {
109
+              this.SMFlag = true;
110
+              // 200检测通过,201没有有效期也通过。
111
+              if (result.state == 200 || result.state == 201) {
112
+                let data = {
113
+                  code: result.code, //二维码
114
+                };
115
+                
116
+                post("/medicalWaste/scanByCode", {
117
+                  code: result.code,
118
+                  hosId: this.hosId,
119
+                })
120
+                  .then((res) => {
121
+                    uni.hideLoading();
122
+                    if (res.status == 200 && res.data) {
123
+                      this.deptId = res.data.id;
124
+                      this.deptName = res.data.dept;
125
+                    } else {
126
+                      uni.showToast({
127
+                        icon: "none",
128
+                        title: res.msg || "接口获取数据失败!",
129
+                      });
130
+                    }
131
+                  });
132
+              } else {
133
+                uni.hideLoading();
134
+                uni.showToast({
135
+                  icon: "none",
136
+                  title: result.info || "接口获取数据失败!",
137
+                });
138
+              }
139
+            })
140
+        }).catch(err => {
141
+          this.SMFlag = true;
142
+        });
143
+      },
144
+      scanNestCommonGoOn(isScan = false){
145
+        if(isScan){
146
+          // 继续扫描
147
+          SM().then((content) => {
148
+            uni.showLoading({
149
+              title: "加载中",
150
+              mask: true,
151
+            });
152
+            //检验二维码的有效性(扫码前必须验证)
153
+            post("/dept/scanning", {
154
+                content,
155
+              })
156
+              .then((result) => {
157
+                // 200检测通过,201没有有效期也通过。
158
+                if (result.state == 200 || result.state == 201) {
159
+                  // 判断是否是医废
160
+                  post("/medicalWaste/continueScan", { code: result.code, hosId: this.hosId })
161
+                    .then((res) => {
162
+                      uni.hideLoading();
163
+                      if (res.status == 200) {
164
+                        this.disabledDept = true;
165
+                        if(res.wasteInfo){
166
+                          // 编辑
167
+                          this.id = res.wasteInfo.id;
168
+                        } else {
169
+                          // 新增
170
+                          this.id = undefined;
171
+                          this.queryObj.qrcode = res.code;
172
+                          this.weight = 0;
173
+                          this.medicalWasteTypeIndex = 0;
174
+                          this.remark = '';
175
+                        }
176
+                      } else {
177
+                        uni.showToast({
178
+                          icon: "none",
179
+                          title: res.msg || "接口获取数据失败!",
180
+                        });
181
+                      }
182
+                    });
183
+                } else {
184
+                  uni.hideLoading();
185
+                  uni.showToast({
186
+                    icon: "none",
187
+                    title: result.info || "接口获取数据失败!",
188
+                  });
189
+                }
190
+              })
191
+          }).catch(err => {});
192
+        }else{
193
+          // 核对回收
194
+          uni.navigateTo({
195
+            url: `/pages/medicalWaste/medicalWasteBindCheck/medicalWasteBindCheck?deptName=${this.deptName}&deptId=${this.deptId}`,
196
+          });
197
+        }
198
+      },
199
+      // 继续扫描
200
+      scanNextCommon(isScan = false){
201
+        let postData = {
202
+          wasteInfo: {
203
+            clinicalWasteType: this.medicalWasteTypes[this.medicalWasteTypeIndex],
204
+            clinicalWasteSn: this.queryObj.qrcode,
205
+            weight: +this.weight,
206
+            deptId: +this.deptId,
207
+            remark: this.remark,
208
+            hosId: this.hosId,
209
+            id: this.id || undefined,
210
+          }
211
+        }
212
+        console.log(postData);
213
+        uni.showLoading({
214
+          title: "加载中",
215
+          mask: true,
216
+        });
217
+        post("/medicalWaste/bindInfo", postData)
218
+          .then((result1) => {
219
+            uni.hideLoading();
220
+            if (result1.status == 200) {
221
+              this.scanNestCommonGoOn(isScan);
222
+            } else {
223
+              uni.showToast({
224
+                icon: "none",
225
+                title: result1.msg || "接口获取数据失败!",
226
+              });
227
+            }
228
+          });
229
+      },
230
+      // 继续扫描-判断重量
231
+      scanNext(isScan = false) {
232
+        if(!this.deptId){
233
+          uni.showModal({
234
+            title: "提示",
235
+            content: "请选择科室!",
236
+            showCancel: false,
237
+            success: function(res) {
238
+              if (res.confirm) {
239
+                console.log("用户点击确定");
240
+              } else if (res.cancel) {
241
+                console.log("用户点击取消");
242
+              }
243
+            },
244
+          });
245
+          return;
246
+        }
247
+        if(this.medicalWasteTypeIndex == 0){
248
+          uni.showModal({
249
+            title: "提示",
250
+            content: "请选择医废类型!",
251
+            showCancel: false,
252
+            success: function(res) {
253
+              if (res.confirm) {
254
+                console.log("用户点击确定");
255
+              } else if (res.cancel) {
256
+                console.log("用户点击取消");
257
+              }
258
+            },
259
+          });
260
+          return;
261
+        }
262
+        let postData = {
263
+            clinicalWasteTypeId: this.medicalWasteTypes[this.medicalWasteTypeIndex].id,
264
+            weight: +this.weight,
265
+            deptId: +this.deptId,
266
+            hosId: this.hosId,
267
+        }
268
+        console.log(postData);
269
+        uni.showLoading({
270
+          title: "加载中",
271
+          mask: true,
272
+        });
273
+        post("/medicalWaste/checkLimit", postData)
274
+          .then((result) => {
275
+            uni.hideLoading();
276
+            if (result.status == 200) {
277
+              this.scanNextCommon(isScan);
278
+            }else if (result.status == 201) {
279
+              uni.showModal({
280
+              	title: '提示',
281
+              	content: result.msg,
282
+              	success: (res) => {
283
+              		if (res.confirm) {
284
+              			console.log('用户点击确定');
285
+                    this.scanNextCommon(isScan);
286
+              		} else if (res.cancel) {
287
+              			console.log('用户点击取消');
288
+              		}
289
+              	}
290
+              });
291
+            } else {
292
+              uni.showToast({
293
+                icon: "none",
294
+                title: result.msg || "接口获取数据失败!",
295
+              });
296
+            }
297
+          });
298
+      },
299
+      // 选择科室
300
+      changeDept() {
301
+        uni.navigateTo({
302
+          url: `/pages/search/search?type=medicalWasteBind&code=${this.queryObj.qrcode}&remark=${this.remark}&weight=${this.weight}&medicalWasteTypeIndex=${this.medicalWasteTypeIndex}`,
303
+        });
304
+      },
305
+      blurWeight(){
306
+        this.weight = Math.abs(this.weight).toFixed(2)
307
+      },
308
+      bindMedicalWasteType: function(e) {
309
+          console.log('picker发送选择改变,携带值为', e.detail.value)
310
+          this.medicalWasteTypeIndex = e.detail.value
311
+      },
312
+      getMedicalWasteType(){
313
+        uni.showLoading({
314
+          title: "加载中",
315
+          mask: true,
316
+        });
317
+        post("/simple/data/fetchDataList/clinicalWasteType", {
318
+          idx: 0,
319
+          sum: 9999,
320
+          clinicalWasteType: {
321
+            hosId: this.hosId
322
+          }
323
+        }).then((result) => {
324
+          uni.hideLoading();
325
+          if (result.status == 200) {
326
+            let medicalWasteTypes = result.list || [];
327
+            medicalWasteTypes.unshift({id: 0, typeName: '请选择'});
328
+            this.medicalWasteTypes = medicalWasteTypes;
329
+          } else {
330
+            uni.showToast({
331
+              icon: "none",
332
+              title: result.msg || "接口获取数据失败!",
333
+            });
334
+          }
335
+        });
336
+      },
337
+    },
338
+    onLoad(options) {
339
+      console.log(options, "result");
340
+      this.queryObj = options;
341
+      if (options.deptId && options.deptName) {
342
+        this.deptId = options.deptId;
343
+        this.deptName = options.deptName;
344
+        this.remark = options.remark;
345
+        this.weight = options.weight;
346
+        this.medicalWasteTypeIndex = options.medicalWasteTypeIndex;
347
+      }
348
+      this.getMedicalWasteType();
349
+      // #ifdef APP-PLUS
350
+      webHandle("no", "app");
351
+      // #endif
352
+      // #ifdef H5
353
+      webHandle("no", "wx");
354
+      // #endif
355
+    },
356
+  };
357
+</script>
358
+<style lang="less" scoped>
359
+  .Scanning_Result {
360
+    height: 100vh;
361
+    display: flex;
362
+    flex-direction: column;
363
+    background-color: #fff;
364
+    .yf /deep/ .uni-input-input[disabled]{
365
+      text-overflow: ellipsis;
366
+    }
367
+    .Scanning_top {
368
+      flex-shrink: 0;
369
+      .Scanning_top_icon {
370
+        padding-top: 26rpx;
371
+        display: flex;
372
+        flex-direction: column;
373
+        justify-content: center;
374
+        align-items: center;
375
+
376
+        .cubeic-ok {
377
+          font-size: 100rpx;
378
+          color: #35b34a;
379
+        }
380
+
381
+        .text1 {
382
+          font-size: 40rpx;
383
+          font-weight: bold;
384
+        }
385
+      }
386
+      .Scanning_top_text{
387
+        text-align: center;
388
+        font-size: 34rpx;
389
+        font-weight: bold;
390
+        padding: 26rpx 0 38rpx 0;
391
+      }
392
+    }
393
+
394
+    .Scanning_cont {
395
+      flex: 1;
396
+      min-height: 0;
397
+      display: flex;
398
+      flex-direction: column;
399
+      width: 710rpx;
400
+      margin: 0 20rpx;
401
+      padding: 6rpx;
402
+      background-color: #FBFCFE;
403
+      box-shadow: 0rpx 3rpx 6rpx 1rpx rgba(0,0,0,0.16);
404
+      font-size: 28rpx;
405
+      line-height: 1;
406
+      .Scanning_cont_list{
407
+        font-weight: bold;
408
+        padding: 27rpx 55rpx;
409
+        border-bottom: 1rpx solid #D9D9D9;
410
+        display: flex;
411
+        justify-content: space-between;
412
+        align-items: center;
413
+        font-size: 32rpx;
414
+        &:last-of-type{
415
+          border-bottom: none;
416
+        }
417
+        .Scanning_cont_list_title{
418
+          font-size: 32rpx;
419
+        }
420
+        .Scanning_cont_list_desc{
421
+          display: flex;
422
+          align-items: center;
423
+          position: relative;
424
+          .mask{
425
+            content: '';
426
+            position: absolute;
427
+            top: 0;
428
+            right: 50rpx;
429
+            bottom: 0;
430
+            left: 0;
431
+          }
432
+          .transport-sousuo{
433
+            position: absolute;
434
+            right: 56rpx;
435
+            color:#C3BFBF;
436
+          }
437
+          .newicon-saoma{
438
+            color: #50b249;
439
+          }
440
+          .newicon-xiala1{
441
+            position: absolute;
442
+            top: 50%;
443
+            right: 16rpx;
444
+            color:#C3BFBF;
445
+            transform: translateY(-50%);
446
+          }
447
+          .deptInput{
448
+            width: 213rpx;
449
+            height: 56rpx;
450
+            border: 1rpx solid #D9D9D9;
451
+            margin-right: 12rpx;
452
+            padding: 8rpx;
453
+            font-size: 28rpx;
454
+            padding-right: 50rpx;
455
+            box-sizing: border-box;
456
+            text-overflow: ellipsis;
457
+            overflow: hidden;
458
+            white-space: nowrap;
459
+          }
460
+          .typeInput{
461
+            font-size: 28rpx;
462
+            width: 260rpx;
463
+            height: 56rpx;
464
+            border: 1rpx solid #D9D9D9; 
465
+            padding: 8rpx;
466
+            padding-right: 50rpx;
467
+            box-sizing: border-box;
468
+            line-height: 38rpx;
469
+            text-overflow: ellipsis;
470
+            overflow: hidden;
471
+            white-space: nowrap;
472
+          }
473
+          .remarkInput{
474
+            font-size: 28rpx;
475
+            width: 500rpx;
476
+            height: 174rpx;
477
+            line-height: mormal;
478
+            border: 1rpx solid #D9D9D9; 
479
+            padding: 8rpx;
480
+            box-sizing: border-box;
481
+          }
482
+        }
483
+      }
484
+    }
485
+
486
+    .foot_btn {
487
+      margin: 57rpx 30rpx 10rpx;
488
+      flex-shrink: 0;
489
+      display: flex;
490
+      justify-content: center;
491
+
492
+      .btn {
493
+        height: 88rpx;
494
+        line-height: 1;
495
+        display: flex;
496
+        justify-content: center;
497
+        align-items: center;
498
+        flex: 1;
499
+        margin-right: 32rpx;
500
+        background-image: linear-gradient(to right, #72c172, #3bb197);
501
+        color: #fff;
502
+        border-radius: 8rpx;
503
+        font-size: 34rpx;
504
+        font-weight: bold;
505
+        &:last-of-type{
506
+          margin-right: 0;
507
+        }
508
+      }
509
+    }
510
+  }
511
+</style>

+ 292 - 0
pages/medicalWaste/medicalWasteBindCheck/medicalWasteBindCheck.vue

@@ -0,0 +1,292 @@
1
+<template>
2
+  <view class="Scanning_Result">
3
+    <view class="Scanning_top">
4
+      <view class="Scanning_top_icon">
5
+        <text class="cubeic-ok icon_transport transport-duigou"></text>
6
+      </view>
7
+      <view class="Scanning_top_text">
8
+        <text>回收医废科室为“{{queryObj.deptName}}”,总重量为{{weightTotal}}kg,{{countTotal}}袋医废。</text>
9
+        <text>请扫描人员工牌或科室码交接。</text>
10
+      </view>
11
+    </view>
12
+
13
+    <view class="Scanning_cont">
14
+      <view class="Scanning_cont_head">
15
+        <view>医废类型</view>
16
+        <view>医废袋数</view>
17
+        <view>医废重量</view>
18
+      </view>
19
+      <scroll-view scroll-y style="flex: 1;min-height: 0;">
20
+        <view class="Scanning_cont_list" v-for="item in infoList" :key="item.wasteTypeId">
21
+          <view>{{item.wasteType}}</view>
22
+          <view>{{item.wasteCount}}袋</view>
23
+          <view>{{item.wasteWeight}}kg</view>
24
+        </view>
25
+      </scroll-view>
26
+    </view>
27
+
28
+    <view class="foot_btn">
29
+      <view class="btn" @click="scanDeptOrUser()"> 扫一扫 </view>
30
+      <view class="btn" @click="goBack()"> 取消 </view>
31
+    </view>
32
+    <!-- 弹窗 -->
33
+    <showModel :title="models1.title" :icon="models1.icon" :disjunctor="models1.disjunctor" :content="models1.content"  @know="know1" :operate="models1.operate"></showModel>
34
+  </view>
35
+</template>
36
+<script>
37
+  import {
38
+    get,
39
+    post,
40
+    SM,
41
+    webHandle
42
+  } from "../../../http/http.js";
43
+  import Big from 'big.js';
44
+  export default {
45
+    data() {
46
+      return {
47
+        countTotal: 0,
48
+        weightTotal: 0,
49
+        SMFlag: true,
50
+        infoList: [],
51
+        hosId: uni.getStorageSync('userData').user.currentHospital.id,
52
+        queryObj: {}, //路由传递过来的数据
53
+        // 弹窗model
54
+        models1: {
55
+          disjunctor: false,
56
+        },
57
+      };
58
+    },
59
+    onShow() {
60
+      this.SMFlag = true;
61
+    },
62
+    methods: {
63
+      // 扫科室或人
64
+      scanDeptOrUser() {
65
+        if (!this.SMFlag) {
66
+          return;
67
+        }
68
+        this.SMFlag = false;
69
+        SM().then((content) => {
70
+          uni.showLoading({
71
+            title: "加载中",
72
+            mask: true,
73
+          });
74
+          //检验二维码的有效性(扫码前必须验证)
75
+          post("/dept/scanning", {
76
+              content,
77
+            })
78
+            .then((result) => {
79
+              this.SMFlag = true;
80
+              // 200检测通过,201没有有效期也通过。
81
+              if (result.state == 200 || result.state == 201) {
82
+                let data = {
83
+                  code: result.code, //二维码
84
+                };
85
+                
86
+                post("/medicalWaste/checkComplete", {
87
+                  code: result.code,
88
+                  deptId: +this.queryObj.deptId,
89
+                  hosId: this.hosId,
90
+                  clinicalWasteTypeIds: this.infoList.map(v => v.wasteTypeId).toString(),
91
+                })
92
+                  .then((res) => {
93
+                    uni.hideLoading();
94
+                    if (res.status == 200 && res.data) {
95
+                      this.showModel1(res.data, res.type);
96
+                    } else {
97
+                      uni.showToast({
98
+                        icon: "none",
99
+                        title: res.msg || "接口获取数据失败!",
100
+                      });
101
+                    }
102
+                  });
103
+              } else {
104
+                uni.hideLoading();
105
+                uni.showToast({
106
+                  icon: "none",
107
+                  title: result.info || "接口获取数据失败!",
108
+                });
109
+              }
110
+            })
111
+        }).catch(err => {
112
+          this.SMFlag = true;
113
+        });
114
+      },
115
+      getInfo(){
116
+        uni.showLoading({
117
+          title: "加载中",
118
+          mask: true,
119
+        });
120
+        post("/medicalWaste/checkComplete", {
121
+            deptId: +this.queryObj.deptId,
122
+            hosId: this.hosId
123
+          }).then((result) => {
124
+          uni.hideLoading();
125
+          if (result.status == 200) {
126
+            this.infoList = result.data || [];
127
+            this.countTotal = this.infoList.reduce((pre, cur) => pre + cur.wasteCount, 0);
128
+            this.weightTotal = this.infoList.reduce((pre, cur) => Big(pre).plus(cur.wasteWeight), 0);
129
+          } else {
130
+            uni.showToast({
131
+              icon: "none",
132
+              title: result.msg || "接口获取数据失败!",
133
+            });
134
+          }
135
+        });
136
+      },
137
+      goBack(){
138
+        uni.navigateBack();
139
+      },
140
+      //知道了
141
+      know1() {
142
+        this.models1.disjunctor = false;
143
+        uni.navigateTo({
144
+          url: `/pages/receiptpage/receiptpage`,
145
+        });
146
+      },
147
+      // 被服送回弹窗
148
+      showModel1(data, type) {
149
+        let content = '';
150
+        if(type === 'dept'){
151
+          content = `您与<strong class="red">${data.dept}</strong>成功交接,总重量为<strong class="red">${this.weightTotal}kg</strong>,<strong class="red">${this.countTotal}袋</strong>医废`;
152
+        }else if(type === 'user'){
153
+          content = `您与<strong class="red">${data.name}</strong>,<strong class="red">${data.dept?data.dept.dept:''}</strong>成功交接,总重量为<strong class="red">${this.weightTotal}kg</strong>,<strong class="red">${this.countTotal}袋</strong>医废`;
154
+        }
155
+        
156
+        this.models1 = {
157
+          disjunctor: true,
158
+          title: "提示",
159
+          content,
160
+          icon: "warn",
161
+          operate: {
162
+            know: "知道了",
163
+          },
164
+        };
165
+      },
166
+    },
167
+    onLoad(options) {
168
+      console.log(options, "result");
169
+      this.queryObj = options;
170
+      this.getInfo();
171
+      // #ifdef APP-PLUS
172
+      webHandle("no", "app");
173
+      // #endif
174
+      // #ifdef H5
175
+      webHandle("no", "wx");
176
+      // #endif
177
+    },
178
+  };
179
+</script>
180
+<style lang="less" scoped>
181
+  .Scanning_Result {
182
+    height: 100vh;
183
+    display: flex;
184
+    flex-direction: column;
185
+    background-color: #fff;
186
+    .yf /deep/ .uni-input-input[disabled]{
187
+      text-overflow: ellipsis;
188
+    }
189
+    .Scanning_top {
190
+      flex-shrink: 0;
191
+      .Scanning_top_icon {
192
+        padding-top: 26rpx;
193
+        display: flex;
194
+        flex-direction: column;
195
+        justify-content: center;
196
+        align-items: center;
197
+
198
+        .cubeic-ok {
199
+          font-size: 100rpx;
200
+          color: #35b34a;
201
+        }
202
+
203
+        .text1 {
204
+          font-size: 40rpx;
205
+          font-weight: bold;
206
+        }
207
+      }
208
+      .Scanning_top_text{
209
+        font-size: 34rpx;
210
+        font-weight: bold;
211
+        padding: 26rpx 32rpx 38rpx 32rpx;
212
+        display: flex;
213
+        flex-direction: column;
214
+        line-height: 1.5;
215
+        text{
216
+          word-break: break-all;
217
+        }
218
+      }
219
+    }
220
+
221
+    .Scanning_cont {
222
+      flex: 1;
223
+      min-height: 0;
224
+      display: flex;
225
+      flex-direction: column;
226
+      width: 710rpx;
227
+      margin: 0 20rpx;
228
+      padding: 6rpx;
229
+      font-size: 28rpx;
230
+      line-height: 1;
231
+      .Scanning_cont_head{
232
+        font-weight: bold;
233
+        height: 92rpx;
234
+        background: #FBFCFE;
235
+        box-shadow: 0rpx 3rpx 6rpx 1rpx rgba(0,0,0,0.16);
236
+        display: flex;
237
+        align-items: center;
238
+        font-size: 32rpx;
239
+        view{
240
+          flex: 1;
241
+          flex-shrink: 0;
242
+          text-align: center;
243
+          text-overflow: ellipsis;
244
+          overflow: hidden;
245
+          white-space: nowrap;
246
+        }
247
+      }
248
+      .Scanning_cont_list{
249
+        font-weight: bold;
250
+        padding: 27rpx 0;
251
+        border-bottom: 1rpx solid #D9D9D9;
252
+        display: flex;
253
+        align-items: center;
254
+        font-size: 32rpx;
255
+        view{
256
+          flex: 1;
257
+          flex-shrink: 0;
258
+          text-align: center;
259
+          text-overflow: ellipsis;
260
+          overflow: hidden;
261
+          white-space: nowrap;
262
+          line-height: normal;
263
+        }
264
+      }
265
+    }
266
+
267
+    .foot_btn {
268
+      margin: 57rpx 30rpx 10rpx;
269
+      flex-shrink: 0;
270
+      display: flex;
271
+      justify-content: center;
272
+
273
+      .btn {
274
+        height: 88rpx;
275
+        line-height: 1;
276
+        display: flex;
277
+        justify-content: center;
278
+        align-items: center;
279
+        flex: 1;
280
+        margin-right: 32rpx;
281
+        background-image: linear-gradient(to right, #72c172, #3bb197);
282
+        color: #fff;
283
+        border-radius: 8rpx;
284
+        font-size: 34rpx;
285
+        font-weight: bold;
286
+        &:last-of-type{
287
+          margin-right: 0;
288
+        }
289
+      }
290
+    }
291
+  }
292
+</style>

+ 282 - 0
pages/medicalWaste/medicalWasteDetail/medicalWasteDetail.vue

@@ -0,0 +1,282 @@
1
+<template>
2
+  <view class="Scanning_Result">
3
+    <view class="Scanning_top">
4
+      <view class="Scanning_top_text">
5
+        医废详情
6
+      </view>
7
+    </view>
8
+
9
+    <scroll-view scroll-y class="Scanning_cont">
10
+      <view class="Scanning_cont_list">
11
+        <view class="Scanning_cont_list_head">
12
+          <view class="circle"></view>
13
+          <view class="title">详情内容</view>
14
+        </view>
15
+        <view class="Scanning_cont_list_body">
16
+          <view class="Scanning_cont_list_body_item">
17
+            <view class="Scanning_cont_list_body_title">医废类型:</view>
18
+            <view class="Scanning_cont_list_body_desc">{{info.clinicalWasteType ? info.clinicalWasteType.typeName : ''}}</view>
19
+          </view>
20
+          <view class="Scanning_cont_list_body_item">
21
+            <view class="Scanning_cont_list_body_title">医废序号:</view>
22
+            <view class="Scanning_cont_list_body_desc">{{info.clinicalWasteSn}}</view>
23
+          </view>
24
+          <view class="Scanning_cont_list_body_item">
25
+            <view class="Scanning_cont_list_body_title">医废重量:</view>
26
+            <view class="Scanning_cont_list_body_desc">{{info.weight}}kg</view>
27
+          </view>
28
+          <view class="Scanning_cont_list_body_item">
29
+            <view class="Scanning_cont_list_body_title">申请科室:</view>
30
+            <view class="Scanning_cont_list_body_desc">{{info.dept ? info.dept.dept : ''}}</view>
31
+          </view>
32
+          <view class="Scanning_cont_list_body_item">
33
+            <view class="Scanning_cont_list_body_title">收取人:</view>
34
+            <view class="Scanning_cont_list_body_desc">{{info.receivor ? info.receivor.name : ''}}</view>
35
+          </view>
36
+          <view class="Scanning_cont_list_body_item">
37
+            <view class="Scanning_cont_list_body_title">收取时间:</view>
38
+            <view class="Scanning_cont_list_body_desc">{{info.receiveTime | formatDate('yyyy-MM-dd hh:mm:ss')}}</view>
39
+          </view>
40
+          <view class="Scanning_cont_list_body_item">
41
+            <view class="Scanning_cont_list_body_title">交接人:</view>
42
+            <view class="Scanning_cont_list_body_desc">{{info.handover ? info.handover.name : ''}}</view>
43
+          </view>
44
+          <view class="Scanning_cont_list_body_item">
45
+            <view class="Scanning_cont_list_body_title">备注:</view>
46
+            <view class="Scanning_cont_list_body_desc">{{info.remark}}</view>
47
+          </view>
48
+        </view>
49
+      </view>
50
+      <view class="Scanning_cont_list">
51
+        <view class="Scanning_cont_list_head">
52
+          <view class="circle"></view>
53
+          <view class="title">操作日志</view>
54
+        </view>
55
+        <view class="Scanning_cont_list_log">
56
+          <view class="Scanning_cont_list_log_item" v-for="(item, index) in info.wasteLogList" :key="index">
57
+            <view class="Scanning_cont_list_log_title">
58
+              <view class="statusText">{{item.operationType ? item.operationType.name : ''}}</view>
59
+              <view class="statusIcon newicon newicon-icon_zhengzaijinx"></view>
60
+              <view class="statusDate">{{item.operationTime | formatDate('MM-dd hh:mm')}}</view>
61
+              <view class="statusUser">{{item.operatorName}}</view>
62
+            </view>
63
+            <view class="Scanning_cont_list_log_desc" :class="{noBorder: index == info.wasteLogList.length - 1}" v-if="item.operationType.value == 5 && item.correctWeight && item.correctWeight">矫正前为{{item.correctWeight}}kg,矫正后为{{item.lastWeight}}kg</view>
64
+            <view class="Scanning_cont_list_log_desc" :class="{noBorder: index == info.wasteLogList.length - 1}" v-else-if="item.handoverName">交接人:{{item.handoverName}}</view>
65
+            <view class="Scanning_cont_list_log_desc" :class="{noBorder: index == info.wasteLogList.length - 1}" v-else></view>
66
+          </view>
67
+        </view>
68
+      </view>
69
+    </scroll-view>
70
+
71
+    <view class="foot_btn">
72
+      <view class="btn" @click="goToList()"> 知道了 </view>
73
+    </view>
74
+  </view>
75
+</template>
76
+<script>
77
+  import {
78
+    get,
79
+    post,
80
+    SM,
81
+    webHandle
82
+  } from "../../../http/http.js";
83
+  export default {
84
+    data() {
85
+      return {
86
+        info: {},
87
+        hosId: uni.getStorageSync('userData').user.currentHospital.id,
88
+        queryObj: {}, //路由传递过来的数据
89
+      };
90
+    },
91
+    methods: {
92
+      goToList(){
93
+        uni.navigateTo({
94
+          url: `/pages/receiptpage/receiptpage`,
95
+        });
96
+      },
97
+      getInfo(){
98
+        uni.showLoading({
99
+          title: "加载中",
100
+          mask: true,
101
+        });
102
+        post("/medicalWaste/details", {
103
+          code: this.queryObj.qrcode,
104
+          hosId: this.hosId,
105
+        }).then((result) => {
106
+          uni.hideLoading();
107
+          if (result.status == 200) {
108
+            let info = result.wasteDetails || {};
109
+            info.wasteLogList = info.wasteLogList || [];
110
+            this.info = info;
111
+          } else {
112
+            uni.showToast({
113
+              icon: "none",
114
+              title: result.msg || "接口获取数据失败!",
115
+            });
116
+          }
117
+        });
118
+      },
119
+    },
120
+    onLoad(options) {
121
+      console.log(options, "result");
122
+      this.queryObj = options;
123
+      this.getInfo();
124
+      // #ifdef APP-PLUS
125
+      webHandle("no", "app");
126
+      // #endif
127
+      // #ifdef H5
128
+      webHandle("no", "wx");
129
+      // #endif
130
+    },
131
+  };
132
+</script>
133
+<style lang="less" scoped>
134
+  .Scanning_Result {
135
+    height: 100vh;
136
+    display: flex;
137
+    flex-direction: column;
138
+    background-color: #F9FAFC;
139
+    .yf /deep/ .uni-input-input[disabled]{
140
+      text-overflow: ellipsis;
141
+    }
142
+    .Scanning_top {
143
+      flex-shrink: 0;
144
+      .Scanning_top_icon {
145
+        padding-top: 26rpx;
146
+        display: flex;
147
+        flex-direction: column;
148
+        justify-content: center;
149
+        align-items: center;
150
+
151
+        .cubeic-ok {
152
+          font-size: 100rpx;
153
+          color: #35b34a;
154
+        }
155
+
156
+        .text1 {
157
+          font-size: 40rpx;
158
+          font-weight: bold;
159
+        }
160
+      }
161
+      .Scanning_top_text{
162
+        text-align: center;
163
+        font-size: 36rpx;
164
+        font-weight: bold;
165
+        padding: 26rpx 0 38rpx 0;
166
+      }
167
+    }
168
+
169
+    .Scanning_cont {
170
+      flex: 1;
171
+      min-height: 0;
172
+      display: flex;
173
+      flex-direction: column;
174
+      margin: 0 20rpx;
175
+      padding: 14rpx;
176
+      background-color: #fff;
177
+      border: 1rpx solid #CBCBCB;
178
+      border-radius: 8rpx;
179
+      font-size: 28rpx;
180
+      width: calc(100% - 20rpx);
181
+      .Scanning_cont_list{
182
+        font-weight: bold;
183
+        padding: 0 6rpx;
184
+        font-size: 32rpx;
185
+        margin-bottom: 20rpx;
186
+        .Scanning_cont_list_head{
187
+          height: 65rpx;
188
+          display: flex;
189
+          align-items: center;
190
+          border-bottom: 1rpx dashed #CCCCCC;
191
+         .circle{
192
+           width: 22rpx;
193
+           height: 22rpx;
194
+           border-radius: 50%;
195
+           background-color: #49B856;
196
+           margin-right: 7rpx;
197
+         }
198
+         .title{
199
+           font-size: 28rpx;
200
+           font-weight: bold;
201
+         }
202
+        }
203
+        .Scanning_cont_list_body{
204
+          padding: 0 46rpx;
205
+          font-size: 28rpx;
206
+          .Scanning_cont_list_body_item{
207
+            margin-top: 20rpx;
208
+            overflow: hidden;
209
+            display: flex;
210
+            .Scanning_cont_list_body_title{
211
+              float: left;
212
+            }
213
+            .Scanning_cont_list_body_desc{
214
+              float: left;
215
+              flex: 1;
216
+            }
217
+          }
218
+        }
219
+        .Scanning_cont_list_log{
220
+          padding: 25rpx 86rpx;
221
+          font-size: 28rpx;
222
+          .Scanning_cont_list_log_item{
223
+            .Scanning_cont_list_log_title{
224
+              display: flex;
225
+              line-height: 1;
226
+              .statusText{
227
+                width: 2em;
228
+                position: absolute;
229
+              }
230
+              .statusIcon{
231
+                margin-left: 78rpx;
232
+                margin-right: 7rpx;
233
+                color: #35B24A;
234
+              }
235
+              .statusDate{
236
+                margin-right: 20rpx;
237
+                color: #A5A5A5;
238
+              }
239
+              .statusUser{
240
+                color: #A5A5A5;
241
+              }
242
+            }
243
+            .Scanning_cont_list_log_desc{
244
+              padding: 10rpx 20rpx;
245
+              height: 85rpx;
246
+              border-left: 2rpx solid #35B24A;
247
+              margin-left: 92rpx;
248
+              &.noBorder{
249
+                border-left: none;
250
+              }
251
+            }
252
+          }
253
+        }
254
+      }
255
+    }
256
+
257
+    .foot_btn {
258
+      margin: 57rpx 20rpx 10rpx;
259
+      flex-shrink: 0;
260
+      display: flex;
261
+      justify-content: center;
262
+
263
+      .btn {
264
+        height: 88rpx;
265
+        line-height: 1;
266
+        display: flex;
267
+        justify-content: center;
268
+        align-items: center;
269
+        flex: 1;
270
+        margin-right: 32rpx;
271
+        background-image: linear-gradient(to right, #72c172, #3bb197);
272
+        color: #fff;
273
+        border-radius: 8rpx;
274
+        font-size: 34rpx;
275
+        font-weight: bold;
276
+        &:last-of-type{
277
+          margin-right: 0;
278
+        }
279
+      }
280
+    }
281
+  }
282
+</style>

+ 19 - 2
pages/search/search.vue

@@ -88,6 +88,12 @@
88 88
         //自选排班-科室绑定人员-科室类型 start
89 89
         quickCombinationDeptType: 0,
90 90
         //自选排班-科室绑定人员-科室类型 end
91
+        //医废绑定 start
92
+        medicalWasteBindCode: '',
93
+        medicalWasteBindRemark: '',
94
+        medicalWasteBindWeight: '',
95
+        medicalWasteTypeIndex: '',
96
+        //医废绑定 end
91 97
       };
92 98
     },
93 99
     onUnload() {
@@ -127,6 +133,12 @@
127 133
         this.sysDeptType = -1;
128 134
       }  else if (this.type == "pharmacy") { //药房切换科室
129 135
         this.sysDeptType = 386;
136
+      }  else if (this.type == "medicalWasteBind") { //医废绑定
137
+        this.medicalWasteBindCode = options.code;
138
+        this.medicalWasteBindRemark = options.remark;
139
+        this.medicalWasteBindWeight = options.weight;
140
+        this.medicalWasteTypeIndex = options.medicalWasteTypeIndex;
141
+        this.sysDeptType = -1;
130 142
       }  else if (this.type == "showDepartmentQrcode") { //科室二维码绑定
131 143
         this.sysDeptType = -1;
132 144
       }  else if (this.type == "bloodSelect") { //选择血制品送达科室
@@ -251,7 +263,7 @@
251 263
           }
252 264
         }
253 265
         //不是送回病房
254
-        if (this.type != "sendBack" && this.type != "sendBackPatientList" && this.type != "settingCode" && this.type != "bloodSelect" && this.type != "showDepartmentQrcode") {
266
+        if (this.type != "sendBack" && this.type != "sendBackPatientList" && this.type != "settingCode" && this.type != "bloodSelect" && this.type != "showDepartmentQrcode" && this.type != "medicalWasteBind") {
255 267
           if(this.quickCombinationDeptType){
256 268
             postData.department.deptTypeIds = this.quickCombinationDeptType;
257 269
           } else if (this.sysDeptType === 0) {
@@ -388,7 +400,7 @@
388 400
         let arr = this.deptList.filter((item) => data.qrId ? (item.qrId === data.qrId) : (item.dept === keyword));
389 401
         if (arr.length) {
390 402
           let msg = "";
391
-          if (this.type == "patientInformationList" || this.type == "inspectList" || this.type == "pharmacy" || this.type == "showDepartmentQrcode") {
403
+          if (this.type == "patientInformationList" || this.type == "inspectList" || this.type == "pharmacy" || this.type == "showDepartmentQrcode" || this.type == "medicalWasteBind") {
392 404
             msg = "切换科室成功";
393 405
             uni.showToast({
394 406
               title: msg,
@@ -428,6 +440,11 @@
428 440
             uni.navigateTo({
429 441
               url: `../receiptpage/receiptpage?showDepartmentQrcodeId=${arr[0].id}&showDepartmentQrcodeDept=${arr[0].dept}`,
430 442
             });
443
+          } else if (this.type == "medicalWasteBind") {
444
+            //医废绑定进入
445
+            uni.navigateTo({
446
+              url: `/pages/medicalWaste/medicalWasteBind/medicalWasteBind?qrcode=${this.medicalWasteBindCode}&deptId=${arr[0].id}&deptName=${arr[0].dept}&remark=${this.medicalWasteBindRemark}&weight=${this.medicalWasteBindWeight}&medicalWasteTypeIndex=${this.medicalWasteTypeIndex}`,
447
+            });
431 448
           } else if (this.type == "setDept") {
432 449
             //上班添加科室进入
433 450
             let obj = uni.getStorageSync("setDepts");

+ 81 - 12
static/newIcon/demo_index.html

@@ -55,9 +55,27 @@
55 55
           <ul class="icon_lists dib-box">
56 56
           
57 57
             <li class="dib">
58
-              <span class="icon newicon">&#xe605;</span>
59
-                <div class="name">资源 7</div>
60
-                <div class="code-name">&amp;#xe605;</div>
58
+              <span class="icon newicon">&#xe635;</span>
59
+                <div class="name">icon_zhengzaijinx</div>
60
+                <div class="code-name">&amp;#xe635;</div>
61
+              </li>
62
+          
63
+            <li class="dib">
64
+              <span class="icon newicon">&#xe662;</span>
65
+                <div class="name">xiala02</div>
66
+                <div class="code-name">&amp;#xe662;</div>
67
+              </li>
68
+          
69
+            <li class="dib">
70
+              <span class="icon newicon">&#xe660;</span>
71
+                <div class="name">扫一扫</div>
72
+                <div class="code-name">&amp;#xe660;</div>
73
+              </li>
74
+          
75
+            <li class="dib">
76
+              <span class="icon newicon">&#xe60a;</span>
77
+                <div class="name">医废管理</div>
78
+                <div class="code-name">&amp;#xe60a;</div>
61 79
               </li>
62 80
           
63 81
             <li class="dib">
@@ -90,9 +108,9 @@
90 108
 <pre><code class="language-css"
91 109
 >@font-face {
92 110
   font-family: 'newicon';
93
-  src: url('iconfont.woff2?t=1698546579618') format('woff2'),
94
-       url('iconfont.woff?t=1698546579618') format('woff'),
95
-       url('iconfont.ttf?t=1698546579618') format('truetype');
111
+  src: url('iconfont.woff2?t=1709362538844') format('woff2'),
112
+       url('iconfont.woff?t=1709362538844') format('woff'),
113
+       url('iconfont.ttf?t=1709362538844') format('truetype');
96 114
 }
97 115
 </code></pre>
98 116
           <h3 id="-iconfont-">第二步:定义使用 iconfont 的样式</h3>
@@ -119,11 +137,38 @@
119 137
         <ul class="icon_lists dib-box">
120 138
           
121 139
           <li class="dib">
122
-            <span class="icon newicon newicon-a-ziyuan71"></span>
140
+            <span class="icon newicon newicon-icon_zhengzaijinx"></span>
141
+            <div class="name">
142
+              icon_zhengzaijinx
143
+            </div>
144
+            <div class="code-name">.newicon-icon_zhengzaijinx
145
+            </div>
146
+          </li>
147
+          
148
+          <li class="dib">
149
+            <span class="icon newicon newicon-xiala1"></span>
150
+            <div class="name">
151
+              xiala02
152
+            </div>
153
+            <div class="code-name">.newicon-xiala1
154
+            </div>
155
+          </li>
156
+          
157
+          <li class="dib">
158
+            <span class="icon newicon newicon-saoma"></span>
123 159
             <div class="name">
124
-              资源 7
160
+              扫一扫
125 161
             </div>
126
-            <div class="code-name">.newicon-a-ziyuan71
162
+            <div class="code-name">.newicon-saoma
163
+            </div>
164
+          </li>
165
+          
166
+          <li class="dib">
167
+            <span class="icon newicon newicon-yifeiguanli"></span>
168
+            <div class="name">
169
+              医废管理
170
+            </div>
171
+            <div class="code-name">.newicon-yifeiguanli
127 172
             </div>
128 173
           </li>
129 174
           
@@ -174,10 +219,34 @@
174 219
           
175 220
             <li class="dib">
176 221
                 <svg class="icon svg-icon" aria-hidden="true">
177
-                  <use xlink:href="#newicon-a-ziyuan71"></use>
222
+                  <use xlink:href="#newicon-icon_zhengzaijinx"></use>
223
+                </svg>
224
+                <div class="name">icon_zhengzaijinx</div>
225
+                <div class="code-name">#newicon-icon_zhengzaijinx</div>
226
+            </li>
227
+          
228
+            <li class="dib">
229
+                <svg class="icon svg-icon" aria-hidden="true">
230
+                  <use xlink:href="#newicon-xiala1"></use>
231
+                </svg>
232
+                <div class="name">xiala02</div>
233
+                <div class="code-name">#newicon-xiala1</div>
234
+            </li>
235
+          
236
+            <li class="dib">
237
+                <svg class="icon svg-icon" aria-hidden="true">
238
+                  <use xlink:href="#newicon-saoma"></use>
239
+                </svg>
240
+                <div class="name">扫一扫</div>
241
+                <div class="code-name">#newicon-saoma</div>
242
+            </li>
243
+          
244
+            <li class="dib">
245
+                <svg class="icon svg-icon" aria-hidden="true">
246
+                  <use xlink:href="#newicon-yifeiguanli"></use>
178 247
                 </svg>
179
-                <div class="name">资源 7</div>
180
-                <div class="code-name">#newicon-a-ziyuan71</div>
248
+                <div class="name">医废管理</div>
249
+                <div class="code-name">#newicon-yifeiguanli</div>
181 250
             </li>
182 251
           
183 252
             <li class="dib">

+ 17 - 5
static/newIcon/iconfont.css

@@ -1,8 +1,8 @@
1 1
 @font-face {
2 2
   font-family: "newicon"; /* Project id 4304849 */
3
-  src: url('~@/static/newIcon/iconfont.woff2?t=1698546579618') format('woff2'),
4
-       url('~@/static/newIcon/iconfont.woff?t=1698546579618') format('woff'),
5
-       url('~@/static/newIcon/iconfont.ttf?t=1698546579618') format('truetype');
3
+  src: url('~@/static/newIcon/iconfont.woff2?t=1709362538844') format('woff2'),
4
+       url('~@/static/newIcon/iconfont.woff?t=1709362538844') format('woff'),
5
+       url('~@/static/newIcon/iconfont.ttf?t=1709362538844') format('truetype');
6 6
 }
7 7
 
8 8
 .newicon {
@@ -13,8 +13,20 @@
13 13
   -moz-osx-font-smoothing: grayscale;
14 14
 }
15 15
 
16
-.newicon-a-ziyuan71:before {
17
-  content: "\e605";
16
+.newicon-icon_zhengzaijinx:before {
17
+  content: "\e635";
18
+}
19
+
20
+.newicon-xiala1:before {
21
+  content: "\e662";
22
+}
23
+
24
+.newicon-saoma:before {
25
+  content: "\e660";
26
+}
27
+
28
+.newicon-yifeiguanli:before {
29
+  content: "\e60a";
18 30
 }
19 31
 
20 32
 .newicon-a-ziyuan7:before {

File diff suppressed because it is too large
+ 1 - 1
static/newIcon/iconfont.js


+ 26 - 5
static/newIcon/iconfont.json

@@ -6,11 +6,32 @@
6 6
   "description": "",
7 7
   "glyphs": [
8 8
     {
9
-      "icon_id": "37864835",
10
-      "name": "资源 7",
11
-      "font_class": "a-ziyuan71",
12
-      "unicode": "e605",
13
-      "unicode_decimal": 58885
9
+      "icon_id": "4852661",
10
+      "name": "icon_zhengzaijinx",
11
+      "font_class": "icon_zhengzaijinx",
12
+      "unicode": "e635",
13
+      "unicode_decimal": 58933
14
+    },
15
+    {
16
+      "icon_id": "5933299",
17
+      "name": "xiala02",
18
+      "font_class": "xiala1",
19
+      "unicode": "e662",
20
+      "unicode_decimal": 58978
21
+    },
22
+    {
23
+      "icon_id": "6757421",
24
+      "name": "扫一扫",
25
+      "font_class": "saoma",
26
+      "unicode": "e660",
27
+      "unicode_decimal": 58976
28
+    },
29
+    {
30
+      "icon_id": "39332508",
31
+      "name": "医废管理",
32
+      "font_class": "yifeiguanli",
33
+      "unicode": "e60a",
34
+      "unicode_decimal": 58890
14 35
     },
15 36
     {
16 37
       "icon_id": "37864731",

BIN
static/newIcon/iconfont.ttf


BIN
static/newIcon/iconfont.woff


BIN
static/newIcon/iconfont.woff2