@lambo-design/workflow-approve 1.0.0-beta.50 → 1.0.0-beta.51
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.json
CHANGED
|
@@ -1,14 +1,18 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div style="min-height: 300px;">
|
|
3
|
-
<Select v-model="countersignersTagsData"
|
|
3
|
+
<Select v-if="organTree.userMap && Object.keys(organTree.userMap).length > 0" v-model="countersignersTagsData"
|
|
4
4
|
filterable multiple
|
|
5
5
|
@on-change="organChange($event)"
|
|
6
6
|
class="custom-select"
|
|
7
7
|
>
|
|
8
|
-
<Option v-for="(value, key) in organTree.userMap" :key="key" :value="`${key},${value}`"
|
|
8
|
+
<Option v-for="(value, key) in organTree.userMap" :key="key" :value="`${key},${value}`" :label="value">
|
|
9
9
|
<span>{{ value }}</span>
|
|
10
10
|
</Option>
|
|
11
11
|
</Select>
|
|
12
|
+
<Tag v-else v-for="(item, index) in countersignersTagsData" :key="item.id" closable @on-close="closeTags(index, item)"
|
|
13
|
+
size="large">
|
|
14
|
+
{{ item.split(',')[1] }}
|
|
15
|
+
</Tag>
|
|
12
16
|
<div class="cont">
|
|
13
17
|
<div
|
|
14
18
|
class="contLeftTwo">
|
|
@@ -159,13 +163,13 @@ export default {
|
|
|
159
163
|
let userList = users.split(',')
|
|
160
164
|
if (users && userList.length > 0) {
|
|
161
165
|
userList.forEach(item => {
|
|
162
|
-
let [userId, userName] = item.split(':')
|
|
163
|
-
let userStr = `${userId},${userName}
|
|
166
|
+
let [userId, userName] = item.split(':')
|
|
167
|
+
let userStr = `${userId},${userName}`
|
|
164
168
|
self.selectedData.push(userStr)
|
|
165
169
|
self.treeUserValue.push(userStr)
|
|
166
170
|
self.selectedKeys.push(userStr)
|
|
167
171
|
if (!self.countersignersTagsData.includes(userStr)) {
|
|
168
|
-
self.countersignersTagsData.push(userStr)
|
|
172
|
+
self.countersignersTagsData.push(userStr)
|
|
169
173
|
}
|
|
170
174
|
self.userNum = '1'
|
|
171
175
|
})
|
|
@@ -173,9 +177,9 @@ export default {
|
|
|
173
177
|
},
|
|
174
178
|
|
|
175
179
|
organChange(event) {
|
|
176
|
-
this.countersignersTagsData = [...event]
|
|
177
|
-
this.treeUserValue = [...event]
|
|
178
|
-
this.selectedKeys = [...event]
|
|
180
|
+
this.countersignersTagsData = [...event] // 直接同步
|
|
181
|
+
this.treeUserValue = [...event] // 保持一致
|
|
182
|
+
this.selectedKeys = [...event]
|
|
179
183
|
|
|
180
184
|
},
|
|
181
185
|
|
|
@@ -266,6 +270,7 @@ export default {
|
|
|
266
270
|
}
|
|
267
271
|
})
|
|
268
272
|
}
|
|
273
|
+
self.organTreeRedis(self.permScope, self.readingRange)
|
|
269
274
|
},
|
|
270
275
|
|
|
271
276
|
getOrganTreeByProType(row, permScope, organTreeType) {
|
|
@@ -361,40 +366,36 @@ export default {
|
|
|
361
366
|
} else {
|
|
362
367
|
//对于流程类型中没有规定人员范围但规定组织范围的情况
|
|
363
368
|
self.readingRange = await this.getOrganTreeByProType(row, row.substring(2, row.indexOf(',')), organTreeType)
|
|
369
|
+
self.organTreeRedis(this.permScope, self.readingRange)
|
|
364
370
|
}
|
|
365
371
|
|
|
366
372
|
},
|
|
367
373
|
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
// organList.push(organ)
|
|
394
|
-
// }
|
|
395
|
-
// })
|
|
396
|
-
// self.countersignersTagsData = organList
|
|
397
|
-
// },
|
|
374
|
+
closeTags(index, info) {
|
|
375
|
+
this.readingRangeScPerDel(index, info)
|
|
376
|
+
},
|
|
377
|
+
|
|
378
|
+
//权限范围人员单条删除
|
|
379
|
+
readingRangeScPerDel(res, info) {
|
|
380
|
+
let self = this
|
|
381
|
+
let index = this.treeUserValue.findIndex(item => {
|
|
382
|
+
return item === info
|
|
383
|
+
})
|
|
384
|
+
if (index !== -1) {
|
|
385
|
+
self.treeUserValue = self.treeUserValue.filter((_, i) => i !== index)
|
|
386
|
+
self.selectedKeys = self.selectedKeys.filter((_, i) => i !== index)
|
|
387
|
+
// self.selectedKeys.splice(index, 1)
|
|
388
|
+
}
|
|
389
|
+
let orgList = []
|
|
390
|
+
let organList = []
|
|
391
|
+
orgList.push(info)
|
|
392
|
+
self.countersignersTagsData.forEach(organ => {
|
|
393
|
+
if (organ.indexOf(info) == -1) {
|
|
394
|
+
organList.push(organ)
|
|
395
|
+
}
|
|
396
|
+
})
|
|
397
|
+
self.countersignersTagsData = organList
|
|
398
|
+
},
|
|
398
399
|
|
|
399
400
|
selectUserChange(node) {
|
|
400
401
|
let self = this
|
|
@@ -551,73 +552,61 @@ export default {
|
|
|
551
552
|
|
|
552
553
|
// 人员选中
|
|
553
554
|
getReadingRangeUser(row) {
|
|
554
|
-
let self = this
|
|
555
|
-
self.userNum = '2'
|
|
555
|
+
let self = this
|
|
556
|
+
self.userNum = '2'
|
|
556
557
|
if (row.length > self.selectedKeys.length) {
|
|
557
558
|
// 用户选择了新人员
|
|
558
|
-
self.treeUserValue = row
|
|
559
|
-
self.selectedKeys = row
|
|
559
|
+
self.treeUserValue = row
|
|
560
|
+
self.selectedKeys = row
|
|
560
561
|
|
|
561
|
-
let index = row.length - 1
|
|
562
|
-
let organName = row[index]
|
|
562
|
+
let index = row.length - 1
|
|
563
|
+
let organName = row[index]
|
|
563
564
|
|
|
564
565
|
if (!self.countersignersTagsData.includes(organName)) {
|
|
565
|
-
self.countersignersTagsData.push(organName)
|
|
566
|
+
self.countersignersTagsData.push(organName)
|
|
566
567
|
}
|
|
567
568
|
|
|
568
|
-
self.organChange(self.countersignersTagsData)
|
|
569
|
+
self.organChange(self.countersignersTagsData)
|
|
569
570
|
|
|
570
571
|
} else if (row.length < self.selectedKeys.length) {
|
|
571
572
|
// 用户取消了选择
|
|
572
|
-
let diff = self.selectedKeys.find(item => !row.includes(item))
|
|
573
|
+
let diff = self.selectedKeys.find(item => !row.includes(item))
|
|
573
574
|
|
|
574
575
|
// 从 countersignersTagsData 中移除取消的用户
|
|
575
576
|
if (diff) {
|
|
576
|
-
self.countersignersTagsData = self.countersignersTagsData.filter(item => item !== diff)
|
|
577
|
-
self.selectedKeys = row
|
|
577
|
+
self.countersignersTagsData = self.countersignersTagsData.filter(item => item !== diff)
|
|
578
|
+
self.selectedKeys = row // 更新选中数据
|
|
578
579
|
}
|
|
579
580
|
}
|
|
580
581
|
},
|
|
581
582
|
|
|
582
583
|
//数据初始化?
|
|
583
584
|
organTreeRedis(row, readingRange) {
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
if (row == 'undefined' || row == 'all') {
|
|
587
|
-
|
|
588
|
-
ajax.get(this.smartFlowServerContext + '/manage/processDesign/getOrgan?orgId=' + (jsonArray.organId)
|
|
589
|
-
).then(resp => {
|
|
590
|
-
if (resp.data.code === '200') {
|
|
591
|
-
this.organTree = resp.data.data
|
|
592
|
-
}
|
|
593
|
-
})
|
|
594
|
-
} else {
|
|
595
|
-
let organIds =[]
|
|
585
|
+
let organIds = []
|
|
586
|
+
if (readingRange.length > 0) {
|
|
596
587
|
readingRange[0].forEach(item => {
|
|
597
588
|
organIds.push(item.organId)
|
|
598
589
|
})
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
590
|
+
}
|
|
591
|
+
|
|
592
|
+
ajax.get(this.smartFlowServerContext + '/manage/user/getAllUsersInfo', {
|
|
593
|
+
params: {
|
|
594
|
+
organIds: organIds.join(','),
|
|
595
|
+
permScopeList: row,
|
|
596
|
+
orgTreeType: this.organTreeType
|
|
606
597
|
}
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
console.log(this.organTree.userMap,"userMap")
|
|
598
|
+
}
|
|
599
|
+
).then(resp => {
|
|
600
|
+
if (resp.data.code === '200') {
|
|
601
|
+
for (let key in resp.data.data) {
|
|
602
|
+
const dataArr = [[key, resp.data.data[key]]]
|
|
603
|
+
for (let i = 0; i < dataArr.length; i++) {
|
|
604
|
+
const [key, value] = dataArr[i]
|
|
605
|
+
this.$set(this.organTree.userMap, key, value)
|
|
606
|
+
}
|
|
617
607
|
}
|
|
618
|
-
}
|
|
619
|
-
|
|
620
|
-
}
|
|
608
|
+
}
|
|
609
|
+
})
|
|
621
610
|
|
|
622
611
|
},
|
|
623
612
|
|
|
@@ -695,7 +684,7 @@ export default {
|
|
|
695
684
|
watch: {
|
|
696
685
|
countersignersTagsData: {
|
|
697
686
|
handler(newVal, oldVal) {
|
|
698
|
-
console.log(
|
|
687
|
+
console.log('countersignersTagsData', newVal)
|
|
699
688
|
let organ = []
|
|
700
689
|
let names = []
|
|
701
690
|
let organs = []
|
|
@@ -770,9 +759,10 @@ export default {
|
|
|
770
759
|
}
|
|
771
760
|
|
|
772
761
|
.contLeft {
|
|
773
|
-
flex:
|
|
774
|
-
|
|
775
|
-
|
|
762
|
+
flex: 1; /* 让右侧自适应剩余空间 */
|
|
763
|
+
margin-top: 34px; /* 您原本的33.98px可改为34px */
|
|
764
|
+
min-height: 350px;
|
|
765
|
+
overflow: auto; /* 可选,若内容过长也可滚动 */
|
|
776
766
|
}
|
|
777
767
|
|
|
778
768
|
.contRight {
|
|
@@ -793,49 +783,48 @@ export default {
|
|
|
793
783
|
}
|
|
794
784
|
|
|
795
785
|
.contLeftTwo {
|
|
796
|
-
flex:
|
|
797
|
-
|
|
786
|
+
flex: none; /* 改为none,这样不按照flex比例缩放 */
|
|
787
|
+
width: 250px; /* 固定宽度或max-width */
|
|
798
788
|
margin-right: 10px;
|
|
789
|
+
overflow: auto; /* 当内容超过300px宽时出现滚动条 */
|
|
799
790
|
}
|
|
800
791
|
|
|
801
|
-
.contRightTwo {
|
|
802
|
-
flex: 0 0 49%;
|
|
803
|
-
margin-top: 30px;
|
|
804
|
-
}
|
|
805
792
|
|
|
806
793
|
/deep/ .ivu-checkbox-input {
|
|
807
794
|
width: 136px;
|
|
808
795
|
}
|
|
809
|
-
|
|
810
|
-
|
|
796
|
+
|
|
797
|
+
/deep/ .custom-select .ivu-select {
|
|
798
|
+
height: 80px; /* 控制总体高度 */
|
|
811
799
|
min-height: 80px;
|
|
812
|
-
line-height: normal;
|
|
800
|
+
line-height: normal; /* 避免行高过大导致居中 */
|
|
813
801
|
box-sizing: border-box;
|
|
814
802
|
}
|
|
815
803
|
|
|
816
|
-
/deep
|
|
804
|
+
/deep/ .custom-select .ivu-select-input {
|
|
817
805
|
height: auto !important;
|
|
818
806
|
line-height: normal !important;
|
|
819
807
|
padding: 0 !important;
|
|
820
808
|
margin-top: 0 !important;
|
|
821
809
|
}
|
|
822
810
|
|
|
823
|
-
/deep
|
|
811
|
+
/deep/ .custom-select .ivu-select-selection {
|
|
824
812
|
display: flex !important;
|
|
825
813
|
flex-wrap: wrap !important;
|
|
826
814
|
align-items: flex-start !important;
|
|
827
|
-
height: 80px;
|
|
815
|
+
height: 80px; /* 与上面的高度一致 */
|
|
828
816
|
padding: 8px !important;
|
|
829
817
|
line-height: normal !important;
|
|
830
818
|
overflow-y: auto;
|
|
831
819
|
}
|
|
832
820
|
|
|
833
|
-
/deep
|
|
821
|
+
/deep/ .custom-select .ivu-select-selection__choice {
|
|
834
822
|
margin: 0 5px 5px 0;
|
|
835
|
-
vertical-align: top;
|
|
823
|
+
vertical-align: top;
|
|
824
|
+
}
|
|
836
825
|
|
|
837
826
|
/* 可选:调整下拉箭头的位置 */
|
|
838
|
-
/deep
|
|
827
|
+
/deep/ .custom-select .ivu-select-arrow {
|
|
839
828
|
display: none;
|
|
840
829
|
}
|
|
841
830
|
</style>
|