openatc-components 0.0.15 → 0.0.16

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 (251) hide show
  1. package/.babelrc +18 -18
  2. package/.editorconfig +9 -9
  3. package/.eslintignore +5 -5
  4. package/.eslintrc.js +29 -29
  5. package/.postcssrc.js +10 -10
  6. package/README.md +30 -30
  7. package/build/build.js +41 -41
  8. package/build/check-versions.js +54 -54
  9. package/build/package.config.js +58 -58
  10. package/build/package.dev.config.js +107 -107
  11. package/build/package.prod.config.js +160 -160
  12. package/build/utils.js +101 -101
  13. package/build/vue-loader.conf.js +22 -22
  14. package/build/webpack.base.conf.js +114 -114
  15. package/build/webpack.dev.conf.js +95 -95
  16. package/build/webpack.prod.conf.js +149 -149
  17. package/config/dev.env.js +8 -8
  18. package/config/index.js +90 -90
  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 +85 -0
  23. package/package/kisscomps/components/BoardCard/index.js +2 -0
  24. package/package/kisscomps/components/CommonKanban/CommonKanban.vue +119 -119
  25. package/package/kisscomps/components/CommonKanban/index.js +2 -2
  26. package/package/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +170 -170
  27. package/package/kisscomps/components/FaultDetailModal/index.js +2 -2
  28. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +497 -497
  29. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  30. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PatternWalkSvg.vue +295 -295
  31. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +300 -300
  32. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +288 -288
  33. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +391 -391
  34. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +336 -336
  35. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +345 -345
  36. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +389 -389
  37. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1179 -1179
  38. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +402 -402
  39. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +361 -361
  40. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +368 -368
  41. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +475 -475
  42. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +494 -494
  43. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +401 -401
  44. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +360 -360
  45. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +367 -367
  46. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +476 -476
  47. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  48. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  49. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  50. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  51. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  52. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  53. package/package/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +856 -856
  54. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +112 -112
  55. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +112 -112
  56. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +111 -111
  57. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  58. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  59. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +99 -99
  60. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +99 -99
  61. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  62. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +99 -99
  63. package/package/kisscomps/components/IntersectionMap/crossDirection/utils.js +78 -78
  64. package/package/kisscomps/components/IntersectionMap/index.js +2 -2
  65. package/package/kisscomps/components/IntersectionMap/intersectionmap.vue +144 -144
  66. package/package/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +273 -273
  67. package/package/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  68. package/package/kisscomps/components/OverLap/OverLap.vue +193 -0
  69. package/package/kisscomps/components/OverLap/index.js +2 -0
  70. package/package/kisscomps/components/PatternStatus/PatternStatus.vue +832 -0
  71. package/package/kisscomps/components/PatternStatus/index.js +2 -0
  72. package/package/kisscomps/components/SchemeConfig/SchemeConfig.vue +772 -772
  73. package/package/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +195 -195
  74. package/package/kisscomps/components/SchemeConfig/index.js +2 -2
  75. package/package/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +198 -198
  76. package/package/kisscomps/components/SchemeConfig/manualControlModal/index.vue +177 -177
  77. package/package/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +298 -298
  78. package/package/kisscomps/components/StageStatus/StageStatus.vue +303 -0
  79. package/package/kisscomps/components/StageStatus/index.js +2 -0
  80. package/package/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  81. package/package/kisscomps/components/SvgIcon/index.js +2 -2
  82. package/package/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +522 -522
  83. package/package/kisscomps/components/XRDDirSelector/index.js +2 -2
  84. package/package/kisscomps/components/patternList/index.js +2 -0
  85. package/package/kisscomps/components/patternList/patternList.vue +558 -0
  86. package/package/kisscomps/index.js +69 -59
  87. package/package/kissui.min.js +1 -1
  88. package/package.json +122 -122
  89. package/src/App.vue +24 -24
  90. package/src/EdgeMgr/EdgeModelBase.js +16 -16
  91. package/src/EdgeMgr/controller/crossDiagramMgr.js +120 -120
  92. package/src/api/authapi.js +31 -31
  93. package/src/api/config.js +21 -21
  94. package/src/api/control.js +76 -76
  95. package/src/api/fault.js +66 -66
  96. package/src/api/index.js +24 -24
  97. package/src/api/login.js +46 -46
  98. package/src/api/optimize.js +72 -72
  99. package/src/api/param.js +154 -154
  100. package/src/api/passwdAssest.js +101 -101
  101. package/src/api/template.js +27 -27
  102. package/src/i18n/index.js +26 -26
  103. package/src/i18n/language/en.js +1108 -1108
  104. package/src/i18n/language/index.js +25 -25
  105. package/src/i18n/language/zh.js +1107 -1107
  106. package/src/icons/index.js +20 -20
  107. package/src/icons/svg/bendi.svg +110 -110
  108. package/src/icons/svg/bujin.svg +36 -36
  109. package/src/icons/svg/connectBlue.svg +7 -7
  110. package/src/icons/svg/currentvolume.svg +0 -0
  111. package/src/icons/svg/cutRed.svg +7 -7
  112. package/src/icons/svg/cycle.svg +0 -0
  113. package/src/icons/svg/dingzhouqi.svg +34 -34
  114. package/src/icons/svg/ganyingkongzhi.svg +30 -30
  115. package/src/icons/svg/guandeng.svg +81 -81
  116. package/src/icons/svg/huangshan.svg +71 -71
  117. package/src/icons/svg/maincontrol.svg +0 -0
  118. package/src/icons/svg/manualcontrolbackground.svg +51 -51
  119. package/src/icons/svg/manualcontrolbackground1.svg +62 -62
  120. package/src/icons/svg/manualcontrolbackgrounden.svg +62 -62
  121. package/src/icons/svg/model.svg +0 -0
  122. package/src/icons/svg/phasediff.svg +0 -0
  123. package/src/icons/svg/quanhong.svg +86 -86
  124. package/src/icons/svg/shanghe.svg +11 -11
  125. package/src/icons/svg/shoudong.svg +103 -103
  126. package/src/icons/svg/time.svg +0 -0
  127. package/src/icons/svg/wuxianlan.svg +46 -46
  128. package/src/icons/svg/xiala.svg +11 -11
  129. package/src/icons/svg/xingrenguojie.svg +33 -33
  130. package/src/icons/svg/xitong.svg +89 -89
  131. package/src/icons/svg/youxian.svg +41 -41
  132. package/src/icons/svg/zizhukongzhi.svg +43 -43
  133. package/src/kisscomps/components/BoardCard/BoardCard.vue +85 -0
  134. package/src/kisscomps/components/BoardCard/index.js +2 -0
  135. package/src/kisscomps/components/CommonKanban/CommonKanban.vue +119 -119
  136. package/src/kisscomps/components/CommonKanban/index.js +2 -2
  137. package/src/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +170 -170
  138. package/src/kisscomps/components/FaultDetailModal/index.js +2 -2
  139. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +497 -497
  140. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  141. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PatternWalkSvg.vue +295 -295
  142. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +300 -300
  143. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +288 -288
  144. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +391 -391
  145. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +336 -336
  146. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +345 -345
  147. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +389 -389
  148. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1179 -1179
  149. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +402 -402
  150. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +361 -361
  151. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +368 -368
  152. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +475 -475
  153. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +494 -494
  154. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +401 -401
  155. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +360 -360
  156. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +367 -367
  157. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +476 -476
  158. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  159. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  160. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  161. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  162. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  163. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  164. package/src/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +856 -856
  165. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +112 -112
  166. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +112 -112
  167. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +111 -111
  168. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  169. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  170. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +99 -99
  171. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +99 -99
  172. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  173. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +99 -99
  174. package/src/kisscomps/components/IntersectionMap/crossDirection/utils.js +78 -78
  175. package/src/kisscomps/components/IntersectionMap/index.js +2 -2
  176. package/src/kisscomps/components/IntersectionMap/intersectionmap.vue +144 -144
  177. package/src/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +273 -273
  178. package/src/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  179. package/src/kisscomps/components/OverLap/OverLap.vue +193 -0
  180. package/src/kisscomps/components/OverLap/index.js +2 -0
  181. package/src/kisscomps/components/PatternStatus/PatternStatus.vue +832 -0
  182. package/src/kisscomps/components/PatternStatus/index.js +2 -0
  183. package/src/kisscomps/components/SchemeConfig/SchemeConfig.vue +772 -772
  184. package/src/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +195 -195
  185. package/src/kisscomps/components/SchemeConfig/index.js +2 -2
  186. package/src/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +198 -198
  187. package/src/kisscomps/components/SchemeConfig/manualControlModal/index.vue +177 -177
  188. package/src/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +298 -298
  189. package/src/kisscomps/components/StageStatus/StageStatus.vue +303 -0
  190. package/src/kisscomps/components/StageStatus/index.js +2 -0
  191. package/src/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  192. package/src/kisscomps/components/SvgIcon/index.js +2 -2
  193. package/src/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +522 -522
  194. package/src/kisscomps/components/XRDDirSelector/index.js +2 -2
  195. package/src/kisscomps/components/patternList/index.js +2 -0
  196. package/src/kisscomps/components/patternList/patternList.vue +558 -0
  197. package/src/kisscomps/index.js +69 -59
  198. package/src/lib/publicjs/ArryListUtil.js +38 -38
  199. package/src/lib/publicjs/HttpurlMgr.js +45 -45
  200. package/src/lib/publicjs/KissApi.js +156 -156
  201. package/src/lib/publicjs/KissWSSub/Heartcheck.js +128 -128
  202. package/src/lib/publicjs/KissWSSub/KissWsSub.js +91 -91
  203. package/src/lib/publicjs/KissWSSub/KissWsSubByType.js +152 -152
  204. package/src/lib/publicjs/KissWSSub/SimuWsSubByType.js +44 -44
  205. package/src/lib/publicjs/KissWSSub/Sub.js +51 -51
  206. package/src/lib/publicjs/KissWSSub/SubChannel.js +119 -119
  207. package/src/lib/publicjs/basecomponents.js +65 -65
  208. package/src/lib/publicjs/localStorage.js +112 -112
  209. package/src/lib/publicjs/objdeepcopy.js +32 -32
  210. package/src/lib/publicjs/pageScroll.js +30 -30
  211. package/src/lib/publicjs/passwdAssest.js +101 -101
  212. package/src/lib/publicjs/styleclassfactory.js +32 -32
  213. package/src/main.js +44 -44
  214. package/src/router/index.js +29 -29
  215. package/src/store/getters.js +16 -16
  216. package/src/store/index.js +26 -26
  217. package/src/store/modules/globalParam.js +27 -27
  218. package/src/utils/RingDataModel.js +98 -98
  219. package/src/utils/auth.js +102 -102
  220. package/src/utils/dateFormat.js +41 -41
  221. package/src/utils/errorcode.js +224 -224
  222. package/src/utils/fault.js +195 -195
  223. package/src/utils/faultcode.js +209 -209
  224. package/src/utils/index.js +69 -69
  225. package/src/utils/pedphasedesc.js +119 -119
  226. package/src/utils/phasedesc.js +124 -124
  227. package/src/utils/responseMessage.js +21 -21
  228. package/src/utils/validate.js +43 -43
  229. package/src/views/home.1.vue +479 -479
  230. package/src/views/home.vue +63 -63
  231. package/src/views/intersection.vue +86 -86
  232. package/src/views/schemeconfig.vue +146 -146
  233. package/static/apiconfig.json +336 -336
  234. package/static/styles/common.scss +17 -17
  235. package/static/styles/commonkanban.scss +87 -87
  236. package/static/styles/dark/index.scss +2 -2
  237. package/static/styles/dark/theme/element-dark.scss +42 -42
  238. package/static/styles/index.scss +84 -84
  239. package/static/styles/intersection.scss +143 -143
  240. package/static/styles/light/index.scss +2 -2
  241. package/static/styles/light/theme/element-light.scss +42 -42
  242. package/static/styles/schemeconfig.scss +298 -298
  243. package/static/token.json +2 -2
  244. package/test/e2e/custom-assertions/elementCount.js +27 -27
  245. package/test/e2e/nightwatch.conf.js +46 -46
  246. package/test/e2e/runner.js +48 -48
  247. package/test/e2e/specs/test.js +19 -19
  248. package/test/unit/.eslintrc +7 -7
  249. package/test/unit/jest.conf.js +30 -30
  250. package/test/unit/setup.js +3 -3
  251. package/test/unit/specs/HelloWorld.spec.js +11 -11
