index.vue 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. <template>
  2. <div class="query-repeal-container layout-pd">
  3. <el-card shadow="never">
  4. <el-form :model="state.queryParams" ref="ruleFormRef" @submit.native.prevent inline>
  5. <el-form-item label="关键词" prop="Keyword">
  6. <el-input v-model="state.queryParams.Keyword" placeholder="工单编码/标题" clearable @keyup.enter="queryList" class="keyword-input" />
  7. </el-form-item>
  8. <el-form-item>
  9. <el-button type="primary" @click="queryList" :loading="state.loading"> <SvgIcon name="ele-Search" class="mr5" />查询 </el-button>
  10. <el-button @click="resetQuery(ruleFormRef)" v-waves class="default-button" :loading="state.loading">
  11. <SvgIcon name="ele-Refresh" class="mr5" />重置
  12. </el-button>
  13. </el-form-item>
  14. </el-form>
  15. </el-card>
  16. <el-card shadow="never">
  17. <!-- 表格 -->
  18. <el-table :data="state.tableData" v-loading="state.loading" row-key="id" ref="multipleTableRef" @selection-change="handleSelectionChange">
  19. <el-table-column type="selection" width="55" />
  20. <el-table-column prop="no" label="工单编码" show-overflow-tooltip></el-table-column>
  21. <el-table-column prop="no" label="来源方式" show-overflow-tooltip></el-table-column>
  22. <el-table-column prop="no" label="当前节点" show-overflow-tooltip></el-table-column>
  23. <el-table-column prop="acceptTypeText" label="省/市工单" show-overflow-tooltip></el-table-column>
  24. <el-table-column prop="expiredTime" label="期满时间" show-overflow-tooltip width="170">
  25. <template #default="{ row }">
  26. <span>{{ formatDate(row.expiredTime, 'YYYY-mm-dd HH:MM:SS') }}</span>
  27. </template>
  28. </el-table-column>
  29. <el-table-column prop="expiredTime" label="受理时间" show-overflow-tooltip width="170">
  30. <template #default="{ row }">
  31. <span>{{ formatDate(row.expiredTime, 'YYYY-mm-dd HH:MM:SS') }}</span>
  32. </template>
  33. </el-table-column>
  34. <el-table-column prop="acceptTypeText" label="受理类型" show-overflow-tooltip></el-table-column>
  35. <el-table-column prop="acceptTypeText" label="工单状态" show-overflow-tooltip></el-table-column>
  36. <el-table-column label="工单标题" show-overflow-tooltip width="300">
  37. <template #default="{ row }">
  38. <order-detail :order="row" @updateList="queryList">{{ row.title }}</order-detail>
  39. </template>
  40. </el-table-column>
  41. <el-table-column prop="acceptTypeText" label="接办部门" show-overflow-tooltip></el-table-column>
  42. <el-table-column prop="expiredTime" label="接办时间" show-overflow-tooltip width="170">
  43. <template #default="{ row }">
  44. <span>{{ formatDate(row.expiredTime, 'YYYY-mm-dd HH:MM:SS') }}</span>
  45. </template>
  46. </el-table-column>
  47. <el-table-column prop="hotspotName" label="热点分类" show-overflow-tooltip></el-table-column>
  48. <el-table-column prop="acceptTypeText" label="撤销部门" show-overflow-tooltip></el-table-column>
  49. <el-table-column prop="acceptTypeText" label="撤销人" show-overflow-tooltip></el-table-column>
  50. <el-table-column prop="expiredTime" label="撤销时间" show-overflow-tooltip width="170">
  51. <template #default="{ row }">
  52. <span>{{ formatDate(row.expiredTime, 'YYYY-mm-dd HH:MM:SS') }}</span>
  53. </template>
  54. </el-table-column>
  55. <el-table-column prop="acceptTypeText" label="撤销原因" show-overflow-tooltip></el-table-column>
  56. <el-table-column label="操作" width="100" fixed="right" align="center">
  57. <template #default="{ row }">
  58. <order-detail :order="row.order" @updateList="queryList" />
  59. </template>
  60. </el-table-column>
  61. <template #empty>
  62. <Empty />
  63. </template>
  64. </el-table>
  65. <!-- 分页 -->
  66. <pagination
  67. :total="state.total"
  68. v-model:page="state.queryParams.PageIndex"
  69. v-model:limit="state.queryParams.PageSize"
  70. @pagination="queryList"
  71. />
  72. </el-card>
  73. </div>
  74. </template>
  75. <script setup lang="ts" name="queryRepeal">
  76. import { defineAsyncComponent, onMounted, reactive, ref } from 'vue';
  77. import { ElButton, ElMessage, FormInstance } from 'element-plus';
  78. import { auth } from '@/utils/authFunction';
  79. import { throttle } from '@/utils/tools';
  80. import { formatDate } from '@/utils/formatTime';
  81. // 引入组件
  82. const OrderDetail = defineAsyncComponent(() => import('@/components/OrderDetail/index.vue')); // 工单详情
  83. // 定义变量内容
  84. const ruleFormRef = ref<RefType>(); // 表单ref
  85. const state = reactive(<any>{
  86. queryParams: {
  87. // 查询条件
  88. PageIndex: 1,
  89. PageSize: 10,
  90. Keyword: null, // 关键字
  91. },
  92. tableData: [], //表单
  93. loading: false, // 加载
  94. total: 0, // 总数
  95. });
  96. /** 获取列表 */
  97. const queryList = throttle(() => {
  98. if (!auth('query:repeal:query')) ElMessage.error('抱歉,您没有权限查看工单撤销查询列表!');
  99. else {
  100. }
  101. }, 300);
  102. /** 重置按钮操作 */
  103. const resetQuery = throttle((formEl: FormInstance | undefined) => {
  104. if (!formEl) return;
  105. formEl.resetFields();
  106. queryList();
  107. }, 300);
  108. // 表格多选
  109. const multipleTableRef = ref<RefType>();
  110. const multipleSelection = ref<any>([]);
  111. const handleSelectionChange = (val: any[]) => {
  112. multipleSelection.value = val;
  113. };
  114. // 导出
  115. const onExport = () => {
  116. console.log('导出');
  117. };
  118. onMounted(async () => {
  119. queryList();
  120. });
  121. </script>