Skip to content

Commit a57840c

Browse files
committed
feat: 发起流程页面-流程时间线的数据获取接口联调与展示
1 parent c1109e9 commit a57840c

File tree

5 files changed

+50
-130
lines changed

5 files changed

+50
-130
lines changed

src/assets/svgs/bpm/finish.svg

Lines changed: 1 addition & 0 deletions
Loading

src/views/bpm/processInstance/create/ProcessDefinitionDetail.vue

Lines changed: 36 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -61,9 +61,14 @@
6161
</form-create>
6262
</el-col>
6363

64-
<el-col :span="7">
65-
<!-- 审批记录时间线 -->
66-
<!-- <ProcessInstanceTimeline ref="timelineRef" :approve-nodes="approveNodes" /> -->
64+
<el-col :span="6" :offset="1">
65+
<!-- 流程时间线 -->
66+
<ProcessInstanceTimeline
67+
ref="timelineRef"
68+
:approve-nodes="approveNodes"
69+
:show-status-icon="false"
70+
candidateField="candidateUserList"
71+
/>
6772
</el-col>
6873
</el-row>
6974
</el-scrollbar>
@@ -82,6 +87,7 @@
8287
<div class="b-t-solid border-t-1px border-[var(--el-border-color)]">
8388
<!-- 操作栏按钮 -->
8489
<div
90+
v-if="activeTab === 'form'"
8591
class="h-50px bottom-10 text-14px flex items-center color-#32373c dark:color-#fff font-bold btn-container"
8692
>
8793
<el-button plain type="success" @click="submitForm">
@@ -99,6 +105,7 @@
99105
<script lang="ts" setup>
100106
import { setConfAndFields2 } from '@/utils/formCreate'
101107
import ProcessInstanceBpmnViewer from '../detail/ProcessInstanceBpmnViewer.vue'
108+
import ProcessInstanceTimeline from '../detail/ProcessInstanceTimeline.vue'
102109
import type { ApiAttrs } from '@form-create/element-ui/types/config'
103110
import { useTagsViewStore } from '@/store/modules/tagsView'
104111
import * as ProcessInstanceApi from '@/api/bpm/processInstance'
@@ -126,11 +133,13 @@ const startUserSelectAssignees = ref({}) // 发起人选择审批人的数据
126133
const startUserSelectAssigneesFormRules = ref({}) // 发起人选择审批人的表单 Rules
127134
const userList = ref<any[]>([]) // 用户列表
128135
const bpmnXML: any = ref(null) // BPMN 数据
129-
130136
/** 当前的Tab */
131137
const activeTab = ref('form')
132138
const emit = defineEmits(['cancel'])
133-
/** 处理选择流程的按钮操作 **/
139+
// 审批节点信息
140+
const approveNodes = ref<ProcessInstanceApi.ApprovalNodeInfo[]>([])
141+
142+
/** 设置表单信息、获取流程图数据 **/
134143
const initProcessInfo = async (row, formVariables?) => {
135144
// 重置指定审批人
136145
startUserSelectTasks.value = []
@@ -141,6 +150,11 @@ const initProcessInfo = async (row, formVariables?) => {
141150
if (row.formType == 10) {
142151
// 设置表单
143152
setConfAndFields2(detailForm, row.formConf, row.formFields, formVariables)
153+
await nextTick()
154+
fApi.value?.btn.show(false) // 隐藏提交按钮
155+
// 获取流程审批信息
156+
getApprovalDetail(row)
157+
144158
// 加载流程图
145159
const processDefinitionDetail = await DefinitionApi.getProcessDefinition(row.id)
146160
if (processDefinitionDetail) {
@@ -174,6 +188,23 @@ const initProcessInfo = async (row, formVariables?) => {
174188
// 这里暂时无需加载流程图,因为跳出到另外个 Tab;
175189
}
176190
}
191+
192+
/** 获取审批详情 */
193+
const getApprovalDetail = async (row) => {
194+
try {
195+
const param = {
196+
processDefinitionId: row.id
197+
}
198+
const data = await ProcessInstanceApi.getApprovalDetail(param)
199+
if (!data) {
200+
message.error('查询不到审批详情信息!')
201+
return
202+
}
203+
// 获取审批节点,显示 Timeline 的数据
204+
approveNodes.value = data.approveNodes
205+
} finally {
206+
}
207+
}
177208
/** 提交按钮 */
178209
const submitForm = async (formData) => {
179210
if (!fApi.value || props.selectProcessDefinition) {

src/views/bpm/processInstance/create/index_new.vue

Lines changed: 0 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -56,7 +56,6 @@ import * as DefinitionApi from '@/api/bpm/definition'
5656
import * as ProcessInstanceApi from '@/api/bpm/processInstance'
5757
import { CategoryApi } from '@/api/bpm/category'
5858
import ProcessDefinitionDetail from './ProcessDefinitionDetail.vue'
59-
import { categoryList as cl, processDefinitionList as pl } from './mock'
6059
6160
defineOptions({ name: 'BpmProcessInstanceCreate' })
6261
@@ -74,17 +73,13 @@ const getList = async () => {
7473
try {
7574
// 流程分类
7675
categoryList.value = await CategoryApi.getCategorySimpleList()
77-
// 测试数据
78-
categoryList.value = cl
7976
if (categoryList.value.length > 0) {
8077
categoryActive.value = categoryList.value[0]
8178
}
8279
// 流程定义
8380
processDefinitionList.value = await DefinitionApi.getProcessDefinitionList({
8481
suspensionState: 1
8582
})
86-
// 测试数据
87-
processDefinitionList.value = pl as any
8883
8984
// 如果 processInstanceId 非空,说明是重新发起
9085
if (processInstanceId?.length > 0) {

src/views/bpm/processInstance/create/mock.js

Lines changed: 0 additions & 117 deletions
This file was deleted.

src/views/bpm/processInstance/detail/ProcessInstanceTimeline.vue

Lines changed: 13 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,7 @@
1515
>
1616
<img class="w-full h-full" :src="getApprovalNodeImg(activity.nodeType)" alt="" />
1717
<div
18+
v-if="showStatusIcon"
1819
class="position-absolute top-17px left-17px bg-#fff rounded-full flex items-center p-2px"
1920
>
2021
<el-icon :size="12" :color="getApprovalNodeColor(activity.status)">
@@ -131,11 +132,18 @@ import auditorSvg from '@/assets/svgs/bpm/auditor.svg'
131132
import copySvg from '@/assets/svgs/bpm/copy.svg'
132133
import conditionSvg from '@/assets/svgs/bpm/condition.svg'
133134
import parallelSvg from '@/assets/svgs/bpm/parallel.svg'
135+
import finishSvg from '@/assets/svgs/bpm/finish.svg'
134136
135137
defineOptions({ name: 'BpmProcessInstanceTimeline' })
136-
defineProps<{
137-
approveNodes: ProcessInstanceApi.ApprovalNodeInfo[] // 审批节点信息
138-
}>()
138+
withDefaults(
139+
defineProps<{
140+
approveNodes: ProcessInstanceApi.ApprovalNodeInfo[] // 审批节点信息
141+
showStatusIcon?: boolean // 是否显示头像右下角状态图标
142+
}>(),
143+
{
144+
showStatusIcon: true // 默认值为 true
145+
}
146+
)
139147
140148
// 审批节点
141149
const statusIconMap2 = {
@@ -180,6 +188,8 @@ const statusIconMap = {
180188
}
181189
182190
const nodeTypeSvgMap = {
191+
// 结束节点
192+
[NodeType.END_EVENT_NODE]: { color: '#ffffff', svg: finishSvg },
183193
// 发起人节点
184194
[NodeType.START_USER_NODE]: { color: '#ffffff', svg: starterSvg },
185195
// 审批人节点

0 commit comments

Comments
 (0)