openatc-components 0.4.7 → 0.4.8

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 (509) 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 +94 -94
  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 +133 -128
  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 +456 -456
  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 +1451 -1451
  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 +220 -220
  118. package/package/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +534 -534
  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/OptimizeKanban/index.js +2 -0
  124. package/package/kisscomps/components/OptimizeKanban/index.vue +369 -0
  125. package/package/kisscomps/components/OverLap/OverLap.vue +237 -237
  126. package/package/kisscomps/components/OverLap/index.js +2 -2
  127. package/package/kisscomps/components/OverviewComponent/index.js +2 -2
  128. package/package/kisscomps/components/OverviewComponent/index.vue +798 -798
  129. package/package/kisscomps/components/PatternOptimize/PatternOptimize.vue +286 -286
  130. package/package/kisscomps/components/PatternOptimize/index.js +2 -2
  131. package/package/kisscomps/components/PatternStatus/PatternStatus.vue +1770 -1750
  132. package/package/kisscomps/components/PatternStatus/index.js +2 -2
  133. package/package/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  134. package/package/kisscomps/components/PatternWalkSvg/index.js +2 -2
  135. package/package/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  136. package/package/kisscomps/components/PhaseDirectionSelect/index.js +2 -2
  137. package/package/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  138. package/package/kisscomps/components/PhaseDirectionText/index.js +2 -2
  139. package/package/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  140. package/package/kisscomps/components/PhaseLegend/index.js +2 -2
  141. package/package/kisscomps/components/PhaseMarker/index.js +6 -6
  142. package/package/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  143. package/package/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  144. package/package/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  145. package/package/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  146. package/package/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  147. package/package/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  148. package/package/kisscomps/components/PhasePedSelect/index.js +2 -2
  149. package/package/kisscomps/components/PhasePedSelect/index.vue +206 -206
  150. package/package/kisscomps/components/SchemeConfig/SchemeConfig.vue +1005 -1005
  151. package/package/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +364 -364
  152. package/package/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  153. package/package/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  154. package/package/kisscomps/components/SchemeConfig/index.js +2 -2
  155. package/package/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +235 -235
  156. package/package/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  157. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +131 -131
  158. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/icon.vue +470 -470
  159. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +868 -868
  160. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  161. package/package/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  162. package/package/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  163. package/package/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +303 -303
  164. package/package/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +1207 -1207
  165. package/package/kisscomps/components/SchemeConfig/utils/thirdPartypermission.js +95 -95
  166. package/package/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  167. package/package/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  168. package/package/kisscomps/components/StageBord/StageBord.vue +303 -303
  169. package/package/kisscomps/components/StageBord/index.js +2 -2
  170. package/package/kisscomps/components/StageOptimize/StageOptimize.vue +315 -315
  171. package/package/kisscomps/components/StageOptimize/index.js +2 -2
  172. package/package/kisscomps/components/StageOptimize/index.vue +310 -0
  173. package/package/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  174. package/package/kisscomps/components/StageStatus/index.js +2 -2
  175. package/package/kisscomps/components/Stages/index.vue +319 -319
  176. package/package/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  177. package/package/kisscomps/components/SvgIcon/index.js +2 -2
  178. package/package/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  179. package/package/kisscomps/components/XRDDirSelector/index.js +2 -2
  180. package/package/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  181. package/package/kisscomps/components/XiaoKanban/index.vue +122 -122
  182. package/package/kisscomps/components/overView/index.vue +676 -676
  183. package/package/kisscomps/components/patternConfig/index.js +2 -2
  184. package/package/kisscomps/components/patternConfig/index.vue +798 -798
  185. package/package/kisscomps/components/patternConfig/pattern/patternTable.vue +599 -599
  186. package/package/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  187. package/package/kisscomps/components/patternConfig/planContent.vue +604 -604
  188. package/package/kisscomps/components/patternConfig/planMenu.vue +329 -329
  189. package/package/kisscomps/components/patternConfig/utils.js +152 -152
  190. package/package/kisscomps/components/patternList/index.js +2 -2
  191. package/package/kisscomps/components/patternList/patternList.vue +606 -601
  192. package/package/kisscomps/index.js +131 -131
  193. package/package/kissui.min.js +1 -1
  194. package/package.json +126 -126
  195. package/src/App.vue +24 -24
  196. package/src/EdgeMgr/EdgeModelBase.js +16 -16
  197. package/src/EdgeMgr/controller/crossDiagramMgr.js +125 -125
  198. package/src/api/authapi.js +31 -31
  199. package/src/api/config.js +21 -21
  200. package/src/api/control.js +110 -110
  201. package/src/api/cross.js +49 -49
  202. package/src/api/device.js +135 -135
  203. package/src/api/fault.js +66 -66
  204. package/src/api/index.js +24 -24
  205. package/src/api/login.js +46 -46
  206. package/src/api/optimize.js +72 -72
  207. package/src/api/param.js +165 -165
  208. package/src/api/passwdAssest.js +101 -101
  209. package/src/api/permission.js +33 -33
  210. package/src/api/route.js +171 -171
  211. package/src/api/template.js +27 -27
  212. package/src/assets/font/LICENSE.txt +202 -202
  213. package/src/assets/font/font.css +6 -6
  214. package/src/i18n/index.js +26 -26
  215. package/src/i18n/language/en.js +1474 -1474
  216. package/src/i18n/language/index.js +25 -25
  217. package/src/i18n/language/zh.js +1474 -1474
  218. package/src/icons/demo_index.html +8445 -8445
  219. package/src/icons/iconfont.css +1451 -1451
  220. package/src/icons/iconfont.json +2522 -2522
  221. package/src/icons/index.js +20 -20
  222. package/src/icons/svg/azimuthlocking.svg +26 -26
  223. package/src/icons/svg/bendi.svg +110 -110
  224. package/src/icons/svg/bujin.svg +36 -36
  225. package/src/icons/svg/connectBlue.svg +7 -7
  226. package/src/icons/svg/currentvolume.svg +0 -0
  227. package/src/icons/svg/custom-BRTlane.svg +40 -40
  228. package/src/icons/svg/custom-buslane.svg +40 -40
  229. package/src/icons/svg/custom-detector.svg +12 -12
  230. package/src/icons/svg/custom-east-bottom.svg +32 -32
  231. package/src/icons/svg/custom-east-top.svg +32 -32
  232. package/src/icons/svg/custom-ewped.svg +35 -35
  233. package/src/icons/svg/custom-nonmotorizedlane.svg +40 -40
  234. package/src/icons/svg/custom-north-left.svg +32 -32
  235. package/src/icons/svg/custom-north-right.svg +32 -32
  236. package/src/icons/svg/custom-peddetector.svg +17 -17
  237. package/src/icons/svg/custom-snped.svg +35 -35
  238. package/src/icons/svg/custom-south-left.svg +32 -32
  239. package/src/icons/svg/custom-south-right.svg +32 -32
  240. package/src/icons/svg/custom-tramlane.svg +40 -40
  241. package/src/icons/svg/custom-vehiclebranch.svg +40 -40
  242. package/src/icons/svg/custom-vehiclemainroad.svg +41 -41
  243. package/src/icons/svg/custom-west-bottom.svg +32 -32
  244. package/src/icons/svg/custom-west-top.svg +32 -32
  245. package/src/icons/svg/custom-xlped.svg +14 -14
  246. package/src/icons/svg/custom-xrped.svg +14 -14
  247. package/src/icons/svg/cutRed.svg +7 -7
  248. package/src/icons/svg/cycle.svg +0 -0
  249. package/src/icons/svg/dingzhouqi.svg +34 -34
  250. package/src/icons/svg/ganyingkongzhi.svg +30 -30
  251. package/src/icons/svg/guandeng.svg +81 -81
  252. package/src/icons/svg/huangshan.svg +71 -71
  253. package/src/icons/svg/maincontrol.svg +0 -0
  254. package/src/icons/svg/manualcontrolbackground.svg +51 -51
  255. package/src/icons/svg/manualcontrolbackground1.svg +62 -62
  256. package/src/icons/svg/manualcontrolbackgrounden.svg +62 -62
  257. package/src/icons/svg/model.svg +0 -0
  258. package/src/icons/svg/phasediff.svg +0 -0
  259. package/src/icons/svg/prioritycontrol.svg +21 -21
  260. package/src/icons/svg/quanhong.svg +86 -86
  261. package/src/icons/svg/shanghe.svg +11 -11
  262. package/src/icons/svg/shoudong.svg +103 -103
  263. package/src/icons/svg/tentativeplan.svg +28 -28
  264. package/src/icons/svg/time.svg +0 -0
  265. package/src/icons/svg/wuxianlan.svg +46 -46
  266. package/src/icons/svg/xiala.svg +11 -11
  267. package/src/icons/svg/xingrenguojie.svg +33 -33
  268. package/src/icons/svg/xitong.svg +89 -89
  269. package/src/icons/svg/youxian.svg +41 -41
  270. package/src/icons/svg/zizhukongzhi.svg +43 -43
  271. package/src/kisscomps/components/BoardCard/BoardCard.vue +133 -128
  272. package/src/kisscomps/components/BoardCard/index.js +2 -2
  273. package/src/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +123 -123
  274. package/src/kisscomps/components/ChannelRealtimeIntersection/index.js +2 -2
  275. package/src/kisscomps/components/Channelization/Channelization.vue +584 -584
  276. package/src/kisscomps/components/Channelization/index.js +2 -2
  277. package/src/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  278. package/src/kisscomps/components/ChannelizationFlowStatistic/index.js +2 -2
  279. package/src/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  280. package/src/kisscomps/components/ChannelizationWithInterface/index.js +2 -2
  281. package/src/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  282. package/src/kisscomps/components/CommonKanban/index.js +2 -2
  283. package/src/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +456 -456
  284. package/src/kisscomps/components/DirectionListConfiguration/index.js +2 -2
  285. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  286. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  287. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  288. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  289. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  290. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  291. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  292. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  293. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  294. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  295. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  296. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  297. package/src/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  298. package/src/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  299. package/src/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  300. package/src/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  301. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  302. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  303. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  304. package/src/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  305. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  306. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  307. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  308. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  309. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +368 -368
  310. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  311. package/src/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  312. package/src/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +1005 -1005
  313. package/src/kisscomps/components/DrawChannelization/drawsvg/index.vue +110 -110
  314. package/src/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  315. package/src/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  316. package/src/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +172 -172
  317. package/src/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  318. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  319. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  320. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  321. package/src/kisscomps/components/DrawChannelization/index.js +2 -2
  322. package/src/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  323. package/src/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  324. package/src/kisscomps/components/ExpendConfig/index.js +2 -2
  325. package/src/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  326. package/src/kisscomps/components/FaultDetailModal/index.js +2 -2
  327. package/src/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +158 -158
  328. package/src/kisscomps/components/IntersectionDirectionSelection/index.js +2 -2
  329. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  330. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  331. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  332. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  333. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  334. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  335. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  336. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  337. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +1302 -1302
  338. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  339. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  340. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  341. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  342. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  343. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  344. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  345. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  346. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  347. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  348. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  349. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  350. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  351. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  352. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  353. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  354. package/src/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +1451 -1451
  355. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  356. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +196 -196
  357. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  358. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  359. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  360. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +115 -115
  361. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  362. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  363. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +219 -219
  364. package/src/kisscomps/components/IntersectionMap/crossDirection/utils.js +84 -84
  365. package/src/kisscomps/components/IntersectionMap/index.js +2 -2
  366. package/src/kisscomps/components/IntersectionMap/intersectionmap.vue +220 -220
  367. package/src/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +534 -534
  368. package/src/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  369. package/src/kisscomps/components/KanBan/index.js +2 -2
  370. package/src/kisscomps/components/KanBan/kanban.vue +231 -231
  371. package/src/kisscomps/components/MessageBox/index.vue +96 -96
  372. package/src/kisscomps/components/OverLap/OverLap.vue +237 -237
  373. package/src/kisscomps/components/OverLap/index.js +2 -2
  374. package/src/kisscomps/components/OverviewComponent/index.js +2 -2
  375. package/src/kisscomps/components/OverviewComponent/index.vue +798 -798
  376. package/src/kisscomps/components/PatternOptimize/PatternOptimize.vue +286 -286
  377. package/src/kisscomps/components/PatternOptimize/index.js +2 -2
  378. package/src/kisscomps/components/PatternStatus/PatternStatus.vue +1770 -1750
  379. package/src/kisscomps/components/PatternStatus/index.js +2 -2
  380. package/src/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  381. package/src/kisscomps/components/PatternWalkSvg/index.js +2 -2
  382. package/src/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  383. package/src/kisscomps/components/PhaseDirectionSelect/index.js +2 -2
  384. package/src/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  385. package/src/kisscomps/components/PhaseDirectionText/index.js +2 -2
  386. package/src/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  387. package/src/kisscomps/components/PhaseLegend/index.js +2 -2
  388. package/src/kisscomps/components/PhaseMarker/index.js +6 -6
  389. package/src/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  390. package/src/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  391. package/src/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  392. package/src/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  393. package/src/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  394. package/src/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  395. package/src/kisscomps/components/PhasePedSelect/index.js +2 -2
  396. package/src/kisscomps/components/PhasePedSelect/index.vue +206 -206
  397. package/src/kisscomps/components/SchemeConfig/SchemeConfig.vue +1005 -1005
  398. package/src/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +364 -364
  399. package/src/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  400. package/src/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  401. package/src/kisscomps/components/SchemeConfig/index.js +2 -2
  402. package/src/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +235 -235
  403. package/src/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  404. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +131 -131
  405. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/icon.vue +470 -470
  406. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +868 -868
  407. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  408. package/src/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  409. package/src/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  410. package/src/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +303 -303
  411. package/src/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +1207 -1207
  412. package/src/kisscomps/components/SchemeConfig/utils/thirdPartypermission.js +95 -95
  413. package/src/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  414. package/src/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  415. package/src/kisscomps/components/StageBord/StageBord.vue +303 -303
  416. package/src/kisscomps/components/StageBord/index.js +2 -2
  417. package/src/kisscomps/components/StageOptimize/StageOptimize.vue +315 -315
  418. package/src/kisscomps/components/StageOptimize/index.js +2 -2
  419. package/src/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  420. package/src/kisscomps/components/StageStatus/index.js +2 -2
  421. package/src/kisscomps/components/Stages/index.vue +319 -319
  422. package/src/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  423. package/src/kisscomps/components/SvgIcon/index.js +2 -2
  424. package/src/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  425. package/src/kisscomps/components/XRDDirSelector/index.js +2 -2
  426. package/src/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  427. package/src/kisscomps/components/XiaoKanban/index.vue +122 -122
  428. package/src/kisscomps/components/overView/index.vue +676 -676
  429. package/src/kisscomps/components/patternConfig/index.js +2 -2
  430. package/src/kisscomps/components/patternConfig/index.vue +798 -798
  431. package/src/kisscomps/components/patternConfig/pattern/patternTable.vue +599 -599
  432. package/src/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  433. package/src/kisscomps/components/patternConfig/planContent.vue +604 -604
  434. package/src/kisscomps/components/patternConfig/planMenu.vue +329 -329
  435. package/src/kisscomps/components/patternConfig/utils.js +152 -152
  436. package/src/kisscomps/components/patternList/index.js +2 -2
  437. package/src/kisscomps/components/patternList/patternList.vue +606 -601
  438. package/src/kisscomps/index.js +131 -131
  439. package/src/lib/publicjs/ArryListUtil.js +38 -38
  440. package/src/lib/publicjs/HttpurlMgr.js +45 -45
  441. package/src/lib/publicjs/KissApi.js +158 -158
  442. package/src/lib/publicjs/KissWSSub/Heartcheck.js +128 -128
  443. package/src/lib/publicjs/KissWSSub/KissWsSub.js +91 -91
  444. package/src/lib/publicjs/KissWSSub/KissWsSubByType.js +152 -152
  445. package/src/lib/publicjs/KissWSSub/SimuWsSubByType.js +44 -44
  446. package/src/lib/publicjs/KissWSSub/Sub.js +51 -51
  447. package/src/lib/publicjs/KissWSSub/SubChannel.js +119 -119
  448. package/src/lib/publicjs/basecomponents.js +65 -65
  449. package/src/lib/publicjs/localStorage.js +112 -112
  450. package/src/lib/publicjs/objdeepcopy.js +32 -32
  451. package/src/lib/publicjs/pageScroll.js +30 -30
  452. package/src/lib/publicjs/passwdAssest.js +101 -101
  453. package/src/lib/publicjs/styleclassfactory.js +32 -32
  454. package/src/main.js +51 -51
  455. package/src/node_modules/.package_versions.json +1 -0
  456. package/src/router/index.js +63 -63
  457. package/src/store/getters.js +16 -16
  458. package/src/store/index.js +26 -26
  459. package/src/store/modules/globalParam.js +67 -67
  460. package/src/utils/ControlFormat.js +68 -68
  461. package/src/utils/RingDataModel.js +335 -335
  462. package/src/utils/auth.js +199 -199
  463. package/src/utils/conflct.js +268 -268
  464. package/src/utils/conflictList.js +87 -87
  465. package/src/utils/dateFormat.js +41 -41
  466. package/src/utils/errorcode.js +227 -227
  467. package/src/utils/fault.js +196 -196
  468. package/src/utils/faultcode.js +209 -209
  469. package/src/utils/index.js +69 -69
  470. package/src/utils/pedphasedesc.js +119 -119
  471. package/src/utils/phaseList.js +203 -203
  472. package/src/utils/phasedesc.js +144 -144
  473. package/src/utils/responseMessage.js +21 -21
  474. package/src/utils/validate.js +43 -43
  475. package/src/views/customchannelization.vue +49 -49
  476. package/src/views/home.1.vue +479 -479
  477. package/src/views/home.vue +93 -93
  478. package/src/views/intersection.vue +522 -522
  479. package/src/views/intersection2.vue +328 -328
  480. package/src/views/overView.vue +63 -63
  481. package/src/views/patternConfig.vue +14792 -14792
  482. package/src/views/schemeconfig.vue +206 -206
  483. package/static/apiconfig.json +461 -461
  484. package/static/styles/channelizatioon.scss +433 -433
  485. package/static/styles/common.scss +30 -30
  486. package/static/styles/commonkanban.scss +168 -168
  487. package/static/styles/dark/index.scss +2 -2
  488. package/static/styles/dark/theme/element-dark.scss +44 -44
  489. package/static/styles/index.scss +84 -84
  490. package/static/styles/intersection.scss +180 -180
  491. package/static/styles/light/index.scss +2 -2
  492. package/static/styles/light/theme/element-light.scss +44 -44
  493. package/static/styles/overview.scss +146 -146
  494. package/static/styles/patternConfig.scss +56 -56
  495. package/static/styles/phasePedSelect.scss +71 -71
  496. package/static/styles/schemeconfig.scss +552 -552
  497. package/static/styles/stages.scss +57 -57
  498. package/static/styles/uiComponents.scss +57 -57
  499. package/static/styles/xiaokanban.scss +61 -61
  500. package/static/token.json +2 -2
  501. package/test/e2e/custom-assertions/elementCount.js +27 -27
  502. package/test/e2e/nightwatch.conf.js +46 -46
  503. package/test/e2e/runner.js +48 -48
  504. package/test/e2e/specs/test.js +19 -19
  505. package/test/unit/.eslintrc +7 -7
  506. package/test/unit/jest.conf.js +30 -30
  507. package/test/unit/setup.js +3 -3
  508. package/test/unit/specs/HelloWorld.spec.js +11 -11
  509. package/package/kissui.js +0 -216608
