openatc-components 0.3.71 → 0.3.72

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 (499) 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 +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 +93 -93
  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 +117 -117
  23. package/package/kisscomps/components/BoardCard/index.js +2 -2
  24. package/package/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +123 -123
  25. package/package/kisscomps/components/ChannelRealtimeIntersection/index.js +2 -2
  26. package/package/kisscomps/components/Channelization/Channelization.vue +584 -584
  27. package/package/kisscomps/components/Channelization/index.js +2 -2
  28. package/package/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  29. package/package/kisscomps/components/ChannelizationFlowStatistic/index.js +2 -2
  30. package/package/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  31. package/package/kisscomps/components/ChannelizationWithInterface/index.js +2 -2
  32. package/package/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  33. package/package/kisscomps/components/CommonKanban/index.js +2 -2
  34. package/package/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +454 -454
  35. package/package/kisscomps/components/DirectionListConfiguration/index.js +2 -2
  36. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  37. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  38. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  39. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  40. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  41. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  42. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  43. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  44. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  45. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  46. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  47. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  48. package/package/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  49. package/package/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  50. package/package/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  51. package/package/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  52. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  53. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  54. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  55. package/package/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  56. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  57. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  58. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  59. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  60. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +368 -368
  61. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  62. package/package/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  63. package/package/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +1005 -1005
  64. package/package/kisscomps/components/DrawChannelization/drawsvg/index.vue +110 -110
  65. package/package/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  66. package/package/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  67. package/package/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +172 -172
  68. package/package/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  69. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  70. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  71. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  72. package/package/kisscomps/components/DrawChannelization/index.js +2 -2
  73. package/package/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  74. package/package/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  75. package/package/kisscomps/components/ExpendConfig/index.js +2 -2
  76. package/package/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  77. package/package/kisscomps/components/FaultDetailModal/index.js +2 -2
  78. package/package/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +158 -158
  79. package/package/kisscomps/components/IntersectionDirectionSelection/index.js +2 -2
  80. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  81. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  82. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  83. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  84. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  85. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  86. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  87. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  88. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +1302 -1302
  89. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  90. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  91. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  92. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  93. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  94. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  95. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  96. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  97. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  98. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  99. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  100. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  101. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  102. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  103. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  104. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  105. package/package/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +1372 -1372
  106. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  107. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +196 -196
  108. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  109. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  110. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  111. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +115 -115
  112. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  113. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  114. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +219 -219
  115. package/package/kisscomps/components/IntersectionMap/crossDirection/utils.js +84 -84
  116. package/package/kisscomps/components/IntersectionMap/index.js +2 -2
  117. package/package/kisscomps/components/IntersectionMap/intersectionmap.vue +211 -216
  118. package/package/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +530 -530
  119. package/package/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  120. package/package/kisscomps/components/KanBan/index.js +2 -2
  121. package/package/kisscomps/components/KanBan/kanban.vue +231 -231
  122. package/package/kisscomps/components/MessageBox/index.vue +96 -96
  123. package/package/kisscomps/components/OverLap/OverLap.vue +237 -237
  124. package/package/kisscomps/components/OverLap/index.js +2 -2
  125. package/package/kisscomps/components/PatternOptimize/PatternOptimize.vue +272 -272
  126. package/package/kisscomps/components/PatternOptimize/index.js +2 -2
  127. package/package/kisscomps/components/PatternStatus/PatternStatus.vue +1649 -1649
  128. package/package/kisscomps/components/PatternStatus/index.js +2 -2
  129. package/package/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  130. package/package/kisscomps/components/PatternWalkSvg/index.js +2 -2
  131. package/package/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  132. package/package/kisscomps/components/PhaseDirectionSelect/index.js +2 -2
  133. package/package/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  134. package/package/kisscomps/components/PhaseDirectionText/index.js +2 -2
  135. package/package/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  136. package/package/kisscomps/components/PhaseLegend/index.js +2 -2
  137. package/package/kisscomps/components/PhaseMarker/index.js +6 -6
  138. package/package/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  139. package/package/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  140. package/package/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  141. package/package/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  142. package/package/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  143. package/package/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  144. package/package/kisscomps/components/PhasePedSelect/index.js +2 -2
  145. package/package/kisscomps/components/PhasePedSelect/index.vue +206 -206
  146. package/package/kisscomps/components/SchemeConfig/SchemeConfig.vue +950 -967
  147. package/package/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +364 -364
  148. package/package/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  149. package/package/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  150. package/package/kisscomps/components/SchemeConfig/index.js +2 -2
  151. package/package/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +235 -235
  152. package/package/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  153. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +128 -128
  154. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/icon.vue +438 -438
  155. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +861 -861
  156. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  157. package/package/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  158. package/package/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  159. package/package/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +283 -303
  160. package/package/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +1207 -1207
  161. package/package/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  162. package/package/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  163. package/package/kisscomps/components/StageBord/StageBord.vue +303 -303
  164. package/package/kisscomps/components/StageBord/index.js +2 -2
  165. package/package/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  166. package/package/kisscomps/components/StageStatus/index.js +2 -2
  167. package/package/kisscomps/components/Stages/index.vue +319 -319
  168. package/package/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  169. package/package/kisscomps/components/SvgIcon/index.js +2 -2
  170. package/package/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  171. package/package/kisscomps/components/XRDDirSelector/index.js +2 -2
  172. package/package/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  173. package/package/kisscomps/components/XiaoKanban/index.vue +122 -122
  174. package/package/kisscomps/components/overView/index.vue +699 -699
  175. package/package/kisscomps/components/patternConfig/index.js +2 -2
  176. package/package/kisscomps/components/patternConfig/index.vue +798 -788
  177. package/package/kisscomps/components/patternConfig/pattern/patternTable.vue +579 -588
  178. package/package/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  179. package/package/kisscomps/components/patternConfig/planContent.vue +604 -573
  180. package/package/kisscomps/components/patternConfig/planMenu.vue +329 -329
  181. package/package/kisscomps/components/patternConfig/utils.js +152 -152
  182. package/package/kisscomps/components/patternList/index.js +2 -2
  183. package/package/kisscomps/components/patternList/patternList.vue +590 -590
  184. package/package/kisscomps/index.js +127 -129
  185. package/package/kissui.js +216608 -0
  186. package/package/kissui.min.js +1 -1
  187. package/package.json +126 -126
  188. package/src/App.vue +24 -24
  189. package/src/EdgeMgr/EdgeModelBase.js +16 -16
  190. package/src/EdgeMgr/controller/crossDiagramMgr.js +125 -125
  191. package/src/api/authapi.js +31 -31
  192. package/src/api/config.js +21 -21
  193. package/src/api/control.js +110 -110
  194. package/src/api/cross.js +49 -49
  195. package/src/api/device.js +135 -135
  196. package/src/api/fault.js +66 -66
  197. package/src/api/index.js +24 -24
  198. package/src/api/login.js +46 -46
  199. package/src/api/optimize.js +72 -72
  200. package/src/api/param.js +165 -165
  201. package/src/api/passwdAssest.js +101 -101
  202. package/src/api/route.js +171 -171
  203. package/src/api/template.js +27 -27
  204. package/src/assets/font/LICENSE.txt +202 -202
  205. package/src/assets/font/font.css +6 -6
  206. package/src/i18n/index.js +26 -26
  207. package/src/i18n/language/en.js +1458 -1465
  208. package/src/i18n/language/index.js +25 -25
  209. package/src/i18n/language/zh.js +1458 -1465
  210. package/src/icons/demo_index.html +8445 -8445
  211. package/src/icons/iconfont.css +1451 -1451
  212. package/src/icons/iconfont.json +2522 -2522
  213. package/src/icons/index.js +20 -20
  214. package/src/icons/svg/azimuthlocking.svg +26 -26
  215. package/src/icons/svg/bendi.svg +110 -110
  216. package/src/icons/svg/bujin.svg +36 -36
  217. package/src/icons/svg/connectBlue.svg +7 -7
  218. package/src/icons/svg/currentvolume.svg +0 -0
  219. package/src/icons/svg/custom-BRTlane.svg +40 -40
  220. package/src/icons/svg/custom-buslane.svg +40 -40
  221. package/src/icons/svg/custom-detector.svg +12 -12
  222. package/src/icons/svg/custom-east-bottom.svg +32 -32
  223. package/src/icons/svg/custom-east-top.svg +32 -32
  224. package/src/icons/svg/custom-ewped.svg +35 -35
  225. package/src/icons/svg/custom-nonmotorizedlane.svg +40 -40
  226. package/src/icons/svg/custom-north-left.svg +32 -32
  227. package/src/icons/svg/custom-north-right.svg +32 -32
  228. package/src/icons/svg/custom-peddetector.svg +17 -17
  229. package/src/icons/svg/custom-snped.svg +35 -35
  230. package/src/icons/svg/custom-south-left.svg +32 -32
  231. package/src/icons/svg/custom-south-right.svg +32 -32
  232. package/src/icons/svg/custom-tramlane.svg +40 -40
  233. package/src/icons/svg/custom-vehiclebranch.svg +40 -40
  234. package/src/icons/svg/custom-vehiclemainroad.svg +41 -41
  235. package/src/icons/svg/custom-west-bottom.svg +32 -32
  236. package/src/icons/svg/custom-west-top.svg +32 -32
  237. package/src/icons/svg/custom-xlped.svg +14 -14
  238. package/src/icons/svg/custom-xrped.svg +14 -14
  239. package/src/icons/svg/cutRed.svg +7 -7
  240. package/src/icons/svg/cycle.svg +0 -0
  241. package/src/icons/svg/dingzhouqi.svg +34 -34
  242. package/src/icons/svg/ganyingkongzhi.svg +30 -30
  243. package/src/icons/svg/guandeng.svg +81 -81
  244. package/src/icons/svg/huangshan.svg +71 -71
  245. package/src/icons/svg/maincontrol.svg +0 -0
  246. package/src/icons/svg/manualcontrolbackground.svg +51 -51
  247. package/src/icons/svg/manualcontrolbackground1.svg +62 -62
  248. package/src/icons/svg/manualcontrolbackgrounden.svg +62 -62
  249. package/src/icons/svg/model.svg +0 -0
  250. package/src/icons/svg/phasediff.svg +0 -0
  251. package/src/icons/svg/prioritycontrol.svg +21 -21
  252. package/src/icons/svg/quanhong.svg +86 -86
  253. package/src/icons/svg/shanghe.svg +11 -11
  254. package/src/icons/svg/shoudong.svg +103 -103
  255. package/src/icons/svg/tentativeplan.svg +28 -28
  256. package/src/icons/svg/time.svg +0 -0
  257. package/src/icons/svg/wuxianlan.svg +46 -46
  258. package/src/icons/svg/xiala.svg +11 -11
  259. package/src/icons/svg/xingrenguojie.svg +33 -33
  260. package/src/icons/svg/xitong.svg +89 -89
  261. package/src/icons/svg/youxian.svg +41 -41
  262. package/src/icons/svg/zizhukongzhi.svg +43 -43
  263. package/src/kisscomps/components/BoardCard/BoardCard.vue +117 -117
  264. package/src/kisscomps/components/BoardCard/index.js +2 -2
  265. package/src/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +123 -123
  266. package/src/kisscomps/components/ChannelRealtimeIntersection/index.js +2 -2
  267. package/src/kisscomps/components/Channelization/Channelization.vue +584 -584
  268. package/src/kisscomps/components/Channelization/index.js +2 -2
  269. package/src/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  270. package/src/kisscomps/components/ChannelizationFlowStatistic/index.js +2 -2
  271. package/src/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  272. package/src/kisscomps/components/ChannelizationWithInterface/index.js +2 -2
  273. package/src/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  274. package/src/kisscomps/components/CommonKanban/index.js +2 -2
  275. package/src/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +454 -454
  276. package/src/kisscomps/components/DirectionListConfiguration/index.js +2 -2
  277. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  278. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  279. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  280. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  281. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  282. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  283. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  284. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  285. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  286. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  287. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  288. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  289. package/src/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  290. package/src/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  291. package/src/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  292. package/src/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  293. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  294. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  295. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  296. package/src/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  297. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  298. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  299. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  300. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  301. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +368 -368
  302. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  303. package/src/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  304. package/src/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +1005 -1005
  305. package/src/kisscomps/components/DrawChannelization/drawsvg/index.vue +110 -110
  306. package/src/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  307. package/src/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  308. package/src/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +172 -172
  309. package/src/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  310. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  311. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  312. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  313. package/src/kisscomps/components/DrawChannelization/index.js +2 -2
  314. package/src/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  315. package/src/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  316. package/src/kisscomps/components/ExpendConfig/index.js +2 -2
  317. package/src/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  318. package/src/kisscomps/components/FaultDetailModal/index.js +2 -2
  319. package/src/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +158 -158
  320. package/src/kisscomps/components/IntersectionDirectionSelection/index.js +2 -2
  321. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  322. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  323. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  324. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  325. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  326. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  327. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  328. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  329. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +1302 -1302
  330. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  331. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  332. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  333. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  334. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  335. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  336. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  337. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  338. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  339. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  340. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  341. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  342. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  343. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  344. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  345. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  346. package/src/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +1372 -1372
  347. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  348. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +196 -196
  349. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  350. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  351. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  352. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +115 -115
  353. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  354. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  355. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +219 -219
  356. package/src/kisscomps/components/IntersectionMap/crossDirection/utils.js +84 -84
  357. package/src/kisscomps/components/IntersectionMap/index.js +2 -2
  358. package/src/kisscomps/components/IntersectionMap/intersectionmap.vue +211 -216
  359. package/src/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +530 -530
  360. package/src/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  361. package/src/kisscomps/components/KanBan/index.js +2 -2
  362. package/src/kisscomps/components/KanBan/kanban.vue +231 -231
  363. package/src/kisscomps/components/MessageBox/index.vue +96 -96
  364. package/src/kisscomps/components/OverLap/OverLap.vue +237 -237
  365. package/src/kisscomps/components/OverLap/index.js +2 -2
  366. package/src/kisscomps/components/PatternOptimize/PatternOptimize.vue +272 -272
  367. package/src/kisscomps/components/PatternOptimize/index.js +2 -2
  368. package/src/kisscomps/components/PatternStatus/PatternStatus.vue +1649 -1649
  369. package/src/kisscomps/components/PatternStatus/index.js +2 -2
  370. package/src/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  371. package/src/kisscomps/components/PatternWalkSvg/index.js +2 -2
  372. package/src/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  373. package/src/kisscomps/components/PhaseDirectionSelect/index.js +2 -2
  374. package/src/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  375. package/src/kisscomps/components/PhaseDirectionText/index.js +2 -2
  376. package/src/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  377. package/src/kisscomps/components/PhaseLegend/index.js +2 -2
  378. package/src/kisscomps/components/PhaseMarker/index.js +6 -6
  379. package/src/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  380. package/src/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  381. package/src/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  382. package/src/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  383. package/src/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  384. package/src/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  385. package/src/kisscomps/components/PhasePedSelect/index.js +2 -2
  386. package/src/kisscomps/components/PhasePedSelect/index.vue +206 -206
  387. package/src/kisscomps/components/SchemeConfig/SchemeConfig.vue +950 -967
  388. package/src/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +364 -364
  389. package/src/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  390. package/src/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  391. package/src/kisscomps/components/SchemeConfig/index.js +2 -2
  392. package/src/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +235 -235
  393. package/src/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  394. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +128 -128
  395. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/icon.vue +438 -438
  396. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +861 -861
  397. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  398. package/src/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  399. package/src/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  400. package/src/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +283 -303
  401. package/src/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +1207 -1207
  402. package/src/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  403. package/src/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  404. package/src/kisscomps/components/StageBord/StageBord.vue +303 -303
  405. package/src/kisscomps/components/StageBord/index.js +2 -2
  406. package/src/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  407. package/src/kisscomps/components/StageStatus/index.js +2 -2
  408. package/src/kisscomps/components/Stages/index.vue +319 -319
  409. package/src/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  410. package/src/kisscomps/components/SvgIcon/index.js +2 -2
  411. package/src/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  412. package/src/kisscomps/components/XRDDirSelector/index.js +2 -2
  413. package/src/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  414. package/src/kisscomps/components/XiaoKanban/index.vue +122 -122
  415. package/src/kisscomps/components/overView/index.vue +699 -699
  416. package/src/kisscomps/components/patternConfig/index.js +2 -2
  417. package/src/kisscomps/components/patternConfig/index.vue +798 -788
  418. package/src/kisscomps/components/patternConfig/pattern/patternTable.vue +579 -588
  419. package/src/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  420. package/src/kisscomps/components/patternConfig/planContent.vue +604 -573
  421. package/src/kisscomps/components/patternConfig/planMenu.vue +329 -329
  422. package/src/kisscomps/components/patternConfig/utils.js +152 -152
  423. package/src/kisscomps/components/patternList/index.js +2 -2
  424. package/src/kisscomps/components/patternList/patternList.vue +590 -590
  425. package/src/kisscomps/index.js +127 -129
  426. package/src/lib/publicjs/ArryListUtil.js +38 -38
  427. package/src/lib/publicjs/HttpurlMgr.js +45 -45
  428. package/src/lib/publicjs/KissApi.js +158 -158
  429. package/src/lib/publicjs/KissWSSub/Heartcheck.js +128 -128
  430. package/src/lib/publicjs/KissWSSub/KissWsSub.js +91 -91
  431. package/src/lib/publicjs/KissWSSub/KissWsSubByType.js +152 -152
  432. package/src/lib/publicjs/KissWSSub/SimuWsSubByType.js +44 -44
  433. package/src/lib/publicjs/KissWSSub/Sub.js +51 -51
  434. package/src/lib/publicjs/KissWSSub/SubChannel.js +119 -119
  435. package/src/lib/publicjs/basecomponents.js +65 -65
  436. package/src/lib/publicjs/localStorage.js +112 -112
  437. package/src/lib/publicjs/objdeepcopy.js +32 -32
  438. package/src/lib/publicjs/pageScroll.js +30 -30
  439. package/src/lib/publicjs/passwdAssest.js +101 -101
  440. package/src/lib/publicjs/styleclassfactory.js +32 -32
  441. package/src/main.js +51 -51
  442. package/src/router/index.js +63 -63
  443. package/src/store/getters.js +16 -16
  444. package/src/store/index.js +26 -26
  445. package/src/store/modules/globalParam.js +67 -67
  446. package/src/utils/ControlFormat.js +68 -68
  447. package/src/utils/RingDataModel.js +331 -331
  448. package/src/utils/auth.js +199 -199
  449. package/src/utils/conflct.js +259 -259
  450. package/src/utils/conflictList.js +87 -87
  451. package/src/utils/dateFormat.js +41 -41
  452. package/src/utils/errorcode.js +227 -227
  453. package/src/utils/fault.js +196 -196
  454. package/src/utils/faultcode.js +209 -209
  455. package/src/utils/index.js +69 -69
  456. package/src/utils/pedphasedesc.js +119 -119
  457. package/src/utils/phaseList.js +203 -203
  458. package/src/utils/phasedesc.js +144 -144
  459. package/src/utils/responseMessage.js +21 -21
  460. package/src/utils/validate.js +43 -43
  461. package/src/views/customchannelization.vue +49 -49
  462. package/src/views/home.1.vue +479 -479
  463. package/src/views/home.vue +93 -93
  464. package/src/views/intersection.vue +521 -521
  465. package/src/views/intersection2.vue +328 -328
  466. package/src/views/overView.vue +41 -54
  467. package/src/views/patternConfig.vue +14762 -408
  468. package/src/views/schemeconfig.vue +208 -208
  469. package/static/apiconfig.json +451 -451
  470. package/static/styles/channelizatioon.scss +433 -433
  471. package/static/styles/common.scss +30 -30
  472. package/static/styles/commonkanban.scss +168 -168
  473. package/static/styles/dark/index.scss +2 -2
  474. package/static/styles/dark/theme/element-dark.scss +44 -44
  475. package/static/styles/index.scss +84 -84
  476. package/static/styles/intersection.scss +180 -180
  477. package/static/styles/light/index.scss +2 -2
  478. package/static/styles/light/theme/element-light.scss +44 -44
  479. package/static/styles/overview.scss +146 -146
  480. package/static/styles/patternConfig.scss +56 -56
  481. package/static/styles/phasePedSelect.scss +71 -71
  482. package/static/styles/schemeconfig.scss +552 -552
  483. package/static/styles/stages.scss +57 -57
  484. package/static/styles/theme/element-dark.scss +0 -0
  485. package/static/styles/uiComponents.scss +57 -57
  486. package/static/styles/xiaokanban.scss +61 -61
  487. package/static/token.json +2 -2
  488. package/test/e2e/custom-assertions/elementCount.js +27 -27
  489. package/test/e2e/nightwatch.conf.js +46 -46
  490. package/test/e2e/runner.js +48 -48
  491. package/test/e2e/specs/test.js +19 -19
  492. package/test/unit/.eslintrc +7 -7
  493. package/test/unit/jest.conf.js +30 -30
  494. package/test/unit/setup.js +3 -3
  495. package/test/unit/specs/HelloWorld.spec.js +11 -11
  496. package/package/kisscomps/components/OverviewComponent/index.js +0 -2
  497. package/package/kisscomps/components/OverviewComponent/index.vue +0 -788
  498. package/src/kisscomps/components/OverviewComponent/index.js +0 -2
  499. package/src/kisscomps/components/OverviewComponent/index.vue +0 -788
