|
@@ -0,0 +1,95 @@
|
|
1
|
+<template>
|
|
2
|
+ <div class="publicity-page">
|
|
3
|
+ <h3>信息公示</h3>
|
|
4
|
+ <van-list
|
|
5
|
+ class="publicity-list"
|
|
6
|
+ v-model:loading="loading"
|
|
7
|
+ :finished="finished"
|
|
8
|
+ @load="onLoad"
|
|
9
|
+ finished-text="我们是有底线的"
|
|
10
|
+ >
|
|
11
|
+ <van-cell
|
|
12
|
+ class="item"
|
|
13
|
+ v-for="item in list"
|
|
14
|
+ :key="item.detailId"
|
|
15
|
+ :title="item.orgName"
|
|
16
|
+ is-link
|
|
17
|
+ :to="{ name: 'invoice.fill', query: { invoiceId, personId: item.personId } }"
|
|
18
|
+ >
|
|
19
|
+ <template #value>
|
|
20
|
+ <span class="pname">{{ item.personName }}</span>
|
|
21
|
+ </template>
|
|
22
|
+ </van-cell>
|
|
23
|
+ </van-list>
|
|
24
|
+ </div>
|
|
25
|
+</template>
|
|
26
|
+<script setup>
|
|
27
|
+import { computed, onMounted, reactive, ref } from "vue"
|
|
28
|
+import { useRouter, useRoute } from 'vue-router'
|
|
29
|
+import { getList } from "@/services/invoice";
|
|
30
|
+
|
|
31
|
+const router = useRouter();
|
|
32
|
+const route = useRoute();
|
|
33
|
+const { invoiceId = 'f11ab8d28fd097e7aa4877ae7068a876' } = route;
|
|
34
|
+
|
|
35
|
+const list = ref([])
|
|
36
|
+const error = ref(false);
|
|
37
|
+const loading = ref(false);
|
|
38
|
+const pagenavi = reactive({ pageNum: 1, pageSize: 10, total: 0 })
|
|
39
|
+const finished = computed(() => pagenavi.pageNum * pagenavi.pageSize > pagenavi.total)
|
|
40
|
+
|
|
41
|
+const queryData = (params) => {
|
|
42
|
+ getList(invoiceId, params).then(res => {
|
|
43
|
+ const { records, ...pageInfo } = res;
|
|
44
|
+ if (pageInfo.current === 1) {
|
|
45
|
+ list.value = records || []
|
|
46
|
+ } else {
|
|
47
|
+ list.value = list.value.concat(records || [])
|
|
48
|
+ }
|
|
49
|
+
|
|
50
|
+ pagenavi.pageNum = pageInfo.current
|
|
51
|
+ pagenavi.total = pageInfo.total
|
|
52
|
+ error.value = false
|
|
53
|
+ loading.value = false
|
|
54
|
+ }).catch(() => {
|
|
55
|
+ error.value = true
|
|
56
|
+ loading.value = false
|
|
57
|
+ })
|
|
58
|
+}
|
|
59
|
+
|
|
60
|
+const onLoad = () => {
|
|
61
|
+ const params = { pageNum: pagenavi.pageNum + 1, pageSize: pagenavi.pageSize }
|
|
62
|
+ queryData(params)
|
|
63
|
+}
|
|
64
|
+
|
|
65
|
+onMounted(() => {
|
|
66
|
+ //获取提交记录
|
|
67
|
+ const params = { pageNum: pagenavi.pageNum, pageSize: pagenavi.pageSize }
|
|
68
|
+ queryData(params)
|
|
69
|
+})
|
|
70
|
+
|
|
71
|
+</script>
|
|
72
|
+<style lang="less" scoped>
|
|
73
|
+.publicity-page {
|
|
74
|
+ height: 100%;
|
|
75
|
+ display: flex;
|
|
76
|
+ flex-direction: column;
|
|
77
|
+
|
|
78
|
+ h3 {
|
|
79
|
+ flex: none;
|
|
80
|
+ text-align: center;
|
|
81
|
+ letter-spacing: 2px;
|
|
82
|
+ }
|
|
83
|
+
|
|
84
|
+ .publicity-list {
|
|
85
|
+ flex: 1;
|
|
86
|
+ }
|
|
87
|
+
|
|
88
|
+ .pname {
|
|
89
|
+ color: #333;
|
|
90
|
+ }
|
|
91
|
+ // .item + .item {
|
|
92
|
+ // margin-top: 16px;
|
|
93
|
+ // }
|
|
94
|
+}
|
|
95
|
+</style>
|