openatc-components 0.4.98 → 0.4.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 (423) hide show
  1. package/.babelrc +18 -18
  2. package/.editorconfig +9 -9
  3. package/.eslintignore +5 -5
  4. package/.eslintrc.js +31 -31
  5. package/.postcssrc.js +10 -10
  6. package/README.md +30 -30
  7. package/build/build.js +41 -41
  8. package/build/check-versions.js +54 -54
  9. package/build/package.config.js +58 -58
  10. package/build/package.dev.config.js +107 -107
  11. package/build/package.prod.config.js +160 -160
  12. package/build/utils.js +101 -101
  13. package/build/vue-loader.conf.js +22 -22
  14. package/build/webpack.base.conf.js +120 -120
  15. package/build/webpack.dev.conf.js +95 -95
  16. package/build/webpack.prod.conf.js +149 -149
  17. package/config/prod.env.js +5 -5
  18. package/config/test.env.js +7 -7
  19. package/index.html +12 -12
  20. package/package/kisscomps/components/BoardCard/BoardCard.vue +8 -0
  21. package/package/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +27 -3
  22. package/package/kisscomps/components/Channelization/Channelization.vue +585 -585
  23. package/package/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  24. package/package/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  25. package/package/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  26. package/package/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +2 -2
  27. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  28. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  29. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  30. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  31. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  32. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  33. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  34. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  35. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  36. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  37. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  38. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  39. package/package/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  40. package/package/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  41. package/package/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  42. package/package/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  43. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  44. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  45. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  46. package/package/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  47. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  48. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  49. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  50. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  51. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +368 -368
  52. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  53. package/package/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  54. package/package/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +64 -19
  55. package/package/kisscomps/components/DrawChannelization/drawsvg/index.vue +144 -144
  56. package/package/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  57. package/package/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  58. package/package/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +2 -2
  59. package/package/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  60. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  61. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  62. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  63. package/package/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  64. package/package/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  65. package/package/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  66. package/package/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +13 -6
  67. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  68. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  69. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  70. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  71. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  72. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  73. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  74. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  75. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +4 -2
  76. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  77. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  78. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  79. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  80. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  81. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  82. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  83. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  84. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  85. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  86. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  87. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  88. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  89. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  90. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  91. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  92. package/package/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +59 -18
  93. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  94. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  95. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  96. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  97. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +0 -16
  98. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  99. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  100. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +0 -16
  101. package/package/kisscomps/components/IntersectionMap/intersectionmap.vue +10 -0
  102. package/package/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +534 -534
  103. package/package/kisscomps/components/KanBan/kanban.vue +231 -231
  104. package/package/kisscomps/components/MessageBox/index.vue +96 -96
  105. package/package/kisscomps/components/OptimizeKanban/index.js +2 -0
  106. package/package/kisscomps/components/OptimizeKanban/index.vue +369 -0
  107. package/package/kisscomps/components/OverviewComponent/index.vue +33 -7
  108. package/package/kisscomps/components/PatternOptimize/PatternOptimize.vue +329 -329
  109. package/package/kisscomps/components/PatternStatus/PatternStatus.vue +157 -1
  110. package/package/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  111. package/package/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  112. package/package/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  113. package/package/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  114. package/package/kisscomps/components/PhaseMarker/index.js +6 -6
  115. package/package/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  116. package/package/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  117. package/package/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  118. package/package/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  119. package/package/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  120. package/package/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  121. package/package/kisscomps/components/PhasePedSelect/index.vue +206 -206
  122. package/package/kisscomps/components/SchemeConfig/SchemeConfig.vue +30 -7
  123. package/package/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +365 -365
  124. package/package/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  125. package/package/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  126. package/package/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +235 -235
  127. package/package/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  128. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +131 -131
  129. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +871 -871
  130. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  131. package/package/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  132. package/package/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  133. package/package/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +308 -308
  134. package/package/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +19 -0
  135. package/package/kisscomps/components/SchemeConfig/utils/thirdPartypermission.js +95 -95
  136. package/package/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  137. package/package/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  138. package/package/kisscomps/components/StageOptimize/StageOptimize.vue +367 -367
  139. package/package/kisscomps/components/StageOptimize/index.js +2 -2
  140. package/package/kisscomps/components/StageOptimize/index.vue +310 -0
  141. package/package/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  142. package/package/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  143. package/package/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  144. package/package/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  145. package/package/kisscomps/components/XiaoKanban/index.vue +122 -122
  146. package/package/kisscomps/components/overView/index.vue +30 -7
  147. package/package/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  148. package/package/kisscomps/components/patternConfig/planContent.vue +604 -604
  149. package/package/kisscomps/components/patternConfig/planMenu.vue +329 -329
  150. package/package/kisscomps/components/patternConfig/utils.js +152 -152
  151. package/package/kisscomps/components/patternList/patternList.vue +4 -0
  152. package/package/kisscomps/index.js +2 -6
  153. package/package/kissui.min.js +1 -1
  154. package/package.json +1 -1
  155. package/src/App.vue +24 -20
  156. package/src/EdgeMgr/EdgeModelBase.js +16 -16
  157. package/src/EdgeMgr/controller/crossDiagramMgr.js +125 -125
  158. package/src/api/authapi.js +31 -31
  159. package/src/api/config.js +21 -21
  160. package/src/api/control.js +110 -110
  161. package/src/api/device.js +135 -135
  162. package/src/api/fault.js +66 -66
  163. package/src/api/index.js +24 -24
  164. package/src/api/login.js +46 -46
  165. package/src/api/optimize.js +72 -72
  166. package/src/api/param.js +165 -165
  167. package/src/api/passwdAssest.js +101 -101
  168. package/src/api/permission.js +33 -33
  169. package/src/api/route.js +171 -171
  170. package/src/api/template.js +27 -27
  171. package/src/assets/font/LICENSE.txt +202 -202
  172. package/src/assets/font/font.css +6 -6
  173. package/src/i18n/index.js +26 -26
  174. package/src/i18n/language/en.js +30 -106
  175. package/src/i18n/language/index.js +25 -31
  176. package/src/i18n/language/zh.js +31 -107
  177. package/src/icons/index.js +20 -20
  178. package/src/icons/svg/azimuthlocking.svg +26 -26
  179. package/src/icons/svg/bendi.svg +110 -110
  180. package/src/icons/svg/bujin.svg +36 -36
  181. package/src/icons/svg/connectBlue.svg +7 -7
  182. package/src/icons/svg/currentvolume.svg +0 -0
  183. package/src/icons/svg/custom-BRTlane.svg +40 -40
  184. package/src/icons/svg/custom-buslane.svg +40 -40
  185. package/src/icons/svg/custom-detector.svg +12 -12
  186. package/src/icons/svg/custom-east-bottom.svg +32 -32
  187. package/src/icons/svg/custom-east-top.svg +32 -32
  188. package/src/icons/svg/custom-ewped.svg +35 -35
  189. package/src/icons/svg/custom-nonmotorizedlane.svg +40 -40
  190. package/src/icons/svg/custom-north-left.svg +32 -32
  191. package/src/icons/svg/custom-north-right.svg +32 -32
  192. package/src/icons/svg/custom-peddetector.svg +17 -17
  193. package/src/icons/svg/custom-snped.svg +35 -35
  194. package/src/icons/svg/custom-south-left.svg +32 -32
  195. package/src/icons/svg/custom-south-right.svg +32 -32
  196. package/src/icons/svg/custom-tramlane.svg +40 -40
  197. package/src/icons/svg/custom-vehiclebranch.svg +40 -40
  198. package/src/icons/svg/custom-vehiclemainroad.svg +41 -41
  199. package/src/icons/svg/custom-west-bottom.svg +32 -32
  200. package/src/icons/svg/custom-west-top.svg +32 -32
  201. package/src/icons/svg/custom-xlped.svg +14 -14
  202. package/src/icons/svg/custom-xrped.svg +14 -14
  203. package/src/icons/svg/cutRed.svg +7 -7
  204. package/src/icons/svg/cycle.svg +0 -0
  205. package/src/icons/svg/dingzhouqi.svg +34 -34
  206. package/src/icons/svg/ganyingkongzhi.svg +30 -30
  207. package/src/icons/svg/guandeng.svg +81 -81
  208. package/src/icons/svg/huangshan.svg +71 -71
  209. package/src/icons/svg/maincontrol.svg +0 -0
  210. package/src/icons/svg/manualcontrolbackground.svg +51 -51
  211. package/src/icons/svg/manualcontrolbackground1.svg +62 -62
  212. package/src/icons/svg/manualcontrolbackgrounden.svg +62 -62
  213. package/src/icons/svg/model.svg +0 -0
  214. package/src/icons/svg/phasediff.svg +0 -0
  215. package/src/icons/svg/prioritycontrol.svg +21 -21
  216. package/src/icons/svg/quanhong.svg +86 -86
  217. package/src/icons/svg/shanghe.svg +11 -11
  218. package/src/icons/svg/shoudong.svg +103 -103
  219. package/src/icons/svg/tentativeplan.svg +28 -28
  220. package/src/icons/svg/time.svg +0 -0
  221. package/src/icons/svg/wuxianlan.svg +46 -46
  222. package/src/icons/svg/xiala.svg +11 -11
  223. package/src/icons/svg/xingrenguojie.svg +33 -33
  224. package/src/icons/svg/xitong.svg +89 -89
  225. package/src/icons/svg/youxian.svg +41 -41
  226. package/src/icons/svg/zizhukongzhi.svg +43 -43
  227. package/src/kisscomps/components/BoardCard/BoardCard.vue +8 -0
  228. package/src/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +27 -3
  229. package/src/kisscomps/components/Channelization/Channelization.vue +585 -585
  230. package/src/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  231. package/src/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  232. package/src/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  233. package/src/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +2 -2
  234. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  235. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  236. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  237. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  238. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  239. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  240. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  241. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  242. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  243. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  244. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  245. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  246. package/src/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  247. package/src/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  248. package/src/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  249. package/src/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  250. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  251. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  252. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  253. package/src/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  254. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  255. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  256. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  257. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  258. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +368 -368
  259. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  260. package/src/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  261. package/src/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +64 -19
  262. package/src/kisscomps/components/DrawChannelization/drawsvg/index.vue +144 -144
  263. package/src/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  264. package/src/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  265. package/src/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +2 -2
  266. package/src/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  267. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  268. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  269. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  270. package/src/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  271. package/src/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  272. package/src/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  273. package/src/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +13 -6
  274. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  275. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  276. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  277. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  278. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  279. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  280. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  281. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  282. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +4 -2
  283. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  284. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  285. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  286. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  287. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  288. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  289. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  290. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  291. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  292. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  293. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  294. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  295. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  296. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  297. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  298. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  299. package/src/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +59 -18
  300. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  301. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  302. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  303. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  304. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +0 -16
  305. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  306. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  307. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +0 -16
  308. package/src/kisscomps/components/IntersectionMap/intersectionmap.vue +10 -0
  309. package/src/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +534 -534
  310. package/src/kisscomps/components/KanBan/kanban.vue +231 -231
  311. package/src/kisscomps/components/MessageBox/index.vue +96 -96
  312. package/src/kisscomps/components/OverviewComponent/index.vue +33 -7
  313. package/src/kisscomps/components/PatternOptimize/PatternOptimize.vue +329 -329
  314. package/src/kisscomps/components/PatternStatus/PatternStatus.vue +157 -1
  315. package/src/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  316. package/src/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  317. package/src/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  318. package/src/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  319. package/src/kisscomps/components/PhaseMarker/index.js +6 -6
  320. package/src/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  321. package/src/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  322. package/src/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  323. package/src/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  324. package/src/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  325. package/src/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  326. package/src/kisscomps/components/PhasePedSelect/index.vue +206 -206
  327. package/src/kisscomps/components/SchemeConfig/SchemeConfig.vue +30 -7
  328. package/src/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +365 -365
  329. package/src/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  330. package/src/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  331. package/src/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +235 -235
  332. package/src/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  333. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +131 -131
  334. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +871 -871
  335. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  336. package/src/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  337. package/src/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  338. package/src/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +308 -308
  339. package/src/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +19 -0
  340. package/src/kisscomps/components/SchemeConfig/utils/thirdPartypermission.js +95 -95
  341. package/src/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  342. package/src/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  343. package/src/kisscomps/components/StageOptimize/StageOptimize.vue +367 -367
  344. package/src/kisscomps/components/StageOptimize/index.js +2 -2
  345. package/src/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  346. package/src/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  347. package/src/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  348. package/src/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  349. package/src/kisscomps/components/XiaoKanban/index.vue +122 -122
  350. package/src/kisscomps/components/overView/index.vue +30 -7
  351. package/src/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  352. package/src/kisscomps/components/patternConfig/planContent.vue +604 -604
  353. package/src/kisscomps/components/patternConfig/planMenu.vue +329 -329
  354. package/src/kisscomps/components/patternConfig/utils.js +152 -152
  355. package/src/kisscomps/components/patternList/patternList.vue +4 -0
  356. package/src/kisscomps/index.js +2 -6
  357. package/src/lib/publicjs/ArryListUtil.js +38 -38
  358. package/src/lib/publicjs/HttpurlMgr.js +45 -45
  359. package/src/lib/publicjs/KissApi.js +158 -158
  360. package/src/lib/publicjs/KissWSSub/Heartcheck.js +128 -128
  361. package/src/lib/publicjs/KissWSSub/KissWsSub.js +91 -91
  362. package/src/lib/publicjs/KissWSSub/KissWsSubByType.js +152 -152
  363. package/src/lib/publicjs/KissWSSub/SimuWsSubByType.js +44 -44
  364. package/src/lib/publicjs/KissWSSub/Sub.js +51 -51
  365. package/src/lib/publicjs/KissWSSub/SubChannel.js +119 -119
  366. package/src/lib/publicjs/basecomponents.js +65 -65
  367. package/src/lib/publicjs/localStorage.js +112 -112
  368. package/src/lib/publicjs/objdeepcopy.js +32 -32
  369. package/src/lib/publicjs/pageScroll.js +30 -30
  370. package/src/lib/publicjs/passwdAssest.js +101 -101
  371. package/src/lib/publicjs/styleclassfactory.js +32 -32
  372. package/src/node_modules/.package_versions.json +1 -0
  373. package/src/router/index.js +63 -63
  374. package/src/store/index.js +26 -26
  375. package/src/store/modules/globalParam.js +67 -67
  376. package/src/utils/ControlFormat.js +36 -14
  377. package/src/utils/RingDataModel.js +335 -335
  378. package/src/utils/auth.js +199 -199
  379. package/src/utils/conflictList.js +87 -87
  380. package/src/utils/dateFormat.js +41 -41
  381. package/src/utils/fault.js +72 -20
  382. package/src/utils/faultcode.js +182 -130
  383. package/src/utils/index.js +69 -69
  384. package/src/utils/pedphasedesc.js +119 -119
  385. package/src/utils/phaseList.js +203 -203
  386. package/src/utils/phasedesc.js +144 -144
  387. package/src/utils/responseMessage.js +21 -24
  388. package/src/utils/validate.js +43 -43
  389. package/src/views/customchannelization.vue +6 -6
  390. package/src/views/home.1.vue +479 -479
  391. package/src/views/home.vue +93 -93
  392. package/src/views/intersection.vue +11 -5
  393. package/src/views/intersection2.vue +328 -328
  394. package/src/views/overView.vue +63 -63
  395. package/src/views/patternConfig.vue +2 -2
  396. package/src/views/schemeconfig.vue +1 -1
  397. package/static/styles/channelizatioon.scss +433 -433
  398. package/static/styles/common.scss +30 -30
  399. package/static/styles/commonkanban.scss +168 -168
  400. package/static/styles/dark/index.scss +2 -2
  401. package/static/styles/dark/theme/element-dark.scss +44 -44
  402. package/static/styles/index.scss +84 -84
  403. package/static/styles/intersection.scss +180 -180
  404. package/static/styles/light/index.scss +2 -2
  405. package/static/styles/light/theme/element-light.scss +44 -44
  406. package/static/styles/overview.scss +146 -146
  407. package/static/styles/patternConfig.scss +56 -56
  408. package/static/styles/phasePedSelect.scss +71 -71
  409. package/static/styles/stages.scss +57 -57
  410. package/static/styles/uiComponents.scss +57 -57
  411. package/static/styles/xiaokanban.scss +61 -61
  412. package/static/token.json +2 -2
  413. package/test/e2e/custom-assertions/elementCount.js +27 -27
  414. package/test/e2e/nightwatch.conf.js +46 -46
  415. package/test/e2e/runner.js +48 -48
  416. package/test/e2e/specs/test.js +19 -19
  417. package/test/unit/.eslintrc +7 -7
  418. package/test/unit/jest.conf.js +30 -30
  419. package/test/unit/setup.js +3 -3
  420. package/test/unit/specs/HelloWorld.spec.js +11 -11
  421. package/package/kissui.js +0 -216608
  422. package/pnpm-lock.yaml +0 -16362
  423. package/src/i18n/language/ru.js +0 -1555
