feat: 后端发起流程

master
dap 4 months ago
parent a4a7f7d096
commit 45b584b092

@ -62,6 +62,10 @@ export interface StartWorkFlowReqData {
* *
*/ */
variables: Record<string, any>; variables: Record<string, any>;
/**
*
*/
flowInstanceBizExtBo?: Record<string, any>;
} }
export interface TaskOperationData { export interface TaskOperationData {

@ -60,3 +60,15 @@ export function leaveUpdate(data: LeaveForm) {
export function leaveRemove(id: ID | IDS) { export function leaveRemove(id: ID | IDS) {
return requestClient.deleteWithMsg<void>(`/workflow/leave/${id}`); return requestClient.deleteWithMsg<void>(`/workflow/leave/${id}`);
} }
/**
* & ()
* @param data data
* @returns void
*/
export function submitAndStartWorkflow(data: LeaveForm) {
return requestClient.postWithMsg<void>(
'/workflow/leave/submitAndFlowStart',
data,
);
}

@ -121,6 +121,22 @@ export const modalSchema: () => VbenFormSchema[] = () => [
triggerFields: [''], triggerFields: [''],
}, },
}, },
{
label: '发起类型',
fieldName: 'type',
component: 'Select',
help: '这里仅仅为了测试, 实际不应该包含此字段',
componentProps: {
options: [
{
label: '前端发起(可选审批人, 选抄送人, 上传附件)',
value: 'frontend',
},
{ label: '后端发起(自行编写构造发起参数)', value: 'backend' },
],
},
defaultValue: 'frontend',
},
{ {
label: '请假类型', label: '请假类型',
fieldName: 'leaveType', fieldName: 'leaveType',

@ -15,7 +15,12 @@ import { useVbenForm } from '#/adapter/form';
import { startWorkFlow } from '#/api/workflow/task'; import { startWorkFlow } from '#/api/workflow/task';
import { applyModal } from '../components'; import { applyModal } from '../components';
import { leaveAdd, leaveInfo, leaveUpdate } from './api'; import {
leaveAdd,
leaveInfo,
leaveUpdate,
submitAndStartWorkflow,
} from './api';
import { modalSchema } from './data'; import { modalSchema } from './data';
const route = useRoute(); const route = useRoute();
@ -58,10 +63,6 @@ const router = useRouter();
* 提取通用逻辑 * 提取通用逻辑
*/ */
async function handleSaveOrUpdate() { async function handleSaveOrUpdate() {
const { valid } = await formApi.validate();
if (!valid) {
return;
}
let data = cloneDeep(await formApi.getValues()) as any; let data = cloneDeep(await formApi.getValues()) as any;
data = omit(data, 'flowType'); data = omit(data, 'flowType');
// //
@ -96,28 +97,44 @@ async function handleTempSave() {
async function handleStartWorkFlow() { async function handleStartWorkFlow() {
loading.value = true; loading.value = true;
try { try {
// const { valid } = await formApi.validate();
const leaveResp = await handleSaveOrUpdate(); if (!valid) {
// return;
const taskVariables = { }
leaveDays: leaveResp!.leaveDays, //
userList: ['1', '3', '4'], const { type } = await formApi.getValues();
}; if (type === 'backend') {
const formValues = await formApi.getValues(); let data = cloneDeep(await formApi.getValues()) as any;
const flowCode = formValues?.flowType ?? 'leave1'; data = omit(data, 'flowType', 'type');
const startWorkFlowData: StartWorkFlowReqData = { //
businessId: leaveResp!.id, data.startDate = dayjs(data.dateRange[0]).format('YYYY-MM-DD HH:mm:ss');
flowCode, data.endDate = dayjs(data.dateRange[1]).format('YYYY-MM-DD HH:mm:ss');
variables: taskVariables, await submitAndStartWorkflow(data);
}; await handleCompleteOrCancel();
const { taskId } = await startWorkFlow(startWorkFlowData); } else {
// //
applyModalApi.setData({ const leaveResp = await handleSaveOrUpdate();
taskId, //
taskVariables, const taskVariables = {
variables: {}, leaveDays: leaveResp!.leaveDays,
}); userList: ['1', '3', '4'],
applyModalApi.open(); };
const formValues = await formApi.getValues();
const flowCode = formValues?.flowType ?? 'leave1';
const startWorkFlowData: StartWorkFlowReqData = {
businessId: leaveResp!.id,
flowCode,
variables: taskVariables,
};
const { taskId } = await startWorkFlow(startWorkFlowData);
//
applyModalApi.setData({
taskId,
taskVariables,
variables: {},
});
applyModalApi.open();
}
} catch (error) { } catch (error) {
console.error(error); console.error(error);
} finally { } finally {

Loading…
Cancel
Save