ImageDetailDrawer.vue 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <template>
  2. <el-drawer
  3. v-model="showDrawer"
  4. title="图片详细"
  5. @close="handlerDrawerClose"
  6. custom-class="drawer-class"
  7. >
  8. <!-- 图片 -->
  9. <div class="item">
  10. <div class="header">
  11. <div>图片</div>
  12. <div>
  13. </div>
  14. </div>
  15. <div class="body">
  16. <ImageTaskCard :image-detail="imageDetail" />
  17. </div>
  18. </div>
  19. <!-- 提示词 -->
  20. <div class="item">
  21. <div class="tip">提示词</div>
  22. <div class="body">
  23. {{imageDetail.prompt}}
  24. </div>
  25. </div>
  26. </el-drawer>
  27. </template>
  28. <script setup lang="ts">
  29. import {ImageApi, ImageDetailVO} from '@/api/ai/image';
  30. import ImageTaskCard from './ImageTaskCard.vue';
  31. import {Delete, Download, More} from "@element-plus/icons-vue";
  32. const showDrawer = ref<boolean>(false) // 是否显示
  33. const imageDetail = ref<ImageDetailVO>({} as ImageDetailVO) // 图片详细信息
  34. const props = defineProps({
  35. show: {
  36. type: Boolean,
  37. require: true,
  38. default: false
  39. }
  40. })
  41. /**
  42. * 抽屉 - close
  43. */
  44. const handlerDrawerClose = async () => {
  45. emits('handlerDrawerClose')
  46. }
  47. /**
  48. * 获取 - 图片 detail
  49. */
  50. const getImageDetail = async (id) => {
  51. // 获取图片详细
  52. imageDetail.value = await ImageApi.getImageDetail(id)
  53. }
  54. /**
  55. * 任务 - detail
  56. */
  57. const handlerTaskDetail = async () => {
  58. showDrawer.value = true
  59. }
  60. // watch
  61. const { show } = toRefs(props)
  62. watch(show, async (newValue, oldValue) => {
  63. showDrawer.value = newValue as boolean
  64. })
  65. //
  66. const emits = defineEmits(['handlerDrawerClose'])
  67. //
  68. onMounted(async () => {
  69. await getImageDetail(1)
  70. })
  71. </script>
  72. <style scoped lang="scss">
  73. .item {
  74. margin-bottom: 20px;
  75. width: 100%;
  76. overflow: hidden;
  77. word-wrap: break-word;
  78. .header {
  79. display: flex;
  80. flex-direction: row;
  81. justify-content: space-between;
  82. }
  83. .tip {
  84. font-weight: bold;
  85. font-size: 16px;
  86. }
  87. .body {
  88. margin-top: 10px;
  89. color: #616161;
  90. .taskImage {
  91. border-radius: 10px;
  92. }
  93. }
  94. }
  95. </style>