From a1d7e81859f554f3a53680cc35f0f49bf1f77098 Mon Sep 17 00:00:00 2001
From: wwf <1971391498@qq.com>
Date: 星期四, 14 五月 2026 14:37:02 +0800
Subject: [PATCH] 导入项目
---
src/views/ai/image/square/index.vue | 67 +++++++++++++++++++++++++++++++++
1 files changed, 67 insertions(+), 0 deletions(-)
diff --git a/src/views/ai/image/square/index.vue b/src/views/ai/image/square/index.vue
new file mode 100644
index 0000000..0f82c48
--- /dev/null
+++ b/src/views/ai/image/square/index.vue
@@ -0,0 +1,67 @@
+<template>
+ <div class="bg-white p-20px">
+ <!-- TODO @fan锛歴tyle 寤鸿鎹㈡垚 unocss -->
+ <!-- TODO @fan锛歋earch 鍙互鎹㈡垚 Icon 缁勪欢涔堬紵 -->
+ <el-input
+ v-model="queryParams.prompt"
+ class="!w-full !mb-20px"
+ size="large"
+ placeholder="璇疯緭鍏ヨ鎼滅储鐨勫唴瀹�"
+ :suffix-icon="Search"
+ @keyup.enter="handleQuery"
+ />
+ <div class="grid grid-cols-[repeat(auto-fill,minmax(200px,1fr))] gap-10px bg-white shadow-[0_0_10px_rgba(0,0,0,0.1)]">
+ <!-- TODO @fan锛氳繖涓浘鐗囩殑椋庢牸锛岃涓嶅拰 ImageCard.vue 鐣岄潰涓�鑷达紵锛堝彧鏈夊崱鐗囷紝娌℃湁鎿嶄綔锛夛紱鍥犱负鐪嬬潃鏇存湁鐩告鐨勬劅瑙墌~~ -->
+ <div v-for="item in list" :key="item.id" class="relative overflow-hidden bg-gray-100 cursor-pointer transition-transform duration-300 hover:scale-105">
+ <img :src="item.picUrl" class="w-full h-auto block transition-transform duration-300 hover:scale-110" />
+ </div>
+ </div>
+ <!-- TODO @fan锛氱己灏戠炕椤� -->
+ <!-- 鍒嗛〉 -->
+ <Pagination
+ :total="total"
+ v-model:page="queryParams.pageNo"
+ v-model:limit="queryParams.pageSize"
+ @pagination="getList"
+ />
+ </div>
+</template>
+<script setup lang="ts">
+import { ImageApi, ImageVO } from '@/api/ai/image'
+import { Search } from '@element-plus/icons-vue'
+
+// TODO @fan锛氬姞涓� loading 鍔犺浇涓殑鐘舵��
+const loading = ref(true) // 鍒楄〃鐨勫姞杞戒腑
+const list = ref<ImageVO[]>([]) // 鍒楄〃鐨勬暟鎹�
+const total = ref(0) // 鍒楄〃鐨勬�婚〉鏁�
+const queryParams = reactive({
+ pageNo: 1,
+ pageSize: 10,
+ publicStatus: true,
+ prompt: undefined
+})
+
+/** 鏌ヨ鍒楄〃 */
+const getList = async () => {
+ loading.value = true
+ try {
+ const data = await ImageApi.getImagePageMy(queryParams)
+ list.value = data.list
+ total.value = data.total
+ } finally {
+ loading.value = false
+ }
+}
+
+/** 鎼滅储鎸夐挳鎿嶄綔 */
+const handleQuery = () => {
+ queryParams.pageNo = 1
+ getList()
+}
+
+/** 鍒濆鍖� */
+onMounted(async () => {
+ await getList()
+})
+</script>
+
--
Gitblit v1.8.0