@@ -1,273 +1,273 @@
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
- <!--动态路口图,只需要设备AgentId,此组件会处理方案状态接口轮询-->
13
- <template>
14
- <div class="intersection-with-interface">
15
- <IntersectionMap
16
- ref="intersectionMap"
17
- :crossStatusData="crossStatusData"
18
- :devStatus="devStatus"
19
- :agentId="agentId"
20
- :graphicMode="true"
21
- :roadDirection="roadDirection" />
22
- </div>
23
- </template>
24
- <script>
25
- import IntersectionMap from '../IntersectionMap'
26
- import { getMessageByCode } from '../../../utils/responseMessage'
27
- import { getTscControl, queryDevice } from '../../../api/control.js'
28
- import { registerMessage } from '../../../api/param'
29
- import { getIframdevid, setIframdevid, setToken } from '../../../utils/auth.js'
30
- export default {
31
- name: 'intersection-with-interface',
32
- components: {
33
- IntersectionMap
34
- },
35
- data () {
36
- return {
37
- boxVisible: false,
38
- dialogWidth: '100%',
39
- crossStatusData: {}, // 路口状态数据
40
- devStatus: 1,
41
- isResend: true,
42
- intervalFlag: true,
43
- phaseControlTimer: null, // 定时器
44
- registerMessageTimer: null // 延时器
45
- }
46
- },
47
- props: {
48
- AgentId: {
49
- type: String,
50
- default: '0'
51
- },
52
- Token: {
53
- type: String,
54
- default: ''
55
- },
56
- roadDirection: {
57
- type: String,
58
- default: 'right'
59
- }
60
- },
61
- watch: {
62
- AgentId: {
63
- handler: function (val, oldVal) {
64
- this.agentId = val
65
- },
66
- // 深度观察监听
67
- deep: true
68
- },
69
- Token: {
70
- handler: function (val) {
71
- this.setPropsToken(val)
72
- }
73
- }
74
- },
75
- methods: {
76
- oncancle () {
77
- this.boxVisible = false
78
- },
79
- handleOpenConfigPanel () {
80
- this.boxVisible = true
81
- },
82
- setDialogWidth () {
83
- var val = document.body.offsetWidth
84
- const def = 1200 // 默认宽度
85
- if (val < def) {
86
- this.dialogWidth = '100%'
87
- } else {
88
- this.dialogWidth = def + 'px'
89
- }
90
- },
91
- resetIntersectionMap () {
92
- this.setPropsToken(this.Token)
93
- this.firstInit()
94
- this.$refs.intersectionMap.resetCrossDiagram()
95
- this.initData()
96
- },
97
- registerMessage () {
98
- registerMessage(this.agentId).then(data => {
99
- if (!data.data.success) {
100
- this.devStatus = 2
101
- let parrenterror = getMessageByCode(data.data.code, this.$i18n.locale)
102
- if (data.data.data) {
103
- // 子类型错误
104
- let childErrorCode = data.data.data.errorCode
105
- if (childErrorCode) {
106
- let childerror = getMessageByCode(data.data.data.errorCode, this.$i18n.locale)
107
- this.$message.error(parrenterror + ',' + childerror)
108
- }
109
- } else {
110
- this.$message.error(parrenterror)
111
- }
112
- if (this.isResend) {
113
- this.reSend()
114
- }
115
- return
116
- }
117
- this.devStatus = 3
118
- this.clearPatternInterval() // 清除其他定时器
119
- this.phaseControlTimer = setInterval(() => {
120
- if (this.intervalFlag) {
121
- this.initData()
122
- }
123
- }, 1000)
124
- })
125
- },
126
- reSend () { // 设备掉线重连机制
127
- this.devStatus = 1
128
- this.clearRegisterMessageTimer()
129
- this.registerMessageTimer = setTimeout(() => {
130
- this.reconnectionDev()
131
- }, 5000)
132
- },
133
- clearPatternInterval () {
134
- if (this.phaseControlTimer !== null) {
135
- clearInterval(this.phaseControlTimer) // 清除定时器
136
- this.phaseControlTimer = null
137
- }
138
- },
139
- clearRegisterMessageTimer () {
140
- if (this.registerMessageTimer !== null) {
141
- clearTimeout(this.registerMessageTimer) // 清除延时器
142
- this.registerMessageTimer = null
143
- }
144
- },
145
- initData () {
146
- this.intervalFlag = false
147
- let iframdevid = getIframdevid()
148
- console.log(iframdevid)
149
- let startTime = new Date().getTime()
150
- getTscControl(this.agentId).then((data) => {
151
- let endTime = new Date().getTime()
152
- let diffTime = endTime - startTime
153
- this.responseTime = diffTime
154
- this.intervalFlag = true
155
- if (!data.data.success) {
156
- if (data.data.code === '4003') {
157
- this.devStatus = 2
158
- this.clearPatternInterval() // 清除其他定时器
159
- this.$message.error(getMessageByCode(data.data.code, this.$i18n.locale))
160
- if (this.isResend) {
161
- this.reSend()
162
- }
163
- return
164
- }
165
- let parrenterror = getMessageByCode(data.data.code, this.$i18n.locale)
166
- if (data.data.data) {
167
- // 子类型错误
168
- let childErrorCode = data.data.data.errorCode
169
- if (childErrorCode) {
170
- let childerror = getMessageByCode(data.data.data.errorCode, this.$i18n.locale)
171
- this.$message.error(parrenterror + ',' + childerror)
172
- }
173
- } else {
174
- this.$message.error(parrenterror)
175
- }
176
- this.clearPatternInterval() // 清除其他定时器
177
- if (this.isResend) {
178
- this.reSend()
179
- }
180
- return
181
- }
182
- this.crossStatusData = JSON.parse(JSON.stringify(data.data.data.data))
183
- }).catch(error => {
184
- this.$message.error(error)
185
- console.log(error)
186
- })
187
- },
188
- reconnectionDev () {
189
- this.registerMessage()
190
- },
191
- queryDevParams () {
192
- let _this = this
193
- queryDevice(this.agentid).then(res => {
194
- if (!res.data.success) {
195
- _this.$message.error(getMessageByCode(res.data.code, _this.$i18n.locale))
196
- return
197
- }
198
- let devParams = res.data.data.jsonparam
199
- _this.ip = devParams.ip
200
- _this.port = String(devParams.port)
201
- _this.protocol = res.data.data.protocol
202
- _this.agentId = res.data.data.agentid
203
- if (res.data.data.name) {
204
- _this.agentName = res.data.data.name
205
- }
206
- _this.platform = res.data.data.platform
207
- _this.$refs.intersectionMap.resetCrossDiagram()
208
- _this.registerMessage() // 注册消息
209
- })
210
- },
211
- firstInit () {
212
- if (this.$route.query !== undefined && Object.keys(this.$route.query).length) {
213
- this.agentId = this.$route.query.agentid
214
- setIframdevid(this.agentId)
215
- this.registerMessage() // 注册消息
216
- } else {
217
- this.queryDevParams() // 查询设备信息
218
- }
219
- },
220
- destroyIntersectionMap () {
221
- this.isResend = false
222
- this.clearPatternInterval() // 清除定时器
223
- this.clearRegisterMessageTimer() // 清除定时器
224
- },
225
- setPropsToken (token) {
226
- // 获取组件外传入的token,便于独立组件调用接口
227
- if (token && token !== '') {
228
- setToken(token)
229
- }
230
- }
231
- },
232
- created () {
233
- this.agentId = this.AgentId
234
- this.setDialogWidth()
235
- },
236
- mounted () {
237
- setIframdevid(this.AgentId)
238
- this.resetIntersectionMap()
239
- window.onresize = () => {
240
- return (() => {
241
- this.setDialogWidth()
242
- })()
243
- }
244
- },
245
- destroyed () {
246
- this.destroyIntersectionMap()
247
- }
248
- }
249
- </script>
250
- <style lang="scss">
251
- .abow_dialog {
252
- display: flex;
253
- justify-content: center;
254
- align-items: Center;
255
- overflow: hidden;
256
- .el-dialog {
257
- margin: 0 auto !important;
258
- height: 90%;
259
- overflow: hidden;
260
- .el-dialog__body {
261
- position: absolute;
262
- left: 0;
263
- top: 54px;
264
- bottom: 0;
265
- right: 0;
266
- padding: 0;
267
- z-index: 1;
268
- overflow-y: auto;
269
- overflow-x: auto;
270
- }
271
- }
272
- }
273
- </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
+ <!--动态路口图,只需要设备AgentId,此组件会处理方案状态接口轮询-->
13
+ <template>
14
+ <div class="intersection-with-interface">
15
+ <IntersectionMap
16
+ ref="intersectionMap"
17
+ :crossStatusData="crossStatusData"
18
+ :devStatus="devStatus"
19
+ :agentId="agentId"
20
+ :graphicMode="true"
21
+ :roadDirection="roadDirection" />
22
+ </div>
23
+ </template>
24
+ <script>
25
+ import IntersectionMap from '../IntersectionMap'
26
+ import { getMessageByCode } from '../../../utils/responseMessage'
27
+ import { getTscControl, queryDevice } from '../../../api/control.js'
28
+ import { registerMessage } from '../../../api/param'
29
+ import { getIframdevid, setIframdevid, setToken } from '../../../utils/auth.js'
30
+ export default {
31
+ name: 'intersection-with-interface',
32
+ components: {
33
+ IntersectionMap
34
+ },
35
+ data () {
36
+ return {
37
+ boxVisible: false,
38
+ dialogWidth: '100%',
39
+ crossStatusData: {}, // 路口状态数据
40
+ devStatus: 1,
41
+ isResend: true,
42
+ intervalFlag: true,
43
+ phaseControlTimer: null, // 定时器
44
+ registerMessageTimer: null // 延时器
45
+ }
46
+ },
47
+ props: {
48
+ AgentId: {
49
+ type: String,
50
+ default: '0'
51
+ },
52
+ Token: {
53
+ type: String,
54
+ default: ''
55
+ },
56
+ roadDirection: {
57
+ type: String,
58
+ default: 'right'
59
+ }
60
+ },
61
+ watch: {
62
+ AgentId: {
63
+ handler: function (val, oldVal) {
64
+ this.agentId = val
65
+ },
66
+ // 深度观察监听
67
+ deep: true
68
+ },
69
+ Token: {
70
+ handler: function (val) {
71
+ this.setPropsToken(val)
72
+ }
73
+ }
74
+ },
75
+ methods: {
76
+ oncancle () {
77
+ this.boxVisible = false
78
+ },
79
+ handleOpenConfigPanel () {
80
+ this.boxVisible = true
81
+ },
82
+ setDialogWidth () {
83
+ var val = document.body.offsetWidth
84
+ const def = 1200 // 默认宽度
85
+ if (val < def) {
86
+ this.dialogWidth = '100%'
87
+ } else {
88
+ this.dialogWidth = def + 'px'
89
+ }
90
+ },
91
+ resetIntersectionMap () {
92
+ this.setPropsToken(this.Token)
93
+ this.firstInit()
94
+ this.$refs.intersectionMap.resetCrossDiagram()
95
+ this.initData()
96
+ },
97
+ registerMessage () {
98
+ registerMessage(this.agentId).then(data => {
99
+ if (!data.data.success) {
100
+ this.devStatus = 2
101
+ let parrenterror = getMessageByCode(data.data.code, this.$i18n.locale)
102
+ if (data.data.data) {
103
+ // 子类型错误
104
+ let childErrorCode = data.data.data.errorCode
105
+ if (childErrorCode) {
106
+ let childerror = getMessageByCode(data.data.data.errorCode, this.$i18n.locale)
107
+ this.$message.error(parrenterror + ',' + childerror)
108
+ }
109
+ } else {
110
+ this.$message.error(parrenterror)
111
+ }
112
+ if (this.isResend) {
113
+ this.reSend()
114
+ }
115
+ return
116
+ }
117
+ this.devStatus = 3
118
+ this.clearPatternInterval() // 清除其他定时器
119
+ this.phaseControlTimer = setInterval(() => {
120
+ if (this.intervalFlag) {
121
+ this.initData()
122
+ }
123
+ }, 1000)
124
+ })
125
+ },
126
+ reSend () { // 设备掉线重连机制
127
+ this.devStatus = 1
128
+ this.clearRegisterMessageTimer()
129
+ this.registerMessageTimer = setTimeout(() => {
130
+ this.reconnectionDev()
131
+ }, 5000)
132
+ },
133
+ clearPatternInterval () {
134
+ if (this.phaseControlTimer !== null) {
135
+ clearInterval(this.phaseControlTimer) // 清除定时器
136
+ this.phaseControlTimer = null
137
+ }
138
+ },
139
+ clearRegisterMessageTimer () {
140
+ if (this.registerMessageTimer !== null) {
141
+ clearTimeout(this.registerMessageTimer) // 清除延时器
142
+ this.registerMessageTimer = null
143
+ }
144
+ },
145
+ initData () {
146
+ this.intervalFlag = false
147
+ let iframdevid = getIframdevid()
148
+ console.log(iframdevid)
149
+ let startTime = new Date().getTime()
150
+ getTscControl(this.agentId).then((data) => {
151
+ let endTime = new Date().getTime()
152
+ let diffTime = endTime - startTime
153
+ this.responseTime = diffTime
154
+ this.intervalFlag = true
155
+ if (!data.data.success) {
156
+ if (data.data.code === '4003') {
157
+ this.devStatus = 2
158
+ this.clearPatternInterval() // 清除其他定时器
159
+ this.$message.error(getMessageByCode(data.data.code, this.$i18n.locale))
160
+ if (this.isResend) {
161
+ this.reSend()
162
+ }
163
+ return
164
+ }
165
+ let parrenterror = getMessageByCode(data.data.code, this.$i18n.locale)
166
+ if (data.data.data) {
167
+ // 子类型错误
168
+ let childErrorCode = data.data.data.errorCode
169
+ if (childErrorCode) {
170
+ let childerror = getMessageByCode(data.data.data.errorCode, this.$i18n.locale)
171
+ this.$message.error(parrenterror + ',' + childerror)
172
+ }
173
+ } else {
174
+ this.$message.error(parrenterror)
175
+ }
176
+ this.clearPatternInterval() // 清除其他定时器
177
+ if (this.isResend) {
178
+ this.reSend()
179
+ }
180
+ return
181
+ }
182
+ this.crossStatusData = JSON.parse(JSON.stringify(data.data.data.data))
183
+ }).catch(error => {
184
+ this.$message.error(error)
185
+ console.log(error)
186
+ })
187
+ },
188
+ reconnectionDev () {
189
+ this.registerMessage()
190
+ },
191
+ queryDevParams () {
192
+ let _this = this
193
+ queryDevice(this.agentid).then(res => {
194
+ if (!res.data.success) {
195
+ _this.$message.error(getMessageByCode(res.data.code, _this.$i18n.locale))
196
+ return
197
+ }
198
+ let devParams = res.data.data.jsonparam
199
+ _this.ip = devParams.ip
200
+ _this.port = String(devParams.port)
201
+ _this.protocol = res.data.data.protocol
202
+ _this.agentId = res.data.data.agentid
203
+ if (res.data.data.name) {
204
+ _this.agentName = res.data.data.name
205
+ }
206
+ _this.platform = res.data.data.platform
207
+ _this.$refs.intersectionMap.resetCrossDiagram()
208
+ _this.registerMessage() // 注册消息
209
+ })
210
+ },
211
+ firstInit () {
212
+ if (this.$route.query !== undefined && Object.keys(this.$route.query).length) {
213
+ this.agentId = this.$route.query.agentid
214
+ setIframdevid(this.agentId)
215
+ this.registerMessage() // 注册消息
216
+ } else {
217
+ this.queryDevParams() // 查询设备信息
218
+ }
219
+ },
220
+ destroyIntersectionMap () {
221
+ this.isResend = false
222
+ this.clearPatternInterval() // 清除定时器
223
+ this.clearRegisterMessageTimer() // 清除定时器
224
+ },
225
+ setPropsToken (token) {
226
+ // 获取组件外传入的token,便于独立组件调用接口
227
+ if (token && token !== '') {
228
+ setToken(token)
229
+ }
230
+ }
231
+ },
232
+ created () {
233
+ this.agentId = this.AgentId
234
+ this.setDialogWidth()
235
+ },
236
+ mounted () {
237
+ setIframdevid(this.AgentId)
238
+ this.resetIntersectionMap()
239
+ window.onresize = () => {
240
+ return (() => {
241
+ this.setDialogWidth()
242
+ })()
243
+ }
244
+ },
245
+ destroyed () {
246
+ this.destroyIntersectionMap()
247
+ }
248
+ }
249
+ </script>
250
+ <style lang="scss">
251
+ .abow_dialog {
252
+ display: flex;
253
+ justify-content: center;
254
+ align-items: Center;
255
+ overflow: hidden;
256
+ .el-dialog {
257
+ margin: 0 auto !important;
258
+ height: 90%;
259
+ overflow: hidden;
260
+ .el-dialog__body {
261
+ position: absolute;
262
+ left: 0;
263
+ top: 54px;
264
+ bottom: 0;
265
+ right: 0;
266
+ padding: 0;
267
+ z-index: 1;
268
+ overflow-y: auto;
269
+ overflow-x: auto;
270
+ }
271
+ }
272
+ }
273
+ </style>
@@ -1,2 +1,2 @@
1
- import IntersectionWithInterface from './IntersectionWithInterface.vue'
2
- export default IntersectionWithInterface
1
+ import IntersectionWithInterface from './IntersectionWithInterface.vue'
2
+ export default IntersectionWithInterface