feat: 后端发起流程

master
dap 4 months ago
parent a4a7f7d096
commit 45b584b092

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

@ -60,3 +60,15 @@ export function leaveUpdate(data: LeaveForm) {
export function leaveRemove(id: ID | IDS) {
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: [''],
},
},
{
label: '发起类型',
fieldName: 'type',
component: 'Select',
help: '这里仅仅为了测试, 实际不应该包含此字段',
componentProps: {
options: [
{
label: '前端发起(可选审批人, 选抄送人, 上传附件)',
value: 'frontend',
},
{ label: '后端发起(自行编写构造发起参数)', value: 'backend' },
],
},
defaultValue: 'frontend',
},
{
label: '请假类型',
fieldName: 'leaveType',

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

Loading…
Cancel
Save