Traduction

    Définition des Traductions

    La fonction t dans intlayer vous permet de déclarer du contenu dans plusieurs langues. Cette fonction assure la sécurité de type, générant une erreur si des traductions sont manquantes, ce qui est particulièrement utile dans les environnements TypeScript.

    Utilisation de TypeScript

    Voici un exemple de comment déclarer du contenu avec des traductions dans un fichier TypeScript :

    import { t, type DeclarationContent } from "intlayer"; const multiLangContent: DeclarationContent = { id: "multi_lang", welcomeMessage: t({ en: "Welcome to our application", fr: "Bienvenue dans notre application", es: "Bienvenido a nuestra aplicación", }), }; export default multiLangContent;

    Utilisation des Modules ECMAScript

    Si vous utilisez des modules ECMAScript, la déclaration ressemble à ceci :

    import { t } from "intlayer"; const multiLangContent = { id: "multi_lang", welcomeMessage: t({ en: "Welcome to our application", fr: "Bienvenue dans notre application", es: "Bienvenido a nuestra aplicación", }), }; export default multiLangContent;

    Utilisation des Modules CommonJS

    Dans un configuration CommonJS, vous pouvez déclarer les traductions ainsi :

    const { t } = require("intlayer"); const multiLangContent = { id: "multi_lang", welcomeMessage: t({ en: "Welcome to our application", fr: "Bienvenue dans notre application", es: "Bienvenido a nuestra aplicación", }), }; module.exports = multiLangContent;

    Utilisation de JSON

    Pour les déclarations basées sur JSON, vous pouvez définir les traductions de la manière suivante :

    { "id": "multi_lang", "welcomeMessage": { "nodeType": "translation", "en": "Welcome to our application", "fr": "Bienvenue dans notre application", "es": "Bienvenido a nuestra aplicación" } }

    Configuration pour les Locales

    Pour assurer une gestion correcte des traductions, vous pouvez configurer les locales acceptées dans intlayer.config.ts. Cette configuration vous permet de définir les langues que votre application prend en charge :

    import { Locales, type IntlayerConfig } from "intlayer"; const config: IntlayerConfig = { internationalization: { locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], }, }; export default config;

    Utilisation des Traductions dans les Composants React

    Avec react-intlayer, vous pouvez utiliser les traductions dans les composants React. Voici un exemple :

    import { useIntlayer } from "react-intlayer"; const MyComponent = () => { const content = useIntlayer("multi_lang"); return ( <div> <p>{content.welcomeMessage}</p> </div> ); }; export default MyComponent;

    Ce composant récupère la traduction correspondante basée sur la locale actuelle définie dans votre application.

    Objets de Contenu Personnalisés

    intlayer prend en charge les objets de contenu personnalisés pour la traduction, vous permettant de définir des structures plus complexes tout en assurant la sécurité de type. Voici un exemple avec un objet personnalisé :

    import { t, type DeclarationContent } from "intlayer"; interface ICustomContent { title: string; content: string; } const customContent: DeclarationContent = { id: "custom_content", profileText: t<ICustomContent>({ en: { title: "Page Title", content: "Page Content", }, fr: { title: "Titre de la Page", content: "Contenu de la Page", }, es: { title: "Título de la Página", content: "Contenido de la Página", }, }), }; export default customContent;

    Dans cette page