2025-08-20 14:39:30 +08:00
|
|
|
|
<template>
|
2025-10-21 18:04:02 +08:00
|
|
|
|
<SimpleForm ref="systemFormRef" :formProps="data.formDataProps" :formModel="{}" :isWorkFlow="props.fromPage != FromPageType.MENU" />
|
2025-08-20 14:39:30 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
<script lang="ts" setup>
|
2025-10-21 18:04:02 +08:00
|
|
|
|
import { reactive, ref, onMounted, createVNode } from 'vue';
|
|
|
|
|
|
import { formProps, formEventConfigs } from './config';
|
2025-08-20 14:39:30 +08:00
|
|
|
|
import SimpleForm from '/@/components/SimpleForm/src/SimpleForm.vue';
|
2025-10-21 18:04:02 +08:00
|
|
|
|
import { addActRuVariable, getActRuVariable, updateActRuVariable, deleteActRuVariable } from '/@/api/editProVar/procVarManage';
|
|
|
|
|
|
import { cloneDeep } from 'lodash-es';
|
|
|
|
|
|
import { FormDataProps } from '/@/components/Designer/src/types';
|
|
|
|
|
|
import { usePermission } from '/@/hooks/web/usePermission';
|
|
|
|
|
|
import { FromPageType } from '/@/enums/workflowEnum';
|
|
|
|
|
|
import { createFormEvent, getFormDataEvent, loadFormEvent, submitFormEvent } from '/@/hooks/web/useFormEvent';
|
|
|
|
|
|
import { changeWorkFlowForm, changeSchemaDisabled } from '/@/hooks/web/useWorkFlowForm';
|
|
|
|
|
|
import { WorkFlowFormParams } from '/@/model/workflow/bpmnConfig';
|
|
|
|
|
|
import { ExclamationCircleOutlined } from '@ant-design/icons-vue';
|
|
|
|
|
|
import { Modal } from 'ant-design-vue';
|
|
|
|
|
|
import { useMessage } from '/@/hooks/web/useMessage';
|
|
|
|
|
|
import { useI18n } from '/@/hooks/web/useI18n';
|
|
|
|
|
|
import { useRouter } from 'vue-router';
|
2025-08-20 14:39:30 +08:00
|
|
|
|
|
|
|
|
|
|
const router = useRouter();
|
2025-10-21 18:04:02 +08:00
|
|
|
|
const { filterFormSchemaAuth } = usePermission();
|
2025-08-20 14:39:30 +08:00
|
|
|
|
const RowKey = 'id';
|
|
|
|
|
|
const emits = defineEmits(['changeUploadComponentIds', 'loadingCompleted', 'form-mounted']);
|
|
|
|
|
|
const props = defineProps({
|
|
|
|
|
|
fromPage: {
|
|
|
|
|
|
type: Number,
|
2025-10-21 18:04:02 +08:00
|
|
|
|
default: FromPageType.MENU
|
|
|
|
|
|
}
|
2025-08-20 14:39:30 +08:00
|
|
|
|
});
|
|
|
|
|
|
const systemFormRef = ref();
|
|
|
|
|
|
const data: { formDataProps: FormDataProps } = reactive({
|
2025-10-21 18:04:02 +08:00
|
|
|
|
formDataProps: cloneDeep(formProps)
|
2025-08-20 14:39:30 +08:00
|
|
|
|
});
|
|
|
|
|
|
const state = reactive({
|
2025-10-21 18:04:02 +08:00
|
|
|
|
formModel: {}
|
2025-08-20 14:39:30 +08:00
|
|
|
|
});
|
2025-10-21 18:04:02 +08:00
|
|
|
|
const { notification } = useMessage();
|
|
|
|
|
|
const { t } = useI18n();
|
2025-08-20 14:39:30 +08:00
|
|
|
|
|
|
|
|
|
|
onMounted(async () => {
|
|
|
|
|
|
try {
|
|
|
|
|
|
if (props.fromPage == FromPageType.MENU) {
|
|
|
|
|
|
setMenuPermission();
|
2025-10-21 18:04:02 +08:00
|
|
|
|
await createFormEvent(formEventConfigs, state.formModel, systemFormRef.value, formProps.schemas); //表单事件:初始化表单
|
|
|
|
|
|
await loadFormEvent(formEventConfigs, state.formModel, systemFormRef.value, formProps.schemas); //表单事件:加载表单
|
2025-08-20 14:39:30 +08:00
|
|
|
|
} else if (props.fromPage == FromPageType.FLOW) {
|
|
|
|
|
|
emits('loadingCompleted'); //告诉系统表单已经加载完毕
|
|
|
|
|
|
// loadingCompleted后 工作流页面直接利用Ref调用setWorkFlowForm方法
|
|
|
|
|
|
} else if (props.fromPage == FromPageType.PREVIEW) {
|
|
|
|
|
|
// 预览 无需权限,表单事件也无需执行
|
|
|
|
|
|
} else if (props.fromPage == FromPageType.DESKTOP) {
|
|
|
|
|
|
// 桌面设计 表单事件需要执行
|
|
|
|
|
|
emits('loadingCompleted'); //告诉系统表单已经加载完毕
|
2025-10-21 18:04:02 +08:00
|
|
|
|
await createFormEvent(formEventConfigs, state.formModel, systemFormRef.value, formProps.schemas); //表单事件:初始化表单
|
|
|
|
|
|
await loadFormEvent(formEventConfigs, state.formModel, systemFormRef.value, formProps.schemas); //表单事件:加载表单
|
2025-08-20 14:39:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
emits('form-mounted', formProps);
|
2025-10-21 18:04:02 +08:00
|
|
|
|
} catch (error) {}
|
2025-08-20 14:39:30 +08:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
// 根据菜单页面权限,设置表单属性(必填,禁用,显示)
|
|
|
|
|
|
function setMenuPermission() {
|
|
|
|
|
|
data.formDataProps.schemas = filterFormSchemaAuth(formProps.schemas!);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 校验form 通过返回表单数据
|
|
|
|
|
|
async function validate() {
|
|
|
|
|
|
let values = [];
|
|
|
|
|
|
try {
|
|
|
|
|
|
values = await systemFormRef.value?.validate();
|
|
|
|
|
|
//添加隐藏组件
|
|
|
|
|
|
if (data.formDataProps.hiddenComponent?.length) {
|
|
|
|
|
|
data.formDataProps.hiddenComponent.forEach((component) => {
|
|
|
|
|
|
values[component.bindField] = component.value;
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
} finally {
|
|
|
|
|
|
}
|
|
|
|
|
|
return values;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 根据行唯一ID查询行数据,并设置表单数据 【编辑】
|
|
|
|
|
|
async function setFormDataFromId(rowId, skipUpdate) {
|
|
|
|
|
|
try {
|
|
|
|
|
|
const currentRoute = router.currentRoute.value;
|
|
|
|
|
|
const queryParams = currentRoute.query;
|
|
|
|
|
|
let reqParam = {
|
|
|
|
|
|
name: queryParams.name,
|
|
|
|
|
|
type: queryParams.type,
|
|
|
|
|
|
value: queryParams.value,
|
2026-01-07 17:54:57 +08:00
|
|
|
|
processId: queryParams.processId
|
2025-08-20 14:39:30 +08:00
|
|
|
|
};
|
|
|
|
|
|
const record = await getActRuVariable(reqParam);
|
|
|
|
|
|
if (skipUpdate) {
|
|
|
|
|
|
return record;
|
|
|
|
|
|
}
|
|
|
|
|
|
reqParam.value = record;
|
|
|
|
|
|
setFieldsValue(reqParam);
|
|
|
|
|
|
state.formModel = reqParam;
|
|
|
|
|
|
await getFormDataEvent(formEventConfigs, state.formModel, systemFormRef.value, formProps.schemas); //表单事件:获取表单数据
|
|
|
|
|
|
return reqParam;
|
2025-10-21 18:04:02 +08:00
|
|
|
|
} catch (error) {}
|
2025-08-20 14:39:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 辅助设置表单数据
|
|
|
|
|
|
function setFieldsValue(record) {
|
|
|
|
|
|
systemFormRef.value.setFieldsValue(record);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 重置表单数据
|
|
|
|
|
|
async function resetFields() {
|
|
|
|
|
|
await systemFormRef.value.resetFields();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 设置表单数据全部为Disabled 【查看】
|
|
|
|
|
|
async function setDisabledForm(isDisabled) {
|
|
|
|
|
|
data.formDataProps.schemas = changeSchemaDisabled(cloneDeep(data.formDataProps.schemas), isDisabled);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 获取行键值
|
|
|
|
|
|
function getRowKey() {
|
|
|
|
|
|
return RowKey;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 更新api表单数据
|
2025-10-21 18:04:02 +08:00
|
|
|
|
async function update({ values, rowId }) {
|
2025-08-20 14:39:30 +08:00
|
|
|
|
try {
|
|
|
|
|
|
let res = systemFormRef.value.getFieldsValue();
|
2025-10-21 18:04:02 +08:00
|
|
|
|
debugger;
|
2025-08-20 14:39:30 +08:00
|
|
|
|
let saveVal = await updateActRuVariable(res);
|
2025-10-21 18:04:02 +08:00
|
|
|
|
await submitFormEvent(formEventConfigs, state.formModel, systemFormRef.value, formProps.schemas); //表单事件:提交表单
|
2025-08-20 14:39:30 +08:00
|
|
|
|
return saveVal;
|
2025-10-21 18:04:02 +08:00
|
|
|
|
} catch (error) {}
|
2025-08-20 14:39:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 新增api表单数据
|
|
|
|
|
|
async function add(values) {
|
|
|
|
|
|
try {
|
|
|
|
|
|
state.formModel = values;
|
|
|
|
|
|
let saveVal = await addActRuVariable(values);
|
2025-10-21 18:04:02 +08:00
|
|
|
|
await submitFormEvent(formEventConfigs, state.formModel, systemFormRef.value, formProps.schemas); //表单事件:提交表单
|
2025-08-20 14:39:30 +08:00
|
|
|
|
return saveVal;
|
2025-10-21 18:04:02 +08:00
|
|
|
|
} catch (error) {}
|
2025-08-20 14:39:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 根据工作流页面权限,设置表单属性(必填,禁用,显示)
|
|
|
|
|
|
async function setWorkFlowForm(obj: WorkFlowFormParams) {
|
|
|
|
|
|
try {
|
|
|
|
|
|
let flowData = changeWorkFlowForm(cloneDeep(formProps), obj);
|
2025-10-21 18:04:02 +08:00
|
|
|
|
let { buildOptionJson, uploadComponentIds, formModels, isViewProcess } = flowData;
|
2025-08-20 14:39:30 +08:00
|
|
|
|
data.formDataProps = buildOptionJson;
|
|
|
|
|
|
emits('changeUploadComponentIds', uploadComponentIds); //工作流中必须保存上传组件id【附件汇总需要】
|
|
|
|
|
|
if (isViewProcess) {
|
|
|
|
|
|
setDisabledForm(); //查看
|
|
|
|
|
|
}
|
|
|
|
|
|
state.formModel = formModels;
|
2025-10-21 18:04:02 +08:00
|
|
|
|
if (formModels[RowKey]) {
|
|
|
|
|
|
setFormDataFromId(formModels[RowKey], false);
|
2025-08-20 14:39:30 +08:00
|
|
|
|
} else {
|
2025-10-21 18:04:02 +08:00
|
|
|
|
setFieldsValue(formModels);
|
2025-08-20 14:39:30 +08:00
|
|
|
|
}
|
2025-10-21 18:04:02 +08:00
|
|
|
|
} catch (error) {}
|
|
|
|
|
|
await createFormEvent(formEventConfigs, state.formModel, systemFormRef.value, formProps.schemas); //表单事件:初始化表单
|
|
|
|
|
|
await loadFormEvent(formEventConfigs, state.formModel, systemFormRef.value, formProps.schemas); //表单事件:加载表单
|
2025-08-20 14:39:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 详情页删除功能
|
|
|
|
|
|
function handleDelete(record: Recordable) {
|
|
|
|
|
|
deleteList([record]);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function deleteList(ids) {
|
|
|
|
|
|
Modal.confirm({
|
|
|
|
|
|
title: '提示信息',
|
|
|
|
|
|
icon: createVNode(ExclamationCircleOutlined),
|
|
|
|
|
|
content: '是否确认删除?',
|
|
|
|
|
|
okText: '确认',
|
|
|
|
|
|
cancelText: '取消',
|
|
|
|
|
|
onOk() {
|
|
|
|
|
|
deleteActRuVariable(ids).then((_) => {
|
|
|
|
|
|
notification.success({
|
2026-03-27 14:59:14 +08:00
|
|
|
|
message: '提示',
|
2025-10-21 18:04:02 +08:00
|
|
|
|
description: t('删除成功!')
|
2025-08-20 14:39:30 +08:00
|
|
|
|
});
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
2025-10-21 18:04:02 +08:00
|
|
|
|
onCancel() {}
|
2025-08-20 14:39:30 +08:00
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
defineExpose({
|
|
|
|
|
|
setFieldsValue,
|
|
|
|
|
|
resetFields,
|
|
|
|
|
|
validate,
|
|
|
|
|
|
add,
|
|
|
|
|
|
update,
|
|
|
|
|
|
setFormDataFromId,
|
|
|
|
|
|
setDisabledForm,
|
|
|
|
|
|
setMenuPermission,
|
|
|
|
|
|
setWorkFlowForm,
|
|
|
|
|
|
getRowKey,
|
|
|
|
|
|
handleDelete
|
|
|
|
|
|
});
|
|
|
|
|
|
</script>
|