openatc-components 0.0.88 → 0.0.89

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