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