feat: 添加 Anki APKG 导入/导出功能

- 添加 APKG 解析器 (src/lib/anki/apkg-parser.ts)
- 添加 APKG 导出器 (src/lib/anki/apkg-exporter.ts)
- 添加导入/导出 Server Actions
- 添加导入/导出 UI 组件
- 集成到牌组页面
- 添加 i18n 翻译

同时修复断链:
- /folders → /decks (Navbar, signup, profile)
This commit is contained in:
2026-03-11 10:37:23 +08:00
parent 4d4062985d
commit 7ba31a37bd
13 changed files with 1654 additions and 32 deletions

View File

@@ -21,7 +21,7 @@ export async function Navbar() {
});
const mobileMenuItems: NavigationItem[] = [
{ label: t("folders"), href: "/folders", icon: <Folder size={18} /> },
{ label: t("folders"), href: "/decks", icon: <Folder size={18} /> },
{ label: t("explore"), href: "/explore", icon: <Compass size={18} /> },
...(session ? [{ label: t("favorites"), href: "/favorites", icon: <Heart size={18} /> }] : []),
{ label: t("sourceCode"), href: "https://github.com/GoddoNebianU/learn-languages", icon: <Github size={18} />, external: true },
@@ -42,7 +42,7 @@ export async function Navbar() {
</GhostLightButton>
<div className="flex gap-0.5 justify-center items-center">
<LanguageSettings />
<GhostLightButton href="/folders" className="md:block! hidden!" size="md">
<GhostLightButton href="/decks" className="md:block! hidden!" size="md">
{t("folders")}
</GhostLightButton>
<GhostLightButton href="/explore" className="md:block! hidden!" size="md">