Skip to content

Latest commit

 

History

History
43 lines (34 loc) · 1.1 KB

i18n.mdx

File metadata and controls

43 lines (34 loc) · 1.1 KB

import Callout from 'nextra-theme-docs/callout'

Next.js I18n

This feature is only available in the docs theme.

Nextra supports Next.js Internationalized Routing out of the box.

To add multi-language pages to your Nextra application, just need to config i18n in next.config.js:

const withNextra = require('nextra')('nextra-theme-docs', './theme.config.js')
module.exports = withNextra({
  i18n: {
    locales: ['en', 'zh', 'de'],
    defaultLocale: 'en'
  }
})

Then, add the locale codes to your file extensions (required for the default locale too):

/pages
  index.en.md
  index.zh.md
  index.de.md
  meta.en.json
  meta.zh.json
  meta.de.json
  ...

Finally, add the i18n option to your theme.config.js to configure the language dropdown:

i18n: [
  { locale: 'en', text: 'English' },
  { locale: 'zh', text: '中文' },
  { locale: 'de', text: 'Deutsch' },
  { locale: 'ar', text: 'العربية', direction: 'rtl' }
]