Criação:2024-08-11Última atualização:2025-06-29

    Integração com React: Documentação do Hook useI18n

    Esta seção fornece orientações detalhadas sobre como usar o hook useI18n em aplicações React, permitindo uma localização eficiente de conteúdo.

    Importando useI18n no React

    O hook useI18n pode ser importado e integrado em aplicações React conforme o contexto, da seguinte forma:

    • Componentes Cliente:

      import { useI18n } from "react-intlayer"; // Use em componentes React do lado do cliente
      import { useI18n } from "react-intlayer"; // Use em componentes React do lado do cliente
      const { useI18n } = require("react-intlayer"); // Use em componentes React do lado do cliente
    • Componentes Servidor:

      import { useI18n } from "react-intlayer/server"; // Use em componentes React do lado do servidor
      import { useI18n } from "react-intlayer/server"; // Use em componentes React do lado do servidor
      const { useI18n } = require("react-intlayer/server"); // Use em componentes React do lado do servidor

    Parâmetros

    Este hook aceita dois parâmetros:

    1. namespace: Um namespace de dicionário para delimitar as chaves de tradução.
    2. locale (opcional): O locale desejado. Se não especificado, o locale do contexto será usado como padrão.

    Dicionário

    Todas as chaves do dicionário devem ser declaradas dentro dos arquivos de declaração de conteúdo para aumentar a segurança de tipos e evitar erros. Instruções de configuração podem ser encontradas aqui.

    Exemplos de Uso em React

    Exemplos de uso do hook useI18n dentro de componentes React:

    import type { FC } from "react";
    import { ClientComponentExample, ServerComponentExample } from "@components";
    import { IntlayerProvider } from "react-intlayer";
    import { useI18n, IntlayerServerProvider } from "react-intlayer/server";
    import { Locales } from "intlayer";
    
    const App: FC<{ locale: Locales }> = ({ locale }) => {
      const t = useI18n("home-page", locale);
    
      return (
        <>
          <p>{t("introduction")}</p>
          <IntlayerProvider locale={locale}>
            <ClientComponentExample />
          </IntlayerProvider>
          <IntlayerServerProvider locale={locale}>
            <ServerComponentExample />
          </IntlayerServerProvider>
        </>
      );
    };
    import type { FC } from "react";
    import { useI18n } from "react-intlayer";
    
    const ComponentExample: FC = () => {
      const t = useI18n("component-example");
    
      return (
        <div>
          <h1>{t("title")}</h1> {/* Exibe o título */}
          <p>{t("description")}</p> {/* Exibe a descrição */}
        </div>
      );
    };
    import { useI18n } from "react-intlayer/server";
    
    const ServerComponentExample = () => {
      const t = useI18n("server-component");
    
      return (
        <div>
          <h1>{t("title")}</h1> {/* Exibe o título */}
          <p>{t("description")}</p> {/* Exibe a descrição */}
        </div>
      );
    };

    Manipulação de Atributos

    Ao localizar atributos, acesse os valores de tradução de forma apropriada:

    <!-- Para atributos de acessibilidade (ex.: aria-label), use .value pois são necessárias strings puras -->
    <button aria-label={t("button.ariaLabel").value}>{t("button.text")}</button>

    Recursos Adicionais

    • Editor Visual Intlayer: Para uma experiência de gerenciamento de conteúdo mais intuitiva, consulte a documentação do editor visual aqui.

    Esta seção cobre especificamente a integração do hook useI18n em aplicações React, simplificando o processo de localização e garantindo a consistência do conteúdo entre diferentes locais.