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,218 +1,198 @@
1
- /**
2
- * Copyright (c) 2020 kedacom
3
- * OpenATC is licensed under Mulan PSL v2.
4
- * You can use this software according to the terms and conditions of the Mulan PSL v2.
5
- * You may obtain a copy of Mulan PSL v2 at:
6
- * http://license.coscl.org.cn/MulanPSL2
7
- * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
8
- * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
9
- * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
10
- * See the Mulan PSL v2 for more details.
11
- **/
12
- <template>
13
- <div class="manual-control-modal lockingphase-control">
14
- <div class="title" style="margin-bottom: 18px;">{{$t('openatccomponents.overview.phaselocking')}}</div>
15
- <el-row>
16
- <el-col :span="24">
17
- <el-form
18
- :inline="true"
19
- ref="manual"
20
- label-position="left"
21
- :model="manualInfo"
22
- label-width="100px">
23
- <el-form-item
24
- :label="$t('openatccomponents.phase.greenclear') + ':'"
25
- prop="intersection">
26
- <el-input-number :min="0" :max="65535" :precision="0" :step="1" :controls="false" v-model.number="manualInfo.tempGreenflash" size="mini"></el-input-number>
27
- </el-form-item>
28
- <el-form-item
29
- :label="$t('openatccomponents.overview.duration') + ':'"
30
- prop="count">
31
- <el-input-number :min="0" :max="65535" :precision="0" :step="1" :controls="false" v-model.number="manualInfo.tempDuration" size="mini"></el-input-number>
32
- </el-form-item>
33
- <el-form-item
34
- :label="$t('openatccomponents.overview.yellowflash') + ':'"
35
- prop="intersection">
36
- <el-input-number :min="0" :max="65535" :precision="0" :step="1" :controls="false" v-model.number="manualInfo.tempYellow" size="mini"></el-input-number>
37
- </el-form-item>
38
- <el-form-item
39
- :label="$t('openatccomponents.overview.allred') + ':'"
40
- prop="intersection">
41
- <el-input-number :min="0" :max="65535" :precision="0" :step="1" :controls="false" v-model.number="manualInfo.tempRedclear" size="mini"></el-input-number>
42
- </el-form-item>
43
- <el-form-item
44
- :label="$t('openatccomponents.phase.mingreen') + ':'"
45
- prop="count">
46
- <el-input-number :min="0" :max="65535" :precision="0" :step="1" :controls="false" v-model.number="manualInfo.tempMingreen" size="mini"></el-input-number>
47
- </el-form-item>
48
- </el-form>
49
- </el-col>
50
- </el-row>
51
- <el-row>
52
- <div class="model-label">{{$t('openatccomponents.overview.mode')}}:</div>
53
- <div style="width: 100%; overflow: hidden;margin-top: 20px;">
54
- <common-kanban
55
- v-for="ring in closePhaseRings"
56
- :key="ring.num" class="closephasekanban"
57
- :list="ring.phases"
58
- :header-text="$t('openatccomponents.pattern.ring') + ring.num"
59
- :Draggable="false"
60
- :sidewalkPhaseData="sidewalkPhaseData"
61
- :roadDirection="roadDirection"
62
- @handleSort="handleSort">
63
- <template v-slot:kanbantitle>
64
- <div class="col-title" v-text="$t('openatccomponents.overview.closemode')"></div>
65
- </template>
66
- <template v-slot:kanbancontent="data">
67
- <el-select v-model="data.element.locktype" class="col-inner" size="small" :placeholder="$t('openatccomponents.common.select')">
68
- <el-option
69
- v-for="item in lockingOption"
70
- :key="item.value"
71
- :label="$t('openatccomponents.overview.lockingOption' + item.value)"
72
- :value="item.value">
73
- </el-option>
74
- </el-select>
75
- </template>
76
- </common-kanban>
77
- </div>
78
- </el-row>
79
- <div class="footer" v-if="realtimeStatusModalvisible">
80
- <el-button @click="handleClose()">{{$t('openatccomponents.button.Back')}}</el-button>
81
- <el-button type="primary" @click="handleManualControl()">{{$t('openatccomponents.overview.implement')}}</el-button>
82
- </div>
83
- <div class="footer" v-if="!realtimeStatusModalvisible">
84
- <el-button @click="handleClose()">{{$t('openatccomponents.button.Back')}}</el-button>
85
- <el-button type="primary" @click="handleManualControl()">{{$t('openatccomponents.overview.comfirm')}}</el-button>
86
- </div>
87
- </div>
88
- </template>
89
-
90
- <script>
91
- export default {
92
- name: 'closePhaselControl',
93
- props: {
94
- Visible: {
95
- type: Boolean
96
- },
97
- controlData: {
98
- type: Object
99
- },
100
- modelList: {
101
- type: Array
102
- },
103
- stagesList: {
104
- type: Array
105
- },
106
- currModel: {
107
- type: Number
108
- },
109
- preselectModel: {
110
- type: Number
111
- },
112
- currentStage: {
113
- type: Number
114
- },
115
- preselectStages: {
116
- type: Number
117
- },
118
- specialcontrolList: {
119
- type: Array
120
- },
121
- closePhaseRings: {
122
- type: Array
123
- },
124
- realtimeStatusModalvisible: {
125
- type: Boolean,
126
- default: true
127
- },
128
- sidewalkPhaseData: {
129
- type: Array
130
- },
131
- roadDirection: {
132
- type: String
133
- }
134
- },
135
- data () {
136
- return {
137
- visible: this.Visible,
138
- manualInfo: {
139
- tempGreenflash: 6,
140
- tempDuration: 600, // 控制方式手动操作的情况下的持续时间的临时值。
141
- tempYellow: 3,
142
- tempRedclear: 2,
143
- tempMingreen: 15
144
- },
145
- lockingOption: [{
146
- value: 0
147
- }, {
148
- value: 1
149
- }, {
150
- value: 2
151
- }, {
152
- value: 3
153
- }]
154
- }
155
- },
156
- methods: {
157
- handleClose () {
158
- this.$emit('closePhaseBack')
159
- },
160
- handleManualControl () {
161
- let submitdata = {
162
- control: 22,
163
- data: {}
164
- }
165
- if (this.manualInfo.tempGreenflash !== undefined) {
166
- submitdata.data.greenflash = Number(this.manualInfo.tempGreenflash)
167
- }
168
- if (this.manualInfo.tempDuration !== undefined) {
169
- submitdata.data.duration = Number(this.manualInfo.tempDuration)
170
- }
171
- if (this.manualInfo.tempYellow !== undefined) {
172
- submitdata.data.yellow = Number(this.manualInfo.tempYellow)
173
- }
174
- if (this.manualInfo.tempRedclear !== undefined) {
175
- submitdata.data.redclear = Number(this.manualInfo.tempRedclear)
176
- }
177
- if (this.manualInfo.tempMingreen !== undefined) {
178
- submitdata.data.mingreen = Number(this.manualInfo.tempMingreen)
179
- }
180
- submitdata.data.phases = this.handleSubmitPhaseLocking()
181
- this.$emit('closePhaseControl', submitdata)
182
- },
183
- handleSubmitPhaseLocking () {
184
- let allRingsPhases = []
185
- for (let i = 0; i < this.closePhaseRings.length; i++) {
186
- let ring = this.closePhaseRings[i]
187
- let phase = ring.phases
188
- for (let j = 0; j < phase.length; j++) {
189
- let obj = {}
190
- obj.id = phase[j].id
191
- obj.type = phase[j].locktype
192
- allRingsPhases.push(obj)
193
- }
194
- }
195
- return allRingsPhases
196
- },
197
- handleSort (sortedlist) {
198
- // 重新排序数据
199
- let ringid = sortedlist[0].ring
200
- for (let i = 0; i < this.closePhaseRings.length; i++) {
201
- if (ringid === this.closePhaseRings[i].num) {
202
- this.closePhaseRings[i].phases = sortedlist
203
- }
204
- }
205
- }
206
- }
207
- }
208
- </script>
209
- <style lang="scss" scoped>
210
- .col-inner {
211
- width: 100%;
212
- float: left;
213
- }
214
- .col-title {
215
- width: 100%;
216
- float: left;
217
- }
218
- </style>
1
+ /**
2
+ * Copyright (c) 2020 kedacom
3
+ * OpenATC is licensed under Mulan PSL v2.
4
+ * You can use this software according to the terms and conditions of the Mulan PSL v2.
5
+ * You may obtain a copy of Mulan PSL v2 at:
6
+ * http://license.coscl.org.cn/MulanPSL2
7
+ * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
8
+ * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
9
+ * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
10
+ * See the Mulan PSL v2 for more details.
11
+ **/
12
+ <template>
13
+ <div class="manual-control-modal lockingphase-control">
14
+ <div class="title" style="margin-bottom: 18px;">{{$t('openatccomponents.overview.phaselocking')}}</div>
15
+ <el-row>
16
+ <el-col :span="24">
17
+ <el-form
18
+ :inline="true"
19
+ ref="manual"
20
+ label-position="left"
21
+ :model="manualInfo"
22
+ label-width="100px">
23
+ <el-form-item
24
+ :label="$t('openatccomponents.phase.greenclear') + ':'"
25
+ prop="intersection">
26
+ <el-input-number :min="0" :max="65535" :precision="0" :step="1" :controls="false" v-model.number="manualInfo.tempGreenflash" size="mini"></el-input-number>
27
+ </el-form-item>
28
+ <el-form-item
29
+ :label="$t('openatccomponents.overview.duration') + ':'"
30
+ prop="count">
31
+ <el-input-number :min="0" :max="65535" :precision="0" :step="1" :controls="false" v-model.number="manualInfo.tempDuration" size="mini"></el-input-number>
32
+ </el-form-item>
33
+ <el-form-item
34
+ :label="$t('openatccomponents.overview.yellowflash') + ':'"
35
+ prop="intersection">
36
+ <el-input-number :min="0" :max="65535" :precision="0" :step="1" :controls="false" v-model.number="manualInfo.tempYellow" size="mini"></el-input-number>
37
+ </el-form-item>
38
+ <el-form-item
39
+ :label="$t('openatccomponents.overview.allred') + ':'"
40
+ prop="intersection">
41
+ <el-input-number :min="0" :max="65535" :precision="0" :step="1" :controls="false" v-model.number="manualInfo.tempRedclear" size="mini"></el-input-number>
42
+ </el-form-item>
43
+ <el-form-item
44
+ :label="$t('openatccomponents.phase.mingreen') + ':'"
45
+ prop="count">
46
+ <el-input-number :min="0" :max="65535" :precision="0" :step="1" :controls="false" v-model.number="manualInfo.tempMingreen" size="mini"></el-input-number>
47
+ </el-form-item>
48
+ </el-form>
49
+ </el-col>
50
+ </el-row>
51
+ <el-row>
52
+ <div class="model-label">{{$t('openatccomponents.overview.mode')}}:</div>
53
+ <div style="width: 100%; overflow: hidden;margin-top: 20px;">
54
+ <common-kanban
55
+ v-for="ring in closePhaseRings"
56
+ :key="ring.num" class="closephasekanban"
57
+ :list="ring.phases"
58
+ :header-text="$t('openatccomponents.pattern.ring') + ring.num"
59
+ :Draggable="false"
60
+ :sidewalkPhaseData="sidewalkPhaseData"
61
+ :roadDirection="roadDirection"
62
+ @handleSort="handleSort">
63
+ <template v-slot:kanbantitle>
64
+ <div class="col-title" v-text="$t('openatccomponents.overview.closemode')"></div>
65
+ </template>
66
+ <template v-slot:kanbancontent="data">
67
+ <el-select v-model="data.element.locktype" class="col-inner" size="small" :placeholder="$t('openatccomponents.common.select')">
68
+ <el-option
69
+ v-for="item in lockingOption"
70
+ :key="item.value"
71
+ :label="$t('openatccomponents.overview.lockingOption' + item.value)"
72
+ :value="item.value">
73
+ </el-option>
74
+ </el-select>
75
+ </template>
76
+ </common-kanban>
77
+ </div>
78
+ </el-row>
79
+ <div class="footer">
80
+ <el-button @click="handleClose()">{{$t('openatccomponents.button.Back')}}</el-button>
81
+ <el-button type="primary" @click="handleLockPhase()">{{lockPhaseBtnName}}</el-button>
82
+ </div>
83
+ </div>
84
+ </template>
85
+
86
+ <script>
87
+ import RingDataModel from '../../../../utils/RingDataModel.js'
88
+ export default {
89
+ name: 'LockPhaselControl',
90
+ props: {
91
+ phaseList: {
92
+ type: Array
93
+ },
94
+ patternStatus: {
95
+ type: Object
96
+ },
97
+ lockPhaseBtnName: {
98
+ type: String,
99
+ default () {
100
+ return this.$t('openatccomponents.overview.implement')
101
+ }
102
+ },
103
+ roadDirection: {
104
+ type: String
105
+ }
106
+ },
107
+ data () {
108
+ return {
109
+ closePhaseRings: [],
110
+ sidewalkPhaseData: [],
111
+ manualInfo: {
112
+ tempGreenflash: 6,
113
+ tempDuration: 600, // 控制方式手动操作的情况下的持续时间的临时值。
114
+ tempYellow: 3,
115
+ tempRedclear: 2,
116
+ tempMingreen: 15
117
+ },
118
+ lockingOption: [{
119
+ value: 0
120
+ }, {
121
+ value: 1
122
+ }, {
123
+ value: 2
124
+ }, {
125
+ value: 3
126
+ }]
127
+ }
128
+ },
129
+ mounted () {
130
+ if (this.patternStatus && this.phaseList && this.phaseList.length > 0) {
131
+ let ringDataModel = new RingDataModel(this.patternStatus, this.phaseList)
132
+ this.closePhaseRings = ringDataModel.initRingPhaseData()
133
+ this.sidewalkPhaseData = ringDataModel.getPedPhasePos()
134
+ }
135
+ },
136
+ methods: {
137
+ handleClose () {
138
+ this.$emit('closePhaseBack')
139
+ },
140
+ handleLockPhase () {
141
+ let submitdata = {
142
+ control: 22,
143
+ data: {}
144
+ }
145
+ if (this.manualInfo.tempGreenflash !== undefined) {
146
+ submitdata.data.greenflash = Number(this.manualInfo.tempGreenflash)
147
+ }
148
+ if (this.manualInfo.tempDuration !== undefined) {
149
+ submitdata.data.duration = Number(this.manualInfo.tempDuration)
150
+ }
151
+ if (this.manualInfo.tempYellow !== undefined) {
152
+ submitdata.data.yellow = Number(this.manualInfo.tempYellow)
153
+ }
154
+ if (this.manualInfo.tempRedclear !== undefined) {
155
+ submitdata.data.redclear = Number(this.manualInfo.tempRedclear)
156
+ }
157
+ if (this.manualInfo.tempMingreen !== undefined) {
158
+ submitdata.data.mingreen = Number(this.manualInfo.tempMingreen)
159
+ }
160
+ submitdata.data.phases = this.handleSubmitPhaseLocking()
161
+ this.$emit('closePhaseControl', submitdata)
162
+ },
163
+ handleSubmitPhaseLocking () {
164
+ let allRingsPhases = []
165
+ for (let i = 0; i < this.closePhaseRings.length; i++) {
166
+ let ring = this.closePhaseRings[i]
167
+ let phase = ring.phases
168
+ for (let j = 0; j < phase.length; j++) {
169
+ let obj = {}
170
+ obj.id = phase[j].id
171
+ obj.type = phase[j].locktype
172
+ allRingsPhases.push(obj)
173
+ }
174
+ }
175
+ return allRingsPhases
176
+ },
177
+ handleSort (sortedlist) {
178
+ // 重新排序数据
179
+ let ringid = sortedlist[0].ring
180
+ for (let i = 0; i < this.closePhaseRings.length; i++) {
181
+ if (ringid === this.closePhaseRings[i].num) {
182
+ this.closePhaseRings[i].phases = sortedlist
183
+ }
184
+ }
185
+ }
186
+ }
187
+ }
188
+ </script>
189
+ <style lang="scss" scoped>
190
+ .col-inner {
191
+ width: 100%;
192
+ float: left;
193
+ }
194
+ .col-title {
195
+ width: 100%;
196
+ float: left;
197
+ }
198
+ </style>