!247 Merge remote-tracking branch 'yudao/dev' into dev

Merge pull request !247 from Jason/dev
pull/248/head
xingyu 2025-11-03 01:39:01 +00:00 committed by Gitee
commit e4f64d2786
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
3 changed files with 87 additions and 24 deletions

View File

@ -24,6 +24,7 @@ import {
} from '#/api/bpm/processInstance';
import { decodeFields, setConfAndFields2 } from '#/components/form-create';
import { router } from '#/router';
import ProcessInstanceBpmnViewer from '#/views/bpm/processInstance/detail/modules/bpm-viewer.vue';
import ProcessInstanceSimpleViewer from '#/views/bpm/processInstance/detail/modules/simple-bpm-viewer.vue';
import ProcessInstanceTimeline from '#/views/bpm/processInstance/detail/modules/time-line.vue';
@ -51,7 +52,6 @@ const props = defineProps({
const emit = defineEmits(['cancel']);
const { closeCurrentTab } = useTabs();
const isFormReady = ref(false); // form-create
const getTitle = computed(() => {
return `流程表单 - ${props.selectProcessDefinition.name}`;
});
@ -122,21 +122,32 @@ async function initProcessInfo(row: any, formVariables?: any) {
// formVariables row.formFields
// formVariables
//
const formApi = formCreate.create(decodeFields(row.formFields));
const allowedFields = formApi.fields();
for (const key in formVariables) {
if (!allowedFields.includes(key)) {
delete formVariables[key];
//
const decodedFields = decodeFields(row.formFields);
const allowedFields = new Set(
decodedFields.map((field: any) => field.field).filter(Boolean),
);
//
if (formVariables) {
for (const key in formVariables) {
if (!allowedFields.has(key)) {
delete formVariables[key];
}
}
}
setConfAndFields2(detailForm, row.formConf, row.formFields, formVariables);
//
// TODO @jason
isFormReady.value = true;
// form-create
detailForm.value.option = {
...detailForm.value.option,
submitBtn: false,
resetBtn: false,
};
await nextTick();
fApi.value?.btn.show(false); //
// ,
await getApprovalDetail({
@ -153,30 +164,32 @@ async function initProcessInfo(row: any, formVariables?: any) {
}
//
} else if (row.formCustomCreatePath) {
// Tab
await router.push({
path: row.formCustomCreatePath,
});
// Tab
//
emit('cancel');
}
}
/** 预测流程节点会因为输入的参数值而产生新的预测结果值,所以需重新预测一次 */
watch(
detailForm.value,
() => detailForm.value.value,
(newValue) => {
if (newValue && Object.keys(newValue.value).length > 0) {
if (newValue && Object.keys(newValue).length > 0) {
//
tempStartUserSelectAssignees.value = startUserSelectAssignees.value;
startUserSelectAssignees.value = {};
//
getApprovalDetail({
id: props.selectProcessDefinition.id,
processVariablesStr: JSON.stringify(newValue.value), // GET String JSON
processVariablesStr: JSON.stringify(newValue), // GET String JSON
});
}
},
{
immediate: true,
deep: true,
},
);
@ -283,7 +296,6 @@ defineExpose({ initProcessInfo });
class="flex-1 overflow-auto"
>
<form-create
v-if="isFormReady"
:rule="detailForm.rule"
v-model:api="fApi"
v-model="detailForm.value"
@ -307,10 +319,15 @@ defineExpose({ initProcessInfo });
class="flex flex-1 overflow-hidden"
:force-render="true"
>
<div class="w-full">
<div class="h-full w-full">
<!-- BPMN 流程图预览 -->
<ProcessInstanceBpmnViewer
:bpmn-xml="bpmnXML"
v-if="BpmModelType.BPMN === selectProcessDefinition.modelType"
/>
<ProcessInstanceSimpleViewer
:simple-json="simpleJson"
v-if="selectProcessDefinition.modelType === BpmModelType.SIMPLE"
v-if="BpmModelType.SIMPLE === selectProcessDefinition.modelType"
/>
</div>
</Tabs.TabPane>

View File

@ -1,10 +1,59 @@
<script setup lang="ts">
import { ref, watch } from 'vue';
import { MyProcessViewer } from '#/views/bpm/components/bpmn-process-designer/package';
defineOptions({ name: 'ProcessInstanceBpmnViewer' });
const props = withDefaults(
defineProps<{
bpmnXml?: string;
loading?: boolean; //
modelView?: Object;
}>(),
{
loading: false,
modelView: () => ({}),
bpmnXml: '',
},
);
// BPMN
const view = ref({
bpmnXml: '',
});
/** 监控 modelView 更新 */
watch(
() => props.modelView,
async (newModelView) => {
//
if (newModelView) {
// @ts-ignore
view.value = newModelView;
}
},
);
/** 监听 bpmnXml */
watch(
() => props.bpmnXml,
(value) => {
view.value.bpmnXml = value;
},
);
</script>
<template>
<!-- TODO @jason这里 BPMN 图的接入 -->
<div>
<h1>BPMN Viewer</h1>
<div
v-loading="loading"
class="h-full w-full overflow-auto rounded-lg border border-gray-200 bg-white p-4"
>
<MyProcessViewer
key="processViewer"
:xml="view.bpmnXml"
:view="view"
class="h-full min-h-[500px] w-full"
/>
</div>
</template>

View File

@ -268,9 +268,6 @@ async function openPopover(type: string) {
Object.keys(popOverVisible.value).forEach((item) => {
if (popOverVisible.value[item]) popOverVisible.value[item] = item === type;
});
// TODO @jason 2
// await nextTick()
// formRef.value.resetFields()
}
/** 关闭气泡卡 */