Compare commits

...

6 Commits

Author SHA1 Message Date
clay 9fb0524c6b Merge pull request 'clay : 任意节点退回完成' (#34) from master into pro
continuous-integration/drone/push Build is passing Details
Reviewed-on: http://git.hchyun.com/clay/workflow-engine-web/pulls/34
2023-03-20 09:29:16 +00:00
clay 9285814edc clay : 任意节点退回完成 2023-03-20 17:28:25 +08:00
clay cde76e13cb clay : fix userPicker报错 2023-03-18 19:48:39 +08:00
clay f98ca9efbb clay : fix userPicker报错 2023-03-18 19:40:07 +08:00
邓洁 87b1d9d2c0 dengjie : 修改人员选择bug 2023-03-18 18:57:29 +08:00
邓洁 fc288926d5 dengjie : 审批流程部分样式修改 2023-03-13 00:55:08 +08:00
7 changed files with 151 additions and 77 deletions

View File

@ -4,9 +4,8 @@
:style="{'--row':row}"> :style="{'--row':row}">
<slot name="pre"></slot> <slot name="pre"></slot>
<div style="display: flex;"> <div style="display: flex;">
<div v-for="(user,index) in userInfo" :key="index"> <div v-for="(user,index) in userInfo" :key="index" class="avatar_name">
<div> <el-avatar size="large"
<el-avatar style="margin-right: 5px;" size="large"
:src="user.avatar"></el-avatar> :src="user.avatar"></el-avatar>
<div v-if="user.icon" <div v-if="user.icon"
class="el-timeline-item__node" :style="{ class="el-timeline-item__node" :style="{
@ -17,8 +16,9 @@
:class="user.icon" :class="user.icon"
></i> ></i>
</div> </div>
</div> <el-tooltip class="item" effect="dark" :content="user.name" placement="bottom-start">
<div>{{user.name}}</div> <span class="item_name">{{ user.name }}</span>
</el-tooltip>
</div> </div>
</div> </div>
</div> </div>
@ -27,20 +27,20 @@
<script> <script>
export default { export default {
name: "AvatarEllipsis", name: "AvatarEllipsis",
install(Vue){ install(Vue) {
Vue.component('avatarEllipsis', this) Vue.component('avatarEllipsis', this)
}, },
components: {}, components: {},
props:{ props: {
row: { row: {
type: Number, type: Number,
default: 1 default: 1
}, },
hoverTip:{ hoverTip: {
type: Boolean, type: Boolean,
default: false default: false
}, },
userInfo:{ userInfo: {
type: Array, type: Array,
default: [] default: []
} }
@ -52,7 +52,7 @@ export default {
return {} return {}
}, },
methods: { methods: {
init(){ init() {
for (let user of this.userInfo) { for (let user of this.userInfo) {
this.initUser(user) this.initUser(user)
} }
@ -60,26 +60,26 @@ export default {
initUser(user) { initUser(user) {
let state = user.state let state = user.state
// //
if (state === 'create') { if (state === 'CREATE') {
this.$set(user, "icon", "el-icon-check") this.$set(user, "icon", "el-icon-check")
this.$set(user, "color", "#0bbd87") this.$set(user, "color", "#0bbd87")
} }
// //
if (state === 'agree') { if (state === 'AGREE') {
this.$set(user, "icon", "el-icon-check") this.$set(user, "icon", "el-icon-check")
this.$set(user, "color", "#0bbd87") this.$set(user, "color", "#0bbd87")
} }
// //
if (state === 'running') { if (state === 'RUNNING') {
this.$set(user, "icon", "el-icon-loading") this.$set(user, "icon", "el-icon-loading")
this.$set(user, "color", "#f78f5f") this.$set(user, "color", "#f78f5f")
} }
// //
if (state === 'refuse') { if (state === 'REFUSE') {
this.$set(user, "icon", "el-icon-close") this.$set(user, "icon", "el-icon-close")
this.$set(user, "color", "#f56c6c") this.$set(user, "color", "#f56c6c")
} }
if (state === 'pass'){ if (state === 'PASS') {
this.$set(user, "icon", "el-icon-more") this.$set(user, "icon", "el-icon-more")
this.$set(user, "color", "#c0c4cc") this.$set(user, "color", "#c0c4cc")
} }
@ -90,5 +90,18 @@ export default {
</script> </script>
<style scoped> <style scoped>
.avatar_name {
display: flex;
flex-direction: column;
align-items: center;
margin-right: 5px;
/*width: 45px;*/
}
.item_name{
width: 45px;
text-align: center;
text-overflow: ellipsis;
white-space: nowrap;
overflow: hidden
}
</style> </style>

View File

@ -19,7 +19,6 @@
<el-tree :data="dataList" ref="tree" :props="defaultProps" empty-text="" node-key="value" <el-tree :data="dataList" ref="tree" :props="defaultProps" empty-text="" node-key="value"
:default-expanded-keys="expandedKeys" :default-expanded-keys="expandedKeys"
@node-click="handleChange" @node-click="handleChange"
:filter-node-method="filterNode"
> >
<div class="tree-node" slot-scope="{ node,data }"> <div class="tree-node" slot-scope="{ node,data }">
<div v-if="data.type === 0" style="display: flex;align-items: center"> <div v-if="data.type === 0" style="display: flex;align-items: center">
@ -70,6 +69,12 @@ export default {
return []; return [];
} }
}, },
selected: {
type: Array,
default: () => {
return [];
}
},
multiple: { // multiple: { //
default: true, default: true,
type: Boolean type: Boolean
@ -127,33 +132,43 @@ export default {
}, },
getList() { getList() {
getUserTree(this.radio, this.chooseId).then(res => { getUserTree(this.radio, this.chooseId).then(res => {
if (res.data) { console.log('人员', res.data)
// if (res.data) {
if (this.selectItem.type === -1 || this.selectItem.type === -2) { if (this.selectItem.type === -1 || this.selectItem.type === -2) {
this.dataList = this.setData(res.data) this.dataList = res.data
} else if (this.selectItem.type === 1) { }
else if (this.selectItem.type === 1) {
this.selectItem.children = res.data this.selectItem.children = res.data
} else if (this.selectItem.type === 2) { } else if (this.selectItem.type === 2) {
this.selectItem.children = this.setData(res.data) this.selectItem.children = res.data
} }
} // }
}); });
}, },
setData(source) { setData(source) {
for (let item of source) { // for (let item of source) {
this.$set(item, "value", this.selectItem.value + "-" + item.id) // this.$set(item, "value", this.selectItem.value + "-" + item.id)
this.$set(item, "children", []) // }
}
return source; return source;
}, },
// //
filterNode(value, data) { // filterNode(value, data) {
if (!value) return true; // if (!value) return true;
return data.name.indexOf(value) !== -1; // return data.name.indexOf(value) !== -1;
}, // },
// //
showUserPicker() { showUserPicker() {
this.getList(); this.selectItem = {
type: -1,
value: '0',
}
this.dataList = []
// this.selectList = []
this.chooseId = 0
this.radio = 0
this.visible = true; this.visible = true;
this.getList();
}, },
// //
handleChange(item, check) { handleChange(item, check) {
@ -162,20 +177,19 @@ export default {
if (item.type !== 0) { if (item.type !== 0) {
this.chooseId = item.id this.chooseId = item.id
this.getList() this.getList()
return
} }
if (!item.children) { if (this.multiple) {
if (this.multiple) { //
// for (let i = 0; i < this.selectList.length; i++) {
for (let i = 0; i < this.selectList.length; i++) { if (this.selectList[i].id === item.id) {
if (this.selectList[i].id === item.id) { this.selectList.splice(i, 1);
this.selectList.splice(i, 1); break;
break;
}
} }
this.selectList.push(item);
} else {
this.selectList = [item];
} }
this.selectList.push(item);
} else {
this.selectList = [item];
} }
// this._value = this.selectList // this._value = this.selectList
}, },
@ -202,6 +216,7 @@ export default {
// //
selectConfirm() { selectConfirm() {
this.$emit("ok", this.selectList); this.$emit("ok", this.selectList);
// this.dataList = []
this.visible = false; this.visible = false;
} }
} }

View File

@ -9,7 +9,7 @@
<el-button icon="el-icon-user" type="primary" size="mini" round @click="$refs.userPicker.showUserPicker()"> <el-button icon="el-icon-user" type="primary" size="mini" round @click="$refs.userPicker.showUserPicker()">
选择人员 选择人员
</el-button> </el-button>
<user-select type="user" :multiple="multiple" ref="userPicker" :selected="_value" @ok="selected"/> <user-select :multiple="multiple" ref="userPicker" title="请选择系统用户" :v-mode="_value" @ok="selected"/>
<span class="placeholder"> {{ placeholder }}</span> <span class="placeholder"> {{ placeholder }}</span>
<div style="display: flex;"> <div style="display: flex;">
<div class="userStyle" v-for="(user, i) in _value" :key="i"> <div class="userStyle" v-for="(user, i) in _value" :key="i">

View File

@ -9,18 +9,21 @@
placement="top"> placement="top">
<el-card> <el-card>
<div style="display: flex;"> <div style="display: flex;">
<div v-for="(user,index) in operation.userInfo" :key="index"> <div v-for="(user,index) in operation.userInfo" :key="index" class="avatar_name">
<el-avatar style="margin-right: 5px;" size="large" <el-avatar size="large"
:src="user.avatar"></el-avatar> :src="user.avatar"></el-avatar>
<div v-if="!$slots.dot && operation.userInfo.length > 1" <div v-if="!$slots.dot && operation.userInfo.length > 1"
class="el-timeline-item__node" :style="{ class="el-timeline-item__node avatar_icon" :style="{
backgroundColor: user.color backgroundColor: user.color
}"> }">
<i v-if="user.icon" <i v-if="user.icon"
class="el-timeline-item__icon" class="el-timeline-item__icon"
:class="user.icon" :class="user.icon"
></i> ></i>
</div> </div>
<el-tooltip effect="dark" :content="user.name" placement="bottom-start">
<span class="username">{{ user.name }}</span>
</el-tooltip>
</div> </div>
<div style="margin-left: 10px;"> <div style="margin-left: 10px;">
<div style="color: #c0bebe">{{ operation.operationName }}</div> <div style="color: #c0bebe">{{ operation.operationName }}</div>
@ -145,26 +148,26 @@ export default {
initUser(user) { initUser(user) {
let state = user.state let state = user.state
// //
if (state === 'create') { if (state === 'CREATE') {
this.$set(user, "icon", "el-icon-check") this.$set(user, "icon", "el-icon-check")
this.$set(user, "color", "#0bbd87") this.$set(user, "color", "#0bbd87")
} }
// //
if (state === 'agree') { if (state === 'AGREE') {
this.$set(user, "icon", "el-icon-check") this.$set(user, "icon", "el-icon-check")
this.$set(user, "color", "#0bbd87") this.$set(user, "color", "#0bbd87")
} }
// //
if (state === 'running') { if (state === 'RUNNING') {
this.$set(user, "icon", "el-icon-loading") this.$set(user, "icon", "el-icon-loading")
this.$set(user, "color", "#f78f5f") this.$set(user, "color", "#f78f5f")
} }
// //
if (state === 'refuse') { if (state === 'REFUSE') {
this.$set(user, "icon", "el-icon-close") this.$set(user, "icon", "el-icon-close")
this.$set(user, "color", "#f56c6c") this.$set(user, "color", "#f56c6c")
} }
if (state === 'pass'){ if (state === 'PASS'){
this.$set(user, "icon", "el-icon-more") this.$set(user, "icon", "el-icon-more")
this.$set(user, "color", "#c0c4cc") this.$set(user, "color", "#c0c4cc")
} }
@ -174,47 +177,47 @@ export default {
let state = operation.state let state = operation.state
let type = operation.operation let type = operation.operation
// //
if (state === 'create') { if (state === 'CREATE') {
this.$set(operation, "icon", "el-icon-check") this.$set(operation, "icon", "el-icon-check")
this.$set(operation, "color", "#0bbd87") this.$set(operation, "color", "#0bbd87")
this.$set(operation, "remark", operation.userInfo.name) this.$set(operation, "remark", operation.userInfo.name)
} }
// //
if (state === 'agree') { if (state === 'AGREE') {
this.$set(operation, "icon", "el-icon-check") this.$set(operation, "icon", "el-icon-check")
this.$set(operation, "color", "#0bbd87") this.$set(operation, "color", "#0bbd87")
this.$set(operation, "remark", operation.userInfo.name + ' (已同意)') this.$set(operation, "remark", operation.userInfo.name + ' (已同意)')
} }
if (state === 'pass'){ if (state === 'PASS'){
this.$set(operation, "icon", "el-icon-more") this.$set(operation, "icon", "el-icon-more")
this.$set(operation, "color", "#c0c4cc") this.$set(operation, "color", "#c0c4cc")
} }
// //
if (state === 'running') { if (state === 'RUNNING') {
this.$set(operation, "icon", "el-icon-loading") this.$set(operation, "icon", "el-icon-loading")
this.$set(operation, "color", "#f78f5f") this.$set(operation, "color", "#f78f5f")
this.$set(operation, "remark", operation.userInfo.name + ' (处理中)') this.$set(operation, "remark", operation.userInfo.name + ' (处理中)')
} }
// //
if (type === 'cc') { if (type === 'CC') {
this.$set(operation, "icon", "el-icon-s-promotion") this.$set(operation, "icon", "el-icon-s-promotion")
this.$set(operation, "color", "#3395f8") this.$set(operation, "color", "#3395f8")
this.$set(operation, "remark", operation.userInfo.name + ' (抄送成功)') this.$set(operation, "remark", operation.userInfo.name + ' (抄送成功)')
} }
// //
if (state === 'comment') { if (state === 'COMMENT') {
this.$set(operation, "icon", "el-icon-chat-dot-round") this.$set(operation, "icon", "el-icon-chat-dot-round")
this.$set(operation, "color", "#0bbd87") this.$set(operation, "color", "#0bbd87")
this.$set(operation, "remark", operation.userInfo.name + ' (添加了评论)') this.$set(operation, "remark", operation.userInfo.name + ' (添加了评论)')
} }
// //
if (state === 'refuse' && type === 'comment') { if (state === 'REFUSE' && type === 'COMMENT') {
this.$set(operation, "icon", "el-icon-chat-dot-round") this.$set(operation, "icon", "el-icon-chat-dot-round")
this.$set(operation, "color", "#f56c6c") this.$set(operation, "color", "#f56c6c")
this.$set(operation, "remark", operation.userInfo.name + ' (填写拒绝理由)') this.$set(operation, "remark", operation.userInfo.name + ' (填写拒绝理由)')
} }
// //
if (state === 'refuse' && type === 'opinion') { if (state === 'REFUSE' && type === 'OPINION') {
this.$set(operation, "icon", "el-icon-close") this.$set(operation, "icon", "el-icon-close")
this.$set(operation, "color", "#f56c6c") this.$set(operation, "color", "#f56c6c")
this.$set(operation, "remark", operation.userInfo.name + ' (拒绝)') this.$set(operation, "remark", operation.userInfo.name + ' (拒绝)')
@ -230,5 +233,25 @@ export default {
/deep/ .el-card__body, .el-main { /deep/ .el-card__body, .el-main {
padding: 10px; padding: 10px;
} }
.avatar_name{
width: 45px;
display: flex;
flex-direction: column;
align-items: center;
position: relative;
margin-right: 5px;
}
.avatar_icon{
position: absolute;
bottom: 16px;
right: -2px;
}
.username{
width: 45px;
padding-top: 2px;
text-align: center;
text-overflow: ellipsis;
white-space: nowrap;
overflow: hidden
}
</style> </style>

View File

@ -27,7 +27,7 @@ export default {
computed:{ computed:{
selectUser(){ selectUser(){
return { return {
show: this.config.props.shouldAdd, show: this.config.props.assignedType !== 'ASSIGN_USER',
multiple: true multiple: true
}; };
}, },

View File

@ -11,8 +11,10 @@
<div class="node-body-content"> <div class="node-body-content">
<i :class="leftIcon" v-if="leftIcon"></i> <i :class="leftIcon" v-if="leftIcon"></i>
<template v-if="viewer && selectUser.show"> <template v-if="viewer && selectUser.show">
<el-button type="primary" icon="el-icon-plus" circle @click="$refs.userPicker.showUserPicker()"/> <div class="avatar_button">
<avatar-ellipsis :row="3" v-if="userInfo.length > 0" :user-info="userInfo"/> <avatar-ellipsis :row="3" v-if="userInfo.length > 0" :user-info="userInfo"/>
<el-button type="primary" icon="el-icon-plus" circle @click="$refs.userPicker.showUserPicker()"/>
</div>
</template> </template>
<template v-else-if="showAvatar"> <template v-else-if="showAvatar">
<span class="placeholder" v-if="userInfo.length === 0">{{ placeholder }}</span> <span class="placeholder" v-if="userInfo.length === 0">{{ placeholder }}</span>
@ -40,8 +42,8 @@
@insertNode="type => $emit('insertNode', type)"></insert-button> @insertNode="type => $emit('insertNode', type)"></insert-button>
</div> </div>
</div> </div>
<user-picker v-if="selectUser.show" title="请选择系统角色" :multiple="selectUser.multiple" ref="userPicker" <user-picker v-if="selectUser.show" title="请选择系统用户" :multiple="selectUser.multiple" ref="userPicker"
:v-model="userInfo" :selected="_userInfo"
@ok="selectedUser"/> @ok="selectedUser"/>
</div> </div>
</template> </template>
@ -77,7 +79,7 @@ export default {
// //
userInfo: { userInfo: {
type: Array, type: Array,
default(){ default() {
return [] return []
} }
}, },
@ -129,12 +131,20 @@ export default {
}, },
}, },
data() { data() {
return{} return {}
}, },
computed: { computed: {
viewer() { viewer() {
return this.$store.state.diagramMode === 'viewer' return this.$store.state.diagramMode === 'viewer'
}, },
_userInfo: {
get() {
return this.userInfo
},
set(val) {
this.userInfo = val
}
},
}, },
methods: { methods: {
selectedUser(select) { selectedUser(select) {
@ -147,8 +157,9 @@ export default {
} }
userInfoList.push(userInfo) userInfoList.push(userInfo)
} }
this.userInfo = userInfoList //todo ,
this.$store.state.selectUserMap.set(this.$store.state.selectedNode.id,userInfoList) this._userInfo = userInfoList
this.$store.state.selectUserMap.set(this.$store.state.selectedNode.id, userInfoList)
}, },
} }
} }
@ -229,6 +240,16 @@ export default {
color: #656363; color: #656363;
font-size: 14px; font-size: 14px;
.avatar_button {
display: flex;
button {
height: 40px;
flex-shrink: 0;
flex-grow: 0;
}
}
i { i {
position: absolute; position: absolute;
top: 55%; top: 55%;

View File

@ -120,10 +120,12 @@ export default {
// todo // todo
submitForm(){ submitForm(){
let processInstance = this.$refs.processInstance; let processInstance = this.$refs.processInstance;
let selectUserMap = {}
this.$store.state.selectUserMap.forEach(((value, key) => {selectUserMap[key]=value}))
let paramsData = { let paramsData = {
processDefinitionId: this.selectForm.processDefinitionId, processDefinitionId: this.selectForm.processDefinitionId,
formData: JSON.stringify(processInstance.formData), formData: JSON.stringify(processInstance.formData),
selectUserMap: this.$store.state.selectUserMap optionalUser: selectUserMap
} }
processInstance.validate(valid => { processInstance.validate(valid => {
if (valid) { if (valid) {