openatc-components 0.3.37 → 0.3.39

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 (497) hide show
  1. package/.babelrc +18 -18
  2. package/.editorconfig +9 -9
  3. package/.eslintignore +5 -5
  4. package/.eslintrc.js +29 -29
  5. package/.postcssrc.js +10 -10
  6. package/README.md +30 -30
  7. package/Untitled-1.json +14753 -0
  8. package/build/build.js +41 -41
  9. package/build/check-versions.js +54 -54
  10. package/build/package.config.js +58 -58
  11. package/build/package.dev.config.js +107 -107
  12. package/build/package.prod.config.js +160 -160
  13. package/build/utils.js +101 -101
  14. package/build/vue-loader.conf.js +22 -22
  15. package/build/webpack.base.conf.js +114 -114
  16. package/build/webpack.dev.conf.js +95 -95
  17. package/build/webpack.prod.conf.js +149 -149
  18. package/config/dev.env.js +8 -8
  19. package/config/index.js +93 -93
  20. package/config/prod.env.js +5 -5
  21. package/config/test.env.js +7 -7
  22. package/index.html +12 -12
  23. package/package/kisscomps/components/BoardCard/BoardCard.vue +117 -117
  24. package/package/kisscomps/components/BoardCard/index.js +2 -2
  25. package/package/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +123 -123
  26. package/package/kisscomps/components/ChannelRealtimeIntersection/index.js +2 -2
  27. package/package/kisscomps/components/Channelization/Channelization.vue +584 -584
  28. package/package/kisscomps/components/Channelization/index.js +2 -2
  29. package/package/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  30. package/package/kisscomps/components/ChannelizationFlowStatistic/index.js +2 -2
  31. package/package/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  32. package/package/kisscomps/components/ChannelizationWithInterface/index.js +2 -2
  33. package/package/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  34. package/package/kisscomps/components/CommonKanban/index.js +2 -2
  35. package/package/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +454 -454
  36. package/package/kisscomps/components/DirectionListConfiguration/index.js +2 -2
  37. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  38. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  39. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  40. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  41. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  42. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  43. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  44. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  45. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  46. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  47. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  48. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  49. package/package/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  50. package/package/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  51. package/package/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  52. package/package/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  53. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  54. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  55. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  56. package/package/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  57. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  58. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  59. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  60. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  61. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +467 -467
  62. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  63. package/package/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  64. package/package/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +1005 -1005
  65. package/package/kisscomps/components/DrawChannelization/drawsvg/index.vue +110 -110
  66. package/package/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  67. package/package/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  68. package/package/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +172 -172
  69. package/package/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  70. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  71. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  72. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  73. package/package/kisscomps/components/DrawChannelization/index.js +2 -2
  74. package/package/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  75. package/package/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  76. package/package/kisscomps/components/ExpendConfig/index.js +2 -2
  77. package/package/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  78. package/package/kisscomps/components/FaultDetailModal/index.js +2 -2
  79. package/package/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +158 -158
  80. package/package/kisscomps/components/IntersectionDirectionSelection/index.js +2 -2
  81. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  82. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  83. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  84. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  85. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  86. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  87. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  88. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  89. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +1302 -1302
  90. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  91. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  92. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  93. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  94. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  95. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  96. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  97. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  98. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  99. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  100. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  101. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  102. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  103. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  104. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  105. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  106. package/package/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +1372 -1372
  107. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  108. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +196 -196
  109. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  110. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  111. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  112. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +115 -115
  113. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  114. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  115. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +219 -219
  116. package/package/kisscomps/components/IntersectionMap/crossDirection/utils.js +84 -84
  117. package/package/kisscomps/components/IntersectionMap/index.js +2 -2
  118. package/package/kisscomps/components/IntersectionMap/intersectionmap.vue +211 -211
  119. package/package/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +530 -530
  120. package/package/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  121. package/package/kisscomps/components/KanBan/index.js +2 -2
  122. package/package/kisscomps/components/KanBan/kanban.vue +231 -231
  123. package/package/kisscomps/components/MessageBox/index.vue +96 -96
  124. package/package/kisscomps/components/OverLap/OverLap.vue +237 -237
  125. package/package/kisscomps/components/OverLap/index.js +2 -2
  126. package/package/kisscomps/components/PatternOptimize/PatternOptimize.vue +272 -272
  127. package/package/kisscomps/components/PatternOptimize/index.js +2 -2
  128. package/package/kisscomps/components/PatternStatus/PatternStatus.vue +1649 -1649
  129. package/package/kisscomps/components/PatternStatus/index.js +2 -2
  130. package/package/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  131. package/package/kisscomps/components/PatternWalkSvg/index.js +2 -2
  132. package/package/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  133. package/package/kisscomps/components/PhaseDirectionSelect/index.js +2 -2
  134. package/package/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  135. package/package/kisscomps/components/PhaseDirectionText/index.js +2 -2
  136. package/package/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  137. package/package/kisscomps/components/PhaseLegend/index.js +2 -2
  138. package/package/kisscomps/components/PhaseMarker/index.js +6 -6
  139. package/package/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  140. package/package/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  141. package/package/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  142. package/package/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  143. package/package/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  144. package/package/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  145. package/package/kisscomps/components/PhasePedSelect/index.js +2 -2
  146. package/package/kisscomps/components/PhasePedSelect/index.vue +206 -206
  147. package/package/kisscomps/components/SchemeConfig/SchemeConfig.vue +949 -949
  148. package/package/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +364 -364
  149. package/package/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  150. package/package/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  151. package/package/kisscomps/components/SchemeConfig/index.js +2 -2
  152. package/package/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +236 -236
  153. package/package/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  154. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +128 -128
  155. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/icon.vue +438 -438
  156. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +864 -864
  157. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  158. package/package/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  159. package/package/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  160. package/package/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +283 -283
  161. package/package/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +1215 -1215
  162. package/package/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  163. package/package/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  164. package/package/kisscomps/components/StageBord/StageBord.vue +303 -303
  165. package/package/kisscomps/components/StageBord/index.js +2 -2
  166. package/package/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  167. package/package/kisscomps/components/StageStatus/index.js +2 -2
  168. package/package/kisscomps/components/Stages/index.vue +319 -319
  169. package/package/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  170. package/package/kisscomps/components/SvgIcon/index.js +2 -2
  171. package/package/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  172. package/package/kisscomps/components/XRDDirSelector/index.js +2 -2
  173. package/package/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  174. package/package/kisscomps/components/XiaoKanban/index.vue +102 -102
  175. package/package/kisscomps/components/overView/index.vue +699 -699
  176. package/package/kisscomps/components/patternConfig/index.js +2 -2
  177. package/package/kisscomps/components/patternConfig/index.vue +739 -739
  178. package/package/kisscomps/components/patternConfig/pattern/patternTable.vue +421 -421
  179. package/package/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  180. package/package/kisscomps/components/patternConfig/planContent.vue +575 -575
  181. package/package/kisscomps/components/patternConfig/planMenu.vue +329 -329
  182. package/package/kisscomps/components/patternConfig/utils.js +152 -152
  183. package/package/kisscomps/components/patternList/index.js +2 -2
  184. package/package/kisscomps/components/patternList/patternList.vue +590 -590
  185. package/package/kisscomps/index.js +127 -127
  186. package/package/kissui.js +216608 -0
  187. package/package/kissui.min.js +1 -1
  188. package/package.json +127 -127
  189. package/src/App.vue +24 -24
  190. package/src/EdgeMgr/EdgeModelBase.js +16 -16
  191. package/src/EdgeMgr/controller/crossDiagramMgr.js +125 -125
  192. package/src/api/authapi.js +31 -31
  193. package/src/api/config.js +21 -21
  194. package/src/api/control.js +106 -106
  195. package/src/api/cross.js +49 -49
  196. package/src/api/device.js +135 -135
  197. package/src/api/fault.js +66 -66
  198. package/src/api/index.js +24 -24
  199. package/src/api/login.js +46 -46
  200. package/src/api/optimize.js +72 -72
  201. package/src/api/param.js +165 -165
  202. package/src/api/passwdAssest.js +101 -101
  203. package/src/api/route.js +171 -171
  204. package/src/api/template.js +27 -27
  205. package/src/assets/font/LICENSE.txt +202 -202
  206. package/src/assets/font/font.css +6 -6
  207. package/src/i18n/index.js +26 -26
  208. package/src/i18n/language/en.js +1450 -1450
  209. package/src/i18n/language/index.js +25 -25
  210. package/src/i18n/language/zh.js +1449 -1449
  211. package/src/icons/demo_index.html +8445 -8445
  212. package/src/icons/iconfont.css +1451 -1451
  213. package/src/icons/iconfont.json +2522 -2522
  214. package/src/icons/index.js +20 -20
  215. package/src/icons/svg/azimuthlocking.svg +26 -26
  216. package/src/icons/svg/bendi.svg +110 -110
  217. package/src/icons/svg/bujin.svg +36 -36
  218. package/src/icons/svg/connectBlue.svg +7 -7
  219. package/src/icons/svg/currentvolume.svg +0 -0
  220. package/src/icons/svg/custom-BRTlane.svg +40 -40
  221. package/src/icons/svg/custom-buslane.svg +40 -40
  222. package/src/icons/svg/custom-detector.svg +12 -12
  223. package/src/icons/svg/custom-east-bottom.svg +32 -32
  224. package/src/icons/svg/custom-east-top.svg +32 -32
  225. package/src/icons/svg/custom-ewped.svg +35 -35
  226. package/src/icons/svg/custom-nonmotorizedlane.svg +40 -40
  227. package/src/icons/svg/custom-north-left.svg +32 -32
  228. package/src/icons/svg/custom-north-right.svg +32 -32
  229. package/src/icons/svg/custom-peddetector.svg +17 -17
  230. package/src/icons/svg/custom-snped.svg +35 -35
  231. package/src/icons/svg/custom-south-left.svg +32 -32
  232. package/src/icons/svg/custom-south-right.svg +32 -32
  233. package/src/icons/svg/custom-tramlane.svg +40 -40
  234. package/src/icons/svg/custom-vehiclebranch.svg +40 -40
  235. package/src/icons/svg/custom-vehiclemainroad.svg +41 -41
  236. package/src/icons/svg/custom-west-bottom.svg +32 -32
  237. package/src/icons/svg/custom-west-top.svg +32 -32
  238. package/src/icons/svg/custom-xlped.svg +14 -14
  239. package/src/icons/svg/custom-xrped.svg +14 -14
  240. package/src/icons/svg/cutRed.svg +7 -7
  241. package/src/icons/svg/cycle.svg +0 -0
  242. package/src/icons/svg/dingzhouqi.svg +34 -34
  243. package/src/icons/svg/ganyingkongzhi.svg +30 -30
  244. package/src/icons/svg/guandeng.svg +81 -81
  245. package/src/icons/svg/huangshan.svg +71 -71
  246. package/src/icons/svg/maincontrol.svg +0 -0
  247. package/src/icons/svg/manualcontrolbackground.svg +51 -51
  248. package/src/icons/svg/manualcontrolbackground1.svg +62 -62
  249. package/src/icons/svg/manualcontrolbackgrounden.svg +62 -62
  250. package/src/icons/svg/model.svg +0 -0
  251. package/src/icons/svg/phasediff.svg +0 -0
  252. package/src/icons/svg/prioritycontrol.svg +21 -21
  253. package/src/icons/svg/quanhong.svg +86 -86
  254. package/src/icons/svg/shanghe.svg +11 -11
  255. package/src/icons/svg/shoudong.svg +103 -103
  256. package/src/icons/svg/tentativeplan.svg +28 -28
  257. package/src/icons/svg/time.svg +0 -0
  258. package/src/icons/svg/wuxianlan.svg +46 -46
  259. package/src/icons/svg/xiala.svg +11 -11
  260. package/src/icons/svg/xingrenguojie.svg +33 -33
  261. package/src/icons/svg/xitong.svg +89 -89
  262. package/src/icons/svg/youxian.svg +41 -41
  263. package/src/icons/svg/zizhukongzhi.svg +43 -43
  264. package/src/kisscomps/components/BoardCard/BoardCard.vue +117 -117
  265. package/src/kisscomps/components/BoardCard/index.js +2 -2
  266. package/src/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +123 -123
  267. package/src/kisscomps/components/ChannelRealtimeIntersection/index.js +2 -2
  268. package/src/kisscomps/components/Channelization/Channelization.vue +584 -584
  269. package/src/kisscomps/components/Channelization/index.js +2 -2
  270. package/src/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  271. package/src/kisscomps/components/ChannelizationFlowStatistic/index.js +2 -2
  272. package/src/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  273. package/src/kisscomps/components/ChannelizationWithInterface/index.js +2 -2
  274. package/src/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  275. package/src/kisscomps/components/CommonKanban/index.js +2 -2
  276. package/src/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +454 -454
  277. package/src/kisscomps/components/DirectionListConfiguration/index.js +2 -2
  278. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  279. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  280. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  281. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  282. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  283. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  284. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  285. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  286. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  287. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  288. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  289. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  290. package/src/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  291. package/src/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  292. package/src/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  293. package/src/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  294. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  295. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  296. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  297. package/src/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  298. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  299. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  300. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  301. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  302. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +467 -467
  303. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  304. package/src/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  305. package/src/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +1005 -1005
  306. package/src/kisscomps/components/DrawChannelization/drawsvg/index.vue +110 -110
  307. package/src/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  308. package/src/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  309. package/src/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +172 -172
  310. package/src/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  311. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  312. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  313. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  314. package/src/kisscomps/components/DrawChannelization/index.js +2 -2
  315. package/src/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  316. package/src/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  317. package/src/kisscomps/components/ExpendConfig/index.js +2 -2
  318. package/src/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  319. package/src/kisscomps/components/FaultDetailModal/index.js +2 -2
  320. package/src/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +158 -158
  321. package/src/kisscomps/components/IntersectionDirectionSelection/index.js +2 -2
  322. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  323. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  324. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  325. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  326. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  327. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  328. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  329. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  330. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +1302 -1302
  331. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  332. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  333. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  334. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  335. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  336. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  337. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  338. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  339. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  340. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  341. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  342. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  343. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  344. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  345. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  346. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  347. package/src/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +1372 -1372
  348. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  349. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +196 -196
  350. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  351. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  352. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  353. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +115 -115
  354. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  355. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  356. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +219 -219
  357. package/src/kisscomps/components/IntersectionMap/crossDirection/utils.js +84 -84
  358. package/src/kisscomps/components/IntersectionMap/index.js +2 -2
  359. package/src/kisscomps/components/IntersectionMap/intersectionmap.vue +211 -211
  360. package/src/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +530 -530
  361. package/src/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  362. package/src/kisscomps/components/KanBan/index.js +2 -2
  363. package/src/kisscomps/components/KanBan/kanban.vue +231 -231
  364. package/src/kisscomps/components/MessageBox/index.vue +96 -96
  365. package/src/kisscomps/components/OverLap/OverLap.vue +237 -237
  366. package/src/kisscomps/components/OverLap/index.js +2 -2
  367. package/src/kisscomps/components/PatternOptimize/PatternOptimize.vue +272 -272
  368. package/src/kisscomps/components/PatternOptimize/index.js +2 -2
  369. package/src/kisscomps/components/PatternStatus/PatternStatus.vue +1649 -1649
  370. package/src/kisscomps/components/PatternStatus/index.js +2 -2
  371. package/src/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  372. package/src/kisscomps/components/PatternWalkSvg/index.js +2 -2
  373. package/src/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  374. package/src/kisscomps/components/PhaseDirectionSelect/index.js +2 -2
  375. package/src/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  376. package/src/kisscomps/components/PhaseDirectionText/index.js +2 -2
  377. package/src/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  378. package/src/kisscomps/components/PhaseLegend/index.js +2 -2
  379. package/src/kisscomps/components/PhaseMarker/index.js +6 -6
  380. package/src/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  381. package/src/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  382. package/src/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  383. package/src/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  384. package/src/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  385. package/src/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  386. package/src/kisscomps/components/PhasePedSelect/index.js +2 -2
  387. package/src/kisscomps/components/PhasePedSelect/index.vue +206 -206
  388. package/src/kisscomps/components/SchemeConfig/SchemeConfig.vue +949 -949
  389. package/src/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +364 -364
  390. package/src/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  391. package/src/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  392. package/src/kisscomps/components/SchemeConfig/index.js +2 -2
  393. package/src/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +236 -236
  394. package/src/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  395. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +128 -128
  396. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/icon.vue +438 -438
  397. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +864 -864
  398. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  399. package/src/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  400. package/src/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  401. package/src/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +283 -283
  402. package/src/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +1215 -1215
  403. package/src/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  404. package/src/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  405. package/src/kisscomps/components/StageBord/StageBord.vue +303 -303
  406. package/src/kisscomps/components/StageBord/index.js +2 -2
  407. package/src/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  408. package/src/kisscomps/components/StageStatus/index.js +2 -2
  409. package/src/kisscomps/components/Stages/index.vue +319 -319
  410. package/src/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  411. package/src/kisscomps/components/SvgIcon/index.js +2 -2
  412. package/src/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  413. package/src/kisscomps/components/XRDDirSelector/index.js +2 -2
  414. package/src/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  415. package/src/kisscomps/components/XiaoKanban/index.vue +102 -102
  416. package/src/kisscomps/components/overView/index.vue +699 -699
  417. package/src/kisscomps/components/patternConfig/index.js +2 -2
  418. package/src/kisscomps/components/patternConfig/index.vue +739 -739
  419. package/src/kisscomps/components/patternConfig/pattern/patternTable.vue +421 -421
  420. package/src/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  421. package/src/kisscomps/components/patternConfig/planContent.vue +575 -575
  422. package/src/kisscomps/components/patternConfig/planMenu.vue +329 -329
  423. package/src/kisscomps/components/patternConfig/utils.js +152 -152
  424. package/src/kisscomps/components/patternList/index.js +2 -2
  425. package/src/kisscomps/components/patternList/patternList.vue +590 -590
  426. package/src/kisscomps/index.js +127 -127
  427. package/src/lib/publicjs/ArryListUtil.js +38 -38
  428. package/src/lib/publicjs/HttpurlMgr.js +45 -45
  429. package/src/lib/publicjs/KissApi.js +158 -158
  430. package/src/lib/publicjs/KissWSSub/Heartcheck.js +128 -128
  431. package/src/lib/publicjs/KissWSSub/KissWsSub.js +91 -91
  432. package/src/lib/publicjs/KissWSSub/KissWsSubByType.js +152 -152
  433. package/src/lib/publicjs/KissWSSub/SimuWsSubByType.js +44 -44
  434. package/src/lib/publicjs/KissWSSub/Sub.js +51 -51
  435. package/src/lib/publicjs/KissWSSub/SubChannel.js +119 -119
  436. package/src/lib/publicjs/basecomponents.js +65 -65
  437. package/src/lib/publicjs/localStorage.js +112 -112
  438. package/src/lib/publicjs/objdeepcopy.js +32 -32
  439. package/src/lib/publicjs/pageScroll.js +30 -30
  440. package/src/lib/publicjs/passwdAssest.js +101 -101
  441. package/src/lib/publicjs/styleclassfactory.js +32 -32
  442. package/src/main.js +51 -51
  443. package/src/router/index.js +63 -63
  444. package/src/store/getters.js +16 -16
  445. package/src/store/index.js +26 -26
  446. package/src/store/modules/globalParam.js +67 -67
  447. package/src/utils/ControlFormat.js +68 -68
  448. package/src/utils/RingDataModel.js +331 -331
  449. package/src/utils/auth.js +199 -199
  450. package/src/utils/conflct.js +259 -259
  451. package/src/utils/conflictList.js +87 -87
  452. package/src/utils/dateFormat.js +41 -41
  453. package/src/utils/errorcode.js +227 -227
  454. package/src/utils/fault.js +196 -196
  455. package/src/utils/faultcode.js +209 -209
  456. package/src/utils/index.js +69 -69
  457. package/src/utils/pedphasedesc.js +119 -119
  458. package/src/utils/phaseList.js +203 -203
  459. package/src/utils/phasedesc.js +144 -144
  460. package/src/utils/responseMessage.js +21 -21
  461. package/src/utils/validate.js +43 -43
  462. package/src/views/customchannelization.vue +49 -49
  463. package/src/views/home.1.vue +479 -479
  464. package/src/views/home.vue +93 -93
  465. package/src/views/intersection.vue +521 -521
  466. package/src/views/intersection2.vue +328 -328
  467. package/src/views/overView.vue +41 -41
  468. package/src/views/patternConfig.vue +609 -609
  469. package/src/views/schemeconfig.vue +208 -208
  470. package/static/apiconfig.json +451 -451
  471. package/static/styles/channelizatioon.scss +433 -433
  472. package/static/styles/common.scss +30 -30
  473. package/static/styles/commonkanban.scss +168 -168
  474. package/static/styles/dark/index.scss +2 -2
  475. package/static/styles/dark/theme/element-dark.scss +44 -44
  476. package/static/styles/index.scss +84 -84
  477. package/static/styles/intersection.scss +180 -180
  478. package/static/styles/light/index.scss +2 -2
  479. package/static/styles/light/theme/element-light.scss +44 -44
  480. package/static/styles/overview.scss +146 -146
  481. package/static/styles/patternConfig.scss +56 -56
  482. package/static/styles/phasePedSelect.scss +71 -71
  483. package/static/styles/schemeconfig.scss +552 -552
  484. package/static/styles/stages.scss +57 -57
  485. package/static/styles/theme/element-dark.scss +0 -0
  486. package/static/styles/uiComponents.scss +57 -57
  487. package/static/styles/xiaokanban.scss +50 -50
  488. package/static/token.json +2 -2
  489. package/test/e2e/custom-assertions/elementCount.js +27 -27
  490. package/test/e2e/nightwatch.conf.js +46 -46
  491. package/test/e2e/runner.js +48 -48
  492. package/test/e2e/specs/test.js +19 -19
  493. package/test/unit/.eslintrc +7 -7
  494. package/test/unit/jest.conf.js +30 -30
  495. package/test/unit/setup.js +3 -3
  496. package/test/unit/specs/HelloWorld.spec.js +11 -11
  497. package/src/node_modules/.package_versions.json +0 -1
