5.3.4 • Published 7 months ago

next-intlayer v5.3.4

Weekly downloads
-
License
Apache-2.0
Repository
github
Last release
7 months ago

next-intlayer: Internationalize (i18n) an Next.js application

Intlayer is a suite of packages designed specifically for JavaScript developers. It is compatible with frameworks like React, Next.js, and Express.js.

The next-intlayer package allows you to internationalize your Next.js application. It provides context providers and hooks for Next.js internationalization. Additionally, it includes the Next.js plugin for integrating Intlayer with Webpack or Turbopack, as well as middleware for detecting the user's preferred locale, managing cookies, and handling URL redirection.

Why Internationalize Your Next.js Application?

Internationalizing your Next.js application is essential for serving a global audience effectively. It allows your application to deliver content and messages in the preferred language of each user. This capability enhances user experience and broadens your application's reach by making it more accessible and relevant to people from different linguistic backgrounds.

Why to integrate Intlayer?

  • JavaScript-Powered Content Management: Harness the flexibility of JavaScript to define and manage your content efficiently.
  • Type-Safe Environment: Leverage TypeScript to ensure all your content definitions are precise and error-free.
  • Integrated Content Files: Keep your translations close to their respective components, enhancing maintainability and clarity.

Installation

Install the necessary package using your preferred package manager:

npm install next-intlayer
yarn add next-intlayer
pnpm add next-intlayer

Example of usage

With Intlayer, you can declare your content in a structured way anywhere in your codebase.

By default, Intlayer scans for files with the extension .content.{ts,tsx,js,jsx,mjs,cjs}.

You can modify the default extension by setting the contentDir property in the configuration file.

.
├── intlayer.config.ts
└── src
    └── components
        ├── ClientComponent
        │   ├── index.content.ts
        │   └── index.tsx
        └── ServerComponent
            ├── index.content.ts
            └── index.tsx

Declare your content

next-intlayer is made to work with the intlayer package.intlayer is a package that allows you to declare your content anywhere in your code. It converts multilingual content declarations into structured dictionaries that integrate seamlessly into your application.

Here’s an example of content declaration:

import { t, type Dictionary } from "intlayer";

const clientComponentContent = {
  key: "client-component",
  content: {
    myTranslatedContent: t({
      en: "Hello World",
      fr: "Bonjour le monde",
      es: "Hola Mundo",
    }),
    numberOfCar: enu({
      "<-1": "Less than minus one car",
      "-1": "Minus one car",
      "0": "No cars",
      "1": "One car",
      ">5": "Some cars",
      ">19": "Many cars",
    }),
  },
} satisfies Dictionary;

export default clientComponentContent;

Utilize Content in Your Code

Once you have declared your content, you can use it in your code. Here's an example of how to use the content in a React component:

"use client";

import type { FC } from "react";
import { useIntlayer } from "next-intlayer";

export const ClientComponentExample: FC = () => {
  const { myTranslatedContent } = useIntlayer("client-component"); // Create related content declaration

  return (
    <div>
      <p>{myTranslatedContent}</p>
    </div>
  );
};
"use client";

import { useIntlayer } from "next-intlayer";

const ClientComponentExample = () => {
  const { myTranslatedContent } = useIntlayer("client-component"); // Create related content declaration

  return (
    <div>
      <p>{myTranslatedContent}</p>
    </div>
  );
};
"use client";

const { useIntlayer } = require("next-intlayer");

const ClientComponentExample = () => {
  const { myTranslatedContent } = useIntlayer("client-component"); // Create related content declaration

  return (
    <div>
      <p>{myTranslatedContent}</p>
    </div>
  );
};

Mastering the internationalization of your Next.js application

