!291 Merge remote-tracking branch 'yudao/dev' into dev
Merge pull request !291 from Jason/dev
This commit is contained in:
@@ -1,23 +1,21 @@
|
|||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
import { inject, nextTick, ref, watch } from 'vue';
|
import { inject, nextTick, ref, watch } from 'vue';
|
||||||
|
|
||||||
|
import { confirm, useVbenDrawer, useVbenModal } from '@vben/common-ui';
|
||||||
import { IconifyIcon } from '@vben/icons';
|
import { IconifyIcon } from '@vben/icons';
|
||||||
import { cloneDeep } from '@vben/utils';
|
import { cloneDeep } from '@vben/utils';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Button,
|
Button,
|
||||||
Divider,
|
Divider,
|
||||||
Drawer,
|
|
||||||
Form,
|
Form,
|
||||||
FormItem,
|
FormItem,
|
||||||
Input,
|
Input,
|
||||||
Modal,
|
|
||||||
Select,
|
Select,
|
||||||
SelectOption,
|
SelectOption,
|
||||||
Table,
|
|
||||||
TableColumn,
|
|
||||||
} from 'ant-design-vue';
|
} from 'ant-design-vue';
|
||||||
|
|
||||||
|
import { useVbenVxeGrid } from '#/adapter/vxe-table';
|
||||||
import ProcessListenerDialog from '#/views/bpm/components/bpmn-process-designer/package/penal/listeners/ProcessListenerDialog.vue';
|
import ProcessListenerDialog from '#/views/bpm/components/bpmn-process-designer/package/penal/listeners/ProcessListenerDialog.vue';
|
||||||
|
|
||||||
import { createListenerObject, updateElementExtensions } from '../../utils';
|
import { createListenerObject, updateElementExtensions } from '../../utils';
|
||||||
@@ -40,47 +38,30 @@ interface Props {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const prefix = inject<string>('prefix');
|
const prefix = inject<string>('prefix');
|
||||||
const width = inject<number>('width');
|
|
||||||
const elementListenersList = ref<any[]>([]);
|
const elementListenersList = ref<any[]>([]);
|
||||||
const listenerEventTypeObject = ref(eventType);
|
const listenerEventTypeObject = ref(eventType);
|
||||||
const listenerTypeObject = ref(listenerType);
|
const listenerTypeObject = ref(listenerType);
|
||||||
const listenerFormModelVisible = ref(false);
|
|
||||||
const listenerForm = ref<any>({});
|
const listenerForm = ref<any>({});
|
||||||
const fieldTypeObject = ref(fieldType);
|
const fieldTypeObject = ref(fieldType);
|
||||||
const fieldsListOfListener = ref<any[]>([]);
|
const fieldsListOfListener = ref<any[]>([]);
|
||||||
const listenerFieldFormModelVisible = ref(false); // 监听器 注入字段表单弹窗 显示状态
|
const editingListenerIndex = ref(-1);
|
||||||
const editingListenerIndex = ref(-1); // 监听器所在下标,-1 为新增
|
const editingListenerFieldIndex = ref<any>(-1);
|
||||||
const editingListenerFieldIndex = ref<any>(-1); // 字段所在下标,-1 为新增
|
const listenerFieldForm = ref<any>({});
|
||||||
const listenerFieldForm = ref<any>({}); // 监听器 注入字段 详情表单
|
|
||||||
const bpmnElement = ref<any>();
|
const bpmnElement = ref<any>();
|
||||||
const bpmnElementListeners = ref<any[]>([]);
|
const bpmnElementListeners = ref<any[]>([]);
|
||||||
const otherExtensionList = ref<any[]>([]);
|
const otherExtensionList = ref<any[]>([]);
|
||||||
const listenerFormRef = ref<any>({});
|
const listenerFormRef = ref<any>({});
|
||||||
const listenerFieldFormRef = ref<any>({});
|
const listenerFieldFormRef = ref<any>({});
|
||||||
|
|
||||||
interface BpmnInstances {
|
const bpmnInstances = () => (window as any)?.bpmnInstances;
|
||||||
bpmnElement: any;
|
|
||||||
[key: string]: any;
|
|
||||||
}
|
|
||||||
|
|
||||||
declare global {
|
|
||||||
interface Window {
|
|
||||||
bpmnInstances?: BpmnInstances;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const bpmnInstances = () => window.bpmnInstances;
|
|
||||||
|
|
||||||
const resetListenersList = () => {
|
const resetListenersList = () => {
|
||||||
// console.log(
|
|
||||||
// bpmnInstances().bpmnElement,
|
|
||||||
// 'window.bpmnInstances.bpmnElementwindow.bpmnInstances.bpmnElementwindow.bpmnInstances.bpmnElementwindow.bpmnInstances.bpmnElementwindow.bpmnInstances.bpmnElementwindow.bpmnInstances.bpmnElement',
|
|
||||||
// );
|
|
||||||
bpmnElement.value = bpmnInstances()?.bpmnElement;
|
bpmnElement.value = bpmnInstances()?.bpmnElement;
|
||||||
otherExtensionList.value =
|
otherExtensionList.value =
|
||||||
bpmnElement.value.businessObject?.extensionElements?.values?.filter(
|
bpmnElement.value.businessObject?.extensionElements?.values?.filter(
|
||||||
(ex: any) => ex.$type !== `${prefix}:TaskListener`,
|
(ex: any) => ex.$type !== `${prefix}:TaskListener`,
|
||||||
) ?? []; // 保留非监听器类型的扩展属性,避免移除监听器时清空其他配置(如审批人等)。相关案例:https://gitee.com/yudaocode/yudao-ui-admin-vue3/issues/ICMSYC
|
) ?? [];
|
||||||
bpmnElementListeners.value =
|
bpmnElementListeners.value =
|
||||||
bpmnElement.value.businessObject?.extensionElements?.values?.filter(
|
bpmnElement.value.businessObject?.extensionElements?.values?.filter(
|
||||||
(ex: any) => ex.$type === `${prefix}:TaskListener`,
|
(ex: any) => ex.$type === `${prefix}:TaskListener`,
|
||||||
@@ -89,13 +70,14 @@ const resetListenersList = () => {
|
|||||||
initListenerType(listener),
|
initListenerType(listener),
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
const openListenerForm = (listener: any, index?: number) => {
|
const openListenerForm = (listener: any, index?: number) => {
|
||||||
if (listener) {
|
if (listener) {
|
||||||
listenerForm.value = initListenerForm(listener);
|
listenerForm.value = initListenerForm(listener);
|
||||||
editingListenerIndex.value = index || -1;
|
editingListenerIndex.value = index || -1;
|
||||||
} else {
|
} else {
|
||||||
listenerForm.value = {};
|
listenerForm.value = {};
|
||||||
editingListenerIndex.value = -1; // 标记为新增
|
editingListenerIndex.value = -1;
|
||||||
}
|
}
|
||||||
if (listener && listener.fields) {
|
if (listener && listener.fields) {
|
||||||
fieldsListOfListener.value = listener.fields.map((field: any) => ({
|
fieldsListOfListener.value = listener.fields.map((field: any) => ({
|
||||||
@@ -106,37 +88,32 @@ const openListenerForm = (listener: any, index?: number) => {
|
|||||||
fieldsListOfListener.value = [];
|
fieldsListOfListener.value = [];
|
||||||
listenerForm.value.fields = [];
|
listenerForm.value.fields = [];
|
||||||
}
|
}
|
||||||
// 打开侧边栏并清楚验证状态
|
listenerDrawerApi.open();
|
||||||
listenerFormModelVisible.value = true;
|
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
if (listenerFormRef.value) listenerFormRef.value.clearValidate();
|
if (listenerFormRef.value) listenerFormRef.value.clearValidate();
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
// 移除监听器
|
|
||||||
const removeListener = (_: any, index: number) => {
|
const removeListener = (_: any, index: number) => {
|
||||||
// console.log(listener, 'listener');
|
confirm({
|
||||||
Modal.confirm({
|
|
||||||
title: '提示',
|
title: '提示',
|
||||||
content: '确认移除该监听器吗?',
|
content: '确认移除该监听器吗?',
|
||||||
okText: '确 认',
|
}).then(() => {
|
||||||
cancelText: '取 消',
|
bpmnElementListeners.value.splice(index, 1);
|
||||||
onOk() {
|
elementListenersList.value.splice(index, 1);
|
||||||
bpmnElementListeners.value.splice(index, 1);
|
updateElementExtensions(bpmnElement.value, [
|
||||||
elementListenersList.value.splice(index, 1);
|
...otherExtensionList.value,
|
||||||
updateElementExtensions(bpmnElement.value, [
|
...bpmnElementListeners.value,
|
||||||
...otherExtensionList.value,
|
]);
|
||||||
...bpmnElementListeners.value,
|
|
||||||
]);
|
|
||||||
},
|
|
||||||
onCancel() {
|
|
||||||
// console.info('操作取消');
|
|
||||||
},
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
// 保存监听器
|
|
||||||
const saveListenerConfig = async () => {
|
async function saveListenerConfig() {
|
||||||
const validateStatus = await listenerFormRef.value.validate();
|
try {
|
||||||
if (!validateStatus) return; // 验证不通过直接返回
|
await listenerFormRef.value.validate();
|
||||||
|
} catch {
|
||||||
|
return;
|
||||||
|
}
|
||||||
const listenerObject = createListenerObject(listenerForm.value, true, prefix);
|
const listenerObject = createListenerObject(listenerForm.value, true, prefix);
|
||||||
if (editingListenerIndex.value === -1) {
|
if (editingListenerIndex.value === -1) {
|
||||||
bpmnElementListeners.value.push(listenerObject);
|
bpmnElementListeners.value.push(listenerObject);
|
||||||
@@ -153,7 +130,6 @@ const saveListenerConfig = async () => {
|
|||||||
listenerForm.value,
|
listenerForm.value,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
// 保存其他配置
|
|
||||||
otherExtensionList.value =
|
otherExtensionList.value =
|
||||||
bpmnElement.value.businessObject?.extensionElements?.values?.filter(
|
bpmnElement.value.businessObject?.extensionElements?.values?.filter(
|
||||||
(ex: any) => ex.$type !== `${prefix}:TaskListener`,
|
(ex: any) => ex.$type !== `${prefix}:TaskListener`,
|
||||||
@@ -162,63 +138,92 @@ const saveListenerConfig = async () => {
|
|||||||
...otherExtensionList.value,
|
...otherExtensionList.value,
|
||||||
...bpmnElementListeners.value,
|
...bpmnElementListeners.value,
|
||||||
]);
|
]);
|
||||||
// 4. 隐藏侧边栏
|
listenerDrawerApi.close();
|
||||||
listenerFormModelVisible.value = false;
|
|
||||||
listenerForm.value = {};
|
listenerForm.value = {};
|
||||||
};
|
}
|
||||||
|
|
||||||
// 打开监听器字段编辑弹窗
|
|
||||||
const openListenerFieldForm = (field: any, index?: number) => {
|
const openListenerFieldForm = (field: any, index?: number) => {
|
||||||
listenerFieldForm.value = field ? cloneDeep(field) : {};
|
listenerFieldForm.value = field ? cloneDeep(field) : {};
|
||||||
editingListenerFieldIndex.value = field ? index : -1;
|
editingListenerFieldIndex.value = field ? index : -1;
|
||||||
listenerFieldFormModelVisible.value = true;
|
fieldModalApi.open();
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
if (listenerFieldFormRef.value) listenerFieldFormRef.value.clearValidate();
|
if (listenerFieldFormRef.value) listenerFieldFormRef.value.clearValidate();
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
// 保存监听器注入字段
|
|
||||||
const saveListenerFiled = async () => {
|
const [ListenerGrid, listenerGridApi] = useVbenVxeGrid({
|
||||||
const validateStatus = await listenerFieldFormRef.value.validate();
|
gridOptions: {
|
||||||
if (!validateStatus) return; // 验证不通过直接返回
|
columns: [
|
||||||
if (editingListenerFieldIndex.value === -1) {
|
{ type: 'seq', width: 50, title: '序号' },
|
||||||
fieldsListOfListener.value.push(listenerFieldForm.value);
|
{
|
||||||
listenerForm.value.fields.push(listenerFieldForm.value);
|
field: 'event',
|
||||||
} else {
|
title: '事件类型',
|
||||||
fieldsListOfListener.value.splice(
|
minWidth: 80,
|
||||||
editingListenerFieldIndex.value,
|
formatter: ({ cellValue }: { cellValue: string }) =>
|
||||||
1,
|
(listenerEventTypeObject.value as Record<string, any>)[cellValue],
|
||||||
listenerFieldForm.value,
|
},
|
||||||
);
|
{ field: 'id', title: '事件id', minWidth: 80, showOverflow: true },
|
||||||
listenerForm.value.fields.splice(
|
{
|
||||||
editingListenerFieldIndex.value,
|
field: 'listenerType',
|
||||||
1,
|
title: '监听器类型',
|
||||||
listenerFieldForm.value,
|
minWidth: 80,
|
||||||
);
|
formatter: ({ cellValue }: { cellValue: string }) =>
|
||||||
}
|
(listenerTypeObject.value as Record<string, any>)[cellValue],
|
||||||
listenerFieldFormModelVisible.value = false;
|
},
|
||||||
nextTick(() => {
|
{
|
||||||
|
title: '操作',
|
||||||
|
width: 120,
|
||||||
|
slots: { default: 'action' },
|
||||||
|
fixed: 'right',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
border: true,
|
||||||
|
showOverflow: true,
|
||||||
|
height: 'auto',
|
||||||
|
toolbarConfig: {
|
||||||
|
enabled: false,
|
||||||
|
},
|
||||||
|
pagerConfig: {
|
||||||
|
enabled: false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
async function saveListenerField() {
|
||||||
|
try {
|
||||||
|
await listenerFieldFormRef.value.validate();
|
||||||
|
if (editingListenerFieldIndex.value === -1) {
|
||||||
|
fieldsListOfListener.value.push(cloneDeep(listenerFieldForm.value));
|
||||||
|
listenerForm.value.fields.push(cloneDeep(listenerFieldForm.value));
|
||||||
|
} else {
|
||||||
|
fieldsListOfListener.value.splice(
|
||||||
|
editingListenerFieldIndex.value,
|
||||||
|
1,
|
||||||
|
cloneDeep(listenerFieldForm.value),
|
||||||
|
);
|
||||||
|
listenerForm.value.fields.splice(
|
||||||
|
editingListenerFieldIndex.value,
|
||||||
|
1,
|
||||||
|
cloneDeep(listenerFieldForm.value),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
fieldModalApi.close();
|
||||||
listenerFieldForm.value = {};
|
listenerFieldForm.value = {};
|
||||||
});
|
} catch (error) {
|
||||||
};
|
console.error(error);
|
||||||
// 移除监听器字段
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const removeListenerField = (_: any, index: number) => {
|
const removeListenerField = (_: any, index: number) => {
|
||||||
// console.log(field, 'field');
|
confirm({
|
||||||
Modal.confirm({
|
|
||||||
title: '提示',
|
title: '提示',
|
||||||
content: '确认移除该字段吗?',
|
content: '确认移除该字段吗?',
|
||||||
okText: '确 认',
|
}).then(() => {
|
||||||
cancelText: '取 消',
|
fieldsListOfListener.value.splice(index, 1);
|
||||||
onOk() {
|
listenerForm.value.fields.splice(index, 1);
|
||||||
fieldsListOfListener.value.splice(index, 1);
|
|
||||||
listenerForm.value.fields.splice(index, 1);
|
|
||||||
},
|
|
||||||
onCancel() {
|
|
||||||
// console.info('操作取消');
|
|
||||||
},
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
// 打开监听器弹窗
|
|
||||||
const processListenerDialogRef = ref<any>();
|
const processListenerDialogRef = ref<any>();
|
||||||
const openProcessListenerDialog = async () => {
|
const openProcessListenerDialog = async () => {
|
||||||
processListenerDialogRef.value.open('task');
|
processListenerDialogRef.value.open('task');
|
||||||
@@ -229,7 +234,6 @@ const selectProcessListener = (listener: any) => {
|
|||||||
bpmnElementListeners.value.push(listenerObject);
|
bpmnElementListeners.value.push(listenerObject);
|
||||||
elementListenersList.value.push(listenerForm);
|
elementListenersList.value.push(listenerForm);
|
||||||
|
|
||||||
// 保存其他配置
|
|
||||||
otherExtensionList.value =
|
otherExtensionList.value =
|
||||||
bpmnElement.value.businessObject?.extensionElements?.values?.filter(
|
bpmnElement.value.businessObject?.extensionElements?.values?.filter(
|
||||||
(ex: any) => ex.$type !== `${prefix}:TaskListener`,
|
(ex: any) => ex.$type !== `${prefix}:TaskListener`,
|
||||||
@@ -240,6 +244,69 @@ const selectProcessListener = (listener: any) => {
|
|||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const [ListenerDrawer, listenerDrawerApi] = useVbenDrawer({
|
||||||
|
title: '任务监听器',
|
||||||
|
destroyOnClose: true,
|
||||||
|
onConfirm: saveListenerConfig,
|
||||||
|
});
|
||||||
|
|
||||||
|
const [FieldModal, fieldModalApi] = useVbenModal({
|
||||||
|
title: '字段配置',
|
||||||
|
onConfirm: saveListenerField,
|
||||||
|
});
|
||||||
|
|
||||||
|
const [FieldsGrid, fieldsGridApi] = useVbenVxeGrid({
|
||||||
|
gridOptions: {
|
||||||
|
columns: [
|
||||||
|
{ type: 'seq', width: 50, title: '序号' },
|
||||||
|
{ field: 'name', title: '字段名称', minWidth: 100 },
|
||||||
|
{
|
||||||
|
field: 'fieldType',
|
||||||
|
title: '字段类型',
|
||||||
|
width: 80,
|
||||||
|
formatter: ({ cellValue }: { cellValue: string }) =>
|
||||||
|
fieldTypeObject.value[cellValue as keyof typeof fieldType],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '字段值/表达式',
|
||||||
|
width: 100,
|
||||||
|
formatter: ({ row }: { row: any }) => row.string || row.expression,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '操作',
|
||||||
|
width: 120,
|
||||||
|
slots: { default: 'action' },
|
||||||
|
fixed: 'right',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
border: true,
|
||||||
|
showOverflow: true,
|
||||||
|
minHeight: 200,
|
||||||
|
toolbarConfig: {
|
||||||
|
enabled: false,
|
||||||
|
},
|
||||||
|
pagerConfig: {
|
||||||
|
enabled: false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
watch(
|
||||||
|
elementListenersList,
|
||||||
|
(val) => {
|
||||||
|
listenerGridApi.setGridOptions({ data: val });
|
||||||
|
},
|
||||||
|
{ deep: true },
|
||||||
|
);
|
||||||
|
|
||||||
|
watch(
|
||||||
|
fieldsListOfListener,
|
||||||
|
(val) => {
|
||||||
|
fieldsGridApi.setGridOptions({ data: val });
|
||||||
|
},
|
||||||
|
{ deep: true },
|
||||||
|
);
|
||||||
|
|
||||||
watch(
|
watch(
|
||||||
() => props.id,
|
() => props.id,
|
||||||
(val) => {
|
(val) => {
|
||||||
@@ -253,257 +320,218 @@ watch(
|
|||||||
);
|
);
|
||||||
</script>
|
</script>
|
||||||
<template>
|
<template>
|
||||||
<div class="panel-tab__content">
|
<div class="-mx-2">
|
||||||
<Table :data="elementListenersList" size="small" bordered>
|
<ListenerGrid>
|
||||||
<TableColumn title="序号" width="50px" type="index" />
|
<template #action="{ row, rowIndex }">
|
||||||
<TableColumn
|
<Button
|
||||||
title="事件类型"
|
size="small"
|
||||||
width="80px"
|
type="link"
|
||||||
:ellipsis="{ showTitle: true }"
|
@click="openListenerForm(row, rowIndex)"
|
||||||
:custom-render="
|
>
|
||||||
({ record }: any) =>
|
编辑
|
||||||
listenerEventTypeObject[record.event as keyof typeof eventType]
|
</Button>
|
||||||
"
|
<Divider type="vertical" />
|
||||||
/>
|
<Button
|
||||||
<TableColumn
|
size="small"
|
||||||
title="事件id"
|
type="link"
|
||||||
width="80px"
|
danger
|
||||||
data-index="id"
|
@click="removeListener(row, rowIndex)"
|
||||||
:ellipsis="{ showTitle: true }"
|
>
|
||||||
/>
|
移除
|
||||||
<TableColumn
|
</Button>
|
||||||
title="监听器类型"
|
</template>
|
||||||
width="80px"
|
</ListenerGrid>
|
||||||
:ellipsis="{ showTitle: true }"
|
<div class="mt-1 flex w-full items-center justify-center gap-2 px-2">
|
||||||
:custom-render="
|
<Button
|
||||||
({ record }: any) =>
|
class="flex flex-1 items-center justify-center"
|
||||||
listenerTypeObject[record.listenerType as keyof typeof listenerType]
|
size="small"
|
||||||
"
|
type="primary"
|
||||||
/>
|
@click="openListenerForm(null)"
|
||||||
<TableColumn title="操作" width="90px">
|
>
|
||||||
<template #default="{ record, index }">
|
|
||||||
<Button
|
|
||||||
size="small"
|
|
||||||
type="link"
|
|
||||||
@click="openListenerForm(record, index)"
|
|
||||||
>
|
|
||||||
编辑
|
|
||||||
</Button>
|
|
||||||
<Divider type="vertical" />
|
|
||||||
<Button
|
|
||||||
size="small"
|
|
||||||
type="link"
|
|
||||||
danger
|
|
||||||
@click="removeListener(record, index)"
|
|
||||||
>
|
|
||||||
移除
|
|
||||||
</Button>
|
|
||||||
</template>
|
|
||||||
</TableColumn>
|
|
||||||
</Table>
|
|
||||||
<div class="element-drawer__button">
|
|
||||||
<Button size="small" type="primary" @click="openListenerForm(null)">
|
|
||||||
<template #icon> <IconifyIcon icon="ep:plus" /></template>
|
<template #icon> <IconifyIcon icon="ep:plus" /></template>
|
||||||
添加监听器
|
添加监听器
|
||||||
</Button>
|
</Button>
|
||||||
<Button size="small" @click="openProcessListenerDialog">
|
<Button
|
||||||
|
class="flex flex-1 items-center justify-center"
|
||||||
|
size="small"
|
||||||
|
@click="openProcessListenerDialog"
|
||||||
|
>
|
||||||
<template #icon> <IconifyIcon icon="ep:select" /></template>
|
<template #icon> <IconifyIcon icon="ep:select" /></template>
|
||||||
选择监听器
|
选择监听器
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- 监听器 编辑/创建 部分 -->
|
<!-- 监听器 编辑/创建 部分 -->
|
||||||
<Drawer
|
<ListenerDrawer class="w-2/5">
|
||||||
v-model:open="listenerFormModelVisible"
|
<template #default>
|
||||||
title="任务监听器"
|
<Form
|
||||||
:width="width"
|
:label-col="{ span: 6 }"
|
||||||
:destroy-on-close="true"
|
:model="listenerForm"
|
||||||
>
|
:wrapper-col="{ span: 18 }"
|
||||||
<Form :model="listenerForm" ref="listenerFormRef">
|
ref="listenerFormRef"
|
||||||
<FormItem
|
|
||||||
label="事件类型"
|
|
||||||
name="event"
|
|
||||||
:rules="[{ required: true, message: '请选择事件类型' }]"
|
|
||||||
>
|
>
|
||||||
<Select v-model:value="listenerForm.event">
|
|
||||||
<SelectOption
|
|
||||||
v-for="i in Object.keys(listenerEventTypeObject)"
|
|
||||||
:key="i"
|
|
||||||
:value="i"
|
|
||||||
>
|
|
||||||
{{ listenerEventTypeObject[i as keyof typeof eventType] }}
|
|
||||||
</SelectOption>
|
|
||||||
</Select>
|
|
||||||
</FormItem>
|
|
||||||
<FormItem
|
|
||||||
label="监听器ID"
|
|
||||||
name="id"
|
|
||||||
:rules="[{ required: true, message: '请输入监听器ID' }]"
|
|
||||||
>
|
|
||||||
<Input v-model:value="listenerForm.id" allow-clear />
|
|
||||||
</FormItem>
|
|
||||||
<FormItem
|
|
||||||
label="监听器类型"
|
|
||||||
name="listenerType"
|
|
||||||
:rules="[{ required: true, message: '请选择监听器类型' }]"
|
|
||||||
>
|
|
||||||
<Select v-model:value="listenerForm.listenerType">
|
|
||||||
<SelectOption
|
|
||||||
v-for="i in Object.keys(listenerTypeObject)"
|
|
||||||
:key="i"
|
|
||||||
:value="i"
|
|
||||||
>
|
|
||||||
{{ listenerTypeObject[i as keyof typeof listenerType] }}
|
|
||||||
</SelectOption>
|
|
||||||
</Select>
|
|
||||||
</FormItem>
|
|
||||||
<FormItem
|
|
||||||
v-if="listenerForm.listenerType === 'classListener'"
|
|
||||||
label="Java类"
|
|
||||||
name="class"
|
|
||||||
key="listener-class"
|
|
||||||
:rules="[{ required: true, message: '请输入Java类' }]"
|
|
||||||
>
|
|
||||||
<Input v-model:value="listenerForm.class" allow-clear />
|
|
||||||
</FormItem>
|
|
||||||
<FormItem
|
|
||||||
v-if="listenerForm.listenerType === 'expressionListener'"
|
|
||||||
label="表达式"
|
|
||||||
name="expression"
|
|
||||||
key="listener-expression"
|
|
||||||
:rules="[{ required: true, message: '请输入表达式' }]"
|
|
||||||
>
|
|
||||||
<Input v-model:value="listenerForm.expression" allow-clear />
|
|
||||||
</FormItem>
|
|
||||||
<FormItem
|
|
||||||
v-if="listenerForm.listenerType === 'delegateExpressionListener'"
|
|
||||||
label="代理表达式"
|
|
||||||
name="delegateExpression"
|
|
||||||
key="listener-delegate"
|
|
||||||
:rules="[{ required: true, message: '请输入代理表达式' }]"
|
|
||||||
>
|
|
||||||
<Input v-model:value="listenerForm.delegateExpression" allow-clear />
|
|
||||||
</FormItem>
|
|
||||||
<template v-if="listenerForm.listenerType === 'scriptListener'">
|
|
||||||
<FormItem
|
<FormItem
|
||||||
label="脚本格式"
|
label="事件类型"
|
||||||
name="scriptFormat"
|
name="event"
|
||||||
key="listener-script-format"
|
:rules="[{ required: true, message: '请选择事件类型' }]"
|
||||||
:rules="[{ required: true, message: '请填写脚本格式' }]"
|
|
||||||
>
|
>
|
||||||
<Input v-model:value="listenerForm.scriptFormat" allow-clear />
|
<Select v-model:value="listenerForm.event">
|
||||||
</FormItem>
|
<SelectOption
|
||||||
<FormItem
|
v-for="i in Object.keys(listenerEventTypeObject)"
|
||||||
label="脚本类型"
|
:key="i"
|
||||||
name="scriptType"
|
:value="i"
|
||||||
key="listener-script-type"
|
>
|
||||||
:rules="[{ required: true, message: '请选择脚本类型' }]"
|
{{ listenerEventTypeObject[i as keyof typeof eventType] }}
|
||||||
>
|
</SelectOption>
|
||||||
<Select v-model:value="listenerForm.scriptType">
|
|
||||||
<SelectOption value="inlineScript">内联脚本</SelectOption>
|
|
||||||
<SelectOption value="externalScript">外部脚本</SelectOption>
|
|
||||||
</Select>
|
</Select>
|
||||||
</FormItem>
|
</FormItem>
|
||||||
<FormItem
|
<FormItem
|
||||||
v-if="listenerForm.scriptType === 'inlineScript'"
|
label="监听器ID"
|
||||||
label="脚本内容"
|
name="id"
|
||||||
name="value"
|
:rules="[{ required: true, message: '请输入监听器ID' }]"
|
||||||
key="listener-script"
|
|
||||||
:rules="[{ required: true, message: '请填写脚本内容' }]"
|
|
||||||
>
|
>
|
||||||
<Input v-model:value="listenerForm.value" allow-clear />
|
<Input v-model:value="listenerForm.id" allow-clear />
|
||||||
</FormItem>
|
</FormItem>
|
||||||
<FormItem
|
<FormItem
|
||||||
v-if="listenerForm.scriptType === 'externalScript'"
|
label="监听器类型"
|
||||||
label="资源地址"
|
name="listenerType"
|
||||||
name="resource"
|
:rules="[{ required: true, message: '请选择监听器类型' }]"
|
||||||
key="listener-resource"
|
|
||||||
:rules="[{ required: true, message: '请填写资源地址' }]"
|
|
||||||
>
|
>
|
||||||
<Input v-model:value="listenerForm.resource" allow-clear />
|
<Select v-model:value="listenerForm.listenerType">
|
||||||
</FormItem>
|
<SelectOption
|
||||||
</template>
|
v-for="i in Object.keys(listenerTypeObject)"
|
||||||
|
:key="i"
|
||||||
<template v-if="listenerForm.event === 'timeout'">
|
:value="i"
|
||||||
<FormItem
|
>
|
||||||
label="定时器类型"
|
{{ listenerTypeObject[i as keyof typeof listenerType] }}
|
||||||
name="eventDefinitionType"
|
</SelectOption>
|
||||||
key="eventDefinitionType"
|
|
||||||
>
|
|
||||||
<Select v-model:value="listenerForm.eventDefinitionType">
|
|
||||||
<SelectOption value="date">日期</SelectOption>
|
|
||||||
<SelectOption value="duration">持续时长</SelectOption>
|
|
||||||
<SelectOption value="cycle">循环</SelectOption>
|
|
||||||
<SelectOption value="null">无</SelectOption>
|
|
||||||
</Select>
|
</Select>
|
||||||
</FormItem>
|
</FormItem>
|
||||||
<FormItem
|
<FormItem
|
||||||
v-if="
|
v-if="listenerForm.listenerType === 'classListener'"
|
||||||
!!listenerForm.eventDefinitionType &&
|
label="Java类"
|
||||||
listenerForm.eventDefinitionType !== 'null'
|
name="class"
|
||||||
"
|
key="listener-class"
|
||||||
label="定时器"
|
:rules="[{ required: true, message: '请输入Java类' }]"
|
||||||
name="eventTimeDefinitions"
|
>
|
||||||
key="eventTimeDefinitions"
|
<Input v-model:value="listenerForm.class" allow-clear />
|
||||||
:rules="[{ required: true, message: '请填写定时器配置' }]"
|
</FormItem>
|
||||||
|
<FormItem
|
||||||
|
v-if="listenerForm.listenerType === 'expressionListener'"
|
||||||
|
label="表达式"
|
||||||
|
name="expression"
|
||||||
|
key="listener-expression"
|
||||||
|
:rules="[{ required: true, message: '请输入表达式' }]"
|
||||||
|
>
|
||||||
|
<Input v-model:value="listenerForm.expression" allow-clear />
|
||||||
|
</FormItem>
|
||||||
|
<FormItem
|
||||||
|
v-if="listenerForm.listenerType === 'delegateExpressionListener'"
|
||||||
|
label="代理表达式"
|
||||||
|
name="delegateExpression"
|
||||||
|
key="listener-delegate"
|
||||||
|
:rules="[{ required: true, message: '请输入代理表达式' }]"
|
||||||
>
|
>
|
||||||
<Input
|
<Input
|
||||||
v-model:value="listenerForm.eventTimeDefinitions"
|
v-model:value="listenerForm.delegateExpression"
|
||||||
allow-clear
|
allow-clear
|
||||||
/>
|
/>
|
||||||
</FormItem>
|
</FormItem>
|
||||||
</template>
|
<template v-if="listenerForm.listenerType === 'scriptListener'">
|
||||||
</Form>
|
<FormItem
|
||||||
|
label="脚本格式"
|
||||||
<Divider />
|
name="scriptFormat"
|
||||||
<div class="mb-2 flex justify-between">
|
key="listener-script-format"
|
||||||
<span class="flex items-center">
|
:rules="[{ required: true, message: '请填写脚本格式' }]"
|
||||||
<IconifyIcon icon="ep:menu" class="mr-2 text-gray-600" />
|
>
|
||||||
注入字段
|
<Input v-model:value="listenerForm.scriptFormat" allow-clear />
|
||||||
</span>
|
</FormItem>
|
||||||
<Button
|
<FormItem
|
||||||
type="primary"
|
label="脚本类型"
|
||||||
title="添加字段"
|
name="scriptType"
|
||||||
@click="openListenerFieldForm(null)"
|
key="listener-script-type"
|
||||||
>
|
:rules="[{ required: true, message: '请选择脚本类型' }]"
|
||||||
<template #icon>
|
>
|
||||||
<IconifyIcon icon="ep:plus" />
|
<Select v-model:value="listenerForm.scriptType">
|
||||||
|
<SelectOption value="inlineScript">内联脚本</SelectOption>
|
||||||
|
<SelectOption value="externalScript">外部脚本</SelectOption>
|
||||||
|
</Select>
|
||||||
|
</FormItem>
|
||||||
|
<FormItem
|
||||||
|
v-if="listenerForm.scriptType === 'inlineScript'"
|
||||||
|
label="脚本内容"
|
||||||
|
name="value"
|
||||||
|
key="listener-script"
|
||||||
|
:rules="[{ required: true, message: '请填写脚本内容' }]"
|
||||||
|
>
|
||||||
|
<Input v-model:value="listenerForm.value" allow-clear />
|
||||||
|
</FormItem>
|
||||||
|
<FormItem
|
||||||
|
v-if="listenerForm.scriptType === 'externalScript'"
|
||||||
|
label="资源地址"
|
||||||
|
name="resource"
|
||||||
|
key="listener-resource"
|
||||||
|
:rules="[{ required: true, message: '请填写资源地址' }]"
|
||||||
|
>
|
||||||
|
<Input v-model:value="listenerForm.resource" allow-clear />
|
||||||
|
</FormItem>
|
||||||
</template>
|
</template>
|
||||||
添加字段
|
|
||||||
</Button>
|
<template v-if="listenerForm.event === 'timeout'">
|
||||||
</div>
|
<FormItem
|
||||||
<Table
|
label="定时器类型"
|
||||||
:data="fieldsListOfListener"
|
name="eventDefinitionType"
|
||||||
size="small"
|
key="eventDefinitionType"
|
||||||
:scroll="{ y: 240 }"
|
>
|
||||||
bordered
|
<Select v-model:value="listenerForm.eventDefinitionType">
|
||||||
style="flex: none"
|
<SelectOption value="date">日期</SelectOption>
|
||||||
>
|
<SelectOption value="duration">持续时长</SelectOption>
|
||||||
<TableColumn title="序号" width="50px" type="index" />
|
<SelectOption value="cycle">循环</SelectOption>
|
||||||
<TableColumn title="字段名称" width="100px" data-index="name" />
|
<SelectOption value="null">无</SelectOption>
|
||||||
<TableColumn
|
</Select>
|
||||||
title="字段类型"
|
</FormItem>
|
||||||
width="80px"
|
<FormItem
|
||||||
:ellipsis="{ showTitle: true }"
|
v-if="
|
||||||
:custom-render="
|
!!listenerForm.eventDefinitionType &&
|
||||||
({ record }: any) =>
|
listenerForm.eventDefinitionType !== 'null'
|
||||||
fieldTypeObject[record.fieldType as keyof typeof fieldType]
|
"
|
||||||
"
|
label="定时器"
|
||||||
/>
|
name="eventTimeDefinitions"
|
||||||
<TableColumn
|
key="eventTimeDefinitions"
|
||||||
title="字段值/表达式"
|
:rules="[{ required: true, message: '请填写定时器配置' }]"
|
||||||
width="100px"
|
>
|
||||||
:ellipsis="{ showTitle: true }"
|
<Input
|
||||||
:custom-render="
|
v-model:value="listenerForm.eventTimeDefinitions"
|
||||||
({ record }: any) => record.string || record.expression
|
allow-clear
|
||||||
"
|
/>
|
||||||
/>
|
</FormItem>
|
||||||
<TableColumn title="操作" width="100px">
|
</template>
|
||||||
<template #default="{ record, index }">
|
</Form>
|
||||||
|
|
||||||
|
<Divider />
|
||||||
|
<div class="mb-2 flex justify-between">
|
||||||
|
<span class="flex items-center">
|
||||||
|
<IconifyIcon icon="ep:menu" class="mr-2 text-gray-600" />
|
||||||
|
注入字段
|
||||||
|
</span>
|
||||||
|
<Button
|
||||||
|
class="flex items-center"
|
||||||
|
size="small"
|
||||||
|
type="link"
|
||||||
|
@click="openListenerFieldForm(null)"
|
||||||
|
>
|
||||||
|
<template #icon>
|
||||||
|
<IconifyIcon class="size-4" icon="ep:plus" />
|
||||||
|
</template>
|
||||||
|
添加字段
|
||||||
|
</Button>
|
||||||
|
</div>
|
||||||
|
<FieldsGrid>
|
||||||
|
<template #action="{ row, rowIndex }">
|
||||||
<Button
|
<Button
|
||||||
size="small"
|
size="small"
|
||||||
type="link"
|
type="link"
|
||||||
@click="openListenerFieldForm(record, index)"
|
@click="openListenerFieldForm(row, rowIndex)"
|
||||||
>
|
>
|
||||||
编辑
|
编辑
|
||||||
</Button>
|
</Button>
|
||||||
@@ -512,32 +540,23 @@ watch(
|
|||||||
size="small"
|
size="small"
|
||||||
type="link"
|
type="link"
|
||||||
danger
|
danger
|
||||||
@click="removeListenerField(record, index)"
|
@click="removeListenerField(row, rowIndex)"
|
||||||
>
|
>
|
||||||
移除
|
移除
|
||||||
</Button>
|
</Button>
|
||||||
</template>
|
</template>
|
||||||
</TableColumn>
|
</FieldsGrid>
|
||||||
</Table>
|
</template>
|
||||||
|
</ListenerDrawer>
|
||||||
<div class="element-drawer__button">
|
|
||||||
<Button size="small" @click="listenerFormModelVisible = false">
|
|
||||||
取 消
|
|
||||||
</Button>
|
|
||||||
<Button size="small" type="primary" @click="saveListenerConfig">
|
|
||||||
保 存
|
|
||||||
</Button>
|
|
||||||
</div>
|
|
||||||
</Drawer>
|
|
||||||
|
|
||||||
<!-- 注入字段 编辑/创建 部分 -->
|
<!-- 注入字段 编辑/创建 部分 -->
|
||||||
<Modal
|
<FieldModal class="w-3/5">
|
||||||
title="字段配置"
|
<Form
|
||||||
v-model:open="listenerFieldFormModelVisible"
|
:label-col="{ span: 4 }"
|
||||||
:width="600"
|
:wrapper-col="{ span: 18 }"
|
||||||
:destroy-on-close="true"
|
:model="listenerFieldForm"
|
||||||
>
|
ref="listenerFieldFormRef"
|
||||||
<Form :model="listenerFieldForm" ref="listenerFieldFormRef">
|
>
|
||||||
<FormItem
|
<FormItem
|
||||||
label="字段名称:"
|
label="字段名称:"
|
||||||
name="name"
|
name="name"
|
||||||
@@ -579,15 +598,7 @@ watch(
|
|||||||
<Input v-model:value="listenerFieldForm.expression" allow-clear />
|
<Input v-model:value="listenerFieldForm.expression" allow-clear />
|
||||||
</FormItem>
|
</FormItem>
|
||||||
</Form>
|
</Form>
|
||||||
<template #footer>
|
</FieldModal>
|
||||||
<Button size="small" @click="listenerFieldFormModelVisible = false">
|
|
||||||
取 消
|
|
||||||
</Button>
|
|
||||||
<Button size="small" type="primary" @click="saveListenerFiled">
|
|
||||||
确 定
|
|
||||||
</Button>
|
|
||||||
</template>
|
|
||||||
</Modal>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- 选择弹窗 -->
|
<!-- 选择弹窗 -->
|
||||||
|
|||||||
Reference in New Issue
Block a user