mirror of
https://github.com/multica-ai/multica.git
synced 2026-06-17 11:48:42 +02:00
* docs(i18n): translate documentation corpus to Korean Add Korean (.ko.mdx) translations for all 32 navigable docs pages plus meta.ko.json navigation, mirroring the English source. Product terms (Issue→이슈, Agent→에이전트, Squad→스쿼드, Runtime→런타임, Skill→스킬, Workspace→워크스페이스, etc.) follow the in-app Korean locale at packages/views/locales/ko/. Roles (owner/admin/member) and issue status enums stay lowercase English per the conventions glossary. MUL-2817 Co-authored-by: multica-agent <github@multica.ai> * feat(docs): serve Korean docs content, remove English-fallback stopgap Now that the *.ko.mdx corpus exists, drop the temporary docsContentLang ko→en shim and the static-params fallback-synthesis loop so /docs/ko/* renders real Korean content. Korean is now a first-class locale whose params come straight from source.generateParams(). Also align the docs home hero copy (agent→에이전트) with the app and the translated body. MUL-2817 Co-authored-by: multica-agent <github@multica.ai> * docs(i18n): align residual Korean UI/product terms with the app Address review: sweep the .ko.mdx corpus for product/UI terms left in English and match the in-app Korean locale. - skills page title Skills → 스킬 - UI nav paths localized: Settings → 설정, Runtimes → 런타임, Agents → 에이전트, Projects → 프로젝트, Squads/New squad → 스쿼드/새 스쿼드, Usage → 사용량, Personal Access Tokens → API 토큰, Provider → 제공자, and the agent-create form labels (Name/Provider/Model/Instructions → 이름/제공자/모델/지침) - see-also links Issues/Workspaces/Environment variables and 'Providers Matrix' → Korean - kept as literals (verified): code blocks, the conventions i18n glossary data, 'Anthropic Agent Skills' (standard name), the Squad Operating Protocol/Roster/Instructions prompt-block names, the literal 'Project Context' prompt section, and Xcode's Settings path - add a docsAlternates test asserting ko hreflang is emitted when a real *.ko.mdx page exists MUL-2817 Co-authored-by: multica-agent <github@multica.ai> --------- Co-authored-by: J <j@multica.ai> Co-authored-by: multica-agent <github@multica.ai>
42 lines
930 B
TypeScript
42 lines
930 B
TypeScript
import { i18n, type Lang } from "@/lib/i18n";
|
|
|
|
export type DocsStaticParam = {
|
|
lang: Lang;
|
|
slug: string[];
|
|
};
|
|
|
|
type SourceStaticParam = {
|
|
lang: string;
|
|
slug: string[];
|
|
};
|
|
|
|
function isLang(lang: string): lang is Lang {
|
|
return (i18n.languages as readonly string[]).includes(lang);
|
|
}
|
|
|
|
function paramKey(param: DocsStaticParam): string {
|
|
return `${param.lang}/${param.slug.join("/")}`;
|
|
}
|
|
|
|
export function docsSlugStaticParams(
|
|
params: SourceStaticParam[],
|
|
): DocsStaticParam[] {
|
|
const slugParams = params.filter(
|
|
(param): param is DocsStaticParam =>
|
|
param.slug.length > 0 && isLang(param.lang),
|
|
);
|
|
const output: DocsStaticParam[] = [];
|
|
const seen = new Set<string>();
|
|
|
|
const addParam = (param: DocsStaticParam) => {
|
|
const key = paramKey(param);
|
|
if (seen.has(key)) return;
|
|
seen.add(key);
|
|
output.push(param);
|
|
};
|
|
|
|
for (const param of slugParams) addParam(param);
|
|
|
|
return output;
|
|
}
|