index.vue 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. <template>
  2. <div class="p-3">
  3. <div class="bg-fff flex1 ov-hd d-flex flex-cln" v-show="showSearch">
  4. <div class="pd-16 border-bottom">
  5. <div class="f-s-20 c-333 f-w-7 mb-10">申报记录</div>
  6. <div class="d-flex">
  7. <div class="flex1 ov-hd d-flex j-ed">
  8. <el-form :model="queryParams" ref="queryFormRef" :inline="true" label-width="auto">
  9. <el-form-item label="标准名称" prop="standardName">
  10. <el-input v-model="queryParams.standardName" placeholder="搜标准名称" clearable style="width: 160px" @keyup.enter="handleQuery" />
  11. </el-form-item>
  12. <el-form-item label="企业名称" prop="cpyname">
  13. <el-input v-model="queryParams.cpyname" placeholder="搜企业名称" clearable style="width: 160px" @keyup.enter="handleQuery" />
  14. </el-form-item>
  15. <el-form-item label="申报人" prop="createByName">
  16. <el-input v-model="queryParams.createByName" placeholder="搜申报人" clearable style="width: 160px" @keyup.enter="handleQuery" />
  17. </el-form-item>
  18. <el-form-item>
  19. <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
  20. <el-button icon="Refresh" @click="resetQuery">重置</el-button>
  21. </el-form-item>
  22. </el-form>
  23. </div>
  24. </div>
  25. </div>
  26. <div class="d-flex flex1 ov-hd flex-cln pd-16">
  27. <div class="d-flex j-sb mb-16">
  28. <div>
  29. <searchTabs v-model="queryParams.status" @change="handleQuery" :list="tabs" key-label="name" key-count="num" key-value="type"></searchTabs>
  30. </div>
  31. </div>
  32. <div class="flex1 ov-hd">
  33. <vxe-table :loading="loading" border :data="dataList" min-height="0" max-height="100%">
  34. <vxe-column title="序号" align="center" type="seq" width="50" />
  35. <vxe-column title="标准名称" field="standardName" :formatter="colNoData" />
  36. <vxe-column title="企业名称" field="cpyname" :formatter="colNoData" />
  37. <vxe-column title="申报时间" align="center" width="240">
  38. <template #default="{ row }">
  39. <span>{{ row.createTime }}</span>
  40. </template>
  41. </vxe-column>
  42. <vxe-column title="申报人" field="createByName" align="center" width="140" />
  43. <vxe-column title="点赞数" field="likeCount" align="center" width="70"/>
  44. <vxe-column title="分享数" field="shareCount" align="center" width="70" />
  45. <vxe-column title="事项状态" width="100">
  46. <template #default="{ row }">
  47. <DictTag :options="dm_expert_item_list" :value="row?.status"></DictTag>
  48. </template>
  49. </vxe-column>
  50. <vxe-column title="操作" width="100" align="center" fixed="right">
  51. <template #default="{ row }">
  52. <el-button v-if="!+row?.status" type="primary" @click="editRow(row)" text>审核</el-button>
  53. <el-button v-else type="primary" @click="editRow(row)" text>详情</el-button>
  54. </template>
  55. </vxe-column>
  56. </vxe-table>
  57. </div>
  58. <pagination :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getdeclarationList" />
  59. </div>
  60. </div>
  61. </div>
  62. </template>
  63. <script setup name="choose-check" lang="ts">
  64. import { colNoData } from '@/utils/noData';
  65. import { searchTabs } from '@/views/models';
  66. import {DeclarationRecordList,queryDeclarationRecordCount} from '@/api/leader'
  67. const router = useRouter();
  68. const { proxy } = getCurrentInstance() as ComponentInternalInstance;
  69. const { dm_join_type, dm_person_type, dm_expert_item_list } = toRefs<any>(proxy?.useDict('dm_join_type', 'dm_person_type', 'dm_expert_item_list'));
  70. const loading = ref(true);
  71. const showSearch = ref(true);
  72. const total = ref(0);
  73. const queryFormRef = ref<ElFormInstance>();
  74. const dataList = ref<any[]>([]);
  75. const initFormData = {};
  76. const data = reactive<any>({
  77. form: { ...initFormData },
  78. queryParams: {
  79. status:"0",
  80. pageNum: 1,
  81. pageSize: 10,
  82. res: '0',
  83. standardName: '',
  84. cpyname: '',
  85. createByName:'',
  86. },
  87. rules: {}
  88. });
  89. const { queryParams, form } = toRefs(data);
  90. /** 查询审批列表 */
  91. const getdeclarationList = async()=>{
  92. loading.value = true;
  93. const res = await DeclarationRecordList(queryParams.value);
  94. dataList.value = res.rows;
  95. total.value = res.total;
  96. loading.value = false;
  97. }
  98. /** 搜索按钮操作 */
  99. const handleQuery = () => {
  100. queryParams.value.pageNum = 1;
  101. getdeclarationList()
  102. };
  103. /** 重置按钮操作 */
  104. const resetQuery = () => {
  105. queryFormRef.value?.resetFields();
  106. queryParams.value.standardName = '';
  107. queryParams.value.cpyname = '';
  108. queryParams.value.createByName = '';
  109. handleQuery();
  110. };
  111. /** 编辑事项 */
  112. const editRow = (row) => {
  113. router.push({ path: 'declaration-detail', query: { id: row.id } });
  114. };
  115. // 获取专家统计数量
  116. const tabs = ref([]);
  117. const getDeclarationRecordCount = async () => {
  118. const res = await queryDeclarationRecordCount();
  119. if (res?.code === 200) {
  120. tabs.value = res.data;
  121. }
  122. };
  123. onMounted(() => {
  124. getdeclarationList()
  125. getDeclarationRecordCount()
  126. });
  127. </script>