浏览代码

消毒供应大屏

seimin 1 年之前
父节点
当前提交
e14c52594a

+ 8 - 4
angular.json

@@ -34,10 +34,12 @@
34 34
             ],
35 35
             "styles": [
36 36
               "src/styles.less",
37
-              "src/assets/iconfont/iconfont.css"
37
+              "src/assets/iconfont/iconfont.css",
38
+              "./node_modules/swiper/swiper-bundle.min.css"
38 39
             ],
39 40
             "scripts": [
40
-              "node_modules/echarts/dist/echarts.min.js"
41
+              "node_modules/echarts/dist/echarts.min.js",
42
+              "./node_modules/swiper/swiper-bundle.min.js"
41 43
             ]
42 44
           },
43 45
           "configurations": {
@@ -103,10 +105,12 @@
103 105
             ],
104 106
             "styles": [
105 107
               "src/styles.less",
106
-              "src/assets/iconfont/iconfont.css"
108
+              "src/assets/iconfont/iconfont.css",
109
+              "./node_modules/swiper/swiper-bundle.min.css"
107 110
             ],
108 111
             "scripts": [
109
-              "node_modules/echarts/dist/echarts.min.js"
112
+              "node_modules/echarts/dist/echarts.min.js",
113
+              "./node_modules/swiper/swiper-bundle.min.js"
110 114
             ]
111 115
           }
112 116
         },

+ 88 - 14
package-lock.json

@@ -18,12 +18,14 @@
18 18
         "@angular/router": "~8.1.1",
19 19
         "@types/crypto-js": "^3.1.47",
20 20
         "@types/overlayscrollbars": "^1.12.1",
21
+        "@types/swiper": "^6.0.0",
21 22
         "atmosphere.js": "2.3.6",
22 23
         "core-js": "^3.18.3",
23 24
         "crypto-js": "^3.3.0",
24 25
         "datatables.net": "^1.11.3",
25 26
         "date-fns": "^2.25.0",
26 27
         "echarts": "^4.6.0",
28
+        "lodash-es": "^4.17.21",
27 29
         "ng-zorro-antd": "^8.5.2",
28 30
         "ngx-echarts": "^4.2.2",
29 31
         "ngx-print": "^1.2.1",
@@ -33,6 +35,7 @@
33 35
         "overlayscrollbars-ngx": "^0.1.1",
34 36
         "rxjs": "~6.4.0",
35 37
         "sortablejs": "^1.14.0",
38
+        "swiper": "^6.8.4",
36 39
         "tslib": "^1.9.0",
37 40
         "viewerjs": "^0.10.0",
38 41
         "zone.js": "^0.9.1"
@@ -1092,6 +1095,15 @@
1092 1095
       "integrity": "sha1-AHiDYGP/rxdBI0m7o2QIfgrALsk=",
1093 1096
       "dev": true
1094 1097
     },
1098
+    "node_modules/@types/swiper": {
1099
+      "version": "6.0.0",
1100
+      "resolved": "https://registry.npmmirror.com/@types/swiper/-/swiper-6.0.0.tgz",
1101
+      "integrity": "sha512-QPZRgxZ+ivXXtzV43B3LxpXUIC7FE/EoKM+rtxngmgt2M7eeUYypZhyqZD8UxJtlBcUDw/ATGoVeSNpvBBrz2w==",
1102
+      "deprecated": "This is a stub types definition. swiper provides its own type definitions, so you do not need this installed.",
1103
+      "dependencies": {
1104
+        "swiper": "*"
1105
+      }
1106
+    },
1095 1107
     "node_modules/@types/webpack-sources": {
1096 1108
       "version": "0.1.8",
1097 1109
       "resolved": "https://registry.npm.taobao.org/@types/webpack-sources/download/@types/webpack-sources-0.1.8.tgz?cache=0&sync_timestamp=1613384834782&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40types%2Fwebpack-sources%2Fdownload%2F%40types%2Fwebpack-sources-0.1.8.tgz",
@@ -3723,6 +3735,14 @@
3723 3735
         "void-elements": "^2.0.0"
3724 3736
       }
3725 3737
     },
3738
+    "node_modules/dom7": {
3739
+      "version": "3.0.0",
3740
+      "resolved": "https://registry.npmmirror.com/dom7/-/dom7-3.0.0.tgz",
3741
+      "integrity": "sha512-oNlcUdHsC4zb7Msx7JN3K0Nro1dzJ48knvBOnDPKJ2GV9wl1i5vydJZUSyOfrkKFDZEud/jBsTk92S/VGSAe/g==",
3742
+      "dependencies": {
3743
+        "ssr-window": "^3.0.0-alpha.1"
3744
+      }
3745
+    },
3726 3746
     "node_modules/domain-browser": {
3727 3747
       "version": "1.2.0",
3728 3748
       "resolved": "https://registry.nlark.com/domain-browser/download/domain-browser-1.2.0.tgz",
@@ -6913,6 +6933,11 @@
6913 6933
       "integrity": "sha1-Z5WRxWTDv/quhFTPCz3zcMPWkRw=",
6914 6934
       "dev": true
6915 6935
     },
6936
+    "node_modules/lodash-es": {
6937
+      "version": "4.17.21",
6938
+      "resolved": "https://registry.npmmirror.com/lodash-es/-/lodash-es-4.17.21.tgz",
6939
+      "integrity": "sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw=="
6940
+    },
6916 6941
     "node_modules/lodash.clonedeep": {
6917 6942
       "version": "4.5.0",
6918 6943
       "resolved": "https://registry.npm.taobao.org/lodash.clonedeep/download/lodash.clonedeep-4.5.0.tgz",
@@ -14904,6 +14929,11 @@
14904 14929
         "node": ">=0.10.0"
14905 14930
       }
14906 14931
     },
14932
+    "node_modules/ssr-window": {
14933
+      "version": "3.0.0",
14934
+      "resolved": "https://registry.npmmirror.com/ssr-window/-/ssr-window-3.0.0.tgz",
14935
+      "integrity": "sha512-q+8UfWDg9Itrg0yWK7oe5p/XRCJpJF9OBtXfOPgSJl+u3Xd5KI328RUEvUqSMVM9CiQUEf1QdBzJMkYGErj9QA=="
14936
+    },
14907 14937
     "node_modules/ssri": {
14908 14938
       "version": "6.0.2",
14909 14939
       "resolved": "https://registry.npm.taobao.org/ssri/download/ssri-6.0.2.tgz?cache=0&sync_timestamp=1617826544307&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fssri%2Fdownload%2Fssri-6.0.2.tgz",
@@ -15225,6 +15255,19 @@
15225 15255
         "node": ">=4"
15226 15256
       }
