|
|
|
|
@ -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 {
|
|
|
|
|
|