Vue3 重构:流程实例的详情(流程任务列表)

liutao_branch
YunaiV 3 years ago
parent 4388d6565a
commit 7587acedb0

@ -97,9 +97,9 @@
</ContentWrap> </ContentWrap>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { useUserStore } from '@/store/modules/user'
import { setConfAndFields2 } from '@/utils/formCreate' import { setConfAndFields2 } from '@/utils/formCreate'
import type { ApiAttrs } from '@form-create/element-ui/types/config' import type { ApiAttrs } from '@form-create/element-ui/types/config'
import { useUserStore } from '@/store/modules/user'
import * as DefinitionApi from '@/api/bpm/definition' import * as DefinitionApi from '@/api/bpm/definition'
import * as ProcessInstanceApi from '@/api/bpm/processInstance' import * as ProcessInstanceApi from '@/api/bpm/processInstance'
import * as TaskApi from '@/api/bpm/task' import * as TaskApi from '@/api/bpm/task'
@ -177,95 +177,101 @@ const handleBack = async (task) => {
console.log(task) console.log(task)
} }
// ========== ========== /** 获得详情 */
onMounted(() => {
getDetail()
})
const getDetail = () => { const getDetail = () => {
// 1. // 1.
processInstanceLoading.value = true getProcessInstance()
ProcessInstanceApi.getProcessInstanceApi(id) // 2.
.then((data) => { getTaskList()
if (!data) { }
message.error('查询不到流程信息!')
return
}
processInstance.value = data
// /** 加载流程实例 */
const processDefinition = data.processDefinition const getProcessInstance = async () => {
if (processDefinition.formType === 10) { try {
setConfAndFields2( processInstanceLoading.value = true
detailForm, const data = await ProcessInstanceApi.getProcessInstanceApi(id)
processDefinition.formConf, if (!data) {
processDefinition.formFields, message.error('查询不到流程信息!')
data.formVariables return
) }
nextTick().then(() => { processInstance.value = data
fApi.value?.fapi?.btn.show(false)
fApi.value?.fapi?.resetBtn.show(false)
fApi.value?.fapi?.disabled(true)
})
}
// //
DefinitionApi.getProcessDefinitionBpmnXML(processDefinition.id).then((data) => { const processDefinition = data.processDefinition
bpmnXML.value = data if (processDefinition.formType === 10) {
setConfAndFields2(
detailForm,
processDefinition.formConf,
processDefinition.formFields,
data.formVariables
)
nextTick().then(() => {
fApi.value?.fapi?.btn.show(false)
fApi.value?.fapi?.resetBtn.show(false)
fApi.value?.fapi?.disabled(true)
}) })
}
//
bpmnXML.value = await DefinitionApi.getProcessDefinitionBpmnXML(processDefinition.id)
} finally {
processInstanceLoading.value = false
}
}
/** 加载任务列表 */
const getTaskList = async () => {
try {
//
tasksLoad.value = true
const data = await TaskApi.getTaskListByProcessInstanceId(id)
tasks.value = []
// 1.1
data.forEach((task) => {
if (task.result !== 4) {
tasks.value.push(task)
}
}) })
.finally(() => { // 1.2
processInstanceLoading.value = false tasks.value.sort((a, b) => {
//
if (a.endTime && b.endTime) {
return b.endTime - a.endTime
} else if (a.endTime) {
return 1
} else if (b.endTime) {
return -1
//
} else {
return b.createTime - a.createTime
}
}) })
// 2. //
tasksLoad.value = true runningTasks.value = []
runningTasks.value = [] auditForms.value = []
auditForms.value = [] tasks.value.forEach((task) => {
TaskApi.getTaskListByProcessInstanceId(id) // 2.1
.then((data) => { if (task.result !== 1) {
// return
tasks.value = [] }
// // 2.2
data.forEach((task) => { if (!task.assigneeUser || task.assigneeUser.id !== userId) {
if (task.result !== 4) { return
tasks.value.push(task) }
} // 2.3
}) runningTasks.value.push({ ...task })
// auditForms.value.push({
tasks.value.sort((a, b) => { reason: ''
//
if (a.endTime && b.endTime) {
return b.endTime - a.endTime
} else if (a.endTime) {
return 1
} else if (b.endTime) {
return -1
//
} else {
return b.createTime - a.createTime
}
})
//
tasks.value.forEach((task) => {
// 1.1
if (task.result !== 1) {
return
}
// 1.2
if (!task.assigneeUser || task.assigneeUser.id !== userId) {
return
}
// 2.
runningTasks.value.push({ ...task })
auditForms.value.push({
reason: ''
})
}) })
}) })
.finally(() => { } finally {
tasksLoad.value = false tasksLoad.value = false
}) }
} }
/** 初始化 */
onMounted(() => {
getDetail()
})
</script> </script>

Loading…
Cancel
Save