15227 15257
     },
15258
+    "node_modules/swiper": {
15259
+      "version": "6.8.4",
15260
+      "resolved": "https://registry.npmmirror.com/swiper/-/swiper-6.8.4.tgz",
15261
+      "integrity": "sha512-O+buF9Q+sMA0H7luMS8R59hCaJKlpo8PXhQ6ZYu6Rn2v9OsFd4d1jmrv14QvxtQpKAvL/ZiovEeANI/uDGet7g==",
15262
+      "hasInstallScript": true,
15263
+      "dependencies": {
15264
+        "dom7": "^3.0.0",
15265
+        "ssr-window": "^3.0.0"
15266
+      },
15267
+      "engines": {
15268
+        "node": ">= 4.7.0"
15269
+      }
15270
+    },
15228 15271
     "node_modules/symbol-observable": {
15229 15272
       "version": "1.2.0",
15230 15273
       "resolved": "https://registry.nlark.com/symbol-observable/download/symbol-observable-1.2.0.tgz",
@@ -17018,7 +17061,8 @@
17018 17061
     "node_modules/zone.js": {
17019 17062
       "version": "0.9.1",
17020 17063
       "resolved": "https://registry.npm.taobao.org/zone.js/download/zone.js-0.9.1.tgz",
17021
-      "integrity": "sha1-43xuXFTBP65N4mtf/o2OkhLabZs="
17064
+      "integrity": "sha1-43xuXFTBP65N4mtf/o2OkhLabZs=",
17065
+      "dev": true
17022 17066
     },
17023 17067
     "node_modules/zrender": {
17024 17068
       "version": "4.3.2",
@@ -17855,6 +17899,14 @@
17855 17899
       "integrity": "sha1-AHiDYGP/rxdBI0m7o2QIfgrALsk=",
17856 17900
       "dev": true
17857 17901
     },
17902
+    "@types/swiper": {
17903
+      "version": "6.0.0",
17904
+      "resolved": "https://registry.npmmirror.com/@types/swiper/-/swiper-6.0.0.tgz",
17905
+      "integrity": "sha512-QPZRgxZ+ivXXtzV43B3LxpXUIC7FE/EoKM+rtxngmgt2M7eeUYypZhyqZD8UxJtlBcUDw/ATGoVeSNpvBBrz2w==",
17906
+      "requires": {
17907
+        "swiper": "*"
17908
+      }
17909
+    },
17858 17910
     "@types/webpack-sources": {
17859 17911
       "version": "0.1.8",
17860 17912
       "resolved": "https://registry.npm.taobao.org/@types/webpack-sources/download/@types/webpack-sources-0.1.8.tgz?cache=0&sync_timestamp=1613384834782&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40types%2Fwebpack-sources%2Fdownload%2F%40types%2Fwebpack-sources-0.1.8.tgz",
@@ -18094,8 +18146,7 @@
18094 18146
       "version": "4.0.0",
18095 18147
       "resolved": "https://registry.npm.taobao.org/acorn-dynamic-import/download/acorn-dynamic-import-4.0.0.tgz",
18096 18148
       "integrity": "sha1-SCIQFAWCo2uDw+NC4c/ryqkkCUg=",
18097
-      "dev": true,
18098
-      "requires": {}
18149
+      "dev": true
18099 18150
     },
18100 18151
     "acorn-walk": {
18101 18152
       "version": "7.2.0",
@@ -18149,15 +18200,13 @@
18149 18200
       "version": "1.0.1",
18150 18201
       "resolved": "https://registry.npm.taobao.org/ajv-errors/download/ajv-errors-1.0.1.tgz",
18151 18202
       "integrity": "sha1-81mGrOuRr63sQQL72FAUlQzvpk0=",
18152
-      "dev": true,
18153
-      "requires": {}
18203
+      "dev": true
18154 18204
     },
18155 18205
     "ajv-keywords": {
18156 18206
       "version": "3.5.2",
18157 18207
       "resolved": "https://registry.npm.taobao.org/ajv-keywords/download/ajv-keywords-3.5.2.tgz?cache=0&sync_timestamp=1616882384060&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fajv-keywords%2Fdownload%2Fajv-keywords-3.5.2.tgz",
18158 18208
       "integrity": "sha1-MfKdpatuANHC0yms97WSlhTVAU0=",
18159
-      "dev": true,
18160
-      "requires": {}
18209
+      "dev": true
18161 18210
     },
18162 18211
     "amdefine": {
18163 18212
       "version": "1.0.1",
@@ -19258,8 +19307,7 @@
19258 19307
       "version": "5.0.2",
19259 19308
       "resolved": "https://registry.npm.taobao.org/circular-dependency-plugin/download/circular-dependency-plugin-5.0.2.tgz",
19260 19309
       "integrity": "sha1-2haMCzfntDVj+5+RLBwAfCEzie8=",
19261
-      "dev": true,
19262
-      "requires": {}
19310
+      "dev": true
19263 19311
     },
19264 19312
     "class-utils": {
19265 19313
       "version": "0.3.6",
@@ -20133,6 +20181,14 @@
20133 20181
         "void-elements": "^2.0.0"
20134 20182
       }
20135 20183
     },
20184
+    "dom7": {
20185
+      "version": "3.0.0",
20186
+      "resolved": "https://registry.npmmirror.com/dom7/-/dom7-3.0.0.tgz",
20187
+      "integrity": "sha512-oNlcUdHsC4zb7Msx7JN3K0Nro1dzJ48knvBOnDPKJ2GV9wl1i5vydJZUSyOfrkKFDZEud/jBsTk92S/VGSAe/g==",
20188
+      "requires": {
20189
+        "ssr-window": "^3.0.0-alpha.1"
20190
+      }
20191
+    },
20136 20192
     "domain-browser": {
20137 20193
       "version": "1.2.0",
20138 20194
       "resolved": "https://registry.nlark.com/domain-browser/download/domain-browser-1.2.0.tgz",
@@ -22654,8 +22710,7 @@
22654 22710
       "version": "1.7.0",
22655 22711
       "resolved": "https://registry.nlark.com/karma-jasmine-html-reporter/download/karma-jasmine-html-reporter-1.7.0.tgz",
22656 22712
       "integrity": "sha1-UsSJp012CTShCJv6XqSo/LhMwos=",
22657
-      "dev": true,
22658
-      "requires": {}
22713
+      "dev": true
22659 22714
     },