@@ -1,585 +1,585 @@
1
- /**
2
- * Copyright (c) 2020 kedacom
3
- * OpenATC is licensed under Mulan PSL v2.
4
- * You can use this software according to the terms and conditions of the Mulan PSL v2.
5
- * You may obtain a copy of Mulan PSL v2 at:
6
- * http://license.coscl.org.cn/MulanPSL2
7
- * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
8
- * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
9
- * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
10
- * See the Mulan PSL v2 for more details.
11
- **/
12
- <!--静态渠化路口,需要传入路口状态数据和检测器状态数据-->
13
- <template>
14
- <div class="show-channelization channelization-base-map" :class="{
15
- 'widescreenCrossImg': bodyDomWidth > 1680,
16
- 'superlargeCrossImg': bodyDomWidth <= 1680 && bodyDomWidth > 1440,
17
- 'largeCrossImg': bodyDomWidth <= 1440 && bodyDomWidth > 1280,
18
- 'middleCrossImg2': bodyDomWidth <= 1280 && bodyDomWidth > 960,
19
- 'smallCrossImg': bodyDomWidth <= 960 && bodyDomWidth > 890,
20
- 'smallCrossImg2': bodyDomWidth <= 890 && bodyDomWidth > 720,
21
- 'miniCrossImg': bodyDomWidth <= 720 && bodyDomWidth > 650,
22
- 'superminiCrossImg': bodyDomWidth <= 650 && bodyDomWidth > 450,
23
- 'transMiddleCrossImg': bodyDomWidth <= 450 && bodyDomWidth > 350,
24
- 'transMiddleCrossImg2': bodyDomWidth <= 350 && bodyDomWidth > 300,
25
- 'transMiddleCrossImg3': bodyDomWidth <= 300 && bodyDomWidth > 260,
26
- 'transMiniCrossImg': bodyDomWidth <= 260,
27
- 'changePaddingBottom': true }">
28
- <ChannelizationElements
29
- ref="channelizationElements"
30
- UsageMode="show"
31
- :allitem="allitem"
32
- :CrossMapVisible="CrossMapVisible"
33
- :CrossMapData="CrossMapData"
34
- :isSeletable="isSeletable"
35
- :Motorways="LanePhaseData"
36
- :Pedwalk="sidewalkPhaseData"
37
- :Countdown="Countdown"
38
- :CountdownList="phaseCountdownList"
39
- :Detector="DetectorData"
40
- :isHasPhase="isHasPhase"
41
- />
42
- </div>
43
- </template>
44
-
45
- <script>
46
- // import { mapState, mapGetters } from 'vuex'
47
- import ChannelizationElements from '../DrawChannelization/drawsvg/channelizationElements'
48
- // import { getIframdevid } from '../../../utils/auth.js'
49
- import { getChannelizatonChart } from '../../../api/cross'
50
-
51
- export default {
52
- name: 'channelization',
53
- components: {
54
- ChannelizationElements
55
- },
56
- computed: {
57
- // ...mapState({
58
- // curOpenatcAgentid: state => state.globalParam.curOpenatcAgentid
59
- // })
60
- // ,
61
- // ...mapGetters([
62
- // 'isfromatc'
63
- // ])
64
- },
65
- props: {
66
- crossStatusData: {
67
- type: Object
68
- },
69
- detectorStatusData: {
70
- type: Object
71
- },
72
- AgentId: {
73
- type: String,
74
- default: '0'
75
- }
76
- },
77
- watch: {
78
- crossStatusData: {
79
- handler: function (val) {
80
- // 路口状态数据
81
- this.statusData = JSON.parse(JSON.stringify(val))
82
- this.phaseStatusList = val.phase
83
- this.overlapStatusList = val.overlap
84
- if (val.control === 1 || val.control === 2 || val.control === 3) {
85
- // 黄闪、全红、关灯属于特殊控制,优先级最高,直接改变灯色,不用判断phase里的type,也不需要考虑跟随相位的灯色优先级
86
- if (val.control === 1) {
87
- this.getYellowFlashColor()
88
- } else {
89
- this.SpecialControl(val)
90
- }
91
- return
92
- }
93
- if (!val.phase && !this.overlapStatusList) {
94
- // 非特殊控制,相位和跟随相位不存在的情况下,灯色恢复默认
95
- this.handleSpecialControlStatus('默认')
96
- return
97
- }
98
- this.curPhase = val.current_phase
99
- this.isHasPhase = true
100
- this.createPhaseStatusMap()
101
- this.createOverlapPhaseStatusMap()
102
- this.getLanePhaseStatusData()
103
- this.getpedStatus()
104
- this.getCurPhaseCountdown()
105
- },
106
- // 深度观察监听
107
- deep: true
108
- },
109
- detectorStatusData: {
110
- handler: function (detectorsStatus) {
111
- // 检测器状态数据
112
- this.detectorStatusList = detectorsStatus.detector
113
- this.pedDetectorStatusList = detectorsStatus.io
114
- this.createDetectorStatusMap()
115
- this.getDetectorStatus()
116
- },
117
- deep: true
118
- },
119
- AgentId: {
120
- handler: function (val) {
121
- // 平台设备切换时,重载当前路口保存的渠化配置
122
- this.load('all')
123
- },
124
- deep: true
125
- }
126
- },
127
- data () {
128
- return {
129
- isSeletable: false,
130
- bodyDomWidth: 352,
131
- bodyDomSize: {
132
- width: 1920,
133
- height: 1080
134
- },
135
- CrossMapVisible: true, // 控制底图显示隐藏
136
- CrossMapData: {
137
- x: 400,
138
- y: 100,
139
- w: 800,
140
- h: 200,
141
- angle: 0,
142
- svgstr: '',
143
- imgfilesrc: ''
144
- }, // 管理底图数据
145
- Motorways: [],
146
- Texts: [],
147
- Pedwalk: [],
148
- Countdown: [],
149
- Detector: [],
150
- allitem: {
151
- x: 435,
152
- y: 325,
153
- w: 870,
154
- h: 650,
155
- angle: 0
156
- },
157
- LanePhaseData: [], // 车道相位数据
158
- // overlapLanePhaseData: [], // 车道跟随相位数据
159
- curPhase: [], // 当前相位列表
160
- phaseStatusList: [], // 相位状态列表
161
- phaseStatusMap: new Map(), // 相位状态映射
162
- phaseCountdownList: [], // 相位倒计时列表
163
- overlapPhaseStatusMap: new Map(), // 跟随相位状态映射
164
- ColorMap: new Map([[0, '#828282'], [1, '#ff2828'], [2, '#f7b500'], [3, '#77fb65'], [4, '#77fb65'], [5, '#f7b500']]), // 当前相位状态 --- 0:关灯, 1:红, 2:黄, 3:绿, 4:绿闪, 5:黄闪
165
- SidewalkColorMap: new Map([[0, '#828282'], [1, '#e24b4b'], [3, '#7bd66b']]),
166
- phaseControlColorMap: new Map([['黄闪', '#f7b500'], ['全红', '#ff2828'], ['关灯', '#828282'], ['默认', '#fff']]),
167
- sidewalkPhaseData: [], // 行人相位
168
- isHasPhase: true, // 是否有相位状态数据
169
-
170
- detectorStatusList: [], // 车辆检测器状态列表
171
- pedDetectorStatusList: [], // 行人检测器状态列表
172
- detectorStatusMap: new Map(), // 车辆检测器状态映射
173
- pedDetectorStatusMap: new Map(), // 行人检测器状态映射
174
- DetectorData: [], // 检测器数据(包括车辆和行人)
175
- DetectorColorMap: new Map([[0, 'transparent'], [1, '#00CCFF'], [2, '#FF0000']]) // 检测器状态填充颜色定义 0: 低电平 无车, 1: 高电平 有车, 2: 故障
176
- }
177
- },
178
- methods: {
179
- createPhaseStatusMap () {
180
- // 生成相位id和相位状态对应数据结构
181
- this.phaseStatusList.map(phase => {
182
- let phaseId = phase.id
183
- let phaseInfo = {
184
- type: phase.type,
185
- phaseCountdown: phase.countdown,
186
- pedtype: phase.pedtype
187
- }
188
- this.phaseStatusMap.set(phaseId, phaseInfo)
189
- })
190
- },
191
- createOverlapPhaseStatusMap () {
192
- if (this.overlapStatusList) {
193
- this.overlapStatusList.map(phase => {
194
- let phaseId = phase.id
195
- let phaseInfo = {
196
- type: phase.type,
197
- phaseCountdown: phase.countdown,
198
- pedtype: phase.pedtype
199
- }
200
- this.overlapPhaseStatusMap.set(phaseId, phaseInfo)
201
- })
202
- }
203
- },
204
- getLanePhaseStatusData () {
205
- let curLanePhaseData = []
206
- for (let i = 0; i < this.LanePhaseData.length; i++) {
207
- let curPhaseStatus
208
- if (this.LanePhaseData[i].phasetype === 'phase') {
209
- curPhaseStatus = this.phaseStatusMap.get(this.LanePhaseData[i].phaseid)
210
- }
211
- if (this.LanePhaseData[i].phasetype === 'overlap') {
212
- curPhaseStatus = this.overlapPhaseStatusMap.get(this.LanePhaseData[i].phaseid)
213
- }
214
- // if (!curPhaseStatus) continue // 没有关联相位的车道不显示
215
- let data
216
- if (curPhaseStatus) {
217
- data = {
218
- ...this.LanePhaseData[i],
219
- type: curPhaseStatus.type,
220
- color: this.ColorMap.get(curPhaseStatus.type),
221
- phaseCountdown: curPhaseStatus.phaseCountdown,
222
- flag: 'phase' // 车道相位数据标识
223
- }
224
- } else {
225
- // 没有关联的,或者没有对应状态的,车道显示默认白色
226
- data = {
227
- ...this.LanePhaseData[i],
228
- type: undefined,
229
- color: '#fff',
230
- flag: 'phase' // 车道相位数据标识
231
- }
232
- }
233
- curLanePhaseData.push(data)
234
- }
235
- this.LanePhaseData = JSON.parse(JSON.stringify(curLanePhaseData))
236
- // console.log(this.LanePhaseData)
237
- },
238
- getpedStatus () {
239
- // 行人相位状态
240
- let curPedStatus = []
241
- for (let i = 0; i < this.sidewalkPhaseData.length; i++) {
242
- let curPhaseStatus
243
- if (this.sidewalkPhaseData[i].phasetype === 'phase') {
244
- curPhaseStatus = this.phaseStatusMap.get(this.sidewalkPhaseData[i].phaseid)
245
- }
246
- if (this.sidewalkPhaseData[i].phasetype === 'overlap') {
247
- curPhaseStatus = this.overlapPhaseStatusMap.get(this.sidewalkPhaseData[i].phaseid)
248
- }
249
- // if (!curPhaseStatus) continue
250
- let data
251
- if (curPhaseStatus) {
252
- data = {
253
- ...this.sidewalkPhaseData[i],
254
- pedtype: curPhaseStatus.pedtype,
255
- color: this.SidewalkColorMap.get(curPhaseStatus.pedtype),
256
- flag: 'ped' // 行人相位数据标识
257
- }
258
- } else {
259
- // 接口没有对应的状态
260
- data = {
261
- ...this.sidewalkPhaseData[i],
262
- pedtype: undefined,
263
- color: '#fff',
264
- flag: 'ped' // 行人相位数据标识
265
- }
266
- }
267
- curPedStatus.push(data)
268
- }
269
- this.sidewalkPhaseData = JSON.parse(JSON.stringify(curPedStatus))
270
- // this.Pedwalk = JSON.parse(JSON.stringify(this.sidewalkPhaseData))
271
- },
272
- getCurPhaseCountdown () {
273
- // 获取当前相位倒计时颜色
274
- let phaseCountdownList = []
275
- this.curPhase.forEach(curP => {
276
- this.phaseStatusList.forEach(phaseInfo => {
277
- if (phaseInfo.id === curP) {
278
- let countdownObj = {}
279
- countdownObj.id = phaseInfo.id
280
- countdownObj.phaseCountdown = phaseInfo.countdown
281
- countdownObj.phaseCountdownColor = this.ColorMap.get(phaseInfo.type)
282
- phaseCountdownList.push(countdownObj)
283
- }
284
- })
285
- })
286
- this.phaseCountdownList = JSON.parse(JSON.stringify(phaseCountdownList))
287
- // console.log(this.phaseCountdownList)
288
- },
289
- // 加载
290
- load (type) {
291
- this.getChannelizatonChart().then((channelizatondata) => {
292
- let savedTemp = JSON.parse(JSON.stringify(channelizatondata))
293
- for (const [key, value] of Object.entries(savedTemp)) {
294
- if (key === 'vehile') {
295
- this.Motorways = value
296
- }
297
- if (key === 'text') {
298
- this.Texts = value
299
- }
300
- if (key === 'ped') {
301
- this.Pedwalk = value
302
- }
303
- if (key === 'countdown') {
304
- this.Countdown = value
305
- }
306
- if (key === 'detector') {
307
- this.Detector = value.filter(ele => ele.detailtype === 'detector')
308
- }
309
- if (key === 'crossMap') {
310
- this.CrossMapData = JSON.parse(JSON.stringify(value))
311
- }
312
- }
313
- this.isSeletable = false
314
- // 从接口得到所有渠化车道和人行道数据
315
- this.LanePhaseData = JSON.parse(JSON.stringify(this.Motorways))
316
- this.sidewalkPhaseData = JSON.parse(JSON.stringify(this.Pedwalk))
317
- this.DetectorData = JSON.parse(JSON.stringify(this.Detector))
318
- })
319
- },
320
- // 重置
321
- handleReset () {
322
- this.Texts = []
323
- this.Motorways = []
324
- this.Countdown = []
325
- this.phaseCountdownList = []
326
- this.Pedwalk = []
327
- this.Detector = []
328
- this.CrossMapData = {
329
- x: 400,
330
- y: 100,
331
- w: 800,
332
- h: 200,
333
- angle: 0,
334
- svgstr: '',
335
- imgfilesrc: ''
336
- }
337
- this.LanePhaseData = []
338
- this.sidewalkPhaseData = []
339
- this.DetectorData = []
340
- this.isHasPhase = true
341
- },
342
- getChannelizatonChart () {
343
- // let agentid = getIframdevid()
344
- // 路口已设置渠化,则总览默认显示渠化路口,未设置显示模版路口
345
- // if (this.isfromatc === true) {
346
- // this.$store.dispatch('SetShowHomePage', 'Graphical')
347
- // }
348
- this.handleReset()
349
- return new Promise((resolve, reject) => {
350
- getChannelizatonChart(this.AgentId).then(data => {
351
- // this.$emit('getChannelizationSetting', data)
352
- if (!data.data.success) {
353
- // let parrenterror = getMessageByCode(data.data.code, this.$i18n.locale)
354
- // if (data.data.data) {
355
- // // 子类型错误
356
- // let childErrorCode = data.data.data.errorCode
357
- // if (childErrorCode) {
358
- // let childerror = getMessageByCode(data.data.data.errorCode, this.$i18n.locale)
359
- // this.$message.error(parrenterror + ',' + childerror)
360
- // }
361
- // } else {
362
- // this.$message.error(parrenterror)
363
- // }
364
- return
365
- }
366
- if (data.data.data === undefined || JSON.stringify(data.data.data) === '{}') return
367
- // if (this.isfromatc === true) {
368
- // this.$store.dispatch('SetShowHomePage', 'Channelization')
369
- // }
370
- this.handleReset()
371
- let channelizatondata = data.data.data
372
- resolve(channelizatondata)
373
- })
374
- })
375
- },
376
- SpecialControl (data) {
377
- switch (data.control) {
378
- case 1: this.handleSpecialControlStatus('黄闪')
379
- break
380
- case 2: this.handleSpecialControlStatus('全红')
381
- break
382
- case 3: this.handleSpecialControlStatus('关灯')
383
- break
384
- default: this.handleSpecialControlStatus('默认')
385
- }
386
- },
387
- handleSpecialControlStatus (Control) {
388
- this.$refs.channelizationElements.resetPhaseStatus()
389
- // 控制黄闪、全红、关灯、默认情况下的车道相位颜色和倒计时颜色
390
- if (Control === '默认') {
391
- // 倒计时恢复默认颜色
392
- this.phaseCountdownList.forEach(item => {
393
- item.phaseCountdown = ''
394
- item.id = ''
395
- item.phaseCountdownColor = '#fff'
396
- })
397
- }
398
- if (this.LanePhaseData.length) {
399
- const LanePhaseData = this.LanePhaseData.map(data => ({
400
- ...data,
401
- color: this.phaseControlColorMap.get(Control)
402
- }))
403
- this.LanePhaseData = JSON.parse(JSON.stringify(LanePhaseData))
404
- }
405
- if (this.sidewalkPhaseData.length) {
406
- const sidewalkPhaseData = this.sidewalkPhaseData.map(data => ({
407
- ...data,
408
- color: this.phaseControlColorMap.get(Control)
409
- }))
410
- this.sidewalkPhaseData = JSON.parse(JSON.stringify(sidewalkPhaseData))
411
- }
412
- this.isHasPhase = false
413
- },
414
- createDetectorStatusMap () {
415
- this.detectorStatusMap = new Map()
416
- if (this.detectorStatusList) {
417
- this.detectorStatusList.map(detector => {
418
- let detectorId = detector.id
419
- let detectorInfo = {
420
- state: detector.state
421
- }
422
- this.detectorStatusMap.set(detectorId, detectorInfo)
423
- })
424
- }
425
- if (this.pedDetectorStatusList) {
426
- this.pedDetectorStatusList.map(peddetector => {
427
- let peddetectorId = peddetector.id
428
- let peddetectorInfo = {
429
- state: peddetector.state
430
- }
431
- this.pedDetectorStatusMap.set(peddetectorId, peddetectorInfo)
432
- })
433
- }
434
- // console.log(this.detectorStatusMap)
435
- // console.log(this.pedDetectorStatusMap)
436
- },
437
- getDetectorStatus () {
438
- let curDetectorData = []
439
- for (let i = 0; i < this.DetectorData.length; i++) {
440
- let curDetectorStatus
441
- let curDetectortype = this.DetectorData[i].detectortype
442
- if (curDetectortype === 1) {
443
- // 车辆检测器
444
- curDetectorStatus = this.detectorStatusMap.get(this.DetectorData[i].detectorid)
445
- }
446
- if (curDetectortype === 2) {
447
- // 行人检测器
448
- curDetectorStatus = this.pedDetectorStatusMap.get(this.DetectorData[i].detectorid)
449
- }
450
- // if (!curDetectorStatus) continue // 没有关联检测器不显示
451
- let data
452
- if (curDetectorStatus) {
453
- data = {
454
- ...this.DetectorData[i],
455
- state: curDetectorStatus.state,
456
- fillcolor: this.DetectorColorMap.get(curDetectorStatus.state),
457
- flag: curDetectortype === 1 ? 'detector' : 'peddetector' // 车道相位数据标识
458
- }
459
- } else {
460
- // 没有关联检测器的填充透明
461
- data = {
462
- ...this.DetectorData[i],
463
- state: undefined,
464
- fillcolor: 'transparent',
465
- flag: curDetectortype === 1 ? 'detector' : 'peddetector' // 车道相位数据标识
466
- }
467
- }
468
- curDetectorData.push(data)
469
- }
470
- this.DetectorData = JSON.parse(JSON.stringify(curDetectorData))
471
- },
472
- getParentSize () {
473
- // 获取最外层dom尺寸,适配准备
474
- var _this = this
475
- this.$nextTick(function () {
476
- if (this.$el.parentElement === null || this.$el.parentElement === undefined) return
477
- this.bodyDomSize.width = this.$el.parentElement.clientWidth
478
- this.bodyDomWidth = this.bodyDomSize.width
479
- window.addEventListener('resize', () => {
480
- // 定义窗口大小变更通知事件
481
- if (_this.$el.parentElement === null || _this.$el.parentElement === undefined) return
482
- _this.bodyDomSize.width = _this.$el.parentElement.clientWidth
483
- this.bodyDomWidth = this.bodyDomSize.width
484
- console.log('resize this.bodyDomSize.width', _this.bodyDomSize.width)
485
- }, false)
486
- })
487
- },
488
- getYellowFlashColor () {
489
- // 渠化车道相位
490
- let curLanePhaseData = []
491
- for (let i = 0; i < this.LanePhaseData.length; i++) {
492
- const data = {
493
- ...this.LanePhaseData[i],
494
- type: '黄闪',
495
- control: 1
496
- }
497
- curLanePhaseData.push(data)
498
- }
499
- this.LanePhaseData = JSON.parse(JSON.stringify(curLanePhaseData))
500
-
501
- // 渠化行人相位
502
- let curPedStatus = []
503
- for (let i = 0; i < this.sidewalkPhaseData.length; i++) {
504
- const data = {
505
- ...this.sidewalkPhaseData[i],
506
- pedtype: '黄闪',
507
- control: 1
508
- }
509
- curPedStatus.push(data)
510
- }
511
- this.sidewalkPhaseData = JSON.parse(JSON.stringify(curPedStatus))
512
- }
513
- },
514
- created () {
515
- this.load()
516
- },
517
- mounted () {
518
- this.getParentSize()
519
- },
520
- destroyed () {
521
- this.handleReset()
522
- }
523
- }
524
- </script>
525
-
526
- <style lang="css" rel="stylesheet/scss">
527
- .show-channelization {
528
- position: relative;
529
- overflow: hidden;
530
- }
531
- .widescreenCrossImg {
532
- zoom: 1.3;
533
- }
534
- .superlargeCrossImg {
535
- zoom: 1.1;
536
- }
537
- .largeCrossImg {
538
- zoom: 1.1;
539
- }
540
- .middleCrossImg {
541
- zoom: 1;
542
- }
543
- .middleCrossImg2 {
544
- zoom: 0.8;
545
- }
546
- .smallCrossImg {
547
- zoom: 0.8;
548
- }
549
- .smallCrossImg2 {
550
- zoom: 0.8;
551
- }
552
- .miniCrossImg {
553
- zoom: 0.7;
554
- }
555
- .superminiCrossImg {
556
- zoom: 0.6;
557
- }
558
- .minimumCrossImg {
559
- zoom: 0.35;
560
- }
561
- .transMiddleCrossImg {
562
- -webkit-transform-origin-y: 0;
563
- transform: scale(0.55);
564
- margin-top: 3%;
565
- padding: 0PX;
566
- }
567
- .transMiddleCrossImg2 {
568
- -webkit-transform-origin-y: 0;
569
- transform: scale(0.27);
570
- margin-top: -1.5%;
571
- padding: 0PX;
572
- }
573
- .transMiddleCrossImg3 {
574
- -webkit-transform-origin-y: 0;
575
- transform: scale(0.22);
576
- margin-top: -1%;
577
- padding: 0PX;
578
- }
579
- .transMiniCrossImg {
580
- -webkit-transform-origin-y: 0;
581
- transform: scale(0.18);
582
- margin-top: -1.6%;
583
- padding: 0PX;
584
- }
585
- </style>
1
+ /**
2
+ * Copyright (c) 2020 kedacom
3
+ * OpenATC is licensed under Mulan PSL v2.
4
+ * You can use this software according to the terms and conditions of the Mulan PSL v2.
5
+ * You may obtain a copy of Mulan PSL v2 at:
6
+ * http://license.coscl.org.cn/MulanPSL2
7
+ * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
8
+ * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
9
+ * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
10
+ * See the Mulan PSL v2 for more details.
11
+ **/
12
+ <!--静态渠化路口,需要传入路口状态数据和检测器状态数据-->
13
+ <template>
14
+ <div class="show-channelization channelization-base-map" :class="{
15
+ 'widescreenCrossImg': bodyDomWidth > 1680,
16
+ 'superlargeCrossImg': bodyDomWidth <= 1680 && bodyDomWidth > 1440,
17
+ 'largeCrossImg': bodyDomWidth <= 1440 && bodyDomWidth > 1280,
18
+ 'middleCrossImg2': bodyDomWidth <= 1280 && bodyDomWidth > 960,
19
+ 'smallCrossImg': bodyDomWidth <= 960 && bodyDomWidth > 890,
20
+ 'smallCrossImg2': bodyDomWidth <= 890 && bodyDomWidth > 720,
21
+ 'miniCrossImg': bodyDomWidth <= 720 && bodyDomWidth > 650,
22
+ 'superminiCrossImg': bodyDomWidth <= 650 && bodyDomWidth > 450,
23
+ 'transMiddleCrossImg': bodyDomWidth <= 450 && bodyDomWidth > 350,
24
+ 'transMiddleCrossImg2': bodyDomWidth <= 350 && bodyDomWidth > 300,
25
+ 'transMiddleCrossImg3': bodyDomWidth <= 300 && bodyDomWidth > 260,
26
+ 'transMiniCrossImg': bodyDomWidth <= 260,
27
+ 'changePaddingBottom': true }">
28
+ <ChannelizationElements
29
+ ref="channelizationElements"
30
+ UsageMode="show"
31
+ :allitem="allitem"
32
+ :CrossMapVisible="CrossMapVisible"
33
+ :CrossMapData="CrossMapData"
34
+ :isSeletable="isSeletable"
35
+ :Motorways="LanePhaseData"
36
+ :Pedwalk="sidewalkPhaseData"
37
+ :Countdown="Countdown"
38
+ :CountdownList="phaseCountdownList"
39
+ :Detector="DetectorData"
40
+ :isHasPhase="isHasPhase"
41
+ />
42
+ </div>
43
+ </template>
44
+
45
+ <script>
46
+ // import { mapState, mapGetters } from 'vuex'
47
+ import ChannelizationElements from '../DrawChannelization/drawsvg/channelizationElements'
48
+ // import { getIframdevid } from '../../../utils/auth.js'
49
+ import { getChannelizatonChart } from '../../../api/cross'
50
+
51
+ export default {
52
+ name: 'channelization',
53
+ components: {
54
+ ChannelizationElements
55
+ },
56
+ computed: {
57
+ // ...mapState({
58
+ // curOpenatcAgentid: state => state.globalParam.curOpenatcAgentid
59
+ // })
60
+ // ,
61
+ // ...mapGetters([
62
+ // 'isfromatc'
63
+ // ])
64
+ },
65
+ props: {
66
+ crossStatusData: {
67
+ type: Object
68
+ },
69
+ detectorStatusData: {
70
+ type: Object
71
+ },
72
+ AgentId: {
73
+ type: String,
74
+ default: '0'
75
+ }
76
+ },
77
+ watch: {
78
+ crossStatusData: {
79
+ handler: function (val) {
80
+ // 路口状态数据
81
+ this.statusData = JSON.parse(JSON.stringify(val))
82
+ this.phaseStatusList = val.phase
83
+ this.overlapStatusList = val.overlap
84
+ if (val.control === 1 || val.control === 2 || val.control === 3) {
85
+ // 黄闪、全红、关灯属于特殊控制,优先级最高,直接改变灯色,不用判断phase里的type,也不需要考虑跟随相位的灯色优先级
86
+ if (val.control === 1) {
87
+ this.getYellowFlashColor()
88
+ } else {
89
+ this.SpecialControl(val)
90
+ }
91
+ return
92
+ }
93
+ if (!val.phase && !this.overlapStatusList) {
94
+ // 非特殊控制,相位和跟随相位不存在的情况下,灯色恢复默认
95
+ this.handleSpecialControlStatus('默认')
96
+ return
97
+ }
98
+ this.curPhase = val.current_phase
99
+ this.isHasPhase = true
100
+ this.createPhaseStatusMap()
101
+ this.createOverlapPhaseStatusMap()
102
+ this.getLanePhaseStatusData()
103
+ this.getpedStatus()
104
+ this.getCurPhaseCountdown()
105
+ },
106
+ // 深度观察监听
107
+ deep: true
108
+ },
109
+ detectorStatusData: {
110
+ handler: function (detectorsStatus) {
111
+ // 检测器状态数据
112
+ this.detectorStatusList = detectorsStatus.detector
113
+ this.pedDetectorStatusList = detectorsStatus.io
114
+ this.createDetectorStatusMap()
115
+ this.getDetectorStatus()
116
+ },
117
+ deep: true
118
+ },
119
+ AgentId: {
120
+ handler: function (val) {
121
+ // 平台设备切换时,重载当前路口保存的渠化配置
122
+ this.load('all')
123
+ },
124
+ deep: true
125
+ }
126
+ },
127
+ data () {
128
+ return {
129
+ isSeletable: false,
130
+ bodyDomWidth: 352,
131
+ bodyDomSize: {
132
+ width: 1920,
133
+ height: 1080
134
+ },
135
+ CrossMapVisible: true, // 控制底图显示隐藏
136
+ CrossMapData: {
137
+ x: 400,
138
+ y: 100,
139
+ w: 800,
140
+ h: 200,
141
+ angle: 0,
142
+ svgstr: '',
143
+ imgfilesrc: ''
144
+ }, // 管理底图数据
145
+ Motorways: [],
146
+ Texts: [],
147
+ Pedwalk: [],
148
+ Countdown: [],
149
+ Detector: [],
150
+ allitem: {
151
+ x: 435,
152
+ y: 325,
153
+ w: 870,
154
+ h: 650,
155
+ angle: 0
156
+ },
157
+ LanePhaseData: [], // 车道相位数据
158
+ // overlapLanePhaseData: [], // 车道跟随相位数据
159
+ curPhase: [], // 当前相位列表
160
+ phaseStatusList: [], // 相位状态列表
161
+ phaseStatusMap: new Map(), // 相位状态映射
162
+ phaseCountdownList: [], // 相位倒计时列表
163
+ overlapPhaseStatusMap: new Map(), // 跟随相位状态映射
164
+ ColorMap: new Map([[0, '#828282'], [1, '#ff2828'], [2, '#f7b500'], [3, '#77fb65'], [4, '#77fb65'], [5, '#f7b500']]), // 当前相位状态 --- 0:关灯, 1:红, 2:黄, 3:绿, 4:绿闪, 5:黄闪
165
+ SidewalkColorMap: new Map([[0, '#828282'], [1, '#e24b4b'], [3, '#7bd66b']]),
166
+ phaseControlColorMap: new Map([['黄闪', '#f7b500'], ['全红', '#ff2828'], ['关灯', '#828282'], ['默认', '#fff']]),
167
+ sidewalkPhaseData: [], // 行人相位
168
+ isHasPhase: true, // 是否有相位状态数据
169
+
170
+ detectorStatusList: [], // 车辆检测器状态列表
171
+ pedDetectorStatusList: [], // 行人检测器状态列表
172
+ detectorStatusMap: new Map(), // 车辆检测器状态映射
173
+ pedDetectorStatusMap: new Map(), // 行人检测器状态映射
174
+ DetectorData: [], // 检测器数据(包括车辆和行人)
175
+ DetectorColorMap: new Map([[0, 'transparent'], [1, '#00CCFF'], [2, '#FF0000']]) // 检测器状态填充颜色定义 0: 低电平 无车, 1: 高电平 有车, 2: 故障
176
+ }
177
+ },
178
+ methods: {
179
+ createPhaseStatusMap () {
180
+ // 生成相位id和相位状态对应数据结构
181
+ this.phaseStatusList.map(phase => {
182
+ let phaseId = phase.id
183
+ let phaseInfo = {
184
+ type: phase.type,
185
+ phaseCountdown: phase.countdown,
186
+ pedtype: phase.pedtype
187
+ }
188
+ this.phaseStatusMap.set(phaseId, phaseInfo)
189
+ })
190
+ },
191
+ createOverlapPhaseStatusMap () {
192
+ if (this.overlapStatusList) {
193
+ this.overlapStatusList.map(phase => {
194
+ let phaseId = phase.id
195
+ let phaseInfo = {
196
+ type: phase.type,
197
+ phaseCountdown: phase.countdown,
198
+ pedtype: phase.pedtype
199
+ }
200
+ this.overlapPhaseStatusMap.set(phaseId, phaseInfo)
201
+ })
202
+ }
203
+ },
204
+ getLanePhaseStatusData () {
205
+ let curLanePhaseData = []
206
+ for (let i = 0; i < this.LanePhaseData.length; i++) {
207
+ let curPhaseStatus
208
+ if (this.LanePhaseData[i].phasetype === 'phase') {
209
+ curPhaseStatus = this.phaseStatusMap.get(this.LanePhaseData[i].phaseid)
210
+ }
211
+ if (this.LanePhaseData[i].phasetype === 'overlap') {
212
+ curPhaseStatus = this.overlapPhaseStatusMap.get(this.LanePhaseData[i].phaseid)
213
+ }
214
+ // if (!curPhaseStatus) continue // 没有关联相位的车道不显示
215
+ let data
216
+ if (curPhaseStatus) {
217
+ data = {
218
+ ...this.LanePhaseData[i],
219
+ type: curPhaseStatus.type,
220
+ color: this.ColorMap.get(curPhaseStatus.type),
221
+ phaseCountdown: curPhaseStatus.phaseCountdown,
222
+ flag: 'phase' // 车道相位数据标识
223
+ }
224
+ } else {
225
+ // 没有关联的,或者没有对应状态的,车道显示默认白色
226
+ data = {
227
+ ...this.LanePhaseData[i],
228
+ type: undefined,
229
+ color: '#fff',
230
+ flag: 'phase' // 车道相位数据标识
231
+ }
232
+ }
233
+ curLanePhaseData.push(data)
234
+ }
235
+ this.LanePhaseData = JSON.parse(JSON.stringify(curLanePhaseData))
236
+ // console.log(this.LanePhaseData)
237
+ },
238
+ getpedStatus () {
239
+ // 行人相位状态
240
+ let curPedStatus = []
241
+ for (let i = 0; i < this.sidewalkPhaseData.length; i++) {
242
+ let curPhaseStatus
243
+ if (this.sidewalkPhaseData[i].phasetype === 'phase') {
244
+ curPhaseStatus = this.phaseStatusMap.get(this.sidewalkPhaseData[i].phaseid)
245
+ }
246
+ if (this.sidewalkPhaseData[i].phasetype === 'overlap') {
247
+ curPhaseStatus = this.overlapPhaseStatusMap.get(this.sidewalkPhaseData[i].phaseid)
248
+ }
249
+ // if (!curPhaseStatus) continue
250
+ let data
251
+ if (curPhaseStatus) {
252
+ data = {
253
+ ...this.sidewalkPhaseData[i],
254
+ pedtype: curPhaseStatus.pedtype,
255
+ color: this.SidewalkColorMap.get(curPhaseStatus.pedtype),
256
+ flag: 'ped' // 行人相位数据标识
257
+ }
258
+ } else {
259
+ // 接口没有对应的状态
260
+ data = {
261
+ ...this.sidewalkPhaseData[i],
262
+ pedtype: undefined,
263
+ color: '#fff',
264
+ flag: 'ped' // 行人相位数据标识
265
+ }
266
+ }
267
+ curPedStatus.push(data)
268
+ }
269
+ this.sidewalkPhaseData = JSON.parse(JSON.stringify(curPedStatus))
270
+ // this.Pedwalk = JSON.parse(JSON.stringify(this.sidewalkPhaseData))
271
+ },
272
+ getCurPhaseCountdown () {
273
+ // 获取当前相位倒计时颜色
274
+ let phaseCountdownList = []
275
+ this.curPhase.forEach(curP => {
276
+ this.phaseStatusList.forEach(phaseInfo => {
277
+ if (phaseInfo.id === curP) {
278
+ let countdownObj = {}
279
+ countdownObj.id = phaseInfo.id
280
+ countdownObj.phaseCountdown = phaseInfo.countdown
281
+ countdownObj.phaseCountdownColor = this.ColorMap.get(phaseInfo.type)
282
+ phaseCountdownList.push(countdownObj)
283
+ }
284
+ })
285
+ })
286
+ this.phaseCountdownList = JSON.parse(JSON.stringify(phaseCountdownList))
287
+ // console.log(this.phaseCountdownList)
288
+ },
289
+ // 加载
290
+ load (type) {
291
+ this.getChannelizatonChart().then((channelizatondata) => {
292
+ let savedTemp = JSON.parse(JSON.stringify(channelizatondata))
293
+ for (const [key, value] of Object.entries(savedTemp)) {
294
+ if (key === 'vehile') {
295
+ this.Motorways = value
296
+ }
297
+ if (key === 'text') {
298
+ this.Texts = value
299
+ }
300
+ if (key === 'ped') {
301
+ this.Pedwalk = value
302
+ }
303
+ if (key === 'countdown') {
304
+ this.Countdown = value
305
+ }
306
+ if (key === 'detector') {
307
+ this.Detector = value.filter(ele => ele.detailtype === 'detector')
308
+ }
309
+ if (key === 'crossMap') {
310
+ this.CrossMapData = JSON.parse(JSON.stringify(value))
311
+ }
312
+ }
313
+ this.isSeletable = false
314
+ // 从接口得到所有渠化车道和人行道数据
315
+ this.LanePhaseData = JSON.parse(JSON.stringify(this.Motorways))
316
+ this.sidewalkPhaseData = JSON.parse(JSON.stringify(this.Pedwalk))
317
+ this.DetectorData = JSON.parse(JSON.stringify(this.Detector))
318
+ })
319
+ },
320
+ // 重置
321
+ handleReset () {
322
+ this.Texts = []
323
+ this.Motorways = []
324
+ this.Countdown = []
325
+ this.phaseCountdownList = []
326
+ this.Pedwalk = []
327
+ this.Detector = []
328
+ this.CrossMapData = {
329
+ x: 400,
330
+ y: 100,
331
+ w: 800,
332
+ h: 200,
333
+ angle: 0,
334
+ svgstr: '',
335
+ imgfilesrc: ''
336
+ }
337
+ this.LanePhaseData = []
338
+ this.sidewalkPhaseData = []
339
+ this.DetectorData = []
340
+ this.isHasPhase = true
341
+ },
342
+ getChannelizatonChart () {
343
+ // let agentid = getIframdevid()
344
+ // 路口已设置渠化,则总览默认显示渠化路口,未设置显示模版路口
345
+ // if (this.isfromatc === true) {
346
+ // this.$store.dispatch('SetShowHomePage', 'Graphical')
347
+ // }
348
+ this.handleReset()
349
+ return new Promise((resolve, reject) => {
350
+ getChannelizatonChart(this.AgentId).then(data => {
351
+ // this.$emit('getChannelizationSetting', data)
352
+ if (!data.data.success) {
353
+ // let parrenterror = getMessageByCode(data.data.code, this.$i18n.locale)
354
+ // if (data.data.data) {
355
+ // // 子类型错误
356
+ // let childErrorCode = data.data.data.errorCode
357
+ // if (childErrorCode) {
358
+ // let childerror = getMessageByCode(data.data.data.errorCode, this.$i18n.locale)
359
+ // this.$message.error(parrenterror + ',' + childerror)
360
+ // }
361
+ // } else {
362
+ // this.$message.error(parrenterror)
363
+ // }
364
+ return
365
+ }
366
+ if (data.data.data === undefined || JSON.stringify(data.data.data) === '{}') return
367
+ // if (this.isfromatc === true) {
368
+ // this.$store.dispatch('SetShowHomePage', 'Channelization')
369
+ // }
370
+ this.handleReset()
371
+ let channelizatondata = data.data.data
372
+ resolve(channelizatondata)
373
+ })
374
+ })
375
+ },
376
+ SpecialControl (data) {
377
+ switch (data.control) {
378
+ case 1: this.handleSpecialControlStatus('黄闪')
379
+ break
380
+ case 2: this.handleSpecialControlStatus('全红')
381
+ break
382
+ case 3: this.handleSpecialControlStatus('关灯')
383
+ break
384
+ default: this.handleSpecialControlStatus('默认')
385
+ }
386
+ },
387
+ handleSpecialControlStatus (Control) {
388
+ this.$refs.channelizationElements.resetPhaseStatus()
389
+ // 控制黄闪、全红、关灯、默认情况下的车道相位颜色和倒计时颜色
390
+ if (Control === '默认') {
391
+ // 倒计时恢复默认颜色
392
+ this.phaseCountdownList.forEach(item => {
393
+ item.phaseCountdown = ''
394
+ item.id = ''
395
+ item.phaseCountdownColor = '#fff'
396
+ })
397
+ }
398
+ if (this.LanePhaseData.length) {
399
+ const LanePhaseData = this.LanePhaseData.map(data => ({
400
+ ...data,
401
+ color: this.phaseControlColorMap.get(Control)
402
+ }))
403
+ this.LanePhaseData = JSON.parse(JSON.stringify(LanePhaseData))
404
+ }
405
+ if (this.sidewalkPhaseData.length) {
406
+ const sidewalkPhaseData = this.sidewalkPhaseData.map(data => ({
407
+ ...data,
408
+ color: this.phaseControlColorMap.get(Control)
409
+ }))
410
+ this.sidewalkPhaseData = JSON.parse(JSON.stringify(sidewalkPhaseData))
411
+ }
412
+ this.isHasPhase = false
413
+ },
414
+ createDetectorStatusMap () {
415
+ this.detectorStatusMap = new Map()
416
+ if (this.detectorStatusList) {
417
+ this.detectorStatusList.map(detector => {
418
+ let detectorId = detector.id
419
+ let detectorInfo = {
420
+ state: detector.state
421
+ }
422
+ this.detectorStatusMap.set(detectorId, detectorInfo)
423
+ })
424
+ }
425
+ if (this.pedDetectorStatusList) {
426
+ this.pedDetectorStatusList.map(peddetector => {
427
+ let peddetectorId = peddetector.id
428
+ let peddetectorInfo = {
429
+ state: peddetector.state
430
+ }
431
+ this.pedDetectorStatusMap.set(peddetectorId, peddetectorInfo)
432
+ })
433
+ }
434
+ // console.log(this.detectorStatusMap)
435
+ // console.log(this.pedDetectorStatusMap)
436
+ },
437
+ getDetectorStatus () {
438
+ let curDetectorData = []
439
+ for (let i = 0; i < this.DetectorData.length; i++) {
440
+ let curDetectorStatus
441
+ let curDetectortype = this.DetectorData[i].detectortype
442
+ if (curDetectortype === 1) {
443
+ // 车辆检测器
444
+ curDetectorStatus = this.detectorStatusMap.get(this.DetectorData[i].detectorid)
445
+ }
446
+ if (curDetectortype === 2) {
447
+ // 行人检测器
448
+ curDetectorStatus = this.pedDetectorStatusMap.get(this.DetectorData[i].detectorid)
449
+ }
450
+ // if (!curDetectorStatus) continue // 没有关联检测器不显示
451
+ let data
452
+ if (curDetectorStatus) {
453
+ data = {
454
+ ...this.DetectorData[i],
455
+ state: curDetectorStatus.state,
456
+ fillcolor: this.DetectorColorMap.get(curDetectorStatus.state),
457
+ flag: curDetectortype === 1 ? 'detector' : 'peddetector' // 车道相位数据标识
458
+ }
459
+ } else {
460
+ // 没有关联检测器的填充透明
461
+ data = {
462
+ ...this.DetectorData[i],
463
+ state: undefined,
464
+ fillcolor: 'transparent',
465
+ flag: curDetectortype === 1 ? 'detector' : 'peddetector' // 车道相位数据标识
466
+ }
467
+ }
468
+ curDetectorData.push(data)
469
+ }
470
+ this.DetectorData = JSON.parse(JSON.stringify(curDetectorData))
471
+ },
472
+ getParentSize () {
473
+ // 获取最外层dom尺寸,适配准备
474
+ var _this = this
475
+ this.$nextTick(function () {
476
+ if (this.$el.parentElement === null || this.$el.parentElement === undefined) return
477
+ this.bodyDomSize.width = this.$el.parentElement.clientWidth
478
+ this.bodyDomWidth = this.bodyDomSize.width
479
+ window.addEventListener('resize', () => {
480
+ // 定义窗口大小变更通知事件
481
+ if (_this.$el.parentElement === null || _this.$el.parentElement === undefined) return
482
+ _this.bodyDomSize.width = _this.$el.parentElement.clientWidth
483
+ this.bodyDomWidth = this.bodyDomSize.width
484
+ console.log('resize this.bodyDomSize.width', _this.bodyDomSize.width)
485
+ }, false)
486
+ })
487
+ },
488
+ getYellowFlashColor () {
489
+ // 渠化车道相位
490
+ let curLanePhaseData = []
491
+ for (let i = 0; i < this.LanePhaseData.length; i++) {
492
+ const data = {
493
+ ...this.LanePhaseData[i],
494
+ type: '黄闪',
495
+ control: 1
496
+ }
497
+ curLanePhaseData.push(data)
498
+ }
499
+ this.LanePhaseData = JSON.parse(JSON.stringify(curLanePhaseData))
500
+
501
+ // 渠化行人相位
502
+ let curPedStatus = []
503
+ for (let i = 0; i < this.sidewalkPhaseData.length; i++) {
504
+ const data = {
505
+ ...this.sidewalkPhaseData[i],
506
+ pedtype: '黄闪',
507
+ control: 1
508
+ }
509
+ curPedStatus.push(data)
510
+ }
511
+ this.sidewalkPhaseData = JSON.parse(JSON.stringify(curPedStatus))
512
+ }
513
+ },
514
+ created () {
515
+ this.load()
516
+ },
517
+ mounted () {
518
+ this.getParentSize()
519
+ },
520
+ destroyed () {
521
+ this.handleReset()
522
+ }
523
+ }
524
+ </script>
525
+
526
+ <style lang="css" rel="stylesheet/scss">
527
+ .show-channelization {
528
+ position: relative;
529
+ overflow: hidden;
530
+ }
531
+ .widescreenCrossImg {
532
+ zoom: 1.3;
533
+ }
534
+ .superlargeCrossImg {
535
+ zoom: 1.1;
536
+ }
537
+ .largeCrossImg {
538
+ zoom: 1.1;
539
+ }
540
+ .middleCrossImg {
541
+ zoom: 1;
542
+ }
543
+ .middleCrossImg2 {
544
+ zoom: 0.8;
545
+ }
546
+ .smallCrossImg {
547
+ zoom: 0.8;
548
+ }
549
+ .smallCrossImg2 {
550
+ zoom: 0.8;
551
+ }
552
+ .miniCrossImg {
553
+ zoom: 0.7;
554
+ }
555
+ .superminiCrossImg {
556
+ zoom: 0.6;
557
+ }
558
+ .minimumCrossImg {
559
+ zoom: 0.35;
560
+ }
561
+ .transMiddleCrossImg {
562
+ -webkit-transform-origin-y: 0;
563
+ transform: scale(0.55);
564
+ margin-top: 3%;
565
+ padding: 0PX;
566
+ }
567
+ .transMiddleCrossImg2 {
568
+ -webkit-transform-origin-y: 0;
569
+ transform: scale(0.27);
570
+ margin-top: -1.5%;
571
+ padding: 0PX;
572
+ }
573
+ .transMiddleCrossImg3 {
574
+ -webkit-transform-origin-y: 0;
575
+ transform: scale(0.22);
576
+ margin-top: -1%;
577
+ padding: 0PX;
578
+ }
579
+ .transMiniCrossImg {
580
+ -webkit-transform-origin-y: 0;
581
+ transform: scale(0.18);
582
+ margin-top: -1.6%;
583
+ padding: 0PX;
584
+ }
585
+ </style>