Use custom translations (i18n)
Ory Elements supports internationalization (i18n) to help you create applications that can be used by users from different locales. This guide will show you how to use custom translations in your Ory Elements components.
Ory Elements uses the react-intl library to handle translations. You can provide your own translations for the Ory Elements
components by wrapping your application in the IntlProvider component from react-intl and passing your translations as
messages.
Set the default locale
By default, a set of translations is provided for the following locales:
- English (en)
- German (de)
- Spanish (es)
- French (fr)
- Italian (it)
- Swedish (sv)
A full list is available in the GitHub repository of Ory Elements. Contributions of new translations are welcome!
To set the default locale for your application, see the locale configuration section.
Detecting a user's locale
If your application supports multiple languages, you can detect the user's locale and set it dynamically. This can be done using
the Accept-Language header from the request in a server-side application or by using the browser's navigator.language property
in a client-side application.
Using custom translations
To use custom translations in your Ory Elements components, follow these steps:
- Standalone
- With react-intl
- 
Define your translations in typescript files. Here is an example of how to create a translations file: translations.tsexport const messages: Record<string, Record<string, string>> = {
 de: {
 "login.title": "Anmeldung",
 "login.description": "Bitte melden Sie sich an, um fortzufahren.",
 // other messages...
 },
 en: {
 "login.title": "Login",
 "login.description": "Please log in to continue.",
 // other messages...
 },
 }noteThe keys in the messagesobject should match the keys used in the Ory Elements components. You can find the full original files in the GitHub repository of Ory Elements.
- 
Pass it to the OryProvider's customTranslationsprop. Here is an example of how to do this in a Next.js application:app.tsximport { OryProvider } from "@ory/elements-react"
 import { messages } from "./translations"
 export default function MyApp({ Component, ...props }: { Component: NextPage }) {
 return (
 <OryProvider customTranslations={messages}>
 <Component {...props} />
 </OryProvider>
 )
 }
- 
Install the react-intllibrary if you haven't already:npm install react-intl
- 
Create a translations file (e.g., translations.ts) that contains your translations for different locales. Here is an example:translations.tsexport const messages: Record<string, string> = {
 en: {
 "login.title": "Login",
 // other messages...
 },
 de: {
 "login.title": "Anmeldung",
 },
 }noteThe keys in the messagesobject should match the keys used in the Ory Elements components. You can find the full original files in the GitHub repository of Ory Elements.
- 
Wrap your application in the IntlProvidercomponent and pass your translations as messages. Here is an example of how to do this in a Next.js application:- Next.js App Router
- Next.js Pages Router
 layout.tsximport { PropsWithChildren } from "react"
 import { IntlProvider } from "react-intl"
 import { messages } from "./translations"
 export default function Layout({ children }: PropsWithChildren) {
 return (
 <IntlProvider locale="en" messages={messages.en}>
 {children}
 </IntlProvider>
 )
 }app.tsximport type { NextPage } from "next"
 import { IntlProvider } from "react-intl"
 import { messages } from "./translations"
 export default function MyApp({ Component, ...props }: { Component: NextPage }) {
 return (
 <IntlProvider locale="en" messages={messages.en}>
 <Component {...props} />
 </IntlProvider>
 )
 }