2022-01-08 15:42:53 +00:00
|
|
|
<template>
|
|
|
|
|
<div style="margin-top: 16px">
|
2022-01-18 13:16:15 +00:00
|
|
|
<el-form-item label="候选类型">
|
2022-01-28 15:04:25 +08:00
|
|
|
<el-select v-model="formData.groupType" placeholder="请选择分组类型" @change="onGroupTypeChange">
|
2022-01-18 13:16:15 +00:00
|
|
|
<el-option label="固定用户" value="ASSIGNEE" />
|
2022-01-28 15:04:25 +08:00
|
|
|
<el-option label="候选用户" value="USERS" />
|
2022-01-18 13:16:15 +00:00
|
|
|
<!-- <el-option label="候选组" value="ROLE" />-->
|
2022-01-08 15:42:53 +00:00
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
2022-01-18 13:16:15 +00:00
|
|
|
<el-form-item label="指定方式" v-if="formData.groupType === 'ASSIGNEE'">
|
2022-02-12 14:51:22 +08:00
|
|
|
<el-radio-group v-model="formData.assignType" @change="onAssignTypeChange">
|
2022-03-20 01:25:55 +08:00
|
|
|
<el-radio :label="'fixed' || '1'">固定</el-radio>
|
|
|
|
|
<el-radio :label="'dynamic' || '2'">动态</el-radio>
|
2022-02-12 14:51:22 +08:00
|
|
|
</el-radio-group>
|
2022-01-18 13:16:15 +00:00
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="处理用户" v-if="formData.groupType === 'ASSIGNEE'">
|
2022-03-20 01:25:55 +08:00
|
|
|
<tag-select v-if="formData.assignType === ('fixed' || '1')" v-model="userTaskForm.assignee">
|
2022-01-18 13:16:15 +00:00
|
|
|
<el-button slot="append" class="append-add" type="default" icon="el-icon-plus" @click="onSelectAssignee()" />
|
|
|
|
|
</tag-select>
|
2022-03-20 01:25:55 +08:00
|
|
|
<el-select v-if="formData.assignType === ('dynamic' || '2')" v-model="userTaskForm.assignee" collapse-tags @change="updateElementTask('assignee')">
|
|
|
|
|
<el-option v-for="item in variableData" :key="item.value" :label="item.label" :value="item">
|
2022-01-18 13:16:15 +00:00
|
|
|
<span style="float: left">{{ item.label }}</span>
|
|
|
|
|
<span style="float: right; color: #8492a6;">{{ item.value }}</span>
|
|
|
|
|
</el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="候选用户" v-if="formData.groupType === 'USERS'">
|
|
|
|
|
<tag-select v-model="userTaskForm.candidateUsers">
|
|
|
|
|
<el-button slot="append" class="append-add" type="default" icon="el-icon-plus" @click="onSelectAssignee()" />
|
|
|
|
|
</tag-select>
|
|
|
|
|
</el-form-item>
|
2022-01-08 15:42:53 +00:00
|
|
|
<!-- <el-form-item label="候选分组">-->
|
|
|
|
|
<!-- <el-select v-model="userTaskForm.candidateGroups" multiple collapse-tags @change="updateElementTask('candidateGroups')">-->
|
|
|
|
|
<!-- <el-option v-for="gk in mockData" :key="'ass-' + gk" :label="`分组${gk}`" :value="`group${gk}`" />-->
|
|
|
|
|
<!-- </el-select>-->
|
|
|
|
|
<!-- </el-form-item>-->
|
|
|
|
|
<el-form-item label="到期时间">
|
|
|
|
|
<el-input v-model="userTaskForm.dueDate" clearable @change="updateElementTask('dueDate')" />
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="跟踪时间">
|
|
|
|
|
<el-input v-model="userTaskForm.followUpDate" clearable @change="updateElementTask('followUpDate')" />
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="优先级">
|
|
|
|
|
<el-input v-model="userTaskForm.priority" clearable @change="updateElementTask('priority')" />
|
|
|
|
|
</el-form-item>
|
2022-01-18 13:16:15 +00:00
|
|
|
|
|
|
|
|
<!-- 候选用户弹窗 -->
|
|
|
|
|
<el-dialog title="候选用户" :visible.sync="candidateVisible" width="60%" append-to-body>
|
|
|
|
|
<el-row type="flex" :gutter="20">
|
|
|
|
|
<!--部门数据-->
|
|
|
|
|
<el-col :span="5">
|
|
|
|
|
<el-card shadow="never" style="height: 100%">
|
|
|
|
|
<div slot="header">
|
|
|
|
|
<span>部门列表</span>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="head-container">
|
|
|
|
|
<el-input
|
|
|
|
|
v-model="deptName"
|
|
|
|
|
placeholder="请输入部门名称"
|
|
|
|
|
clearable
|
|
|
|
|
size="small"
|
|
|
|
|
prefix-icon="el-icon-search"
|
|
|
|
|
style="margin-bottom: 20px"
|
|
|
|
|
/>
|
|
|
|
|
<el-tree
|
|
|
|
|
:data="deptOptions"
|
|
|
|
|
:props="deptProps"
|
|
|
|
|
:expand-on-click-node="false"
|
|
|
|
|
:filter-node-method="filterNode"
|
|
|
|
|
ref="tree"
|
|
|
|
|
default-expand-all
|
|
|
|
|
@node-click="handleNodeClick"
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
</el-card>
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="14">
|
2022-02-12 14:51:22 +08:00
|
|
|
<el-table ref="multipleTable" height="600" :data="userList" border @selection-change="handleSelectionChange">
|
|
|
|
|
<el-table-column type="selection" width="50" align="center" :selectable="selectEnable" />
|
2022-01-18 13:16:15 +00:00
|
|
|
<el-table-column label="用户名" align="center" prop="nickName" />
|
|
|
|
|
<el-table-column label="部门" align="center" prop="dept.deptName" />
|
|
|
|
|
</el-table>
|
|
|
|
|
<pagination
|
|
|
|
|
:total="total"
|
|
|
|
|
:page.sync="queryParams.pageNum"
|
|
|
|
|
:limit.sync="queryParams.pageSize"
|
|
|
|
|
@pagination="getList"
|
|
|
|
|
/>
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="5">
|
|
|
|
|
<el-card shadow="never" style="height: 100%">
|
|
|
|
|
<div slot="header">
|
|
|
|
|
<span>已选人员</span>
|
|
|
|
|
</div>
|
|
|
|
|
<el-tag
|
|
|
|
|
v-for="tag in selectedUserDate"
|
|
|
|
|
:key="tag.nickName"
|
|
|
|
|
closable
|
|
|
|
|
@close="handleClose(tag)">
|
|
|
|
|
{{tag.nickName}} {{tag.dept.deptName}}
|
|
|
|
|
</el-tag>
|
|
|
|
|
</el-card>
|
|
|
|
|
</el-col>
|
|
|
|
|
</el-row>
|
|
|
|
|
<div slot="footer" class="dialog-footer">
|
|
|
|
|
<el-button type="primary" @click="handleTaskComplete">确 定</el-button>
|
|
|
|
|
<!-- <el-input style="width: 50%;margin-right: 34%" type="textarea" v-model="taskForm.comment"-->
|
|
|
|
|
<!-- placeholder="请输入处理意见"-->
|
|
|
|
|
<!-- />-->
|
|
|
|
|
<!-- <el-button @click="completeOpen = false">取 消</el-button>-->
|
2022-04-06 17:28:58 +00:00
|
|
|
</div>
|
2022-01-18 13:16:15 +00:00
|
|
|
</el-dialog>
|
2022-01-08 15:42:53 +00:00
|
|
|
</div>
|
2022-01-18 13:16:15 +00:00
|
|
|
|
2022-01-08 15:42:53 +00:00
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
2022-01-18 13:16:15 +00:00
|
|
|
import { listUser, getUser } from "@/api/system/user";
|
|
|
|
|
import { treeselect } from '@/api/system/dept'
|
|
|
|
|
import TagSelect from "./TagSelect";
|
2022-01-08 15:42:53 +00:00
|
|
|
|
|
|
|
|
export default {
|
|
|
|
|
name: "UserTask",
|
|
|
|
|
props: {
|
|
|
|
|
id: String,
|
|
|
|
|
type: String
|
|
|
|
|
},
|
2022-01-18 13:16:15 +00:00
|
|
|
components: {
|
|
|
|
|
TagSelect
|
|
|
|
|
},
|
2022-01-08 15:42:53 +00:00
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
defaultTaskForm: {
|
|
|
|
|
assignee: "",
|
|
|
|
|
candidateUsers: [],
|
|
|
|
|
candidateGroups: [],
|
|
|
|
|
dueDate: "",
|
|
|
|
|
followUpDate: "",
|
|
|
|
|
priority: ""
|
|
|
|
|
},
|
2022-01-18 13:16:15 +00:00
|
|
|
formData: {
|
|
|
|
|
groupType: 'ASSIGNEE',
|
2022-03-20 01:25:55 +08:00
|
|
|
assignType: 'fixed'
|
2022-01-18 13:16:15 +00:00
|
|
|
},
|
2022-01-08 15:42:53 +00:00
|
|
|
userTaskForm: {},
|
2022-01-18 13:16:15 +00:00
|
|
|
candidateVisible: false,
|
|
|
|
|
deptName: undefined,
|
|
|
|
|
deptOptions: [],
|
|
|
|
|
deptProps: {
|
|
|
|
|
children: "children",
|
|
|
|
|
label: "label"
|
|
|
|
|
},
|
|
|
|
|
// 查询参数
|
|
|
|
|
queryParams: {
|
|
|
|
|
deptId: undefined
|
|
|
|
|
},
|
|
|
|
|
userList: [],
|
|
|
|
|
total: 0,
|
|
|
|
|
selectedUserDate: [],
|
|
|
|
|
variableData: [{
|
|
|
|
|
label: "流程发起人",
|
|
|
|
|
value: "${INITIATOR}"
|
|
|
|
|
}],
|
2022-01-08 15:42:53 +00:00
|
|
|
mockData: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
watch: {
|
|
|
|
|
id: {
|
|
|
|
|
immediate: true,
|
|
|
|
|
handler() {
|
|
|
|
|
this.bpmnElement = window.bpmnInstances.bpmnElement;
|
|
|
|
|
this.$nextTick(() => this.resetTaskForm());
|
|
|
|
|
}
|
2022-01-18 13:16:15 +00:00
|
|
|
},
|
2022-01-28 15:04:25 +08:00
|
|
|
// 'userTaskForm.assignee': {
|
|
|
|
|
// handler () {
|
|
|
|
|
// this.updateElementTask('assignee');
|
|
|
|
|
// }
|
|
|
|
|
// },
|
|
|
|
|
// 'userTaskForm.candidateUsers': {
|
|
|
|
|
// handler () {
|
|
|
|
|
// this.updateElementTask('candidateUsers');
|
|
|
|
|
// }
|
|
|
|
|
// },
|
2022-01-08 15:42:53 +00:00
|
|
|
},
|
|
|
|
|
created() {
|
|
|
|
|
listUser().then(response => {
|
2022-03-20 01:25:55 +08:00
|
|
|
this.userList = response.rows;
|
2022-01-08 15:42:53 +00:00
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
resetTaskForm() {
|
|
|
|
|
for (let key in this.defaultTaskForm) {
|
2022-01-28 15:04:25 +08:00
|
|
|
if (key === "candidateUsers") {
|
|
|
|
|
const val = this.bpmnElement?.businessObject[key] ? this.bpmnElement.businessObject[key].split(",") : [];
|
|
|
|
|
if (val && val.length > 0) {
|
|
|
|
|
this.formData.groupType = 'USERS';
|
|
|
|
|
let users = [];
|
|
|
|
|
// TODO 2022/01/28 优化用户信息获取方式
|
|
|
|
|
val.forEach(k => {
|
|
|
|
|
getUser(k).then(response => {
|
|
|
|
|
let user = response.data.user
|
|
|
|
|
users.push(user)
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
this.$set(this.userTaskForm, key, users);
|
|
|
|
|
}
|
|
|
|
|
} else if (key === "candidateGroups") {
|
|
|
|
|
// TODO 2022/01/28 添加候选组的设值 this.$set(this.userTaskForm, key, value);
|
2022-01-18 13:16:15 +00:00
|
|
|
} else if (key === "assignee") {
|
2022-02-12 14:51:22 +08:00
|
|
|
this.formData.groupType = 'ASSIGNEE';
|
2022-01-18 13:16:15 +00:00
|
|
|
let val = this.bpmnElement?.businessObject[key] || this.defaultTaskForm[key];
|
2022-03-20 01:25:55 +08:00
|
|
|
// TODO 2022/03/20 根据type判断是否为动态用户
|
2022-01-18 13:16:15 +00:00
|
|
|
// 判断是否为动态用户
|
|
|
|
|
if (val && val.startsWith('${') && val.endsWith('}')) {
|
2022-03-20 01:25:55 +08:00
|
|
|
this.formData.assignType = 'dynamic';
|
2022-01-18 13:16:15 +00:00
|
|
|
this.$set(this.userTaskForm, key, val);
|
|
|
|
|
} else {
|
2022-03-20 01:25:55 +08:00
|
|
|
this.formData.assignType = 'fixed';
|
2022-01-18 13:16:15 +00:00
|
|
|
getUser(val).then(response => {
|
|
|
|
|
let user = response.data.user
|
|
|
|
|
this.$set(this.userTaskForm, key, user);
|
|
|
|
|
})
|
|
|
|
|
}
|
2022-01-08 15:42:53 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
updateElementTask(key) {
|
|
|
|
|
const taskAttr = Object.create(null);
|
2022-03-21 23:20:37 +08:00
|
|
|
taskAttr['flowable:assignType'] = this.formData.assignType;
|
2022-04-06 17:28:58 +00:00
|
|
|
// 修复切换候选类型XML仍保留assignee的问题
|
|
|
|
|
if ((key === 'candidateUsers' || key === 'assignee') && !this.userTaskForm[key]) {
|
|
|
|
|
taskAttr[key] = null
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-08 15:42:53 +00:00
|
|
|
if (key === "candidateUsers" || key === "candidateGroups") {
|
2022-01-18 13:16:15 +00:00
|
|
|
if (this.userTaskForm[key] && this.userTaskForm[key].length > 0) {
|
2022-01-28 15:04:25 +08:00
|
|
|
taskAttr[key] = this.userTaskForm[key].map(k => k.userId) || null
|
2022-01-18 13:16:15 +00:00
|
|
|
}
|
2022-01-28 15:04:25 +08:00
|
|
|
// TODO 2022/01/10 添加候选组的设值
|
2022-01-18 13:16:15 +00:00
|
|
|
// taskAttr[key] = this.userTaskForm[key] && this.userTaskForm[key].length ? this.userTaskForm[key].join() : null;
|
2022-01-08 15:42:53 +00:00
|
|
|
} else {
|
2022-01-18 13:16:15 +00:00
|
|
|
if (this.userTaskForm[key]) {
|
2022-03-20 01:25:55 +08:00
|
|
|
if (this.formData.assignType === ('fixed' || '1')) {
|
2022-03-21 23:20:37 +08:00
|
|
|
taskAttr['flowable:text'] = this.userTaskForm[key].nickName
|
2022-01-18 13:16:15 +00:00
|
|
|
taskAttr[key] = this.userTaskForm[key].userId || null;
|
2022-03-20 01:25:55 +08:00
|
|
|
} else if (this.formData.assignType === ('dynamic' || '2')) {
|
2022-03-21 23:20:37 +08:00
|
|
|
taskAttr['flowable:text'] = this.userTaskForm[key].label
|
2022-03-20 01:25:55 +08:00
|
|
|
taskAttr[key] = this.userTaskForm[key].value || null;
|
2022-01-18 13:16:15 +00:00
|
|
|
}
|
|
|
|
|
}
|
2022-01-08 15:42:53 +00:00
|
|
|
}
|
|
|
|
|
window.bpmnInstances.modeling.updateProperties(this.bpmnElement, taskAttr);
|
2022-01-18 13:16:15 +00:00
|
|
|
},
|
|
|
|
|
/**
|
|
|
|
|
* 查询部门下拉树结构
|
|
|
|
|
*/
|
|
|
|
|
getDeptTreeSelect() {
|
|
|
|
|
treeselect().then(response => {
|
|
|
|
|
this.deptOptions = response.data;
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
/** 查询用户列表 */
|
|
|
|
|
getList() {
|
|
|
|
|
listUser(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
|
|
|
|
|
this.userList = response.rows;
|
|
|
|
|
this.total = response.total;
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
},
|
2022-02-12 14:51:22 +08:00
|
|
|
selectEnable(row, index) {
|
|
|
|
|
if (this.formData.groupType === 'ASSIGNEE') {
|
|
|
|
|
if (this.selectedUserDate.length > 0) {
|
|
|
|
|
return this.selectedUserDate[0].userId === row.userId;
|
|
|
|
|
} else {
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
},
|
2022-01-18 13:16:15 +00:00
|
|
|
// 筛选节点
|
|
|
|
|
filterNode(value, data) {
|
|
|
|
|
if (!value) return true;
|
|
|
|
|
return data.label.indexOf(value) !== -1;
|
|
|
|
|
},
|
|
|
|
|
// 节点单击事件
|
|
|
|
|
handleNodeClick(data) {
|
|
|
|
|
this.queryParams.deptId = data.id;
|
|
|
|
|
this.getList();
|
|
|
|
|
},
|
|
|
|
|
// 关闭标签
|
|
|
|
|
handleClose(tag) {
|
|
|
|
|
this.selectedUserDate.splice(this.selectedUserDate.indexOf(tag), 1);
|
2022-02-12 14:51:22 +08:00
|
|
|
this.$refs.multipleTable.toggleRowSelection(tag);
|
2022-01-18 13:16:15 +00:00
|
|
|
},
|
|
|
|
|
// 多选框选中数据
|
|
|
|
|
handleSelectionChange(selection) {
|
|
|
|
|
this.selectedUserDate = selection;
|
|
|
|
|
},
|
|
|
|
|
handleTaskComplete() {
|
|
|
|
|
if (!this.selectedUserDate) {
|
|
|
|
|
this.userTaskForm.assignee = null;
|
|
|
|
|
this.userTaskForm.candidateUsers = null;
|
|
|
|
|
} else {
|
|
|
|
|
let val = null;
|
|
|
|
|
if (this.formData.groupType === 'ASSIGNEE') {
|
|
|
|
|
val = this.selectedUserDate[0];
|
|
|
|
|
this.userTaskForm.assignee = val;
|
|
|
|
|
} else {
|
|
|
|
|
val = this.selectedUserDate;
|
|
|
|
|
this.userTaskForm.candidateUsers = val;
|
|
|
|
|
}
|
2022-04-06 17:28:58 +00:00
|
|
|
this.updateElementTask('assignee')
|
|
|
|
|
this.updateElementTask('candidateUsers')
|
2022-01-18 13:16:15 +00:00
|
|
|
}
|
|
|
|
|
this.candidateVisible = false;
|
|
|
|
|
},
|
2022-01-28 15:04:25 +08:00
|
|
|
onGroupTypeChange(val) {
|
|
|
|
|
this.userTaskForm = {}
|
2022-02-12 14:51:22 +08:00
|
|
|
// 清空已选候选人数据
|
2022-01-28 15:04:25 +08:00
|
|
|
if (val === 'ASSIGNEE') {
|
2022-03-20 01:25:55 +08:00
|
|
|
this.formData.assignType = 'fixed'
|
2022-01-28 15:04:25 +08:00
|
|
|
}
|
2022-02-12 14:51:22 +08:00
|
|
|
this.selectedUserDate = []
|
|
|
|
|
this.$refs.multipleTable?.clearSelection();
|
|
|
|
|
},
|
|
|
|
|
onAssignTypeChange() {
|
|
|
|
|
this.userTaskForm.assignee = null
|
2022-01-28 15:04:25 +08:00
|
|
|
},
|
2022-01-18 13:16:15 +00:00
|
|
|
onSelectAssignee() {
|
2022-03-20 01:25:55 +08:00
|
|
|
this.selectedUserDate = []
|
|
|
|
|
this.$refs.multipleTable?.clearSelection();
|
2022-01-28 15:04:25 +08:00
|
|
|
this.getDeptTreeSelect();
|
2022-01-18 13:16:15 +00:00
|
|
|
this.candidateVisible = true;
|
2022-01-08 15:42:53 +00:00
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
beforeDestroy() {
|
|
|
|
|
this.bpmnElement = null;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
</script>
|
2022-01-18 13:16:15 +00:00
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
</style>
|