openatc-components 0.0.97 → 0.0.98
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.
- package/package/kisscomps/components/BoardCard/BoardCard.vue +6 -1
- package/package/kisscomps/components/KanBan/kanban.vue +6 -6
- package/package/kisscomps/components/PatternStatus/PatternStatus.vue +152 -37
- package/package/kisscomps/components/StageStatus/StageStatus.vue +6 -2
- package/package/kissui.min.js +1 -1
- package/package.json +1 -1
- package/src/kisscomps/components/BoardCard/BoardCard.vue +6 -1
- package/src/kisscomps/components/KanBan/kanban.vue +6 -6
- package/src/kisscomps/components/PatternStatus/PatternStatus.vue +152 -37
- package/src/kisscomps/components/StageStatus/StageStatus.vue +6 -2
package/package.json
CHANGED
|
@@ -8,6 +8,7 @@
|
|
|
8
8
|
:patternStatusList="patternStatusList">
|
|
9
9
|
</StageStatus>
|
|
10
10
|
<PatternStatus
|
|
11
|
+
:showBarrier="showBarrier"
|
|
11
12
|
:localPatternList="localPatternList"
|
|
12
13
|
:contrloType="contrloType"
|
|
13
14
|
:stagesChange="stagesChange"
|
|
@@ -17,7 +18,7 @@
|
|
|
17
18
|
:phaseList="phaseList"
|
|
18
19
|
:cycle="cycle"
|
|
19
20
|
:syncTime="syncTime"
|
|
20
|
-
:style="{'margin-top':cycle ? '25px':'0'}"
|
|
21
|
+
:style="{'margin-top':(cycle || !showBarrier)? '25px':'0'}"
|
|
21
22
|
:patternStatusList="patternStatusList"
|
|
22
23
|
:patternId="patternId"
|
|
23
24
|
:cycles="cycles">
|
|
@@ -52,6 +53,10 @@ export default {
|
|
|
52
53
|
stagesChange: {
|
|
53
54
|
type: Array
|
|
54
55
|
},
|
|
56
|
+
showBarrier: {
|
|
57
|
+
type: Boolean,
|
|
58
|
+
default: false
|
|
59
|
+
},
|
|
55
60
|
phaseList: {
|
|
56
61
|
type: Array
|
|
57
62
|
},
|
|
@@ -202,12 +202,12 @@ export default {
|
|
|
202
202
|
}
|
|
203
203
|
return maxCycle
|
|
204
204
|
},
|
|
205
|
-
doChange (
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
205
|
+
doChange (e) {
|
|
206
|
+
if (e) {
|
|
207
|
+
let n = this.index
|
|
208
|
+
this.$emit('handleSplit', n)
|
|
209
|
+
this.$forceUpdate()
|
|
210
|
+
}
|
|
211
211
|
}
|
|
212
212
|
}
|
|
213
213
|
}
|
|
@@ -43,7 +43,7 @@
|
|
|
43
43
|
<div class="first-1" :style="{'width':item.redWidth,'height':'34px','background':'#f27979'}"></div>
|
|
44
44
|
</div>
|
|
45
45
|
</div>
|
|
46
|
-
<div v-for="(item, index) in barrierList" :key="index + '1'">
|
|
46
|
+
<div v-if="showBarrier" v-for="(item, index) in barrierList" :key="index + '1'">
|
|
47
47
|
<div class="divider" :style="{'left':item, 'height':barrierHeight}"></div>
|
|
48
48
|
</div>
|
|
49
49
|
<div v-show="(syncTime && cycle && cycle>0) || (syncTime && newCycle && newCycle>0)">
|
|
@@ -123,6 +123,10 @@ export default {
|
|
|
123
123
|
patternList: {
|
|
124
124
|
type: Array
|
|
125
125
|
},
|
|
126
|
+
showBarrier: {
|
|
127
|
+
type: Boolean,
|
|
128
|
+
default: false
|
|
129
|
+
},
|
|
126
130
|
localPatternList: {
|
|
127
131
|
type: Array
|
|
128
132
|
},
|
|
@@ -162,10 +166,10 @@ export default {
|
|
|
162
166
|
return res
|
|
163
167
|
},
|
|
164
168
|
timeNumDevide () {
|
|
165
|
-
if (this.newCycle && this.newCycle > 0) {
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
}
|
|
169
|
+
// if (this.newCycle && this.newCycle > 0) {
|
|
170
|
+
// let res = (this.newCycle - this.syncTime) + '/' + this.newCycle
|
|
171
|
+
// return res
|
|
172
|
+
// }
|
|
169
173
|
if (this.cycle && this.cycle > 0) {
|
|
170
174
|
let res = (this.cycle - this.syncTime) + '/' + this.cycle
|
|
171
175
|
return res
|
|
@@ -407,63 +411,174 @@ export default {
|
|
|
407
411
|
this.newList = []
|
|
408
412
|
if (Object.keys(this.controlData).length === 0 || this.phaseList.length === 0) return
|
|
409
413
|
if (!this.controlData.phase) return
|
|
410
|
-
let cycle = this.controlData.cycle
|
|
414
|
+
// let cycle = this.controlData.cycle
|
|
411
415
|
if (!this.controlData.rings) return
|
|
416
|
+
let newValue = []
|
|
412
417
|
for (let rings of this.controlData.rings) {
|
|
413
418
|
let phase = this.controlData.phase
|
|
414
|
-
let list = []
|
|
419
|
+
// let list = []
|
|
420
|
+
let obj = {}
|
|
421
|
+
for (let key in rings.sequence) {
|
|
422
|
+
obj[key] = rings.sequence[key]
|
|
423
|
+
}
|
|
424
|
+
let newObj = Object.keys(obj).map(val => ({
|
|
425
|
+
id: obj[val]
|
|
426
|
+
}))
|
|
427
|
+
newValue.push(newObj)
|
|
415
428
|
for (let sequ of rings.sequence) {
|
|
416
429
|
let obj = {}
|
|
417
430
|
obj.id = sequ
|
|
418
431
|
let split = phase.filter((item) => {
|
|
419
432
|
return item.id === sequ
|
|
420
433
|
})[0].split
|
|
434
|
+
newValue.map(d => {
|
|
435
|
+
d.map(r => {
|
|
436
|
+
if (r.id === sequ) {
|
|
437
|
+
r.value = split
|
|
438
|
+
}
|
|
439
|
+
})
|
|
440
|
+
})
|
|
441
|
+
// let currPhase = this.phaseList.filter((item) => {
|
|
442
|
+
// if (item.id === sequ && item.controltype === 99) {
|
|
443
|
+
// obj.controltype = item.controltype
|
|
444
|
+
// }
|
|
445
|
+
// return item.id === sequ
|
|
446
|
+
// })[0]
|
|
447
|
+
// if (currPhase) {
|
|
448
|
+
// obj.redWidth = (currPhase.redclear / cycle * 100).toFixed(3) + '%'
|
|
449
|
+
// obj.yellowWidth = (currPhase.yellow / cycle * 100).toFixed(3) + '%'
|
|
450
|
+
// obj.greenWidth = ((split - currPhase.redclear - currPhase.yellow - currPhase.flashgreen) / cycle * 100).toFixed(3) + '%'
|
|
451
|
+
// obj.flashgreen = (currPhase.flashgreen / cycle * 100).toFixed(3) + '%'
|
|
452
|
+
// // obj.peddirection = currPhase.peddirection
|
|
453
|
+
// let peddirections = []
|
|
454
|
+
// for (let walk of this.sidewalkPhaseData) {
|
|
455
|
+
// for (let ped of currPhase.peddirection) {
|
|
456
|
+
// // if (stg === walk.phaseid) {
|
|
457
|
+
// let objs = {}
|
|
458
|
+
// objs.name = walk.name
|
|
459
|
+
// objs.id = walk.id
|
|
460
|
+
// if (ped === walk.id) {
|
|
461
|
+
// peddirections.push(objs)
|
|
462
|
+
// peddirections = Array.from(new Set(peddirections))
|
|
463
|
+
// }
|
|
464
|
+
// // }
|
|
465
|
+
// }
|
|
466
|
+
// }
|
|
467
|
+
// obj.peddirection = peddirections
|
|
468
|
+
// obj.split = split
|
|
469
|
+
// obj.direction = currPhase.direction.map(item => {
|
|
470
|
+
// return {
|
|
471
|
+
// id: item,
|
|
472
|
+
// color: '#454545'
|
|
473
|
+
// }
|
|
474
|
+
// })
|
|
475
|
+
// list.push(obj)
|
|
476
|
+
// }
|
|
477
|
+
}
|
|
478
|
+
// this.newList.push(list)
|
|
479
|
+
// this.patternInfo = [...this.newList]
|
|
480
|
+
}
|
|
481
|
+
this.handleOverViewChange(newValue)
|
|
482
|
+
},
|
|
483
|
+
handleBarrierHeight () { // 屏障高度
|
|
484
|
+
if (!this.patternInfo) return
|
|
485
|
+
let patternLength = this.patternInfo.length
|
|
486
|
+
this.barrierHeight = (patternLength * 35 + 21) + 'px'
|
|
487
|
+
},
|
|
488
|
+
handleOverViewChange (val) {
|
|
489
|
+
if (val === null || val.length === 0) return
|
|
490
|
+
this.patternInfo = []
|
|
491
|
+
let currentArr = []
|
|
492
|
+
let newPattern = []
|
|
493
|
+
val.map(i => {
|
|
494
|
+
newPattern.push(...i)
|
|
495
|
+
})
|
|
496
|
+
if (this.phaseList.length === 0) return
|
|
497
|
+
for (let patternStatus of val[0]) {
|
|
498
|
+
if (patternStatus.mode !== 7) {
|
|
499
|
+
let concurrent = this.phaseList.filter((item) => {
|
|
500
|
+
return item.id === patternStatus.id // patternStatus.id当前相位id concurrent当前相位的并发相位
|
|
501
|
+
})[0].concurrent// 当前相位的并发相位
|
|
502
|
+
if (concurrent) {
|
|
503
|
+
let obj = {
|
|
504
|
+
id: patternStatus.id,
|
|
505
|
+
current: concurrent.sort()
|
|
506
|
+
}
|
|
507
|
+
currentArr.push(obj)
|
|
508
|
+
}
|
|
509
|
+
}
|
|
510
|
+
}
|
|
511
|
+
if (currentArr.length !== 0) {
|
|
512
|
+
let newCurrent = this.tranform(currentArr)
|
|
513
|
+
let ringTeam = this.step1(this.phaseList, newCurrent)
|
|
514
|
+
this.fillGap(ringTeam, val)
|
|
515
|
+
}
|
|
516
|
+
let cycle = this.controlData.cycle
|
|
517
|
+
for (let rings of val) {
|
|
518
|
+
if (rings.length === 0) continue
|
|
519
|
+
let list = []
|
|
520
|
+
for (let ring of rings) {
|
|
521
|
+
if (ring.value === 0) continue
|
|
522
|
+
let obj = {}
|
|
523
|
+
let split = ring.value
|
|
524
|
+
obj.id = ring.id
|
|
525
|
+
// obj.split = split
|
|
421
526
|
let currPhase = this.phaseList.filter((item) => {
|
|
422
|
-
if (item.id ===
|
|
527
|
+
if (item.id === ring.id && item.controltype === 99) {
|
|
423
528
|
obj.controltype = item.controltype
|
|
424
529
|
}
|
|
425
|
-
return item.id ===
|
|
530
|
+
return item.id === ring.id
|
|
426
531
|
})[0]
|
|
427
|
-
if (
|
|
428
|
-
obj.
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
// obj.peddirection = currPhase.peddirection
|
|
433
|
-
let peddirections = []
|
|
434
|
-
for (let walk of this.sidewalkPhaseData) {
|
|
435
|
-
for (let ped of currPhase.peddirection) {
|
|
436
|
-
// if (stg === walk.phaseid) {
|
|
437
|
-
let objs = {}
|
|
438
|
-
objs.name = walk.name
|
|
439
|
-
objs.id = walk.id
|
|
440
|
-
if (ped === walk.id) {
|
|
441
|
-
peddirections.push(objs)
|
|
442
|
-
peddirections = Array.from(new Set(peddirections))
|
|
443
|
-
}
|
|
444
|
-
// }
|
|
532
|
+
if (ring.desc) {
|
|
533
|
+
obj.direction = ring.desc.map(item => { // 虚相位desc为空
|
|
534
|
+
return {
|
|
535
|
+
id: item.id,
|
|
536
|
+
color: '#454545'
|
|
445
537
|
}
|
|
446
|
-
}
|
|
447
|
-
|
|
448
|
-
obj.split = split
|
|
538
|
+
})
|
|
539
|
+
} else {
|
|
449
540
|
obj.direction = currPhase.direction.map(item => {
|
|
450
541
|
return {
|
|
451
542
|
id: item,
|
|
452
543
|
color: '#454545'
|
|
453
544
|
}
|
|
454
545
|
})
|
|
546
|
+
}
|
|
547
|
+
if (ring.sum) {
|
|
548
|
+
obj.split = split
|
|
549
|
+
obj.redWidth = (currPhase.redclear + ring.sum / (this.max ? this.max : cycle) * 100).toFixed(3) + '%'
|
|
550
|
+
} else {
|
|
551
|
+
obj.split = split
|
|
552
|
+
obj.redWidth = (currPhase.redclear / (this.max ? this.max : cycle) * 100).toFixed(3) + '%'
|
|
553
|
+
}
|
|
554
|
+
obj.flashgreen = (currPhase.flashgreen / (this.max ? this.max : cycle) * 100).toFixed(3) + '%'
|
|
555
|
+
obj.yellowWidth = (currPhase.yellow / (this.max ? this.max : cycle) * 100).toFixed(3) + '%'
|
|
556
|
+
obj.greenWidth = ((split - currPhase.redclear - currPhase.yellow - currPhase.flashgreen) / (this.max ? this.max : cycle) * 100).toFixed(3) + '%'
|
|
557
|
+
// obj.peddirection = currPhase.peddirection
|
|
558
|
+
let peddirections = []
|
|
559
|
+
for (let walk of this.sidewalkPhaseData) {
|
|
560
|
+
for (let ped of currPhase.peddirection) {
|
|
561
|
+
// if (stg === walk.phaseid) {
|
|
562
|
+
let objs = {}
|
|
563
|
+
objs.name = walk.name
|
|
564
|
+
objs.id = walk.id
|
|
565
|
+
if (ped === walk.id) {
|
|
566
|
+
peddirections.push(objs)
|
|
567
|
+
peddirections = Array.from(new Set(peddirections))
|
|
568
|
+
}
|
|
569
|
+
// }
|
|
570
|
+
}
|
|
571
|
+
}
|
|
572
|
+
obj.peddirection = peddirections
|
|
573
|
+
// 忽略相位不显示
|
|
574
|
+
let mode = ring.mode
|
|
575
|
+
if (mode !== 7) { // 忽略相位不显示
|
|
455
576
|
list.push(obj)
|
|
456
577
|
}
|
|
457
578
|
}
|
|
458
|
-
this.
|
|
459
|
-
this.patternInfo = [...this.newList]
|
|
579
|
+
this.patternInfo.push(list)
|
|
460
580
|
}
|
|
461
581
|
},
|
|
462
|
-
handleBarrierHeight () { // 屏障高度
|
|
463
|
-
if (!this.patternInfo) return
|
|
464
|
-
let patternLength = this.patternInfo.length
|
|
465
|
-
this.barrierHeight = (patternLength * 35 + 21) + 'px'
|
|
466
|
-
},
|
|
467
582
|
handleCurrentChange (val) { // 两个ring的数据
|
|
468
583
|
if (val === null || val.length === 0) return
|
|
469
584
|
this.patternInfo = []
|
|
@@ -57,7 +57,9 @@ export default {
|
|
|
57
57
|
if (this.contrloType === 'stage') {
|
|
58
58
|
this.getStageLine()
|
|
59
59
|
} else {
|
|
60
|
-
|
|
60
|
+
if (this.controlData) {
|
|
61
|
+
this.getPhaseId(this.controlData)
|
|
62
|
+
}
|
|
61
63
|
}
|
|
62
64
|
},
|
|
63
65
|
// 深度观察监听
|
|
@@ -66,7 +68,9 @@ export default {
|
|
|
66
68
|
patternStatusList: {
|
|
67
69
|
handler: function (val, oldVal) {
|
|
68
70
|
// this.handleStages() // 计算屏障高度
|
|
69
|
-
|
|
71
|
+
if (this.patternStatusList) {
|
|
72
|
+
this.getPhaseId(this.patternStatusList)
|
|
73
|
+
}
|
|
70
74
|
},
|
|
71
75
|
// 深度观察监听
|
|
72
76
|
deep: true
|