22660 22715
     "karma-source-map-support": {
22661 22716
       "version": "1.4.0",
@@ -22782,6 +22837,11 @@
22782 22837
       "integrity": "sha1-Z5WRxWTDv/quhFTPCz3zcMPWkRw=",
22783 22838
       "dev": true
22784 22839
     },
22840
+    "lodash-es": {
22841
+      "version": "4.17.21",
22842
+      "resolved": "https://registry.npmmirror.com/lodash-es/-/lodash-es-4.17.21.tgz",
22843
+      "integrity": "sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw=="
22844
+    },
22785 22845
     "lodash.clonedeep": {
22786 22846
       "version": "4.5.0",
22787 22847
       "resolved": "https://registry.npm.taobao.org/lodash.clonedeep/download/lodash.clonedeep-4.5.0.tgz",
@@ -26999,8 +27059,7 @@
26999 27059
     "overlayscrollbars-ngx": {
27000 27060
       "version": "0.1.1",
27001 27061
       "resolved": "https://registry.nlark.com/overlayscrollbars-ngx/download/overlayscrollbars-ngx-0.1.1.tgz",
27002
-      "integrity": "sha1-APyVynU9vV7by2Njp9AokJJVIow=",
27003
-      "requires": {}
27062
+      "integrity": "sha1-APyVynU9vV7by2Njp9AokJJVIow="
27004 27063
     },
27005 27064
     "p-defer": {
27006 27065
       "version": "1.0.0",
@@ -29071,6 +29130,11 @@
29071 29130
         "tweetnacl": "~0.14.0"
29072 29131
       }
29073 29132
     },
29133
+    "ssr-window": {
29134
+      "version": "3.0.0",
29135
+      "resolved": "https://registry.npmmirror.com/ssr-window/-/ssr-window-3.0.0.tgz",
29136
+      "integrity": "sha512-q+8UfWDg9Itrg0yWK7oe5p/XRCJpJF9OBtXfOPgSJl+u3Xd5KI328RUEvUqSMVM9CiQUEf1QdBzJMkYGErj9QA=="
29137
+    },
29074 29138
     "ssri": {
29075 29139
       "version": "6.0.2",
29076 29140
       "resolved": "https://registry.npm.taobao.org/ssri/download/ssri-6.0.2.tgz?cache=0&sync_timestamp=1617826544307&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fssri%2Fdownload%2Fssri-6.0.2.tgz",
@@ -29340,6 +29404,15 @@
29340 29404
         "has-flag": "^3.0.0"
29341 29405
       }
29342 29406
     },
