feat: 集成 KieAI 服务,移除 models-integration 子项目
- 添加 Gemini 2.5 Flash 对话接口(流式+非流式) - 添加 NanoBanana 图像生成/编辑接口 - 添加 Sora2 视频生成接口(文生视频、图生视频、去水印) - 移除 models-integration 子项目(功能已迁移至主后端) - 新增测试文档和 Playwright E2E 配置 - 更新前端页面和 API 接口 - 更新后端配置和日志处理
This commit is contained in:
@@ -58,7 +58,7 @@
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 饮食指南Tab内容 -->
|
||||
<!-- 饮食指南Tab内容(来自 v2_knowledge,type=guide) -->
|
||||
<view v-if="currentTab === 'guide'" class="tab-content">
|
||||
<view class="knowledge-list">
|
||||
<view
|
||||
@@ -67,7 +67,10 @@
|
||||
:key="index"
|
||||
@click="goToDetail(item)"
|
||||
>
|
||||
<view class="knowledge-icon">
|
||||
<view class="knowledge-cover" v-if="item.coverImage || item.cover_image">
|
||||
<image :src="item.coverImage || item.cover_image" mode="aspectFill" class="cover-img" />
|
||||
</view>
|
||||
<view class="knowledge-icon" v-else>
|
||||
<text>{{ item.icon }}</text>
|
||||
</view>
|
||||
<view class="knowledge-info">
|
||||
@@ -86,7 +89,7 @@
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 科普文章Tab内容 -->
|
||||
<!-- 科普文章Tab内容(来自 v2_knowledge,type=article) -->
|
||||
<view v-if="currentTab === 'articles'" class="tab-content">
|
||||
<view class="knowledge-list">
|
||||
<view
|
||||
@@ -95,7 +98,10 @@
|
||||
:key="index"
|
||||
@click="goToDetail(item)"
|
||||
>
|
||||
<view class="knowledge-icon">
|
||||
<view class="knowledge-cover" v-if="item.coverImage || item.cover_image">
|
||||
<image :src="item.coverImage || item.cover_image" mode="aspectFill" class="cover-img" />
|
||||
</view>
|
||||
<view class="knowledge-icon" v-else>
|
||||
<text>{{ item.icon }}</text>
|
||||
</view>
|
||||
<view class="knowledge-info">
|
||||
@@ -177,37 +183,72 @@ export default {
|
||||
}
|
||||
},
|
||||
onLoad(options) {
|
||||
// 如果携带id参数,自动切换到对应tab并加载
|
||||
if (options && options.id) {
|
||||
// 有id时切换到文章tab展示详情
|
||||
// 有 id 时切换到科普文章 tab 并加载列表
|
||||
this.switchTab('articles');
|
||||
} else {
|
||||
this.loadKnowledgeList();
|
||||
// 无 id 时保持当前 tab(nutrients);切换到「饮食指南」或「科普文章」时由 switchTab 触发 loadKnowledgeList
|
||||
this.currentTab = 'nutrients';
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
formatKnowledgeTime(val) {
|
||||
if (!val) return '';
|
||||
const d = new Date(val);
|
||||
if (isNaN(d.getTime())) return String(val);
|
||||
const y = d.getFullYear();
|
||||
const m = String(d.getMonth() + 1).padStart(2, '0');
|
||||
const day = String(d.getDate()).padStart(2, '0');
|
||||
return `${y}-${m}-${day}`;
|
||||
},
|
||||
async loadKnowledgeList() {
|
||||
// 营养素列表使用本地静态数据,不从API加载
|
||||
if (this.currentTab === 'nutrients') {
|
||||
return;
|
||||
}
|
||||
|
||||
// type 与后端一致:guide / article
|
||||
const typeParam = this.currentTab === 'guide' ? 'guide' : 'article';
|
||||
try {
|
||||
const { getKnowledgeList } = await import('@/api/tool.js');
|
||||
const result = await getKnowledgeList({
|
||||
type: this.currentTab === 'guide' ? 'guide' : 'article',
|
||||
type: typeParam,
|
||||
page: 1,
|
||||
limit: 50
|
||||
});
|
||||
if (result.data && result.data.list) {
|
||||
if (this.currentTab === 'guide') {
|
||||
this.guideList = result.data.list;
|
||||
} else {
|
||||
this.articleList = result.data.list;
|
||||
// 兼容 result.data.list 或 result.data 为数组
|
||||
let rawList = [];
|
||||
if (result && result.data) {
|
||||
if (Array.isArray(result.data.list)) {
|
||||
rawList = result.data.list;
|
||||
} else if (Array.isArray(result.data)) {
|
||||
rawList = result.data;
|
||||
}
|
||||
}
|
||||
const list = rawList.map(item => ({
|
||||
...item,
|
||||
desc: item.desc || item.summary || '',
|
||||
time: item.time || (item.publishedAt || item.createdAt ? this.formatKnowledgeTime(item.publishedAt || item.createdAt) : ''),
|
||||
views: item.views != null ? item.views : (item.viewCount != null ? item.viewCount : 0),
|
||||
icon: item.icon || '📄',
|
||||
coverImage: item.coverImage || item.cover_image || ''
|
||||
}));
|
||||
if (this.currentTab === 'guide') {
|
||||
this.guideList = list;
|
||||
} else if (this.currentTab === 'articles') {
|
||||
this.articleList = list;
|
||||
}
|
||||
} catch (error) {
|
||||
console.error('加载知识列表失败:', error);
|
||||
uni.showToast({
|
||||
title: (error && (error.message || error.msg)) || '加载列表失败',
|
||||
icon: 'none'
|
||||
});
|
||||
// 确保列表始终为数组,不设为 undefined
|
||||
if (this.currentTab === 'guide') {
|
||||
this.guideList = this.guideList ?? [];
|
||||
} else if (this.currentTab === 'articles') {
|
||||
this.articleList = this.articleList ?? [];
|
||||
}
|
||||
}
|
||||
},
|
||||
async switchTab(tab) {
|
||||
@@ -220,16 +261,19 @@ export default {
|
||||
})
|
||||
},
|
||||
goToDetail(item) {
|
||||
if (!item) return
|
||||
// 饮食指南和科普文章使用知识详情页(富文本内容),而非营养素详情页
|
||||
if (item.knowledgeId || item.id) {
|
||||
const id = item.knowledgeId || item.id
|
||||
// 如果有content(富文本),使用内嵌webview或者新闻详情页
|
||||
// 跳转到文章详情(使用现有新闻详情页展示富文本内容)
|
||||
uni.navigateTo({
|
||||
url: `/pages/news/news_details/index?id=${id}`
|
||||
})
|
||||
if (!item) {
|
||||
uni.showToast({ title: '暂无详情', icon: 'none' });
|
||||
return;
|
||||
}
|
||||
const id = item.knowledgeId ?? item.id;
|
||||
if (id === undefined || id === null || id === '') {
|
||||
uni.showToast({ title: '暂无详情', icon: 'none' });
|
||||
return;
|
||||
}
|
||||
// 饮食指南、科普文章使用知识详情页(调用 tool/knowledge/detail 接口)
|
||||
uni.navigateTo({
|
||||
url: `/pages/tool/knowledge-detail?id=${id}`
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -440,6 +484,18 @@ export default {
|
||||
gap: 32rpx;
|
||||
}
|
||||
|
||||
.knowledge-cover {
|
||||
width: 128rpx;
|
||||
height: 128rpx;
|
||||
border-radius: 32rpx;
|
||||
overflow: hidden;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
.cover-img {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.knowledge-icon {
|
||||
width: 128rpx;
|
||||
height: 128rpx;
|
||||
|
||||
Reference in New Issue
Block a user