223 lines
7.6 KiB
Vue
Raw Normal View History

2023-09-17 17:42:50 +08:00
<template>
<div class="p-2">
<transition :enter-active-class="proxy?.animate.searchAnimate.enter"
:leave-active-class="proxy?.animate.searchAnimate.leave">
<div class="search" v-show="showSearch">
<el-form :model="queryParams" ref="queryFormRef" :inline="true" label-width="68px">
<el-form-item label="表单名称" prop="formName">
<el-input v-model="queryParams.formName" placeholder="请输入表单名称" clearable @keyup.enter="handleQuery" />
</el-form-item>
<el-form-item>
<el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
<el-button icon="Refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
</div>
</transition>
<el-card shadow="never" v-loading="loading">
<template #header>
<el-row :gutter="10" class="mb8">
<right-toolbar v-model:showSearch="showSearch" @queryTable="queryFromList"></right-toolbar>
</el-row>
</template>
<el-row :gutter="12">
<el-col :span="8" style="padding-top: 15px;" v-for="(item, index) in formList" :key="index">
<el-card shadow="hover" style="cursor: pointer;" @click="handleAppay(item)">
<div style="display: flex;justify-content:flex-start;">
<div>
<img
src=""
width="60">
</div>
<div style="display: inline-block;padding-left: 15px;">
<div class="from-font">{{ item.formName }}</div>
<div class="from-time">{{ item.updateTime }}</div>
</div>
</div>
</el-card>
</el-col>
</el-row>
<el-empty description="暂无可用表单" v-if="formList.length === 0" />
</el-card>
<!-- 流程表单设计器对话框 -->
<el-dialog :title="render.title" v-if="render.visible" v-model="render.visible" width="80%" append-to-body>
<div v-loading="fromLoading">
<v-form-render :form-json="{}" :form-data="{}" ref="vfRenderRef" />
</div>
<template #footer>
<span class="dialog-footer">
<el-button v-loading="buttonLoading" @click="render.visible = false">取消</el-button>
<el-button type="success" v-loading="buttonLoading" @click="submitData('draft')">暂存</el-button>
<el-button type="primary" v-loading="buttonLoading" @click="submitData('submit')">提交</el-button>
</span>
</template>
</el-dialog>
<!-- 提交组件 -->
<submitVerify ref="submitVerifyRef" @submitCallback="submitCallback" @cancelCallback="cancelCallback" />
</div>
</template>
<script setup name="BusinessForm" lang="ts">
import { queryList, getForm } from "@/api/workflow/form";
import { FormVO } from "@/api/workflow/form/types";
2023-09-21 21:07:19 +08:00
import { addBusinessForm, updateBusinessForm } from '@/api/workflow/businessForm';
2023-09-17 17:42:50 +08:00
import { BusinessFormForm } from '@/api/workflow/businessForm/types';
import { startWorkFlow } from '@/api/workflow/task';
import SubmitVerify from '@/components/Process/submitVerify.vue';
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
//提交组件
const submitVerifyRef = ref<InstanceType<typeof SubmitVerify>>();
const showSearch = ref(true);
const ids = ref<Array<string | number>>([]);
const formList = ref<FormVO[]>([]);
const loading = ref(true);
const fromLoading = ref(true);
const buttonLoading = ref(false);
const processDefinitionKey = ref<string>('');
const queryFormRef = ref<ElFormInstance>();
const vfRenderRef = ref(null);
const render = reactive<DialogOption>({
visible: false,
title: ''
})
const queryParams = ref<Record<string, any>>({
formName: ''
});
2023-09-21 21:07:19 +08:00
const initFormData = ref<BusinessFormForm>({
2023-09-17 17:42:50 +08:00
id: undefined,
applyCode: undefined,
formId: undefined,
formName: undefined,
content: undefined,
contentValue: undefined
2023-09-21 21:07:19 +08:00
})
2023-09-17 17:42:50 +08:00
const submitFormData = ref<Record<string, any>>({
businessKey: '',
processKey: '',
variables: {}
});
/** 搜索按钮操作 */
const handleQuery = () => {
queryFromList();
}
/** 重置按钮操作 */
const resetQuery = () => {
queryFormRef.value?.resetFields();
handleQuery();
}
/** 查询可用表单 */
const queryFromList = async () => {
loading.value = true
const res = await queryList(queryParams.value);
formList.value = res.data;
loading.value = false
}
/** 申请单据 */
const handleAppay = async (row?: FormVO) => {
render.visible = true;
2023-09-21 21:07:19 +08:00
fromLoading.value = true
2023-09-17 17:42:50 +08:00
render.title = row?.formName;
const formId = row?.formId || ids.value[0];
2023-09-21 21:07:19 +08:00
initFormData.value.formId = row?.formId
initFormData.value.formName = row?.formName
initFormData.value.content = row?.content
2023-09-17 17:42:50 +08:00
const res = await getForm(formId);
if (vfRenderRef.value) {
fromLoading.value = false
if (res.data.wfFormDefinitionVo && res.data.wfFormDefinitionVo.processDefinitionKey) {
processDefinitionKey.value = res.data.wfFormDefinitionVo.processDefinitionKey
}
vfRenderRef.value.setFormJson(res.data.content);
}
}
/** 提交按钮 */
const submitData = (status: string) => {
if (vfRenderRef.value) {
fromLoading.value = true
buttonLoading.value = true;
vfRenderRef.value.getFormData().then((formData) => {
2023-09-21 21:07:19 +08:00
initFormData.value.contentValue = JSON.stringify(formData)
2023-09-17 17:42:50 +08:00
if ('draft' === status) {
2023-09-21 21:07:19 +08:00
addBusinessForm(initFormData.value).then(res => {
2023-09-17 17:42:50 +08:00
proxy?.$modal.msgSuccess("暂存成功");
render.visible = false;
buttonLoading.value = false;
})
} else {
if (!processDefinitionKey.value) {
proxy?.$modal.msgError("未绑定流程!");
buttonLoading.value = false;
fromLoading.value = false;
2023-09-21 21:07:19 +08:00
return
}
if (initFormData.value && initFormData.value.id) {
updateBusinessForm(initFormData.value).then(res => {
initFormData.value = res.data
handleStartWorkFlow(res.data)
})
} else {
addBusinessForm(initFormData.value).then(res => {
initFormData.value = res.data
handleStartWorkFlow(res.data)
})
2023-09-17 17:42:50 +08:00
}
}
})
}
}
//提交申请
const handleStartWorkFlow = async (data: any) => {
submitFormData.value.processKey = processDefinitionKey.value;
submitFormData.value.businessKey = data.id;
submitFormData.value.variables = data.variable;
startWorkFlow(submitFormData.value).then((response: any) => {
if (submitVerifyRef.value) {
submitVerifyRef.value.openDialog(response.data.taskId);
}
});
};
//提交回调
const submitCallback = async () => {
render.visible = false;
buttonLoading.value = false;
fromLoading.value = false;
handleQuery();
};
//取消回调
const cancelCallback = async () => {
buttonLoading.value = false;
fromLoading.value = false;
};
onMounted(() => {
queryFromList();
});
</script>
<style scoped>
.from-font {
font-size: 18px;
font-weight: bold;
vertical-align: top;
height: 30px;
}
.from-time {
font-size: 12px;
vertical-align: bottom;
height: 30px;
}
</style>