apps/v4/content/docs/rtl/start.mdx
Starting a new project? Use shadcn/create for a fully configured TanStack Start app with custom themes, Base UI or Radix, and icon libraries.
</Callout> <Steps>Create a new project using the --rtl flag and the start template.
You can skip this step if you have already created a project using shadcn/create.
npx shadcn@latest create --template start --rtl
This will create a components.json file with the rtl: true flag.
{
"$schema": "https://ui.shadcn.com/schema.json",
"style": "base-nova",
"rtl": true
}
Add the dir="rtl" and lang="ar" attributes to the html tag. Update lang="ar" to your target language.
Then wrap your app with the DirectionProvider component with the direction="rtl" prop in your __root.tsx:
import { DirectionProvider } from "@/components/ui/direction"
export const Route = createRootRoute({
component: RootComponent,
})
function RootComponent() {
return (
<html lang="ar" dir="rtl">
<head>
<Meta />
</head>
<body>
<DirectionProvider direction="rtl">{children}</DirectionProvider>
<Scripts />
</body>
</html>
)
}
For the best RTL experience, we recommend using fonts that have proper support for your target language. Noto is a great font family for this and it pairs well with Inter and Geist.
Install the font using Fontsource:
npm install @fontsource-variable/noto-sans-arabic
Import the font in your styles.css:
@import "tailwindcss";
@import "tw-animate-css";
@import "shadcn/tailwind.css";
@import "@fontsource-variable/noto-sans-arabic";
@theme inline {
--font-sans: "Noto Sans Arabic Variable", sans-serif;
}
For other languages, eg. Hebrew, you can use @fontsource-variable/noto-sans-hebrew.
You are now ready to add components to your project. The CLI will take care of handling RTL support for you.
npx shadcn@latest add item