myFilling.vue 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. <template>
  2. <div>
  3. <div v-show="!writeFormState.show && !formDetailState.show" class="app-container">
  4. <div>
  5. <transition name="fade">
  6. <div v-show="showSearch">
  7. <el-form ref="queryFormRef" :model="queryParams">
  8. <el-row :gutter="20">
  9. <el-col :span="6">
  10. <el-form-item label="表格名称:" prop="table_name" label-width="auto">
  11. <el-input v-model="queryParams.table_name" placeholder="请输入巡查人"></el-input>
  12. </el-form-item>
  13. </el-col>
  14. <el-col :span="6">
  15. <!-- <el-form-item label="任务状态:" prop="submission_status">-->
  16. <!-- <el-radio-group v-model="queryParams.submission_status">-->
  17. <!-- <el-radio value="0" size="large">待填报</el-radio>-->
  18. <!-- <el-radio value="1" size="large">已上报</el-radio>-->
  19. <!-- </el-radio-group>-->
  20. <!-- </el-form-item>-->
  21. <el-form-item label="任务状态:" prop="submission_status">
  22. <el-select
  23. v-model="queryParams.submission_status"
  24. clearable
  25. placeholder="请选择"
  26. style="width: 240px"
  27. >
  28. <el-option
  29. v-for="item in options"
  30. :key="item.value"
  31. :label="item.label"
  32. :value="item.value"
  33. />
  34. </el-select>
  35. </el-form-item>
  36. </el-col>
  37. <el-col :span="6">
  38. <el-button type="primary" @click="handleQuery">查询</el-button>
  39. <el-button @click="resetQuery">重置</el-button>
  40. </el-col>
  41. </el-row>
  42. </el-form>
  43. </div>
  44. </transition>
  45. <!-- 表格组件 -->
  46. <el-table ref="multipleTable" v-loading="loading" :data="tableData" @selection-change="handleSelectionChange">
  47. <el-table-column label="序号" align="center" width="80">
  48. <template #default="scope">
  49. {{ (queryParams.page - 1) * queryParams.pageSize + scope.$index + 1 }}
  50. </template>
  51. </el-table-column>
  52. <el-table-column label="表格名称" align="center" prop="table_name" />
  53. <el-table-column label="开始日期" align="center" prop="start_time" />
  54. <el-table-column label="截止填报时间" align="center" prop="end_time" />
  55. <el-table-column label="任务状态" align="center" prop="submission_status">
  56. <template #default="scope">
  57. <div>
  58. <span v-if="Number(scope.row.submission_status) === 0">待填报</span>
  59. <span v-else>已上报</span>
  60. </div>
  61. </template>
  62. </el-table-column>
  63. <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
  64. <template #default="scope">
  65. <el-text v-if="Number(scope.row.submission_status) === 0" class="common-btn-text-primary" @click="handleWrite(scope.row)">填表</el-text>
  66. <el-text class="common-btn-text-primary" @click="handleView(scope.row)">详情</el-text>
  67. </template>
  68. </el-table-column>
  69. </el-table>
  70. <pagination v-show="total > 0" v-model:page="queryParams.page" v-model:limit="queryParams.pageSize" :total="total" @pagination="tableData" />
  71. </div>
  72. </div>
  73. <WriteForm v-if="writeFormState.show" :event-id="writeFormState.eventId" @close="handleCancel" />
  74. <FormDetail v-if="formDetailState.show" :event-id="formDetailState.eventId" @close="handleCancel" />
  75. </div>
  76. </template>
  77. <script setup lang="ts">
  78. import { onMounted, reactive, ref } from 'vue';
  79. import { fillList } from '@/api/dataFilling/datafilling';
  80. import WriteForm from './writeForm.vue';
  81. import FormDetail from './formDetail.vue';
  82. import { ComponentInternalInstance, getCurrentInstance } from 'vue';
  83. import { parseTime } from '@/utils/ruoyi';
  84. import { deepClone } from '@/utils';
  85. const loading = ref(true);
  86. const showSearch = ref(true);
  87. const multiple = ref(true);
  88. const ids = ref<Array<number | string>>([]);
  89. const single = ref(true);
  90. const total = ref(0);
  91. const tableData = ref([]);
  92. const { proxy } = getCurrentInstance() as ComponentInternalInstance;
  93. const options = [
  94. {
  95. value: '0',
  96. label: '待填报',
  97. },
  98. {
  99. value: '1',
  100. label: '已上报',
  101. }]
  102. const initFormData = reactive({
  103. report_id: '',
  104. table_name: '',
  105. start_time: '',
  106. end_time: '',
  107. submission_status: []
  108. });
  109. const data = reactive({
  110. form: { ...initFormData },
  111. queryParams: {
  112. page: 1,
  113. pageSize: 10,
  114. table_name: '',
  115. submission_status: ''
  116. }
  117. });
  118. const { queryParams, form } = toRefs(data);
  119. let writeFormState = reactive({
  120. show: false,
  121. eventId: ''
  122. });
  123. let formDetailState = reactive({
  124. show: false,
  125. eventId: ''
  126. });
  127. const handleCancel = () => {
  128. writeFormState.show = false;
  129. formDetailState.show = false;
  130. };
  131. const handleWrite = (row) => {
  132. if (row) {
  133. writeFormState.eventId = row.report_id;
  134. writeFormState.show = true;
  135. }
  136. };
  137. const handleView = (row) => {
  138. if (row) {
  139. formDetailState.eventId = row.report_id;
  140. formDetailState.show = true;
  141. }
  142. };
  143. const fetchFillList = () => {
  144. loading.value = true;
  145. const params = deepClone(queryParams.value);
  146. params.submission_status = !queryParams.value.submission_status ? [] : [queryParams.value.submission_status]
  147. fillList(params)
  148. .then((res) => {
  149. for(let i = 0; i < res.data.length; i++) {
  150. res.data[i].end_time = parseTime(res.data[i].end_time);
  151. res.data[i].start_time = parseTime(res.data[i].start_time);
  152. }
  153. tableData.value = res.data;
  154. total.value = res.total;
  155. })
  156. .finally(() => {
  157. loading.value = false;
  158. });
  159. };
  160. onMounted(() => {
  161. fetchFillList();
  162. });
  163. const handleQuery = () => {
  164. queryParams.value.page = 1; // 重置页码
  165. fetchFillList(queryParams.value);
  166. };
  167. const resetQuery = () => {
  168. queryParams.value = { page: 1, pageSize: 10, table_name: '', submission_status: [] };
  169. handleQuery();
  170. };
  171. const handleSelectionChange = (selection) => {
  172. ids.value = selection.map((item) => item.id);
  173. };
  174. </script>