openatc-components 0.0.14 → 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 -119
  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 -856
  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 -78
  62. package/package/kisscomps/components/IntersectionMap/index.js +2 -2
  63. package/package/kisscomps/components/IntersectionMap/intersectionmap.vue +144 -144
  64. package/package/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +273 -273
  65. package/package/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  66. package/package/kisscomps/components/SchemeConfig/SchemeConfig.vue +772 -756
  67. package/package/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +195 -195
  68. package/package/kisscomps/components/SchemeConfig/index.js +2 -2
  69. package/package/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +198 -218
  70. package/package/kisscomps/components/SchemeConfig/manualControlModal/index.vue +177 -177
  71. package/package/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +298 -298
  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 -522
  75. package/package/kisscomps/components/XRDDirSelector/index.js +2 -2
  76. package/package/kisscomps/index.js +59 -57
  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 -119
  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 -856
  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 -78
  163. package/src/kisscomps/components/IntersectionMap/index.js +2 -2
  164. package/src/kisscomps/components/IntersectionMap/intersectionmap.vue +144 -144
  165. package/src/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +273 -273
  166. package/src/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  167. package/src/kisscomps/components/SchemeConfig/SchemeConfig.vue +772 -756
  168. package/src/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +195 -195
  169. package/src/kisscomps/components/SchemeConfig/index.js +2 -2
  170. package/src/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +198 -218
  171. package/src/kisscomps/components/SchemeConfig/manualControlModal/index.vue +177 -177
  172. package/src/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +298 -298
  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 -522
  176. package/src/kisscomps/components/XRDDirSelector/index.js +2 -2
  177. package/src/kisscomps/index.js +59 -57
  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 -85
  212. package/src/views/schemeconfig.vue +146 -131
  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,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().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