@lambo-design/workflow-approve 1.0.0-beta.45 → 1.0.0-beta.47
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 +3 -3
- package/src/components/countersigners-box.vue +202 -271
- package/src/components/history.vue +4 -2
- package/src/portrait.vue +1569 -1565
- package/src/workflow-diagram.vue +4 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@lambo-design/workflow-approve",
|
|
3
|
-
"version": "1.0.0-beta.
|
|
3
|
+
"version": "1.0.0-beta.47",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"author": "lambo",
|
|
@@ -12,8 +12,8 @@
|
|
|
12
12
|
"devDependencies": {
|
|
13
13
|
"axios": "^0.24.0",
|
|
14
14
|
"axios-cache-plugin": "^0.1.0",
|
|
15
|
-
"@lambo-design/
|
|
16
|
-
"@lambo-design/
|
|
15
|
+
"@lambo-design/core": "^4.7.1-beta.156",
|
|
16
|
+
"@lambo-design/shared": "^1.0.0-beta.246"
|
|
17
17
|
},
|
|
18
18
|
"dependencies": {
|
|
19
19
|
"bpmn-js": "^7.3.1",
|
|
@@ -1,15 +1,14 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div style="min-height: 300px;">
|
|
3
|
-
<
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
</div>
|
|
3
|
+
<Select v-model="countersignersTagsData"
|
|
4
|
+
filterable multiple
|
|
5
|
+
@on-change="organChange($event)"
|
|
6
|
+
class="custom-select"
|
|
7
|
+
>
|
|
8
|
+
<Option v-for="(value, key) in organTree.userMap" :key="key" :value="`${key},${value}`" :label="value">
|
|
9
|
+
<span>{{ value }}</span>
|
|
10
|
+
</Option>
|
|
11
|
+
</Select>
|
|
13
12
|
<div class="cont">
|
|
14
13
|
<div
|
|
15
14
|
class="contLeftTwo">
|
|
@@ -89,7 +88,7 @@ export default {
|
|
|
89
88
|
userNum: '0',
|
|
90
89
|
// permScope: "",
|
|
91
90
|
organTreeType: '00',
|
|
92
|
-
|
|
91
|
+
organIdList: [],
|
|
93
92
|
countersignersTagsData: [],
|
|
94
93
|
organTree: {
|
|
95
94
|
orgenMap: {},
|
|
@@ -152,24 +151,6 @@ export default {
|
|
|
152
151
|
},
|
|
153
152
|
methods: {
|
|
154
153
|
//把已选择的数据放入到已选列表中展示
|
|
155
|
-
getOrgan(row) {
|
|
156
|
-
let self = this
|
|
157
|
-
self.countersignersTagsData = []
|
|
158
|
-
let organs = row.organs
|
|
159
|
-
let organList = organs.split(',')
|
|
160
|
-
if (organs && organList.length > 0) {
|
|
161
|
-
organList.forEach(item => {
|
|
162
|
-
let organ = {
|
|
163
|
-
code: item.split(':')[0],
|
|
164
|
-
name: item.split(':')[1],
|
|
165
|
-
}
|
|
166
|
-
self.treeValueBM.push(organ)
|
|
167
|
-
self.orgList.push(organ)
|
|
168
|
-
self.countersignersTagsData.push(item + ',1')
|
|
169
|
-
self.userNum = '1'
|
|
170
|
-
})
|
|
171
|
-
}
|
|
172
|
-
},
|
|
173
154
|
getUser(row) {
|
|
174
155
|
let self = this
|
|
175
156
|
self.selectedKeys = []
|
|
@@ -178,79 +159,24 @@ export default {
|
|
|
178
159
|
let userList = users.split(',')
|
|
179
160
|
if (users && userList.length > 0) {
|
|
180
161
|
userList.forEach(item => {
|
|
181
|
-
let userId = item.split(':')
|
|
182
|
-
let
|
|
183
|
-
let user = {
|
|
184
|
-
userId: userId,
|
|
185
|
-
userName: userName,
|
|
186
|
-
}
|
|
187
|
-
let userStr = userId + ',' + userName
|
|
162
|
+
let [userId, userName] = item.split(':');
|
|
163
|
+
let userStr = `${userId},${userName}`;
|
|
188
164
|
self.selectedData.push(userStr)
|
|
189
165
|
self.treeUserValue.push(userStr)
|
|
190
166
|
self.selectedKeys.push(userStr)
|
|
191
|
-
self.countersignersTagsData.
|
|
192
|
-
|
|
193
|
-
})
|
|
194
|
-
}
|
|
195
|
-
},
|
|
196
|
-
getRole(row) {
|
|
197
|
-
let self = this
|
|
198
|
-
self.noticeRoleList = []
|
|
199
|
-
self.noticeList = []
|
|
200
|
-
self.noticeRoleNameList = []
|
|
201
|
-
let roles = row.roles
|
|
202
|
-
let roleList = roles.split(',')
|
|
203
|
-
if (roles && roleList.length > 0) {
|
|
204
|
-
roleList.forEach(item => {
|
|
205
|
-
let roleId = item.split(':')[0]
|
|
206
|
-
let roleName = item.split(':')[1]
|
|
207
|
-
self.noticeRoleNameList.push(roleName)
|
|
208
|
-
self.countersignersTagsData.push(item + ',3')
|
|
209
|
-
let roles = roleId + ',' + roleName
|
|
210
|
-
self.selectedData.push(roles)
|
|
211
|
-
self.noticeList.push(roles)
|
|
212
|
-
})
|
|
213
|
-
}
|
|
214
|
-
},
|
|
215
|
-
getPost(row) {
|
|
216
|
-
let self = this
|
|
217
|
-
self.treePostValue = []
|
|
218
|
-
self.postKeys = []
|
|
219
|
-
self.treePostNameCenterValue = []
|
|
220
|
-
let positions = row.positions
|
|
221
|
-
let positionList = positions.split(',')
|
|
222
|
-
if (positions && positionList.length > 0) {
|
|
223
|
-
positionList.forEach(item => {
|
|
224
|
-
let positionId = item.split(':')[0]
|
|
225
|
-
let positionName = item.split(':')[1]
|
|
226
|
-
let position = {
|
|
227
|
-
positionId: positionId,
|
|
228
|
-
positionName: positionName,
|
|
167
|
+
if (!self.countersignersTagsData.includes(userStr)) {
|
|
168
|
+
self.countersignersTagsData.push(userStr);
|
|
229
169
|
}
|
|
230
|
-
|
|
231
|
-
self.treePostValue.push(post)
|
|
232
|
-
self.postKeys.push(post)
|
|
233
|
-
// resp.data.data.code = resp.data.data.orgCode
|
|
234
|
-
// self.treePostNameCenterValue.push(resp.data.data)
|
|
235
|
-
self.treePostNameCenterValue.push(position)
|
|
236
|
-
self.countersignersTagsData.push(item + ',4')
|
|
170
|
+
self.userNum = '1'
|
|
237
171
|
})
|
|
238
172
|
}
|
|
239
173
|
},
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
let type = {
|
|
247
|
-
bizTypeCode: item.split(':')[0],
|
|
248
|
-
typeName: item.split(':')[1],
|
|
249
|
-
}
|
|
250
|
-
self.treeOrgTypeValue.push(type)
|
|
251
|
-
self.updateLength()
|
|
252
|
-
})
|
|
253
|
-
}
|
|
174
|
+
|
|
175
|
+
organChange(event) {
|
|
176
|
+
this.countersignersTagsData = [...event]; // 直接同步
|
|
177
|
+
this.treeUserValue = [...event]; // 保持一致
|
|
178
|
+
this.selectedKeys = [...event];
|
|
179
|
+
|
|
254
180
|
},
|
|
255
181
|
|
|
256
182
|
getRootOrganTree(organTreeType) {
|
|
@@ -345,69 +271,69 @@ export default {
|
|
|
345
271
|
getOrganTreeByProType(row, permScope, organTreeType) {
|
|
346
272
|
const self = this
|
|
347
273
|
return new Promise((resolve, reject) => {
|
|
348
|
-
let organTree = []
|
|
349
|
-
let childsTree = []
|
|
274
|
+
let organTree = []
|
|
275
|
+
let childsTree = []
|
|
350
276
|
if (permScope && permScope.length > 0) {
|
|
351
277
|
let params = {
|
|
352
278
|
orgTreeType: organTreeType,
|
|
353
|
-
}
|
|
354
|
-
permScope = permScope.split(';')
|
|
279
|
+
}
|
|
280
|
+
permScope = permScope.split(';')
|
|
355
281
|
|
|
356
282
|
const requests = permScope.map(perm => {
|
|
357
283
|
return ajax.get(self.smartFlowServerContext + '/manage/organ/get/' + perm, { params: params })
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
})
|
|
284
|
+
.then(resp => {
|
|
285
|
+
if (resp.data.code === 200) {
|
|
286
|
+
return resp.data.data
|
|
287
|
+
} else {
|
|
288
|
+
return []
|
|
289
|
+
}
|
|
290
|
+
})
|
|
291
|
+
.catch(err => {
|
|
292
|
+
console.error(err)
|
|
293
|
+
return []
|
|
294
|
+
})
|
|
295
|
+
})
|
|
370
296
|
|
|
371
297
|
Promise.all(requests)
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
};
|
|
389
|
-
childsTree.push(obj);
|
|
390
|
-
}
|
|
391
|
-
});
|
|
392
|
-
|
|
393
|
-
organTree.push(childsTree);
|
|
394
|
-
const codesSeen = new Map();
|
|
395
|
-
organTree = organTree.reduce((acc, item, index) => {
|
|
396
|
-
if (!codesSeen.has(item.code)) {
|
|
397
|
-
codesSeen.set(item.code, index);
|
|
398
|
-
acc.push(item);
|
|
298
|
+
.then(results => {
|
|
299
|
+
results.forEach(data => {
|
|
300
|
+
if (data) {
|
|
301
|
+
let obj = {
|
|
302
|
+
type: data.organType,
|
|
303
|
+
id: data.id,
|
|
304
|
+
organId: data.organId,
|
|
305
|
+
orders: data.orders,
|
|
306
|
+
title: data.organName,
|
|
307
|
+
name: data.organName,
|
|
308
|
+
com: data.organId,
|
|
309
|
+
code: data.organCode,
|
|
310
|
+
loading: false,
|
|
311
|
+
checked: false,
|
|
312
|
+
children: [],
|
|
313
|
+
hasChild: true,
|
|
399
314
|
}
|
|
400
|
-
|
|
401
|
-
}
|
|
402
|
-
resolve(organTree);
|
|
315
|
+
childsTree.push(obj)
|
|
316
|
+
}
|
|
403
317
|
})
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
318
|
+
|
|
319
|
+
organTree.push(childsTree)
|
|
320
|
+
const codesSeen = new Map()
|
|
321
|
+
organTree = organTree.reduce((acc, item, index) => {
|
|
322
|
+
if (!codesSeen.has(item.code)) {
|
|
323
|
+
codesSeen.set(item.code, index)
|
|
324
|
+
acc.push(item)
|
|
325
|
+
}
|
|
326
|
+
return acc
|
|
327
|
+
}, [])
|
|
328
|
+
resolve(organTree)
|
|
329
|
+
})
|
|
330
|
+
.catch(err => {
|
|
331
|
+
reject(err)
|
|
332
|
+
})
|
|
407
333
|
} else {
|
|
408
|
-
resolve([])
|
|
334
|
+
resolve([])
|
|
409
335
|
}
|
|
410
|
-
})
|
|
336
|
+
})
|
|
411
337
|
},
|
|
412
338
|
//获取人员树信息(数据初始化)
|
|
413
339
|
async getReadingRange(row, organTreeType) {
|
|
@@ -415,55 +341,60 @@ export default {
|
|
|
415
341
|
var permScope = row.substring(row.indexOf('U:'))
|
|
416
342
|
permScope = permScope.substring(2, permScope.indexOf(','))
|
|
417
343
|
let permScopeTwo = permScope.split(';')
|
|
418
|
-
if (permScopeTwo.length > 0 && permScopeTwo[0]){
|
|
344
|
+
if (permScopeTwo.length > 0 && permScopeTwo[0]) {
|
|
419
345
|
let promises = []
|
|
420
346
|
for (let i = 0; i < permScopeTwo.length; i++) {
|
|
421
|
-
let promise = ajax.get(self.smartFlowServerContext +
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
347
|
+
let promise = ajax.get(self.smartFlowServerContext + '/manage/user/get/' + permScopeTwo[i] + '?treeType=' + organTreeType)
|
|
348
|
+
.then(resp => {
|
|
349
|
+
if (resp.data.code === 200) {
|
|
350
|
+
return resp.data.data.organCode
|
|
351
|
+
}
|
|
352
|
+
})
|
|
427
353
|
promises.push(promise)
|
|
428
354
|
}
|
|
429
355
|
Promise.all(promises).then(async (result) => {
|
|
430
|
-
const uniqueResults = [...new Set(result.filter(Boolean))]
|
|
431
|
-
permScope = uniqueResults.join(';')
|
|
432
|
-
self.readingRange = await this.getOrganTreeByProType(row, permScope, organTreeType)
|
|
356
|
+
const uniqueResults = [...new Set(result.filter(Boolean))]
|
|
357
|
+
permScope = uniqueResults.join(';')
|
|
358
|
+
self.readingRange = await this.getOrganTreeByProType(row, permScope, organTreeType)
|
|
359
|
+
self.organTreeRedis(this.permScope, self.readingRange)
|
|
433
360
|
})
|
|
434
361
|
} else {
|
|
435
362
|
//对于流程类型中没有规定人员范围但规定组织范围的情况
|
|
436
|
-
self.readingRange = await this.getOrganTreeByProType(row, row.substring(2, row.indexOf(
|
|
363
|
+
self.readingRange = await this.getOrganTreeByProType(row, row.substring(2, row.indexOf(',')), organTreeType)
|
|
437
364
|
}
|
|
438
365
|
|
|
439
366
|
},
|
|
440
367
|
|
|
441
|
-
closeTags(index, info) {
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
},
|
|
446
|
-
|
|
447
|
-
//权限范围人员单条删除
|
|
448
|
-
readingRangeScPerDel(res, info) {
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
368
|
+
// closeTags(index, info) {
|
|
369
|
+
// let type = info.split(',')[1]
|
|
370
|
+
// let data = info.split(',')[0]
|
|
371
|
+
// this.readingRangeScPerDel(index, data)
|
|
372
|
+
// },
|
|
373
|
+
|
|
374
|
+
// //权限范围人员单条删除
|
|
375
|
+
// readingRangeScPerDel(res, info) {
|
|
376
|
+
// let self = this
|
|
377
|
+
// console.log(this.treeUserValue,"treeUserValue")
|
|
378
|
+
// console.log(info,"info")
|
|
379
|
+
// let index = this.treeUserValue.findIndex(item => {
|
|
380
|
+
// return item === info
|
|
381
|
+
// })
|
|
382
|
+
// if (index !== -1) {
|
|
383
|
+
// self.treeUserValue = self.treeUserValue.filter((_, i) => i !== index)
|
|
384
|
+
// self.selectedKeys = self.selectedKeys.filter((_, i) => i !== index)
|
|
385
|
+
// // self.selectedKeys.splice(index, 1)
|
|
386
|
+
// }
|
|
387
|
+
// let orgList = []
|
|
388
|
+
// let organList = []
|
|
389
|
+
// orgList.push(info)
|
|
390
|
+
// info = info.replace(',', ':')
|
|
391
|
+
// self.countersignersTagsData.forEach(organ => {
|
|
392
|
+
// if (organ.indexOf(info) == -1) {
|
|
393
|
+
// organList.push(organ)
|
|
394
|
+
// }
|
|
395
|
+
// })
|
|
396
|
+
// self.countersignersTagsData = organList
|
|
397
|
+
// },
|
|
467
398
|
|
|
468
399
|
selectUserChange(node) {
|
|
469
400
|
let self = this
|
|
@@ -544,7 +475,6 @@ export default {
|
|
|
544
475
|
})
|
|
545
476
|
},
|
|
546
477
|
|
|
547
|
-
|
|
548
478
|
//权限范围用户点击事件(点击人员树,触发查询,显示在右侧)
|
|
549
479
|
selectReRaYHChange(data, info) {
|
|
550
480
|
let self = this
|
|
@@ -569,7 +499,7 @@ export default {
|
|
|
569
499
|
}
|
|
570
500
|
}).then(function (resp) {
|
|
571
501
|
if (resp.data.code === 200) {
|
|
572
|
-
let nodeUser = resp.data.data.rows ? resp.data.data.rows : resp.data.data
|
|
502
|
+
let nodeUser = resp.data.data.rows ? resp.data.data.rows : resp.data.data
|
|
573
503
|
nodeUser.forEach(item => {
|
|
574
504
|
if (!userIdSet.has(item.userId)) {
|
|
575
505
|
userIdSet.add(item.userId)
|
|
@@ -597,7 +527,7 @@ export default {
|
|
|
597
527
|
}
|
|
598
528
|
}).then(function (resp) {
|
|
599
529
|
if (resp.data.code === 200) {
|
|
600
|
-
let nodeUser = resp.data.data.rows ? resp.data.data.rows : resp.data.data
|
|
530
|
+
let nodeUser = resp.data.data.rows ? resp.data.data.rows : resp.data.data
|
|
601
531
|
nodeUser.forEach(item => {
|
|
602
532
|
if ((!userIdSet.has(item.userId) && userPermScope.includes(item.userId)) || userPermScope.length <= 0 || !userPermScope[0]) {
|
|
603
533
|
userIdSet.add(item.userId)
|
|
@@ -619,41 +549,38 @@ export default {
|
|
|
619
549
|
self.treeUserCenterValue = treeUserCenters
|
|
620
550
|
},
|
|
621
551
|
|
|
622
|
-
|
|
623
|
-
//人员选中
|
|
552
|
+
// 人员选中
|
|
624
553
|
getReadingRangeUser(row) {
|
|
625
|
-
let self = this
|
|
626
|
-
|
|
627
|
-
self.userNum = '2'
|
|
554
|
+
let self = this;
|
|
555
|
+
self.userNum = '2';
|
|
628
556
|
if (row.length > self.selectedKeys.length) {
|
|
629
|
-
|
|
630
|
-
self.
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
let
|
|
634
|
-
|
|
557
|
+
// 用户选择了新人员
|
|
558
|
+
self.treeUserValue = row;
|
|
559
|
+
self.selectedKeys = row;
|
|
560
|
+
|
|
561
|
+
let index = row.length - 1;
|
|
562
|
+
let organName = row[index];
|
|
563
|
+
|
|
564
|
+
if (!self.countersignersTagsData.includes(organName)) {
|
|
565
|
+
self.countersignersTagsData.push(organName);
|
|
566
|
+
}
|
|
567
|
+
|
|
568
|
+
self.organChange(self.countersignersTagsData);
|
|
569
|
+
|
|
635
570
|
} else if (row.length < self.selectedKeys.length) {
|
|
636
|
-
|
|
637
|
-
let
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
571
|
+
// 用户取消了选择
|
|
572
|
+
let diff = self.selectedKeys.find(item => !row.includes(item));
|
|
573
|
+
|
|
574
|
+
// 从 countersignersTagsData 中移除取消的用户
|
|
575
|
+
if (diff) {
|
|
576
|
+
self.countersignersTagsData = self.countersignersTagsData.filter(item => item !== diff);
|
|
577
|
+
self.selectedKeys = row; // 更新选中数据
|
|
642
578
|
}
|
|
643
|
-
diff = diff.replace(',', ':')
|
|
644
|
-
self.countersignersTagsData.forEach(organ => {
|
|
645
|
-
if (organ.indexOf(diff) == -1) {
|
|
646
|
-
orgList.push(organ)
|
|
647
|
-
}
|
|
648
|
-
})
|
|
649
|
-
self.countersignersTagsData = orgList
|
|
650
|
-
self.selectedKeys = row
|
|
651
579
|
}
|
|
652
580
|
},
|
|
653
581
|
|
|
654
|
-
|
|
655
582
|
//数据初始化?
|
|
656
|
-
organTreeRedis(row) {
|
|
583
|
+
organTreeRedis(row, readingRange) {
|
|
657
584
|
const user = sessionStorage.getItem('userInfo')
|
|
658
585
|
const jsonArray = JSON.parse(user)
|
|
659
586
|
if (row == 'undefined' || row == 'all') {
|
|
@@ -665,43 +592,31 @@ export default {
|
|
|
665
592
|
}
|
|
666
593
|
})
|
|
667
594
|
} else {
|
|
668
|
-
|
|
669
|
-
|
|
670
|
-
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
|
|
674
|
-
|
|
675
|
-
|
|
676
|
-
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
).then(resp => {
|
|
688
|
-
if (resp.data.code === '200') {
|
|
689
|
-
for (let key in resp.data.data.userMap) {
|
|
690
|
-
for (let i = 0; i < userPermScope.length; i++) {
|
|
691
|
-
if (key == userPermScope[i]) {
|
|
692
|
-
const dataArr = [[key, resp.data.data.userMap[key]]]
|
|
693
|
-
for (let i = 0; i < dataArr.length; i++) {
|
|
694
|
-
const [key, value] = dataArr[i]
|
|
695
|
-
this.$set(this.organTree.userMap, key, value)
|
|
696
|
-
}
|
|
697
|
-
}
|
|
595
|
+
let organIds =[]
|
|
596
|
+
readingRange[0].forEach(item => {
|
|
597
|
+
organIds.push(item.organId)
|
|
598
|
+
})
|
|
599
|
+
console.log(organIds)
|
|
600
|
+
ajax.get(this.smartFlowServerContext + '/manage/user/getAllUsersInfo', {
|
|
601
|
+
params: {
|
|
602
|
+
organIds: organIds.join(','),
|
|
603
|
+
permScopeList: row,
|
|
604
|
+
orgTreeType: this.organTreeType
|
|
605
|
+
}
|
|
606
|
+
}
|
|
607
|
+
).then(resp => {
|
|
608
|
+
if (resp.data.code === '200') {
|
|
609
|
+
for (let key in resp.data.data) {
|
|
610
|
+
const dataArr = [[key, resp.data.data[key]]]
|
|
611
|
+
for (let i = 0; i < dataArr.length; i++) {
|
|
612
|
+
const [key, value] = dataArr[i]
|
|
613
|
+
this.$set(this.organTree.userMap, key, value)
|
|
698
614
|
}
|
|
699
615
|
}
|
|
616
|
+
console.log(this.organTree.userMap,"userMap")
|
|
617
|
+
}
|
|
618
|
+
})
|
|
700
619
|
|
|
701
|
-
}
|
|
702
|
-
})
|
|
703
|
-
|
|
704
|
-
})
|
|
705
620
|
}
|
|
706
621
|
|
|
707
622
|
},
|
|
@@ -753,7 +668,7 @@ export default {
|
|
|
753
668
|
this.id = id
|
|
754
669
|
this.permScope = permScope
|
|
755
670
|
this.organTreeType = organTreeType
|
|
756
|
-
this.organTreeRedis(this.permScope)
|
|
671
|
+
// this.organTreeRedis(this.permScope)
|
|
757
672
|
if (inputValue) {
|
|
758
673
|
//加入已选择的数据
|
|
759
674
|
this.getUser(inputValue)
|
|
@@ -764,25 +679,9 @@ export default {
|
|
|
764
679
|
} else {
|
|
765
680
|
this.getReadingRange(this.permScope, this.organTreeType)
|
|
766
681
|
}
|
|
767
|
-
},
|
|
768
|
-
findTitleByValue(arr, value) {
|
|
769
|
-
function traverse(items) {
|
|
770
|
-
for (let item of items) {
|
|
771
|
-
if (item.value === value) {
|
|
772
|
-
return item.title
|
|
773
|
-
}
|
|
774
|
-
if (item.children && item.children.length > 0) {
|
|
775
|
-
let result = traverse(item.children)
|
|
776
|
-
if (result) {
|
|
777
|
-
return result
|
|
778
|
-
}
|
|
779
|
-
}
|
|
780
|
-
}
|
|
781
|
-
return ''
|
|
782
|
-
}
|
|
783
682
|
|
|
784
|
-
return traverse(arr)
|
|
785
683
|
},
|
|
684
|
+
|
|
786
685
|
showUserDetail(item) {
|
|
787
686
|
if (item.organName) {
|
|
788
687
|
return `(${item.organName} )`
|
|
@@ -796,6 +695,7 @@ export default {
|
|
|
796
695
|
watch: {
|
|
797
696
|
countersignersTagsData: {
|
|
798
697
|
handler(newVal, oldVal) {
|
|
698
|
+
console.log("countersignersTagsData",newVal)
|
|
799
699
|
let organ = []
|
|
800
700
|
let names = []
|
|
801
701
|
let organs = []
|
|
@@ -806,13 +706,12 @@ export default {
|
|
|
806
706
|
})
|
|
807
707
|
let nameValue = []
|
|
808
708
|
let users = []
|
|
809
|
-
//倒着从treeUserValue遍历,保证顺序和显示的一样
|
|
810
709
|
this.treeUserValue.forEach(item => {
|
|
811
|
-
const parts = item.split(',')
|
|
812
|
-
nameValue.push(parts[0])
|
|
813
|
-
names.push(parts[1])
|
|
814
|
-
users.push(parts[0] + ':' + parts[1])
|
|
815
|
-
})
|
|
710
|
+
const parts = item.split(',')
|
|
711
|
+
nameValue.push(parts[0])
|
|
712
|
+
names.push(parts[1])
|
|
713
|
+
users.push(parts[0] + ':' + parts[1])
|
|
714
|
+
})
|
|
816
715
|
let roleList = []
|
|
817
716
|
let roles = []
|
|
818
717
|
this.noticeRoleList.forEach(item => {
|
|
@@ -907,4 +806,36 @@ export default {
|
|
|
907
806
|
/deep/ .ivu-checkbox-input {
|
|
908
807
|
width: 136px;
|
|
909
808
|
}
|
|
809
|
+
/deep/.custom-select .ivu-select {
|
|
810
|
+
height: 80px; /* 控制总体高度 */
|
|
811
|
+
min-height: 80px;
|
|
812
|
+
line-height: normal; /* 避免行高过大导致居中 */
|
|
813
|
+
box-sizing: border-box;
|
|
814
|
+
}
|
|
815
|
+
|
|
816
|
+
/deep/.custom-select .ivu-select-input {
|
|
817
|
+
height: auto !important;
|
|
818
|
+
line-height: normal !important;
|
|
819
|
+
padding: 0 !important;
|
|
820
|
+
margin-top: 0 !important;
|
|
821
|
+
}
|
|
822
|
+
|
|
823
|
+
/deep/.custom-select .ivu-select-selection {
|
|
824
|
+
display: flex !important;
|
|
825
|
+
flex-wrap: wrap !important;
|
|
826
|
+
align-items: flex-start !important;
|
|
827
|
+
height: 80px; /* 与上面的高度一致 */
|
|
828
|
+
padding: 8px !important;
|
|
829
|
+
line-height: normal !important;
|
|
830
|
+
overflow-y: auto;
|
|
831
|
+
}
|
|
832
|
+
|
|
833
|
+
/deep/.custom-select .ivu-select-selection__choice {
|
|
834
|
+
margin: 0 5px 5px 0;
|
|
835
|
+
vertical-align: top;}
|
|
836
|
+
|
|
837
|
+
/* 可选:调整下拉箭头的位置 */
|
|
838
|
+
/deep/.custom-select .ivu-select-arrow {
|
|
839
|
+
display: none;
|
|
840
|
+
}
|
|
910
841
|
</style>
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
<Timeline class="portrait-timeline">
|
|
5
5
|
<TimelineItem v-for="(items,index) in itemList" :key="index" class="portrait-timeline-item">
|
|
6
6
|
<template #dot>
|
|
7
|
-
<div v-if="items[0].auditResult === '00' || items[0].auditResult === '30' || items[0].auditResult === '80'" class="cicle" style="background-color: #005aff"></div>
|
|
7
|
+
<div v-if="items[0].auditResult === '00' || items[0].auditResult === '10' || items[0].auditResult === '30' || items[0].auditResult === '80'" class="cicle" style="background-color: #005aff"></div>
|
|
8
8
|
<div v-else-if="items[0].auditResult === '40' || items[0].auditResult === '50'" class="cicle" style="background-color: #ffcc66"></div>
|
|
9
9
|
<div v-else-if="items[0].auditResult === '60'" class="cicle" style="background-color: #ed4014"></div>
|
|
10
10
|
<div v-else class="cicle" style="background-color: #ff9900"></div>
|
|
@@ -56,6 +56,8 @@
|
|
|
56
56
|
<Col span="12">
|
|
57
57
|
<span style="color: #005aff;; font-size: 13px;"
|
|
58
58
|
v-if="item.auditResult === '00'">流程发起</span>
|
|
59
|
+
<span style="color: #005aff;; font-size: 13px;"
|
|
60
|
+
v-else-if="item.auditResult === '10'">自动跳过</span>
|
|
59
61
|
<span style="color: #005aff;; font-size: 13px;"
|
|
60
62
|
v-else-if="item.auditResult === '30'">通过</span>
|
|
61
63
|
<span style="color: #ed4014; font-size: 13px;"
|
|
@@ -74,7 +76,7 @@
|
|
|
74
76
|
</Col>
|
|
75
77
|
<Col span="12" style="text-align: right">
|
|
76
78
|
<Button v-if="item.fileList && item.fileList.length > 0" size="small" type="primary" ghost class="urging" @click="openModal(item)">查看附件</Button>
|
|
77
|
-
<Button v-if="displayPushButton && item.auditResult !== '00'&& item.auditResult !== '30'&&item.auditResult !== '40'&&item.auditResult !== '50'&&item.auditResult !== '60'&&item.auditResult!=='80'&&item.auditResult!=='90'"
|
|
79
|
+
<Button v-if="displayPushButton && item.auditResult !== '00' && item.auditResult !== '10' && item.auditResult !== '30'&&item.auditResult !== '40'&&item.auditResult !== '50'&&item.auditResult !== '60'&&item.auditResult!=='80'&&item.auditResult!=='90'"
|
|
78
80
|
size="small" type="primary" ghost class="urging"
|
|
79
81
|
@click="pushHim(item,itemListItem,itemListIndex)">催一下
|
|
80
82
|
</Button>
|