feat(web): 重构前端UI并支持OpenAI协议

- 添加账号管理详情页(基本信息、提示词、CapCut、参考图标签页)
- 重构资产页面,按项目组分开展示图片/视频
- 聊天界面支持深度思考内容折叠展示、复制、删除消息
- 设置页面支持Agent配置(Anthropic/OpenAI协议)和工具配置
- 后端支持OpenAI兼容协议流式输出和DeepSeek思考模式
- 添加对话置顶/删除功能、数据库迁移、资产清单API
- 添加账号参考图上传/删除、技能配置持久化、连接测试API
This commit is contained in:
2026-05-07 23:48:26 +08:00
parent 01963aac96
commit 088bdb9a8e
40 changed files with 2594 additions and 678 deletions

View File

@@ -6,7 +6,6 @@ import { SCHEMA_SQL } from './schema';
const __filename = fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);
const DB_PATH = path.resolve(__dirname, '..', '..', 'data', 'meitu-agent.db');
let db: Database.Database;
@@ -22,7 +21,18 @@ export function getDb(): Database.Database {
return db;
}
// Ensure a column exists on a table, add it with DEFAULT if missing
function ensureColumn(d: Database.Database, table: string, column: string, definition: string) {
const cols = d.prepare(`PRAGMA table_info('${table}')`).all() as { name: string }[];
if (!cols.some((c) => c.name === column)) {
d.exec(`ALTER TABLE ${table} ADD COLUMN ${column} ${definition}`);
}
}
export function initDb(): void {
const d = getDb();
d.exec(SCHEMA_SQL);
// Migrations for existing databases
ensureColumn(d, 'conversations', 'pinned', 'INTEGER NOT NULL DEFAULT 0');
}

View File

@@ -3,6 +3,7 @@ export const SCHEMA_SQL = `
id TEXT PRIMARY KEY,
title TEXT NOT NULL,
account_id TEXT,
pinned INTEGER NOT NULL DEFAULT 0,
created_at TEXT NOT NULL DEFAULT (datetime('now')),
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
);