ImageTask.vue 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <template>
  2. <el-card class="dr-task" body-class="task-card" shadow="never">
  3. <template #header>绘画任务</template>
  4. <ImageTaskCard v-for="image in imageList" :key="image" :image-detail="image" @on-btn-click="handlerImageBtnClick" />
  5. </el-card>
  6. <!-- 图片 detail 抽屉 -->
  7. <ImageDetailDrawer
  8. :show="showTaskDetail"
  9. @handler-drawer-close="handlerDrawerClose"
  10. />
  11. </template>
  12. <script setup lang="ts">
  13. import {ImageApi, ImageDetailVO} from '@/api/ai/image';
  14. import ImageDetailDrawer from './ImageDetailDrawer.vue'
  15. import ImageTaskCard from './ImageTaskCard.vue'
  16. import {bool} from "vue-types";
  17. const imageList = ref<ImageDetailVO[]>([]) // image 列表
  18. const showTaskDetail = ref<bool>(false) // 是否显示 task 详情
  19. /**
  20. * 图片人物 - detail
  21. */
  22. const handlerTaskDetail = async () => {
  23. showTaskDetail.value = !showTaskDetail.value
  24. }
  25. /**
  26. * 抽屉 - close
  27. */
  28. const handlerDrawerClose = async () => {
  29. showTaskDetail.value = false
  30. }
  31. /**
  32. * 任务 - detail
  33. */
  34. const handlerDrawerOpen = async () => {
  35. showTaskDetail.value = true
  36. }
  37. /**
  38. * 获取 - image 列表
  39. */
  40. const getImageList = async () => {
  41. const { list } = await ImageApi.getImageList({pageNo: 1, pageSize: 20})
  42. imageList.value = list
  43. }
  44. /**
  45. * 图片 - btn click
  46. */
  47. const handlerImageBtnClick = async (type, imageDetail: ImageDetailVO) => {
  48. if (type === 'more') {
  49. await handlerDrawerOpen()
  50. }
  51. }
  52. //
  53. onMounted(async () => {
  54. await getImageList()
  55. })
  56. </script>
  57. <style scoped lang="scss">
  58. .dr-task {
  59. width: 100%;
  60. height: 100%;
  61. .task-card {
  62. }
  63. }
  64. </style>