From dbd1853e6e9976f06845ae95733892ec95f5c1cf Mon Sep 17 00:00:00 2001 From: hubian <908234780@qq.com> Date: Mon, 27 Apr 2026 10:45:30 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E6=99=BA=E8=83=BD=E4=BD=93=E5=8F=91?= =?UTF-8?q?=E7=8E=B0=E5=92=8C=E6=94=B6=E8=97=8F=E5=8A=9F=E8=83=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - 智能体界面顶部右侧添加搜索按钮(发现智能体) - 点击进入发现页面,显示所有系统智能体 - 每个智能体显示简介、热度、类别 - 支持添加和收藏按钮 - 添加的智能体自动归类到对应类别 - 智能体界面顶部右侧添加收藏按钮(☆) - 点击进入收藏夹页面,点击智能体进入对话 - 智能体长按弹出操作菜单(置顶、收藏、删除) - 置顶、收藏、用户智能体配置持久化存储 --- www/app.js | 730 +++++++++++++++++++++++++++++++++++++++++++++---- www/index.html | 6 +- www/style.css | 440 +++++++++++++++++++++++++++++ 3 files changed, 1125 insertions(+), 51 deletions(-) diff --git a/www/app.js b/www/app.js index 314e337..83cb9e9 100644 --- a/www/app.js +++ b/www/app.js @@ -19,30 +19,52 @@ let isLoading = false; // 当前页面状态 let currentPage = 'chats'; // chats | agents | profile -// 智能体数据 -let agents = [ +// 系统智能体数据(完整列表) +let systemAgents = [ // 热门智能体 - { id: 'assistant', name: '通用助手', avatar: '🤖', category: 'hot', desc: '能回答各类问题,帮助写作、分析、解答疑惑', systemPrompt: '你是一个智能助手,能够回答各类问题,帮助用户解决问题。' }, - { id: 'writer', name: '写作助手', avatar: '✍️', category: 'hot', desc: '专注于文章写作、文案创作、内容润色', systemPrompt: '你是一个专业的写作助手,擅长各类文章写作、文案创作和内容润色。' }, - { id: 'coder', name: '编程助手', avatar: '👨💻', category: 'hot', desc: '精通编程语言,解答技术问题,生成代码', systemPrompt: '你是一个专业的编程助手,精通各类编程语言,能够解答技术问题并生成高质量代码。' }, - { id: 'translator', name: '翻译助手', avatar: '🌐', category: 'hot', desc: '多语言翻译,精准表达,文化适配', systemPrompt: '你是一个专业的翻译助手,精通多语言翻译,能够精准表达并适配文化差异。' }, + { id: 'assistant', name: '通用助手', avatar: '🤖', category: 'hot', desc: '能回答各类问题,帮助写作、分析、解答疑惑', systemPrompt: '你是一个智能助手,能够回答各类问题,帮助用户解决问题。', heat: 9500 }, + { id: 'writer', name: '写作助手', avatar: '✍️', category: 'hot', desc: '专注于文章写作、文案创作、内容润色', systemPrompt: '你是一个专业的写作助手,擅长各类文章写作、文案创作和内容润色。', heat: 8800 }, + { id: 'coder', name: '编程助手', avatar: '👨💻', category: 'hot', desc: '精通编程语言,解答技术问题,生成代码', systemPrompt: '你是一个专业的编程助手,精通各类编程语言,能够解答技术问题并生成高质量代码。', heat: 8500 }, + { id: 'translator', name: '翻译助手', avatar: '🌐', category: 'hot', desc: '多语言翻译,精准表达,文化适配', systemPrompt: '你是一个专业的翻译助手,精通多语言翻译,能够精准表达并适配文化差异。', heat: 7200 }, // 工作助手 - { id: 'assistant-work', name: '工作助手', avatar: '💼', category: 'work', desc: '职场问题解答,工作效率提升', systemPrompt: '你是一个工作助手,帮助解决职场问题,提升工作效率。' }, - { id: 'ppt', name: 'PPT助手', avatar: '📊', category: 'work', desc: 'PPT内容生成,结构优化,设计建议', systemPrompt: '你是一个PPT助手,擅长PPT内容生成、结构优化和设计建议。' }, - { id: 'excel', name: 'Excel助手', avatar: '📈', category: 'work', desc: 'Excel公式、数据分析、表格优化', systemPrompt: '你是一个Excel助手,精通Excel公式、数据分析和表格优化。' }, + { id: 'assistant-work', name: '工作助手', avatar: '💼', category: 'work', desc: '职场问题解答,工作效率提升', systemPrompt: '你是一个工作助手,帮助解决职场问题,提升工作效率。', heat: 5000 }, + { id: 'ppt', name: 'PPT助手', avatar: '📊', category: 'work', desc: 'PPT内容生成,结构优化,设计建议', systemPrompt: '你是一个PPT助手,擅长PPT内容生成、结构优化和设计建议。', heat: 4500 }, + { id: 'excel', name: 'Excel助手', avatar: '📈', category: 'work', desc: 'Excel公式、数据分析、表格优化', systemPrompt: '你是一个Excel助手,精通Excel公式、数据分析和表格优化。', heat: 4000 }, // 学习助手 - { id: 'teacher', name: '学习助手', avatar: '📚', category: 'study', desc: '知识讲解,学习方法,考试辅导', systemPrompt: '你是一个学习助手,擅长知识讲解、学习方法指导和考试辅导。' }, - { id: 'english', name: '英语助手', avatar: '🔤', category: 'study', desc: '英语学习,语法纠正,口语练习', systemPrompt: '你是一个英语助手,帮助英语学习、语法纠正和口语练习。' }, - { id: 'math', name: '数学助手', avatar: '🔢', category: 'study', desc: '数学解题,公式推导,概念讲解', systemPrompt: '你是一个数学助手,擅长数学解题、公式推导和概念讲解。' }, + { id: 'teacher', name: '学习助手', avatar: '📚', category: 'study', desc: '知识讲解,学习方法,考试辅导', systemPrompt: '你是一个学习助手,擅长知识讲解、学习方法指导和考试辅导。', heat: 5500 }, + { id: 'english', name: '英语助手', avatar: '🔤', category: 'study', desc: '英语学习,语法纠正,口语练习', systemPrompt: '你是一个英语助手,帮助英语学习、语法纠正和口语练习。', heat: 5000 }, + { id: 'math', name: '数学助手', avatar: '🔢', category: 'study', desc: '数学解题,公式推导,概念讲解', systemPrompt: '你是一个数学助手,擅长数学解题、公式推导和概念讲解。', heat: 4500 }, // 生活助手 - { id: 'health', name: '健康助手', avatar: '🏥', category: 'life', desc: '健康咨询,养生建议,运动指导', systemPrompt: '你是一个健康助手,提供健康咨询、养生建议和运动指导。' }, - { id: 'travel', name: '旅行助手', avatar: '✈️', category: 'life', desc: '旅行规划,景点推荐,美食指南', systemPrompt: '你是一个旅行助手,擅长旅行规划、景点推荐和美食指南。' }, - { id: 'food', name: '美食助手', avatar: '🍳', category: 'life', desc: '菜谱推荐,烹饪技巧,营养搭配', systemPrompt: '你是一个美食助手,提供菜谱推荐、烹饪技巧和营养搭配建议。' }, + { id: 'health', name: '健康助手', avatar: '🏥', category: 'life', desc: '健康咨询,养生建议,运动指导', systemPrompt: '你是一个健康助手,提供健康咨询、养生建议和运动指导。', heat: 3500 }, + { id: 'travel', name: '旅行助手', avatar: '✈️', category: 'life', desc: '旅行规划,景点推荐,美食指南', systemPrompt: '你是一个旅行助手,擅长旅行规划、景点推荐和美食指南。', heat: 3200 }, + { id: 'food', name: '美食助手', avatar: '🍳', category: 'life', desc: '菜谱推荐,烹饪技巧,营养搭配', systemPrompt: '你是一个美食助手,提供菜谱推荐、烹饪技巧和营养搭配建议。', heat: 3000 }, ]; +// 用户智能体界面显示的智能体(默认显示热门智能体) +let agents = []; + +// 用户添加的智能体(按类别分组) +let myAgents = { + hot: ['assistant', 'writer', 'coder', 'translator'], + work: ['assistant-work', 'ppt', 'excel'], + study: ['teacher', 'english', 'math'], + life: ['health', 'travel', 'food'] +}; + +// 收藏的智能体列表 +let favoriteAgents = []; + +// 置顶的智能体列表(按类别) +let pinnedAgents = { + hot: [], + work: [], + study: [], + life: [] +}; + let currentAgent = null; // 当前选中的智能体 // 获取使用智能体的对话列表(按时间倒序) @@ -52,7 +74,7 @@ function getAgentConversationHistory(limit = 5) { .sort((a, b) => b.updatedAt - a.updatedAt) // 按更新时间倒序 .slice(0, limit) .map(conv => { - const agent = agents.find(a => a.id === conv.agentId); + const agent = systemAgents.find(a => a.id === conv.agentId); return { ...conv, agent: agent @@ -105,6 +127,27 @@ document.addEventListener('DOMContentLoaded', () => { } } + // 加载用户智能体数据 + const savedMyAgents = localStorage.getItem('myAgents'); + if (savedMyAgents) { + myAgents = JSON.parse(savedMyAgents); + } + + // 加载收藏的智能体 + const savedFavoriteAgents = localStorage.getItem('favoriteAgents'); + if (savedFavoriteAgents) { + favoriteAgents = JSON.parse(savedFavoriteAgents); + } + + // 加载置顶的智能体 + const savedPinnedAgents = localStorage.getItem('pinnedAgents'); + if (savedPinnedAgents) { + pinnedAgents = JSON.parse(savedPinnedAgents); + } + + // 根据用户配置更新显示的智能体 + updateAgentsDisplay(); + // 加载当前页面状态 const savedPage = localStorage.getItem('currentPage'); if (savedPage) { @@ -115,6 +158,39 @@ document.addEventListener('DOMContentLoaded', () => { showMainPage(); }); +// 根据用户配置更新显示的智能体 +function updateAgentsDisplay() { + agents = []; + Object.keys(myAgents).forEach(category => { + myAgents[category].forEach(agentId => { + const agent = systemAgents.find(a => a.id === agentId); + if (agent) { + agents.push({ + ...agent, + is_pinned: pinnedAgents[category]?.includes(agentId) || false, + is_favorite: favoriteAgents.includes(agentId) + }); + } + }); + }); +} + +// 保存用户智能体配置 +function saveMyAgents() { + localStorage.setItem('myAgents', JSON.stringify(myAgents)); + updateAgentsDisplay(); +} + +// 保存收藏的智能体 +function saveFavoriteAgents() { + localStorage.setItem('favoriteAgents', JSON.stringify(favoriteAgents)); +} + +// 保存置顶的智能体 +function savePinnedAgents() { + localStorage.setItem('pinnedAgents', JSON.stringify(pinnedAgents)); +} + // ==================== 主页(底部导航栏) ==================== function showMainPage() { @@ -343,6 +419,7 @@ function bindChatsPageEvents() { // ==================== 智能体页面 ==================== function renderAgentsPage() { + // 根据用户配置筛选智能体 const hotAgents = agents.filter(a => a.category === 'hot'); const workAgents = agents.filter(a => a.category === 'work'); const studyAgents = agents.filter(a => a.category === 'study'); @@ -352,10 +429,21 @@ function renderAgentsPage() { const recentAgentConvos = getAgentConversationHistory(5); const totalAgentConvos = conversations.filter(c => c.agentId).length; + // 是否有收藏的智能体 + const hasFavorites = favoriteAgents.length > 0; + return `
暂无收藏的智能体
点击右上角搜索按钮发现更多智能体