【功能修改】 新审批页面 v4 部分修改

pull/582/head
jason 2024-10-18 21:16:44 +08:00
parent 0f8522e306
commit 5267fe459f
6 changed files with 28 additions and 23 deletions

View File

@ -507,7 +507,7 @@ OPERATION_BUTTON_NAME.set(OperationButtonType.REJECT, '拒绝')
OPERATION_BUTTON_NAME.set(OperationButtonType.TRANSFER, '转办') OPERATION_BUTTON_NAME.set(OperationButtonType.TRANSFER, '转办')
OPERATION_BUTTON_NAME.set(OperationButtonType.DELEGATE, '委派') OPERATION_BUTTON_NAME.set(OperationButtonType.DELEGATE, '委派')
OPERATION_BUTTON_NAME.set(OperationButtonType.ADD_SIGN, '加签') OPERATION_BUTTON_NAME.set(OperationButtonType.ADD_SIGN, '加签')
OPERATION_BUTTON_NAME.set(OperationButtonType.RETURN, '退') OPERATION_BUTTON_NAME.set(OperationButtonType.RETURN, '退')
OPERATION_BUTTON_NAME.set(OperationButtonType.COPY, '抄送') OPERATION_BUTTON_NAME.set(OperationButtonType.COPY, '抄送')
// 默认的按钮权限设置 // 默认的按钮权限设置

View File

@ -119,7 +119,6 @@ const saveConfig = async () => {
currentNode.value.fieldsPermission = fieldsPermissionConfig.value currentNode.value.fieldsPermission = fieldsPermissionConfig.value
// //
currentNode.value.buttonsSetting = START_USER_BUTTON_SETTING currentNode.value.buttonsSetting = START_USER_BUTTON_SETTING
console.log('currentNode.value.buttonsSetting==>', currentNode.value.buttonsSetting)
settingVisible.value = false settingVisible.value = false
return true return true
} }

View File

