mirror of
https://gitee.com/dapppp/ruoyi-plus-vben5.git
synced 2026-04-11 03:13:14 +08:00
feat: 后端发起流程
This commit is contained in:
@@ -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 {
|
||||||
|
|||||||
Reference in New Issue
Block a user