index.vue
2.53 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<template>
<div class="app-container">
<component
:is="appComponent" ref="appComponentRef" @view-exam="handleView" @do-approval="handleApproval" @do-back="handleBack"
@view-transcript="handleViewTranscript" @view-merge="handleViewMerge"
/>
<exam-view ref="examViewRef" @approval="handleApproval" />
<do-approval ref="doApprovalRef" @approval="approval" />
<view-files ref="viewFilesRef" />
<view-merge ref="viewMergeRef" />
</div>
</template>
<script setup name="Level_Approval">
import { getCurrentInstance } from '@vue/runtime-core'
import { computed, defineAsyncComponent } from 'vue'
import useUserStore from '@/store/modules/user'
import ExamView from '@/views/exam/level/apply/components/examView'
import DoApproval from './do'
import ViewFiles from '@/views/exam/components/viewFiles'
import ViewMerge from '@/views/exam/level/approval/components/mergeView'
import { useRoute } from 'vue-router'
const { proxy } = getCurrentInstance()
const userStore = useUserStore()
const route = useRoute()
const appComponent = computed(() => {
let component
switch (userStore.deptType) {
case '1':
component = defineAsyncComponent(() => import('./components/ztx'))
break
case '2':
case '3':
const step = route.query.step || '1'
switch (step) {
case '1':
component = defineAsyncComponent(() => import('./components/province_step1'))
break
case '2':
component = defineAsyncComponent(() => import('./components/province_step2'))
break
case '3':
component = defineAsyncComponent(() => import('./components/province_step3'))
break
}
break
default:
component = defineAsyncComponent(() => import('./components/city'))
break
}
return component
})
function getList() {
proxy.$refs['appComponentRef'].getList()
}
function handleApproval(rows, params) {
proxy.$refs['doApprovalRef'].open(rows, params)
}
function handleView(row, params) {
proxy.$refs['examViewRef'].open(row, params)
}
function approval(flag) {
proxy.$refs['examViewRef']?.close()
getList()
approvalCompleted(flag)
}
function approvalCompleted(flag) {
proxy.$refs['appComponentRef']?.approvalCompleted(flag)
}
function handleBack(row) {
proxy.$refs['doApprovalRef'].open([JSON.stringify(row.sourceData)], {
isBack: true
})
}
function handleViewTranscript(row) {
proxy.$refs['viewFilesRef'].open(row.transcript)
}
function handleViewMerge(row) {
proxy.$refs['viewMergeRef'].open(row, null)
}
</script>