2025-09-05 15:38:09 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<div class="panel-tab__content">
|
2025-09-14 18:16:02 +08:00
|
|
|
|
<Form :label-col="{ span: 9 }" :wrapper-col="{ span: 15 }">
|
2025-09-05 15:38:09 +08:00
|
|
|
|
<!-- add by 芋艿:由于「异步延续」暂时用不到,所以这里 display 为 none -->
|
2025-09-14 18:16:02 +08:00
|
|
|
|
<Form.Item label="异步延续" style="display: none">
|
|
|
|
|
|
<Checkbox
|
|
|
|
|
|
v-model:checked="taskConfigForm.asyncBefore"
|
2025-09-05 15:38:09 +08:00
|
|
|
|
@change="changeTaskAsync"
|
2025-09-14 18:16:02 +08:00
|
|
|
|
>
|
|
|
|
|
|
异步前
|
|
|
|
|
|
</Checkbox>
|
|
|
|
|
|
<Checkbox
|
|
|
|
|
|
v-model:checked="taskConfigForm.asyncAfter"
|
2025-09-05 15:38:09 +08:00
|
|
|
|
@change="changeTaskAsync"
|
2025-09-14 18:16:02 +08:00
|
|
|
|
>
|
|
|
|
|
|
异步后
|
|
|
|
|
|
</Checkbox>
|
|
|
|
|
|
<Checkbox
|
|
|
|
|
|
v-model:checked="taskConfigForm.exclusive"
|
2025-09-05 15:38:09 +08:00
|
|
|
|
v-if="taskConfigForm.asyncAfter || taskConfigForm.asyncBefore"
|
|
|
|
|
|
@change="changeTaskAsync"
|
2025-09-14 18:16:02 +08:00
|
|
|
|
>
|
|
|
|
|
|
排除
|
|
|
|
|
|
</Checkbox>
|
|
|
|
|
|
</Form.Item>
|
2025-09-05 15:38:09 +08:00
|
|
|
|
<component :is="witchTaskComponent" v-bind="$props" />
|
2025-09-14 18:16:02 +08:00
|
|
|
|
</Form>
|
2025-09-05 15:38:09 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script lang="ts" setup>
|
2025-09-14 18:16:02 +08:00
|
|
|
|
import { Form } from 'ant-design-vue';
|
|
|
|
|
|
import { ref, watch } from 'vue';
|
2025-09-05 15:38:09 +08:00
|
|
|
|
import { installedComponent } from './data';
|
|
|
|
|
|
|
|
|
|
|
|
defineOptions({ name: 'ElementTaskConfig' });
|
|
|
|
|
|
|
|
|
|
|
|
const props = defineProps({
|
|
|
|
|
|
id: String,
|
|
|
|
|
|
type: String,
|
|
|
|
|
|
});
|
|
|
|
|
|
const taskConfigForm = ref({
|
|
|
|
|
|
asyncAfter: false,
|
|
|
|
|
|
asyncBefore: false,
|
|
|
|
|
|
exclusive: false,
|
|
|
|
|
|
});
|
|
|
|
|
|
const witchTaskComponent = ref();
|
|
|
|
|
|
|
|
|
|
|
|
const bpmnElement = ref();
|
|
|
|
|
|
|
|
|
|
|
|
const bpmnInstances = () => (window as any).bpmnInstances;
|
|
|
|
|
|
const changeTaskAsync = () => {
|
|
|
|
|
|
if (!taskConfigForm.value.asyncBefore && !taskConfigForm.value.asyncAfter) {
|
|
|
|
|
|
taskConfigForm.value.exclusive = false;
|
|
|
|
|
|
}
|
|
|
|
|
|
bpmnInstances().modeling.updateProperties(bpmnInstances().bpmnElement, {
|
|
|
|
|
|
...taskConfigForm.value,
|
|
|
|
|
|
});
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
watch(
|
|
|
|
|
|
() => props.id,
|
|
|
|
|
|
() => {
|
|
|
|
|
|
bpmnElement.value = bpmnInstances().bpmnElement;
|
|
|
|
|
|
taskConfigForm.value.asyncBefore =
|
|
|
|
|
|
bpmnElement.value?.businessObject?.asyncBefore;
|
|
|
|
|
|
taskConfigForm.value.asyncAfter =
|
|
|
|
|
|
bpmnElement.value?.businessObject?.asyncAfter;
|
|
|
|
|
|
taskConfigForm.value.exclusive =
|
|
|
|
|
|
bpmnElement.value?.businessObject?.exclusive;
|
|
|
|
|
|
},
|
|
|
|
|
|
{ immediate: true },
|
|
|
|
|
|
);
|
|
|
|
|
|
watch(
|
|
|
|
|
|
() => props.type,
|
|
|
|
|
|
() => {
|
|
|
|
|
|
if (props.type) {
|
|
|
|
|
|
witchTaskComponent.value = installedComponent[props.type].component;
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
{ immediate: true },
|
|
|
|
|
|
);
|
|
|
|
|
|
</script>
|