openatc-components 0.0.12 → 0.0.15

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