29407
+    "swiper": {
29408
+      "version": "6.8.4",
29409
+      "resolved": "https://registry.npmmirror.com/swiper/-/swiper-6.8.4.tgz",
29410
+      "integrity": "sha512-O+buF9Q+sMA0H7luMS8R59hCaJKlpo8PXhQ6ZYu6Rn2v9OsFd4d1jmrv14QvxtQpKAvL/ZiovEeANI/uDGet7g==",
29411
+      "requires": {
29412
+        "dom7": "^3.0.0",
29413
+        "ssr-window": "^3.0.0"
29414
+      }
29415
+    },
29343 29416
     "symbol-observable": {
29344 29417
       "version": "1.2.0",
29345 29418
       "resolved": "https://registry.nlark.com/symbol-observable/download/symbol-observable-1.2.0.tgz",
@@ -30818,7 +30891,8 @@
30818 30891
     "zone.js": {
30819 30892
       "version": "0.9.1",
30820 30893
       "resolved": "https://registry.npm.taobao.org/zone.js/download/zone.js-0.9.1.tgz",
30821
-      "integrity": "sha1-43xuXFTBP65N4mtf/o2OkhLabZs="
30894
+      "integrity": "sha1-43xuXFTBP65N4mtf/o2OkhLabZs=",
30895
+      "dev": true
30822 30896
     },
30823 30897
     "zrender": {
30824 30898
       "version": "4.3.2",

+ 3 - 0
package.json

@@ -23,12 +23,14 @@
23 23
     "@angular/router": "~8.1.1",
24 24
     "@types/crypto-js": "^3.1.47",
25 25
     "@types/overlayscrollbars": "^1.12.1",
26
+    "@types/swiper": "^6.0.0",
26 27
     "atmosphere.js": "2.3.6",
27 28
     "core-js": "^3.18.3",
28 29
     "crypto-js": "^3.3.0",
29 30
     "datatables.net": "^1.11.3",
30 31
     "date-fns": "^2.25.0",
31 32
     "echarts": "^4.6.0",
33
+    "lodash-es": "^4.17.21",
32 34
     "ng-zorro-antd": "^8.5.2",
33 35
     "ngx-echarts": "^4.2.2",
34 36
     "ngx-print": "^1.2.1",
@@ -38,6 +40,7 @@
38 40
     "overlayscrollbars-ngx": "^0.1.1",
39 41
     "rxjs": "~6.4.0",
40 42
     "sortablejs": "^1.14.0",
43
+    "swiper": "^6.8.4",
41 44
     "tslib": "^1.9.0",
42 45
     "viewerjs": "^0.10.0",
43 46
     "zone.js": "^0.9.1"

+ 1 - 1
proxy.conf.json

@@ -1,6 +1,6 @@
1 1
 {
2 2
   "/service": {
3
-    "target": "http://192.168.4.240",
3
+    "target": "http://192.168.3.108",
4 4
     "logLevel": "debug",
5 5
     "changeOrigin": true,
6 6
     "pathRewrite": {

+ 6 - 0
src/app/app-routing.module.ts

@@ -6,6 +6,7 @@ import { FuwutaiGuard } from './guard/fuwutai.guard';//服务台权限
6 6
 import { MainGuard } from './guard/main.guard';//管理端权限
7 7
 import { PharmacyGuard } from './guard/pharmacy.guard';//药房端权限
8 8
 import { SpecimenView2Guard } from './guard/SpecimenView2Guard.guard';//标本视图权限
9
+import { DisinfectionSupplyGuard } from './guard/DisinfectionSupplyGuard.guard';
9 10
 const routes: Routes = [
10 11
   {
11 12
     path: '',
@@ -51,6 +52,11 @@ const routes: Routes = [
51 52
     canActivate: [SpecimenView2Guard]
52 53
   },
53 54
   {
55
+    path: 'disinfectionSupply',//全局业务查看
56
+    loadChildren: () => import('./views/disinfection-supply/disinfection-supply.module').then(m => m.DisinfectionSupplyModule),
57
+    canActivate: [DisinfectionSupplyGuard]
58
+  },
59
+  {
54 60
     // 问卷预览
55 61
     path: "preview",
56 62
     loadChildren: () => import("./views/preview/preview.module").then((m) => m.PreviewModule),

+ 0 - 1
src/app/app.component.ts

@@ -19,7 +19,6 @@ export class AppComponent {
19 19
       this.tool.setLogo(logoUrl);
20 20
       this.tool.setFavicon(faviconUrl);
21 21
       this.titleService.setTitle(this.tool.logoTitle);
22
-      console.log(document.querySelector('#favicon'));
23 22
       (document.querySelector('#favicon') as any).href = this.tool.faviconUrl;
24 23
     })
25 24
   }

+ 26 - 0
src/app/guard/DisinfectionSupplyGuard.guard.ts

@@ -0,0 +1,26 @@
1
+import { Injectable } from '@angular/core';
2
+import { CanActivate, Router } from '@angular/router';
3
+
4
+@Injectable({
5
+  providedIn: 'root'
6
+})
7
+export class DisinfectionSupplyGuard implements CanActivate  {
8
+  constructor(public router: Router) { }
9
+
10
+  canActivate(): boolean {
11
+    let menus = JSON.parse(localStorage.getItem('menu'));
12
+    let can = false;
13
+    if (menus) {
14
+      menus.forEach((e) => {
15
+        if (e.link == 'disinfectionSupply') {
16
+          can = true;
17
+        }
18
+      });
19
+    }
20
+    if (!can) {
21
+      this.router.navigate(['login']);
22
+      return false
23
+    }
24
+    return true;
25
+  }
26
+}

+ 17 - 0
src/app/views/disinfection-supply/disinfection-supply-routing.module.ts

@@ -0,0 +1,17 @@
1
+import { NgModule } from '@angular/core';
2
+import { Routes, RouterModule } from '@angular/router';
3
+import { DisinfectionSupplyComponent } from './disinfection-supply.component';
4
+
5
+
6
+const routes: Routes = [
7
+  {
8
+    path: "",
9
+    component: DisinfectionSupplyComponent,
10
+  },
11
+];
12
+
13
+@NgModule({
14
+  imports: [RouterModule.forChild(routes)],
15
+  exports: [RouterModule]
16
+})
17
+export class DisinfectionSupplyRoutingModule { }

+ 116 - 0
src/app/views/disinfection-supply/disinfection-supply.component.html

@@ -0,0 +1,116 @@
1
+<div class="mask" *ngIf="isMask">
2
+  <div class="con-wrap">
3
+    <div class="con">
4
+      <div class="title">配置</div>
5
+      <div class="conditions">
6
+        <div nz-row>
7
+          <div nz-col nzSpan="6"><span class="red">*</span>任务类型:</div>
8
+          <div nz-col nzSpan="15">
9
+            <div nz-row>
10
+              <nz-select class="w100" [nzDropdownMatchSelectWidth]="false" nzShowSearch nzPlaceHolder="请选择任务类型" nzServerSearch (nzOnSearch)="onSearchOtherTaskType($event)" [(ngModel)]="tasktype">
11
+                <ng-container *ngFor="let o of taskTypeList">
12
+                  <nz-option *ngIf="!searchLoading" [nzLabel]="o.taskName" [nzValue]="o.id"></nz-option>
13
+                </ng-container>
14
+                <nz-option *ngIf="searchLoading" nzDisabled nzCustomContent>
15
+                  <i nz-icon nzType="loading" class="loading-icon"></i>
16
+                  搜索中...
17
+                </nz-option>
18
+              </nz-select>
19
+            </div>
20
+          </div>
21
+        </div>
22
+        <div nz-row>
23
+          <div nz-col nzSpan="6"><span class="red">*</span>刷新时间:</div>
24
+          <div nz-col nzSpan="15">
25
+            <div nz-row>
26
+              <div nz-col nzSpan="">
27
+                <nz-input-group nzAddOnAfter="秒">
28
+                  <nz-input-number
29
+                    class="w100"
30
+                    [(ngModel)]="refreshTime"
31
+                    [nzMin]="10"
32
+                    [nzStep]="1"
33
+                    placeholder="请输入刷新时间"
34
+                  ></nz-input-number>
35
+                </nz-input-group>
36
+              </div>
37
+            </div>
38
+          </div>
39
+        </div>
40
+        <div nz-row>
41
+          <div nz-col nzSpan="6"><span class="red">*</span>切屏时间:</div>
42
+          <div nz-col nzSpan="15">
43
+            <div nz-row>
44
+              <div nz-col nzSpan="">
45
+                <nz-input-group nzAddOnAfter="秒">
46
+                  <nz-input-number
47
+                    class="w100"
48
+                    [(ngModel)]="screenCuttingTime"
49
+                    [nzMin]="10"
50
+                    [nzStep]="1"
51
+                    placeholder="请输入切屏时间"
52
+                  ></nz-input-number>
53
+                </nz-input-group>
54
+              </div>
55
+            </div>
56
+          </div>
57
+        </div>
58
+      </div>
59
+      <div class="btns display_flex justify-content_flex-center">
60
+        <button
61
+          nz-button
62
+          nzType="primary"
63
+          nzValue="small"
64
+          (click)="saveScreen()"
65
+        >
66
+          确定
67
+        </button>
68
+      </div>
69
+    </div>
70
+  </div>
71
+</div>
72
+<div class="screen" *ngIf="!isMask">
73
+  <!-- 头部 -->
74
+  <div class="screen_head">
75
+    <div class="screen_head_txt">
76
+      <h1>消毒供应中心下收下送实时表</h1>
77
+      <div class="left_oblique_line_image"></div>
78
+      <div class="right_oblique_line_image"></div>
79
+    </div>
80
+    <div class="left_line"></div>
81
+    <div class="right_line"></div>
82
+    <div class="left_oblique_line"></div>
83
+    <div class="right_oblique_line"></div>
84
+    <div class="bottom_line"></div>
85
+  </div>
86
+
87
+  <!-- 内容 -->
88
+  <div class="screen_body swiper" id="mySwiper" *ngIf="buildings.length">
89
+    <div class="swiper-wrapper display_flex">
90
+      <div class="screen_wrap swiper-slide" *ngFor="let screen of buildings">
91
+        <div class="screen_list" *ngFor="let building of screen">
92
+          <div class="screen_list_head">
93
+            <div class="screen_list_title">{{building.name}}</div>
94
+            <div class="screen_list_column">
95
+              <div class="column" *ngIf="building.name">科室名称</div>
96
+              <div class="column" *ngIf="building.name">{{taskTypeName}}工单状态</div>
97
+            </div>
98
+          </div>
99
+          <div class="screen_list_body">
100
+            <div class="screen_list_item" *ngFor="let department of building.departments">
101
+              <div class="item_name">{{department.name}}</div>
102
+              <div class="item_description">
103
+                <div class="item_orderInfo" *ngIf="department.orders[0]">{{department.orders[0][11].slice(-4)}}-{{department.orders[0][7]}} {{department.orders[0][8]}}</div>
104
+                <div class="item_remarks" *ngIf="department.orders[0]">{{department.orders[0][13]}}</div>
105
+              </div>
106
+            </div>
107
+          </div>
108
+        </div>
109
+      </div>
110
+    </div>
111
+    <!-- 如果需要分页器 -->
112
+    <div class="swiper-pagination">
113
+      <div class="dit" [ngClass]="{active: activeIndex == i}" *ngFor="let dit of buildings;let i = index;" (click)="setActiveIndex(i)"></div>
114
+    </div>
115
+  </div>
116
+</div>

+ 451 - 0
src/app/views/disinfection-supply/disinfection-supply.component.less

@@ -0,0 +1,451 @@
1
+@import "../../../../src/theme.less";
2
+
3
+:host {
4
+  background-color: #00253f;
5
+  width: 100vw;
6
+  height: 100vh;
7
+  overflow: hidden;
8
+
9
+  // 遮罩
10
+  .mask{
11
+    background-color: rgba(80, 80, 80, 0.5);
12
+    position: absolute;
13
+    left: 0;
14
+    right: 0;
15
+    top: 0;
16
+    bottom: 0;
17
+    z-index: 9;
18
+    .con-wrap{
19
+      width: 480px;
20
+      background: #fff;
21
+      padding: 16px;
22
+      border-radius: 5px;
23
+      border: 1px solid #e5e9ed;
24
+      position: absolute;
25
+      left: 50%;
26
+      top: 50%;
27
+      transform: translate(-50%, -50%);
28
+      .con {
29
+        background: #f9fafb;
30
+        width: 100%;
31
+        border-radius: 5px;
32
+        border: 1px solid #e5e9ed;
33
+        padding: 16px;
34
+        &.bindingExtension {
35
+          min-height: 246px;
36
+          .bindingExtension_content {
37
+            display: flex;
38
+            flex-wrap: wrap;
39
+          }
40
+          .noContentFlex {
41
+            display: flex;
42
+            justify-content: center;
43
+            align-items: center;
44
+            height: 136px;
45
+            flex-direction: column;
46
+            .noContent {
47
+              width: 128px;
48
+            }
49
+            p {
50
+              margin-top: 8px;
51
+            }
52
+          }
53
+          .ant-checkbox-wrapper {
54
+            font-size: 12px;
55
+            width: 100%;
56
+            display: flex;
57
+            margin-top: 8px;
58
+            justify-content: space-between;
59
+            align-items: center;
60
+            ::ng-deep .ant-checkbox {
61
+              font-size: 12px;
62
+              top: 0;
63
+            }
64
+            ::ng-deep .ant-checkbox + span {
65
+              flex: 1;
66
+            }
67
+          }
68
+        }
69
+
70
+        &.tableCon {
71
+          padding: 0;
72
+
73
+          .table {
74
+            font-size: 14px;
75
+
76
+            tr {
77
+              td {
78
+                padding: 15px 6px;
79
+                text-align: center;
80
+
81
+                & > .tdiv {
82
+                  overflow: hidden;
83
+
84
+                  .name {
85
+                    float: left;
86
+                  }
87
+
88
+                  .num {
89
+                    float: right;
90
+                    font-size: 12px;
91
+
92
+                    span {
93
+                      color: @primary-color;
94
+                      font-size: 14px;
95
+                    }
96
+                  }
97
+                }
98
+
99
+                .notOpen {
100
+                  color: #666;
101
+                  font-size: 12px;
102
+
103
+                  img {
104
+                    margin-bottom: 8px;
105
+                  }
106
+                }
107
+              }
108
+            }
109
+          }
110
+        }
111
+
112
+        .title {
113
+          color: #333;
114
+          text-align: center;
115
+        }
116
+
117
+        .conditions {
118
+          & > .ant-row {
119
+            margin: 8px 0;
120
+            display: flex;
121
+            align-items: center;
122
+
123
+            .ant-row {
124
+              .ant-col-6 {
125
+                margin: 2px 0;
126
+              }
127
+            }
128
+
129
+            .checkAll {
130
+              width: 100%;
131
+              border-bottom: 1px solid rgb(233, 233, 233);
132
+              color: @primary-color;
133
+            }
134
+          }
135
+        }
136
+
137
+        .btns {
138
+          padding: 5px 20px 0 20px;
139
+        }
140
+      }
141
+    }
142
+  }
143
+
144
+  // 大屏
145
+  .screen{
146
+    // 头部
147
+    .screen_head{
148
+      height: 117px;
149
+      padding-top: 21px;
150
+      display: flex;
151
+      justify-content: center;
152
+      position: relative;
153
+
154
+      .screen_head_txt{
155
+        width: 855px;
156
+        height: 52px;
157
+        position: relative;
158
+
159
+        h1{
160
+          letter-spacing: 8px;
161
+          font-weight: bold;
162
+          color: #fff;
163
+          font-size: 36px;
164
+          margin: 0;
165
+          display: flex;
166
+          justify-content: center;
167
+          align-items: center;
168
+          position: absolute;
169
+          left: 0;
170
+          right: 0;
171
+          top: 0;
172
+          bottom: 0;
173
+          z-index: 11;
174
+        }
175
+        &::after{
176
+          content: '';
177
+          position: absolute;
178
+          left: 0;
179
+          right: 0;
180
+          top: 0;
181
+          bottom: 0;
182
+          z-index: 1;
183
+          width: 855px;
184
+          background: linear-gradient(to bottom, #15B4ED, #09658E);
185
+          clip-path: polygon(0 0, 100% 0, calc(100% - 52px) 100%, 52px 100%);
186
+        }
187
+
188
+        .left_oblique_line_image{
189
+          position: absolute;
190
+          left: 0;
191
+          top: 18px;
192
+          width: 413px;
193
+          height: 41px;
194
+          background: url(../../../assets/images/screen/left_oblique_line.png) no-repeat;
195
+          background-size: contain;
196
+          transform: translateX(-100%);
197
+        }
198
+
199
+        .right_oblique_line_image{
200
+          position: absolute;
201
+          right: 0;
202
+          top: 18px;
203
+          width: 413px;
204
+          height: 41px;
205
+          background: url(../../../assets/images/screen/right_oblique_line.png) no-repeat;
206
+          background-size: contain;
207
+          transform: translateX(100%);
208
+        }
209
+      }
210
+
211
+      .left_line{
212
+        position: absolute;
213
+        left: 0;
214
+        top: 21px;
215
+        width: calc((100% - 855px) / 2 - 22px);
216
+        height: 4px;
217
+        background-color: #76A8BC;
218
+      }
219
+
220
+      .right_line{
221
+        position: absolute;
222
+        right: 0;
223
+        top: 21px;
224
+        width: calc((100% - 855px) / 2 - 22px);
225
+        height: 4px;
226
+        background-color: #76A8BC;
227
+      }
228
+
229
+      .left_oblique_line{
230
+        position: absolute;
231
+        left: calc((100% - 855px) / 2 - 22px - 17px);
232
+        top: 54px;
233
+        width: 89px;
234
+        height: 4px;
235
+        background-color: #76A8BC;
236
+        transform: rotate(50deg);
237
+      }
238
+
239
+      // .left_oblique_line_common(@n){
240
+      //   position: absolute;
241
+      //   left: calc((100% - 855px) / 2 - 22px - 17px - 24px * (@n - 1));
242
+      //   top: 41px;
243
+      //   width: 12px;
244
+      //   height: 45px;
245
+      //   background-image: linear-gradient(to right bottom, rgba(0, 172, 221, 0.01) 70%, rgba(0, 172, 221, 0.5));
246
+      //   transform: skewX(40deg);
247
+      // }
248
+
249
+      // @numList: {
250
+      //   1: 1;
251
+      //   2: 2;
252
+      //   3: 3;
253
+      //   4: 4;
254
+      //   5: 5;
255
+      //   6: 6;
256
+      //   7: 7;
257
+      //   8: 8;
258
+      //   9: 9;
259
+      //   10: 10;
260
+      //   11: 11;
261
+      //   12: 12;
262
+      //   13: 13;
263
+      //   14: 14;
264
+      //   15: 15;
265
+      // }
266
+
267
+      // each(@numList, {
268
+      //   .left_oblique_line@{key} {
269
+      //     .left_oblique_line_common(@value);
270
+      //   }
271
+      // });
272
+
273
+      .right_oblique_line{
274
+        position: absolute;
275
+        right: calc((100% - 855px) / 2 - 22px - 17px);
276
+        top: 54px;
277
+        width: 89px;
278
+        height: 4px;
279
+        background-color: #76A8BC;
280
+        transform: rotate(-50deg);
281
+      }
282
+
283
+      .bottom_line{
284
+        position: absolute;
285
+        left: 50%;
286
+        bottom: 25px;
287
+        width: calc(855px - 52px * 2 + 20px * 2);
288
+        height: 4px;
289
+        background-color: #76A8BC;
290
+        transform: translateX(-50%);
291
+      }
292
+    }
293
+    // 内容
294
+    .screen_body{
295
+      .swiper-pagination{
296
+        position: fixed;
297
+        right: 0;
298
+        bottom: 0;
299
+        height: 70px;
300
+        display: flex;
301
+        align-items: center;
302
+        .dit{
303
+          width: 28px;
304
+          height: 28px;
305
+          background: #FFFFFF;
306
+          border-radius: 50%;
307
+          margin-right: 14px;
308
+          cursor: pointer;
309
+          &:last-of-type{
310
+            margin-right: 20px;
311
+          }
312
+          &.active{
313
+            background: #8AE4FF;
314
+          }
315
+        }
316
+      }
317
+      .screen_wrap{
318
+        padding: 0 20px 70px;
319
+        display: flex;
320
+        .screen_list{
321
+          min-width: 464px;
322
+          flex: 1;
323
+          .screen_list_head{
324
+            height: 70px;
325
+            background-color: #02356D;
326
+            box-shadow: 0px 3px 6px 1px #092543;
327
+            margin-left: 6px;
328
+            position: relative;
329
+            display: flex;
330
+            flex-direction: column;
331
+            justify-content: center;
332
+            align-items: center;
333
+            &::before{
334
+              content: '';
335
+              position: absolute;
336
+              left: 0;
337
+              top: 0;
338
+              width: 13px;
339
+              height: 13px;
340
+              border-top: 1px solid #B3ECFD;
341
+              border-left: 1px solid #B3ECFD;
342
+            }
343
+            &::after{
344
+              content: '';
345
+              position: absolute;
346
+              right: 0;
347
+              bottom: 0;
348
+              width: 13px;
349
+              height: 13px;
350
+              border-bottom: 1px solid #B3ECFD;
351
+              border-right: 1px solid #B3ECFD;
352
+            }
353
+            .screen_list_title{
354
+              font-size: 20px;
355
+              font-weight: bold;
356
+              color: #57D8FF;
357
+            }
358
+            .screen_list_column{
359
+              display: flex;
360
+              justify-content: center;
361
+              align-items: center;
362
+              width: 100%;
363
+              text-align: center;
364
+              .column{
365
+                font-size: 18px;
366
+                font-weight: 400;
367
+                color: #75B2C4;
368
+                flex: 1;
369
+                overflow: hidden;
370
+                text-overflow: ellipsis;
371
+                white-space: nowrap;
372
+              }
373
+            }
374
+          }
375
+          .screen_list_body{
376
+            margin-top: 20px;
377
+            border: 6px solid #fff;
378
+            border-right: none;
379
+            height: calc(100vh - 289px);
380
+            overflow: hidden;
381
+            .screen_list_item{
382
+              height: 80px;
383
+              display: flex;
384
+              &:nth-of-type(2n + 1){
385
+                background-color: #043144;
386
+              }
387
+              &:nth-of-type(2n){
388
+                background-color: #02374E;
389
+              }
390
+              .item_name{
391
+                flex: 1;
392
+                font-size: 21px;
393
+                font-weight: 400;
394
+                color: #B3ECFD;
395
+                display: flex;
396
+                justify-content: center;
397
+                align-items: center;
398
+                overflow: hidden;
399
+                text-overflow: ellipsis;
400
+                white-space: nowrap;
401
+                // word-break: break-all;
402
+                // text-overflow: ellipsis;
403
+                // overflow: hidden;
404
+                // display: -webkit-box;
405
+                // -webkit-box-orient: vertical;
406
+                // -webkit-line-clamp: 2; /* 这里是超出几行省略 */
407
+              }
408
+              .item_description{
409
+                flex: 1;
410
+                font-size: 17px;
411
+                font-weight: 300;
412
+                color: #FFFFFF;
413
+                display: flex;
414
+                flex-direction: column;
415
+                justify-content: center;
416
+                align-items: center;
417
+                .item_orderInfo{
418
+                  width: 100%;
419
+                  display: flex;
420
+                  justify-content: center;
421
+                  align-items: center;
422
+                }
423
+                .item_remarks{
424
+                  width: 100%;
425
+                  display: flex;
426
+                  justify-content: center;
427
+                  align-items: center;
428
+                  overflow: hidden;
429
+                  text-overflow: ellipsis;
430
+                  white-space: nowrap;
431
+                  // word-break: break-all;
432
+                  // text-overflow: ellipsis;
433
+                  // overflow: hidden;
434
+                  // display: -webkit-box;
435
+                  // -webkit-box-orient: vertical;
436
+                  // -webkit-line-clamp: 2; /* 这里是超出几行省略 */
437
+                }
438
+              }
439
+            }
440
+          }
441
+          &:last-of-type .screen_list_body{
442
+            border-right: 6px solid #fff;
443
+          }
444
+          &:last-of-type .screen_list_head{
445
+            margin-right: 6px;
446
+          }
447
+        }
448
+      }
449
+    }
450
+  }
451
+}

+ 192 - 0
src/app/views/disinfection-supply/disinfection-supply.component.ts

@@ -0,0 +1,192 @@
1
+import { Component, OnInit, AfterViewInit, OnDestroy } from '@angular/core';
2
+import { debounceTime } from 'rxjs/operators';
3
+import { ToolService } from 'src/app/services/tool.service';
4
+import { MainService } from 'src/app/services/main.service';
5
+import { Subject } from 'rxjs';
6
+import { NzMessageService } from 'ng-zorro-antd';
7
+import chunk from 'lodash-es/chunk';
8
+import { Swiper, Autoplay } from 'swiper';
9
+Swiper.use([Autoplay]);
10
+@Component({
11
+  selector: 'app-disinfection-supply',
12
+  templateUrl: './disinfection-supply.component.html',
13
+  styleUrls: ['./disinfection-supply.component.less']
14
+})
15
+export class DisinfectionSupplyComponent implements OnInit, OnDestroy {
16
+
17
+  constructor(
18
+    private mainService: MainService,
19
+    private tool: ToolService,
20
+    private message: NzMessageService,
21
+  ) { }
22
+
23
+  tasktype = null; //任务类型
24
+  refreshTime: number = 60; //刷新时间
25
+  screenCuttingTime: number = 10; //切屏时间
26
+
27
+  taskTypeName:string = '';
28
+  buildings: any[] = [];
29
+  taskTypeList: any[] = [];
30
+  hosId;
31
+  onSearchOtherTaskTypeSubject = new Subject(); //搜索防抖
32
+  searchLoading: boolean = false;
33
+  isMask: boolean = true;
34
+  mySwiper:Swiper;
35
+  timer = null;
36
+  activeIndex: number = 0;
37
+
38
+  ngOnDestroy(){
39
+    clearTimeout(this.timer);
40
+    this.mySwiper.destroy();
41
+  }
42
+
43
+  ngOnInit() {
44
+    this.hosId = this.tool.getCurrentHospital().id;
45
+
46
+    this.onSearchOtherTaskTypeSubject.pipe(debounceTime(500)).subscribe((v) => {
47
+      this.getOtherTasktype(v).then((result) => {
48
+        this.searchLoading = false;
49
+        if (result.status == 200) {
50
+          this.taskTypeList = result.list;
51
+        }
52
+      });
53
+    });
54
+
55
+    this.getOtherTasktype().then((result) => {
56
+      this.searchLoading = false;
57
+      if (result.status == 200) {
58
+        this.taskTypeList = result.list;
59
+      }
60
+    });
61
+  }
62
+
63
+  setActiveIndex(i:number){
64
+    this.activeIndex = i;
65
+    this.mySwiper.slideToLoop(i, 1000, false);
66
+  }
67
+
68
+  startGetList(){
69
+    clearTimeout(this.timer);
70
+    this.timer = setTimeout(() => {
71
+      this.getList();
72
+    }, this.refreshTime * 1000)
73
+  }
74
+
75
+  // 轮播
76
+  startSwiper(){
77
+    let _this = this;
78
+    setTimeout(() => {
79
+      // this.mySwiper && this.mySwiper.destroy();
80
+      if(this.mySwiper){
81
+        this.mySwiper.loopDestroy()
82
+        this.mySwiper.loopCreate()
83
+        return;
84
+      }
85
+      this.mySwiper = new Swiper('#mySwiper', {
86
+        autoplay: {
87
+          delay: this.screenCuttingTime * 1000,
88
+          stopOnLastSlide: false,
89
+          disableOnInteraction: false,
90
+        },
91
+        observer: true, //修改swiper自己或子元素时,自动初始化swiper
92
+        observeParents: true, //修改swiper的父元素时,自动初始化swiper
93
+        loop: true,
94
+        pagination: {
95
+          el: '.swiper-pagination',
96
+          clickable: true, //轮播按钮支持点击
97
+        },
98
+        on: {
99
+          slideChangeTransitionEnd: function(swiper) {
100
+            _this.activeIndex = swiper.realIndex;
101
+            console.log(swiper, _this.activeIndex)
102
+          },
103
+        },
104
+      });
105
+    }, 0)
106
+  }
107
+
108
+  // 获取列表数据
109
+  getList(){
110
+    let maskFlag = this.message.loading("加载中", { nzDuration: 0 }).messageId;
111
+    this.mainService.listMsgByMain('reserveView', {
112
+      taskTypeId: this.tasktype
113
+    }).subscribe((result: any) => {
114
+      this.message.remove(maskFlag);
115
+      const data = result.data || {};
116
+      console.log(data);
117
+      if(result.state == 200){
118
+        if(Object.keys(data).length > 0){
119
+          // 楼栋-楼层-科室-工单 转成前端可用的 楼栋-科室-工单
120
+          let buildings = Object.keys(data)
121
+          .map(v => ({
122
+            id: v,
123
+            name: Object.values(Object.values(data[v])[0])[0][0][3],
124
+            departments: (
125
+              Object.values(data[v]).map(vv => Object.keys(vv).map(vvv => ({id: vvv, name: vv[vvv][0][6], orders: vv[vvv], checked: false, isDisabled: vv[vvv].every(vvvv => !(vvvv[12] == 2 || (!vvvv[8] && vvvv[12] != 2 && vvvv[12] != 6 && vvvv[12] != 7 && vvvv[12] != 11)))}))) as any
126
+            ).flat()
127
+          }));
128
+          console.log(buildings);
129
+          let oItemH = 80;
130
+          let oBodyH = window.innerHeight - 289;
131
+          let n = Math.floor(oBodyH / oItemH); //有效个数
132
+          if(buildings.length){
133
+            let arr = [];
134
+            buildings.forEach(v => {
135
+              let item = chunk(v.departments, n).map(vv => ({id: v.id, name: v.name, departments: vv}));
136
+              arr.push(item);
137
+            })
138
+            arr = chunk((arr as any).flat(), 4);
139
+            let m = arr[arr.length - 1].length;
140
+            for (let index = 0; index < 4 - m; index++) {
141
+              arr[arr.length - 1].push({});
142
+            }
143
+            this.buildings = arr;
144
+            console.log(this.buildings);
145
+            this.startSwiper();
146
+            this.startGetList();
147
+          }else{
148
+            this.buildings = [];
149
+          }
150
+        }else{
151
+          this.buildings = [];
152
+        }
153
+      }else{
154
+        this.buildings = [];
155
+      }
156
+    })
157
+  }
158
+
159
+  // 获取其他临床服务
160
+  getOtherTasktype(keyword?) {
161
+    let postData: any = {
162
+      idx: 0,
163
+      sum: 10,
164
+      taskType: {
165
+        hosId: {id: this.hosId},
166
+        taskName: keyword,
167
+        simpleQuery: true,
168
+        associationType: {key: "association_types", value: "other"},
169
+      },
170
+    };
171
+    return this.mainService
172
+      .getFetchDataList("configuration", "taskType", postData)
173
+      .toPromise();
174
+  }
175
+
176
+  //其他临床服务任务类型
177
+  onSearchOtherTaskType(e){
178
+    this.searchLoading = true;
179
+    this.onSearchOtherTaskTypeSubject.next(e);
180
+  }
181
+
182
+  // 确定
183
+  saveScreen(){
184
+    if(!this.tasktype || !this.refreshTime || !this.screenCuttingTime){
185
+      this.message.info('请填写必选项!');
186
+      return;
187
+    }
188
+    this.taskTypeName = this.taskTypeList.find(v => v.id == this.tasktype).taskName;
189
+    this.isMask = false;
190
+    this.getList();
191
+  }
192
+}

+ 17 - 0
src/app/views/disinfection-supply/disinfection-supply.module.ts

@@ -0,0 +1,17 @@
1
+import { NgModule } from '@angular/core';
2
+import { CommonModule } from '@angular/common';
3
+
4
+import { DisinfectionSupplyRoutingModule } from './disinfection-supply-routing.module';
5
+import { DisinfectionSupplyComponent } from './disinfection-supply.component';
6
+import { ShareModule } from 'src/app/share/share.module';
7
+
8
+
9
+@NgModule({
10
+  declarations: [DisinfectionSupplyComponent],
11
+  imports: [
12
+    CommonModule,
13
+    DisinfectionSupplyRoutingModule,
14
+    ShareModule,
15
+  ]
16
+})
17
+export class DisinfectionSupplyModule { }

+ 1 - 0
src/app/views/main/main.component.html

@@ -42,6 +42,7 @@
42 42
           <button nz-button nzType="primary" *ngIf="specimenViewRole" (click)="toBigScreen('specimenView')"
43 43
             [nzLoading]="deptTypeLoading">业务视图</button>
44 44
           <button nz-button nzType="primary" *ngIf="specimenViewRole2" (click)="toSpecimenView2()">标本视图</button>
45
+          <button nz-button nzType="primary" *ngIf="disinfectionSupplyRole" (click)="toDisinfectionSupply()">全局业务查看</button>
45 46
         </div>
46 47
         <div class="right">
47 48
           <div class="msg">

+ 9 - 0
src/app/views/main/main.component.ts

@@ -29,6 +29,7 @@ export class MainComponent implements OnInit {
29 29
   largeScreenRole2: boolean = false; //大屏端权限
30 30
   specimenViewRole: boolean = false; //业务视图权限
31 31
   specimenViewRole2: boolean = false; //标本视图权限
32
+  disinfectionSupplyRole: boolean = false; //全局业务查看权限
32 33
   @ViewChild("osComponentRef1", {
33 34
     read: OverlayScrollbarsComponent,
34 35
     static: false,
@@ -125,6 +126,10 @@ export class MainComponent implements OnInit {
125 126
         this.specimenViewRole2 = true;
126 127
         console.log("标本视图权限");
127 128
       }
129
+      if (e.link == "disinfectionSupply") {
130
+        this.disinfectionSupplyRole = true;
131
+        console.log("全局业务查看权限");
132
+      }
128 133
       if (!e.link) {
129 134
         arr.push(e);
130 135
       }
@@ -232,6 +237,10 @@ export class MainComponent implements OnInit {
232 237
   toSpecimenView2(): void {
233 238
     this.router.navigateByUrl("specimenView2");
234 239
   }
240
+  // 全局业务查看
241
+  toDisinfectionSupply(): void {
242
+    this.router.navigateByUrl("disinfectionSupply");
243
+  }
235 244
   // 大屏端或视图端
236 245
   screenType;
237 246
   hosFlag = false;

二进制
src/assets/images/screen/left_oblique_line.png


二进制
src/assets/images/screen/right_oblique_line.png


+ 1 - 1
tsconfig.app.json

@@ -2,7 +2,7 @@
2 2
   "extends": "./tsconfig.json",
3 3
   "compilerOptions": {
4 4
     "outDir": "./out-tsc/app",
5
-    "types": []
5
+    "types": ["swiper"]
6 6
   },
7 7
   "include": [
8 8
     "src/**/*.ts"