- Add border styles to JsonEditor (CodeMirror) with theme-responsive colors - Update all dialog header/footer dividers to use border-border-default - Replace remaining border-border instances in settings components - Ensure all borders (including separators and container borders) use unified design system - All borders now consistently use CSS variables and respond to light/dark themes
57 lines
1.6 KiB
TypeScript
57 lines
1.6 KiB
TypeScript
import { Button } from "@/components/ui/button";
|
|
import { cn } from "@/lib/utils";
|
|
import { useTranslation } from "react-i18next";
|
|
|
|
interface LanguageSettingsProps {
|
|
value: "zh" | "en";
|
|
onChange: (value: "zh" | "en") => void;
|
|
}
|
|
|
|
export function LanguageSettings({ value, onChange }: LanguageSettingsProps) {
|
|
const { t } = useTranslation();
|
|
|
|
return (
|
|
<section className="space-y-2">
|
|
<header className="space-y-1">
|
|
<h3 className="text-sm font-medium">{t("settings.language")}</h3>
|
|
<p className="text-xs text-muted-foreground">
|
|
{t("settings.languageHint")}
|
|
</p>
|
|
</header>
|
|
<div className="inline-flex gap-1 rounded-md border border-border-default bg-background p-1">
|
|
<LanguageButton active={value === "zh"} onClick={() => onChange("zh")}>
|
|
{t("settings.languageOptionChinese")}
|
|
</LanguageButton>
|
|
<LanguageButton active={value === "en"} onClick={() => onChange("en")}>
|
|
{t("settings.languageOptionEnglish")}
|
|
</LanguageButton>
|
|
</div>
|
|
</section>
|
|
);
|
|
}
|
|
|
|
interface LanguageButtonProps {
|
|
active: boolean;
|
|
onClick: () => void;
|
|
children: React.ReactNode;
|
|
}
|
|
|
|
function LanguageButton({ active, onClick, children }: LanguageButtonProps) {
|
|
return (
|
|
<Button
|
|
type="button"
|
|
onClick={onClick}
|
|
size="sm"
|
|
variant={active ? "default" : "ghost"}
|
|
className={cn(
|
|
"min-w-[96px]",
|
|
active
|
|
? "shadow-sm"
|
|
: "text-muted-foreground hover:text-foreground hover:bg-muted",
|
|
)}
|
|
>
|
|
{children}
|
|
</Button>
|
|
);
|
|
}
|