safecheck-client 3.0.33-97 → 3.0.33-99

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (295) hide show
  1. package/.babelrc +5 -5
  2. package/.editorconfig +9 -9
  3. package/android.html +18 -18
  4. package/build/css-loaders.js +34 -34
  5. package/build/dev-android.js +151 -151
  6. package/build/dev-client.js +8 -8
  7. package/build/release.sh +28 -28
  8. package/build/utils.js +71 -71
  9. package/build/webpack.baseandroid.conf.js +83 -83
  10. package/build/webpack.devandroid.conf.js +33 -33
  11. package/build/webpack.hanwei.conf.js +57 -57
  12. package/build/webpack.hwbase.conf.js +78 -78
  13. package/build/webpack.prodandroid.conf.js +60 -60
  14. package/build/webpack.test.conf.js +31 -31
  15. package/config/dev.env.js +6 -6
  16. package/config/index.js +38 -38
  17. package/config/prod.env.js +3 -3
  18. package/config/test.env.js +6 -6
  19. package/docs/AppBase.md +22 -22
  20. package/docs/Busy.md +14 -14
  21. package/docs/Criteria.md +47 -47
  22. package/docs/CriteriaPaged.md +47 -47
  23. package/docs/DataGrid.md +54 -54
  24. package/docs/DataModel.md +22 -22
  25. package/docs/Dynamic.md +42 -42
  26. package/docs/FormPrint.md +18 -18
  27. package/docs/GetParams.md +11 -11
  28. package/docs/GridTree.md +47 -47
  29. package/docs/HttpBusy.md +13 -13
  30. package/docs/HttpStore.md +29 -29
  31. package/docs/MessageBox.md +28 -28
  32. package/docs/PagedList.md +29 -29
  33. package/docs/Pager.md +21 -21
  34. package/docs/PrintFile.md +38 -38
  35. package/docs/Project.md +23 -23
  36. package/docs/Route.md +105 -105
  37. package/docs/SafetyCheck/AdjustPlan.md +13 -13
  38. package/docs/SafetyCheck/CheckerPlan.md +12 -12
  39. package/docs/Task.md +46 -46
  40. package/docs/TreeList.md +28 -28
  41. package/docs/TreeMixin.md +18 -18
  42. package/docs/all.md +10 -10
  43. package/docs/list.md +42 -42
  44. package/docs/partial.md +75 -75
  45. package/docs/selector.md +82 -82
  46. package/docs/tree.md +40 -40
  47. package/docs//345/274/200/345/217/221/346/226/207/346/241/243/Snippets.md +28 -28
  48. package/docs//345/274/200/345/217/221/346/226/207/346/241/243/vue-strap/345/217/230/346/233/264/350/256/260/345/275/225.md +7 -7
  49. package/docs//345/274/200/345/217/221/346/226/207/346/241/243/vue/345/217/230/346/233/264/350/256/260/345/275/225.md +13 -13
  50. package/docs//345/274/200/345/217/221/346/226/207/346/241/243//345/274/200/345/217/221/347/216/257/345/242/203/350/256/276/347/275/256.md +77 -77
  51. package/docs//347/225/214/351/235/242/345/210/266/344/275/234/350/247/204/350/214/203.md +54 -54
  52. package/examples/AddressList/App.vue +13 -13
  53. package/examples/AddressList/index.html +11 -11
  54. package/examples/DispatchList/App.vue +10 -10
  55. package/examples/DispatchList/BaseTree.vue +13 -13
  56. package/examples/DispatchList/Init.vue +22 -22
  57. package/examples/DispatchList/Test.vue +20 -20
  58. package/examples/DispatchList/index.html +11 -11
  59. package/examples/DispatchList/main.js +18 -18
  60. package/home.html +16 -16
  61. package/package.json +1 -1
  62. package/publish.bat +7 -7
  63. package/release.bat +5 -5
  64. package/src/Widget.vue +13 -13
  65. package/src/android-bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  66. package/src/android-bootstrap/less/.csscomb.json +304 -304
  67. package/src/android-bootstrap/less/.csslintrc +19 -19
  68. package/src/android-bootstrap/less/alerts.less +73 -73
  69. package/src/android-bootstrap/less/badges.less +66 -66
  70. package/src/android-bootstrap/less/bootstrap.less +56 -56
  71. package/src/android-bootstrap/less/breadcrumbs.less +26 -26
  72. package/src/android-bootstrap/less/button-groups.less +247 -247
  73. package/src/android-bootstrap/less/buttons.less +173 -173
  74. package/src/android-bootstrap/less/carousel.less +269 -269
  75. package/src/android-bootstrap/less/close.less +34 -34
  76. package/src/android-bootstrap/less/code.less +69 -69
  77. package/src/android-bootstrap/less/component-animations.less +33 -33
  78. package/src/android-bootstrap/less/grid.less +84 -84
  79. package/src/android-bootstrap/less/input-groups.less +167 -167
  80. package/src/android-bootstrap/less/jumbotron.less +52 -52
  81. package/src/android-bootstrap/less/labels.less +64 -64
  82. package/src/android-bootstrap/less/list-group.less +141 -141
  83. package/src/android-bootstrap/less/media.less +66 -66
  84. package/src/android-bootstrap/less/mixins/alerts.less +14 -14
  85. package/src/android-bootstrap/less/mixins/background-variant.less +9 -9
  86. package/src/android-bootstrap/less/mixins/border-radius.less +18 -18
  87. package/src/android-bootstrap/less/mixins/buttons.less +69 -69
  88. package/src/android-bootstrap/less/mixins/center-block.less +7 -7
  89. package/src/android-bootstrap/less/mixins/clearfix.less +22 -22
  90. package/src/android-bootstrap/less/mixins/forms.less +90 -90
  91. package/src/android-bootstrap/less/mixins/gradients.less +59 -59
  92. package/src/android-bootstrap/less/mixins/grid-framework.less +92 -92
  93. package/src/android-bootstrap/less/mixins/grid.less +122 -122
  94. package/src/android-bootstrap/less/mixins/hide-text.less +21 -21
  95. package/src/android-bootstrap/less/mixins/image.less +33 -33
  96. package/src/android-bootstrap/less/mixins/labels.less +12 -12
  97. package/src/android-bootstrap/less/mixins/list-group.less +30 -30
  98. package/src/android-bootstrap/less/mixins/nav-divider.less +10 -10
  99. package/src/android-bootstrap/less/mixins/nav-vertical-align.less +9 -9
  100. package/src/android-bootstrap/less/mixins/opacity.less +8 -8
  101. package/src/android-bootstrap/less/mixins/pagination.less +24 -24
  102. package/src/android-bootstrap/less/mixins/panels.less +24 -24
  103. package/src/android-bootstrap/less/mixins/progress-bar.less +10 -10
  104. package/src/android-bootstrap/less/mixins/reset-filter.less +8 -8
  105. package/src/android-bootstrap/less/mixins/reset-text.less +18 -18
  106. package/src/android-bootstrap/less/mixins/resize.less +6 -6
  107. package/src/android-bootstrap/less/mixins/responsive-visibility.less +15 -15
  108. package/src/android-bootstrap/less/mixins/size.less +10 -10
  109. package/src/android-bootstrap/less/mixins/tab-focus.less +9 -9
  110. package/src/android-bootstrap/less/mixins/table-row.less +44 -44
  111. package/src/android-bootstrap/less/mixins/text-emphasis.less +9 -9
  112. package/src/android-bootstrap/less/mixins/text-overflow.less +8 -8
  113. package/src/android-bootstrap/less/mixins/vendor-prefixes.less +227 -227
  114. package/src/android-bootstrap/less/mixins.less +40 -40
  115. package/src/android-bootstrap/less/modals.less +151 -151
  116. package/src/android-bootstrap/less/navbar.less +660 -660
  117. package/src/android-bootstrap/less/navs.less +290 -290
  118. package/src/android-bootstrap/less/normalize.less +424 -424
  119. package/src/android-bootstrap/less/pager.less +76 -76
  120. package/src/android-bootstrap/less/pagination.less +89 -89
  121. package/src/android-bootstrap/less/panels.less +274 -274
  122. package/src/android-bootstrap/less/popovers.less +131 -131
  123. package/src/android-bootstrap/less/print.less +101 -101
  124. package/src/android-bootstrap/less/progress-bars.less +87 -87
  125. package/src/android-bootstrap/less/responsive-embed.less +35 -35
  126. package/src/android-bootstrap/less/responsive-utilities.less +194 -194
  127. package/src/android-bootstrap/less/scaffolding.less +161 -161
  128. package/src/android-bootstrap/less/tables.less +262 -262
  129. package/src/android-bootstrap/less/theme.less +291 -291
  130. package/src/android-bootstrap/less/thumbnails.less +36 -36
  131. package/src/android-bootstrap/less/tooltip.less +102 -102
  132. package/src/android-bootstrap/less/type.less +303 -303
  133. package/src/android-bootstrap/less/utilities.less +55 -55
  134. package/src/android-bootstrap/less/variables.less +896 -896
  135. package/src/android-bootstrap/less/wells.less +29 -29
  136. package/src/androidTest.js +20 -20
  137. package/src/bootstrap/less/.csscomb.json +304 -304
  138. package/src/bootstrap/less/.csslintrc +19 -19
  139. package/src/bootstrap/less/alerts.less +73 -73
  140. package/src/bootstrap/less/badges.less +66 -66
  141. package/src/bootstrap/less/breadcrumbs.less +26 -26
  142. package/src/bootstrap/less/button-groups.less +247 -247
  143. package/src/bootstrap/less/buttons.less +172 -172
  144. package/src/bootstrap/less/carousel.less +269 -269
  145. package/src/bootstrap/less/close.less +34 -34
  146. package/src/bootstrap/less/code.less +69 -69
  147. package/src/bootstrap/less/component-animations.less +33 -33
  148. package/src/bootstrap/less/dropdowns.less +216 -216
  149. package/src/bootstrap/less/forms.less +626 -626
  150. package/src/bootstrap/less/grid.less +84 -84
  151. package/src/bootstrap/less/input-groups.less +167 -167
  152. package/src/bootstrap/less/jumbotron.less +52 -52
  153. package/src/bootstrap/less/labels.less +64 -64
  154. package/src/bootstrap/less/list-group.less +141 -141
  155. package/src/bootstrap/less/media.less +66 -66
  156. package/src/bootstrap/less/mixins/alerts.less +14 -14
  157. package/src/bootstrap/less/mixins/background-variant.less +9 -9
  158. package/src/bootstrap/less/mixins/border-radius.less +18 -18
  159. package/src/bootstrap/less/mixins/buttons.less +69 -69
  160. package/src/bootstrap/less/mixins/center-block.less +7 -7
  161. package/src/bootstrap/less/mixins/clearfix.less +22 -22
  162. package/src/bootstrap/less/mixins/forms.less +90 -90
  163. package/src/bootstrap/less/mixins/gradients.less +59 -59
  164. package/src/bootstrap/less/mixins/grid-framework.less +92 -92
  165. package/src/bootstrap/less/mixins/grid.less +122 -122
  166. package/src/bootstrap/less/mixins/hide-text.less +21 -21
  167. package/src/bootstrap/less/mixins/image.less +33 -33
  168. package/src/bootstrap/less/mixins/labels.less +12 -12
  169. package/src/bootstrap/less/mixins/list-group.less +30 -30
  170. package/src/bootstrap/less/mixins/nav-divider.less +10 -10
  171. package/src/bootstrap/less/mixins/nav-vertical-align.less +9 -9
  172. package/src/bootstrap/less/mixins/opacity.less +8 -8
  173. package/src/bootstrap/less/mixins/pagination.less +24 -24
  174. package/src/bootstrap/less/mixins/panels.less +24 -24
  175. package/src/bootstrap/less/mixins/progress-bar.less +10 -10
  176. package/src/bootstrap/less/mixins/reset-filter.less +8 -8
  177. package/src/bootstrap/less/mixins/reset-text.less +18 -18
  178. package/src/bootstrap/less/mixins/resize.less +6 -6
  179. package/src/bootstrap/less/mixins/responsive-visibility.less +15 -15
  180. package/src/bootstrap/less/mixins/size.less +10 -10
  181. package/src/bootstrap/less/mixins/tab-focus.less +9 -9
  182. package/src/bootstrap/less/mixins/table-row.less +44 -44
  183. package/src/bootstrap/less/mixins/text-emphasis.less +9 -9
  184. package/src/bootstrap/less/mixins/text-overflow.less +8 -8
  185. package/src/bootstrap/less/mixins/vendor-prefixes.less +227 -227
  186. package/src/bootstrap/less/mixins.less +40 -40
  187. package/src/bootstrap/less/modals.less +151 -151
  188. package/src/bootstrap/less/navbar.less +660 -660
  189. package/src/bootstrap/less/normalize.less +424 -424
  190. package/src/bootstrap/less/pager.less +76 -76
  191. package/src/bootstrap/less/pagination.less +89 -89
  192. package/src/bootstrap/less/panels.less +275 -275
  193. package/src/bootstrap/less/popovers.less +131 -131
  194. package/src/bootstrap/less/print.less +101 -101
  195. package/src/bootstrap/less/progress-bars.less +87 -87
  196. package/src/bootstrap/less/responsive-embed.less +35 -35
  197. package/src/bootstrap/less/responsive-utilities.less +194 -194
  198. package/src/bootstrap/less/scaffolding.less +161 -161
  199. package/src/bootstrap/less/theme.less +291 -291
  200. package/src/bootstrap/less/thumbnails.less +36 -36
  201. package/src/bootstrap/less/tooltip.less +102 -102
  202. package/src/bootstrap/less/type.less +303 -303
  203. package/src/bootstrap/less/utilities.less +55 -55
  204. package/src/bootstrap/less/wells.less +29 -29
  205. package/src/components/FileUpload.vue +696 -696
  206. package/src/components/Hello.vue +39 -39
  207. package/src/components/LeftTree.vue +27 -27
  208. package/src/components/android/AddGas.vue +147 -147
  209. package/src/components/android/AddressList.vue +61 -61
  210. package/src/components/android/AttendanceTally.vue +116 -116
  211. package/src/components/android/Blank.vue +10 -10
  212. package/src/components/android/CheckUnplanPage.vue +56 -56
  213. package/src/components/android/Checker.vue +12 -12
  214. package/src/components/android/CheckerAnnual.vue +81 -81
  215. package/src/components/android/CheckerAvarta.vue +82 -82
  216. package/src/components/android/CheckerMonthly.vue +84 -84
  217. package/src/components/android/EquipmentInspection.vue +348 -348
  218. package/src/components/android/FootprintMap.vue +120 -120
  219. package/src/components/android/HiddentroubleInvestigation.vue +192 -192
  220. package/src/components/android/LcheckUnplan.vue +108 -108
  221. package/src/components/android/MasterMain.vue +77 -77
  222. package/src/components/android/Menu.vue +132 -132
  223. package/src/components/android/NavBottom.vue +157 -157
  224. package/src/components/android/PaperAlarm.vue +85 -85
  225. package/src/components/android/PaperDeviceNoncivil.vue +214 -214
  226. package/src/components/android/PlumberAnnual.vue +83 -83
  227. package/src/components/android/PlumberAnnualDetail.vue +65 -65
  228. package/src/components/android/PlumberMonthly.vue +84 -84
  229. package/src/components/android/PostMap.vue +83 -83
  230. package/src/components/android/QueryCheckHistory.vue +122 -122
  231. package/src/components/android/QueryCheckHistoryItem.vue +62 -62
  232. package/src/components/android/RepairMain.vue +60 -60
  233. package/src/components/android/Repairman.vue +12 -12
  234. package/src/components/android/SafecheckDevices.vue +1296 -1296
  235. package/src/components/android/StationMaster.vue +12 -12
  236. package/src/components/checkerphonestate/Checker.vue +32 -32
  237. package/src/components/checkerphonestate/CheckerState.vue +97 -97
  238. package/src/components/defects/AddDefectModal.vue +120 -120
  239. package/src/components/defects/AddDevice.vue +95 -95
  240. package/src/components/defects/DefectModal.vue +101 -101
  241. package/src/components/defects/DevicesAndItem.vue +39 -39
  242. package/src/components/defects/DevicesSeting.vue +106 -106
  243. package/src/components/issueplan/IssuePlanMain.vue +23 -23
  244. package/src/components/metterfiles/AddUserfiles.vue +246 -246
  245. package/src/components/metterfiles/MetterFiles.vue +104 -104
  246. package/src/components/notice/NoticeForm.vue +100 -100
  247. package/src/components/notice/NoticeIssue.vue +20 -20
  248. package/src/components/notice/NoticeQuery.vue +76 -76
  249. package/src/components/paper/PicViewer.vue +18 -18
  250. package/src/components/paper/PlanChooser.vue +167 -165
  251. package/src/components/paper/RepairVerifyForm.vue +76 -76
  252. package/src/components/phonestate/DailyTraffic.vue +57 -57
  253. package/src/components/phonestate/LastKnownState.vue +74 -74
  254. package/src/components/phonestate/MonthlyTraffic.vue +66 -66
  255. package/src/components/phonestate/MonthlyTrafficRouter.vue +15 -15
  256. package/src/components/phonestate/PostMap.vue +82 -82
  257. package/src/components/planmanage/PlanManage.vue +836 -834
  258. package/src/components/querycheckpaper/PaperItem.vue +59 -59
  259. package/src/components/task/RepairAnnual.vue +79 -79
  260. package/src/components/task/RepairAnnualDetail.vue +49 -49
  261. package/src/components/task/RepairMonthly.vue +91 -91
  262. package/src/components/task/TaskAnnual.vue +77 -77
  263. package/src/components/task/TaskAnnualDetail.vue +47 -47
  264. package/src/components/task/TaskMonthly.vue +89 -89
  265. package/src/components/userfile/MeterFile.vue +145 -145
  266. package/src/components/userfile/MeterModify.vue +46 -46
  267. package/src/components/userfile/UserFile.vue +118 -118
  268. package/src/components/userfile/UserfileChange.vue +277 -277
  269. package/src/components/userfileaudit/MeterAuditFile.vue +129 -129
  270. package/src/filiale/liaoyuan/pc/checkPlanList.vue +373 -0
  271. package/src/filiale/liaoyuan/pc.js +18 -17
  272. package/src/filiale/rongchuang/android/SafecheckOrderV.vue +2692 -2692
  273. package/src/filiale/tianke/pc/checkScreen.vue +780 -780
  274. package/src/filiale/weinan/android/SafecheckDevices.vue +1295 -1295
  275. package/src/filiale/yangchunboneng/android/SafecheckDevices.vue +1332 -1332
  276. package/src/filiale/yangchunboneng/pc/CheckBookList.vue +347 -347
  277. package/src/filiale/yangchunboneng/pc/CheckBookUser.vue +269 -269
  278. package/src/filiale/yangchunboneng/pc/CheckSearchUser.vue +1192 -1192
  279. package/src/filiale/yongzhou/android/SafecheckOrderV.vue +2774 -2774
  280. package/src/filiale/yongzhou/pc/PaperDefectMain.vue +872 -872
  281. package/src/filiale/yongzhou/pc/SelectCheckPlan.vue +364 -364
  282. package/src/filiale/yongzhou/pc/communityTypeDetailG.vue +138 -138
  283. package/src/main.js +33 -33
  284. package/src/plugins/LoadData.js +10 -10
  285. package/src/plugins/LoadParams.js +24 -24
  286. package/src/stores/wxconfig.js +10 -10
  287. package/src/utils/getNowDate.js +33 -33
  288. package/test/e2e/custom-assertions/elementCount.js +26 -26
  289. package/test/e2e/nightwatch.conf.js +40 -40
  290. package/test/e2e/runner.js +30 -30
  291. package/test/e2e/specs/test.js +13 -13
  292. package/test/unit/.eslintrc +5 -5
  293. package/test/unit/TestUtil.js +62 -62
  294. package/test/unit/context.html +20 -20
  295. package/test/unit/index.js +13 -13
