* fix -- 修改获取流程节点信息接口(供前端渲染流程跟踪图着色使用) * fix -- 修复流程跟踪着色问题 * fix -- 采用ProcessViewer组件显示流程跟踪信息 * fix -- 整合表单设计代码 * fix -- 简易实现用户任务选择用户下拉框内容 * fix -- 修改项目介绍及sql文件 * del -- 移除未使用的文件 * fix -- 修复组件无法显示和修改的问题 * add -- 整合 Rtony/RuoYi-flowable 工作流 * add -- 添加process-designer流程设计插件 * !3 同步ruoyi-vue-plus更新 * !2 登录认证用户信息添加nickName字段(流程任务需要使用到)
95 lines
3.2 KiB
Vue
95 lines
3.2 KiB
Vue
<template>
|
|
<div style="margin-top: 16px">
|
|
<el-form-item label="处理用户">
|
|
<el-select v-model="userTaskForm.assignee" @change="updateElementTask('assignee')">
|
|
<el-option v-for="userItem in userMockDate" :key="'ass-' + userItem.userId" :label="userItem.nickName" :value="userItem.userId.toString()" />
|
|
</el-select>
|
|
</el-form-item>
|
|
<!-- <el-form-item label="候选用户">-->
|
|
<!-- <el-select v-model="userTaskForm.candidateUsers" multiple collapse-tags @change="updateElementTask('candidateUsers')">-->
|
|
<!-- <el-option v-for="uk in mockData" :key="'user-' + uk" :label="`用户${uk}`" :value="`user${uk}`" />-->
|
|
<!-- </el-select>-->
|
|
<!-- </el-form-item>-->
|
|
<!-- <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>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import { listUser } from "@/api/system/user";
|
|
|
|
export default {
|
|
name: "UserTask",
|
|
props: {
|
|
id: String,
|
|
type: String
|
|
},
|
|
data() {
|
|
return {
|
|
defaultTaskForm: {
|
|
assignee: "",
|
|
candidateUsers: [],
|
|
candidateGroups: [],
|
|
dueDate: "",
|
|
followUpDate: "",
|
|
priority: ""
|
|
},
|
|
userTaskForm: {},
|
|
userMockDate: [],
|
|
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());
|
|
}
|
|
}
|
|
},
|
|
created() {
|
|
listUser().then(response => {
|
|
this.userMockDate = response.rows;
|
|
})
|
|
},
|
|
methods: {
|
|
resetTaskForm() {
|
|
for (let key in this.defaultTaskForm) {
|
|
let value;
|
|
if (key === "candidateUsers" || key === "candidateGroups") {
|
|
value = this.bpmnElement?.businessObject[key] ? this.bpmnElement.businessObject[key].split(",") : [];
|
|
} else {
|
|
value = this.bpmnElement?.businessObject[key] || this.defaultTaskForm[key];
|
|
}
|
|
this.$set(this.userTaskForm, key, value);
|
|
}
|
|
},
|
|
updateElementTask(key) {
|
|
const taskAttr = Object.create(null);
|
|
if (key === "candidateUsers" || key === "candidateGroups") {
|
|
taskAttr[key] = this.userTaskForm[key] && this.userTaskForm[key].length ? this.userTaskForm[key].join() : null;
|
|
} else {
|
|
taskAttr[key] = this.userTaskForm[key] || null;
|
|
}
|
|
window.bpmnInstances.modeling.updateProperties(this.bpmnElement, taskAttr);
|
|
}
|
|
},
|
|
beforeDestroy() {
|
|
this.bpmnElement = null;
|
|
}
|
|
};
|
|
</script>
|