Intlayer provides a lot of features to help you internationalize your Next.js application. Here are some of the key features:

  • Internationalization of server components: Intlayer allows you to internationalize your server components in the same way as your client components. This means that you can use the same content declarations for both client and server components.
  • Middleware for Locale Detection: Intlayer provides middleware to detect the user's preferred locale. This middleware is used to detect the user's preferred locale and redirect them to the appropriate URL as specified in the configuration.
  • Internationalization of metadata: Intlayer provides a way to internationalize your metadata, such as the title of your page, using the generateMetadata function provided by Next.js. You can use the getTranslation function to translate your metadata.
  • Internationalization of sitemap.xml and robots.txt: Intlayer allows you to internationalize your sitemap.xml and robots.txt files. You can use the getMultilingualUrls function to generate multilingual URLs for your sitemap.
  • Internationalization of URLs: Intlayer allows you to internationalize your URLs by using the getMultilingualUrls function. This function generates multilingual URLs for your sitemap.

To learn more about these features, refer to the Next.js Internationalization (i18n) with Intlayer and Next.js 15 App Router guide.

Functions provided by next-intlayer package

The next-intlayer package also provides some functions to help you to internationalize your application.

Read about Intlayer

5.3.3

7 months ago

5.3.2

7 months ago

5.3.1

7 months ago

5.3.0

8 months ago

3.5.11

9 months ago

3.5.10

9 months ago

4.1.8

9 months ago

4.1.7

9 months ago

4.1.9

9 months ago

3.3.6

11 months ago

3.2.2

11 months ago

3.2.1

11 months ago

3.2.0

11 months ago

4.0.5

9 months ago

4.0.4

9 months ago

4.0.0

9 months ago

4.0.3

9 months ago

4.0.2

9 months ago

5.0.6

9 months ago

5.0.5

9 months ago

5.0.4

9 months ago

5.0.3

9 months ago

5.0.2

9 months ago

5.0.1

9 months ago

5.0.0

9 months ago

3.1.0

11 months ago

3.5.3

11 months ago

3.5.2

11 months ago

3.5.1

11 months ago

3.5.0

11 months ago

5.1.8

8 months ago

5.1.7

8 months ago

5.1.6

8 months ago

5.1.5

8 months ago

5.1.4

8 months ago

5.1.3

8 months ago

5.1.2

8 months ago

5.1.1

8 months ago

5.1.0

8 months ago

3.5.7

9 months ago

3.5.6

10 months ago

3.5.5

10 months ago

3.5.4

10 months ago

3.5.9

9 months ago

3.5.8

9 months ago

3.0.3

12 months ago

3.0.2

12 months ago

3.0.1

12 months ago

3.0.0

12 months ago

5.2.9

8 months ago

5.2.8

8 months ago

5.2.7

8 months ago

5.2.6

8 months ago

5.2.5

8 months ago

5.2.4

8 months ago

5.2.3

8 months ago

5.2.2

8 months ago

5.2.1

8 months ago

5.2.0

8 months ago

4.1.10

9 months ago

4.1.11

9 months ago

3.4.8

11 months ago

3.4.7

11 months ago

3.4.6

11 months ago

3.4.9

11 months ago

3.3.5

11 months ago

3.3.4

11 months ago

3.3.3

11 months ago

3.3.2

11 months ago

4.1.4

9 months ago

4.1.3

9 months ago

4.1.6

9 months ago

4.1.5

9 months ago

4.1.0

9 months ago

4.1.2

9 months ago

4.1.1

9 months ago

5.3.4

7 months ago

2.0.3

1 year ago

2.0.2

1 year ago

2.0.13

1 year ago

2.0.5

1 year ago

2.0.4

1 year ago

2.0.11

1 year ago

2.0.7

1 year ago

2.0.12

1 year ago

2.0.6

1 year ago

2.0.9

1 year ago

2.0.10

1 year ago

2.0.8

1 year ago

2.0.1

1 year ago

2.0.0

1 year ago

1.2.1

1 year ago

1.2.0

2 years ago

1.0.1

2 years ago

1.0.0

2 years ago