rescueResourcesResult.vue 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. <template>
  2. <div>
  3. <el-dialog v-model="showSearch" title="采集结果" width="80%" @close="$emit('close')">
  4. <div class="app-container">
  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="area" label-width="auto">
  11. <el-tree-select
  12. v-model="divisionSelectedId"
  13. :data="formattedDivisionData"
  14. :props="{ label: 'label', value: 'code', children: 'children' }"
  15. :render-after-expand="false"
  16. style="width: 468px"
  17. @change="onDivisionChange"
  18. />
  19. </el-form-item>
  20. </el-col>
  21. <el-col :span="6">
  22. <el-form-item label="采集结果:" prop="result" label-width="auto">
  23. <el-select v-model="queryParams.result" placeholder="全部" clearable>
  24. <el-option v-for="item in cycleOptions" :key="item.value" :label="item.label" :value="item.value"></el-option>
  25. </el-select>
  26. </el-form-item>
  27. </el-col>
  28. <el-col :span="6">
  29. <el-form-item prop="nick_name" label-width="auto">
  30. <el-input v-model="queryParams.nick_name" placeholder="请输入排查人"></el-input>
  31. </el-form-item>
  32. </el-col>
  33. <el-col :span="6">
  34. <el-button type="primary" @click="handleQuery">搜索</el-button>
  35. <el-button @click="resetQuery">重置</el-button>
  36. </el-col>
  37. </el-row>
  38. </el-form>
  39. </div>
  40. </transition>
  41. <el-row :gutter="10" class="mb8">
  42. <el-col :span="1.5">
  43. <el-button type="primary" icon="Plus" @click="handleExport">导出</el-button>
  44. </el-col>
  45. </el-row>
  46. <!-- 表格组件 -->
  47. <el-table ref="multipleTable" v-loading="loading" :data="tableData" @selection-change="handleSelectionChange">
  48. <el-table-column label="排查点" align="center" prop="point_name" />
  49. <el-table-column label="所属区划" align="center" prop="area" />
  50. <el-table-column label="执行日期" align="center" prop="create_time" />
  51. <el-table-column label="排查人" align="center" prop="nick_name" />
  52. <el-table-column label="排查结果" align="center">
  53. <template #default="{ row }">
  54. {{ getInspectionResultText(row.result) }}
  55. </template>
  56. </el-table-column>
  57. <el-table-column label="现场照片" align="center" prop="fileList">
  58. <template #default="scope">
  59. <el-image
  60. style="width: 100px; height: 100px"
  61. :src="scope.row.url"
  62. :preview-src-list="scope.row.urlList"
  63. :preview-teleported="true"
  64. fit="cover"
  65. />
  66. </template>
  67. </el-table-column>
  68. <el-table-column label="备注" align="center" prop="remark" />
  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. </el-dialog>
  73. </div>
  74. </template>
  75. <script setup lang="ts">
  76. import { onMounted, reactive, ref } from 'vue';
  77. import { inspectorDivision, resultList } from '@/api/inspectionWork/inspector';
  78. import { ElMessage } from 'element-plus';
  79. const baseUrl = import.meta.env.VITE_APP_BASE_API;
  80. const downLoadApi = import.meta.env.VITE_APP_BASE_DOWNLOAD_API;
  81. const loading = ref(true);
  82. const showSearch = ref(true);
  83. const multiple = ref(true);
  84. const ids = ref<Array<number | string>>([]);
  85. const single = ref(true);
  86. const total = ref(0);
  87. const tableData = ref([]);
  88. const { proxy } = getCurrentInstance() as ComponentInternalInstance;
  89. const divisionSelectedId = ref(null);
  90. const formattedDivisionData = ref([]);
  91. const rawDivisionData = ref([]);
  92. const props = defineProps<{
  93. eventId: string | number;
  94. }>();
  95. const initFormData = reactive({
  96. id: '',
  97. children_task_id: '',
  98. point_name: '',
  99. area: '',
  100. create_time: '',
  101. nick_name: '',
  102. result: '',
  103. remark: '',
  104. fileList: ''
  105. });
  106. const data = reactive({
  107. form: { ...initFormData },
  108. queryParams: {
  109. page: 1,
  110. pageSize: 10,
  111. result: '',
  112. area: '',
  113. nick_name: ''
  114. }
  115. });
  116. const { queryParams, form } = toRefs(data);
  117. const cycleOptions = ref([
  118. { label: '全部', value: '' }, // 通常“全部”对应空值或者特定的标识符,表示不按此条件过滤
  119. { label: '正常', value: '1' },
  120. { label: '异常', value: '2' }
  121. ]);
  122. const getInspectionResultText = (resultCode) => {
  123. switch (resultCode) {
  124. case '1':
  125. return '正常';
  126. case '2':
  127. return '异常';
  128. default:
  129. return '全部';
  130. }
  131. };
  132. const fetchResulData = () => {
  133. loading.value = true; // 开始加载
  134. return resultList(props.eventId, queryParams.value)
  135. .then((res) => {
  136. res.data.forEach((item) => {
  137. if (item.fileList && item.fileList.length > 0) {
  138. let urlList = [];
  139. item.fileList.forEach((item2) => {
  140. urlList.push(baseUrl + downLoadApi + item2.url);
  141. });
  142. item.urlList = urlList;
  143. item.url = urlList[0];
  144. }
  145. });
  146. tableData.value = res.data || []; // 确保tableData是一个数组
  147. total.value = res.total || 0; // 确保total是一个数字
  148. console.log('Fetched subtasks data:', tableData.value);
  149. loading.value = false; // 结束加载
  150. })
  151. .catch((error) => {
  152. console.error('Error fetching sub tasks:', error);
  153. loading.value = false; // 结束加载
  154. });
  155. };
  156. const handleQuery = () => {
  157. queryParams.value.page = 1;
  158. fetchResulData();
  159. };
  160. const handleExport = () => {
  161. ElMessage.info('导出成功');
  162. };
  163. // 重置查询条件
  164. const resetQuery = () => {
  165. queryParams.value = { page: 1, pageSize: 10, nick_name: '', area: '', result: '' };
  166. handleQuery();
  167. };
  168. const handleSelectionChange = (selection) => {
  169. ids.value = selection.map((item) => item.id);
  170. selectedRow.value = selection.length === 1 ? selection[0] : null;
  171. single.value = selection.length != 1;
  172. multiple.value = !selection.length;
  173. };
  174. const fetchDivisionData = async () => {
  175. const response = await inspectorDivision();
  176. if (response.code === 200) {
  177. rawDivisionData.value = response.data;
  178. formattedDivisionData.value = formatDivisionData(rawDivisionData.value);
  179. console.log('Formatted Division Data:', formattedDivisionData.value);
  180. } else {
  181. ElMessage.error(response.msg);
  182. }
  183. };
  184. const onDivisionChange = (value) => {
  185. // 确认选中的项存在
  186. const selectedDivision = findNode(formattedDivisionData.value, value);
  187. if (!selectedDivision) {
  188. ElMessage.warning('未找到匹配的责任区划。');
  189. // 将选中的值重置为 null 或空字符串,防止后续逻辑错误
  190. divisionSelectedId.value = null;
  191. } else {
  192. console.log('Selected Division:', selectedDivision); // 调试输出
  193. }
  194. };
  195. // 递归查找节点
  196. const findNode = (nodes, code) => {
  197. for (let i = 0; i < nodes.length; i++) {
  198. const node = nodes[i];
  199. if (node.code === code) {
  200. return node;
  201. }
  202. if (node.children && node.children.length > 0) {
  203. const found = findNode(node.children, code);
  204. if (found) {
  205. return found;
  206. }
  207. }
  208. }
  209. return null;
  210. };
  211. // 格式化责任区划数据
  212. const formatDivisionData = (data) => {
  213. return data.map((item) => ({
  214. id: item.id,
  215. label: item.label,
  216. code: item.code,
  217. children: item.children ? formatDivisionData(item.children) : []
  218. }));
  219. };
  220. onMounted(() => {
  221. fetchResulData();
  222. fetchDivisionData();
  223. });
  224. </script>