|
@@ -14,18 +14,23 @@
|
|
|
<el-input v-model="form.code" placeholder="请输入模板编码" clearable></el-input>
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
- <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="8">
|
|
|
- <el-form-item label="模板类型" prop="flowType" :rules="[{ required: true, message: '请选择模板类型', trigger: 'change' }]">
|
|
|
- <el-select v-model="form.flowType" class="w100" placeholder="请选择模板类型">
|
|
|
- <el-option v-for="item in baseDataResult.flowTypeOptions" :key="item.key" :label="item.value" :value="item.key" />
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="8">
|
|
|
- <el-form-item label="模板描述" prop="description" :rules="[{ required: false, message: '请输入模板描述', trigger: 'blur' }]">
|
|
|
- <el-input v-model="form.description" placeholder="请输入模板描述" clearable></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
+ <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="8">
|
|
|
+ <el-form-item label="模板类型" prop="flowType" :rules="[{ required: true, message: '请选择模板类型', trigger: 'change' }]">
|
|
|
+ <el-select v-model="form.flowType" class="w100" placeholder="请选择模板类型">
|
|
|
+ <el-option v-for="item in baseDataResult.flowTypeOptions" :key="item.key" :label="item.value" :value="item.key" />
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="8">
|
|
|
+ <el-form-item label="展示主办" prop="isMainHandlerShow" :rules="[{ required: false, message: '请选择模板类型', trigger: 'change' }]">
|
|
|
+ <el-switch v-model="form.isMainHandlerShow" inline-prompt active-text="展示" inactive-text="隐藏" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="8">
|
|
|
+ <el-form-item label="模板描述" prop="description" :rules="[{ required: false, message: '请输入模板描述', trigger: 'blur' }]">
|
|
|
+ <el-input v-model="form.description" placeholder="请输入模板描述" clearable></el-input>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
</el-row>
|
|
|
</el-form>
|
|
|
<!-- 流程图画布内容 -->
|
|
@@ -33,33 +38,39 @@
|
|
|
<div class="w100 h100" ref="lfElRef" style="height: 100%"></div>
|
|
|
</div>
|
|
|
<!-- 节点内容弹窗 -->
|
|
|
- <PropertySetting ref="propertySettingRef" v-model="formData" @change="handlePropertyChange" @changeOther="handlePropertyChangeOther" :baseData="baseDataResult"/>
|
|
|
+ <PropertySetting
|
|
|
+ ref="propertySettingRef"
|
|
|
+ v-model="formData"
|
|
|
+ @change="handlePropertyChange"
|
|
|
+ @changeOther="handlePropertyChangeOther"
|
|
|
+ :baseData="baseDataResult"
|
|
|
+ />
|
|
|
</div>
|
|
|
</div>
|
|
|
</template>
|
|
|
<script setup lang="ts" name="hotlineFlowDesigner">
|
|
|
-import {defineAsyncComponent, nextTick, onMounted, reactive, Ref, ref, unref, watch} from 'vue';
|
|
|
-import {useRoute, useRouter} from 'vue-router';
|
|
|
+import { defineAsyncComponent, nextTick, onMounted, reactive, Ref, ref, unref, watch } from 'vue';
|
|
|
+import { useRoute, useRouter } from 'vue-router';
|
|
|
import LogicFlow from '@logicflow/core';
|
|
|
-import {Control, DndPanel, Group, InsertNodeInPolyline, Menu, MiniMap, SelectionSelect, Snapshot} from '@logicflow/extension';
|
|
|
+import { Control, DndPanel, Group, InsertNodeInPolyline, Menu, MiniMap, SelectionSelect, Snapshot } from '@logicflow/extension';
|
|
|
import '@logicflow/core/dist/style/index.css';
|
|
|
import '@logicflow/extension/lib/style/index.css';
|
|
|
-import {SnakerFlowAdapter, SnakerFlowElement} from './snakerflow/index';
|
|
|
-import {NodeTypeEnum} from './enums';
|
|
|
-import {baseData, workflowAdd, workflowUpdate} from '@/api/system/workflow';
|
|
|
+import { SnakerFlowAdapter, SnakerFlowElement } from './snakerflow/index';
|
|
|
+import { NodeTypeEnum } from './enums';
|
|
|
+import { baseData, workflowAdd, workflowUpdate } from '@/api/system/workflow';
|
|
|
import mittBus from '@/utils/mitt';
|
|
|
-import {throttle} from '@/utils/tools';
|
|
|
-import {ElMessage, FormInstance} from 'element-plus';
|
|
|
+import { throttle } from '@/utils/tools';
|
|
|
+import { ElMessage, FormInstance } from 'element-plus';
|
|
|
// 引入组件
|
|
|
-const PropertySetting = defineAsyncComponent(() => import('./PropertySetting/index.vue')); // 节点属性设置
|
|
|
+const PropertySetting = defineAsyncComponent(() => import('./PropertySetting/index.vue')); // 节点属性设置
|
|
|
|
|
|
const route = useRoute(); // 当前路由信息
|
|
|
const router = useRouter(); // 路由实例
|
|
|
-const emits = defineEmits(['update:modelValue', 'on-save']); // 定义组件事件
|
|
|
+const emits = defineEmits(['update:modelValue', 'on-save']); // 定义组件事件
|
|
|
// 提交表单数据
|
|
|
let formData = reactive({} as any);
|
|
|
// 外层表单
|
|
|
-let form = reactive<Record<string, any>>({});
|
|
|
+let form = reactive<Record<string, any>>({});
|
|
|
const ruleFormRef = ref<RefType>();
|
|
|
// 定义组件接收的参数
|
|
|
const props = defineProps({
|
|
@@ -251,17 +262,15 @@ const initOp = () => {
|
|
|
text: '开始',
|
|
|
label: '开始节点',
|
|
|
properties: {
|
|
|
- stepType: 1, // 节点类型(开始1 结束2)
|
|
|
- },
|
|
|
+ stepType: 1, // 节点类型(开始1 结束2)
|
|
|
+ },
|
|
|
icon: '',
|
|
|
},
|
|
|
{
|
|
|
type: 'hotline:task',
|
|
|
text: '流程节点',
|
|
|
label: '流程节点',
|
|
|
- properties: {
|
|
|
-
|
|
|
- },
|
|
|
+ properties: {},
|
|
|
icon: '',
|
|
|
className: 'important-node',
|
|
|
},
|
|
@@ -270,8 +279,8 @@ const initOp = () => {
|
|
|
text: '结束',
|
|
|
label: '结束节点',
|
|
|
properties: {
|
|
|
- stepType: 2, // 节点类型(开始1 结束2)
|
|
|
- },
|
|
|
+ stepType: 2, // 节点类型(开始1 结束2)
|
|
|
+ },
|
|
|
icon: '',
|
|
|
},
|
|
|
]);
|
|
@@ -300,7 +309,7 @@ const initEvent = () => {
|
|
|
// })
|
|
|
// 节点点击事件
|
|
|
eventCenter.on('node:click', (args: any) => {
|
|
|
- if (['hotline:start','hotline:task'].includes(args.data.type)) {
|
|
|
+ if (['hotline:start', 'hotline:task'].includes(args.data.type)) {
|
|
|
currentOpId.value = args.data.id;
|
|
|
propertySettingRef.value.show({
|
|
|
...args.data.properties,
|
|
@@ -324,54 +333,56 @@ const initEvent = () => {
|
|
|
// })
|
|
|
};
|
|
|
const closePage = () => {
|
|
|
- // 更新
|
|
|
- ElMessage.success('操作成功');
|
|
|
- // 关闭当前 tagsView
|
|
|
- mittBus.emit('onCurrentContextmenuClick', Object.assign({}, { contextMenuClickId: 1, ...route }));
|
|
|
- mittBus.emit('clearCache', 'systemWorkflow');
|
|
|
- if(!router.hasRoute('systemWorkflow')){
|
|
|
- ElMessage.warning('未找到流程模板列表页面');
|
|
|
- return;
|
|
|
- }
|
|
|
- router.push({
|
|
|
- name: 'systemWorkflow',
|
|
|
- state:{
|
|
|
- index:'1'
|
|
|
- }
|
|
|
- });
|
|
|
+ // 更新
|
|
|
+ ElMessage.success('操作成功');
|
|
|
+ // 关闭当前 tagsView
|
|
|
+ mittBus.emit('onCurrentContextmenuClick', Object.assign({}, { contextMenuClickId: 1, ...route }));
|
|
|
+ mittBus.emit('clearCache', 'systemWorkflow');
|
|
|
+ if (!router.hasRoute('systemWorkflow')) {
|
|
|
+ ElMessage.warning('未找到流程模板列表页面');
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ router.push({
|
|
|
+ name: 'systemWorkflow',
|
|
|
+ state: {
|
|
|
+ index: '1',
|
|
|
+ },
|
|
|
+ });
|
|
|
};
|
|
|
// 暂存(保存为草稿)
|
|
|
const saveOnly = throttle((formEl: FormInstance | undefined) => {
|
|
|
const lf = unref(lfInstance);
|
|
|
if (!lf) return;
|
|
|
- if(!formEl) return;
|
|
|
- // 表单验证
|
|
|
- formEl.validate((valid: boolean)=>{
|
|
|
- if(!valid) return;
|
|
|
- // 流程模板属性 最外层
|
|
|
- Object.keys(form).forEach((key: string) => {
|
|
|
- // 监听属性变化 并保存
|
|
|
- lf.graphModel[key] = form[key];
|
|
|
- });
|
|
|
- const { submitData } = getGraphData();
|
|
|
+ if (!formEl) return;
|
|
|
+ // 表单验证
|
|
|
+ formEl.validate((valid: boolean) => {
|
|
|
+ if (!valid) return;
|
|
|
+ // 流程模板属性 最外层
|
|
|
+ Object.keys(form).forEach((key: string) => {
|
|
|
+ // 监听属性变化 并保存
|
|
|
+ lf.graphModel[key] = form[key];
|
|
|
+ });
|
|
|
+ const { submitData } = getGraphData();
|
|
|
|
|
|
- if (submitData.error) {
|
|
|
- //错误提示
|
|
|
- ElMessage.warning(submitData.error);
|
|
|
- return;
|
|
|
- }
|
|
|
- if (route.params.id) {
|
|
|
- workflowUpdate(submitData).then(() => { //更新
|
|
|
- closePage();
|
|
|
- });
|
|
|
- } else {
|
|
|
- workflowAdd(submitData).then(() => {//保存
|
|
|
- closePage()
|
|
|
- });
|
|
|
- }
|
|
|
+ if (submitData.error) {
|
|
|
+ //错误提示
|
|
|
+ ElMessage.warning(submitData.error);
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ if (route.params.id) {
|
|
|
+ workflowUpdate(submitData).then(() => {
|
|
|
+ //更新
|
|
|
+ closePage();
|
|
|
+ });
|
|
|
+ } else {
|
|
|
+ workflowAdd(submitData).then(() => {
|
|
|
+ //保存
|
|
|
+ closePage();
|
|
|
+ });
|
|
|
+ }
|
|
|
|
|
|
- emits('on-save', getGraphData());
|
|
|
- })
|
|
|
+ emits('on-save', getGraphData());
|
|
|
+ });
|
|
|
}, 300);
|
|
|
// 重新渲染
|
|
|
const reRender = (data: any): void => {
|
|
@@ -383,8 +394,9 @@ const reRender = (data: any): void => {
|
|
|
// 最外层扩展属性赋值
|
|
|
form.name = lf.graphModel.name;
|
|
|
form.code = lf.graphModel.code;
|
|
|
- form.flowType = lf.graphModel.flowType;
|
|
|
- form.description = lf.graphModel.description;
|
|
|
+ form.flowType = lf.graphModel.flowType;
|
|
|
+ form.description = lf.graphModel.description;
|
|
|
+ form.isMainHandlerShow = lf.graphModel.isMainHandlerShow;
|
|
|
form.id = route.params.id;
|
|
|
form.name = lf.graphModel.name;
|
|
|
});
|
|
@@ -460,11 +472,11 @@ const importJson = (data: any) => {
|
|
|
reRender(data);
|
|
|
};
|
|
|
const baseDataResult = ref<EmptyObjectType>({});
|
|
|
-onMounted( async()=>{
|
|
|
- // 获取页面基础数据
|
|
|
- const {result} = await baseData();
|
|
|
- baseDataResult.value = result;
|
|
|
- await init();
|
|
|
+onMounted(async () => {
|
|
|
+ // 获取页面基础数据
|
|
|
+ const { result } = await baseData();
|
|
|
+ baseDataResult.value = result;
|
|
|
+ await init();
|
|
|
});
|
|
|
|
|
|
// 出提供给外部操作-$refs.xxx
|