|
@@ -1,23 +1,51 @@
|
|
<template>
|
|
<template>
|
|
<div class="panel-tab__content">
|
|
<div class="panel-tab__content">
|
|
- <el-form size="mini" label-width="90px" :model="model" :rules="rules" @submit.native.prevent>
|
|
|
|
- <div v-if="elementBaseInfo.$type === 'bpmn:Process'"> <!-- 如果是 Process 信息的时候,使用自定义表单 -->
|
|
|
|
- <el-link href="https://doc.iocoder.cn/bpm/#_3-%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%A4%BA%E4%BE%8B"
|
|
|
|
- type="danger" target="_blank">如何实现实现会签、或签?</el-link>
|
|
|
|
|
|
+ <el-form
|
|
|
|
+ size="mini"
|
|
|
|
+ label-width="90px"
|
|
|
|
+ :model="model"
|
|
|
|
+ :rules="rules"
|
|
|
|
+ @submit.native.prevent
|
|
|
|
+ >
|
|
|
|
+ <div v-if="elementBaseInfo.$type === 'bpmn:Process'">
|
|
|
|
+ <!-- 如果是 Process 信息的时候,使用自定义表单 -->
|
|
|
|
+ <el-link
|
|
|
|
+ href="https://doc.iocoder.cn/bpm/#_3-%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%A4%BA%E4%BE%8B"
|
|
|
|
+ type="danger"
|
|
|
|
+ target="_blank"
|
|
|
|
+ >如何实现实现会签、或签?</el-link
|
|
|
|
+ >
|
|
<el-form-item label="流程标识" prop="key">
|
|
<el-form-item label="流程标识" prop="key">
|
|
- <el-input v-model="model.key" placeholder="请输入流标标识"
|
|
|
|
- :disabled="model.id !== undefined && model.id.length > 0" @change="handleKeyUpdate" />
|
|
|
|
|
|
+ <el-input
|
|
|
|
+ v-model="model.key"
|
|
|
|
+ placeholder="请输入流标标识"
|
|
|
|
+ :disabled="model.id !== undefined && model.id.length > 0"
|
|
|
|
+ @change="handleKeyUpdate"
|
|
|
|
+ />
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item label="流程名称" prop="name">
|
|
<el-form-item label="流程名称" prop="name">
|
|
- <el-input v-model="model.name" placeholder="请输入流程名称" clearable @change="handleNameUpdate" />
|
|
|
|
|
|
+ <el-input
|
|
|
|
+ v-model="model.name"
|
|
|
|
+ placeholder="请输入流程名称"
|
|
|
|
+ clearable
|
|
|
|
+ @change="handleNameUpdate"
|
|
|
|
+ />
|
|
</el-form-item>
|
|
</el-form-item>
|
|
</div>
|
|
</div>
|
|
<div v-else>
|
|
<div v-else>
|
|
<el-form-item label="ID">
|
|
<el-form-item label="ID">
|
|
- <el-input v-model="elementBaseInfo.id" clearable @change="updateBaseInfo('id')"/>
|
|
|
|
|
|
+ <el-input
|
|
|
|
+ v-model="elementBaseInfo.id"
|
|
|
|
+ clearable
|
|
|
|
+ @change="updateBaseInfo('id')"
|
|
|
|
+ />
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item label="名称">
|
|
<el-form-item label="名称">
|
|
- <el-input v-model="elementBaseInfo.name" clearable @change="updateBaseInfo('name')" />
|
|
|
|
|
|
+ <el-input
|
|
|
|
+ v-model="elementBaseInfo.name"
|
|
|
|
+ clearable
|
|
|
|
+ @change="updateBaseInfo('name')"
|
|
|
|
+ />
|
|
</el-form-item>
|
|
</el-form-item>
|
|
</div>
|
|
</div>
|
|
</el-form>
|
|
</el-form>
|
|
@@ -31,7 +59,7 @@ export default {
|
|
businessObject: Object,
|
|
businessObject: Object,
|
|
model: Object, // 流程模型的数据
|
|
model: Object, // 流程模型的数据
|
|
},
|
|
},
|
|
- data() {
|
|
|
|
|
|
+ data () {
|
|
return {
|
|
return {
|
|
elementBaseInfo: {},
|
|
elementBaseInfo: {},
|
|
// 流程表单的下拉框的数据
|
|
// 流程表单的下拉框的数据
|
|
@@ -41,14 +69,14 @@ export default {
|
|
key: [{ required: true, message: "流程标识不能为空", trigger: "blur" }],
|
|
key: [{ required: true, message: "流程标识不能为空", trigger: "blur" }],
|
|
name: [{ required: true, message: "流程名称不能为空", trigger: "blur" }],
|
|
name: [{ required: true, message: "流程名称不能为空", trigger: "blur" }],
|
|
},
|
|
},
|
|
- };
|
|
|
|
|
|
+ }
|
|
},
|
|
},
|
|
watch: {
|
|
watch: {
|
|
businessObject: {
|
|
businessObject: {
|
|
immediate: false,
|
|
immediate: false,
|
|
- handler: function(val) {
|
|
|
|
|
|
+ handler: function (val) {
|
|
if (val) {
|
|
if (val) {
|
|
- this.$nextTick(() => this.resetBaseInfo());
|
|
|
|
|
|
+ this.$nextTick(() => this.resetBaseInfo())
|
|
}
|
|
}
|
|
}
|
|
}
|
|
},
|
|
},
|
|
@@ -59,7 +87,7 @@ export default {
|
|
// }
|
|
// }
|
|
// }
|
|
// }
|
|
},
|
|
},
|
|
- created() {
|
|
|
|
|
|
+ created () {
|
|
// 针对上传的 bpmn 流程图时,需要延迟 1 秒的时间,保证 key 和 name 的更新
|
|
// 针对上传的 bpmn 流程图时,需要延迟 1 秒的时间,保证 key 和 name 的更新
|
|
setTimeout(() => {
|
|
setTimeout(() => {
|
|
this.handleKeyUpdate(this.model.key)
|
|
this.handleKeyUpdate(this.model.key)
|
|
@@ -67,53 +95,53 @@ export default {
|
|
}, 1000)
|
|
}, 1000)
|
|
},
|
|
},
|
|
methods: {
|
|
methods: {
|
|
- resetBaseInfo() {
|
|
|
|
- this.bpmnElement = window?.bpmnInstances?.bpmnElement;
|
|
|
|
- this.elementBaseInfo = JSON.parse(JSON.stringify(this.bpmnElement.businessObject));
|
|
|
|
|
|
+ resetBaseInfo () {
|
|
|
|
+ this.bpmnElement = window?.bpmnInstances?.bpmnElement
|
|
|
|
+ this.elementBaseInfo = JSON.parse(JSON.stringify(this.bpmnElement.businessObject))
|
|
},
|
|
},
|
|
- handleKeyUpdate(value) {
|
|
|
|
|
|
+ handleKeyUpdate (value) {
|
|
// 校验 value 的值,只有 XML NCName 通过的情况下,才进行赋值。否则,会导致流程图报错,无法绘制的问题
|
|
// 校验 value 的值,只有 XML NCName 通过的情况下,才进行赋值。否则,会导致流程图报错,无法绘制的问题
|
|
if (!value) {
|
|
if (!value) {
|
|
- return;
|
|
|
|
|
|
+ return
|
|
}
|
|
}
|
|
if (!value.match(/[a-zA-Z_][\-_.0-9a-zA-Z$]*/)) {
|
|
if (!value.match(/[a-zA-Z_][\-_.0-9a-zA-Z$]*/)) {
|
|
- console.log('key 不满足 XML NCName 规则,所以不进行赋值');
|
|
|
|
- return;
|
|
|
|
|
|
+ console.log('key 不满足 XML NCName 规则,所以不进行赋值')
|
|
|
|
+ return
|
|
}
|
|
}
|
|
- console.log('key 满足 XML NCName 规则,所以进行赋值');
|
|
|
|
|
|
+ console.log('key 满足 XML NCName 规则,所以进行赋值')
|
|
|
|
|
|
// 在 BPMN 的 XML 中,流程标识 key,其实对应的是 id 节点
|
|
// 在 BPMN 的 XML 中,流程标识 key,其实对应的是 id 节点
|
|
- this.elementBaseInfo['id'] = value;
|
|
|
|
- this.updateBaseInfo('id');
|
|
|
|
|
|
+ this.elementBaseInfo['id'] = value
|
|
|
|
+ this.updateBaseInfo('id')
|
|
},
|
|
},
|
|
- handleNameUpdate(value) {
|
|
|
|
|
|
+ handleNameUpdate (value) {
|
|
if (!value) {
|
|
if (!value) {
|
|
return
|
|
return
|
|
}
|
|
}
|
|
- this.elementBaseInfo['name'] = value;
|
|
|
|
- this.updateBaseInfo('name');
|
|
|
|
|
|
+ this.elementBaseInfo['name'] = value
|
|
|
|
+ this.updateBaseInfo('name')
|
|
},
|
|
},
|
|
- handleDescriptionUpdate(value) {
|
|
|
|
|
|
+ handleDescriptionUpdate (value) {
|
|
// TODO 芋艿:documentation 暂时无法修改,后续在看看
|
|
// TODO 芋艿:documentation 暂时无法修改,后续在看看
|
|
// this.elementBaseInfo['documentation'] = value;
|
|
// this.elementBaseInfo['documentation'] = value;
|
|
// this.updateBaseInfo('documentation');
|
|
// this.updateBaseInfo('documentation');
|
|
},
|
|
},
|
|
- updateBaseInfo(key) {
|
|
|
|
|
|
+ updateBaseInfo (key) {
|
|
// 触发 elementBaseInfo 对应的字段
|
|
// 触发 elementBaseInfo 对应的字段
|
|
- const attrObj = Object.create(null);
|
|
|
|
- attrObj[key] = this.elementBaseInfo[key];
|
|
|
|
|
|
+ const attrObj = Object.create(null)
|
|
|
|
+ attrObj[key] = this.elementBaseInfo[key]
|
|
if (key === "id") {
|
|
if (key === "id") {
|
|
window.bpmnInstances.modeling.updateProperties(this.bpmnElement, {
|
|
window.bpmnInstances.modeling.updateProperties(this.bpmnElement, {
|
|
id: this.elementBaseInfo[key],
|
|
id: this.elementBaseInfo[key],
|
|
di: { id: `${this.elementBaseInfo[key]}_di` }
|
|
di: { id: `${this.elementBaseInfo[key]}_di` }
|
|
- });
|
|
|
|
|
|
+ })
|
|
} else {
|
|
} else {
|
|
- window.bpmnInstances.modeling.updateProperties(this.bpmnElement, attrObj);
|
|
|
|
|
|
+ window.bpmnInstances.modeling.updateProperties(this.bpmnElement, attrObj)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
},
|
|
},
|
|
- beforeDestroy() {
|
|
|
|
- this.bpmnElement = null;
|
|
|
|
|
|
+ beforeDestroy () {
|
|
|
|
+ this.bpmnElement = null
|
|
}
|
|
}
|
|
};
|
|
};
|
|
</script>
|
|
</script>
|