seimin 3 роки тому
батько
коміт
a9d8089f20

+ 78 - 1
package-lock.json

@@ -15,7 +15,8 @@
15 15
         "lodash": "^4.17.21",
16 16
         "vue": "^2.5.2",
17 17
         "vue-axios": "^2.1.4",
18
-        "vue-router": "^3.0.1"
18
+        "vue-router": "^3.0.1",
19
+        "weixin-jsapi": "^1.1.0"
19 20
       },
20 21
       "devDependencies": {
21 22
         "autoprefixer": "^7.1.2",
@@ -14375,6 +14376,11 @@
14375 14376
         "node": ">=0.8.0"
14376 14377
       }
14377 14378
     },
14379
+    "node_modules/weixin-jsapi": {
14380
+      "version": "1.1.0",
14381
+      "resolved": "https://registry.nlark.com/weixin-jsapi/download/weixin-jsapi-1.1.0.tgz",
14382
+      "integrity": "sha1-UalaIiTFnR2PAv3bxt5S2hazRLM="
14383
+    },
14378 14384
     "node_modules/when": {
14379 14385
       "version": "3.6.4",
14380 14386
       "resolved": "https://registry.npm.taobao.org/when/download/when-3.6.4.tgz",
@@ -18873,24 +18879,28 @@
18873 18879
       "dependencies": {
18874 18880
         "abbrev": {
18875 18881
           "version": "1.1.1",
18882
+          "integrity": "sha1-+PLIh60Qv2f2NPAFtph/7TF5qsg=",
18876 18883
           "bundled": true,
18877 18884
           "dev": true,
18878 18885
           "optional": true
18879 18886
         },
18880 18887
         "ansi-regex": {
18881 18888
           "version": "2.1.1",
18889
+          "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=",
18882 18890
           "bundled": true,
18883 18891
           "dev": true,
18884 18892
           "optional": true
18885 18893
         },
18886 18894
         "aproba": {
18887 18895
           "version": "1.2.0",
18896
+          "integrity": "sha1-aALmJk79GMeQobDVF/DyYnvyyUo=",
18888 18897
           "bundled": true,
18889 18898
           "dev": true,
18890 18899
           "optional": true
18891 18900
         },
18892 18901
         "are-we-there-yet": {
18893 18902
           "version": "1.1.5",
18903
+          "integrity": "sha1-SzXClE8GKov82mZBB2A1D+nd/CE=",
18894 18904
           "bundled": true,
18895 18905
           "dev": true,
18896 18906
           "optional": true,
@@ -18901,12 +18911,14 @@
18901 18911
         },
18902 18912
         "balanced-match": {
18903 18913
           "version": "1.0.0",
18914
+          "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
18904 18915
           "bundled": true,
18905 18916
           "dev": true,
18906 18917
           "optional": true
18907 18918
         },
18908 18919
         "brace-expansion": {
18909 18920
           "version": "1.1.11",
18921
+          "integrity": "sha1-PH/L9SnYcibz0vUrlm/1Jx60Qd0=",
18910 18922
           "bundled": true,
18911 18923
           "dev": true,
18912 18924
           "optional": true,
@@ -18917,36 +18929,42 @@
18917 18929
         },
18918 18930
         "chownr": {
18919 18931
           "version": "1.1.4",
18932
+          "integrity": "sha1-b8nXtC0ypYNZYzdmbn0ICE2izGs=",
18920 18933
           "bundled": true,
18921 18934
           "dev": true,
18922 18935
           "optional": true
18923 18936
         },
18924 18937
         "code-point-at": {
18925 18938
           "version": "1.1.0",
18939
+          "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=",
18926 18940
           "bundled": true,
18927 18941
           "dev": true,
18928 18942
           "optional": true
18929 18943
         },
18930 18944
         "concat-map": {
18931 18945
           "version": "0.0.1",
18946
+          "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
18932 18947
           "bundled": true,
18933 18948
           "dev": true,
18934 18949
           "optional": true
18935 18950
         },
18936 18951
         "console-control-strings": {
18937 18952
           "version": "1.1.0",
18953
+          "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=",
18938 18954
           "bundled": true,
18939 18955
           "dev": true,
18940 18956
           "optional": true
18941 18957
         },
18942 18958
         "core-util-is": {
18943 18959
           "version": "1.0.2",
18960
+          "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=",
18944 18961
           "bundled": true,
18945 18962
           "dev": true,
18946 18963
           "optional": true
18947 18964
         },
18948 18965
         "debug": {
18949 18966
           "version": "3.2.6",
18967
+          "integrity": "sha1-6D0X3hbYp++3cX7b5fsQE17uYps=",
18950 18968
           "bundled": true,
18951 18969
           "dev": true,
18952 18970
           "optional": true,
@@ -18956,24 +18974,28 @@
18956 18974
         },
18957 18975
         "deep-extend": {
18958 18976
           "version": "0.6.0",
18977
+          "integrity": "sha1-xPp8lUBKF6nD6Mp+FTcxK3NjMKw=",
18959 18978
           "bundled": true,
18960 18979
           "dev": true,
18961 18980
           "optional": true
18962 18981
         },
18963 18982
         "delegates": {
18964 18983
           "version": "1.0.0",
18984
+          "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=",
18965 18985
           "bundled": true,
18966 18986
           "dev": true,
18967 18987
           "optional": true
18968 18988
         },
18969 18989
         "detect-libc": {
18970 18990
           "version": "1.0.3",
18991
+          "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=",
18971 18992
           "bundled": true,
18972 18993
           "dev": true,
18973 18994
           "optional": true
18974 18995
         },
18975 18996
         "fs-minipass": {
18976 18997
           "version": "1.2.7",
18998
+          "integrity": "sha1-zP+FcIQef+QmVpPaiJNsVa7X98c=",
18977 18999
           "bundled": true,
18978 19000
           "dev": true,
18979 19001
           "optional": true,
@@ -18983,12 +19005,14 @@
18983 19005
         },
18984 19006
         "fs.realpath": {
18985 19007
           "version": "1.0.0",
19008
+          "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=",
18986 19009
           "bundled": true,
18987 19010
           "dev": true,
18988 19011
           "optional": true
18989 19012
         },
18990 19013
         "gauge": {
18991 19014
           "version": "2.7.4",
19015
+          "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=",
18992 19016
           "bundled": true,
18993 19017
           "dev": true,
18994 19018
           "optional": true,
@@ -19005,6 +19029,7 @@
19005 19029
         },
19006 19030
         "glob": {
19007 19031
           "version": "7.1.6",
19032
+          "integrity": "sha1-FB8zuBp8JJLhJVlDB0gMRmeSeKY=",
19008 19033
           "bundled": true,
19009 19034
           "dev": true,
19010 19035
           "optional": true,
@@ -19019,12 +19044,14 @@
19019 19044
         },
19020 19045
         "has-unicode": {
19021 19046
           "version": "2.0.1",
19047
+          "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=",
19022 19048
           "bundled": true,
19023 19049
           "dev": true,
19024 19050
           "optional": true
19025 19051
         },
19026 19052
         "iconv-lite": {
19027 19053
           "version": "0.4.24",
19054
+          "integrity": "sha1-ICK0sl+93CHS9SSXSkdKr+czkIs=",
19028 19055
           "bundled": true,
19029 19056
           "dev": true,
19030 19057
           "optional": true,
@@ -19034,6 +19061,7 @@
19034 19061
         },
19035 19062
         "ignore-walk": {
19036 19063
           "version": "3.0.3",
19064
+          "integrity": "sha1-AX4kRxhL/q3nwjjkrv3R6PlbHjc=",
19037 19065
           "bundled": true,
19038 19066
           "dev": true,
19039 19067
           "optional": true,
@@ -19043,6 +19071,7 @@
19043 19071
         },
19044 19072
         "inflight": {
19045 19073
           "version": "1.0.6",
19074
+          "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=",
19046 19075
           "bundled": true,
19047 19076
           "dev": true,
19048 19077
           "optional": true,
@@ -19053,18 +19082,21 @@
19053 19082
         },
19054 19083
         "inherits": {
19055 19084
           "version": "2.0.4",
19085
+          "integrity": "sha1-D6LGT5MpF8NDOg3tVTY6rjdBa3w=",
19056 19086
           "bundled": true,
19057 19087
           "dev": true,
19058 19088
           "optional": true
19059 19089
         },
19060 19090
         "ini": {
19061 19091
           "version": "1.3.5",
19092
+          "integrity": "sha1-7uJfVtscnsYIXgwid4CD9Zar+Sc=",
19062 19093
           "bundled": true,
19063 19094
           "dev": true,
19064 19095
           "optional": true
19065 19096
         },
19066 19097
         "is-fullwidth-code-point": {
19067 19098
           "version": "1.0.0",
19099
+          "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=",
19068 19100
           "bundled": true,
19069 19101
           "dev": true,
19070 19102
           "optional": true,
@@ -19074,12 +19106,14 @@
19074 19106
         },
19075 19107
         "isarray": {
19076 19108
           "version": "1.0.0",
19109
+          "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=",
19077 19110
           "bundled": true,
19078 19111
           "dev": true,
19079 19112
           "optional": true
19080 19113
         },
19081 19114
         "minimatch": {
19082 19115
           "version": "3.0.4",
19116
+          "integrity": "sha1-UWbihkV/AzBgZL5Ul+jbsMPTIIM=",
19083 19117
           "bundled": true,
19084 19118
           "dev": true,
19085 19119
           "optional": true,
@@ -19089,12 +19123,14 @@
19089 19123
         },
19090 19124
         "minimist": {
19091 19125
           "version": "1.2.5",
19126
+          "integrity": "sha1-Z9ZgFLZqaoqqDAg8X9WN9OTpdgI=",
19092 19127
           "bundled": true,
19093 19128
           "dev": true,
19094 19129
           "optional": true
19095 19130
         },
19096 19131
         "minipass": {
19097 19132
           "version": "2.9.0",
19133
+          "integrity": "sha1-5xN2Ln0+Mv7YAxFc+T4EvKn8yaY=",
19098 19134
           "bundled": true,
19099 19135
           "dev": true,
19100 19136
           "optional": true,
@@ -19105,6 +19141,7 @@
19105 19141
         },
19106 19142
         "minizlib": {
19107 19143
           "version": "1.3.3",
19144
+          "integrity": "sha1-IpDeloGKNMKVUcio0wEha9Zahh0=",
19108 19145
           "bundled": true,
19109 19146
           "dev": true,
19110 19147
           "optional": true,
@@ -19114,6 +19151,7 @@
19114 19151
         },
19115 19152
         "mkdirp": {
19116 19153
           "version": "0.5.3",
19154
+          "integrity": "sha1-WlFLcXklkoeVKIHpRBDsVGVln4w=",
19117 19155
           "bundled": true,
19118 19156
           "dev": true,
19119 19157
           "optional": true,
@@ -19123,12 +19161,14 @@
19123 19161
         },
19124 19162
         "ms": {
19125 19163
           "version": "2.1.2",
19164
+          "integrity": "sha1-0J0fNXtEP0kzgqjrPM0YOHKuYAk=",
19126 19165
           "bundled": true,
19127 19166
           "dev": true,
19128 19167
           "optional": true
19129 19168
         },
19130 19169
         "needle": {
19131 19170
           "version": "2.3.3",
19171
+          "integrity": "sha1-oEGtHQSocbDrtmb0C6rx+0eGcRc=",
19132 19172
           "bundled": true,
19133 19173
           "dev": true,
19134 19174
           "optional": true,
@@ -19140,6 +19180,7 @@
19140 19180
         },
19141 19181
         "node-pre-gyp": {
19142 19182
           "version": "0.14.0",
19183
+          "integrity": "sha1-mgWWUzuHcom8rU4UOYLKPZBN3IM=",
19143 19184
           "bundled": true,
19144 19185
           "dev": true,
19145 19186
           "optional": true,
@@ -19158,6 +19199,7 @@
19158 19199
         },
19159 19200
         "nopt": {
19160 19201
           "version": "4.0.3",
19202
+          "integrity": "sha1-o3XK2dAv2SEnjZVMIlTVqlfhXkg=",
19161 19203
           "bundled": true,
19162 19204
           "dev": true,
19163 19205
           "optional": true,
@@ -19168,6 +19210,7 @@
19168 19210
         },
19169 19211
         "npm-bundled": {
19170 19212
           "version": "1.1.1",
19213
+          "integrity": "sha1-Ht1XCGWpTNsbyCIHdeKUZsn7I0s=",
19171 19214
           "bundled": true,
19172 19215
           "dev": true,
19173 19216
           "optional": true,
@@ -19177,12 +19220,14 @@
19177 19220
         },
19178 19221
         "npm-normalize-package-bin": {
19179 19222
           "version": "1.0.1",
19223
+          "integrity": "sha1-bnmkHyP9I1wGIyGCKNp9nCO49uI=",
19180 19224
           "bundled": true,
19181 19225
           "dev": true,
19182 19226
           "optional": true
19183 19227
         },
19184 19228
         "npm-packlist": {
19185 19229
           "version": "1.4.8",
19230
+          "integrity": "sha1-Vu5swTW5+YrT1Rwcldoiu7my7z4=",
19186 19231
           "bundled": true,
19187 19232
           "dev": true,
19188 19233
           "optional": true,
@@ -19194,6 +19239,7 @@
19194 19239
         },
19195 19240
         "npmlog": {
19196 19241
           "version": "4.1.2",
19242
+          "integrity": "sha1-CKfyqL9zRgR3mp76StXMcXq7lUs=",
19197 19243
           "bundled": true,
19198 19244
           "dev": true,
19199 19245
           "optional": true,
@@ -19206,18 +19252,21 @@
19206 19252
         },
19207 19253
         "number-is-nan": {
19208 19254
           "version": "1.0.1",
19255
+          "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=",
19209 19256
           "bundled": true,
19210 19257
           "dev": true,
19211 19258
           "optional": true
19212 19259
         },
19213 19260
         "object-assign": {
19214 19261
           "version": "4.1.1",
19262
+          "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=",
19215 19263
           "bundled": true,
19216 19264
           "dev": true,
19217 19265
           "optional": true
19218 19266
         },
19219 19267
         "once": {
19220 19268
           "version": "1.4.0",
19269
+          "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
19221 19270
           "bundled": true,
19222 19271
           "dev": true,
19223 19272
           "optional": true,
@@ -19227,18 +19276,21 @@
19227 19276
         },
19228 19277
         "os-homedir": {
19229 19278
           "version": "1.0.2",
19279
+          "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=",
19230 19280
           "bundled": true,
19231 19281
           "dev": true,
19232 19282
           "optional": true
19233 19283
         },
19234 19284
         "os-tmpdir": {
19235 19285
           "version": "1.0.2",
19286
+          "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=",
19236 19287
           "bundled": true,
19237 19288
           "dev": true,
19238 19289
           "optional": true
19239 19290
         },
19240 19291
         "osenv": {
19241 19292
           "version": "0.1.5",
19293
+          "integrity": "sha1-hc36+uso6Gd/QW4odZK18/SepBA=",
19242 19294
           "bundled": true,
19243 19295
           "dev": true,
19244 19296
           "optional": true,
@@ -19249,18 +19301,21 @@
19249 19301
         },
19250 19302
         "path-is-absolute": {
19251 19303
           "version": "1.0.1",
19304
+          "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
19252 19305
           "bundled": true,
19253 19306
           "dev": true,
19254 19307
           "optional": true
19255 19308
         },
19256 19309
         "process-nextick-args": {
19257 19310
           "version": "2.0.1",
19311
+          "integrity": "sha1-eCDZsWEgzFXKmud5JoCufbptf+I=",
19258 19312
           "bundled": true,
19259 19313
           "dev": true,
19260 19314
           "optional": true
19261 19315
         },
19262 19316
         "rc": {
19263 19317
           "version": "1.2.8",
19318
+          "integrity": "sha1-zZJL9SAKB1uDwYjNa54hG3/A0+0=",
19264 19319
           "bundled": true,
19265 19320
           "dev": true,
19266 19321
           "optional": true,
@@ -19273,6 +19328,7 @@
19273 19328
         },
19274 19329
         "readable-stream": {
19275 19330
           "version": "2.3.7",
19331
+          "integrity": "sha1-Hsoc9xGu+BTAT2IlKjamL2yyO1c=",
19276 19332
           "bundled": true,
19277 19333
           "dev": true,
19278 19334
           "optional": true,
@@ -19288,6 +19344,7 @@
19288 19344
         },
19289 19345
         "rimraf": {
19290 19346
           "version": "2.7.1",
19347
+          "integrity": "sha1-NXl/E6f9rcVmFCwp1PB8ytSD4+w=",
19291 19348
           "bundled": true,
19292 19349
           "dev": true,
19293 19350
           "optional": true,
@@ -19297,42 +19354,49 @@
19297 19354
         },
19298 19355
         "safe-buffer": {
19299 19356
           "version": "5.1.2",
19357
+          "integrity": "sha1-mR7GnSluAxN0fVm9/St0XDX4go0=",
19300 19358
           "bundled": true,
19301 19359
           "dev": true,
19302 19360
           "optional": true
19303 19361
         },
19304 19362
         "safer-buffer": {
19305 19363
           "version": "2.1.2",
19364
+          "integrity": "sha1-RPoWGwGHuVSd2Eu5GAL5vYOFzWo=",
19306 19365
           "bundled": true,
19307 19366
           "dev": true,
19308 19367
           "optional": true
19309 19368
         },
19310 19369
         "sax": {
19311 19370
           "version": "1.2.4",
19371
+          "integrity": "sha1-KBYjTiN4vdxOU1T6tcqold9xANk=",
19312 19372
           "bundled": true,
19313 19373
           "dev": true,
19314 19374
           "optional": true
19315 19375
         },
19316 19376
         "semver": {
19317 19377
           "version": "5.7.1",
19378
+          "integrity": "sha1-qVT5Ma66UI0we78Gnv8MAclhFvc=",
19318 19379
           "bundled": true,
19319 19380
           "dev": true,
19320 19381
           "optional": true
19321 19382
         },
19322 19383
         "set-blocking": {
19323 19384
           "version": "2.0.0",
19385
+          "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=",
19324 19386
           "bundled": true,
19325 19387
           "dev": true,
19326 19388
           "optional": true
19327 19389
         },
19328 19390
         "signal-exit": {
19329 19391
           "version": "3.0.2",
19392
+          "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=",
19330 19393
           "bundled": true,
19331 19394
           "dev": true,
19332 19395
           "optional": true
19333 19396
         },
19334 19397
         "string_decoder": {
19335 19398
           "version": "1.1.1",
19399
+          "integrity": "sha1-nPFhG6YmhdcDCunkujQUnDrwP8g=",
19336 19400
           "bundled": true,
19337 19401
           "dev": true,
19338 19402
           "optional": true,
@@ -19342,6 +19406,7 @@
19342 19406
         },
19343 19407
         "string-width": {
19344 19408
           "version": "1.0.2",
19409
+          "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=",
19345 19410
           "bundled": true,
19346 19411
           "dev": true,
19347 19412
           "optional": true,
@@ -19353,6 +19418,7 @@
19353 19418
         },
19354 19419
         "strip-ansi": {
19355 19420
           "version": "3.0.1",
19421
+          "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=",
19356 19422
           "bundled": true,
19357 19423
           "dev": true,
19358 19424
           "optional": true,
@@ -19362,12 +19428,14 @@
19362 19428
         },
19363 19429
         "strip-json-comments": {
19364 19430
           "version": "2.0.1",
19431
+          "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=",
19365 19432
           "bundled": true,
19366 19433
           "dev": true,
19367 19434
           "optional": true
19368 19435
         },
19369 19436
         "tar": {
19370 19437
           "version": "4.4.13",
19438
+          "integrity": "sha1-Q7NkvFKIjVVSmGN7ENYHkCVKtSU=",
19371 19439
           "bundled": true,
19372 19440
           "dev": true,
19373 19441
           "optional": true,
@@ -19383,12 +19451,14 @@
19383 19451
         },
19384 19452
         "util-deprecate": {
19385 19453
           "version": "1.0.2",
19454
+          "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=",
19386 19455
           "bundled": true,
19387 19456
           "dev": true,
19388 19457
           "optional": true
19389 19458
         },
19390 19459
         "wide-align": {
19391 19460
           "version": "1.1.3",
19461
+          "integrity": "sha1-rgdOa9wMFKQx6ATmJFScYzsABFc=",
19392 19462
           "bundled": true,
19393 19463
           "dev": true,
19394 19464
           "optional": true,
@@ -19398,12 +19468,14 @@
19398 19468
         },
19399 19469
         "wrappy": {
19400 19470
           "version": "1.0.2",
19471
+          "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
19401 19472
           "bundled": true,
19402 19473
           "dev": true,
19403 19474
           "optional": true
19404 19475
         },
19405 19476
         "yallist": {
19406 19477
           "version": "3.1.1",
19478
+          "integrity": "sha1-27fa+b/YusmrRev2ArjLrQ1dCP0=",
19407 19479
           "bundled": true,
19408 19480
           "dev": true,
19409 19481
           "optional": true
@@ -26730,6 +26802,11 @@
26730 26802
       "integrity": "sha1-XS/yKXcAPsaHpLhwc9+7rBRszyk=",
26731 26803
       "dev": true
26732 26804
     },
26805
+    "weixin-jsapi": {
26806
+      "version": "1.1.0",
26807
+      "resolved": "https://registry.nlark.com/weixin-jsapi/download/weixin-jsapi-1.1.0.tgz",
26808
+      "integrity": "sha1-UalaIiTFnR2PAv3bxt5S2hazRLM="
26809
+    },
26733 26810
     "when": {
26734 26811
       "version": "3.6.4",
26735 26812
       "resolved": "https://registry.npm.taobao.org/when/download/when-3.6.4.tgz",

+ 2 - 1
package.json

@@ -17,7 +17,8 @@
17 17
     "lodash": "^4.17.21",
18 18
     "vue": "^2.5.2",
19 19
     "vue-axios": "^2.1.4",
20
-    "vue-router": "^3.0.1"
20
+    "vue-router": "^3.0.1",
21
+    "weixin-jsapi": "^1.1.0"
21 22
   },
22 23
   "compileDependencies": [
23 24
     "cube-ui"

+ 34 - 0
src/http/http.js

@@ -0,0 +1,34 @@
1
+import wx from 'weixin-jsapi'
2
+// 扫一扫
3
+export function SM(Vue) {
4
+  return new Promise((resolve, reject) => {
5
+    let param = {
6
+      requestUrl: location.href.split('#')[0]
7
+    };
8
+    Vue.$http.post("service/wechat/getJsConfig", param).then(res => {
9
+      res = res.data;
10
+      if (res) {
11
+        wx.config({
12
+          debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
13
+          appId: res.appId, // 必填,企业号的唯一标识,此处填写企业号corpid
14
+          timestamp: res.timestamp, // 必填,生成签名的时间戳
15
+          nonceStr: res.nonceStr, // 必填,生成签名的随机串
16
+          signature: res.signature, // 必填,签名,见附录1
17
+          jsApiList: res.jsApiList // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
18
+        });
19
+        wx.ready(function() {
20
+          wx.scanQRCode({
21
+            desc: "scanQRCode desc",
22
+            needResult: 1, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
23
+            scanType: ["qrCode", "barCode"], // 可以指定扫二维码还是一维码,默认二者都有
24
+            success: function(res) {
25
+              // 当needResult 为 1 时,扫码返回的结果
26
+              let str = res.resultStr.replace(/[\s\/]/g, '') || 'none';
27
+              resolve(str);
28
+            }
29
+          });
30
+        });
31
+      }
32
+    })
33
+  });
34
+}

+ 40 - 41
src/views/Login.vue

@@ -35,17 +35,17 @@ export default {
35 35
       zhanghao: "",
36 36
       mima: "",
37 37
       requesterLgoinType: "",
38
-      isSSo: true // 是否单点登录
38
+      isSSo: true, // 是否单点登录
39 39
     };
40 40
   },
41 41
   components: {
42
-    LoadIng
42
+    LoadIng,
43 43
   },
44 44
   methods: {
45 45
     // 登陆
46 46
     login() {
47 47
       var that = this;
48
-      that.$http.post("service/auth/wechatAuth", {}).then(res => {
48
+      that.$http.post("service/auth/wechatAuth", {}).then((res) => {
49 49
         if (res.data.url) {
50 50
           window.location.href = res.data.url;
51 51
         } else {
@@ -70,7 +70,7 @@ export default {
70 70
           code: url[1],
71 71
           // name: "微信报修"
72 72
         };
73
-        that.$http.post("service/auth/wechatLoginEncrypt", code).then(res => {
73
+        that.$http.post("service/auth/wechatLoginEncrypt", code).then((res) => {
74 74
           if (res.data.state == 200) {
75 75
             if (res.data.user) {
76 76
               localStorage.setItem(
@@ -84,7 +84,7 @@ export default {
84 84
               .$createDialog({
85 85
                 type: "alert",
86 86
                 title: "您的账号被删除,请联系管理员",
87
-                icon: "cubeic-alert"
87
+                icon: "cubeic-alert",
88 88
               })
89 89
               .show();
90 90
           } else {
@@ -92,7 +92,7 @@ export default {
92 92
               .$createDialog({
93 93
                 type: "alert",
94 94
                 title: res.data.remarks,
95
-                icon: "cubeic-alert"
95
+                icon: "cubeic-alert",
96 96
               })
97 97
               .show();
98 98
           }
@@ -106,39 +106,41 @@ export default {
106 106
         .post("service/sysinfo/data/fetchDataList/systemConfiguration", {
107 107
           idx: 0,
108 108
           sum: 1000,
109
-          systemConfiguration: { keyconfig: "repairMain" }
110 109
         })
111
-        .then(result => {
110
+        .then((result) => {
112 111
           if (result.data.status == 200) {
113
-            var repairMain = result.data.list[0];
114
-            window.localStorage.setItem(
112
+            let list = result.data.list;
113
+            let repairMain = list.find((v) => v.keyconfig == "repairMain"); //报修主体
114
+            let incidentWithConsumable = list.find(
115
+              (v) => v.keyconfig == "incidentWithConsumable"
116
+            ); //是否绑定耗材
117
+            let wxIncidentWithCmdb = list.find(
118
+              (v) => v.keyconfig == "wxIncidentWithCmdb"
119
+            ); //是否绑定资产
120
+            let reqHasCategory = list.find(
121
+              (v) => v.keyconfig == "reqHasCategory"
122
+            ); //获取是否自动建单
123
+            localStorage.setItem(
115 124
               "repairMain",
116 125
               JSON.stringify(repairMain)
117 126
             );
118
-            // 获取是否自动建单
119
-            this.$http
120
-              .post("service/sysinfo/data/fetchDataList/systemConfiguration", {
121
-                idx: 0,
122
-                sum: 1000,
123
-                systemConfiguration: { keyconfig: "reqHasCategory" }
124
-              })
125
-              .then(result => {
126
-                if (result.data.status == 200) {
127
-                  var reqHasCategory = result.data.list[0];
128
-                  window.localStorage.setItem(
129
-                    "reqHasCategory",
130
-                    JSON.stringify(reqHasCategory)
131
-                  );
132
-                  this.$router.push({ path: "/main" });
133
-                }
134
-              });
127
+            localStorage.setItem(
128
+              "incidentWithConsumable",
129
+              incidentWithConsumable.valueconfig
130
+            );
131
+            localStorage.setItem(
132
+              "wxIncidentWithCmdb",
133
+              wxIncidentWithCmdb.valueconfig
134
+            );
135
+            localStorage.setItem("reqHasCategory", JSON.stringify(reqHasCategory));
136
+            this.$router.push({ path: "/main" });
135 137
           }
136 138
         });
137 139
       // seimin
138 140
     },
139 141
     // 获取报修人登录方式
140 142
     getLoginType() {
141
-      this.$http.post("service/wechat/getLoginType", {}).then(result => {
143
+      this.$http.post("service/wechat/getLoginType", {}).then((result) => {
142 144
         if (result.data.status == 200) {
143 145
           this.requesterLgoinType = result.data.data;
144 146
           window.localStorage.setItem(
@@ -160,17 +162,14 @@ export default {
160 162
       var ssoStr = "";
161 163
       var ssoJson;
162 164
       if (this.isSSo) {
163
-        ssoStr = location.search
164
-          .replace("?", "")
165
-          .split("&")[0]
166
-          .split("=")[1];
165
+        ssoStr = location.search.replace("?", "").split("&")[0].split("=")[1];
167 166
         ssoStr = decode(decodeURIComponent(ssoStr));
168 167
         ssoJson = JSON.parse(ssoStr);
169 168
       }
170 169
       var postData = this.isSSo
171 170
         ? { username: ssoJson.a, password: ssoJson.r, t: false }
172 171
         : { username: this.zhanghao, password: this.mima };
173
-      this.$http.post("service/auth/reqlogin", postData).then(res => {
172
+      this.$http.post("service/auth/reqlogin", postData).then((res) => {
174 173
         that.loading = false;
175 174
         if (res.data && res.data.state == 200) {
176 175
           localStorage.setItem(
@@ -195,7 +194,7 @@ export default {
195 194
               title: "系统错误",
196 195
               content: "请稍后再试",
197 196
               icon: "cubeic-wrong",
198
-              color: "red"
197
+              color: "red",
199 198
             })
200 199
             .show();
201 200
         }
@@ -203,9 +202,9 @@ export default {
203 202
     },
204 203
     // 获取查询参数
205 204
     getQueryString(name) {
206
-    var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
207
-    var r = window.location.search.substr(1).match(reg);
208
-    if (r != null){
205
+      var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
206
+      var r = window.location.search.substr(1).match(reg);
207
+      if (r != null) {
209 208
         return unescape(r[2]);
210 209
       }
211 210
       return null;
@@ -213,16 +212,16 @@ export default {
213 212
   },
214 213
   created() {
215 214
     localStorage.clear();
216
-    if(location.search.length > 0){
217
-      this.isSSo = Boolean(this.getQueryString('t'));
218
-    }else{
215
+    if (location.search.length > 0) {
216
+      this.isSSo = Boolean(this.getQueryString("t"));
217
+    } else {
219 218
       this.isSSo = false;
220 219
     }
221 220
     if (this.isSSo) {
222 221
       this.zlogin();
223 222
     }
224 223
     this.getLoginType();
225
-  }
224
+  },
226 225
 };
227 226
 </script>
228 227
 

+ 10 - 0
src/views/incidentDetails.vue

@@ -47,6 +47,14 @@
47 47
           {{ data.address }}
48 48
         </div>
49 49
       </div>
50
+      <div class="faultLocation" v-if="wxIncidentWithCmdb == 1">
51
+        <div>
52
+          资产:
53
+        </div>
54
+        <div>
55
+          {{ data.assetId}}
56
+        </div>
57
+      </div>
50 58
     </div>
51 59
     <div class="repairProgress">
52 60
       <div class="label">
@@ -392,6 +400,8 @@ import LoadIng from "./../views/loading.vue";
392 400
 export default {
393 401
   data() {
394 402
     return {
403
+      incidentWithConsumable: localStorage.getItem("incidentWithConsumable"), //是否绑定耗材
404
+      wxIncidentWithCmdb: localStorage.getItem("wxIncidentWithCmdb"), //是否绑定资产
395 405
       data: "",
396 406
       initialIndex: 0,
397 407
       imgs: [],

+ 458 - 358
src/views/incidentList.vue

@@ -1,487 +1,587 @@
1 1
 <template>
2
-    <div class="bgColor">
3
-        <div slot="content" class="scroll-wrapper">
4
-            <div class="demo">
5
-                <div class="scroll-list-wrap">
6
-                    <cube-scroll ref="scroll" :data="items" :options="options" @pulling-down="onPullingDown" @pulling-up="onPullingUp">
7
-                        <cube-select
8
-                          v-model="stateValue"
9
-                          :options="stateData"
10
-                          @change="stateChange()">
11
-                        </cube-select>
12
-                        <ul class="foods-wrapper">
13
-                            <li v-for="data in items" class="food-item border-1px" @click="toIncidentDetails(data)">
14
-                                <div class="food-content">
15
-                                    <div class="title">
16
-                                      <div><i class="iconfont icon-baoxiuliebiao"></i><span>报修编号:&nbsp;{{data.bxcode||"暂无"}}</span></div>
17
-                                      <div :class="stateClassFn(data.state.name)">{{data.state.name}}</div>
18
-                                    </div>
19
-                                    <div class="conent">
20
-                                      {{data.description}}
21
-                                    </div>
22
-                                    <div class="timeBox">
23
-                                      <div>
24
-                                        维修人:&nbsp;{{data.incident.handlingPersonnelUser?data.incident.handlingPersonnelUser.name:"暂无"}}
25
-                                      </div>
26
-                                      <div>
27
-                                        报修时间:&nbsp;{{data.createTime}}
28
-                                      </div>
29
-                                    </div>
30
-                                </div>
31
-                            </li>
32
-                            <div class="wushuju" v-show="wushuju">
33
-                              <img src="./../../static/images/wushuju.svg" alt="">
34
-                              <div class="noDataFont">暂无数据</div>
35
-                          </div>
36
-                        </ul>
37
-                        <template v-if="customPullDown" slot="pulldown" slot-scope="props">
38
-                            <div v-if="props.pullDownRefresh" class="cube-pulldown-wrapper" :style="props.pullDownStyle">
39
-                                <div v-show="props.beforePullDown" class="before-trigger" :style="{paddingTop: props.bubbleY + 'px'}">
40
-                                    <span :class="{rotate: props.bubbleY > pullDownRefreshThreshold - 40}">↓</span>
41
-                                </div>
42
-                                <div class="after-trigger" v-show="!props.beforePullDown">
43
-                                    <div v-show="props.isPullingDown" class="loading">
44
-                                        <cube-loading></cube-loading>
45
-                                    </div>
46
-                                    <div v-show="!props.isPullingDown" class="text">
47
-                                        <span class="refresh-text">更新成功</span>
48
-                                    </div>
49
-                                </div>
50
-                            </div>
51
-                        </template>
52
-                    </cube-scroll>
2
+  <div class="bgColor">
3
+    <div slot="content" class="scroll-wrapper">
4
+      <div class="demo">
5
+        <div class="scroll-list-wrap">
6
+          <cube-scroll
7
+            ref="scroll"
8
+            :data="items"
9
+            :options="options"
10
+            @pulling-down="onPullingDown"
11
+            @pulling-up="onPullingUp"
12
+          >
13
+            <cube-select
14
+              v-model="stateValue"
15
+              :options="stateData"
16
+              @change="stateChange()"
17
+            >
18
+            </cube-select>
19
+            <ul class="foods-wrapper">
20
+              <li
21
+                v-for="data in items"
22
+                class="food-item border-1px"
23
+                @click="toIncidentDetails(data)"
24
+              >
25
+                <div class="food-content">
26
+                  <div class="title">
27
+                    <div>
28
+                      <i class="iconfont icon-baoxiuliebiao"></i
29
+                      ><span>报修编号:&nbsp;{{ data.bxcode || "暂无" }}</span>
30
+                    </div>
31
+                    <div :class="stateClassFn(data.state.name)">
32
+                      {{ data.state.name }}
33
+                    </div>
34
+                  </div>
35
+                  <div class="conent">
36
+                    {{ data.description }}
37
+                  </div>
38
+                  <div class="timeBox">
39
+                    <div>
40
+                      维修人:&nbsp;{{
41
+                        data.incident.handlingPersonnelUser
42
+                          ? data.incident.handlingPersonnelUser.name
43
+                          : "暂无"
44
+                      }}
45
+                    </div>
46
+                    <div>报修时间:&nbsp;{{ data.createTime }}</div>
47
+                  </div>
48
+                  <div
49
+                    class="timeBox noneBorder"
50
+                    v-if="wxIncidentWithCmdb == 1"
51
+                  >
52
+                    <div>资产:&nbsp;{{ data.assetId || "无" }}</div>
53
+                  </div>
53 54
                 </div>
54
-            </div>
55
+              </li>
56
+              <div class="wushuju" v-show="wushuju">
57
+                <img src="./../../static/images/wushuju.svg" alt="" />
58
+                <div class="noDataFont">暂无数据</div>
59
+              </div>
60
+            </ul>
61
+            <template v-if="customPullDown" slot="pulldown" slot-scope="props">
62
+              <div
63
+                v-if="props.pullDownRefresh"
64
+                class="cube-pulldown-wrapper"
65
+                :style="props.pullDownStyle"
66
+              >
67
+                <div
68
+                  v-show="props.beforePullDown"
69
+                  class="before-trigger"
70
+                  :style="{ paddingTop: props.bubbleY + 'px' }"
71
+                >
72
+                  <span
73
+                    :class="{
74
+                      rotate: props.bubbleY > pullDownRefreshThreshold - 40,
75
+                    }"
76
+                    >↓</span
77
+                  >
78
+                </div>
79
+                <div class="after-trigger" v-show="!props.beforePullDown">
80
+                  <div v-show="props.isPullingDown" class="loading">
81
+                    <cube-loading></cube-loading>
82
+                  </div>
83
+                  <div v-show="!props.isPullingDown" class="text">
84
+                    <span class="refresh-text">更新成功</span>
85
+                  </div>
86
+                </div>
87
+              </div>
88
+            </template>
89
+          </cube-scroll>
55 90
         </div>
56
-        <load-ing v-show="loadShow"></load-ing>
91
+      </div>
57 92
     </div>
93
+    <load-ing v-show="loadShow"></load-ing>
94
+  </div>
58 95
 </template>
59 96
 <script>
60
-import Vue from 'vue'
61
-import CubePage from '../components/cube-page.vue'
62
-import SwitchOption from '../components/switch-option'
63
-import InputOption from '../components/input-option'
64
-import SelectOption from '../components/select-option'
65
-import {formatDate} from './../components/js/date.js';
66
-import LoadIng from './../views/loading.vue'
97
+import Vue from "vue";
98
+import CubePage from "../components/cube-page.vue";
99
+import SwitchOption from "../components/switch-option";
100
+import InputOption from "../components/input-option";
101
+import SelectOption from "../components/select-option";
102
+import { formatDate } from "./../components/js/date.js";
103
+import LoadIng from "./../views/loading.vue";
67 104
 export default {
68 105
   data() {
69 106
     return {
70
-    //   items: _foods,
71
-    loginUser:JSON.parse(localStorage.getItem("loginUser")),
72
-        items:[],
107
+      //   items: _foods,
108
+      incidentWithConsumable: localStorage.getItem("incidentWithConsumable"), //是否绑定耗材
109
+      wxIncidentWithCmdb: localStorage.getItem("wxIncidentWithCmdb"), //是否绑定资产
110
+      loginUser: JSON.parse(localStorage.getItem("loginUser")),
111
+      items: [],
73 112
       pullDownRefresh: true,
74 113
       pullDownRefreshThreshold: 60,
75 114
       pullDownRefreshStop: 40,
76
-      pullDownRefreshTxt: 'Refresh success',
115
+      pullDownRefreshTxt: "Refresh success",
77 116
       pullUpLoad: true,
78 117
       pullUpLoadThreshold: 0,
79
-      pullUpLoadMoreTxt: 'Load more',
80
-      pullUpLoadNoMoreTxt: '没有更多数据',
118
+      pullUpLoadMoreTxt: "Load more",
119
+      pullUpLoadNoMoreTxt: "没有更多数据",
81 120
       customPullDown: true,
82
-      wushuju:false,
83
-      stateData:[
121
+      wushuju: false,
122
+      stateData: [
84 123
         {
85
-          text:"全部",
86
-          value:0
87
-        },{
88
-          text:"未转换",
89
-          value:1592
90
-        },{
91
-          text:"不受理",
92
-          value:1593
93
-        },{
94
-          text:"处理中",
95
-          value:1594
96
-        },{
97
-          text:"待评价",
98
-          value:1595
99
-        },{
100
-          text:"已解决",
101
-          value:1596
102
-        },{
103
-          text:"已撤回",
104
-          value:1597
105
-        }
124
+          text: "全部",
125
+          value: 0,
126
+        },
127
+        {
128
+          text: "未转换",
129
+          value: 1592,
130
+        },
131
+        {
132
+          text: "不受理",
133
+          value: 1593,
134
+        },
135
+        {
136
+          text: "处理中",
137
+          value: 1594,
138
+        },
139
+        {
140
+          text: "待评价",
141
+          value: 1595,
142
+        },
143
+        {
144
+          text: "已解决",
145
+          value: 1596,
146
+        },
147
+        {
148
+          text: "已撤回",
149
+          value: 1597,
150
+        },
106 151
       ],
107
-      stateValue:0,
108
-      sum:10,
109
-      idx:0,
110
-      stateClass:"",
111
-      loadShow:true
112
-    }
152
+      stateValue: 0,
153
+      sum: 10,
154
+      idx: 0,
155
+      stateClass: "",
156
+      loadShow: true,
157
+    };
113 158
   },
114 159
   components: {
115 160
     CubePage,
116 161
     SwitchOption,
117 162
     InputOption,
118 163
     SelectOption,
119
-    LoadIng
164
+    LoadIng,
120 165
   },
121 166
   computed: {
122 167
     options() {
123 168
       return {
124 169
         pullDownRefresh: this.pullDownRefreshObj,
125 170
         pullUpLoad: this.pullUpLoadObj,
126
-        scrollbar: true
127
-      }
171
+        scrollbar: true,
172
+      };
128 173
     },
129
-    pullDownRefreshObj: function() {
130
-      return this.pullDownRefresh ? {
131
-        threshold: parseInt(this.pullDownRefreshThreshold),
132
-        txt: this.pullDownRefreshTxt
133
-      } : false
174
+    pullDownRefreshObj: function () {
175
+      return this.pullDownRefresh
176
+        ? {
177
+            threshold: parseInt(this.pullDownRefreshThreshold),
178
+            txt: this.pullDownRefreshTxt,
179
+          }
180
+        : false;
181
+    },
182
+    pullUpLoadObj: function () {
183
+      return this.pullUpLoad
184
+        ? {
185
+            threshold: parseInt(this.pullUpLoadThreshold),
186
+            txt: {
187
+              more: this.pullUpLoadMoreTxt,
188
+              noMore: this.pullUpLoadNoMoreTxt,
189
+            },
190
+          }
191
+        : false;
134 192
     },
135
-    pullUpLoadObj: function() {
136
-      return this.pullUpLoad ? {
137
-        threshold: parseInt(this.pullUpLoadThreshold),
138
-        txt: {
139
-          more: this.pullUpLoadMoreTxt,
140
-          noMore: this.pullUpLoadNoMoreTxt
141
-        }
142
-      } : false
143
-    }
144 193
   },
145 194
   methods: {
146
-    getParamsState(){
147
-      if(this.$route.params.state){
148
-        this.stateValue=this.$route.params.state
195
+    getParamsState() {
196
+      if (this.$route.params.state) {
197
+        this.stateValue = this.$route.params.state;
149 198
       }
150 199
     },
151
-    stateClassFn(data){
152
-      if(data=="未转换"){
153
-        return "weishouli"
154
-      }else if(data=="不受理"){
155
-        return "bushouli"
156
-      }else if(data=="处理中"){
157
-        return "chulizhong"
158
-      }else if(data=="待评价"){
159
-        return "daipingjia"
160
-      }else if(data=="已解决"){
161
-        return "yijiejue"
162
-      }else if(data=="已撤回"){
163
-        return "yichehui"
164
-      }else{
165
-        return "yichehui"
200
+    stateClassFn(data) {
201
+      if (data == "未转换") {
202
+        return "weishouli";
203
+      } else if (data == "不受理") {
204
+        return "bushouli";
205
+      } else if (data == "处理中") {
206
+        return "chulizhong";
207
+      } else if (data == "待评价") {
208
+        return "daipingjia";
209
+      } else if (data == "已解决") {
210
+        return "yijiejue";
211
+      } else if (data == "已撤回") {
212
+        return "yichehui";
213
+      } else {
214
+        return "yichehui";
166 215
       }
167 216
     },
168
-    stateChange(){
169
-      var that=this;
170
-      this.loadShow=true;
171
-      that.items=[];
172
-      this.$http.post('service/apply/bpm/fetchServiceTasks',{
173
-          'assignee':that.loginUser.account,
174
-          'state':that.stateValue,
175
-          'idx':0,
176
-          'sum':10
177
-          }).then(function(res){
178
-            if(res.data.data.length>0){
179
-              for(var i=0;i<res.data.data.length;i++){
180
-                res.data.data[i].createTime=formatDate(new Date(res.data.data[i].createTime), 'yyyy-MM-dd hh:mm');
181
-              }
182
-              that.items=res.data.data;
183
-              that.wushuju=false
184
-            }else{
185
-              that.wushuju=true
186
-            }
187
-            that.loadShow=false
217
+    stateChange() {
218
+      var that = this;
219
+      this.loadShow = true;
220
+      that.items = [];
221
+      this.$http
222
+        .post("service/apply/bpm/fetchServiceTasks", {
223
+          assignee: that.loginUser.account,
224
+          state: that.stateValue,
225
+          idx: 0,
226
+          sum: 10,
188 227
         })
228
+        .then(function (res) {
229
+          if (res.data.data.length > 0) {
230
+            for (var i = 0; i < res.data.data.length; i++) {
231
+              res.data.data[i].createTime = formatDate(
232
+                new Date(res.data.data[i].createTime),
233
+                "yyyy-MM-dd hh:mm"
234
+              );
235
+            }
236
+            that.items = res.data.data;
237
+            that.wushuju = false;
238
+          } else {
239
+            that.wushuju = true;
240
+          }
241
+          that.loadShow = false;
242
+        });
189 243
     },
190
-    toIncidentDetails(data){
244
+    toIncidentDetails(data) {
191 245
       this.$router.push({
192
-          name:'IncidentDetails',
193
-          params:{
194
-              data:JSON.stringify(data)
195
-          }
196
-      })
246
+        name: "IncidentDetails",
247
+        params: {
248
+          data: JSON.stringify(data),
249
+        },
250
+      });
197 251
     },
198 252
     onPullingDown() {
199 253
       // 模拟更新数据
200
-      this.idx=0;
254
+      this.idx = 0;
201 255
       setTimeout(() => {
202
-        var that=this;
256
+        var that = this;
203 257
         // that.items=[];
204
-        this.$http.post('service/apply/bpm/fetchServiceTasks',{
205
-          'assignee':that.loginUser.account,
206
-          'state':that.stateValue,
207
-          'idx':0,
208
-          'sum':10
209
-          }).then(function(res){
210
-            if(res.data.data.length>0){
211
-                that.wushuju=false;
212
-                for(var i=0;i<res.data.data.length;i++){
213
-                  res.data.data[i].createTime=formatDate(new Date(res.data.data[i].createTime), 'yyyy-MM-dd hh:mm');
214
-                }
215
-                that.items=res.data.data;
216
-            }else{
217
-                that.wushuju=true;
218
-                that.$refs.scroll.forceUpdate()
219
-            }
220
-        })
221
-      }, 1000)
222
-    },
223
-    getData(idx,sum){
224
-        var that=this;
225
-        this.$http.post('service/apply/bpm/fetchServiceTasks',{
226
-            'assignee':that.loginUser.account,
227
-            'state':that.stateValue,
228
-            'idx':idx,
229
-            'sum':sum
230
-        }).then(function(res){
231
-            if(res.data.data.length>0){
232
-              that.wushuju=false;
233
-              for(var i=0;i<res.data.data.length;i++){
234
-                res.data.data[i].createTime=formatDate(new Date(res.data.data[i].createTime), 'yyyy-MM-dd hh:mm');
258
+        this.$http
259
+          .post("service/apply/bpm/fetchServiceTasks", {
260
+            assignee: that.loginUser.account,
261
+            state: that.stateValue,
262
+            idx: 0,
263
+            sum: 10,
264
+          })
265
+          .then(function (res) {
266
+            if (res.data.data.length > 0) {
267
+              that.wushuju = false;
268
+              for (var i = 0; i < res.data.data.length; i++) {
269
+                res.data.data[i].createTime = formatDate(
270
+                  new Date(res.data.data[i].createTime),
271
+                  "yyyy-MM-dd hh:mm"
272
+                );
235 273
               }
236
-              that.items=res.data.data;
237
-            }else{
238
-              that.wushuju=true
274
+              that.items = res.data.data;
275
+            } else {
276
+              that.wushuju = true;
277
+              that.$refs.scroll.forceUpdate();
239 278
             }
240
-            that.loadShow=false
279
+          });
280
+      }, 1000);
281
+    },
282
+    getData(idx, sum) {
283
+      var that = this;
284
+      this.$http
285
+        .post("service/apply/bpm/fetchServiceTasks", {
286
+          assignee: that.loginUser.account,
287
+          state: that.stateValue,
288
+          idx: idx,
289
+          sum: sum,
241 290
         })
291
+        .then(function (res) {
292
+          if (res.data.data.length > 0) {
293
+            that.wushuju = false;
294
+            for (var i = 0; i < res.data.data.length; i++) {
295
+              res.data.data[i].createTime = formatDate(
296
+                new Date(res.data.data[i].createTime),
297
+                "yyyy-MM-dd hh:mm"
298
+              );
299
+            }
300
+            that.items = res.data.data;
301
+          } else {
302
+            that.wushuju = true;
303
+          }
304
+          that.loadShow = false;
305
+        });
242 306
     },
243 307
     onPullingUp() {
244
-      var that=this;
245
-      that.idx=that.idx+1;
246
-        this.$http.post('service/apply/bpm/fetchServiceTasks',{
247
-          'assignee':that.loginUser.account,
248
-          'state':that.stateValue,
249
-          'idx':that.idx,
250
-          'sum':that.sum,
251
-          }).then(function(res){
252
-            for(var i=0;i<res.data.data.length;i++){
253
-              res.data.data[i].createTime=formatDate(new Date(res.data.data[i].createTime), 'yyyy-MM-dd hh:mm');
254
-            }
255
-            setTimeout(() => {
256
-                if(res.data.data.length>0){
257
-                    that.items=that.items.concat(res.data.data);
258
-                }else{
259
-                    that.$refs.scroll.forceUpdate()
260
-                }
261
-            }, 1000)
308
+      var that = this;
309
+      that.idx = that.idx + 1;
310
+      this.$http
311
+        .post("service/apply/bpm/fetchServiceTasks", {
312
+          assignee: that.loginUser.account,
313
+          state: that.stateValue,
314
+          idx: that.idx,
315
+          sum: that.sum,
262 316
         })
317
+        .then(function (res) {
318
+          for (var i = 0; i < res.data.data.length; i++) {
319
+            res.data.data[i].createTime = formatDate(
320
+              new Date(res.data.data[i].createTime),
321
+              "yyyy-MM-dd hh:mm"
322
+            );
323
+          }
324
+          setTimeout(() => {
325
+            if (res.data.data.length > 0) {
326
+              that.items = that.items.concat(res.data.data);
327
+            } else {
328
+              that.$refs.scroll.forceUpdate();
329
+            }
330
+          }, 1000);
331
+        });
263 332
     },
264 333
     updatePullDownRefresh(val) {
265
-      this.pullDownRefresh = val
334
+      this.pullDownRefresh = val;
266 335
     },
267 336
     updatePullDownRefreshThreshold(val) {
268
-      this.pullDownRefreshThreshold = val
337
+      this.pullDownRefreshThreshold = val;
269 338
     },
270 339
     updatePullDownRefreshTxt(val) {
271
-      this.pullDownRefreshTxt = val
340
+      this.pullDownRefreshTxt = val;
272 341
     },
273 342
     updatePullUpLoad(val) {
274
-      this.pullUpLoad = val
343
+      this.pullUpLoad = val;
275 344
     },
276 345
     updatePullUpLoadThreshold(val) {
277
-      this.pullUpLoadThreshold = val
346
+      this.pullUpLoadThreshold = val;
278 347
     },
279 348
     updatePullUpLoadMoreTxt(val) {
280
-      this.pullUpLoadMoreTxt = val
349
+      this.pullUpLoadMoreTxt = val;
281 350
     },
282 351
     updatePullUpLoadNoMoreTxt(val) {
283
-      this.pullUpLoadNoMoreTxt = val
352
+      this.pullUpLoadNoMoreTxt = val;
284 353
     },
285 354
     updateCustomPullDown(val) {
286
-      this.customPullDown = val
355
+      this.customPullDown = val;
287 356
     },
288 357
     rebuildScroll() {
289 358
       Vue.nextTick(() => {
290
-        this.$refs.scroll.destroy()
291
-        this.$refs.scroll.initScroll()
292
-      })
293
-    }
359
+        this.$refs.scroll.destroy();
360
+        this.$refs.scroll.initScroll();
361
+      });
362
+    },
294 363
   },
295
-  created(){
296
-      this.getParamsState();
297
-      this.getData(this.idx,this.sum);
298
-  }
299
-}
364
+  created() {
365
+    this.getParamsState();
366
+    this.getData(this.idx, this.sum);
367
+  },
368
+};
300 369
 </script>
301 370
 <style lang="stylus" rel="stylesheet/stylus" scoped>
302
-.scroll-list-wrap
371
+.scroll-list-wrap {
303 372
   /* height: 350px */
304
-  height:95vh
373
+  height: 95vh;
305 374
   /* border: 1px solid rgba(0, 0, 0, 0.1) */
306
-  border-radius: 5px
307
-  transform: rotate(0deg) // fix 子元素超出边框圆角部分不隐藏的问题
308
-  overflow: hidden
375
+  border-radius: 5px;
376
+  transform: rotate(0deg); // fix 子元素超出边框圆角部分不隐藏的问题
377
+  overflow: hidden;
378
+}
379
+
380
+.foods-wrapper {
381
+  .food-item {
382
+    display: flex;
309 383
 
310
-.foods-wrapper
311
-  .food-item
312
-    display: flex
313 384
     /* padding: 18px */
314 385
     /* border-bottom: 1px solid rgba(7, 17, 27, 0.1) */
315 386
     /* border-top: 1px solid rgba(7, 17, 27, 0.1)!important */
387
+    &:last-child {
388
+      border-none();
389
+      margin-bottom: 0;
390
+    }
316 391
 
317
-    &:last-child
318
-      border-none()
319
-      margin-bottom: 0
320
-    .icon
321
-      flex: 0 0 57px
322
-      margin-right: 10px
392
+    .icon {
393
+      flex: 0 0 57px;
394
+      margin-right: 10px;
395
+    }
323 396
 
324
-    .food-content
325
-      flex: 1
326
-      .name
327
-        margin: 2px 0 8px 0
328
-        height: 14px
329
-        line-height: 14px
330
-        font-size: 14px
331
-        color: rgb(7, 17, 27)
332
-      .description, .extra
333
-        line-height: 10px
334
-        font-size: 10px
335
-        color: rgb(147, 153, 159)
336
-      .description
337
-        line-height: 12px
338
-        margin-bottom: 8px
339
-      .extra
340
-        .count
341
-          margin-right: 12px
342
-      .price
343
-        font-weight: 700
344
-        line-height: 24px
345
-        .now
346
-          margin-right: 8px
347
-          font-size: 14px
348
-          color: rgb(240, 20, 20)
349
-        .old
350
-          text-decoration: line-through
351
-          font-size: 10px
352
-          color: rgb(147, 153, 159)
353
-      .cartcontrol-wrapper
354
-        position: absolute
355
-        right: 0
356
-        bottom: 12px
357
-        .scroll-wrapper{
358
-  .cube-pulldown-wrapper{
359
-    .before-trigger{
360
-      font-size: 30px;
361
-      line-height: 30px;
362
-      align-self: flex-end;
363
-      span{
364
-        display: inline-block;
365
-        transition: all 0.3s;
366
-        color: #666;
367
-        &.rotate{
368
-            transform: rotate(180deg)
369
-          }
397
+    .food-content {
398
+      flex: 1;
399
+
400
+      .name {
401
+        margin: 2px 0 8px 0;
402
+        height: 14px;
403
+        line-height: 14px;
404
+        font-size: 14px;
405
+        color: rgb(7, 17, 27);
370 406
       }
371
-    }
372
-    .after-trigger{
373
-      .refresh-text{
374
-        color: grey
407
+
408
+      .description, .extra {
409
+        line-height: 10px;
410
+        font-size: 10px;
411
+        color: rgb(147, 153, 159);
412
+      }
413
+
414
+      .description {
415
+        line-height: 12px;
416
+        margin-bottom: 8px;
417
+      }
418
+
419
+      .extra {
420
+        .count {
421
+          margin-right: 12px;
422
+        }
423
+      }
424
+
425
+      .price {
426
+        font-weight: 700;
427
+        line-height: 24px;
428
+
429
+        .now {
430
+          margin-right: 8px;
431
+          font-size: 14px;
432
+          color: rgb(240, 20, 20);
433
+        }
434
+
435
+        .old {
436
+          text-decoration: line-through;
437
+          font-size: 10px;
438
+          color: rgb(147, 153, 159);
439
+        }
440
+      }
441
+
442
+      .cartcontrol-wrapper {
443
+        position: absolute;
444
+        right: 0;
445
+        bottom: 12px;
446
+
447
+        .scroll-wrapper {
448
+          .cube-pulldown-wrapper {
449
+            .before-trigger {
450
+              font-size: 30px;
451
+              line-height: 30px;
452
+              align-self: flex-end;
453
+
454
+              span {
455
+                display: inline-block;
456
+                transition: all 0.3s;
457
+                color: #666;
458
+
459
+                &.rotate {
460
+                  transform: rotate(180deg);
461
+                }
462
+              }
463
+            }
464
+
465
+            .after-trigger {
466
+              .refresh-text {
467
+                color: grey;
468
+              }
469
+            }
470
+          }
471
+        }
375 472
       }
376 473
     }
377
- }
474
+  }
378 475
 }
379 476
 </style>
380 477
 <style scoped>
381
-.bgColor{
382
-    background-color: white
478
+.bgColor {
479
+  background-color: white;
383 480
 }
384
-.food-item{
385
-  border-top: .16rem rgb(238,238,238) solid;
481
+.food-item {
482
+  border-top: 0.16rem rgb(238, 238, 238) solid;
386 483
 }
387
-.food-content{
388
-  border-top: .01rem rgb(223, 222, 222) solid;
389
-  border-bottom: .01rem rgb(223, 222, 222) solid;
484
+.food-content {
485
+  border-top: 0.01rem rgb(223, 222, 222) solid;
486
+  border-bottom: 0.01rem rgb(223, 222, 222) solid;
390 487
 }
391
-.cube-select{
392
-  height: .88rem;
393
-  line-height: .88rem;
394
-  padding: 0 .24rem;
395
-  font-size: .36rem;
396
-  color:#333333
488
+.cube-select {
489
+  height: 0.88rem;
490
+  line-height: 0.88rem;
491
+  padding: 0 0.24rem;
492
+  font-size: 0.36rem;
493
+  color: #333333;
397 494
 }
398
-.title{
495
+.title {
399 496
   display: flex;
400
-  justify-content:space-between;
401
-  height: .7rem;
402
-  line-height: .7rem;
403
-  border-top: .01rem rgb(223, 222, 222) solid;
404
-  padding: 0 .24rem;
405
-  border-bottom: .01rem rgb(223, 222, 222) solid;
497
+  justify-content: space-between;
498
+  height: 0.7rem;
499
+  line-height: 0.7rem;
500
+  border-top: 0.01rem rgb(223, 222, 222) solid;
501
+  padding: 0 0.24rem;
502
+  border-bottom: 0.01rem rgb(223, 222, 222) solid;
406 503
 }
407
-.title i{
408
-  font-size: .32rem;
409
-  color: #005395
504
+.title i {
505
+  font-size: 0.32rem;
506
+  color: #005395;
410 507
 }
411
-.title div:nth-child(1){
412
-  font-size: .32rem;
508
+.title div:nth-child(1) {
509
+  font-size: 0.32rem;
413 510
 }
414
-.title div:nth-child(1) span{
511
+.title div:nth-child(1) span {
415 512
   display: inline-block;
416
-  margin-left: .08rem
513
+  margin-left: 0.08rem;
417 514
 }
418
-.title div:nth-child(2){
419
-  padding: .05rem .3rem;
515
+.title div:nth-child(2) {
516
+  padding: 0.05rem 0.3rem;
420 517
   /* border: 0.01rem rgb(0,0,255) solid; */
421
-  border-radius: 16px ;
518
+  border-radius: 16px;
422 519
   /* color: rgb(0,0,255); */
423
-  height: .25rem;
424
-  line-height: .25rem;
425
-  margin-top: .15rem;
426
-  font-size: .24rem
520
+  height: 0.25rem;
521
+  line-height: 0.25rem;
522
+  margin-top: 0.15rem;
523
+  font-size: 0.24rem;
427 524
 }
428
-.weishouli{
429
-  color:#991f00;
525
+.weishouli {
526
+  color: #991f00;
430 527
   border: 0.01rem #991f00 solid;
431
-  background-color: #f4e8e5
528
+  background-color: #f4e8e5;
432 529
 }
433
-.bushouli{
434
-  color:#666666;
530
+.bushouli {
531
+  color: #666666;
435 532
   background-color: #eeeeee;
436 533
   border: 0.01rem #666666 solid;
437 534
 }
438
-.chulizhong{
439
-  color:#003057;
535
+.chulizhong {
536
+  color: #003057;
440 537
   background-color: #e5eaee;
441 538
   border: 0.01rem #003057 solid;
442 539
 }
443
-.daipingjia{
444
-  color:#825b00;
540
+.daipingjia {
541
+  color: #825b00;
445 542
   background-color: #f2eee5;
446 543
   border: 0.01rem #825b00 solid;
447 544
 }
448
-.yijiejue{
449
-  color:#40a19c;
545
+.yijiejue {
546
+  color: #40a19c;
450 547
   background-color: #ebf5f5;
451 548
   border: 0.01rem #40a19c solid;
452 549
 }
453
-.yichehui{
454
-  color:#48a843;
550
+.yichehui {
551
+  color: #48a843;
455 552
   background-color: #ecf6ec;
456 553
   border: 0.01rem #48a843 solid;
457 554
 }
458
-.conent{
459
-  font-size: .28rem;
460
-  line-height: .39rem;
555
+.conent {
556
+  font-size: 0.28rem;
557
+  line-height: 0.39rem;
461 558
   overflow: hidden;
462 559
   display: -webkit-box;
463 560
   -webkit-line-clamp: 2;
464 561
   -webkit-box-orient: vertical;
465 562
   word-break: break-all;
466
-  padding: 0 .64rem;
467
-  margin: .24rem 0
563
+  padding: 0 0.64rem;
564
+  margin: 0.24rem 0;
468 565
 }
469
-.timeBox{
566
+.timeBox {
470 567
   display: flex;
471
-  justify-content:space-between;
472
-  font-size: .24rem;
568
+  justify-content: space-between;
569
+  font-size: 0.24rem;
473 570
   color: #999999;
474
-  border-top: .01rem rgb(223, 222, 222) solid;
475
-  height: .7rem;
476
-  line-height: .7rem;
477
-  padding: 0 .24rem 0 .64rem
571
+  height: 0.7rem;
572
+  line-height: 0.7rem;
573
+  padding: 0 0.24rem 0 0.24rem;
574
+  border-top: 0.01rem rgb(223, 222, 222) solid;
575
+}
576
+.timeBox.noneBorder {
577
+  border-top: none;
478 578
 }
479
-.wushuju{
480
-    margin-top: 2.4rem;
481
-    text-align: center;
579
+.wushuju {
580
+  margin-top: 2.4rem;
581
+  text-align: center;
482 582
 }
483
-.wushuju img{
484
-    width: 5.12rem;
485
-    height: 2.84rem;
583
+.wushuju img {
584
+  width: 5.12rem;
585
+  height: 2.84rem;
486 586
 }
487 587
 </style>

+ 43 - 2
src/views/repair.vue

@@ -42,6 +42,11 @@
42 42
         ></cube-form-item>
43 43
         <div class="label">报修信息</div>
44 44
         <cube-form-item :field="fields[4]"></cube-form-item>
45
+        <div class="label" v-if="wxIncidentWithCmdb == 1">资产</div>
46
+        <div class="zc" v-if="wxIncidentWithCmdb == 1">
47
+          <cube-form-item :field="fields[7]" class="zc-item"></cube-form-item>
48
+          <span class="icon dash dash-saoyisao zc-sao" @click="scan()"></span>
49
+        </div>
45 50
         <div class="label">
46 51
           报修图片
47 52
           <span>(最多可上传3张JPG或PNG,每张不能超过10M)</span>
@@ -76,6 +81,7 @@ import DatePicker from "./../components/date-picker.vue";
76 81
 import CubeExtendPopup from "./../components/extend-popup.vue";
77 82
 import LoadIng from "./../views/loading.vue";
78 83
 import PrompTing from "./../views/prompting.vue";
84
+import { SM } from "./../http/http";
79 85
 const PCA = {
80 86
   props: {
81 87
     value: {
@@ -183,6 +189,8 @@ const delay = (function() {
183 189
 export default {
184 190
   data() {
185 191
     return {
192
+      incidentWithConsumable: localStorage.getItem("incidentWithConsumable"), //是否绑定耗材
193
+      wxIncidentWithCmdb: localStorage.getItem("wxIncidentWithCmdb"), //是否绑定资产
186 194
       loginUser: null,
187 195
       // 故障地点下拉数据
188 196
       // addressData: [],
@@ -223,7 +231,8 @@ export default {
223 231
         description: "",
224 232
         bxcode: "",
225 233
         deptId: "",
226
-        contacts: ""
234
+        contacts: "",
235
+        assetId:'',
227 236
       },
228 237
       // showPrompting:false,
229 238
       promptingConent: "",
@@ -310,11 +319,29 @@ export default {
310 319
           rules: {
311 320
             required: true
312 321
           }
313
-        }
322
+        },
323
+        {
324
+          type: "input",
325
+          modelKey: "assetId",
326
+          label: "资产:",
327
+          props: {
328
+            placeholder: "右侧扫一扫资产",
329
+            disabled:true
330
+          },
331
+          rules: {
332
+            required: false
333
+          },
334
+        },
314 335
       ]
315 336
     };
316 337
   },
317 338
   methods: {
339
+    //扫资产
340
+    scan(){
341
+      SM(this).then((ress1) => {
342
+        this.model.assetId = ress1;
343
+      })
344
+    },
318 345
     // -----------故障地点-----
319 346
     showAddressPicker() {
320 347
       if (!this.picker) {
@@ -617,6 +644,20 @@ export default {
617 644
 };
618 645
 </script>
619 646
 <style lang="stylus" rel="stylesheet/stylus" scoped>
647
+.zc{
648
+  display:flex;
649
+  position:relative;
650
+  .zc-item{
651
+    flex:7;
652
+  }
653
+  .zc-sao{
654
+    flex:3;
655
+    display:flex;
656
+    justify-content:center;
657
+    align-item:center;
658
+    font-size:0.6rem;
659
+  }
660
+}
620 661
 .form-custom {
621 662
   .cube-form-item {
622 663
     .cube-btn {

+ 26 - 3
static/font/seimin/demo_index.html

@@ -55,6 +55,12 @@
55 55
           <ul class="icon_lists dib-box">
56 56
           
57 57
             <li class="dib">
58
+              <span class="icon dash">&#xe8b5;</span>
59
+                <div class="name">扫一扫</div>
60
+                <div class="code-name">&amp;#xe8b5;</div>
61
+              </li>
62
+          
63
+            <li class="dib">
58 64
               <span class="icon dash">&#xe609;</span>
59 65
                 <div class="name">fangdajing</div>
60 66
                 <div class="code-name">&amp;#xe609;</div>
@@ -90,9 +96,9 @@
90 96
 <pre><code class="language-css"
91 97
 >@font-face {
92 98
   font-family: 'dash';
93
-  src: url('iconfont.woff2?t=1638846521111') format('woff2'),
94
-       url('iconfont.woff?t=1638846521111') format('woff'),
95
-       url('iconfont.ttf?t=1638846521111') format('truetype');
99
+  src: url('iconfont.woff2?t=1641526164246') format('woff2'),
100
+       url('iconfont.woff?t=1641526164246') format('woff'),
101
+       url('iconfont.ttf?t=1641526164246') format('truetype');
96 102
 }
97 103
 </code></pre>
98 104
           <h3 id="-iconfont-">第二步:定义使用 iconfont 的样式</h3>
@@ -119,6 +125,15 @@
119 125
         <ul class="icon_lists dib-box">
120 126
           
121 127
           <li class="dib">
128
+            <span class="icon dash dash-saoyisao"></span>
129
+            <div class="name">
130
+              扫一扫
131
+            </div>
132
+            <div class="code-name">.dash-saoyisao
133
+            </div>
134
+          </li>
135
+          
136
+          <li class="dib">
122 137
             <span class="icon dash dash-fangdajing"></span>
123 138
             <div class="name">
124 139
               fangdajing
@@ -174,6 +189,14 @@
174 189
           
175 190
             <li class="dib">
176 191
                 <svg class="icon svg-icon" aria-hidden="true">
192
+                  <use xlink:href="#dash-saoyisao"></use>
193
+                </svg>
194
+                <div class="name">扫一扫</div>
195
+                <div class="code-name">#dash-saoyisao</div>
196
+            </li>
197
+          
198
+            <li class="dib">
199
+                <svg class="icon svg-icon" aria-hidden="true">
177 200
                   <use xlink:href="#dash-fangdajing"></use>
178 201
                 </svg>
179 202
                 <div class="name">fangdajing</div>

+ 7 - 3
static/font/seimin/iconfont.css

@@ -1,8 +1,8 @@
1 1
 @font-face {
2 2
   font-family: "dash"; /* Project id 2879659 */
3
-  src: url('iconfont.woff2?t=1638846521111') format('woff2'),
4
-       url('iconfont.woff?t=1638846521111') format('woff'),
5
-       url('iconfont.ttf?t=1638846521111') format('truetype');
3
+  src: url('iconfont.woff2?t=1641526164246') format('woff2'),
4
+       url('iconfont.woff?t=1641526164246') format('woff'),
5
+       url('iconfont.ttf?t=1641526164246') format('truetype');
6 6
 }
7 7
 
8 8
 .dash {
@@ -13,6 +13,10 @@
13 13
   -moz-osx-font-smoothing: grayscale;
14 14
 }
15 15
 
16
+.dash-saoyisao:before {
17
+  content: "\e8b5";
18
+}
19
+
16 20
 .dash-fangdajing:before {
17 21
   content: "\e609";
18 22
 }

Різницю між файлами не показано, бо вона завелика
+ 1 - 1
static/font/seimin/iconfont.js


+ 7 - 0
static/font/seimin/iconfont.json

@@ -6,6 +6,13 @@
6 6
   "description": "引入一个新的字体图标",
7 7
   "glyphs": [
8 8
     {
9
+      "icon_id": "11372685",
10
+      "name": "扫一扫",
11
+      "font_class": "saoyisao",
12
+      "unicode": "e8b5",
13
+      "unicode_decimal": 59573
14
+    },
15
+    {
9 16
       "icon_id": "463375",
10 17
       "name": "fangdajing",
11 18
       "font_class": "fangdajing",

BIN
static/font/seimin/iconfont.ttf


BIN
static/font/seimin/iconfont.woff


BIN
static/font/seimin/iconfont.woff2