@@ -1,599 +1,599 @@
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="app-container" ref="pattern-container">
14
- <el-table :data="newPatternList" :max-height="tableHeight" id="footerBtn" :show-header="isShowTableHeader">
15
- <el-table-column :type="isAllowedExpand ? 'expand' : ''" v-if="isAllowedExpand">
16
- <template slot-scope="scope">
17
- <div v-if="isAllowedExpand && isSingleCrossMode" class="optimizetype">
18
- <span>{{$t('openatccomponents.pattern.optimizetype')}}</span>
19
- <el-select v-model="value" clearable :placeholder="$t('openatccomponents.common.select')">
20
- <el-option
21
- v-for="item in typeOptions"
22
- :key="item.value"
23
- :label="$t('openatccomponents.overview.type' + item.value)"
24
- :value="item.value"
25
- >
26
- </el-option>
27
- </el-select>
28
- <span class="optimiNum">{{$t('openatccomponents.pattern.optimizecycle')}}</span>
29
- <el-input v-model="optimizecycle" clearable :placeholder="$t('openatccomponents.common.enter')"></el-input>
30
- <el-button type="primary" @click="onOptimizeClick(scope.row, scope.$index)">{{$t('openatccomponents.pattern.inoptimize')}}</el-button>
31
- </div>
32
- <div class="components-container board">
33
- <XiaoKanBan v-for="n in scope.row.ringCount"
34
- :key="n"
35
- :isSingleCrossMode="isSingleCrossMode"
36
- class="kanban todo"
37
- :list="scope.row.rings[n-1]"
38
- :header-text="$t('openatccomponents.pattern.ring') +' '+n"
39
- :index="scope.$index"
40
- @fatherMethod="fatherMethod"/>
41
- </div>
42
- </template>
43
- </el-table-column>
44
- <el-table-column align="center" label="No" width="45" minWidth="40" v-if="isShowColumn('no')">
45
- <template slot-scope="scope">
46
- <span>{{scope.$index+1}}</span>
47
- </template>
48
- </el-table-column>
49
- <el-table-column align="center" :label="$t('openatccomponents.greenwaveoptimize.deviceid')" width="100" minWidth="40" v-if="isShowColumn('agentid')">
50
- <template slot-scope="scope">
51
- <span>{{scope.row.agentid}}</span>
52
- </template>
53
- </el-table-column>
54
- <el-table-column align="center" :label="$t('openatccomponents.overview.crossname')" width="120" minWidth="40" v-if="isShowColumn('name')">
55
- <template slot-scope="scope">
56
- <span>{{getDevName(scope.row)}}</span>
57
- </template>
58
- </el-table-column>
59
- <el-table-column align="center" :label="$t('openatccomponents.greenwaveoptimize.period')" width="100" minWidth="40" v-if="isShowColumn('period')">
60
- <template slot-scope="scope">
61
- <span>{{getPeriod(scope.row)}}</span>
62
- </template>
63
- </el-table-column>
64
- <el-table-column property="isValid" :label="$t('openatccomponents.token.isValid')" align="center" width="80" prop="isused" v-if="isShowColumn('isused')">
65
- <template slot-scope="scope">
66
- <el-switch
67
- style="padding-left: 5px;"
68
- v-model="scope.row.isused"
69
- active-color="#299BCC">
70
- </el-switch>
71
- </template>
72
- </el-table-column>
73
- <el-table-column
74
- :label="$t('openatccomponents.greenwaveoptimize.pattern')"
75
- width="120"
76
- align="center"
77
- v-if="isShowColumn('patternid')">
78
- <template slot-scope="scope">
79
- <el-select
80
- v-model="scope.row.patternid"
81
- size="small"
82
- :loading="loading"
83
- @focus="getCurPattern(scope.row.agentid)"
84
- @change="changeCurPattern(scope.row,$event)">
85
- <el-option v-for="option in (scope.row.allPatterns)"
86
- :key="option.patternid"
87
- :label="option.patterndesc"
88
- :value="option.patternid">
89
- <span>{{ option.patterndesc }}</span>
90
- </el-option>
91
- </el-select>
92
- <span></span>
93
- </template>
94
- </el-table-column>
95
- <el-table-column align="center" :label="$t('openatccomponents.greenwaveoptimize.offset')" width="85" prop="offset" v-if="isShowColumn('offset')">
96
- <template slot-scope="scope">
97
- <el-input-number v-if="isAllowedExpand" :controls="false" :min="0" :step="1" v-model.number="scope.row.offset" size="small" style="width:70%;"></el-input-number>
98
- <span v-else>
99
- {{ scope.row.offset }}
100
- </span>
101
- </template>
102
- </el-table-column>
103
- <el-table-column align="center" :label="$t('openatccomponents.greenwaveoptimize.cycle')" width="60" prop="cycle" v-if="isShowColumn('cycle')">
104
- </el-table-column>
105
- <el-table-column align="center" :label="$t('openatccomponents.pattern.plan')" v-if="isShowColumn('pattern')">
106
- <template slot-scope="scope">
107
- <div class="pattern-figure">
108
- <pattern-list
109
- v-if="getControlType(scope.row) === 'ring'"
110
- :patternStatusList="JSON.parse(JSON.stringify(scope.row.rings))"
111
- :cycles="scope.row.cycle"
112
- :phaseList="JSON.parse(JSON.stringify(scope.row.currPhase))"
113
- :contrloType="getControlType(scope.row)"
114
- >
115
- </pattern-list>
116
- <pattern-list
117
- v-else
118
- :patternId="scope.row.patternid"
119
- :contrloType="getControlType(scope.row)"
120
- :index="scope.$index"
121
- :cycleChange="false"
122
- :stagesChange="getSelectedPattern(scope.row).stagesList"
123
- :patternStatusList="getSelectedPattern(scope.row).rings"
124
- :patternList="JSON.parse(JSON.stringify(scope.row.allPatterns))"
125
- :allPatternList="JSON.parse(JSON.stringify(scope.row.allPatterns))"
126
- :cycles="scope.row.cycle"
127
- :phaseList="JSON.parse(JSON.stringify(scope.row.currPhase))"
128
- :agentId="scope.row.agentid"
129
- :showBarrier="false">
130
- </pattern-list>
131
- </div>
132
- </template>
133
- </el-table-column>
134
- </el-table>
135
- </div>
136
- </template>
137
-
138
- <script>
139
- import XiaoKanBan from '../../XiaoKanBan/index.vue'
140
- // import { getPatternList } from '../../../../api/route'
141
- import { getIntersectionInfo } from '../../../../api/template'
142
- import { getMessageByCode } from '../../../../utils/responseMessage'
143
- import { getDuration } from '../../../../api/cross'
144
- // import { getDirName } from '../../../components/SelectCrossPhase/utils.js'
145
- export default {
146
- name: 'PatternTable',
147
- components: {
148
- XiaoKanBan
149
- },
150
- props: {
151
- devicesData: {
152
- type: Array,
153
- default: () => []
154
- },
155
- optList: {
156
- type: Array
157
- },
158
- isSingleCrossMode: {
159
- type: Boolean,
160
- default: false
161
- },
162
- tableColums: {
163
- type: Array,
164
- default: () => []
165
- },
166
- isAllowedExpand: {
167
- type: Boolean,
168
- default: true
169
- },
170
- isShowGenerateButton: {
171
- type: Boolean,
172
- default: true
173
- },
174
- isShowTableHeader: {
175
- type: Boolean,
176
- default: true
177
- },
178
- maxTableHeight: {
179
- type: Number,
180
- default: 200
181
- }
182
- },
183
- data () {
184
- return {
185
- typeOptions: [{
186
- value: 'flow-split-opt'
187
- }, {
188
- value: 'cycle-opt'
189
- }],
190
- value: 'flow-split-opt',
191
- optimizecycle: 0,
192
- controlType: 'stage',
193
- loading: true,
194
- tableHeight: 460,
195
- screenHeight: window.innerHeight, // 屏幕高度
196
- newPatternList: []
197
- }
198
- },
199
- created () {
200
- },
201
- watch: {
202
- maxTableHeight: function () {
203
- this.$nextTick(() => {
204
- this.tableHeight = this.maxTableHeight // 动态更新高度
205
- })
206
- },
207
- optList: {
208
- handler: function (val) {
209
- if (val && val.length > 0) {
210
- // for () {
211
-
212
- // }
213
- }
214
- },
215
- deep: true
216
- },
217
- newPatternList: {
218
- handler: function (val) {
219
- console.log('onNewPatternListChange', val)
220
- this.$emit('onNewPatternListChange', val)
221
- },
222
- deep: true
223
- }
224
- },
225
- mounted: function () {
226
- },
227
- methods: {
228
- onOptimizeClick (row, index) {
229
- let msg = this.$t('openatccomponents.pattern.algorithmEngineOptimization')
230
- const loading = this.$loading({
231
- lock: true,
232
- text: msg,
233
- spinner: 'el-icon-loading',
234
- background: 'rgba(0, 0, 0, 0.7)'
235
- })
236
- setTimeout(() => {
237
- loading.close()
238
- this.handeleOptimizeClick(row, index)
239
- }, 1000)
240
- },
241
- handeleOptimizeClick (row, index) {
242
- let newPha = []
243
- for (let i = 0; i < row.rings.length; i++) {
244
- newPha.push(...row.rings[i])
245
- }
246
- let phaseData = newPha.map(item => {
247
- return {
248
- id: item.id,
249
- flowperhour: item.flowperhour,
250
- saturation: item.saturation
251
- }
252
- })
253
- let patternList = row.allPatterns
254
- if (row.feature && row.feature.patternList && row.feature.patternList.length > 0) {
255
- patternList = row.feature.patternList
256
- }
257
- let pattern = patternList.filter((item) => item.id === row.patternid)[0]
258
- let phaseList = row.currPhase
259
- let reqData = {
260
- 'type': this.value,
261
- 'optcycle': this.optimizecycle ? this.optimizecycle : 0,
262
- 'phaseList': phaseList,
263
- 'pattern': pattern,
264
- 'phases': phaseData
265
- }
266
- let isValidata = []
267
- for (let j = 0; j < newPha.length; j++) {
268
- let comNum = (newPha[j].length / 4) * 1700 * 0.8
269
- isValidata.push(newPha[j].flowperhour > comNum)
270
- }
271
- if (isValidata.includes(true)) {
272
- this.$confirm(this.$t('openatccomponents.overview.maxFlow'),
273
- this.$t('openatccomponents.common.alarm'), {
274
- confirmButtonText: this.$t('openatccomponents.common.confirm'),
275
- cancelButtonText: this.$t('openatccomponents.common.cancel'),
276
- type: 'warning'
277
- }).then(() => {
278
- this.doOptimize(row, index, reqData)
279
- }).catch(() => {})
280
- } else {
281
- this.doOptimize(row, index, reqData)
282
- }
283
- },
284
- doOptimize (row, index, reqData) {
285
- // let _this = this
286
- getDuration(reqData).then(data => {
287
- if (data.data.success) {
288
- this.$message({
289
- type: 'success',
290
- message: this.$t('openatccomponents.pattern.success')
291
- })
292
- // let cycle = 0
293
- for (let i = 0; i < row.rings.length; i++) {
294
- for (let j = 0; j < row.rings[i].length; j++) {
295
- for (let h = 0; h < data.data.data.phase.length; h++) {
296
- if (row.rings[i][j].id === data.data.data.phase[h].id) {
297
- row.rings[i][j].value = data.data.data.phase[h].duration
298
- // cycle = cycle + row.rings[i][j].value
299
- }
300
- }
301
- }
302
- }
303
- }
304
- }).catch(error => {
305
- console.log(error)
306
- })
307
- },
308
- isShowColumn (colum) {
309
- let res = true
310
- if (this.tableColums && this.tableColums.length > 0) {
311
- res = this.tableColums.find(item => item === colum)
312
- }
313
- return res
314
- },
315
- getPeriod (row) {
316
- let period = row.timeperiodrange || row.period
317
- let res = ''
318
- if (period && period.length > 0) {
319
- res = period[0].substring(0, 5) + '-' + period[1].substring(0, 5)
320
- }
321
- return res
322
- },
323
- getDevName (row) {
324
- let res = row.name ? row.name : ''
325
- if (this.devicesData) {
326
- let dev = this.devicesData.find(item => item.agentid === row.agentid)
327
- res = dev ? dev.name : res
328
- }
329
- return res
330
- },
331
- onPatternTable (routeData, patternList, phaseList) {
332
- if (patternList.length === 0) {
333
- // this.$message.error('方案为空!')
334
- return
335
- }
336
- if (phaseList.length === 0) {
337
- // this.$message.error('相位为空!')
338
- return
339
- }
340
- // this.routeData = routeData
341
- // this.patternList = patternList
342
- // this.phaseList = phaseList
343
- this.handlePatternList(routeData, patternList, phaseList)
344
- },
345
- // 依据anengid获取设备信息,同时兼容单路口数据按序index取值
346
- getDevFromDevsOrIndex (devs, agentid, index) {
347
- let res
348
- // check special
349
- let isSingleCrossMode = false
350
- if (devs && devs.length > 1 && devs[0].agentid === devs[1].agentid) {
351
- isSingleCrossMode = true
352
- // check errData
353
- if (index === undefined || index === null) {
354
- console.log('getDevFromDevsOrIndex Err: index is null')
355
- }
356
- }
357
- if (!isSingleCrossMode) {
358
- res = devs.filter(ist => ist.agentid === agentid)[0]
359
- } else {
360
- res = devs[index]
361
- console.log('getDevByIndex:', res)
362
- }
363
- return res
364
- },
365
- handlePatternList (routeData, patternList, phaseList) {
366
- this.newPatternList = []
367
- let devs = routeData.devs
368
- let index = 0
369
- for (let pattern of patternList) {
370
- let obj = {}
371
- let id = pattern.agentid
372
- obj.agentid = id
373
- let count = [] // 计算相位有几个环
374
- if (pattern.feature !== undefined && pattern.feature.patternList.length !== 0) {
375
- let currPatternList = pattern.feature.patternList
376
- // let dev = devs.filter(ist => ist.agentid === id)[0]
377
- let dev = this.getDevFromDevsOrIndex(devs, id, index)
378
- index = index + 1
379
- let patternId = dev.patternid
380
- let currPattern
381
- if (Array.isArray(currPatternList)) {
382
- currPattern = currPatternList.filter(cpl => cpl.id === patternId)[0]
383
- if (!currPattern) {
384
- currPattern = currPatternList[0]
385
- }
386
- } else {
387
- currPattern = currPatternList
388
- }
389
- if (!currPattern) {
390
- currPattern = currPatternList[0]
391
- }
392
- // let currPattern = currPatternList.filter(cpl => cpl.id === patternId)[0]
393
- if (currPattern.desc === '') {
394
- obj.desc = this.$t('openatccomponents.greenwaveoptimize.pattern') + currPattern.id
395
- } else {
396
- obj.desc = currPattern.desc
397
- }
398
- obj = {...obj, ...dev}
399
- obj.id = currPattern.id
400
- obj.offset = currPattern.offset
401
- obj.cycle = currPattern.cycle
402
- obj.patternId = currPattern.id
403
- obj.patternid = currPattern.id
404
- obj.patternDesc = currPattern.desc === '' ? `${this.$t('openatccomponents.greenwaveoptimize.pattern')}${currPattern.id}` : currPattern.desc
405
- obj.allPatterns = currPatternList.map(ele => {
406
- let patterndesc = ele.desc === '' ? `${this.$t('openatccomponents.greenwaveoptimize.pattern')}${currPattern.id}` : ele.desc
407
- return {
408
- patternid: ele.id,
409
- patterndes: ele.desc,
410
- patterndesc: patterndesc,
411
- ...ele
412
- }
413
- })
414
- let rings = currPattern.rings
415
- let currPhase = phaseList.filter(phl => phl.agentid === id)[0].feature.phaseList
416
- obj.currPhase = currPhase
417
- obj.phaseList = currPhase
418
- // 计算有几个环
419
- for (let ring of rings) {
420
- if (ring.length === 0) continue
421
- for (let rr of ring) {
422
- rr.desc = []
423
- let targetPhase = currPhase.filter(curp => curp.id === rr.id)[0]
424
- if (!targetPhase) continue
425
- let direction = targetPhase.direction // 相位方向集合
426
- let phaseRing = currPhase.filter(curp => curp.id === rr.id)[0].ring
427
- count.push(phaseRing)
428
- for (let dir of direction) {
429
- let obj = {}
430
- obj.id = dir
431
- rr.desc.push(obj)
432
- }
433
- }
434
- }
435
- obj.rings = rings
436
- }
437
- let ringCount = Array.from(new Set(count)) // 去除数组重复的元素
438
- ringCount = ringCount.sort(this.sortNumbers) // 把数组中的值按照从小到大的顺序重新排序
439
- obj.ringCount = ringCount
440
- this.newPatternList.push(obj)
441
- }
442
- console.log('handlePatternList newPatternList', this.newPatternList)
443
- },
444
- sortNumbers (a, b) {
445
- return a - b
446
- },
447
- fatherMethod (val) {
448
- let index = val.index
449
- let cycle = val.cycle
450
- this.newPatternList[index].cycle = cycle
451
- },
452
- changeCurPattern (row, curPatternid) {
453
- // 修改当前方案(allPatterns: 所有可选项)
454
- const data = {
455
- agentid: row.agentid,
456
- patternid: curPatternid,
457
- patterndes: row.allPatterns.filter(ele => ele.patternid === curPatternid)[0].patterndes,
458
- allPatterns: row.allPatterns
459
- }
460
- row.desc = data.patternDesc
461
- row.patternId = data.patternid
462
- row.patternid = data.patternid
463
- row.patterndes = data.patterndes
464
- row.allPatterns = data.allPatterns
465
- row.patternid = data.patternid
466
- let selectPattern = row.allPatterns.filter(item => item.patternid === row.patternid)[0]
467
- let res = this.getRings(selectPattern.rings, row.phaseList)
468
- row.rings = res.rings
469
- row.ringCount = res.ringCount
470
- // row.rings = selectPattern.rings
471
- row.cycle = selectPattern.cycle
472
- row.offset = selectPattern.offset
473
- row.currPhase = row.phaseList
474
- },
475
- getRings (ringsList, phaseList) {
476
- let res = {}
477
- let rings = JSON.parse(JSON.stringify(ringsList))
478
- let count = []
479
- // 计算有几个环
480
- for (let ring of rings) {
481
- if (ring.length === 0) continue
482
- for (let rr of ring) {
483
- rr.desc = []
484
- let direction = phaseList.filter(curp => curp.id === rr.id)[0].direction // 相位方向集合
485
- let phaseRing = phaseList.filter(curp => curp.id === rr.id)[0].ring
486
- count.push(phaseRing)
487
- for (let dir of direction) {
488
- let obj = {}
489
- obj.id = dir
490
- rr.desc.push(obj)
491
- }
492
- }
493
- }
494
- let ringCount = Array.from(new Set(count)) // 去除数组重复的元素
495
- ringCount = ringCount.sort(this.sortNumbers) // 把数组中的值按照从小到大的顺序重新排序
496
- res = {
497
- rings: rings,
498
- ringCount: ringCount
499
- }
500
- return res
501
- },
502
- getControlType (row) {
503
- let contrloType = 'ring'
504
- let allPatternList = row.feature && row.feature.patternList ? row.feature.patternList : row.allPatterns
505
- if (
506
- !allPatternList[0].contrloType &&
507
- allPatternList[0].rings.length > 0
508
- ) {
509
- contrloType = 'ring'
510
- } else if (
511
- !allPatternList[0].contrloType &&
512
- allPatternList[0].rings.length === 0
513
- ) {
514
- contrloType = 'stage'
515
- } else {
516
- contrloType = allPatternList[0].contrloType
517
- }
518
- let res = contrloType
519
- return res
520
- },
521
- getSelectedPattern (row) {
522
- let res = []
523
- let patternList = row.feature && row.feature.patternList ? row.feature.patternList : row.allPatterns
524
- let pattern = patternList.find(item => item.id === row.patternid)
525
- if (pattern) {
526
- res = JSON.parse(JSON.stringify(pattern))
527
- }
528
- return res
529
- },
530
- getCurPattern (agentid) {
531
- // 获取当前设备所有可选方案
532
- this.loading = true
533
- let _this = this
534
- getIntersectionInfo(agentid).then(res => {
535
- this.loading = false
536
- if (!res.data.success) {
537
- let commomMsg = this.$t('openatccomponents.overview.signalID') + ' : ' + agentid
538
- let msg = getMessageByCode(res.data.code, this.$i18n.locale)
539
- if (res.data.data) {
540
- // 子类型错误
541
- let childErrorCode = res.data.data.errorCode
542
- if (childErrorCode) {
543
- let childerror = getMessageByCode(res.data.data.errorCode, this.$i18n.locale)
544
- msg = msg + ' - ' + childerror
545
- }
546
- }
547
- msg = msg + ' - ' + commomMsg
548
- this.$message.error(msg)
549
- return
550
- }
551
- let allPatternList = res.data.data.param.patternList
552
- _this.newPatternList.forEach(ele => {
553
- if (ele.agentid === agentid) {
554
- ele.allPatterns = allPatternList.map(ele => {
555
- return {
556
- ...ele,
557
- patternid: ele.id,
558
- patterndes: ele.desc,
559
- patterndesc: ele.desc === '' ? `${_this.$t('openatccomponents.greenwaveoptimize.pattern')}${ele.id}` : ele.desc
560
- }
561
- })
562
- }
563
- })
564
- })
565
- }
566
- }
567
- }
568
- </script>
569
-
570
- <style lang="scss">
571
- .board {
572
- width: 100%;
573
- margin-left: 10PX;
574
- display: flex;
575
- justify-content: flex-start;
576
- gap: 10PX;
577
- align-items: flex-start;
578
- }
579
- .optimizetype{
580
- font-size: 14PX;
581
- display: flex;
582
- justify-content: flex-start;
583
- align-items: center;
584
- gap: 10PX;
585
- padding-left: 20PX;
586
- .el-input {
587
- width: 120PX;
588
- }
589
- // .el-select{
590
- // width: 170PX;
591
- // }
592
- // .el-button {
593
- // margin-left: 10PX;
594
- // }
595
- .optimiNum {
596
- padding-left: 10PX;
597
- }
598
- }
599
- </style>
1
+ /**
2
+ * Copyright (c) 2020 kedacom
3
+ * OpenATC is licensed under Mulan PSL v2.
4
+ * You can use this software according to the terms and conditions of the Mulan PSL v2.
5
+ * You may obtain a copy of Mulan PSL v2 at:
6
+ * http://license.coscl.org.cn/MulanPSL2
7
+ * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
8
+ * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
9
+ * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
10
+ * See the Mulan PSL v2 for more details.
11
+ **/
12
+ <template>
13
+ <div class="app-container" ref="pattern-container">
14
+ <el-table :data="newPatternList" :max-height="tableHeight" id="footerBtn" :show-header="isShowTableHeader">
15
+ <el-table-column :type="isAllowedExpand ? 'expand' : ''" v-if="isAllowedExpand">
16
+ <template slot-scope="scope">
17
+ <div v-if="isAllowedExpand && isSingleCrossMode" class="optimizetype">
18
+ <span>{{$t('openatccomponents.pattern.optimizetype')}}</span>
19
+ <el-select v-model="value" clearable :placeholder="$t('openatccomponents.common.select')">
20
+ <el-option
21
+ v-for="item in typeOptions"
22
+ :key="item.value"
23
+ :label="$t('openatccomponents.overview.type' + item.value)"
24
+ :value="item.value"
25
+ >
26
+ </el-option>
27
+ </el-select>
28
+ <span class="optimiNum">{{$t('openatccomponents.pattern.optimizecycle')}}</span>
29
+ <el-input v-model="optimizecycle" clearable :placeholder="$t('openatccomponents.common.enter')"></el-input>
30
+ <el-button type="primary" @click="onOptimizeClick(scope.row, scope.$index)">{{$t('openatccomponents.pattern.inoptimize')}}</el-button>
31
+ </div>
32
+ <div class="components-container board">
33
+ <XiaoKanBan v-for="n in scope.row.ringCount"
34
+ :key="n"
35
+ :isSingleCrossMode="isSingleCrossMode"
36
+ class="kanban todo"
37
+ :list="scope.row.rings[n-1]"
38
+ :header-text="$t('openatccomponents.pattern.ring') +' '+n"
39
+ :index="scope.$index"
40
+ @fatherMethod="fatherMethod"/>
41
+ </div>
42
+ </template>
43
+ </el-table-column>
44
+ <el-table-column align="center" label="No" width="45" minWidth="40" v-if="isShowColumn('no')">
45
+ <template slot-scope="scope">
46
+ <span>{{scope.$index+1}}</span>
47
+ </template>
48
+ </el-table-column>
49
+ <el-table-column align="center" :label="$t('openatccomponents.greenwaveoptimize.deviceid')" width="100" minWidth="40" v-if="isShowColumn('agentid')">
50
+ <template slot-scope="scope">
51
+ <span>{{scope.row.agentid}}</span>
52
+ </template>
53
+ </el-table-column>
54
+ <el-table-column align="center" :label="$t('openatccomponents.overview.crossname')" width="120" minWidth="40" v-if="isShowColumn('name')">
55
+ <template slot-scope="scope">
56
+ <span>{{getDevName(scope.row)}}</span>
57
+ </template>
58
+ </el-table-column>
59
+ <el-table-column align="center" :label="$t('openatccomponents.greenwaveoptimize.period')" width="100" minWidth="40" v-if="isShowColumn('period')">
60
+ <template slot-scope="scope">
61
+ <span>{{getPeriod(scope.row)}}</span>
62
+ </template>
63
+ </el-table-column>
64
+ <el-table-column property="isValid" :label="$t('openatccomponents.token.isValid')" align="center" width="80" prop="isused" v-if="isShowColumn('isused')">
65
+ <template slot-scope="scope">
66
+ <el-switch
67
+ style="padding-left: 5px;"
68
+ v-model="scope.row.isused"
69
+ active-color="#299BCC">
70
+ </el-switch>
71
+ </template>
72
+ </el-table-column>
73
+ <el-table-column
74
+ :label="$t('openatccomponents.greenwaveoptimize.pattern')"
75
+ width="120"
76
+ align="center"
77
+ v-if="isShowColumn('patternid')">
78
+ <template slot-scope="scope">
79
+ <el-select
80
+ v-model="scope.row.patternid"
81
+ size="small"
82
+ :loading="loading"
83
+ @focus="getCurPattern(scope.row.agentid)"
84
+ @change="changeCurPattern(scope.row,$event)">
85
+ <el-option v-for="option in (scope.row.allPatterns)"
86
+ :key="option.patternid"
87
+ :label="option.patterndesc"
88
+ :value="option.patternid">
89
+ <span>{{ option.patterndesc }}</span>
90
+ </el-option>
91
+ </el-select>
92
+ <span></span>
93
+ </template>
94
+ </el-table-column>
95
+ <el-table-column align="center" :label="$t('openatccomponents.greenwaveoptimize.offset')" width="85" prop="offset" v-if="isShowColumn('offset')">
96
+ <template slot-scope="scope">
97
+ <el-input-number v-if="isAllowedExpand" :controls="false" :min="0" :step="1" v-model.number="scope.row.offset" size="small" style="width:70%;"></el-input-number>
98
+ <span v-else>
99
+ {{ scope.row.offset }}
100
+ </span>
101
+ </template>
102
+ </el-table-column>
103
+ <el-table-column align="center" :label="$t('openatccomponents.greenwaveoptimize.cycle')" width="60" prop="cycle" v-if="isShowColumn('cycle')">
104
+ </el-table-column>
105
+ <el-table-column align="center" :label="$t('openatccomponents.pattern.plan')" v-if="isShowColumn('pattern')">
106
+ <template slot-scope="scope">
107
+ <div class="pattern-figure">
108
+ <pattern-list
109
+ v-if="getControlType(scope.row) === 'ring'"
110
+ :patternStatusList="JSON.parse(JSON.stringify(scope.row.rings))"
111
+ :cycles="scope.row.cycle"
112
+ :phaseList="JSON.parse(JSON.stringify(scope.row.currPhase))"
113
+ :contrloType="getControlType(scope.row)"
114
+ >
115
+ </pattern-list>
116
+ <pattern-list
117
+ v-else
118
+ :patternId="scope.row.patternid"
119
+ :contrloType="getControlType(scope.row)"
120
+ :index="scope.$index"
121
+ :cycleChange="false"
122
+ :stagesChange="getSelectedPattern(scope.row).stagesList"
123
+ :patternStatusList="getSelectedPattern(scope.row).rings"
124
+ :patternList="JSON.parse(JSON.stringify(scope.row.allPatterns))"
125
+ :allPatternList="JSON.parse(JSON.stringify(scope.row.allPatterns))"
126
+ :cycles="scope.row.cycle"
127
+ :phaseList="JSON.parse(JSON.stringify(scope.row.currPhase))"
128
+ :agentId="scope.row.agentid"
129
+ :showBarrier="false">
130
+ </pattern-list>
131
+ </div>
132
+ </template>
133
+ </el-table-column>
134
+ </el-table>
135
+ </div>
136
+ </template>
137
+
138
+ <script>
139
+ import XiaoKanBan from '../../XiaoKanBan/index.vue'
140
+ // import { getPatternList } from '../../../../api/route'
141
+ import { getIntersectionInfo } from '../../../../api/template'
142
+ import { getMessageByCode } from '../../../../utils/responseMessage'
143
+ import { getDuration } from '../../../../api/cross'
144
+ // import { getDirName } from '../../../components/SelectCrossPhase/utils.js'
145
+ export default {
146
+ name: 'PatternTable',
147
+ components: {
148
+ XiaoKanBan
149
+ },
150
+ props: {
151
+ devicesData: {
152
+ type: Array,
153
+ default: () => []
154
+ },
155
+ optList: {
156
+ type: Array
157
+ },
158
+ isSingleCrossMode: {
159
+ type: Boolean,
160
+ default: false
161
+ },
162
+ tableColums: {
163
+ type: Array,
164
+ default: () => []
165
+ },
166
+ isAllowedExpand: {
167
+ type: Boolean,
168
+ default: true
169
+ },
170
+ isShowGenerateButton: {
171
+ type: Boolean,
172
+ default: true
173
+ },
174
+ isShowTableHeader: {
175
+ type: Boolean,
176
+ default: true
177
+ },
178
+ maxTableHeight: {
179
+ type: Number,
180
+ default: 200
181
+ }
182
+ },
183
+ data () {
184
+ return {
185
+ typeOptions: [{
186
+ value: 'flow-split-opt'
187
+ }, {
188
+ value: 'cycle-opt'
189
+ }],
190
+ value: 'flow-split-opt',
191
+ optimizecycle: 0,
192
+ controlType: 'stage',
193
+ loading: true,
194
+ tableHeight: 460,
195
+ screenHeight: window.innerHeight, // 屏幕高度
196
+ newPatternList: []
197
+ }
198
+ },
199
+ created () {
200
+ },
201
+ watch: {
202
+ maxTableHeight: function () {
203
+ this.$nextTick(() => {
204
+ this.tableHeight = this.maxTableHeight // 动态更新高度
205
+ })
206
+ },
207
+ optList: {
208
+ handler: function (val) {
209
+ if (val && val.length > 0) {
210
+ // for () {
211
+
212
+ // }
213
+ }
214
+ },
215
+ deep: true
216
+ },
217
+ newPatternList: {
218
+ handler: function (val) {
219
+ console.log('onNewPatternListChange', val)
220
+ this.$emit('onNewPatternListChange', val)
221
+ },
222
+ deep: true
223
+ }
224
+ },
225
+ mounted: function () {
226
+ },
227
+ methods: {
228
+ onOptimizeClick (row, index) {
229
+ let msg = this.$t('openatccomponents.pattern.algorithmEngineOptimization')
230
+ const loading = this.$loading({
231
+ lock: true,
232
+ text: msg,
233
+ spinner: 'el-icon-loading',
234
+ background: 'rgba(0, 0, 0, 0.7)'
235
+ })
236
+ setTimeout(() => {
237
+ loading.close()
238
+ this.handeleOptimizeClick(row, index)
239
+ }, 1000)
240
+ },
241
+ handeleOptimizeClick (row, index) {
242
+ let newPha = []
243
+ for (let i = 0; i < row.rings.length; i++) {
244
+ newPha.push(...row.rings[i])
245
+ }
246
+ let phaseData = newPha.map(item => {
247
+ return {
248
+ id: item.id,
249
+ flowperhour: item.flowperhour,
250
+ saturation: item.saturation
251
+ }
252
+ })
253
+ let patternList = row.allPatterns
254
+ if (row.feature && row.feature.patternList && row.feature.patternList.length > 0) {
255
+ patternList = row.feature.patternList
256
+ }
257
+ let pattern = patternList.filter((item) => item.id === row.patternid)[0]
258
+ let phaseList = row.currPhase
259
+ let reqData = {
260
+ 'type': this.value,
261
+ 'optcycle': this.optimizecycle ? this.optimizecycle : 0,
262
+ 'phaseList': phaseList,
263
+ 'pattern': pattern,
264
+ 'phases': phaseData
265
+ }
266
+ let isValidata = []
267
+ for (let j = 0; j < newPha.length; j++) {
268
+ let comNum = (newPha[j].length / 4) * 1700 * 0.8
269
+ isValidata.push(newPha[j].flowperhour > comNum)
270
+ }
271
+ if (isValidata.includes(true)) {
272
+ this.$confirm(this.$t('openatccomponents.overview.maxFlow'),
273
+ this.$t('openatccomponents.common.alarm'), {
274
+ confirmButtonText: this.$t('openatccomponents.common.confirm'),
275
+ cancelButtonText: this.$t('openatccomponents.common.cancel'),
276
+ type: 'warning'
277
+ }).then(() => {
278
+ this.doOptimize(row, index, reqData)
279
+ }).catch(() => {})
280
+ } else {
281
+ this.doOptimize(row, index, reqData)
282
+ }
283
+ },
284
+ doOptimize (row, index, reqData) {
285
+ // let _this = this
286
+ getDuration(reqData).then(data => {
287
+ if (data.data.success) {
288
+ this.$message({
289
+ type: 'success',
290
+ message: this.$t('openatccomponents.pattern.success')
291
+ })
292
+ // let cycle = 0
293
+ for (let i = 0; i < row.rings.length; i++) {
294
+ for (let j = 0; j < row.rings[i].length; j++) {
295
+ for (let h = 0; h < data.data.data.phase.length; h++) {
296
+ if (row.rings[i][j].id === data.data.data.phase[h].id) {
297
+ row.rings[i][j].value = data.data.data.phase[h].duration
298
+ // cycle = cycle + row.rings[i][j].value
299
+ }
300
+ }
301
+ }
302
+ }
303
+ }
304
+ }).catch(error => {
305
+ console.log(error)
306
+ })
307
+ },
308
+ isShowColumn (colum) {
309
+ let res = true
310
+ if (this.tableColums && this.tableColums.length > 0) {
311
+ res = this.tableColums.find(item => item === colum)
312
+ }
313
+ return res
314
+ },
315
+ getPeriod (row) {
316
+ let period = row.timeperiodrange || row.period
317
+ let res = ''
318
+ if (period && period.length > 0) {
319
+ res = period[0].substring(0, 5) + '-' + period[1].substring(0, 5)
320
+ }
321
+ return res
322
+ },
323
+ getDevName (row) {
324
+ let res = row.name ? row.name : ''
325
+ if (this.devicesData) {
326
+ let dev = this.devicesData.find(item => item.agentid === row.agentid)
327
+ res = dev ? dev.name : res
328
+ }
329
+ return res
330
+ },
331
+ onPatternTable (routeData, patternList, phaseList) {
332
+ if (patternList.length === 0) {
333
+ // this.$message.error('方案为空!')
334
+ return
335
+ }
336
+ if (phaseList.length === 0) {
337
+ // this.$message.error('相位为空!')
338
+ return
339
+ }
340
+ // this.routeData = routeData
341
+ // this.patternList = patternList
342
+ // this.phaseList = phaseList
343
+ this.handlePatternList(routeData, patternList, phaseList)
344
+ },
345
+ // 依据anengid获取设备信息,同时兼容单路口数据按序index取值
346
+ getDevFromDevsOrIndex (devs, agentid, index) {
347
+ let res
348
+ // check special
349
+ let isSingleCrossMode = false
350
+ if (devs && devs.length > 1 && devs[0].agentid === devs[1].agentid) {
351
+ isSingleCrossMode = true
352
+ // check errData
353
+ if (index === undefined || index === null) {
354
+ console.log('getDevFromDevsOrIndex Err: index is null')
355
+ }
356
+ }
357
+ if (!isSingleCrossMode) {
358
+ res = devs.filter(ist => ist.agentid === agentid)[0]
359
+ } else {
360
+ res = devs[index]
361
+ console.log('getDevByIndex:', res)
362
+ }
363
+ return res
364
+ },
365
+ handlePatternList (routeData, patternList, phaseList) {
366
+ this.newPatternList = []
367
+ let devs = routeData.devs
368
+ let index = 0
369
+ for (let pattern of patternList) {
370
+ let obj = {}
371
+ let id = pattern.agentid
372
+ obj.agentid = id
373
+ let count = [] // 计算相位有几个环
374
+ if (pattern.feature !== undefined && pattern.feature.patternList.length !== 0) {
375
+ let currPatternList = pattern.feature.patternList
376
+ // let dev = devs.filter(ist => ist.agentid === id)[0]
377
+ let dev = this.getDevFromDevsOrIndex(devs, id, index)
378
+ index = index + 1
379
+ let patternId = dev.patternid
380
+ let currPattern
381
+ if (Array.isArray(currPatternList)) {
382
+ currPattern = currPatternList.filter(cpl => cpl.id === patternId)[0]
383
+ if (!currPattern) {
384
+ currPattern = currPatternList[0]
385
+ }
386
+ } else {
387
+ currPattern = currPatternList
388
+ }
389
+ if (!currPattern) {
390
+ currPattern = currPatternList[0]
391
+ }
392
+ // let currPattern = currPatternList.filter(cpl => cpl.id === patternId)[0]
393
+ if (currPattern.desc === '') {
394
+ obj.desc = this.$t('openatccomponents.greenwaveoptimize.pattern') + currPattern.id
395
+ } else {
396
+ obj.desc = currPattern.desc
397
+ }
398
+ obj = {...obj, ...dev}
399
+ obj.id = currPattern.id
400
+ obj.offset = currPattern.offset
401
+ obj.cycle = currPattern.cycle
402
+ obj.patternId = currPattern.id
403
+ obj.patternid = currPattern.id
404
+ obj.patternDesc = currPattern.desc === '' ? `${this.$t('openatccomponents.greenwaveoptimize.pattern')}${currPattern.id}` : currPattern.desc
405
+ obj.allPatterns = currPatternList.map(ele => {
406
+ let patterndesc = ele.desc === '' ? `${this.$t('openatccomponents.greenwaveoptimize.pattern')}${currPattern.id}` : ele.desc
407
+ return {
408
+ patternid: ele.id,
409
+ patterndes: ele.desc,
410
+ patterndesc: patterndesc,
411
+ ...ele
412
+ }
413
+ })
414
+ let rings = currPattern.rings
415
+ let currPhase = phaseList.filter(phl => phl.agentid === id)[0].feature.phaseList
416
+ obj.currPhase = currPhase
417
+ obj.phaseList = currPhase
418
+ // 计算有几个环
419
+ for (let ring of rings) {
420
+ if (ring.length === 0) continue
421
+ for (let rr of ring) {
422
+ rr.desc = []
423
+ let targetPhase = currPhase.filter(curp => curp.id === rr.id)[0]
424
+ if (!targetPhase) continue
425
+ let direction = targetPhase.direction // 相位方向集合
426
+ let phaseRing = currPhase.filter(curp => curp.id === rr.id)[0].ring
427
+ count.push(phaseRing)
428
+ for (let dir of direction) {
429
+ let obj = {}
430
+ obj.id = dir
431
+ rr.desc.push(obj)
432
+ }
433
+ }
434
+ }
435
+ obj.rings = rings
436
+ }
437
+ let ringCount = Array.from(new Set(count)) // 去除数组重复的元素
438
+ ringCount = ringCount.sort(this.sortNumbers) // 把数组中的值按照从小到大的顺序重新排序
439
+ obj.ringCount = ringCount
440
+ this.newPatternList.push(obj)
441
+ }
442
+ console.log('handlePatternList newPatternList', this.newPatternList)
443
+ },
444
+ sortNumbers (a, b) {
445
+ return a - b
446
+ },
447
+ fatherMethod (val) {
448
+ let index = val.index
449
+ let cycle = val.cycle
450
+ this.newPatternList[index].cycle = cycle
451
+ },
452
+ changeCurPattern (row, curPatternid) {
453
+ // 修改当前方案(allPatterns: 所有可选项)
454
+ const data = {
455
+ agentid: row.agentid,
456
+ patternid: curPatternid,
457
+ patterndes: row.allPatterns.filter(ele => ele.patternid === curPatternid)[0].patterndes,
458
+ allPatterns: row.allPatterns
459
+ }
460
+ row.desc = data.patternDesc
461
+ row.patternId = data.patternid
462
+ row.patternid = data.patternid
463
+ row.patterndes = data.patterndes
464
+ row.allPatterns = data.allPatterns
465
+ row.patternid = data.patternid
466
+ let selectPattern = row.allPatterns.filter(item => item.patternid === row.patternid)[0]
467
+ let res = this.getRings(selectPattern.rings, row.phaseList)
468
+ row.rings = res.rings
469
+ row.ringCount = res.ringCount
470
+ // row.rings = selectPattern.rings
471
+ row.cycle = selectPattern.cycle
472
+ row.offset = selectPattern.offset
473
+ row.currPhase = row.phaseList
474
+ },
475
+ getRings (ringsList, phaseList) {
476
+ let res = {}
477
+ let rings = JSON.parse(JSON.stringify(ringsList))
478
+ let count = []
479
+ // 计算有几个环
480
+ for (let ring of rings) {
481
+ if (ring.length === 0) continue
482
+ for (let rr of ring) {
483
+ rr.desc = []
484
+ let direction = phaseList.filter(curp => curp.id === rr.id)[0].direction // 相位方向集合
485
+ let phaseRing = phaseList.filter(curp => curp.id === rr.id)[0].ring
486
+ count.push(phaseRing)
487
+ for (let dir of direction) {
488
+ let obj = {}
489
+ obj.id = dir
490
+ rr.desc.push(obj)
491
+ }
492
+ }
493
+ }
494
+ let ringCount = Array.from(new Set(count)) // 去除数组重复的元素
495
+ ringCount = ringCount.sort(this.sortNumbers) // 把数组中的值按照从小到大的顺序重新排序
496
+ res = {
497
+ rings: rings,
498
+ ringCount: ringCount
499
+ }
500
+ return res
501
+ },
502
+ getControlType (row) {
503
+ let contrloType = 'ring'
504
+ let allPatternList = row.feature && row.feature.patternList ? row.feature.patternList : row.allPatterns
505
+ if (
506
+ !allPatternList[0].contrloType &&
507
+ allPatternList[0].rings.length > 0
508
+ ) {
509
+ contrloType = 'ring'
510
+ } else if (
511
+ !allPatternList[0].contrloType &&
512
+ allPatternList[0].rings.length === 0
513
+ ) {
514
+ contrloType = 'stage'
515
+ } else {
516
+ contrloType = allPatternList[0].contrloType
517
+ }
518
+ let res = contrloType
519
+ return res
520
+ },
521
+ getSelectedPattern (row) {
522
+ let res = []
523
+ let patternList = row.feature && row.feature.patternList ? row.feature.patternList : row.allPatterns
524
+ let pattern = patternList.find(item => item.id === row.patternid)
525
+ if (pattern) {
526
+ res = JSON.parse(JSON.stringify(pattern))
527
+ }
528
+ return res
529
+ },
530
+ getCurPattern (agentid) {
531
+ // 获取当前设备所有可选方案
532
+ this.loading = true
533
+ let _this = this
534
+ getIntersectionInfo(agentid).then(res => {
535
+ this.loading = false
536
+ if (!res.data.success) {
537
+ let commomMsg = this.$t('openatccomponents.overview.signalID') + ' : ' + agentid
538
+ let msg = getMessageByCode(res.data.code, this.$i18n.locale)
539
+ if (res.data.data) {
540
+ // 子类型错误
541
+ let childErrorCode = res.data.data.errorCode
542
+ if (childErrorCode) {
543
+ let childerror = getMessageByCode(res.data.data.errorCode, this.$i18n.locale)
544
+ msg = msg + ' - ' + childerror
545
+ }
546
+ }
547
+ msg = msg + ' - ' + commomMsg
548
+ this.$message.error(msg)
549
+ return
550
+ }
551
+ let allPatternList = res.data.data.param.patternList
552
+ _this.newPatternList.forEach(ele => {
553
+ if (ele.agentid === agentid) {
554
+ ele.allPatterns = allPatternList.map(ele => {
555
+ return {
556
+ ...ele,
557
+ patternid: ele.id,
558
+ patterndes: ele.desc,
559
+ patterndesc: ele.desc === '' ? `${_this.$t('openatccomponents.greenwaveoptimize.pattern')}${ele.id}` : ele.desc
560
+ }
561
+ })
562
+ }
563
+ })
564
+ })
565
+ }
566
+ }
567
+ }
568
+ </script>
569
+
570
+ <style lang="scss">
571
+ .board {
572
+ width: 100%;
573
+ margin-left: 10PX;
574
+ display: flex;
575
+ justify-content: flex-start;
576
+ gap: 10PX;
577
+ align-items: flex-start;
578
+ }
579
+ .optimizetype{
580
+ font-size: 14PX;
581
+ display: flex;
582
+ justify-content: flex-start;
583
+ align-items: center;
584
+ gap: 10PX;
585
+ padding-left: 20PX;
586
+ .el-input {
587
+ width: 120PX;
588
+ }
589
+ // .el-select{
590
+ // width: 170PX;
591
+ // }
592
+ // .el-button {
593
+ // margin-left: 10PX;
594
+ // }
595
+ .optimiNum {
596
+ padding-left: 10PX;
597
+ }
598
+ }
599
+ </style>