task-logs.vue 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <template>
  2. <el-drawer v-model="state.showDialog" :title="title" direction="ltr" size="780">
  3. <div class="my-drawer-body-padding">
  4. <el-table v-loading="state.loading" :data="state.taskLogListData" row-key="id" style="width: 100%">
  5. <el-table-column prop="round" label="当前次数" width="80" />
  6. <el-table-column prop="success" label="状态" width="80">
  7. <template #default="{ row }">
  8. <el-tag v-if="!row.success" type="danger" disable-transitions>失败</el-tag>
  9. <el-tag v-else type="success" disable-transitions>成功</el-tag>
  10. </template>
  11. </el-table-column>
  12. <el-table-column prop="elapsedMilliseconds" label="耗时(ms)" width="100" />
  13. <el-table-column prop="exception" label="异常" min-width="180" />
  14. <el-table-column prop="createTime" label="创建时间" :formatter="formatterTime" width="160" />
  15. <el-table-column prop="Remark" label="备注" min-width="180" />
  16. </el-table>
  17. <div class="my-flex my-flex-end" style="margin-top: 20px">
  18. <el-pagination
  19. v-model:currentPage="state.pageInput.currentPage"
  20. v-model:page-size="state.pageInput.pageSize"
  21. :total="state.total"
  22. :page-sizes="[10, 20, 50, 100]"
  23. small
  24. background
  25. @size-change="onSizeChange"
  26. @current-change="onCurrentChange"
  27. layout="total, sizes, prev, pager, next, jumper"
  28. />
  29. </div>
  30. </div>
  31. <template #footer>
  32. <div style="flex: auto; padding: 20px !important">
  33. <el-button @click="onCancel" size="default">取 消</el-button>
  34. </div>
  35. </template>
  36. </el-drawer>
  37. </template>
  38. <script lang="ts" setup name="admin/taskLog">
  39. import { reactive } from 'vue'
  40. import { ResultOutputPageOutputTaskLog, PageInputTaskLogGetPageDto, TaskListOutput } from '/@/api/admin/data-contracts'
  41. import { TaskLogApi } from '/@/api/admin/TaskLog'
  42. import dayjs from 'dayjs'
  43. defineProps({
  44. title: {
  45. type: String,
  46. default: '',
  47. },
  48. })
  49. const state = reactive({
  50. showDialog: false,
  51. loading: false,
  52. taskLogFormTitle: '',
  53. total: 0,
  54. pageInput: {
  55. currentPage: 1,
  56. pageSize: 20,
  57. filter: {
  58. taskId: null,
  59. },
  60. } as PageInputTaskLogGetPageDto,
  61. taskLogListData: [] as Array<ResultOutputPageOutputTaskLog>,
  62. })
  63. const formatterTime = (row: any, column: any, cellValue: any) => {
  64. return dayjs(cellValue).format('YYYY-MM-DD HH:mm:ss')
  65. }
  66. const onQuery = async () => {
  67. state.loading = true
  68. const res = await new TaskLogApi().getPage(state.pageInput).catch(() => {
  69. state.loading = false
  70. })
  71. state.taskLogListData = res?.data?.list ?? []
  72. state.total = res?.data?.total ?? 0
  73. state.loading = false
  74. }
  75. const onSizeChange = (val: number) => {
  76. state.pageInput.pageSize = val
  77. onQuery()
  78. }
  79. const onCurrentChange = (val: number) => {
  80. state.pageInput.currentPage = val
  81. onQuery()
  82. }
  83. // 打开对话框
  84. const open = (row: TaskListOutput) => {
  85. if (state.pageInput.filter) state.pageInput.filter.taskId = row.id
  86. onQuery()
  87. state.showDialog = true
  88. }
  89. // 取消
  90. const onCancel = () => {
  91. state.showDialog = false
  92. }
  93. defineExpose({
  94. open,
  95. })
  96. </script>
  97. <style scoped lang="scss">
  98. .my-drawer-body-padding {
  99. padding: 10px;
  100. }
  101. </style>