@@ -1,739 +1,739 @@
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="patternConfig">
14
- <el-container v-if="!isShowSingle" >
15
- <div class="main-container" style="height: 100%;width: 100%;">
16
- <el-tabs v-model="editableTabsValue" type="card" @edit="handleTabsEdit" :before-leave="beforeLeave" style="height: 100%;">
17
- <el-tab-pane
18
- :closable="true"
19
- :key="item.tabName"
20
- v-for="(item) in editableTabs"
21
- :label="item.title"
22
- :name="item.tabName"
23
- >
24
- <div class="panel-content" style="height: 100%;">
25
- <div style="height: 6%;">
26
- <div class="route-filter-container" style="display:flex;">
27
- <div class="filter">
28
- <span class="header-span">{{$t('openatccomponents.greenwaveoptimize.name')}}:</span>
29
- <el-input
30
- clearable
31
- size="small"
32
- v-model="item.title"
33
- style="width:70%;"
34
- @change="onConditionChange"
35
- />
36
- </div>
37
- </div>
38
- </div>
39
- <div style="height: 94%;" class="table-container">
40
- <PatternTable ref="patterntable"
41
- :devicesData="devicesData"
42
- :maxTableHeight="maxTableHeight"
43
- :opt="item.devs"
44
- :isAllowedExpand="isAllowedExpand"
45
- @onNewPatternListChange="onNewPatternListChange"/>
46
- </div>
47
- </div>
48
- </el-tab-pane>
49
- <el-tab-pane key="add" name="add" :closable="false">
50
- <span slot="label" style="padding: 8px;font-size:20px;font-weight:bold;">
51
- +
52
- </span>
53
- </el-tab-pane>
54
- </el-tabs>
55
- </div>
56
- </el-container>
57
- <div v-if="isShowSingle" style="height: 94%;" class="table-container">
58
- <PatternTable ref="patterntable"
59
- :devicesData="devicesData"
60
- :opt="opt.optPatternList[0].devs"
61
- :isAllowedExpand="isAllowedExpand"
62
- :maxTableHeight="maxTableHeight"
63
- @onNewPatternListChange="onNewPatternListChange"/>
64
- </div>
65
- <PlanContent v-show="false"
66
- :schemeData="schemeData"
67
- :step="step"
68
- :zIndexObj="zIndexObj"
69
- ref="planContent"
70
- @handlePlanChart="handlePlanChart"
71
- @handlePatternTable="handlePatternTable"
72
- @ErrorOcurrred='onErrorOcurrred'
73
- @resetContentComponent="resetContentComponent"/>
74
- </div>
75
- </template>
76
-
77
- <script>
78
- import PlanContent from './planContent'
79
- import { getMessageByCode } from '../../../utils/responseMessage'
80
- import PatternTable from './pattern/patternTable'
81
- import dateObj from './utils.js'
82
- import { GetDeviceByIds } from '../../../api/device.js'
83
- import { getAllPatternOfDevs } from '../../../api/route'
84
- const { monthsModel, daysModelCh, daysModelEn, datesModel, monthsModelEn, datesModelEn } = dateObj
85
- export default {
86
- name: 'PatternConfig',
87
- components: {
88
- PatternTable,
89
- PlanContent
90
- },
91
- props: {
92
- agentids: {
93
- type: Array,
94
- default: () => []
95
- },
96
- opt: {
97
- type: Object,
98
- default: () => null
99
- },
100
- isOnlyOneTab: {
101
- type: Boolean,
102
- default: true
103
- },
104
- isAllowedExpand: {
105
- type: Boolean,
106
- default: true
107
- },
108
- isShowSingle: {
109
- type: Boolean,
110
- default: false
111
- }
112
- },
113
- watch: {
114
- agentids: {
115
- handler (val, old) {
116
- if (old && val.join('') === old.join('')) {
117
- return false
118
- }
119
- if (!val || val.length === 0) {
120
- console.log('ematy anentids:', val)
121
- return false
122
- }
123
- console.log('full anentids:', val)
124
- this.handeAgentidsChange()
125
- },
126
- immediate: true
127
- }
128
- },
129
- data () {
130
- return {
131
- devicesData: [],
132
- deviceIds: [],
133
- maxTableHeight: 200,
134
- chartData: {},
135
- months: monthsModel,
136
- days: [],
137
- dates: datesModel,
138
- planData: [],
139
- schemeData: [],
140
- step: false, // 控制第二个蒙层是否可以显示
141
- zIndexObj: {
142
- // 由于“新增”“编辑”均有蒙层,因此需动态改变可点击按钮层级
143
- addZIndex: 98,
144
- editZIndex: 98
145
- },
146
- reset: false,
147
- activeName: 'first',
148
- chooseId: 0, // 选中的计划id
149
- // agentids: [],
150
- // isOnlyOneTab: true,
151
- loading: false,
152
- keyintsidOptions: [],
153
- editableTabsValue: '1',
154
- routePattern: {
155
- 'id': 1,
156
- 'optPatternList': []
157
- },
158
- defaultOptPattern: {
159
- 'tabName': '1',
160
- 'month': [],
161
- patternid: 1,
162
- 'day': [],
163
- 'date': [],
164
- 'plan': {
165
- 'start': '11:00',
166
- 'end': '13:00'
167
- },
168
- 'optstrategy': 'green',
169
- 'direction': 'up',
170
- 'keyintsid': '',
171
- 'upspeed': 0,
172
- 'downspeed': 0,
173
- 'devs': []
174
- },
175
- currentIndex: 0,
176
- editableTabs: [{
177
- title: '仿真实例 1',
178
- tabName: '1',
179
- content: 'Tab 1 content',
180
- patternid: 1,
181
- 'month': [],
182
- 'day': [],
183
- 'date': [],
184
- 'plan': {
185
- 'start': '11:00',
186
- 'end': '13:00'
187
- },
188
- 'optstrategy': 'green',
189
- 'direction': 'up',
190
- 'keyintsid': '',
191
- 'upspeed': 0,
192
- 'downspeed': 0,
193
- 'devs': []
194
- }],
195
- tabIndex: 1
196
- }
197
- },
198
- created () {
199
- this.resetTab()
200
- let lan = this.$i18n.locale
201
- if (lan === 'en') {
202
- this.days = daysModelEn
203
- this.dates = datesModelEn
204
- this.months = monthsModelEn
205
- }
206
- if (lan === 'zh') {
207
- this.days = daysModelCh
208
- this.dates = datesModel
209
- this.months = monthsModel
210
- }
211
- },
212
- mounted () {
213
- // this.getAllPlan()
214
- const clientHeight = this.$el.parentElement.clientHeight
215
- const extHeight = this.isShowSingle ? 0 : 94
216
- this.maxTableHeight = clientHeight - extHeight - 1
217
- },
218
- methods: {
219
- async handeAgentidsChange () {
220
- let devs = []
221
- for (let agentid of this.agentids) {
222
- let item = {
223
- agentid: agentid,
224
- patternid: 1,
225
- isused: true
226
- }
227
- devs.push(item)
228
- }
229
- let _this = this
230
- this.$nextTick(async () => {
231
- let route = {
232
- devs: devs
233
- }
234
- let optPatternList
235
- if (_this.opt && _this.opt.optPatternList && _this.opt.optPatternList.length > 0) {
236
- route = _this.opt.optPatternList[0]
237
- let arr = []
238
- for (let dev of route.devs) {
239
- arr.push(dev.agentid)
240
- }
241
- if (arr.length === this.agentids.length) {
242
- optPatternList = _this.opt.optPatternList
243
- let opt = await this.checkAndResetList(optPatternList)
244
- optPatternList = opt.optPatternList
245
- }
246
- }
247
- this.route = route
248
- await _this.getDeviceByIds(route)
249
- _this.onAgentidsChange('', optPatternList, _this.agentids)
250
- })
251
- },
252
- async checkAndResetList (optPatternList) {
253
- let res = JSON.parse(JSON.stringify(optPatternList))
254
- let resetFlag = false
255
- for (let opt of optPatternList) {
256
- if (opt.devs && opt.devs.length > 0) {
257
- for (let dev of opt.devs) {
258
- if (!dev.feature || dev.feature.patternList) {
259
- resetFlag = true
260
- break
261
- }
262
- }
263
- }
264
- if (resetFlag) {
265
- break
266
- }
267
- }
268
- if (resetFlag) {
269
- res = await this.getFullOptList(optPatternList)
270
- }
271
- return res
272
- },
273
- async getAllPatternOfRoute (agentids) {
274
- if (agentids.length === 0) return
275
- return new Promise((resolve, reject) => {
276
- getAllPatternOfDevs(agentids).then(res => {
277
- if (!res.data.success) {
278
- let agentid = res.data.data.agentid
279
- let commomMsg = this.$t('openatccomponents.greenwaveoptimize.device') + agentid
280
- let data = res
281
- let parrenterror = getMessageByCode(data.data.code, this.$i18n.locale)
282
- if (data.data.data) {
283
- // 子类型错误
284
- let childErrorCode = data.data.data.errorCode
285
- if (childErrorCode) {
286
- let childerror = getMessageByCode(data.data.data.errorCode, this.$i18n.locale)
287
- this.$message.error(parrenterror + ',' + childerror + ',' + commomMsg)
288
- }
289
- } else {
290
- this.$message.error(parrenterror + ',' + commomMsg)
291
- }
292
- console.error('ErrorOcurrred')
293
- resolve([])
294
- }
295
- let allPatternList = res.data.data.devs
296
- resolve(allPatternList)
297
- })
298
- })
299
- },
300
- async getFullOptList (optPatternList) {
301
- let allPatternList = await this.getAllPatternOfRoute(this.agentids)
302
- // console.log('allPatternList', allPatternList)
303
- let res = {
304
- 'optPatternList': []
305
- }
306
- for (let i = 0; i < optPatternList.length; i++) {
307
- let opt = optPatternList[i]
308
- let opteItem = {
309
- 'id': i + 1,
310
- 'name': opt.name,
311
- title: opt.name,
312
- 'tabName': i + 1 + '',
313
- 'devs': []
314
- }
315
- for (let j = 0; j < opt.devs.length; j++) {
316
- let dev = opt.devs[j]
317
- let patternList = allPatternList.filter(ap => ap.agentid === dev.agentid)[0].feature.patternList
318
- let patternItem = patternList.filter(pattern => pattern.id === dev.patternid)[0]
319
- let devItem = {
320
- 'agentid': dev.agentid,
321
- 'patternid': dev.patternid,
322
- 'isused': dev.isused,
323
- 'id': j + 1,
324
- 'offset': patternItem.offset,
325
- 'cycle': patternItem.cycle,
326
- 'patternId': patternItem.id,
327
- 'desc': patternItem.desc,
328
- 'patternDesc': patternItem.patternDesc,
329
- 'feature': {
330
- 'patternList': patternList
331
- }
332
- }
333
- opteItem.devs.push(devItem)
334
- }
335
- res.optPatternList.push(opteItem)
336
- }
337
- // console.log('getFullOptList', res)
338
- return res
339
- },
340
- handlePlanChart (routeData, patternList, greenwave, allPatternList) {
341
- let chartData = {
342
- routeData,
343
- patternList,
344
- greenwave,
345
- allPatternList
346
- }
347
- this.chartData = chartData
348
- },
349
- handlePatternTable (routeData, patternList, phaseList) {
350
- let index = this.currentIndex
351
- let patterntable = this.$refs.patterntable
352
- if (patterntable instanceof Array) {
353
- patterntable = this.$refs.patterntable[index]
354
- }
355
- patterntable.onPatternTable(routeData, patternList, phaseList)
356
- },
357
- onNewPatternListChange (newPatternList) {
358
- let list = JSON.parse(JSON.stringify(newPatternList))
359
- let editableTab = this.editableTabs[this.currentIndex]
360
- let devs = editableTab.devs
361
- let devList = []
362
- for (let dev of devs) {
363
- for (let pattern of list) {
364
- if (dev.agentid === pattern.agentid) {
365
- dev = {...dev, ...pattern}
366
- dev.isused = pattern.isused
367
- let allPatterns = pattern.allPatterns
368
- for (let p of allPatterns) {
369
- if (p.id === dev.patternid) {
370
- p.cycle = dev.cycle
371
- p.offset = dev.offset
372
- p.rings = dev.rings
373
- }
374
- }
375
- dev.patternList = JSON.parse(JSON.stringify(allPatterns))
376
- if (dev.feature && dev.feature.patternList) {
377
- dev.feature.patternList = JSON.parse(JSON.stringify(allPatterns))
378
- } else {
379
- let feature = {
380
- patternList: JSON.parse(JSON.stringify(allPatterns))
381
- }
382
- dev.feature = feature
383
- }
384
- devList.push(dev)
385
- }
386
- }
387
- }
388
- editableTab.devs = devList
389
- // this.refreshChart()
390
- },
391
- afterEnter () {
392
- if (this.chooseId === 0) {
393
- return false
394
- }
395
- },
396
- checkData (tabs, isCheckName = true) {
397
- let res = true
398
- if (this.agentids.length === 0) {
399
- this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.chooseRoute'))
400
- return false
401
- }
402
- for (let tab of tabs) {
403
- if (!tab.devs || tab.devs.length === 0) {
404
- this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.abnormalIntersections'))
405
- return false
406
- }
407
- // reset date
408
- this.resetDate(tab)
409
- }
410
- return res
411
- },
412
- getPatternConfig () {
413
- let res = this.getSaveParam(true)
414
- return res
415
- },
416
- getSaveParam (filter) {
417
- // check
418
- let check = this.checkData(this.editableTabs)
419
- if (!check) {
420
- return false
421
- }
422
- let routeData = this.editableTabs
423
- let planContent = this.$refs.planContent
424
- let params = planContent.getSaveParam(this.route.id, routeData, filter)
425
- return params
426
- },
427
- onSaveClick () {
428
- // check
429
- let check = this.checkData(this.editableTabs)
430
- if (!check) {
431
- return false
432
- }
433
- let routeData = this.editableTabs
434
- let planContent = this.$refs.planContent
435
- planContent.handleSave(this.route.id, routeData)
436
- },
437
- onDownSendClick () {
438
- let routeData = this.editableTabs[this.currentIndex]
439
- let check = this.checkData([routeData])
440
- if (!check) {
441
- return false
442
- }
443
- this.resetDate(routeData)
444
- let planContent = this.$refs.planContent
445
- planContent.handleDownload(this.route.id, routeData)
446
- },
447
- async onDeleteClick (targetName) {
448
- let routeData = this.editableTabs[this.currentIndex]
449
- // check
450
- let id = routeData.id
451
- if (targetName !== routeData.tabName) {
452
- this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.choosePattern'))
453
- return false
454
- }
455
- if (this.editableTabs.length === 1) {
456
- this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.atleastOnePattern'))
457
- return false
458
- }
459
- let optPatternList = this.route.optPatternList
460
- if (!optPatternList) {
461
- return true
462
- }
463
- let list = optPatternList.filter(item => item.id === id)
464
- if (list.length === 0) {
465
- return true
466
- } else {
467
- let planContent = this.$refs.planContent
468
- let param = {
469
- routeid: this.route.id,
470
- optpatternid: id
471
- }
472
- let flag = await planContent.handleDelete(param)
473
- return flag
474
- }
475
- },
476
- resetDate (tab) {
477
- let date = tab.date
478
- let day = tab.day
479
- let month = tab.month
480
- if (date && date.includes('全选')) {
481
- let index = date.indexOf('全选')
482
- date.splice(index, 1) // 排除全选选项
483
- } else if (date && date.includes('All')) {
484
- let index = date.indexOf('All')
485
- date.splice(index, 1) // 排除全选选项
486
- }
487
- if (day && day.includes(8)) {
488
- let index = day.indexOf(8)
489
- day.splice(index, 1) // 排除全选选项
490
- }
491
- if (month && month.includes(0)) {
492
- let index = month.indexOf(0)
493
- month.splice(index, 1) // 排除全选选项
494
- }
495
- },
496
- onConditionChange () {},
497
- beforeLeave (currentName, oldName) {
498
- // var self = this // 重点,如果name是add,则什么都不触发
499
- if (currentName === 'add') {
500
- if (this.agentids.length === 0) {
501
- this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.chooseCros'))
502
- return false
503
- }
504
- if (this.isOnlyOneTab) {
505
- this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.onlyOneTab'))
506
- return false
507
- }
508
- this.addTab()
509
- return false
510
- }
511
- for (let i = 0; i < this.editableTabs.length; i++) {
512
- let tab = this.editableTabs[i]
513
- if (tab.tabName === currentName) {
514
- this.currentIndex = i
515
- break
516
- }
517
- }
518
- this.initPatternList(this.chooseId, this.agentids)
519
- },
520
- addTab () {
521
- this.handleTabsEdit('', 'add')
522
- },
523
- async handleTabsEdit (targetName, action) {
524
- if (action === 'add') {
525
- let newTabName = ++this.tabIndex + ''
526
- let tabObj = {
527
- id: this.currentIndex + 1,
528
- name: '',
529
- title: this.$t('openatccomponents.greenwaveoptimize.scene') + ' ' + newTabName,
530
- tabName: newTabName,
531
- content: 'New Tab content',
532
- patternid: 1,
533
- 'month': [],
534
- 'day': [],
535
- 'date': [],
536
- 'plan': {
537
- 'start': '08:00',
538
- 'end': '09:30'
539
- },
540
- 'optstrategy': 'green',
541
- 'direction': 'up',
542
- 'keyintsid': '',
543
- 'upspeed': 0,
544
- 'downspeed': 0,
545
- 'devs': []
546
- }
547
- this.editableTabs.push(tabObj)
548
- }
549
- if (action === 'remove') {
550
- let flag = await this.onDeleteClick(targetName)
551
- if (!flag) {
552
- return false
553
- }
554
- let tabs = this.editableTabs
555
- let activeName = this.editableTabsValue
556
- if (activeName === targetName) {
557
- tabs.forEach((tab, index) => {
558
- if (tab.tabName === targetName) {
559
- let nextTab = tabs[index + 1] || tabs[index - 1]
560
- if (nextTab) {
561
- activeName = nextTab.tabName
562
- }
563
- }
564
- })
565
- }
566
- this.editableTabsValue = activeName
567
- this.editableTabs = tabs.filter(tab => tab.tabName !== targetName)
568
- }
569
- },
570
- refresh () {
571
- // this.getAllPlan()
572
- let planContent = this.$refs.planContent
573
- if (planContent) {
574
- planContent.closeInterval()
575
- planContent.startInterval()
576
- }
577
- },
578
- editStart () {
579
- let planContent = this.$refs.planContent
580
- if (planContent && planContent.timer > 0) {
581
- planContent.closeInterval()
582
- }
583
- },
584
- maskChange (val) {
585
- // 控制两个蒙层下按钮的层级关系,并判断第二个蒙层显示的时机
586
- if (val) {
587
- this.step = false
588
- this.zIndexObj = {
589
- addZIndex: 99,
590
- editZIndex: 96
591
- }
592
- } else {
593
- this.step = true
594
- this.zIndexObj = {
595
- addZIndex: 96,
596
- editZIndex: 99
597
- }
598
- }
599
- },
600
- resetContentComponent () {
601
- // 每次切换侧边栏方案时,重置销毁planContent组件
602
- this.reset = false
603
- this.$nextTick(() => {
604
- this.reset = true
605
- })
606
- },
607
- resetTab () {
608
- this.editableTabs = [
609
- {
610
- title: this.$t('openatccomponents.greenwaveoptimize.scene') + ' 1',
611
- id: 1,
612
- name: '',
613
- tabName: '1',
614
- content: 'Tab 1 content',
615
- patternid: 1,
616
- 'month': [],
617
- 'day': [],
618
- 'date': [],
619
- 'plan': {
620
- 'start': '08:00',
621
- 'end': '09:30'
622
- },
623
- 'optstrategy': 'green',
624
- 'direction': 'up',
625
- 'keyintsid': '',
626
- 'upspeed': 0,
627
- 'downspeed': 0,
628
- 'devs': []
629
- }
630
- ]
631
- this.tabIndex = 1
632
- this.currentIndex = 0
633
- this.editableTabsValue = '1'
634
- this.keyintsidOptions = []
635
- this.chartData = {}
636
- // this.route = {}
637
- // this.agentids = []
638
- },
639
- onAgentidsChange (id, optPatternList, agentids) {
640
- // reset data
641
- if (agentids.length === 0) {
642
- return false
643
- }
644
- this.resetTab()
645
- this.chooseId = id
646
- // this.agentids = agentids
647
- // console.log('this.optPatternList', optPatternList)
648
- if (optPatternList && optPatternList.length > 0) {
649
- this.editableTabs = JSON.parse(JSON.stringify(optPatternList))
650
- // console.log('this.editableTabs', this.editableTabs)
651
- } else {
652
- // console.log(222)
653
- this.editableTabs[0].devs = this.route.devs
654
- }
655
- this.tabIndex = this.editableTabs.length
656
- this.initPatternList(id, agentids)
657
- },
658
- chooseRoute (id, route, agentids) {
659
- this.agentids = agentids
660
- },
661
- initPatternList (id, agentids) {
662
- let index = this.currentIndex
663
- let editableTab = this.editableTabs[index]
664
- let planContent = this.$refs.planContent
665
- if (planContent) {
666
- if (editableTab.devs && editableTab.devs.length === 0) {
667
- let devs = []
668
- for (let agentid of agentids) {
669
- let item = {
670
- agentid: agentid,
671
- isused: true,
672
- patternid: 1
673
- }
674
- devs.push(item)
675
- }
676
- let route = {
677
- devs: devs
678
- }
679
- editableTab = {...editableTab, ...route}
680
- editableTab.id = this.currentIndex + 1
681
- }
682
- if (this.editableTabs[index].devs.length === 0) {
683
- this.editableTabs[index] = editableTab
684
- }
685
- planContent.init(this.chooseId, editableTab, agentids)
686
- }
687
- },
688
- onErrorOcurrred () {
689
- this.resetTab()
690
- let patterntable = this.$refs.patterntable
691
- if (patterntable instanceof Array) {
692
- patterntable = patterntable[0]
693
- }
694
- patterntable.newPatternList = []
695
- },
696
- async getDeviceByIds (routeData) {
697
- // 获取设备表格信息
698
- let realtimeRouteData = JSON.parse(JSON.stringify(routeData))
699
- this.deviceIds = realtimeRouteData.devs.map(ele => ele.agentid)
700
- await GetDeviceByIds(this.deviceIds).then(res => {
701
- if (!res.data.success) {
702
- this.$message.error(getMessageByCode(res.data.code, this.$i18n.locale))
703
- return
704
- }
705
- this.devicesData = res.data.data
706
- // // 取路口对应的实际方案id
707
- // let devs = realtimeRouteData.devs
708
- // for (let inter of devs) {
709
- // inter.patternid = this.getActurlPatternid(inter.agentid)
710
- // }
711
- // this.chartData.realPatternRouteData = realtimeRouteData
712
- // this.$refs.chartDialog.show(true, this.chartData, this.route.name, this.devicesData)
713
- })
714
- },
715
- getActurlPatternid (agentid) {
716
- let devinfo = this.devicesData.filter(dev => dev.agentid === agentid)[0]
717
- if (devinfo.patternid !== undefined) {
718
- return devinfo.patternid
719
- } else {
720
- return 1
721
- }
722
- }
723
- }
724
- }
725
- </script>
726
-
727
- <style lang="scss" scoped>
728
- .el-button--primary.is-plain:active{
729
- color: #fff;
730
- }
731
- .el-button--primary.is-plain:hover, .el-button--primary.is-plain:focus{
732
- color: #fff;
733
- }
734
- >>> .el-tabs__header {
735
- padding: 0;
736
- position: relative;
737
- margin: 0 0 0px;
738
- }
739
- </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="patternConfig">
14
+ <el-container v-if="!isShowSingle" >
15
+ <div class="main-container" style="height: 100%;width: 100%;">
16
+ <el-tabs v-model="editableTabsValue" type="card" @edit="handleTabsEdit" :before-leave="beforeLeave" style="height: 100%;">
17
+ <el-tab-pane
18
+ :closable="true"
19
+ :key="item.tabName"
20
+ v-for="(item) in editableTabs"
21
+ :label="item.title"
22
+ :name="item.tabName"
23
+ >
24
+ <div class="panel-content" style="height: 100%;">
25
+ <div style="height: 6%;">
26
+ <div class="route-filter-container" style="display:flex;">
27
+ <div class="filter">
28
+ <span class="header-span">{{$t('openatccomponents.greenwaveoptimize.name')}}:</span>
29
+ <el-input
30
+ clearable
31
+ size="small"
32
+ v-model="item.title"
33
+ style="width:70%;"
34
+ @change="onConditionChange"
35
+ />
36
+ </div>
37
+ </div>
38
+ </div>
39
+ <div style="height: 94%;" class="table-container">
40
+ <PatternTable ref="patterntable"
41
+ :devicesData="devicesData"
42
+ :maxTableHeight="maxTableHeight"
43
+ :opt="item.devs"
44
+ :isAllowedExpand="isAllowedExpand"
45
+ @onNewPatternListChange="onNewPatternListChange"/>
46
+ </div>
47
+ </div>
48
+ </el-tab-pane>
49
+ <el-tab-pane key="add" name="add" :closable="false">
50
+ <span slot="label" style="padding: 8px;font-size:20px;font-weight:bold;">
51
+ +
52
+ </span>
53
+ </el-tab-pane>
54
+ </el-tabs>
55
+ </div>
56
+ </el-container>
57
+ <div v-if="isShowSingle" style="height: 94%;" class="table-container">
58
+ <PatternTable ref="patterntable"
59
+ :devicesData="devicesData"
60
+ :opt="opt.optPatternList[0].devs"
61
+ :isAllowedExpand="isAllowedExpand"
62
+ :maxTableHeight="maxTableHeight"
63
+ @onNewPatternListChange="onNewPatternListChange"/>
64
+ </div>
65
+ <PlanContent v-show="false"
66
+ :schemeData="schemeData"
67
+ :step="step"
68
+ :zIndexObj="zIndexObj"
69
+ ref="planContent"
70
+ @handlePlanChart="handlePlanChart"
71
+ @handlePatternTable="handlePatternTable"
72
+ @ErrorOcurrred='onErrorOcurrred'
73
+ @resetContentComponent="resetContentComponent"/>
74
+ </div>
75
+ </template>
76
+
77
+ <script>
78
+ import PlanContent from './planContent'
79
+ import { getMessageByCode } from '../../../utils/responseMessage'
80
+ import PatternTable from './pattern/patternTable'
81
+ import dateObj from './utils.js'
82
+ import { GetDeviceByIds } from '../../../api/device.js'
83
+ import { getAllPatternOfDevs } from '../../../api/route'
84
+ const { monthsModel, daysModelCh, daysModelEn, datesModel, monthsModelEn, datesModelEn } = dateObj
85
+ export default {
86
+ name: 'PatternConfig',
87
+ components: {
88
+ PatternTable,
89
+ PlanContent
90
+ },
91
+ props: {
92
+ agentids: {
93
+ type: Array,
94
+ default: () => []
95
+ },
96
+ opt: {
97
+ type: Object,
98
+ default: () => null
99
+ },
100
+ isOnlyOneTab: {
101
+ type: Boolean,
102
+ default: true
103
+ },
104
+ isAllowedExpand: {
105
+ type: Boolean,
106
+ default: true
107
+ },
108
+ isShowSingle: {
109
+ type: Boolean,
110
+ default: false
111
+ }
112
+ },
113
+ watch: {
114
+ agentids: {
115
+ handler (val, old) {
116
+ if (old && val.join('') === old.join('')) {
117
+ return false
118
+ }
119
+ if (!val || val.length === 0) {
120
+ console.log('ematy anentids:', val)
121
+ return false
122
+ }
123
+ console.log('full anentids:', val)
124
+ this.handeAgentidsChange()
125
+ },
126
+ immediate: true
127
+ }
128
+ },
129
+ data () {
130
+ return {
131
+ devicesData: [],
132
+ deviceIds: [],
133
+ maxTableHeight: 200,
134
+ chartData: {},
135
+ months: monthsModel,
136
+ days: [],
137
+ dates: datesModel,
138
+ planData: [],
139
+ schemeData: [],
140
+ step: false, // 控制第二个蒙层是否可以显示
141
+ zIndexObj: {
142
+ // 由于“新增”“编辑”均有蒙层,因此需动态改变可点击按钮层级
143
+ addZIndex: 98,
144
+ editZIndex: 98
145
+ },
146
+ reset: false,
147
+ activeName: 'first',
148
+ chooseId: 0, // 选中的计划id
149
+ // agentids: [],
150
+ // isOnlyOneTab: true,
151
+ loading: false,
152
+ keyintsidOptions: [],
153
+ editableTabsValue: '1',
154
+ routePattern: {
155
+ 'id': 1,
156
+ 'optPatternList': []
157
+ },
158
+ defaultOptPattern: {
159
+ 'tabName': '1',
160
+ 'month': [],
161
+ patternid: 1,
162
+ 'day': [],
163
+ 'date': [],
164
+ 'plan': {
165
+ 'start': '11:00',
166
+ 'end': '13:00'
167
+ },
168
+ 'optstrategy': 'green',
169
+ 'direction': 'up',
170
+ 'keyintsid': '',
171
+ 'upspeed': 0,
172
+ 'downspeed': 0,
173
+ 'devs': []
174
+ },
175
+ currentIndex: 0,
176
+ editableTabs: [{
177
+ title: '仿真实例 1',
178
+ tabName: '1',
179
+ content: 'Tab 1 content',
180
+ patternid: 1,
181
+ 'month': [],
182
+ 'day': [],
183
+ 'date': [],
184
+ 'plan': {
185
+ 'start': '11:00',
186
+ 'end': '13:00'
187
+ },
188
+ 'optstrategy': 'green',
189
+ 'direction': 'up',
190
+ 'keyintsid': '',
191
+ 'upspeed': 0,
192
+ 'downspeed': 0,
193
+ 'devs': []
194
+ }],
195
+ tabIndex: 1
196
+ }
197
+ },
198
+ created () {
199
+ this.resetTab()
200
+ let lan = this.$i18n.locale
201
+ if (lan === 'en') {
202
+ this.days = daysModelEn
203
+ this.dates = datesModelEn
204
+ this.months = monthsModelEn
205
+ }
206
+ if (lan === 'zh') {
207
+ this.days = daysModelCh
208
+ this.dates = datesModel
209
+ this.months = monthsModel
210
+ }
211
+ },
212
+ mounted () {
213
+ // this.getAllPlan()
214
+ const clientHeight = this.$el.parentElement.clientHeight
215
+ const extHeight = this.isShowSingle ? 0 : 94
216
+ this.maxTableHeight = clientHeight - extHeight - 1
217
+ },
218
+ methods: {
219
+ async handeAgentidsChange () {
220
+ let devs = []
221
+ for (let agentid of this.agentids) {
222
+ let item = {
223
+ agentid: agentid,
224
+ patternid: 1,
225
+ isused: true
226
+ }
227
+ devs.push(item)
228
+ }
229
+ let _this = this
230
+ this.$nextTick(async () => {
231
+ let route = {
232
+ devs: devs
233
+ }
234
+ let optPatternList
235
+ if (_this.opt && _this.opt.optPatternList && _this.opt.optPatternList.length > 0) {
236
+ route = _this.opt.optPatternList[0]
237
+ let arr = []
238
+ for (let dev of route.devs) {
239
+ arr.push(dev.agentid)
240
+ }
241
+ if (arr.length === this.agentids.length) {
242
+ optPatternList = _this.opt.optPatternList
243
+ let opt = await this.checkAndResetList(optPatternList)
244
+ optPatternList = opt.optPatternList
245
+ }
246
+ }
247
+ this.route = route
248
+ await _this.getDeviceByIds(route)
249
+ _this.onAgentidsChange('', optPatternList, _this.agentids)
250
+ })
251
+ },
252
+ async checkAndResetList (optPatternList) {
253
+ let res = JSON.parse(JSON.stringify(optPatternList))
254
+ let resetFlag = false
255
+ for (let opt of optPatternList) {
256
+ if (opt.devs && opt.devs.length > 0) {
257
+ for (let dev of opt.devs) {
258
+ if (!dev.feature || dev.feature.patternList) {
259
+ resetFlag = true
260
+ break
261
+ }
262
+ }
263
+ }
264
+ if (resetFlag) {
265
+ break
266
+ }
267
+ }
268
+ if (resetFlag) {
269
+ res = await this.getFullOptList(optPatternList)
270
+ }
271
+ return res
272
+ },
273
+ async getAllPatternOfRoute (agentids) {
274
+ if (agentids.length === 0) return
275
+ return new Promise((resolve, reject) => {
276
+ getAllPatternOfDevs(agentids).then(res => {
277
+ if (!res.data.success) {
278
+ let agentid = res.data.data.agentid
279
+ let commomMsg = this.$t('openatccomponents.greenwaveoptimize.device') + agentid
280
+ let data = res
281
+ let parrenterror = getMessageByCode(data.data.code, this.$i18n.locale)
282
+ if (data.data.data) {
283
+ // 子类型错误
284
+ let childErrorCode = data.data.data.errorCode
285
+ if (childErrorCode) {
286
+ let childerror = getMessageByCode(data.data.data.errorCode, this.$i18n.locale)
287
+ this.$message.error(parrenterror + ',' + childerror + ',' + commomMsg)
288
+ }
289
+ } else {
290
+ this.$message.error(parrenterror + ',' + commomMsg)
291
+ }
292
+ console.error('ErrorOcurrred')
293
+ resolve([])
294
+ }
295
+ let allPatternList = res.data.data.devs
296
+ resolve(allPatternList)
297
+ })
298
+ })
299
+ },
300
+ async getFullOptList (optPatternList) {
301
+ let allPatternList = await this.getAllPatternOfRoute(this.agentids)
302
+ // console.log('allPatternList', allPatternList)
303
+ let res = {
304
+ 'optPatternList': []
305
+ }
306
+ for (let i = 0; i < optPatternList.length; i++) {
307
+ let opt = optPatternList[i]
308
+ let opteItem = {
309
+ 'id': i + 1,
310
+ 'name': opt.name,
311
+ title: opt.name,
312
+ 'tabName': i + 1 + '',
313
+ 'devs': []
314
+ }
315
+ for (let j = 0; j < opt.devs.length; j++) {
316
+ let dev = opt.devs[j]
317
+ let patternList = allPatternList.filter(ap => ap.agentid === dev.agentid)[0].feature.patternList
318
+ let patternItem = patternList.filter(pattern => pattern.id === dev.patternid)[0]
319
+ let devItem = {
320
+ 'agentid': dev.agentid,
321
+ 'patternid': dev.patternid,
322
+ 'isused': dev.isused,
323
+ 'id': j + 1,
324
+ 'offset': patternItem.offset,
325
+ 'cycle': patternItem.cycle,
326
+ 'patternId': patternItem.id,
327
+ 'desc': patternItem.desc,
328
+ 'patternDesc': patternItem.patternDesc,
329
+ 'feature': {
330
+ 'patternList': patternList
331
+ }
332
+ }
333
+ opteItem.devs.push(devItem)
334
+ }
335
+ res.optPatternList.push(opteItem)
336
+ }
337
+ // console.log('getFullOptList', res)
338
+ return res
339
+ },
340
+ handlePlanChart (routeData, patternList, greenwave, allPatternList) {
341
+ let chartData = {
342
+ routeData,
343
+ patternList,
344
+ greenwave,
345
+ allPatternList
346
+ }
347
+ this.chartData = chartData
348
+ },
349
+ handlePatternTable (routeData, patternList, phaseList) {
350
+ let index = this.currentIndex
351
+ let patterntable = this.$refs.patterntable
352
+ if (patterntable instanceof Array) {
353
+ patterntable = this.$refs.patterntable[index]
354
+ }
355
+ patterntable.onPatternTable(routeData, patternList, phaseList)
356
+ },
357
+ onNewPatternListChange (newPatternList) {
358
+ let list = JSON.parse(JSON.stringify(newPatternList))
359
+ let editableTab = this.editableTabs[this.currentIndex]
360
+ let devs = editableTab.devs
361
+ let devList = []
362
+ for (let dev of devs) {
363
+ for (let pattern of list) {
364
+ if (dev.agentid === pattern.agentid) {
365
+ dev = {...dev, ...pattern}
366
+ dev.isused = pattern.isused
367
+ let allPatterns = pattern.allPatterns
368
+ for (let p of allPatterns) {
369
+ if (p.id === dev.patternid) {
370
+ p.cycle = dev.cycle
371
+ p.offset = dev.offset
372
+ p.rings = dev.rings
373
+ }
374
+ }
375
+ dev.patternList = JSON.parse(JSON.stringify(allPatterns))
376
+ if (dev.feature && dev.feature.patternList) {
377
+ dev.feature.patternList = JSON.parse(JSON.stringify(allPatterns))
378
+ } else {
379
+ let feature = {
380
+ patternList: JSON.parse(JSON.stringify(allPatterns))
381
+ }
382
+ dev.feature = feature
383
+ }
384
+ devList.push(dev)
385
+ }
386
+ }
387
+ }
388
+ editableTab.devs = devList
389
+ // this.refreshChart()
390
+ },
391
+ afterEnter () {
392
+ if (this.chooseId === 0) {
393
+ return false
394
+ }
395
+ },
396
+ checkData (tabs, isCheckName = true) {
397
+ let res = true
398
+ if (this.agentids.length === 0) {
399
+ this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.chooseRoute'))
400
+ return false
401
+ }
402
+ for (let tab of tabs) {
403
+ if (!tab.devs || tab.devs.length === 0) {
404
+ this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.abnormalIntersections'))
405
+ return false
406
+ }
407
+ // reset date
408
+ this.resetDate(tab)
409
+ }
410
+ return res
411
+ },
412
+ getPatternConfig () {
413
+ let res = this.getSaveParam(true)
414
+ return res
415
+ },
416
+ getSaveParam (filter) {
417
+ // check
418
+ let check = this.checkData(this.editableTabs)
419
+ if (!check) {
420
+ return false
421
+ }
422
+ let routeData = this.editableTabs
423
+ let planContent = this.$refs.planContent
424
+ let params = planContent.getSaveParam(this.route.id, routeData, filter)
425
+ return params
426
+ },
427
+ onSaveClick () {
428
+ // check
429
+ let check = this.checkData(this.editableTabs)
430
+ if (!check) {
431
+ return false
432
+ }
433
+ let routeData = this.editableTabs
434
+ let planContent = this.$refs.planContent
435
+ planContent.handleSave(this.route.id, routeData)
436
+ },
437
+ onDownSendClick () {
438
+ let routeData = this.editableTabs[this.currentIndex]
439
+ let check = this.checkData([routeData])
440
+ if (!check) {
441
+ return false
442
+ }
443
+ this.resetDate(routeData)
444
+ let planContent = this.$refs.planContent
445
+ planContent.handleDownload(this.route.id, routeData)
446
+ },
447
+ async onDeleteClick (targetName) {
448
+ let routeData = this.editableTabs[this.currentIndex]
449
+ // check
450
+ let id = routeData.id
451
+ if (targetName !== routeData.tabName) {
452
+ this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.choosePattern'))
453
+ return false
454
+ }
455
+ if (this.editableTabs.length === 1) {
456
+ this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.atleastOnePattern'))
457
+ return false
458
+ }
459
+ let optPatternList = this.route.optPatternList
460
+ if (!optPatternList) {
461
+ return true
462
+ }
463
+ let list = optPatternList.filter(item => item.id === id)
464
+ if (list.length === 0) {
465
+ return true
466
+ } else {
467
+ let planContent = this.$refs.planContent
468
+ let param = {
469
+ routeid: this.route.id,
470
+ optpatternid: id
471
+ }
472
+ let flag = await planContent.handleDelete(param)
473
+ return flag
474
+ }
475
+ },
476
+ resetDate (tab) {
477
+ let date = tab.date
478
+ let day = tab.day
479
+ let month = tab.month
480
+ if (date && date.includes('全选')) {
481
+ let index = date.indexOf('全选')
482
+ date.splice(index, 1) // 排除全选选项
483
+ } else if (date && date.includes('All')) {
484
+ let index = date.indexOf('All')
485
+ date.splice(index, 1) // 排除全选选项
486
+ }
487
+ if (day && day.includes(8)) {
488
+ let index = day.indexOf(8)
489
+ day.splice(index, 1) // 排除全选选项
490
+ }
491
+ if (month && month.includes(0)) {
492
+ let index = month.indexOf(0)
493
+ month.splice(index, 1) // 排除全选选项
494
+ }
495
+ },
496
+ onConditionChange () {},
497
+ beforeLeave (currentName, oldName) {
498
+ // var self = this // 重点,如果name是add,则什么都不触发
499
+ if (currentName === 'add') {
500
+ if (this.agentids.length === 0) {
501
+ this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.chooseCros'))
502
+ return false
503
+ }
504
+ if (this.isOnlyOneTab) {
505
+ this.$message.warning(this.$t('openatccomponents.greenwaveoptimize.onlyOneTab'))
506
+ return false
507
+ }
508
+ this.addTab()
509
+ return false
510
+ }
511
+ for (let i = 0; i < this.editableTabs.length; i++) {
512
+ let tab = this.editableTabs[i]
513
+ if (tab.tabName === currentName) {
514
+ this.currentIndex = i
515
+ break
516
+ }
517
+ }
518
+ this.initPatternList(this.chooseId, this.agentids)
519
+ },
520
+ addTab () {
521
+ this.handleTabsEdit('', 'add')
522
+ },
523
+ async handleTabsEdit (targetName, action) {
524
+ if (action === 'add') {
525
+ let newTabName = ++this.tabIndex + ''
526
+ let tabObj = {
527
+ id: this.currentIndex + 1,
528
+ name: '',
529
+ title: this.$t('openatccomponents.greenwaveoptimize.scene') + ' ' + newTabName,
530
+ tabName: newTabName,
531
+ content: 'New Tab content',
532
+ patternid: 1,
533
+ 'month': [],
534
+ 'day': [],
535
+ 'date': [],
536
+ 'plan': {
537
+ 'start': '08:00',
538
+ 'end': '09:30'
539
+ },
540
+ 'optstrategy': 'green',
541
+ 'direction': 'up',
542
+ 'keyintsid': '',
543
+ 'upspeed': 0,
544
+ 'downspeed': 0,
545
+ 'devs': []
546
+ }
547
+ this.editableTabs.push(tabObj)
548
+ }
549
+ if (action === 'remove') {
550
+ let flag = await this.onDeleteClick(targetName)
551
+ if (!flag) {
552
+ return false
553
+ }
554
+ let tabs = this.editableTabs
555
+ let activeName = this.editableTabsValue
556
+ if (activeName === targetName) {
557
+ tabs.forEach((tab, index) => {
558
+ if (tab.tabName === targetName) {
559
+ let nextTab = tabs[index + 1] || tabs[index - 1]
560
+ if (nextTab) {
561
+ activeName = nextTab.tabName
562
+ }
563
+ }
564
+ })
565
+ }
566
+ this.editableTabsValue = activeName
567
+ this.editableTabs = tabs.filter(tab => tab.tabName !== targetName)
568
+ }
569
+ },
570
+ refresh () {
571
+ // this.getAllPlan()
572
+ let planContent = this.$refs.planContent
573
+ if (planContent) {
574
+ planContent.closeInterval()
575
+ planContent.startInterval()
576
+ }
577
+ },
578
+ editStart () {
579
+ let planContent = this.$refs.planContent
580
+ if (planContent && planContent.timer > 0) {
581
+ planContent.closeInterval()
582
+ }
583
+ },
584
+ maskChange (val) {
585
+ // 控制两个蒙层下按钮的层级关系,并判断第二个蒙层显示的时机
586
+ if (val) {
587
+ this.step = false
588
+ this.zIndexObj = {
589
+ addZIndex: 99,
590
+ editZIndex: 96
591
+ }
592
+ } else {
593
+ this.step = true
594
+ this.zIndexObj = {
595
+ addZIndex: 96,
596
+ editZIndex: 99
597
+ }
598
+ }
599
+ },
600
+ resetContentComponent () {
601
+ // 每次切换侧边栏方案时,重置销毁planContent组件
602
+ this.reset = false
603
+ this.$nextTick(() => {
604
+ this.reset = true
605
+ })
606
+ },
607
+ resetTab () {
608
+ this.editableTabs = [
609
+ {
610
+ title: this.$t('openatccomponents.greenwaveoptimize.scene') + ' 1',
611
+ id: 1,
612
+ name: '',
613
+ tabName: '1',
614
+ content: 'Tab 1 content',
615
+ patternid: 1,
616
+ 'month': [],
617
+ 'day': [],
618
+ 'date': [],
619
+ 'plan': {
620
+ 'start': '08:00',
621
+ 'end': '09:30'
622
+ },
623
+ 'optstrategy': 'green',
624
+ 'direction': 'up',
625
+ 'keyintsid': '',
626
+ 'upspeed': 0,
627
+ 'downspeed': 0,
628
+ 'devs': []
629
+ }
630
+ ]
631
+ this.tabIndex = 1
632
+ this.currentIndex = 0
633
+ this.editableTabsValue = '1'
634
+ this.keyintsidOptions = []
635
+ this.chartData = {}
636
+ // this.route = {}
637
+ // this.agentids = []
638
+ },
639
+ onAgentidsChange (id, optPatternList, agentids) {
640
+ // reset data
641
+ if (agentids.length === 0) {
642
+ return false
643
+ }
644
+ this.resetTab()
645
+ this.chooseId = id
646
+ // this.agentids = agentids
647
+ // console.log('this.optPatternList', optPatternList)
648
+ if (optPatternList && optPatternList.length > 0) {
649
+ this.editableTabs = JSON.parse(JSON.stringify(optPatternList))
650
+ // console.log('this.editableTabs', this.editableTabs)
651
+ } else {
652
+ // console.log(222)
653
+ this.editableTabs[0].devs = this.route.devs
654
+ }
655
+ this.tabIndex = this.editableTabs.length
656
+ this.initPatternList(id, agentids)
657
+ },
658
+ chooseRoute (id, route, agentids) {
659
+ this.agentids = agentids
660
+ },
661
+ initPatternList (id, agentids) {
662
+ let index = this.currentIndex
663
+ let editableTab = this.editableTabs[index]
664
+ let planContent = this.$refs.planContent
665
+ if (planContent) {
666
+ if (editableTab.devs && editableTab.devs.length === 0) {
667
+ let devs = []
668
+ for (let agentid of agentids) {
669
+ let item = {
670
+ agentid: agentid,
671
+ isused: true,
672
+ patternid: 1
673
+ }
674
+ devs.push(item)
675
+ }
676
+ let route = {
677
+ devs: devs
678
+ }
679
+ editableTab = {...editableTab, ...route}
680
+ editableTab.id = this.currentIndex + 1
681
+ }
682
+ if (this.editableTabs[index].devs.length === 0) {
683
+ this.editableTabs[index] = editableTab
684
+ }
685
+ planContent.init(this.chooseId, editableTab, agentids)
686
+ }
687
+ },
688
+ onErrorOcurrred () {
689
+ this.resetTab()
690
+ let patterntable = this.$refs.patterntable
691
+ if (patterntable instanceof Array) {
692
+ patterntable = patterntable[0]
693
+ }
694
+ patterntable.newPatternList = []
695
+ },
696
+ async getDeviceByIds (routeData) {
697
+ // 获取设备表格信息
698
+ let realtimeRouteData = JSON.parse(JSON.stringify(routeData))
699
+ this.deviceIds = realtimeRouteData.devs.map(ele => ele.agentid)
700
+ await GetDeviceByIds(this.deviceIds).then(res => {
701
+ if (!res.data.success) {
702
+ this.$message.error(getMessageByCode(res.data.code, this.$i18n.locale))
703
+ return
704
+ }
705
+ this.devicesData = res.data.data
706
+ // // 取路口对应的实际方案id
707
+ // let devs = realtimeRouteData.devs
708
+ // for (let inter of devs) {
709
+ // inter.patternid = this.getActurlPatternid(inter.agentid)
710
+ // }
711
+ // this.chartData.realPatternRouteData = realtimeRouteData
712
+ // this.$refs.chartDialog.show(true, this.chartData, this.route.name, this.devicesData)
713
+ })
714
+ },
715
+ getActurlPatternid (agentid) {
716
+ let devinfo = this.devicesData.filter(dev => dev.agentid === agentid)[0]
717
+ if (devinfo.patternid !== undefined) {
718
+ return devinfo.patternid
719
+ } else {
720
+ return 1
721
+ }
722
+ }
723
+ }
724
+ }
725
+ </script>
726
+
727
+ <style lang="scss" scoped>
728
+ .el-button--primary.is-plain:active{
729
+ color: #fff;
730
+ }
731
+ .el-button--primary.is-plain:hover, .el-button--primary.is-plain:focus{
732
+ color: #fff;
733
+ }
734
+ >>> .el-tabs__header {
735
+ padding: 0;
736
+ position: relative;
737
+ margin: 0 0 0px;
738
+ }
739
+ </style>