@@ -1,454 +1,454 @@
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="direction-list-configuration">
14
- <div class="dir-config-row">
15
- <div class="label" :style="{width: labelWidth}">{{$t('openatccomponents.phase.desc')}}:</div>
16
- <div class="dir-btn lane-dir">
17
- <div class="each-icon" v-for="(item, index) in laneList" :key="index" :class="item.disabled ? 'disabled-icon': ''">
18
- <el-tooltip class="item" effect="dark" :content="item.name" placement="bottom-start">
19
- <div class="single-icon"
20
- @click="selectDire(item, 'lane')"
21
- :class="!item.disabled && preselectDirection.indexOf(item.id) !== -1 ? 'single-icon-select' : ''">
22
- <i :class="item.iconclass"></i>
23
- <div class="single-icon-name">{{item.name}}</div>
24
- </div>
25
- </el-tooltip>
26
- </div>
27
- </div>
28
- </div>
29
- <div class="dir-config-row">
30
- <div class="label" :style="{width: labelWidth}">{{$t('openatccomponents.phase.peddesc')}}:</div>
31
- <div class="dir-btn ped-dir">
32
- <div class="each-icon" v-for="(item, index) in pedList" :key="index" :class="item.disabled ? 'disabled-icon': ''">
33
- <el-tooltip class="item" effect="dark" :content="item.name" placement="bottom-start">
34
- <div class="single-icon ped-icon"
35
- @click="selectDire(item, 'ped')"
36
- :class="!item.disabled && preselectPedDirection.indexOf(item.id) !== -1 ? 'single-icon-select' : ''">
37
- <PedSvg :pedId="item.id" />
38
- <div class="single-icon-name" style="margin-top: 5px;">{{item.name}}</div>
39
- </div>
40
- </el-tooltip>
41
- </div>
42
- </div>
43
- </div>
44
- </div>
45
- </template>
46
- <script>
47
- import xdrdirselector from '../XRDDirSelector/XRDDirSelector'
48
- import { uploadSingleTscParam } from '../../../api/param.js'
49
- import { getMessageByCode } from '../../../utils/responseMessage.js'
50
- // import { getIntersectionInfo } from '../../../api/template.js'
51
- import CrossDiagramMgr from '../../../EdgeMgr/controller/crossDiagramMgr.js'
52
- import PhaseDataModel from '../IntersectionMap/crossDirection/utils.js'
53
- // import { getTheme } from '../../../utils/auth'
54
- import { images } from '../../../utils/phasedesc.js'
55
- import PedSvg from './svg/pedSvg'
56
-
57
- import CrossDirectionConflictList from '../../../utils/conflictList.js'
58
-
59
- export default {
60
- name: 'direction-list-configuration',
61
- data () {
62
- return {
63
- laneList: [],
64
- pedList: [],
65
- preselectDirection: [], // 预选方向
66
- preselectPedDirection: [] // 预选行人方向
67
- }
68
- },
69
- components: {
70
- xdrdirselector,
71
- PedSvg
72
- },
73
- props: {
74
- labelWidth: {
75
- type: String,
76
- default: '130px'
77
- },
78
- agentId: {
79
- type: String
80
- },
81
- list: {
82
- type: Array,
83
- default () {
84
- return []
85
- }
86
- },
87
- roadDirection: {
88
- type: String,
89
- default: 'right'
90
- },
91
- isThirdSignal: {
92
- type: Boolean,
93
- default: false
94
- },
95
- choosedDirection: {
96
- type: Array
97
- },
98
- choosedPedDirection: {
99
- type: Array
100
- }
101
- },
102
- methods: {
103
- init (IntersectionInfo) {
104
- this.CrossDiagramMgr = new CrossDiagramMgr()
105
- this.PhaseDataModel = new PhaseDataModel(this.roadDirection)
106
- this.getIntersectionInfo(IntersectionInfo) // 获取路口信息
107
- },
108
- getIntersectionInfo (res) {
109
- // 获取路口信息
110
- // const agentid = this.agentId || '0'
111
- // getIntersectionInfo(agentid).then(res => {
112
- // if (!res.data.success) {
113
- // this.isLoaded = false
114
- // let commomMsg = this.$t('openatccomponents.overview.signalID') + ' : ' + agentid
115
- // let msg = getMessageByCode(res.data.code, this.$i18n.locale)
116
- // if (res.data.data) {
117
- // // 子类型错误
118
- // let childErrorCode = res.data.data.errorCode
119
- // if (childErrorCode) {
120
- // let childerror = getMessageByCode(res.data.data.errorCode, this.$i18n.locale)
121
- // msg = msg + ' - ' + childerror
122
- // }
123
- // }
124
- // msg = msg + ' - ' + commomMsg
125
- // this.$message.error(msg)
126
- // return
127
- // }
128
- this.tempType = res.data.data.type
129
- // 获取车道相位、行人相位信息(坐标、名称)
130
- this.mainType = this.tempType.split('-')[0]
131
- this.mainDirection = this.tempType.split('-')[1]
132
- if (!this.isThirdSignal) {
133
- // 可点击模式下,非第三方设备,按通道显示相位方向
134
- this.getChannelInfo()
135
- return
136
- }
137
- this.crossInfo = res.data.data.param
138
- // 城市道路加载车道相位坐标和人行道坐标
139
- this.getPhasePos()
140
- this.getOverlapPhasePos()
141
- this.getPedPhasePos()
142
- this.getOverlapPedPhasePos()
143
- if (this.isThirdSignal) {
144
- // 第三方设备,按相位方向显示相位方向
145
- this.compLanePhaseData = this.CrossDiagramMgr.compare(this.LanePhaseData, this.overlapLanePhaseData, 'type', 'nostatus')
146
- this.compSidewalkPhaseData = this.CrossDiagramMgr.compare(this.sidewalkPhaseData, this.overlapsidewalkPhaseData, 'pedtype', 'nostatus')
147
- let allDir = this.compLanePhaseData.map(ele => ele.id)
148
- let allPedDir = this.compSidewalkPhaseData.map(ele => ele.id)
149
- this.inneChoosedDirection = this.choosedDirection.filter(dir => allDir.indexOf(dir) !== -1)
150
- this.inneChoosedPedDirection = this.choosedPedDirection.filter(dir => allPedDir.indexOf(dir) !== -1)
151
- this.drawPhaseIcon()
152
- }
153
- // })
154
- },
155
- getPhasePos () {
156
- // 车道相位信息
157
- this.LanePhaseData = []
158
- this.crossInfo.phaseList.forEach((ele, i) => {
159
- if (ele.controltype === undefined || ele.controltype <= 2) {
160
- ele.direction.forEach((dir, index) => {
161
- let dirinfo = this.PhaseDataModel.getPhase(dir)
162
- if (dir <= 16) {
163
- // 车道相位
164
- this.LanePhaseData.push({
165
- key: this.CrossDiagramMgr.getUniqueKey('phase'),
166
- phaseid: ele.id, // 相位id,用于对应相位状态
167
- id: dir, // 接口返回的dir字段,对应前端定义的相位方向id,唯一标识
168
- name: dirinfo.name
169
- })
170
- }
171
- })
172
- }
173
- })
174
- },
175
- getOverlapPhasePos () {
176
- // 车道跟随相位信息
177
- if (!this.crossInfo.overlaplList) return
178
- this.overlapLanePhaseData = []
179
- this.crossInfo.overlaplList.forEach((ele, i) => {
180
- if (ele.direction) {
181
- ele.direction.forEach((dir, index) => {
182
- this.overlapLanePhaseData.push({
183
- key: this.CrossDiagramMgr.getUniqueKey('overlapphase'),
184
- phaseid: ele.id, // 相位id,用于对应相位状态
185
- id: dir, // 接口返回的dir字段,对应前端定义的相位方向id,唯一标识
186
- name: this.PhaseDataModel.getPhase(dir).name,
187
- left: this.PhaseDataModel.getPhase(dir).x,
188
- top: this.PhaseDataModel.getPhase(dir).y
189
- })
190
- })
191
- }
192
- })
193
- },
194
- getPedPhasePos () {
195
- // 行人相位信息
196
- this.sidewalkPhaseData = []
197
- this.crossInfo.phaseList.forEach((ele, i) => {
198
- if (ele.peddirection) {
199
- ele.peddirection.forEach((dir, index) => {
200
- // 行人相位
201
- let dirinfo = this.PhaseDataModel.getSidePos(dir)
202
- if (dir <= 16) {
203
- let key = this.CrossDiagramMgr.getUniqueKey('pedphase')
204
- if (this.isVipRoute && this.isThirdSignal) {
205
- key = this.CrossDiagramMgr.getUniqueKey('pedphase') + `-${this.agentId}`
206
- }
207
- this.sidewalkPhaseData.push({
208
- key,
209
- phaseid: ele.id, // 相位id,用于对应相位状态
210
- id: dir,
211
- name: dirinfo.name
212
- })
213
- }
214
- })
215
- }
216
- })
217
- },
218
- getOverlapPedPhasePos () {
219
- // 行人跟随相位信息
220
- if (!this.crossInfo.overlaplList) return
221
- this.overlapsidewalkPhaseData = []
222
- this.crossInfo.overlaplList.forEach((ele, i) => {
223
- if (ele.peddirection) {
224
- ele.peddirection.forEach((dir, index) => {
225
- if (this.PhaseDataModel.getSidePos(dir)) {
226
- this.overlapsidewalkPhaseData.push({
227
- key: this.CrossDiagramMgr.getUniqueKey('overlappedphase'),
228
- phaseid: ele.id, // 相位id,用于对应相位状态
229
- id: dir,
230
- name: this.PhaseDataModel.getSidePos(dir).name,
231
- left: this.PhaseDataModel.getSidePos(dir).x,
232
- top: this.PhaseDataModel.getSidePos(dir).y
233
- })
234
- }
235
- })
236
- }
237
- })
238
- },
239
- getChannelInfo () {
240
- uploadSingleTscParam('channel', this.agentId).then(data => {
241
- let res = data.data
242
- if (!res.success) {
243
- if (res.code === '4003') {
244
- this.$message.error(this.$t('openatccomponents.errorTip.devicenotonline'))
245
- return
246
- }
247
- this.$message.error(getMessageByCode(data.data.code, this.$i18n.locale))
248
- return
249
- }
250
- let channelList = res.data.data.channelList.filter(ele => ele.type !== undefined)
251
- this.channelList = this.handleRepeatRealdir(channelList)
252
- console.log('this.channelList', this.channelList)
253
- this.handleChannelDirection()
254
- })
255
- },
256
- handleRepeatRealdir (channelList) {
257
- let map = new Map()
258
- channelList.forEach(ele => {
259
- ele.realdir.forEach(dir => {
260
- if (map.get(dir) === undefined) {
261
- map.set(dir, ele)
262
- }
263
- })
264
- })
265
- let arr = Array.from(map)
266
- let newarr = []
267
- arr.forEach(ele => {
268
- newarr.push(ele[1])
269
- })
270
- // console.log(newarr)
271
- return newarr
272
- },
273
- handleChannelDirection () {
274
- this.LanePhaseData = []
275
- this.sidewalkPhaseData = []
276
- this.sidewalkDir = []
277
- let realphasedirarr = []
278
- let realpeddirarr = []
279
- this.channelList.forEach((ele, i) => {
280
- if (ele.type === 0 || ele.type === 1 || ele.type === 3) {
281
- if (ele.realdir) {
282
- ele.realdir.forEach((dir, index) => {
283
- let phaseinfo = this.PhaseDataModel.getPhase(dir)
284
- // 车道相位(通道类型是机动车,非机动车,公交时,对应相位机动车)
285
- this.LanePhaseData.push({
286
- key: this.CrossDiagramMgr.getUniqueKey('phase'),
287
- channelid: ele.id, // 通道id
288
- id: dir, // 接口返回的dir字段,对应前端定义的相位方向id,唯一标识
289
- name: this.$i18n.locale === 'en' ? phaseinfo.ename : phaseinfo.name
290
- })
291
- })
292
- realphasedirarr = Array.from(new Set(realphasedirarr.concat(ele.realdir)))
293
- }
294
- }
295
- if (ele.type === 2) {
296
- if (ele.realdir) {
297
- ele.realdir.forEach((dir, index) => {
298
- // 行人相位
299
- if (this.sidewalkDir.indexOf(dir) === -1 && this.PhaseDataModel.getSidePos(dir)) {
300
- let pedinfo = this.PhaseDataModel.getSidePos(dir)
301
- this.sidewalkPhaseData.push({
302
- key: this.CrossDiagramMgr.getUniqueKey('pedphase'),
303
- channelid: ele.id, // 通道id
304
- id: dir,
305
- name: this.$i18n.locale === 'en' ? pedinfo.ename : pedinfo.desc
306
- })
307
- }
308
- })
309
- realpeddirarr = Array.from(new Set(realpeddirarr.concat(ele.realdir)))
310
- this.sidewalkDir = Array.from(new Set([...this.sidewalkDir.concat(ele.realdir)]))
311
- }
312
- }
313
- })
314
- this.inneChoosedDirection = this.choosedDirection.filter(dir => realphasedirarr.indexOf(dir) !== -1)
315
- this.inneChoosedPedDirection = this.choosedPedDirection.filter(dir => realpeddirarr.indexOf(dir) !== -1)
316
- this.drawPhaseIcon()
317
- },
318
- async drawPhaseIcon () {
319
- if (!this.isThirdSignal) {
320
- await this.getConflictList()
321
- this.handleClickedPhase()
322
- this.handleClickedPedPhase()
323
- this.handleLaneDir()
324
- this.handlePedDir()
325
- } else {
326
- this.handleClickedPhase()
327
- this.handleClickedPedPhase()
328
- this.handleLaneDir()
329
- this.handlePedDir()
330
- }
331
- },
332
- async getConflictList () {
333
- let ConflictList = new CrossDirectionConflictList(this.agentId)
334
- return ConflictList.getConflictListByAgentid().then(res => {
335
- if (res) {
336
- let conflictList = ConflictList.getListDirConflict(this.inneChoosedDirection, this.inneChoosedPedDirection)
337
- this.phaseConflictList = conflictList.allConflictDir
338
- this.pedConflictList = conflictList.allPedConflictDir
339
- // 排他
340
- for (let index = 0; index < this.LanePhaseData.length; index++) {
341
- const element = this.LanePhaseData[index]
342
- delete element.disabled
343
- }
344
- for (let index = 0; index < this.sidewalkPhaseData.length; index++) {
345
- const element = this.sidewalkPhaseData[index]
346
- delete element.disabled
347
- }
348
- for (let index = 0; index < this.LanePhaseData.length; index++) {
349
- const element = this.LanePhaseData[index]
350
- if (this.phaseConflictList.indexOf(element.id) !== -1) {
351
- element.disabled = true
352
- }
353
- }
354
- for (let index = 0; index < this.sidewalkPhaseData.length; index++) {
355
- const element = this.sidewalkPhaseData[index]
356
- if (this.pedConflictList.indexOf(element.id) !== -1) {
357
- element.disabled = true
358
- }
359
- }
360
- }
361
- })
362
- },
363
- handleClickedPhase () {
364
- if (!this.isThirdSignal) {
365
- this.preselectDirection = this.inneChoosedDirection.filter(dir => this.phaseConflictList.indexOf(dir) === -1)
366
- } else {
367
- this.preselectDirection = JSON.parse(JSON.stringify(this.inneChoosedDirection))
368
- }
369
- },
370
- handleClickedPedPhase () {
371
- if (!this.isThirdSignal) {
372
- this.preselectPedDirection = this.inneChoosedPedDirection.filter(dir => this.pedConflictList.indexOf(dir) === -1)
373
- } else {
374
- this.preselectPedDirection = JSON.parse(JSON.stringify(this.inneChoosedPedDirection))
375
- }
376
- },
377
-
378
- handleLaneDir () {
379
- if (!this.isThirdSignal) {
380
- this.laneList = this.getPhaseDirIcon(this.LanePhaseData)
381
- } else {
382
- this.laneList = this.getPhaseDirIcon(this.compLanePhaseData)
383
- }
384
- },
385
- handlePedDir () {
386
- if (!this.isThirdSignal) {
387
- this.pedList = JSON.parse(JSON.stringify(this.sidewalkPhaseData))
388
- } else {
389
- this.pedList = JSON.parse(JSON.stringify(this.compSidewalkPhaseData))
390
- }
391
- },
392
- getPhaseDirIcon (list) {
393
- let idarr = []
394
- let dirlist = []
395
- for (let i = 0; i < list.length; i++) {
396
- if (list[i].id <= 16 && idarr.indexOf(list[i].id) === -1) {
397
- idarr.push(list[i].id)
398
- let obj = {
399
- ...list[i],
400
- iconclass: images.filter(ele => ele.id === list[i].id)[0].class
401
- }
402
- if (this.roadDirection === 'left') {
403
- if (list[i].id === 4 || list[i].id === 8 || list[i].id === 12 || list[i].id === 16) {
404
- obj.iconclass = images.filter(ele => ele.id === list[i].id)[0].leftclass
405
- }
406
- }
407
- dirlist.push(obj)
408
- }
409
- }
410
- return dirlist
411
- },
412
- selectDire (value, type) {
413
- if (value.disabled) return
414
- let id = value.id
415
- if (type === 'lane') {
416
- let index = this.preselectDirection.indexOf(id)
417
- if (index === -1) {
418
- this.preselectDirection.push(id)
419
- } else {
420
- this.preselectDirection.splice(index, 1)
421
- }
422
- // console.log(this.preselectDirection)
423
- this.choosedLanePhase = this.laneList.filter(lane => this.preselectDirection.includes(lane.id))
424
- // console.log(this.choosedLanePhase)
425
- this.inneChoosedDirection = JSON.parse(JSON.stringify(this.preselectDirection))
426
- }
427
- if (type === 'ped') {
428
- let index = this.preselectPedDirection.indexOf(id)
429
- if (index === -1) {
430
- this.preselectPedDirection.push(id)
431
- } else {
432
- this.preselectPedDirection.splice(index, 1)
433
- }
434
- // console.log(this.preselectPedDirection)
435
- this.choosedPedPhase = this.pedList.filter(lane => this.preselectPedDirection.includes(lane.id))
436
- // console.log(this.choosedPedPhase)
437
- this.inneChoosedPedDirection = JSON.parse(JSON.stringify(this.preselectPedDirection))
438
- }
439
- this.EmitAllChoosedDirection(value)
440
- },
441
- EmitAllChoosedDirection (curClickedPhase) {
442
- let allChoosedDir = {
443
- direction: this.preselectDirection,
444
- peddirection: this.preselectPedDirection
445
- }
446
- this.$emit('handleClickCrossIcon', allChoosedDir, curClickedPhase)
447
- this.drawPhaseIcon()
448
- }
449
- },
450
- mounted () {
451
- // this.init()
452
- }
453
- }
454
- </script>
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="direction-list-configuration">
14
+ <div class="dir-config-row">
15
+ <div class="label" :style="{width: labelWidth}">{{$t('openatccomponents.phase.desc')}}:</div>
16
+ <div class="dir-btn lane-dir">
17
+ <div class="each-icon" v-for="(item, index) in laneList" :key="index" :class="item.disabled ? 'disabled-icon': ''">
18
+ <el-tooltip class="item" effect="dark" :content="item.name" placement="bottom-start">
19
+ <div class="single-icon"
20
+ @click="selectDire(item, 'lane')"
21
+ :class="!item.disabled && preselectDirection.indexOf(item.id) !== -1 ? 'single-icon-select' : ''">
22
+ <i :class="item.iconclass"></i>
23
+ <div class="single-icon-name">{{item.name}}</div>
24
+ </div>
25
+ </el-tooltip>
26
+ </div>
27
+ </div>
28
+ </div>
29
+ <div class="dir-config-row">
30
+ <div class="label" :style="{width: labelWidth}">{{$t('openatccomponents.phase.peddesc')}}:</div>
31
+ <div class="dir-btn ped-dir">
32
+ <div class="each-icon" v-for="(item, index) in pedList" :key="index" :class="item.disabled ? 'disabled-icon': ''">
33
+ <el-tooltip class="item" effect="dark" :content="item.name" placement="bottom-start">
34
+ <div class="single-icon ped-icon"
35
+ @click="selectDire(item, 'ped')"
36
+ :class="!item.disabled && preselectPedDirection.indexOf(item.id) !== -1 ? 'single-icon-select' : ''">
37
+ <PedSvg :pedId="item.id" />
38
+ <div class="single-icon-name" style="margin-top: 5px;">{{item.name}}</div>
39
+ </div>
40
+ </el-tooltip>
41
+ </div>
42
+ </div>
43
+ </div>
44
+ </div>
45
+ </template>
46
+ <script>
47
+ import xdrdirselector from '../XRDDirSelector/XRDDirSelector'
48
+ import { uploadSingleTscParam } from '../../../api/param.js'
49
+ import { getMessageByCode } from '../../../utils/responseMessage.js'
50
+ // import { getIntersectionInfo } from '../../../api/template.js'
51
+ import CrossDiagramMgr from '../../../EdgeMgr/controller/crossDiagramMgr.js'
52
+ import PhaseDataModel from '../IntersectionMap/crossDirection/utils.js'
53
+ // import { getTheme } from '../../../utils/auth'
54
+ import { images } from '../../../utils/phasedesc.js'
55
+ import PedSvg from './svg/pedSvg'
56
+
57
+ import CrossDirectionConflictList from '../../../utils/conflictList.js'
58
+
59
+ export default {
60
+ name: 'direction-list-configuration',
61
+ data () {
62
+ return {
63
+ laneList: [],
64
+ pedList: [],
65
+ preselectDirection: [], // 预选方向
66
+ preselectPedDirection: [] // 预选行人方向
67
+ }
68
+ },
69
+ components: {
70
+ xdrdirselector,
71
+ PedSvg
72
+ },
73
+ props: {
74
+ labelWidth: {
75
+ type: String,
76
+ default: '130px'
77
+ },
78
+ agentId: {
79
+ type: String
80
+ },
81
+ list: {
82
+ type: Array,
83
+ default () {
84
+ return []
85
+ }
86
+ },
87
+ roadDirection: {
88
+ type: String,
89
+ default: 'right'
90
+ },
91
+ isThirdSignal: {
92
+ type: Boolean,
93
+ default: false
94
+ },
95
+ choosedDirection: {
96
+ type: Array
97
+ },
98
+ choosedPedDirection: {
99
+ type: Array
100
+ }
101
+ },
102
+ methods: {
103
+ init (IntersectionInfo) {
104
+ this.CrossDiagramMgr = new CrossDiagramMgr()
105
+ this.PhaseDataModel = new PhaseDataModel(this.roadDirection)
106
+ this.getIntersectionInfo(IntersectionInfo) // 获取路口信息
107
+ },
108
+ getIntersectionInfo (res) {
109
+ // 获取路口信息
110
+ // const agentid = this.agentId || '0'
111
+ // getIntersectionInfo(agentid).then(res => {
112
+ // if (!res.data.success) {
113
+ // this.isLoaded = false
114
+ // let commomMsg = this.$t('openatccomponents.overview.signalID') + ' : ' + agentid
115
+ // let msg = getMessageByCode(res.data.code, this.$i18n.locale)
116
+ // if (res.data.data) {
117
+ // // 子类型错误
118
+ // let childErrorCode = res.data.data.errorCode
119
+ // if (childErrorCode) {
120
+ // let childerror = getMessageByCode(res.data.data.errorCode, this.$i18n.locale)
121
+ // msg = msg + ' - ' + childerror
122
+ // }
123
+ // }
124
+ // msg = msg + ' - ' + commomMsg
125
+ // this.$message.error(msg)
126
+ // return
127
+ // }
128
+ this.tempType = res.data.data.type
129
+ // 获取车道相位、行人相位信息(坐标、名称)
130
+ this.mainType = this.tempType.split('-')[0]
131
+ this.mainDirection = this.tempType.split('-')[1]
132
+ if (!this.isThirdSignal) {
133
+ // 可点击模式下,非第三方设备,按通道显示相位方向
134
+ this.getChannelInfo()
135
+ return
136
+ }
137
+ this.crossInfo = res.data.data.param
138
+ // 城市道路加载车道相位坐标和人行道坐标
139
+ this.getPhasePos()
140
+ this.getOverlapPhasePos()
141
+ this.getPedPhasePos()
142
+ this.getOverlapPedPhasePos()
143
+ if (this.isThirdSignal) {
144
+ // 第三方设备,按相位方向显示相位方向
145
+ this.compLanePhaseData = this.CrossDiagramMgr.compare(this.LanePhaseData, this.overlapLanePhaseData, 'type', 'nostatus')
146
+ this.compSidewalkPhaseData = this.CrossDiagramMgr.compare(this.sidewalkPhaseData, this.overlapsidewalkPhaseData, 'pedtype', 'nostatus')
147
+ let allDir = this.compLanePhaseData.map(ele => ele.id)
148
+ let allPedDir = this.compSidewalkPhaseData.map(ele => ele.id)
149
+ this.inneChoosedDirection = this.choosedDirection.filter(dir => allDir.indexOf(dir) !== -1)
150
+ this.inneChoosedPedDirection = this.choosedPedDirection.filter(dir => allPedDir.indexOf(dir) !== -1)
151
+ this.drawPhaseIcon()
152
+ }
153
+ // })
154
+ },
155
+ getPhasePos () {
156
+ // 车道相位信息
157
+ this.LanePhaseData = []
158
+ this.crossInfo.phaseList.forEach((ele, i) => {
159
+ if (ele.controltype === undefined || ele.controltype <= 2) {
160
+ ele.direction.forEach((dir, index) => {
161
+ let dirinfo = this.PhaseDataModel.getPhase(dir)
162
+ if (dir <= 16) {
163
+ // 车道相位
164
+ this.LanePhaseData.push({
165
+ key: this.CrossDiagramMgr.getUniqueKey('phase'),
166
+ phaseid: ele.id, // 相位id,用于对应相位状态
167
+ id: dir, // 接口返回的dir字段,对应前端定义的相位方向id,唯一标识
168
+ name: dirinfo.name
169
+ })
170
+ }
171
+ })
172
+ }
173
+ })
174
+ },
175
+ getOverlapPhasePos () {
176
+ // 车道跟随相位信息
177
+ if (!this.crossInfo.overlaplList) return
178
+ this.overlapLanePhaseData = []
179
+ this.crossInfo.overlaplList.forEach((ele, i) => {
180
+ if (ele.direction) {
181
+ ele.direction.forEach((dir, index) => {
182
+ this.overlapLanePhaseData.push({
183
+ key: this.CrossDiagramMgr.getUniqueKey('overlapphase'),
184
+ phaseid: ele.id, // 相位id,用于对应相位状态
185
+ id: dir, // 接口返回的dir字段,对应前端定义的相位方向id,唯一标识
186
+ name: this.PhaseDataModel.getPhase(dir).name,
187
+ left: this.PhaseDataModel.getPhase(dir).x,
188
+ top: this.PhaseDataModel.getPhase(dir).y
189
+ })
190
+ })
191
+ }
192
+ })
193
+ },
194
+ getPedPhasePos () {
195
+ // 行人相位信息
196
+ this.sidewalkPhaseData = []
197
+ this.crossInfo.phaseList.forEach((ele, i) => {
198
+ if (ele.peddirection) {
199
+ ele.peddirection.forEach((dir, index) => {
200
+ // 行人相位
201
+ let dirinfo = this.PhaseDataModel.getSidePos(dir)
202
+ if (dir <= 16) {
203
+ let key = this.CrossDiagramMgr.getUniqueKey('pedphase')
204
+ if (this.isVipRoute && this.isThirdSignal) {
205
+ key = this.CrossDiagramMgr.getUniqueKey('pedphase') + `-${this.agentId}`
206
+ }
207
+ this.sidewalkPhaseData.push({
208
+ key,
209
+ phaseid: ele.id, // 相位id,用于对应相位状态
210
+ id: dir,
211
+ name: dirinfo.name
212
+ })
213
+ }
214
+ })
215
+ }
216
+ })
217
+ },
218
+ getOverlapPedPhasePos () {
219
+ // 行人跟随相位信息
220
+ if (!this.crossInfo.overlaplList) return
221
+ this.overlapsidewalkPhaseData = []
222
+ this.crossInfo.overlaplList.forEach((ele, i) => {
223
+ if (ele.peddirection) {
224
+ ele.peddirection.forEach((dir, index) => {
225
+ if (this.PhaseDataModel.getSidePos(dir)) {
226
+ this.overlapsidewalkPhaseData.push({
227
+ key: this.CrossDiagramMgr.getUniqueKey('overlappedphase'),
228
+ phaseid: ele.id, // 相位id,用于对应相位状态
229
+ id: dir,
230
+ name: this.PhaseDataModel.getSidePos(dir).name,
231
+ left: this.PhaseDataModel.getSidePos(dir).x,
232
+ top: this.PhaseDataModel.getSidePos(dir).y
233
+ })
234
+ }
235
+ })
236
+ }
237
+ })
238
+ },
239
+ getChannelInfo () {
240
+ uploadSingleTscParam('channel', this.agentId).then(data => {
241
+ let res = data.data
242
+ if (!res.success) {
243
+ if (res.code === '4003') {
244
+ this.$message.error(this.$t('openatccomponents.errorTip.devicenotonline'))
245
+ return
246
+ }
247
+ this.$message.error(getMessageByCode(data.data.code, this.$i18n.locale))
248
+ return
249
+ }
250
+ let channelList = res.data.data.channelList.filter(ele => ele.type !== undefined)
251
+ this.channelList = this.handleRepeatRealdir(channelList)
252
+ console.log('this.channelList', this.channelList)
253
+ this.handleChannelDirection()
254
+ })
255
+ },
256
+ handleRepeatRealdir (channelList) {
257
+ let map = new Map()
258
+ channelList.forEach(ele => {
259
+ ele.realdir.forEach(dir => {
260
+ if (map.get(dir) === undefined) {
261
+ map.set(dir, ele)
262
+ }
263
+ })
264
+ })
265
+ let arr = Array.from(map)
266
+ let newarr = []
267
+ arr.forEach(ele => {
268
+ newarr.push(ele[1])
269
+ })
270
+ // console.log(newarr)
271
+ return newarr
272
+ },
273
+ handleChannelDirection () {
274
+ this.LanePhaseData = []
275
+ this.sidewalkPhaseData = []
276
+ this.sidewalkDir = []
277
+ let realphasedirarr = []
278
+ let realpeddirarr = []
279
+ this.channelList.forEach((ele, i) => {
280
+ if (ele.type === 0 || ele.type === 1 || ele.type === 3) {
281
+ if (ele.realdir) {
282
+ ele.realdir.forEach((dir, index) => {
283
+ let phaseinfo = this.PhaseDataModel.getPhase(dir)
284
+ // 车道相位(通道类型是机动车,非机动车,公交时,对应相位机动车)
285
+ this.LanePhaseData.push({
286
+ key: this.CrossDiagramMgr.getUniqueKey('phase'),
287
+ channelid: ele.id, // 通道id
288
+ id: dir, // 接口返回的dir字段,对应前端定义的相位方向id,唯一标识
289
+ name: this.$i18n.locale === 'en' ? phaseinfo.ename : phaseinfo.name
290
+ })
291
+ })
292
+ realphasedirarr = Array.from(new Set(realphasedirarr.concat(ele.realdir)))
293
+ }
294
+ }
295
+ if (ele.type === 2) {
296
+ if (ele.realdir) {
297
+ ele.realdir.forEach((dir, index) => {
298
+ // 行人相位
299
+ if (this.sidewalkDir.indexOf(dir) === -1 && this.PhaseDataModel.getSidePos(dir)) {
300
+ let pedinfo = this.PhaseDataModel.getSidePos(dir)
301
+ this.sidewalkPhaseData.push({
302
+ key: this.CrossDiagramMgr.getUniqueKey('pedphase'),
303
+ channelid: ele.id, // 通道id
304
+ id: dir,
305
+ name: this.$i18n.locale === 'en' ? pedinfo.ename : pedinfo.desc
306
+ })
307
+ }
308
+ })
309
+ realpeddirarr = Array.from(new Set(realpeddirarr.concat(ele.realdir)))
310
+ this.sidewalkDir = Array.from(new Set([...this.sidewalkDir.concat(ele.realdir)]))
311
+ }
312
+ }
313
+ })
314
+ this.inneChoosedDirection = this.choosedDirection.filter(dir => realphasedirarr.indexOf(dir) !== -1)
315
+ this.inneChoosedPedDirection = this.choosedPedDirection.filter(dir => realpeddirarr.indexOf(dir) !== -1)
316
+ this.drawPhaseIcon()
317
+ },
318
+ async drawPhaseIcon () {
319
+ if (!this.isThirdSignal) {
320
+ await this.getConflictList()
321
+ this.handleClickedPhase()
322
+ this.handleClickedPedPhase()
323
+ this.handleLaneDir()
324
+ this.handlePedDir()
325
+ } else {
326
+ this.handleClickedPhase()
327
+ this.handleClickedPedPhase()
328
+ this.handleLaneDir()
329
+ this.handlePedDir()
330
+ }
331
+ },
332
+ async getConflictList () {
333
+ let ConflictList = new CrossDirectionConflictList(this.agentId)
334
+ return ConflictList.getConflictListByAgentid().then(res => {
335
+ if (res) {
336
+ let conflictList = ConflictList.getListDirConflict(this.inneChoosedDirection, this.inneChoosedPedDirection)
337
+ this.phaseConflictList = conflictList.allConflictDir
338
+ this.pedConflictList = conflictList.allPedConflictDir
339
+ // 排他
340
+ for (let index = 0; index < this.LanePhaseData.length; index++) {
341
+ const element = this.LanePhaseData[index]
342
+ delete element.disabled
343
+ }
344
+ for (let index = 0; index < this.sidewalkPhaseData.length; index++) {
345
+ const element = this.sidewalkPhaseData[index]
346
+ delete element.disabled
347
+ }
348
+ for (let index = 0; index < this.LanePhaseData.length; index++) {
349
+ const element = this.LanePhaseData[index]
350
+ if (this.phaseConflictList.indexOf(element.id) !== -1) {
351
+ element.disabled = true
352
+ }
353
+ }
354
+ for (let index = 0; index < this.sidewalkPhaseData.length; index++) {
355
+ const element = this.sidewalkPhaseData[index]
356
+ if (this.pedConflictList.indexOf(element.id) !== -1) {
357
+ element.disabled = true
358
+ }
359
+ }
360
+ }
361
+ })
362
+ },
363
+ handleClickedPhase () {
364
+ if (!this.isThirdSignal) {
365
+ this.preselectDirection = this.inneChoosedDirection.filter(dir => this.phaseConflictList.indexOf(dir) === -1)
366
+ } else {
367
+ this.preselectDirection = JSON.parse(JSON.stringify(this.inneChoosedDirection))
368
+ }
369
+ },
370
+ handleClickedPedPhase () {
371
+ if (!this.isThirdSignal) {
372
+ this.preselectPedDirection = this.inneChoosedPedDirection.filter(dir => this.pedConflictList.indexOf(dir) === -1)
373
+ } else {
374
+ this.preselectPedDirection = JSON.parse(JSON.stringify(this.inneChoosedPedDirection))
375
+ }
376
+ },
377
+
378
+ handleLaneDir () {
379
+ if (!this.isThirdSignal) {
380
+ this.laneList = this.getPhaseDirIcon(this.LanePhaseData)
381
+ } else {
382
+ this.laneList = this.getPhaseDirIcon(this.compLanePhaseData)
383
+ }
384
+ },
385
+ handlePedDir () {
386
+ if (!this.isThirdSignal) {
387
+ this.pedList = JSON.parse(JSON.stringify(this.sidewalkPhaseData))
388
+ } else {
389
+ this.pedList = JSON.parse(JSON.stringify(this.compSidewalkPhaseData))
390
+ }
391
+ },
392
+ getPhaseDirIcon (list) {
393
+ let idarr = []
394
+ let dirlist = []
395
+ for (let i = 0; i < list.length; i++) {
396
+ if (list[i].id <= 16 && idarr.indexOf(list[i].id) === -1) {
397
+ idarr.push(list[i].id)
398
+ let obj = {
399
+ ...list[i],
400
+ iconclass: images.filter(ele => ele.id === list[i].id)[0].class
401
+ }
402
+ if (this.roadDirection === 'left') {
403
+ if (list[i].id === 4 || list[i].id === 8 || list[i].id === 12 || list[i].id === 16) {
404
+ obj.iconclass = images.filter(ele => ele.id === list[i].id)[0].leftclass
405
+ }
406
+ }
407
+ dirlist.push(obj)
408
+ }
409
+ }
410
+ return dirlist
411
+ },
412
+ selectDire (value, type) {
413
+ if (value.disabled) return
414
+ let id = value.id
415
+ if (type === 'lane') {
416
+ let index = this.preselectDirection.indexOf(id)
417
+ if (index === -1) {
418
+ this.preselectDirection.push(id)
419
+ } else {
420
+ this.preselectDirection.splice(index, 1)
421
+ }
422
+ // console.log(this.preselectDirection)
423
+ this.choosedLanePhase = this.laneList.filter(lane => this.preselectDirection.includes(lane.id))
424
+ // console.log(this.choosedLanePhase)
425
+ this.inneChoosedDirection = JSON.parse(JSON.stringify(this.preselectDirection))
426
+ }
427
+ if (type === 'ped') {
428
+ let index = this.preselectPedDirection.indexOf(id)
429
+ if (index === -1) {
430
+ this.preselectPedDirection.push(id)
431
+ } else {
432
+ this.preselectPedDirection.splice(index, 1)
433
+ }
434
+ // console.log(this.preselectPedDirection)
435
+ this.choosedPedPhase = this.pedList.filter(lane => this.preselectPedDirection.includes(lane.id))
436
+ // console.log(this.choosedPedPhase)
437
+ this.inneChoosedPedDirection = JSON.parse(JSON.stringify(this.preselectPedDirection))
438
+ }
439
+ this.EmitAllChoosedDirection(value)
440
+ },
441
+ EmitAllChoosedDirection (curClickedPhase) {
442
+ let allChoosedDir = {
443
+ direction: this.preselectDirection,
444
+ peddirection: this.preselectPedDirection
445
+ }
446
+ this.$emit('handleClickCrossIcon', allChoosedDir, curClickedPhase)
447
+ this.drawPhaseIcon()
448
+ }
449
+ },
450
+ mounted () {
451
+ // this.init()
452
+ }
453
+ }
454
+ </script>