@ -1,6 +1,6 @@
<template> <template>
<el-card v-loading="loading" class="box-card"> <el-card v-loading="loading" class="box-card">
<template #header> <template #header v-if="showHeader">
<span class="el-icon-picture-outline">流程图</span> <span class="el-icon-picture-outline">流程图</span>
</template> </template>
<MyProcessViewer key="designer" :xml="view.bpmnXml" :view="view" class="h-700px" /> <MyProcessViewer key="designer" :xml="view.bpmnXml" :view="view" class="h-700px" />
@ -16,7 +16,8 @@ defineOptions({ name: 'BpmProcessInstanceBpmnViewer' })
const props = defineProps({ const props = defineProps({
loading: propTypes.bool.def(false), // loading: propTypes.bool.def(false), //
id: propTypes.string, // id: propTypes.string, //
bpmnXml: propTypes.string // BPMN XML bpmnXml: propTypes.string, // BPMN XML
showHeader: propTypes.bool.def(true), //
}) })
const view = ref({ const view = ref({

View File

@ -391,7 +391,7 @@
</div> </div>
</el-popover> </el-popover>
<!--按钮 这个对应发起人的取消, 只有发起人可以取消 --> <!--按钮 这个对应发起人的取消, 只有发起人可以取消 -->
<el-popover <el-popover
:visible="popOverVisible.cancel" :visible="popOverVisible.cancel"
placement="top-start" placement="top-start"
@ -401,7 +401,7 @@
> >
<template #reference> <template #reference>
<div @click="openPopover('cancel')" class="hover-bg-gray-100 rounded-xl p-6px"> <div @click="openPopover('cancel')" class="hover-bg-gray-100 rounded-xl p-6px">
<Icon :size="14" icon="fa:mail-reply" />&nbsp; <Icon :size="14" icon="fa:mail-reply" />&nbsp;
</div> </div>
</template> </template>
<div class="flex flex-col flex-1 pt-20px px-20px" v-loading="formLoading"> <div class="flex flex-col flex-1 pt-20px px-20px" v-loading="formLoading">
@ -413,18 +413,18 @@
:rules="genericRule" :rules="genericRule"
label-width="100px" label-width="100px"
> >
<el-form-item label="消理由" prop="cancelReason"> <el-form-item label="消理由" prop="cancelReason">
<span class=" text-#878c93 text-12px">&nbsp; 消后该审批流程将自动结束</span> <span class=" text-#878c93 text-12px">&nbsp; 消后该审批流程将自动结束</span>
<el-input <el-input
v-model="genericForm.cancelReason" v-model="genericForm.cancelReason"
clearable clearable
placeholder="请输入消理由" placeholder="请输入消理由"
type="textarea" type="textarea"
:rows="3" :rows="3"
/> />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button :disabled="formLoading" type="primary" @click="handleCancel()"></el-button> <el-button :disabled="formLoading" type="primary" @click="handleCancel()"></el-button>
<el-button @click="popOverVisible.cancel = false"> 取消 </el-button> <el-button @click="popOverVisible.cancel = false"> 取消 </el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
@ -493,11 +493,12 @@ const formRef = ref()
const genericRule = reactive({ const genericRule = reactive({
reason: [{ required: true, message: '审批意见不能为空', trigger: 'blur' }], reason: [{ required: true, message: '审批意见不能为空', trigger: 'blur' }],
returnReason: [{ required: true, message: '退回理由不能为空', trigger: 'blur' }], returnReason: [{ required: true, message: '退回理由不能为空', trigger: 'blur' }],
cancelReason: [{ required: true, message: '消理由不能为空', trigger: 'blur' }], cancelReason: [{ required: true, message: '消理由不能为空', trigger: 'blur' }],
copyUserIds: [{ required: true, message: '抄送人不能为空', trigger: 'change' }], copyUserIds: [{ required: true, message: '抄送人不能为空', trigger: 'change' }],
assigneeUserId: [{ required: true, message: '新审批人不能为空', trigger: 'change' }], assigneeUserId: [{ required: true, message: '新审批人不能为空', trigger: 'change' }],
delegateUserId: [{ required: true, message: '接收人不能为空', trigger: 'change' }], delegateUserId: [{ required: true, message: '接收人不能为空', trigger: 'change' }],
addSignUserIds: [{ required: true, message: '加签处理人不能为空', trigger: 'change' }] addSignUserIds: [{ required: true, message: '加签处理人不能为空', trigger: 'change' }],
targetTaskDefinitionKey: [{ required: true, message: '退回节点不能为空', trigger: 'change' }]
}) })
/** 监听 approveFormFApis实现它对应的 form-create 初始化后,隐藏掉对应的表单提交按钮 */ /** 监听 approveFormFApis实现它对应的 form-create 初始化后,隐藏掉对应的表单提交按钮 */
@ -530,7 +531,9 @@ const openPopover = (type: string) => {
popOverVisible.value[item] = false popOverVisible.value[item] = false
} }
}) })
nextTick().then(() => {
formRef.value.resetFields() formRef.value.resetFields()
})
} }
/** 处理审批通过和不通过的操作 */ /** 处理审批通过和不通过的操作 */
@ -814,7 +817,7 @@ defineExpose({ loadTodoTask })
.btn-container { .btn-container {
> div { > div {
display: flex; display: flex;
margin: 0 15px; margin: 0 8px;
cursor: pointer; cursor: pointer;
align-items: center; align-items: center;

View File

@ -1,6 +1,6 @@
<template> <template>
<el-card v-loading="loading" class="box-card"> <el-card v-loading="loading" class="box-card">
<template #header> <template #header v-if="showHeader">
<span class="el-icon-picture-outline">审批记录</span> <span class="el-icon-picture-outline">审批记录</span>
</template> </template>
<el-col :offset="3" :span="17"> <el-col :offset="3" :span="17">
@ -104,7 +104,8 @@ defineOptions({ name: 'BpmProcessInstanceTaskList' })
defineProps({ defineProps({
loading: propTypes.bool, // loading: propTypes.bool, //
processInstance: propTypes.object, // processInstance: propTypes.object, //
tasks: propTypes.arrayOf(propTypes.object) // tasks: propTypes.arrayOf(propTypes.object), //
showHeader: propTypes.bool.def(true), //
}) })
/** 获得流程实例对应的颜色 */ /** 获得流程实例对应的颜色 */

View File

@ -1,5 +1,5 @@
<template> <template>
<ContentWrap :bodyStyle="{ padding: '10px 20px' }" class="position-relative"> <ContentWrap :bodyStyle="{ padding: '10px 20px 0' }" class="position-relative">
<div class="processInstance-wrap-main"> <div class="processInstance-wrap-main">
<el-scrollbar> <el-scrollbar>
<img <img
@ -73,7 +73,7 @@
<!-- 流程图 --> <!-- 流程图 -->
<el-tab-pane label="流程图" name="diagram"> <el-tab-pane label="流程图" name="diagram">
<div class="form-scroll-area"> <div class="form-scroll-area">
<ProcessInstanceBpmnViewer :id="`${id}`" :loading="processInstanceLoading" /> <ProcessInstanceBpmnViewer :id="`${id}`" :loading="processInstanceLoading" :show-header="false"/>
</div> </div>
</el-tab-pane> </el-tab-pane>
@ -85,6 +85,7 @@
:loading="tasksLoad" :loading="tasksLoad"
:process-instance="processInstance" :process-instance="processInstance"
:tasks="tasks" :tasks="tasks"
:show-header="false"
/> />
</el-scrollbar> </el-scrollbar>
</div> </div>
@ -305,27 +306,27 @@ onMounted(async () => {
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
$wrap-padding-height: 30px; $wrap-padding-height: 20px;
$wrap-margin-height: 15px; $wrap-margin-height: 15px;
$button-height: 51px; $button-height: 51px;
$process-header-height: 194px; $process-header-height: 194px;
.processInstance-wrap-main { .processInstance-wrap-main {
height: calc( height: calc(
100vh - var(--top-tool-height) - var(--tags-view-height) - var(--app-footer-height) - 45px 100vh - var(--top-tool-height) - var(--tags-view-height) - var(--app-footer-height) - 35px
); );
max-height: calc( max-height: calc(
100vh - var(--top-tool-height) - var(--tags-view-height) - var(--app-footer-height) - 45px 100vh - var(--top-tool-height) - var(--tags-view-height) - var(--app-footer-height) - 35px
); );
overflow: auto; overflow: auto;
.form-scroll-area { .form-scroll-area {
height: calc( height: calc(
100vh - var(--top-tool-height) - var(--tags-view-height) - var(--app-footer-height) - 45px - 100vh - var(--top-tool-height) - var(--tags-view-height) - var(--app-footer-height) - 35px -
$process-header-height - 40px $process-header-height - 40px
); );
max-height: calc( max-height: calc(
100vh - var(--top-tool-height) - var(--tags-view-height) - var(--app-footer-height) - 45px - 100vh - var(--top-tool-height) - var(--tags-view-height) - var(--app-footer-height) - 35px -
$process-header-height - 40px $process-header-height - 40px
); );
overflow: auto; overflow: auto;