@@ -1,780 +1,780 @@
1
- <template>
2
- <div class="flex-row">
3
- <div class="basic-main" style="flex:7">
4
- <div id="check_map" style="height:100%">
5
- <img-self-safe :src="imgSrc" width="45" style="z-index: 0"
6
- height="50" class="img-rounded" v-ref:defectimg></img-self-safe>
7
- </div>
8
- </div>
9
- <modal :styles="'width:1230px'" width="1230px" :show.sync="showModal" v-ref:modal backdrop="false">
10
- <header slot="modal-header" class="modal-header" v-show="false"></header>
11
- <article slot="modal-body" class="modal-body" style="width: 1200px;">
12
- <div class="auto">
13
- <img style="height:800px;width: 1200px;" src="./cq.jpg"
14
- v-show="city_properEnable" alt="图片加载失败"/>
15
- <img style="height:800px;width: 1200px;" src="./qy.jpg"
16
- v-show="townshipEnable" alt="图片加载失败"/>
17
- </div>
18
- </article>
19
- <footer slot="modal-footer" class="modal-footer">
20
- <button type="button" class="btn btn-success" @click='closeModal()'>关闭</button>
21
- </footer>
22
- </modal>
23
-
24
- <div id="zzz" class="basic-main" style="flex:1;margin-left: 0px;overflow: hidden">
25
- <div class="flex">
26
- <div class="panel panel-info" style="flex: 1;margin-top:0px">
27
- <div class="panel-heading" style="height: auto">
28
- <h3 class="panel-title">图层设置</h3>
29
- </div>
30
- <div class="panel-body">
31
- <ul class="safe_ul_sty">
32
- <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="layers.satelliteEnable" @change="enableChange('satelliteEnable',layers.satelliteEnable)" type="checkbox"/>卫星图层</li>
33
- <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="layers.roadNetEnable" @change="enableChange('roadNetEnable',layers.roadNetEnable)" type="checkbox"/>网路图层</li>
34
- <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="layers.townshipEnable" @click="enableChange('townshipEnable')" type="checkbox"/>乡镇管网图层</li>
35
- <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="layers.city_properEnable" @click="enableChange('city_properEnable')" type="checkbox"/>城区管网图层</li>
36
- <!--<button @click="safeRefresh">刷新111</button>-->
37
- </ul>
38
- </div>
39
- </div>
40
- <div class="panel panel-info" style="flex: 2;margin-top:0px;">
41
- <div class="panel-heading" style="height: auto">
42
- <h3 class="panel-title">覆盖物设置</h3>
43
- </div>
44
- <div class="panel-body">
45
- <ul class="safe_ul_sty">
46
- <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="mulchs.checker" @change="enableChange('checker',mulchs.checker)" type="checkbox"/><img class="safe_deimg" src="../../../assets/anjianyuan.png"/>工作人员</li>
47
- <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="mulchs.level1" @change="enableChange('level1',mulchs.level1)" type="checkbox"/><img class="safe_deimg" src="../../../assets/level1.png"/>一级隐患</li>
48
- <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="mulchs.level2" @change="enableChange('level2',mulchs.level2)" type="checkbox"/><img class="safe_deimg" src="../../../assets/level2.png"/>二级隐患</li>
49
- <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="mulchs.level3" @change="enableChange('level3',mulchs.level3)" type="checkbox"/><img class="safe_deimg" src="../../../assets/level3.png"/>三级隐患</li>
50
- <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="mulchs.problems" @change="enableChange('problems',mulchs.problems)" type="checkbox"/><img class="safe_deimg" src="../../../assets/ordinary.png"/>普通问题</li>
51
- </ul>
52
- <!--<data-grid :model="defectList" partial='list' class="table_sy" >
53
- <template partial='body' style="height:100%">
54
- <td @click="$parent.$parent.setDefectPos(row)">
55
- <div style="width: 100%;"class="flex-row">
56
- <img src="../../../assets/星球背景.jpg" style="width:45px;height: 50px" class="img-rounded">
57
- <div >
58
- <p class="safe_p" :title="row.f_item_name"><nobr>{{row.f_item_name}}</nobr></p>
59
- <p class="safe_p" :title="row.f_checker_name"><nobr>{{row.f_checker_name}}</nobr></p>
60
- <p class="safe_p" :title="row.f_upload_date"><nobr>{{row.f_upload_date.substring(11)}}</nobr></p>
61
- </div>
62
- </div>
63
- </td>
64
- </template>
65
- </data-grid>-->
66
- </div>
67
- </div>
68
- <div class="panel panel-info" style="flex: 4;margin-top:0px;height: 50%">
69
- <div class="panel-heading" style="height: auto">
70
- <h3 class="panel-title">今日隐患</h3>
71
- </div>
72
- <div class="panel-body" style="overflow: scroll">
73
- <ul class="safe_ul_sty">
74
- <li v-for="row in todayDefectList" track-by="$index" class="safe_li_sty safe_list_li" @click="setDefectPos(row)" style="border: 1px #4d4d4d solid;border-radius: 2px" >
75
- <div style="width: 100%;" class="flex-row">
76
- <div style="width:35%">
77
- <!--<img-self-safe :src="'/rs/image/file/'+row.f_path" style="float: left" width="45"
78
- height="50" class="img-rounded"></img-self-safe>-->
79
- <img :src="'/rs/image/file/'+row.f_path" style="width:45px;height: 50px" @click.stop="seePhotos(row.f_path)" class="img-rounded">
80
- </div>
81
- <div style="width:65%">
82
- <p class="safe_p" :title="row.f_item_name">{{row.f_item_name}}</p>
83
- <p class="safe_p" :title="row.f_checker_name">{{row.f_checker_name}}</p>
84
- <p class="safe_p" :title="row.f_upload_date">{{row.f_upload_date.substring(11)}}</p>
85
- </div>
86
- </div>
87
- </li>
88
- </ul>
89
- </div>
90
- </div>
91
- </div>
92
- </div>
93
-
94
- </div>
95
- </template>
96
-
97
- <script>
98
- import Vue from 'vue'
99
- import * as Util from '../../Util'
100
- import {HttpResetClass,trans} from 'vue-client'
101
-
102
- export default {
103
- title: '安检实时监控中心',
104
- data() {
105
- return {
106
- map:null,
107
- infoWindow:null,
108
- satellite:null,
109
- roadNet:null,
110
- checkerMulchs:null,//安检员点位
111
- level1Mulchs:null,//一级隐患点位
112
- level2Mulchs:null,//二级隐患点位
113
- level3Mulchs:null,//三级隐患点位
114
- problemsMulchs:null,//普通问题点位
115
- checkers:[],
116
- employeeList:[],
117
- level1:[],
118
- level2:[],
119
- level3:[],
120
- problems:[],
121
- chekckOps:null,
122
- defectList:{rows:[]},
123
- todayDefectList:[],
124
- intervalNum:'',
125
- layers:{//图层控制显示
126
- satelliteEnable:false,
127
- roadNetEnable:false,
128
- townshipEnable:false,
129
- city_properEnable:false
130
- },
131
- imgSrc:'',
132
- geocoder:null,//逆地理编码
133
- mulchs:{//覆盖物控制显示
134
- checker:true,
135
- level1:true,
136
- level2:true,
137
- level3:true,
138
- problems:true
139
- },
140
- styleObject :[
141
- {
142
- url: '/images/anjianyuan.png', //人员图标URL
143
- anchor: new AMap.Pixel(14, 8), // 图标偏移位置
144
- size: new AMap.Size(26, 28) //图标大小
145
- },
146
- {
147
- url: '/images/level1.png', //一级隐患图标URL
148
- anchor: new AMap.Pixel(14, 8), // 图标偏移位置
149
- size: new AMap.Size(26, 28) //图标大小
150
- },
151
- {
152
- url: '/images/level2.png', //二级隐患图标URL
153
- anchor: new AMap.Pixel(14, 8), // 图标偏移位置
154
- size: new AMap.Size(26, 28) //图标大小
155
- },
156
- {
157
- url: '/images/level3.png', //三级隐患图标URL
158
- anchor: new AMap.Pixel(14, 8), // 图标偏移位置
159
- size: new AMap.Size(26, 28) //图标大小
160
- },
161
- {
162
- url: '/images/ordinary.png', //普通问题图标URL
163
- anchor: new AMap.Pixel(14, 8), // 图标偏移位置
164
- size: new AMap.Size(26, 28) //图标大小
165
- }
166
- ],
167
- showModal:false,
168
- city_properEnable:false,
169
- townshipEnable:false
170
- }
171
- },
172
- async ready(){
173
- this.initMap()
174
- //tag)
175
- await this.getNewData()
176
- //tag
177
- this.assemblyData()
178
- //tag
179
- window.safe_closeInfoWindow=this.closeInfoWindow
180
- this.intervalNum=window.setInterval(this.safeRefresh, 240000)
181
- },
182
- methods: {
183
- seePhotos(path){
184
- if(path){
185
- this.imgSrc='/rs/image/file/'+path
186
- this.infoWindow.close()
187
- this.$refs.defectimg.open()
188
- }
189
- },
190
- setDefectPos(row){
191
- this.map.setZoomAndCenter(15,[row.f_longitude,row.f_latitude])
192
- let defectContent=this.getDefectContent(row)
193
- this.infoWindow.setContent(defectContent)
194
- this.infoWindow.open(this.map, [row.f_longitude,row.f_latitude]);
195
- },
196
- //获取定位人员类表
197
- async getNewData(){
198
- let res=await new HttpResetClass().load('POST', '/rs/search', {
199
- source: `root.getResourceById($${this.$login.f.orgid}$,$organization$).getSpecialResByType($user$).where(row.getAttributes().get($rolestr$).indexOf($需要定位人员$) != -1)`,
200
- userid: this.$login.f.id
201
- }, {resolveMsg: null, rejectMsg: null})
202
- let arr1=await new HttpResetClass().load("GET", `/rs/safePosition/getPosition`, {},{resolveMsg: null, rejectMsg: null})
203
- //tag+'---------'+typeof arr1)
204
- //let d=this.toStandardTimeString()
205
- this.checkers=[]
206
- console.log("res.data",res.data)
207
- console.log("arr1",arr1)
208
- if(res.data){
209
- res.data.forEach((checker)=>{
210
- ////tag)
211
-
212
- for(let check in arr1.data){
213
- let checkerpos=JSON.parse(arr1.data[check])
214
- ////tag+check)
215
- if(this.$login.f.rolestr.includes('定位管理员')==true){
216
- checkerpos.userid=checker.userid
217
- checkerpos.f_user_telephone=checker.f_user_telephone
218
- checkerpos.rolestr=checker.rolestr
219
- this.checkers.push(checkerpos)
220
- }else{
221
- if(checker.id==check){
222
- //tag
223
- console.log("zhaodao;e",checkerpos)
224
- checkerpos.userid=checker.userid
225
- checkerpos.f_user_telephone=checker.f_user_telephone
226
- checkerpos.rolestr=checker.rolestr
227
- this.checkers.push(checkerpos)
228
- }
229
- }
230
- }
231
- })
232
- }
233
- let td=Util.toStandardDateString()
234
- //获取今天上传的所有隐患
235
- let arr=await new HttpResetClass().load("POST", `rs/sql/defectDetails`, {data:{condition:` f_filialeid in ('${this.$login.f.orgid}') and f_upload_date>'${Util.toStandardDateString()} 00:00:00'`}},
236
- {resolveMsg: null, rejectMsg: null})
237
- //tag)
238
- if(arr.data){
239
- this.todayDefectList=[]
240
- arr.data.forEach((defect)=>{
241
- if(defect.f_upload_date.indexOf(td)!=-1){
242
- this.todayDefectList.push(defect)
243
- }
244
- if(defect.f_defect_level.indexOf('一级') >=0){
245
- this.level1.push(defect)
246
- }else if(defect.f_defect_level.indexOf('二级') >=0){
247
- this.level2.push(defect)
248
- }else if(defect.f_defect_level.indexOf('三级') >=0){
249
- this.level3.push(defect)
250
- }else{
251
- this.problems.push(defect)
252
- }
253
- })
254
- }
255
- this.defectList.rows=arr.data
256
- },
257
- getDefectContent(row){
258
- return `
259
- <div style="padding:0px;margin-left: 8px;"><b>隐患详情</b></div>
260
- <div class="panel panel-default" style="background-color: azure;border-radius: 5px;margin-left: 8px;">
261
- <div class="panel-body">
262
- <ul style="list-style-type: none;font-size: 15px;">
263
- <li style="margin: 3px 0;">隐患内容: ${row.f_item_name}-${row.f_item_value}</li>
264
- <li style="margin: 3px 0;">隐患级别: ${row.f_defect_level}</li>
265
- <li style="margin: 3px 0;">发现人员: ${row.f_checker_name}</li>
266
- <li style="margin: 3px 0;">上报时间: ${row.f_upload_date}</li>
267
- <li style="margin: 3px 0;">是否处理: ${row.F_IS_REPAIRED?row.F_IS_REPAIRED:'未处理'}</li>
268
- <li style="margin: 3px 0;">隐患位置: ${row.f_address}</li>
269
- </ul>
270
- </div>
271
- </div>`
272
- },
273
- getCheckerContent(row){
274
- return `
275
- <div style="padding:0px;margin-left: 8px;"><b>员工信息</b></div>
276
- <div class="panel panel-default" style="background-color: azure;border-radius: 5px;margin-left: 8px;">
277
- <div class="panel-body">
278
- <ul style="list-style-type: none;font-size: 15px;">
279
- <li style="margin: 3px 0;">员工工号: ${row.userid}</li>
280
- <li style="margin: 3px 0;">员工姓名: ${row.name}</li>
281
- <li style="margin: 3px 0;">员工电话: ${row.f_user_telephone?row.f_user_telephone:'未查到电话'}</li>
282
- <li style="margin: 3px 0;">角色列表: ${row.rolestr}</li>
283
- <li style="margin: 3px 0;">剩余电量: ${row.f_battery_level} %</li>
284
- <li style="margin: 3px 0;">剩余内存: ${row.f_internal_quote} MB</li>
285
- <li style="margin: 3px 0;">信号强度: ${row.f_signal_strength}</li>
286
- <li style="margin: 3px 0;">实时位置: ${row.checkAddress}</li>
287
- <li style="margin: 3px 0;">状态更新时间: ${row.uploadTime}</li>
288
- <!--<li style="margin: 3px 0;">客户地址: 河南省周口市工农南路xx酒店302</li>-->
289
- </ul>
290
- </div>
291
- </div>`
292
- },
293
- assemblyData(){
294
- let that=this
295
- this.checkerInit()
296
- /*this.checkers=[
297
- {f_longitude:114.718285,f_latitude:33.610584},
298
- {f_longitude:114.713736,f_latitude:33.642387}
299
- ]*/
300
- /*this.level1=[
301
- {f_longitude:114.68736,f_latitude:33.655248},
302
- {f_longitude:114.716736,f_latitude:33.627523}
303
- ]*/
304
- /*this.level2=[
305
- {f_longitude:114.676833,f_latitude:33.609726},
306
- {f_longitude:114.684013,f_latitude:33.642387}
307
- ]
308
- this.level3=[
309
- {f_longitude:114.71502,f_latitude:33.648675},
310
- {f_longitude:114.725002,f_latitude:33.637242}
311
- ]
312
- this.problems=[
313
- {f_longitude:114.696969,f_latitude:33.635241},
314
- {f_longitude:114.68836,f_latitude:33.655248}
315
- ]*/
316
- /*let a1=[]
317
- for(let i=0;i<this.checkers.length;i++){
318
- a1.push({
319
- lnglat: [this.checkers[i].f_longitude,this.checkers[i].f_latitude], //点标记位置
320
- name: '安检员',
321
- id:i,
322
- rowstr:this.checkers[i]
323
- })
324
- }
325
- // 将数组设置到 massMarks 图层
326
- this.checkerMulchs.setData(a1);
327
- // 将 massMarks 添加到地图实例
328
- this.checkerMulchs.setMap(this.map);*/
329
- let a2=[]
330
- for(let i=0;i<this.level1.length;i++){
331
- a2.push({
332
- lnglat: [this.level1[i].f_longitude, this.level1[i].f_latitude], //点标记位置
333
- name: '一级隐患',
334
- id:i,
335
- rowstr:this.level1[i]
336
- })
337
- }
338
- // 将数组设置到 massMarks 图层
339
- this.level1Mulchs.setData(a2);
340
- // 将 massMarks 添加到地图实例
341
- this.level1Mulchs.setMap(this.map);
342
-
343
-
344
- let a3=[]
345
- for(let i=0;i<this.level2.length;i++){
346
- a3.push({
347
- lnglat: [this.level2[i].f_longitude,this.level2[i].f_latitude], //点标记位置
348
- name: '二级隐患',
349
- id:i,
350
- rowstr:this.level2[i]
351
- })
352
- }
353
- // 将数组设置到 massMarks 图层
354
- this.level2Mulchs.setData(a3);
355
- // 将 massMarks 添加到地图实例
356
- this.level2Mulchs.setMap(this.map);
357
-
358
- let a4=[]
359
- for(let i=0;i<this.level3.length;i++){
360
- a4.push({
361
- lnglat: [this.level3[i].f_longitude, this.level3[i].f_latitude], //点标记位置
362
- name: '三级隐患',
363
- id:i,
364
- rowstr:this.level3[i]
365
- })
366
- }
367
- // 将数组设置到 massMarks 图层
368
- this.level3Mulchs.setData(a4);
369
- // 将 massMarks 添加到地图实例
370
- this.level3Mulchs.setMap(this.map);
371
-
372
-
373
- let a5=[]
374
- for(let i=0;i<this.problems.length;i++){
375
- a5.push({
376
- lnglat: [this.problems[i].f_longitude, this.problems[i].f_latitude], //点标记位置
377
- name: '普通问题',
378
- id:i,
379
- rowstr:this.problems[i]
380
- })
381
- }
382
- // 将数组设置到 massMarks 图层
383
- this.problemsMulchs.setData(a5);
384
- // 将 massMarks 添加到地图实例
385
- this.problemsMulchs.setMap(this.map);
386
- //组装安检员点位集合
387
- },
388
- //处理图层和覆盖物的显示隐藏
389
- enableChange(vname,val){
390
- //tag
391
- //tag
392
- switch(vname){
393
- case 'satelliteEnable':
394
- if(val){
395
- this.map.add(this.satellite)
396
- }else{
397
- this.map.remove(this.satellite)
398
- }
399
- break;
400
- case 'roadNetEnable':
401
- if(val){
402
- this.map.add(this.roadNet)
403
- }else{
404
- this.map.remove(this.roadNet)
405
- }
406
- break;
407
- case 'checker':
408
- if(val){
409
- this.chekckOps.show()
410
- }else{
411
- this.chekckOps.hide()
412
- }
413
- break;
414
- case 'level1':
415
- if(val){
416
- this.level1Mulchs.show()
417
- }else{
418
- this.level1Mulchs.hide()
419
- }
420
- break;
421
- case 'level2':
422
- if(val){
423
- this.level2Mulchs.show()
424
- }else{
425
- this.level2Mulchs.hide()
426
- }
427
- break;
428
- case 'level3':
429
- if(val){
430
- this.level3Mulchs.show()
431
- }else{
432
- this.level3Mulchs.hide()
433
- }
434
- break;
435
- case 'problems':
436
- if(val){
437
- this.problemsMulchs.show()
438
- }else{
439
- this.problemsMulchs.hide()
440
- }
441
- break;
442
- case 'townshipEnable':
443
- this.showModal=true
444
- this.townshipEnable=true
445
- this.city_properEnable=false
446
- break;
447
- case 'city_properEnable':
448
- this.showModal=true
449
- this.city_properEnable=true
450
- this.townshipEnable=false
451
- break;
452
- default:
453
- }
454
- },
455
- closeModal(){
456
- this.showModal=false
457
- this.city_properEnable=false
458
- this.townshipEnable=false
459
- this.layers.townshipEnable=false
460
- this.layers.city_properEnable=false
461
- },
462
- initMap(){
463
- let that=this
464
- this.map = new AMap.Map('check_map', {
465
- zoom: 12,
466
- center: [116.80030599999998, 37.65219],
467
- showIndoorMap: false,
468
- viewMode: '2D', //设置地图模式
469
- lang: 'zh_cn', //设置地图语言类型
470
- zindex: 99
471
- });
472
-
473
- let bounds = this.map.getBounds();
474
- this.map.setLimitBounds(bounds);
475
- // 异步加载地图插件
476
- AMap.plugin(
477
- ['AMap.ToolBar','AMap.Geolocation','AMap.Geocoder'], () => {//异步加载插件
478
- // 自动定位插件
479
- var geolocation = new AMap.Geolocation({
480
- // 是否使用高精度定位,默认:true
481
- enableHighAccuracy: true,
482
- // 设置定位超时时间,默认:无穷大
483
- showbutton: true,
484
- //控制按钮的显示
485
- timeout: 10000,
486
- // 定位按钮的停靠位置的偏移量,默认:Pixel(10, 20)
487
- buttonOffset: new AMap.Pixel(10, 20),
488
- // 定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false
489
- //zoomToAccuracy: true,
490
- // 定位按钮的排放位置, RB表示右下
491
- buttonPosition: 'LB'
492
- })
493
- that.geocoder = new AMap.Geocoder({
494
- radius: 500 //范围,默认:500
495
- });
496
- that.map.addControl(geolocation)
497
- geolocation.getCurrentPosition();
498
- that.map.addControl(new AMap.ToolBar()) //初始化工具插件
499
- });
500
- this.map.setDefaultCursor('move');
501
- //this.map.setMapStyle('amap://styles/whitesmoke');
502
- this.satellite=new AMap.TileLayer.Satellite()//卫星图层
503
- this.roadNet=new AMap.TileLayer.RoadNet({opacity:0.8})//网路图层
504
- //安检员位置集合
505
- this.chekckOps=new AMap.OverlayGroup()
506
- //初始化窗体
507
- this.infoWindow = new AMap.InfoWindow({
508
- anchor: 'bottom-center',
509
- //isCustom: true, //使用自定义窗体
510
- autoMove:true,
511
- content: '',
512
- offset: new AMap.Pixel(0, -25)
513
- });
514
- //安检员点位
515
- /*this.checkerMulchs = new AMap.MassMarks([], {
516
- opacity: 0.8, // 图层的透明度,取值范围[0,1],1代表完全不透明,0代表完全透明
517
- zIndex: 111, //图层叠加的顺序值,0表示最底层。默认zIndex:5
518
- cursor: 'pointer', //指定鼠标悬停时的鼠标样式,自定义cursor,IE仅支持cur/ani/ico格式,Opera不支持自定义cursor
519
- //alwaysRender:false,
520
- style: this.styleObject[0]
521
- });
522
- //tag
523
- this.checkerMulchs.on('click',function (e) {
524
- //tag)
525
- let checkAddress='未获取到实时位置'
526
- that.geocoder.getAddress(e.data.lnglat, function(status, result) {
527
- if (status === 'complete'&& result.regeocode) {
528
- checkAddress = result.regeocode.formattedAddress;
529
- }else{
530
- log.error('根据经纬度查询地址失败')
531
- }
532
- e.data.rowstr.checkAddress=checkAddress
533
- let defectContent=that.getCheckerContent(e.data.rowstr)
534
- that.infoWindow.setContent(defectContent)
535
- that.infoWindow.open(that.map, e.data.lnglat);
536
- });
537
- })*/
538
- //一级隐患点位
539
- this.level1Mulchs=new AMap.MassMarks([], {
540
- opacity: 0.8, // 图层的透明度,取值范围[0,1],1代表完全不透明,0代表完全透明
541
- zIndex: 111, //图层叠加的顺序值,0表示最底层。默认zIndex:5
542
- cursor: 'pointer', //指定鼠标悬停时的鼠标样式,自定义cursor,IE仅支持cur/ani/ico格式,Opera不支持自定义cursor
543
- //alwaysRender:false,
544
- style: this.styleObject[1]
545
- });
546
- this.level1Mulchs.on('click',function (e) {
547
- //tag)
548
- let defectContent=that.getDefectContent(e.data.rowstr)
549
- that.infoWindow.setContent(defectContent)
550
- that.infoWindow.open(that.map, e.data.lnglat);
551
- })
552
- //二级隐患点位
553
- this.level2Mulchs=new AMap.MassMarks([], {
554
- opacity: 0.8, // 图层的透明度,取值范围[0,1],1代表完全不透明,0代表完全透明
555
- zIndex: 111, //图层叠加的顺序值,0表示最底层。默认zIndex:5
556
- cursor: 'pointer', //指定鼠标悬停时的鼠标样式,自定义cursor,IE仅支持cur/ani/ico格式,Opera不支持自定义cursor
557
- //alwaysRender:false,
558
- style: this.styleObject[2]
559
- });
560
- this.level2Mulchs.on('click',function (e) {
561
- //tag)
562
- let defectContent=that.getDefectContent(e.data.rowstr)
563
- that.infoWindow.setContent(defectContent)
564
- that.infoWindow.open(that.map, e.data.lnglat);
565
- })
566
- //三级隐患点位
567
- this.level3Mulchs=new AMap.MassMarks([], {
568
- opacity: 0.8, // 图层的透明度,取值范围[0,1],1代表完全不透明,0代表完全透明
569
- zIndex: 111, //图层叠加的顺序值,0表示最底层。默认zIndex:5
570
- cursor: 'pointer', //指定鼠标悬停时的鼠标样式,自定义cursor,IE仅支持cur/ani/ico格式,Opera不支持自定义cursor
571
- //alwaysRender:false,
572
- style: this.styleObject[3]
573
- });
574
- this.level3Mulchs.on('click',function (e) {
575
- //tag)
576
- let defectContent=that.getDefectContent(e.data.rowstr)
577
- that.infoWindow.setContent(defectContent)
578
- that.infoWindow.open(that.map, e.data.lnglat);
579
- })
580
- //普通问题点位
581
- this.problemsMulchs=new AMap.MassMarks([], {
582
- opacity: 0.8, // 图层的透明度,取值范围[0,1],1代表完全不透明,0代表完全透明
583
- zIndex: 111, //图层叠加的顺序值,0表示最底层。默认zIndex:5
584
- cursor: 'pointer', //指定鼠标悬停时的鼠标样式,自定义cursor,IE仅支持cur/ani/ico格式,Opera不支持自定义cursor
585
- //alwaysRender:false,
586
- style: this.styleObject[4]
587
- });
588
- this.problemsMulchs.on('click',function (e) {
589
- //tag)
590
- let defectContent=that.getDefectContent(e.data.rowstr)
591
- that.infoWindow.setContent(defectContent)
592
- that.infoWindow.open(that.map, e.data.lnglat);
593
- })
594
-
595
-
596
- },
597
- closeInfoWindow(){
598
- this.infoWindow.close()
599
- },
600
- checkerInit(){
601
- /*let marker1 = new AMap.Marker({
602
- position: [114.574809,33.621501],
603
- icon:'http://192.168.20.28:8400/image/anjianyuan.png'
604
- });
605
- //tag
606
- marker1.setLabel({
607
- //offset: new AMap.Pixel(20, 20), //设置文本标注偏移量
608
- content: "<div class='info' style='background-color: #0b87e2'>何文强</div>", //设置文本标注内容
609
- direction: 'bottom' //设置文本标注方位
610
- })*/
611
- let that = this
612
- this.chekckOps.clearOverlays()
613
- for(let j=0;j<this.checkers.length;j++){
614
- //tag+"---"+this.checkers[j].f_longitude+"---"+this.checkers[j].f_latitude)
615
- //let o={f_longitude:"114.72"+(Math.floor(Math.random()*(9999-1000))+1000),f_latitude:"33.56"+(Math.floor(Math.random()*(9999-1000))+1000),name:"hwq3",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865}
616
- let marker=new AMap.Marker({
617
- //map: that.map,
618
- offset:new AMap.Pixel(-18, -10),
619
- position: [this.checkers[j].f_longitude,this.checkers[j].f_latitude],
620
- icon:new AMap.Icon({
621
- image: '/images/anjianyuan.png', //人员图标URL
622
- imageOffset: new AMap.Pixel(0, 0), // 图标偏移位置
623
- imageSize: new AMap.Size(36, 36) //图标大小
624
- }),
625
- label:{
626
- //offset: new AMap.Pixel(20, 20), //设置文本标注偏移量
627
- content: `<div class='info' style='background-color: rgb(0,185,255);color: #ffffff;padding: 5px;border-radius: 4px'>${this.checkers[j].name}</div>`, //设置文本标注内容
628
- direction: 'bottom', //设置文本标注方位
629
- offset:new AMap.Pixel(0, -4)
630
- },
631
- extData:this.checkers[j]
632
- })
633
- this.chekckOps.addOverlay(marker)
634
-
635
- }
636
- this.chekckOps.setMap(this.map)
637
- this.chekckOps.on('click',function (e) {
638
- let pe=e.target.getExtData()
639
- for(let obj in pe){
640
- //tag
641
- }
642
- let checkAddress='未获取到实时位置'
643
- that.geocoder.getAddress([pe.f_longitude,pe.f_latitude], function(status, result) {
644
- if (status === 'complete'&& result.regeocode) {
645
- checkAddress = result.regeocode.formattedAddress;
646
- }/*else{
647
- log.error('根据经纬度查询地址失败')
648
- }*/
649
- pe.checkAddress=checkAddress
650
- let defectContent=that.getCheckerContent(pe)
651
- that.infoWindow.setContent(defectContent)
652
- that.infoWindow.open(that.map, [pe.f_longitude,pe.f_latitude])
653
- })
654
- })
655
- /*AMap.event.addListener(this.ops, 'click', function (e) {
656
- //tag)
657
- //that.infoWindow.open(that.map, marker.getPosition());
658
- })*/
659
- },
660
- //获取当前时间的前两个小时
661
- getNowFormatDate(house=0) {
662
- //tag
663
- let date = new Date();
664
- let seperator1 = "-";
665
- let seperator2 = ":";
666
- if(house != 0){
667
- date.setHours(date.getHours()-house)
668
- }
669
- let month = date.getMonth() + 1;
670
- let strDate = date.getDate();
671
- let hour = date.getHours();
672
- let min = date.getMinutes();
673
- let second = date.getSeconds();
674
- if (month >= 1 && month <= 9) {
675
- month = "0" + month;
676
- }
677
- if (strDate >= 0 && strDate <= 9) {
678
- strDate = "0" + strDate;
679
- }
680
- if (hour >= 0 && hour <= 9) {
681
- hour = "0" + hour;
682
- }
683
- if (min >= 0 && min <= 9) {
684
- min = "0" + min;
685
- }
686
- if (second >= 0 && second <= 9) {
687
- second = "0" + second;
688
- }
689
- let currentdate = date.getFullYear() + seperator1 + month + seperator1 + strDate
690
- + " " + hour + seperator2 + min
691
- + seperator2 + second;
692
- return currentdate;
693
- },
694
- toStandardTimeString() {
695
- let dt = new Date()
696
- let month = dt.getMonth()+1
697
- let date = dt.getDate()
698
- let hour = dt.getHours()
699
- let min = dt.getMinutes()
700
- let sec = dt.getSeconds()
701
- return dt.getFullYear() + '-' + (month<10? '0'+ month : month) + '-' + (date<10? '0'+ date : date)
702
- + ' ' + (hour<10? '0'+ hour : hour)
703
- },
704
- async safeRefresh(){
705
- //tag
706
- //获取所有安检员的点位集合-----测试数据
707
- /*this.checkers=[]
708
- this.checkers.push({f_longitude:114.7318,f_latitude:33.567126,name:"hwq1",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865})
709
- this.checkers.push({f_longitude:114.726801,f_latitude:33.566912,name:"hwq2",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865})
710
- this.checkers.push({f_longitude:114.723346,f_latitude:33.568932,name:"hwq3",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865})
711
- this.checkers.push({f_longitude:114.711741,f_latitude:33.585519,name:"hwq4",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865})
712
- this.checkers.push({f_longitude:114.756716,f_latitude:33.594528,name:"hwq5",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865})
713
- this.defectList.rows=[]
714
- this.defectList.rows.push({"f_longitude":114.661358,"f_latitude":33.596897,"f_checker_name":"hwq2","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
715
- this.defectList.rows.push({"f_longitude":114.659985,"f_latitude":33.62892,"f_checker_name":"hwq3","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
716
- this.defectList.rows.push({"f_longitude":114.634579,"f_latitude":33.616627,"f_checker_name":"hwq4","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
717
- this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
718
- this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
719
- this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
720
- this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
721
- this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
722
- this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
723
- this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})*/
724
- await this.getNewData()
725
- this.assemblyData()
726
- }
727
- },
728
- computed:{
729
-
730
- },
731
- destroyed(){
732
- window.clearInterval(this.intervalNum)
733
- }
734
- }
735
-
736
- </script>
737
-
738
- <style lang="less" scoped>
739
-
740
- .safe_checkbox_sty{
741
- vertical-align:text-bottom;
742
- margin-right: 3px;
743
-
744
- }
745
- .safe_ul_sty{
746
- list-style-type: none;
747
- font-size: 13px;
748
- padding-left: 5px;
749
- }
750
- .safe_li_sty{
751
- font-size: 13px;
752
- margin-top: 5px;
753
- }
754
- .safe_p{
755
- white-space: nowrap;
756
- overflow: hidden;
757
- text-overflow: ellipsis;
758
- margin: 0 0 0 10px;
759
-
760
- font-size: 12px;
761
- }
762
- .safe_list_li{
763
- margin-top: 5px;
764
- background-color: #ffffff;
765
- border: solid 1px #f0f4fa !important;
766
- color: #666666 !important;
767
- font-size: 1.3rem !important;
768
- font-family: PINGFANG-MEDIUM !important;
769
- padding: 8px;
770
- }
771
- .safe_list_li:hover{
772
- background-color: rgb(203,234,241);
773
- }
774
- .safe_deimg{
775
- vertical-align: text-bottom;
776
- width: 15px;
777
- margin-right: 3px;
778
- }
779
- </style>
780
-
1
+ <template>
2
+ <div class="flex-row">
3
+ <div class="basic-main" style="flex:7">
4
+ <div id="check_map" style="height:100%">
5
+ <img-self-safe :src="imgSrc" width="45" style="z-index: 0"
6
+ height="50" class="img-rounded" v-ref:defectimg></img-self-safe>
7
+ </div>
8
+ </div>
9
+ <modal :styles="'width:1230px'" width="1230px" :show.sync="showModal" v-ref:modal backdrop="false">
10
+ <header slot="modal-header" class="modal-header" v-show="false"></header>
11
+ <article slot="modal-body" class="modal-body" style="width: 1200px;">
12
+ <div class="auto">
13
+ <img style="height:800px;width: 1200px;" src="./cq.jpg"
14
+ v-show="city_properEnable" alt="图片加载失败"/>
15
+ <img style="height:800px;width: 1200px;" src="./qy.jpg"
16
+ v-show="townshipEnable" alt="图片加载失败"/>
17
+ </div>
18
+ </article>
19
+ <footer slot="modal-footer" class="modal-footer">
20
+ <button type="button" class="btn btn-success" @click='closeModal()'>关闭</button>
21
+ </footer>
22
+ </modal>
23
+
24
+ <div id="zzz" class="basic-main" style="flex:1;margin-left: 0px;overflow: hidden">
25
+ <div class="flex">
26
+ <div class="panel panel-info" style="flex: 1;margin-top:0px">
27
+ <div class="panel-heading" style="height: auto">
28
+ <h3 class="panel-title">图层设置</h3>
29
+ </div>
30
+ <div class="panel-body">
31
+ <ul class="safe_ul_sty">
32
+ <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="layers.satelliteEnable" @change="enableChange('satelliteEnable',layers.satelliteEnable)" type="checkbox"/>卫星图层</li>
33
+ <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="layers.roadNetEnable" @change="enableChange('roadNetEnable',layers.roadNetEnable)" type="checkbox"/>网路图层</li>
34
+ <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="layers.townshipEnable" @click="enableChange('townshipEnable')" type="checkbox"/>乡镇管网图层</li>
35
+ <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="layers.city_properEnable" @click="enableChange('city_properEnable')" type="checkbox"/>城区管网图层</li>
36
+ <!--<button @click="safeRefresh">刷新111</button>-->
37
+ </ul>
38
+ </div>
39
+ </div>
40
+ <div class="panel panel-info" style="flex: 2;margin-top:0px;">
41
+ <div class="panel-heading" style="height: auto">
42
+ <h3 class="panel-title">覆盖物设置</h3>
43
+ </div>
44
+ <div class="panel-body">
45
+ <ul class="safe_ul_sty">
46
+ <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="mulchs.checker" @change="enableChange('checker',mulchs.checker)" type="checkbox"/><img class="safe_deimg" src="../../../assets/anjianyuan.png"/>工作人员</li>
47
+ <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="mulchs.level1" @change="enableChange('level1',mulchs.level1)" type="checkbox"/><img class="safe_deimg" src="../../../assets/level1.png"/>一级隐患</li>
48
+ <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="mulchs.level2" @change="enableChange('level2',mulchs.level2)" type="checkbox"/><img class="safe_deimg" src="../../../assets/level2.png"/>二级隐患</li>
49
+ <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="mulchs.level3" @change="enableChange('level3',mulchs.level3)" type="checkbox"/><img class="safe_deimg" src="../../../assets/level3.png"/>三级隐患</li>
50
+ <li class="safe_li_sty"><input class="safe_checkbox_sty" v-model="mulchs.problems" @change="enableChange('problems',mulchs.problems)" type="checkbox"/><img class="safe_deimg" src="../../../assets/ordinary.png"/>普通问题</li>
51
+ </ul>
52
+ <!--<data-grid :model="defectList" partial='list' class="table_sy" >
53
+ <template partial='body' style="height:100%">
54
+ <td @click="$parent.$parent.setDefectPos(row)">
55
+ <div style="width: 100%;"class="flex-row">
56
+ <img src="../../../assets/星球背景.jpg" style="width:45px;height: 50px" class="img-rounded">
57
+ <div >
58
+ <p class="safe_p" :title="row.f_item_name"><nobr>{{row.f_item_name}}</nobr></p>
59
+ <p class="safe_p" :title="row.f_checker_name"><nobr>{{row.f_checker_name}}</nobr></p>
60
+ <p class="safe_p" :title="row.f_upload_date"><nobr>{{row.f_upload_date.substring(11)}}</nobr></p>
61
+ </div>
62
+ </div>
63
+ </td>
64
+ </template>
65
+ </data-grid>-->
66
+ </div>
67
+ </div>
68
+ <div class="panel panel-info" style="flex: 4;margin-top:0px;height: 50%">
69
+ <div class="panel-heading" style="height: auto">
70
+ <h3 class="panel-title">今日隐患</h3>
71
+ </div>
72
+ <div class="panel-body" style="overflow: scroll">
73
+ <ul class="safe_ul_sty">
74
+ <li v-for="row in todayDefectList" track-by="$index" class="safe_li_sty safe_list_li" @click="setDefectPos(row)" style="border: 1px #4d4d4d solid;border-radius: 2px" >
75
+ <div style="width: 100%;" class="flex-row">
76
+ <div style="width:35%">
77
+ <!--<img-self-safe :src="'/rs/image/file/'+row.f_path" style="float: left" width="45"
78
+ height="50" class="img-rounded"></img-self-safe>-->
79
+ <img :src="'/rs/image/file/'+row.f_path" style="width:45px;height: 50px" @click.stop="seePhotos(row.f_path)" class="img-rounded">
80
+ </div>
81
+ <div style="width:65%">
82
+ <p class="safe_p" :title="row.f_item_name">{{row.f_item_name}}</p>
83
+ <p class="safe_p" :title="row.f_checker_name">{{row.f_checker_name}}</p>
84
+ <p class="safe_p" :title="row.f_upload_date">{{row.f_upload_date.substring(11)}}</p>
85
+ </div>
86
+ </div>
87
+ </li>
88
+ </ul>
89
+ </div>
90
+ </div>
91
+ </div>
92
+ </div>
93
+
94
+ </div>
95
+ </template>
96
+
97
+ <script>
98
+ import Vue from 'vue'
99
+ import * as Util from '../../Util'
100
+ import {HttpResetClass,trans} from 'vue-client'
101
+
102
+ export default {
103
+ title: '安检实时监控中心',
104
+ data() {
105
+ return {
106
+ map:null,
107
+ infoWindow:null,
108
+ satellite:null,
109
+ roadNet:null,
110
+ checkerMulchs:null,//安检员点位
111
+ level1Mulchs:null,//一级隐患点位
112
+ level2Mulchs:null,//二级隐患点位
113
+ level3Mulchs:null,//三级隐患点位
114
+ problemsMulchs:null,//普通问题点位
115
+ checkers:[],
116
+ employeeList:[],
117
+ level1:[],
118
+ level2:[],
119
+ level3:[],
120
+ problems:[],
121
+ chekckOps:null,
122
+ defectList:{rows:[]},
123
+ todayDefectList:[],
124
+ intervalNum:'',
125
+ layers:{//图层控制显示
126
+ satelliteEnable:false,
127
+ roadNetEnable:false,
128
+ townshipEnable:false,
129
+ city_properEnable:false
130
+ },
131
+ imgSrc:'',
132
+ geocoder:null,//逆地理编码
133
+ mulchs:{//覆盖物控制显示
134
+ checker:true,
135
+ level1:true,
136
+ level2:true,
137
+ level3:true,
138
+ problems:true
139
+ },
140
+ styleObject :[
141
+ {
142
+ url: '/images/anjianyuan.png', //人员图标URL
143
+ anchor: new AMap.Pixel(14, 8), // 图标偏移位置
144
+ size: new AMap.Size(26, 28) //图标大小
145
+ },
146
+ {
147
+ url: '/images/level1.png', //一级隐患图标URL
148
+ anchor: new AMap.Pixel(14, 8), // 图标偏移位置
149
+ size: new AMap.Size(26, 28) //图标大小
150
+ },
151
+ {
152
+ url: '/images/level2.png', //二级隐患图标URL
153
+ anchor: new AMap.Pixel(14, 8), // 图标偏移位置
154
+ size: new AMap.Size(26, 28) //图标大小
155
+ },
156
+ {
157
+ url: '/images/level3.png', //三级隐患图标URL
158
+ anchor: new AMap.Pixel(14, 8), // 图标偏移位置
159
+ size: new AMap.Size(26, 28) //图标大小
160
+ },
161
+ {
162
+ url: '/images/ordinary.png', //普通问题图标URL
163
+ anchor: new AMap.Pixel(14, 8), // 图标偏移位置
164
+ size: new AMap.Size(26, 28) //图标大小
165
+ }
166
+ ],
167
+ showModal:false,
168
+ city_properEnable:false,
169
+ townshipEnable:false
170
+ }
171
+ },
172
+ async ready(){
173
+ this.initMap()
174
+ //tag)
175
+ await this.getNewData()
176
+ //tag
177
+ this.assemblyData()
178
+ //tag
179
+ window.safe_closeInfoWindow=this.closeInfoWindow
180
+ this.intervalNum=window.setInterval(this.safeRefresh, 240000)
181
+ },
182
+ methods: {
183
+ seePhotos(path){
184
+ if(path){
185
+ this.imgSrc='/rs/image/file/'+path
186
+ this.infoWindow.close()
187
+ this.$refs.defectimg.open()
188
+ }
189
+ },
190
+ setDefectPos(row){
191
+ this.map.setZoomAndCenter(15,[row.f_longitude,row.f_latitude])
192
+ let defectContent=this.getDefectContent(row)
193
+ this.infoWindow.setContent(defectContent)
194
+ this.infoWindow.open(this.map, [row.f_longitude,row.f_latitude]);
195
+ },
196
+ //获取定位人员类表
197
+ async getNewData(){
198
+ let res=await new HttpResetClass().load('POST', '/rs/search', {
199
+ source: `root.getResourceById($${this.$login.f.orgid}$,$organization$).getSpecialResByType($user$).where(row.getAttributes().get($rolestr$).indexOf($需要定位人员$) != -1)`,
200
+ userid: this.$login.f.id
201
+ }, {resolveMsg: null, rejectMsg: null})
202
+ let arr1=await new HttpResetClass().load("GET", `/rs/safePosition/getPosition`, {},{resolveMsg: null, rejectMsg: null})
203
+ //tag+'---------'+typeof arr1)
204
+ //let d=this.toStandardTimeString()
205
+ this.checkers=[]
206
+ console.log("res.data",res.data)
207
+ console.log("arr1",arr1)
208
+ if(res.data){
209
+ res.data.forEach((checker)=>{
210
+ ////tag)
211
+
212
+ for(let check in arr1.data){
213
+ let checkerpos=JSON.parse(arr1.data[check])
214
+ ////tag+check)
215
+ if(this.$login.f.rolestr.includes('定位管理员')==true){
216
+ checkerpos.userid=checker.userid
217
+ checkerpos.f_user_telephone=checker.f_user_telephone
218
+ checkerpos.rolestr=checker.rolestr
219
+ this.checkers.push(checkerpos)
220
+ }else{
221
+ if(checker.id==check){
222
+ //tag
223
+ console.log("zhaodao;e",checkerpos)
224
+ checkerpos.userid=checker.userid
225
+ checkerpos.f_user_telephone=checker.f_user_telephone
226
+ checkerpos.rolestr=checker.rolestr
227
+ this.checkers.push(checkerpos)
228
+ }
229
+ }
230
+ }
231
+ })
232
+ }
233
+ let td=Util.toStandardDateString()
234
+ //获取今天上传的所有隐患
235
+ let arr=await new HttpResetClass().load("POST", `rs/sql/defectDetails`, {data:{condition:` f_filialeid in ('${this.$login.f.orgid}') and f_upload_date>'${Util.toStandardDateString()} 00:00:00'`}},
236
+ {resolveMsg: null, rejectMsg: null})
237
+ //tag)
238
+ if(arr.data){
239
+ this.todayDefectList=[]
240
+ arr.data.forEach((defect)=>{
241
+ if(defect.f_upload_date.indexOf(td)!=-1){
242
+ this.todayDefectList.push(defect)
243
+ }
244
+ if(defect.f_defect_level.indexOf('一级') >=0){
245
+ this.level1.push(defect)
246
+ }else if(defect.f_defect_level.indexOf('二级') >=0){
247
+ this.level2.push(defect)
248
+ }else if(defect.f_defect_level.indexOf('三级') >=0){
249
+ this.level3.push(defect)
250
+ }else{
251
+ this.problems.push(defect)
252
+ }
253
+ })
254
+ }
255
+ this.defectList.rows=arr.data
256
+ },
257
+ getDefectContent(row){
258
+ return `
259
+ <div style="padding:0px;margin-left: 8px;"><b>隐患详情</b></div>
260
+ <div class="panel panel-default" style="background-color: azure;border-radius: 5px;margin-left: 8px;">
261
+ <div class="panel-body">
262
+ <ul style="list-style-type: none;font-size: 15px;">
263
+ <li style="margin: 3px 0;">隐患内容: ${row.f_item_name}-${row.f_item_value}</li>
264
+ <li style="margin: 3px 0;">隐患级别: ${row.f_defect_level}</li>
265
+ <li style="margin: 3px 0;">发现人员: ${row.f_checker_name}</li>
266
+ <li style="margin: 3px 0;">上报时间: ${row.f_upload_date}</li>
267
+ <li style="margin: 3px 0;">是否处理: ${row.F_IS_REPAIRED?row.F_IS_REPAIRED:'未处理'}</li>
268
+ <li style="margin: 3px 0;">隐患位置: ${row.f_address}</li>
269
+ </ul>
270
+ </div>
271
+ </div>`
272
+ },
273
+ getCheckerContent(row){
274
+ return `
275
+ <div style="padding:0px;margin-left: 8px;"><b>员工信息</b></div>
276
+ <div class="panel panel-default" style="background-color: azure;border-radius: 5px;margin-left: 8px;">
277
+ <div class="panel-body">
278
+ <ul style="list-style-type: none;font-size: 15px;">
279
+ <li style="margin: 3px 0;">员工工号: ${row.userid}</li>
280
+ <li style="margin: 3px 0;">员工姓名: ${row.name}</li>
281
+ <li style="margin: 3px 0;">员工电话: ${row.f_user_telephone?row.f_user_telephone:'未查到电话'}</li>
282
+ <li style="margin: 3px 0;">角色列表: ${row.rolestr}</li>
283
+ <li style="margin: 3px 0;">剩余电量: ${row.f_battery_level} %</li>
284
+ <li style="margin: 3px 0;">剩余内存: ${row.f_internal_quote} MB</li>
285
+ <li style="margin: 3px 0;">信号强度: ${row.f_signal_strength}</li>
286
+ <li style="margin: 3px 0;">实时位置: ${row.checkAddress}</li>
287
+ <li style="margin: 3px 0;">状态更新时间: ${row.uploadTime}</li>
288
+ <!--<li style="margin: 3px 0;">客户地址: 河南省周口市工农南路xx酒店302</li>-->
289
+ </ul>
290
+ </div>
291
+ </div>`
292
+ },
293
+ assemblyData(){
294
+ let that=this
295
+ this.checkerInit()
296
+ /*this.checkers=[
297
+ {f_longitude:114.718285,f_latitude:33.610584},
298
+ {f_longitude:114.713736,f_latitude:33.642387}
299
+ ]*/
300
+ /*this.level1=[
301
+ {f_longitude:114.68736,f_latitude:33.655248},
302
+ {f_longitude:114.716736,f_latitude:33.627523}
303
+ ]*/
304
+ /*this.level2=[
305
+ {f_longitude:114.676833,f_latitude:33.609726},
306
+ {f_longitude:114.684013,f_latitude:33.642387}
307
+ ]
308
+ this.level3=[
309
+ {f_longitude:114.71502,f_latitude:33.648675},
310
+ {f_longitude:114.725002,f_latitude:33.637242}
311
+ ]
312
+ this.problems=[
313
+ {f_longitude:114.696969,f_latitude:33.635241},
314
+ {f_longitude:114.68836,f_latitude:33.655248}
315
+ ]*/
316
+ /*let a1=[]
317
+ for(let i=0;i<this.checkers.length;i++){
318
+ a1.push({
319
+ lnglat: [this.checkers[i].f_longitude,this.checkers[i].f_latitude], //点标记位置
320
+ name: '安检员',
321
+ id:i,
322
+ rowstr:this.checkers[i]
323
+ })
324
+ }
325
+ // 将数组设置到 massMarks 图层
326
+ this.checkerMulchs.setData(a1);
327
+ // 将 massMarks 添加到地图实例
328
+ this.checkerMulchs.setMap(this.map);*/
329
+ let a2=[]
330
+ for(let i=0;i<this.level1.length;i++){
331
+ a2.push({
332
+ lnglat: [this.level1[i].f_longitude, this.level1[i].f_latitude], //点标记位置
333
+ name: '一级隐患',
334
+ id:i,
335
+ rowstr:this.level1[i]
336
+ })
337
+ }
338
+ // 将数组设置到 massMarks 图层
339
+ this.level1Mulchs.setData(a2);
340
+ // 将 massMarks 添加到地图实例
341
+ this.level1Mulchs.setMap(this.map);
342
+
343
+
344
+ let a3=[]
345
+ for(let i=0;i<this.level2.length;i++){
346
+ a3.push({
347
+ lnglat: [this.level2[i].f_longitude,this.level2[i].f_latitude], //点标记位置
348
+ name: '二级隐患',
349
+ id:i,
350
+ rowstr:this.level2[i]
351
+ })
352
+ }
353
+ // 将数组设置到 massMarks 图层
354
+ this.level2Mulchs.setData(a3);
355
+ // 将 massMarks 添加到地图实例
356
+ this.level2Mulchs.setMap(this.map);
357
+
358
+ let a4=[]
359
+ for(let i=0;i<this.level3.length;i++){
360
+ a4.push({
361
+ lnglat: [this.level3[i].f_longitude, this.level3[i].f_latitude], //点标记位置
362
+ name: '三级隐患',
363
+ id:i,
364
+ rowstr:this.level3[i]
365
+ })
366
+ }
367
+ // 将数组设置到 massMarks 图层
368
+ this.level3Mulchs.setData(a4);
369
+ // 将 massMarks 添加到地图实例
370
+ this.level3Mulchs.setMap(this.map);
371
+
372
+
373
+ let a5=[]
374
+ for(let i=0;i<this.problems.length;i++){
375
+ a5.push({
376
+ lnglat: [this.problems[i].f_longitude, this.problems[i].f_latitude], //点标记位置
377
+ name: '普通问题',
378
+ id:i,
379
+ rowstr:this.problems[i]
380
+ })
381
+ }
382
+ // 将数组设置到 massMarks 图层
383
+ this.problemsMulchs.setData(a5);
384
+ // 将 massMarks 添加到地图实例
385
+ this.problemsMulchs.setMap(this.map);
386
+ //组装安检员点位集合
387
+ },
388
+ //处理图层和覆盖物的显示隐藏
389
+ enableChange(vname,val){
390
+ //tag
391
+ //tag
392
+ switch(vname){
393
+ case 'satelliteEnable':
394
+ if(val){
395
+ this.map.add(this.satellite)
396
+ }else{
397
+ this.map.remove(this.satellite)
398
+ }
399
+ break;
400
+ case 'roadNetEnable':
401
+ if(val){
402
+ this.map.add(this.roadNet)
403
+ }else{
404
+ this.map.remove(this.roadNet)
405
+ }
406
+ break;
407
+ case 'checker':
408
+ if(val){
409
+ this.chekckOps.show()
410
+ }else{
411
+ this.chekckOps.hide()
412
+ }
413
+ break;
414
+ case 'level1':
415
+ if(val){
416
+ this.level1Mulchs.show()
417
+ }else{
418
+ this.level1Mulchs.hide()
419
+ }
420
+ break;
421
+ case 'level2':
422
+ if(val){
423
+ this.level2Mulchs.show()
424
+ }else{
425
+ this.level2Mulchs.hide()
426
+ }
427
+ break;
428
+ case 'level3':
429
+ if(val){
430
+ this.level3Mulchs.show()
431
+ }else{
432
+ this.level3Mulchs.hide()
433
+ }
434
+ break;
435
+ case 'problems':
436
+ if(val){
437
+ this.problemsMulchs.show()
438
+ }else{
439
+ this.problemsMulchs.hide()
440
+ }
441
+ break;
442
+ case 'townshipEnable':
443
+ this.showModal=true
444
+ this.townshipEnable=true
445
+ this.city_properEnable=false
446
+ break;
447
+ case 'city_properEnable':
448
+ this.showModal=true
449
+ this.city_properEnable=true
450
+ this.townshipEnable=false
451
+ break;
452
+ default:
453
+ }
454
+ },
455
+ closeModal(){
456
+ this.showModal=false
457
+ this.city_properEnable=false
458
+ this.townshipEnable=false
459
+ this.layers.townshipEnable=false
460
+ this.layers.city_properEnable=false
461
+ },
462
+ initMap(){
463
+ let that=this
464
+ this.map = new AMap.Map('check_map', {
465
+ zoom: 12,
466
+ center: [116.80030599999998, 37.65219],
467
+ showIndoorMap: false,
468
+ viewMode: '2D', //设置地图模式
469
+ lang: 'zh_cn', //设置地图语言类型
470
+ zindex: 99
471
+ });
472
+
473
+ let bounds = this.map.getBounds();
474
+ this.map.setLimitBounds(bounds);
475
+ // 异步加载地图插件
476
+ AMap.plugin(
477
+ ['AMap.ToolBar','AMap.Geolocation','AMap.Geocoder'], () => {//异步加载插件
478
+ // 自动定位插件
479
+ var geolocation = new AMap.Geolocation({
480
+ // 是否使用高精度定位,默认:true
481
+ enableHighAccuracy: true,
482
+ // 设置定位超时时间,默认:无穷大
483
+ showbutton: true,
484
+ //控制按钮的显示
485
+ timeout: 10000,
486
+ // 定位按钮的停靠位置的偏移量,默认:Pixel(10, 20)
487
+ buttonOffset: new AMap.Pixel(10, 20),
488
+ // 定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false
489
+ //zoomToAccuracy: true,
490
+ // 定位按钮的排放位置, RB表示右下
491
+ buttonPosition: 'LB'
492
+ })
493
+ that.geocoder = new AMap.Geocoder({
494
+ radius: 500 //范围,默认:500
495
+ });
496
+ that.map.addControl(geolocation)
497
+ geolocation.getCurrentPosition();
498
+ that.map.addControl(new AMap.ToolBar()) //初始化工具插件
499
+ });
500
+ this.map.setDefaultCursor('move');
501
+ //this.map.setMapStyle('amap://styles/whitesmoke');
502
+ this.satellite=new AMap.TileLayer.Satellite()//卫星图层
503
+ this.roadNet=new AMap.TileLayer.RoadNet({opacity:0.8})//网路图层
504
+ //安检员位置集合
505
+ this.chekckOps=new AMap.OverlayGroup()
506
+ //初始化窗体
507
+ this.infoWindow = new AMap.InfoWindow({
508
+ anchor: 'bottom-center',
509
+ //isCustom: true, //使用自定义窗体
510
+ autoMove:true,
511
+ content: '',
512
+ offset: new AMap.Pixel(0, -25)
513
+ });
514
+ //安检员点位
515
+ /*this.checkerMulchs = new AMap.MassMarks([], {
516
+ opacity: 0.8, // 图层的透明度,取值范围[0,1],1代表完全不透明,0代表完全透明
517
+ zIndex: 111, //图层叠加的顺序值,0表示最底层。默认zIndex:5
518
+ cursor: 'pointer', //指定鼠标悬停时的鼠标样式,自定义cursor,IE仅支持cur/ani/ico格式,Opera不支持自定义cursor
519
+ //alwaysRender:false,
520
+ style: this.styleObject[0]
521
+ });
522
+ //tag
523
+ this.checkerMulchs.on('click',function (e) {
524
+ //tag)
525
+ let checkAddress='未获取到实时位置'
526
+ that.geocoder.getAddress(e.data.lnglat, function(status, result) {
527
+ if (status === 'complete'&& result.regeocode) {
528
+ checkAddress = result.regeocode.formattedAddress;
529
+ }else{
530
+ log.error('根据经纬度查询地址失败')
531
+ }
532
+ e.data.rowstr.checkAddress=checkAddress
533
+ let defectContent=that.getCheckerContent(e.data.rowstr)
534
+ that.infoWindow.setContent(defectContent)
535
+ that.infoWindow.open(that.map, e.data.lnglat);
536
+ });
537
+ })*/
538
+ //一级隐患点位
539
+ this.level1Mulchs=new AMap.MassMarks([], {
540
+ opacity: 0.8, // 图层的透明度,取值范围[0,1],1代表完全不透明,0代表完全透明
541
+ zIndex: 111, //图层叠加的顺序值,0表示最底层。默认zIndex:5
542
+ cursor: 'pointer', //指定鼠标悬停时的鼠标样式,自定义cursor,IE仅支持cur/ani/ico格式,Opera不支持自定义cursor
543
+ //alwaysRender:false,
544
+ style: this.styleObject[1]
545
+ });
546
+ this.level1Mulchs.on('click',function (e) {
547
+ //tag)
548
+ let defectContent=that.getDefectContent(e.data.rowstr)
549
+ that.infoWindow.setContent(defectContent)
550
+ that.infoWindow.open(that.map, e.data.lnglat);
551
+ })
552
+ //二级隐患点位
553
+ this.level2Mulchs=new AMap.MassMarks([], {
554
+ opacity: 0.8, // 图层的透明度,取值范围[0,1],1代表完全不透明,0代表完全透明
555
+ zIndex: 111, //图层叠加的顺序值,0表示最底层。默认zIndex:5
556
+ cursor: 'pointer', //指定鼠标悬停时的鼠标样式,自定义cursor,IE仅支持cur/ani/ico格式,Opera不支持自定义cursor
557
+ //alwaysRender:false,
558
+ style: this.styleObject[2]
559
+ });
560
+ this.level2Mulchs.on('click',function (e) {
561
+ //tag)
562
+ let defectContent=that.getDefectContent(e.data.rowstr)
563
+ that.infoWindow.setContent(defectContent)
564
+ that.infoWindow.open(that.map, e.data.lnglat);
565
+ })
566
+ //三级隐患点位
567
+ this.level3Mulchs=new AMap.MassMarks([], {
568
+ opacity: 0.8, // 图层的透明度,取值范围[0,1],1代表完全不透明,0代表完全透明
569
+ zIndex: 111, //图层叠加的顺序值,0表示最底层。默认zIndex:5
570
+ cursor: 'pointer', //指定鼠标悬停时的鼠标样式,自定义cursor,IE仅支持cur/ani/ico格式,Opera不支持自定义cursor
571
+ //alwaysRender:false,
572
+ style: this.styleObject[3]
573
+ });
574
+ this.level3Mulchs.on('click',function (e) {
575
+ //tag)
576
+ let defectContent=that.getDefectContent(e.data.rowstr)
577
+ that.infoWindow.setContent(defectContent)
578
+ that.infoWindow.open(that.map, e.data.lnglat);
579
+ })
580
+ //普通问题点位
581
+ this.problemsMulchs=new AMap.MassMarks([], {
582
+ opacity: 0.8, // 图层的透明度,取值范围[0,1],1代表完全不透明,0代表完全透明
583
+ zIndex: 111, //图层叠加的顺序值,0表示最底层。默认zIndex:5
584
+ cursor: 'pointer', //指定鼠标悬停时的鼠标样式,自定义cursor,IE仅支持cur/ani/ico格式,Opera不支持自定义cursor
585
+ //alwaysRender:false,
586
+ style: this.styleObject[4]
587
+ });
588
+ this.problemsMulchs.on('click',function (e) {
589
+ //tag)
590
+ let defectContent=that.getDefectContent(e.data.rowstr)
591
+ that.infoWindow.setContent(defectContent)
592
+ that.infoWindow.open(that.map, e.data.lnglat);
593
+ })
594
+
595
+
596
+ },
597
+ closeInfoWindow(){
598
+ this.infoWindow.close()
599
+ },
600
+ checkerInit(){
601
+ /*let marker1 = new AMap.Marker({
602
+ position: [114.574809,33.621501],
603
+ icon:'http://192.168.20.28:8400/image/anjianyuan.png'
604
+ });
605
+ //tag
606
+ marker1.setLabel({
607
+ //offset: new AMap.Pixel(20, 20), //设置文本标注偏移量
608
+ content: "<div class='info' style='background-color: #0b87e2'>何文强</div>", //设置文本标注内容
609
+ direction: 'bottom' //设置文本标注方位
610
+ })*/
611
+ let that = this
612
+ this.chekckOps.clearOverlays()
613
+ for(let j=0;j<this.checkers.length;j++){
614
+ //tag+"---"+this.checkers[j].f_longitude+"---"+this.checkers[j].f_latitude)
615
+ //let o={f_longitude:"114.72"+(Math.floor(Math.random()*(9999-1000))+1000),f_latitude:"33.56"+(Math.floor(Math.random()*(9999-1000))+1000),name:"hwq3",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865}
616
+ let marker=new AMap.Marker({
617
+ //map: that.map,
618
+ offset:new AMap.Pixel(-18, -10),
619
+ position: [this.checkers[j].f_longitude,this.checkers[j].f_latitude],
620
+ icon:new AMap.Icon({
621
+ image: '/images/anjianyuan.png', //人员图标URL
622
+ imageOffset: new AMap.Pixel(0, 0), // 图标偏移位置
623
+ imageSize: new AMap.Size(36, 36) //图标大小
624
+ }),
625
+ label:{
626
+ //offset: new AMap.Pixel(20, 20), //设置文本标注偏移量
627
+ content: `<div class='info' style='background-color: rgb(0,185,255);color: #ffffff;padding: 5px;border-radius: 4px'>${this.checkers[j].name}</div>`, //设置文本标注内容
628
+ direction: 'bottom', //设置文本标注方位
629
+ offset:new AMap.Pixel(0, -4)
630
+ },
631
+ extData:this.checkers[j]
632
+ })
633
+ this.chekckOps.addOverlay(marker)
634
+
635
+ }
636
+ this.chekckOps.setMap(this.map)
637
+ this.chekckOps.on('click',function (e) {
638
+ let pe=e.target.getExtData()
639
+ for(let obj in pe){
640
+ //tag
641
+ }
642
+ let checkAddress='未获取到实时位置'
643
+ that.geocoder.getAddress([pe.f_longitude,pe.f_latitude], function(status, result) {
644
+ if (status === 'complete'&& result.regeocode) {
645
+ checkAddress = result.regeocode.formattedAddress;
646
+ }/*else{
647
+ log.error('根据经纬度查询地址失败')
648
+ }*/
649
+ pe.checkAddress=checkAddress
650
+ let defectContent=that.getCheckerContent(pe)
651
+ that.infoWindow.setContent(defectContent)
652
+ that.infoWindow.open(that.map, [pe.f_longitude,pe.f_latitude])
653
+ })
654
+ })
655
+ /*AMap.event.addListener(this.ops, 'click', function (e) {
656
+ //tag)
657
+ //that.infoWindow.open(that.map, marker.getPosition());
658
+ })*/
659
+ },
660
+ //获取当前时间的前两个小时
661
+ getNowFormatDate(house=0) {
662
+ //tag
663
+ let date = new Date();
664
+ let seperator1 = "-";
665
+ let seperator2 = ":";
666
+ if(house != 0){
667
+ date.setHours(date.getHours()-house)
668
+ }
669
+ let month = date.getMonth() + 1;
670
+ let strDate = date.getDate();
671
+ let hour = date.getHours();
672
+ let min = date.getMinutes();
673
+ let second = date.getSeconds();
674
+ if (month >= 1 && month <= 9) {
675
+ month = "0" + month;
676
+ }
677
+ if (strDate >= 0 && strDate <= 9) {
678
+ strDate = "0" + strDate;
679
+ }
680
+ if (hour >= 0 && hour <= 9) {
681
+ hour = "0" + hour;
682
+ }
683
+ if (min >= 0 && min <= 9) {
684
+ min = "0" + min;
685
+ }
686
+ if (second >= 0 && second <= 9) {
687
+ second = "0" + second;
688
+ }
689
+ let currentdate = date.getFullYear() + seperator1 + month + seperator1 + strDate
690
+ + " " + hour + seperator2 + min
691
+ + seperator2 + second;
692
+ return currentdate;
693
+ },
694
+ toStandardTimeString() {
695
+ let dt = new Date()
696
+ let month = dt.getMonth()+1
697
+ let date = dt.getDate()
698
+ let hour = dt.getHours()
699
+ let min = dt.getMinutes()
700
+ let sec = dt.getSeconds()
701
+ return dt.getFullYear() + '-' + (month<10? '0'+ month : month) + '-' + (date<10? '0'+ date : date)
702
+ + ' ' + (hour<10? '0'+ hour : hour)
703
+ },
704
+ async safeRefresh(){
705
+ //tag
706
+ //获取所有安检员的点位集合-----测试数据
707
+ /*this.checkers=[]
708
+ this.checkers.push({f_longitude:114.7318,f_latitude:33.567126,name:"hwq1",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865})
709
+ this.checkers.push({f_longitude:114.726801,f_latitude:33.566912,name:"hwq2",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865})
710
+ this.checkers.push({f_longitude:114.723346,f_latitude:33.568932,name:"hwq3",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865})
711
+ this.checkers.push({f_longitude:114.711741,f_latitude:33.585519,name:"hwq4",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865})
712
+ this.checkers.push({f_longitude:114.756716,f_latitude:33.594528,name:"hwq5",f_provider:"lbs",f_battery_level:38,f_bearing:"210.0",uploadTime:"2021-11-17 17:28:35",f_signal_strength:4,userid:"141701",f_speed:"0.0",f_internal_quote:8535,f_altitude:"9.72", f_traffic:345865})
713
+ this.defectList.rows=[]
714
+ this.defectList.rows.push({"f_longitude":114.661358,"f_latitude":33.596897,"f_checker_name":"hwq2","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
715
+ this.defectList.rows.push({"f_longitude":114.659985,"f_latitude":33.62892,"f_checker_name":"hwq3","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
716
+ this.defectList.rows.push({"f_longitude":114.634579,"f_latitude":33.616627,"f_checker_name":"hwq4","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
717
+ this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
718
+ this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
719
+ this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
720
+ this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
721
+ this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
722
+ this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})
723
+ this.defectList.rows.push({"f_longitude":114.690197,"f_latitude":33.604332,"f_checker_name":"hwq5","f_address":"人民路东段百昌家园路西北1栋西单元4层西户","f_item_value":"是","f_item_name":"过墙、暗封等隐蔽部位锈蚀","f_upload_date":"2021-11-16 20:07:24","f_defect_level":"一级隐患","f_is_repaired":null})*/
724
+ await this.getNewData()
725
+ this.assemblyData()
726
+ }
727
+ },
728
+ computed:{
729
+
730
+ },
731
+ destroyed(){
732
+ window.clearInterval(this.intervalNum)
733
+ }
734
+ }
735
+
736
+ </script>
737
+
738
+ <style lang="less" scoped>
739
+
740
+ .safe_checkbox_sty{
741
+ vertical-align:text-bottom;
742
+ margin-right: 3px;
743
+
744
+ }
745
+ .safe_ul_sty{
746
+ list-style-type: none;
747
+ font-size: 13px;
748
+ padding-left: 5px;
749
+ }
750
+ .safe_li_sty{
751
+ font-size: 13px;
752
+ margin-top: 5px;
753
+ }
754
+ .safe_p{
755
+ white-space: nowrap;
756
+ overflow: hidden;
757
+ text-overflow: ellipsis;
758
+ margin: 0 0 0 10px;
759
+
760
+ font-size: 12px;
761
+ }
762
+ .safe_list_li{
763
+ margin-top: 5px;
764
+ background-color: #ffffff;
765
+ border: solid 1px #f0f4fa !important;
766
+ color: #666666 !important;
767
+ font-size: 1.3rem !important;
768
+ font-family: PINGFANG-MEDIUM !important;
769
+ padding: 8px;
770
+ }
771
+ .safe_list_li:hover{
772
+ background-color: rgb(203,234,241);
773
+ }
774
+ .safe_deimg{
775
+ vertical-align: text-bottom;
776
+ width: 15px;
777
+ margin-right: 3px;
778
+ }
779
+ </style>
780
+