mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-25 21:56:08 +00:00
* feat: rtl * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add sidebar * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * chore: changeset * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix
89 lines
2.1 KiB
TypeScript
89 lines
2.1 KiB
TypeScript
"use client"
|
|
|
|
import { Button } from "@/examples/base/ui-rtl/button"
|
|
import {
|
|
Tooltip,
|
|
TooltipContent,
|
|
TooltipTrigger,
|
|
} from "@/examples/base/ui-rtl/tooltip"
|
|
|
|
import {
|
|
useTranslation,
|
|
type Translations,
|
|
} from "@/components/language-selector"
|
|
|
|
const translations: Translations = {
|
|
en: {
|
|
dir: "ltr",
|
|
values: {
|
|
content: "Add to library",
|
|
"inline-start": "Inline Start",
|
|
left: "Left",
|
|
top: "Top",
|
|
bottom: "Bottom",
|
|
right: "Right",
|
|
"inline-end": "Inline End",
|
|
},
|
|
},
|
|
ar: {
|
|
dir: "rtl",
|
|
values: {
|
|
content: "إضافة إلى المكتبة",
|
|
"inline-start": "بداية السطر",
|
|
left: "يسار",
|
|
top: "أعلى",
|
|
bottom: "أسفل",
|
|
right: "يمين",
|
|
"inline-end": "نهاية السطر",
|
|
},
|
|
},
|
|
he: {
|
|
dir: "rtl",
|
|
values: {
|
|
content: "הוסף לספרייה",
|
|
"inline-start": "תחילת השורה",
|
|
left: "שמאל",
|
|
top: "למעלה",
|
|
bottom: "למטה",
|
|
right: "ימין",
|
|
"inline-end": "סוף השורה",
|
|
},
|
|
},
|
|
}
|
|
|
|
const physicalSides = ["left", "top", "bottom", "right"] as const
|
|
const logicalSides = ["inline-start", "inline-end"] as const
|
|
|
|
export function TooltipRtl() {
|
|
const { dir, t } = useTranslation(translations, "ar")
|
|
|
|
return (
|
|
<div className="grid gap-4">
|
|
<div className="flex flex-wrap justify-center gap-2">
|
|
{physicalSides.map((side) => (
|
|
<Tooltip key={side}>
|
|
<TooltipTrigger render={<Button variant="outline" />}>
|
|
{t[side]}
|
|
</TooltipTrigger>
|
|
<TooltipContent side={side} dir={dir}>
|
|
{t.content}
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
))}
|
|
</div>
|
|
<div className="flex flex-wrap justify-center gap-2">
|
|
{logicalSides.map((side) => (
|
|
<Tooltip key={side}>
|
|
<TooltipTrigger render={<Button variant="outline" />}>
|
|
{t[side]}
|
|
</TooltipTrigger>
|
|
<TooltipContent side={side} dir={dir}>
|
|
{t.content}
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
))}
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|