Adicione uma localidade para o Forms adaptável com base nos Componentes principais supporting-new-locales-for-adaptive-forms-localization
O recurso de suporte a idiomas da direita para a esquerda está disponível no programa dos primeiros usuários. Você pode escrever para aem-forms-ea@adobe.com da sua ID de email oficial para ingressar no programa de adoção antecipada e solicitar acesso ao recurso.
O AEM Forms oferece suporte imediato para as localidades de inglês (en), espanhol (es), francês (fr), italiano (it), alemão (de), japonês (ja), português-brasileiro (pt-BR), chinês (zh-CN), chinês-Taiwan (zh-TW) e coreano (ko-KR). Você também pode adicionar suporte para mais locais, como Hindi(hi_IN). Você também pode apresentar o Adaptive Forms em um idioma da Direita para a Esquerda (RTL), como árabe, persa e urdu, adicionando esses locais.
Como o AEM Forms determina a localidade de um formulário adaptável?
Entender como o AEM Forms seleciona o local para renderizar um Formulário adaptável é crucial para a localização adequada. Veja um detalhamento do processo de seleção:
Seleção de localidade com base em prioridade
O AEM Forms prioriza os seguintes métodos para determinar a localidade de um Formulário adaptável:
-
Seletor de Localidade da URL ([localidade]):
O sistema prioriza a localidade especificada na URL usando o seletor de [localidade]. Esse formato permite o armazenamento em cache para melhorar o desempenho.
Formato: A URL segue este formato: http:/[URL do AEM Forms Server]/content/forms/af/[afName].[locale].html?wcmmode=disabled.
Exemplo: https://[server]/content/forms/af/contact-us.hi.html renderiza o formulário em híndi.
-
Parâmetro de Solicitação afAcceptLang:
Para substituir a localidade do navegador do usuário, você pode usar o parâmetro
afAcceptLang
na URL.Exemplo: https://[server]/forms/af/survey.ca-fr.html?afAcceptLang=ca-fr força o formulário a ser renderizado em francês canadense.
-
Localidade do Navegador do Usuário (Cabeçalho Accept-Language):
Se nenhuma outra localidade for especificada, a AEM Forms considerará a localidade do navegador do usuário enviada usando o cabeçalho
Accept-Language
.
Mecanismo de fallback:
-
Se uma biblioteca do cliente (processo para adicionar um novo local, explicado mais adiante neste documento) para o local solicitado não estiver disponível, o AEM Forms verificará se há uma biblioteca com base no código do idioma no local.
Exemplo: se en_ZA (inglês da África do Sul) for solicitado e não houver uma biblioteca en_ZA, ela usará en (inglês), se disponível.
Se nenhuma biblioteca de cliente adequada for encontrada, o dicionário padrão (principalmente
en
) para a linguagem de criação do formulário será usado.Na ausência de informações de local, o Formulário adaptável é exibido em seu idioma original usado durante o desenvolvimento.
Pré-requisitos para adicionar um local
Antes de começar a adicionar um novo local para o Adaptive Forms, verifique se você tem o seguinte:
Software:
-
Editor de texto sem formatação (IDE): embora qualquer editor de texto sem formatação possa funcionar, um IDE (Ambiente de Desenvolvimento Integrado) como o Microsoft Visual Studio Code oferece recursos avançados para facilitar a edição.
-
Git: este sistema de controle de versão é necessário para gerenciar alterações de código. Se você não o instalou, baixe-o de https://git-scm.com.
Repositório de Códigos:
Clonar o repositório dos componentes principais adaptáveis do Forms: você precisa de uma biblioteca do cliente desse repositório para adicionar um local. Para clonar o repositório:
-
Abra a linha de comando ou a janela do terminal.
-
Navegue até o local desejado no computador onde deseja armazenar o repositório (por exemplo, /adaptive-forms-core-components).
-
Execute o seguinte comando para clonar o repositório:
code language-none git clone https://github.com/adobe/aem-core-forms-components.git
Este comando baixa o repositório e cria uma pasta chamada
aem-core-forms-components
no computador. Neste guia, nos referimos a esta pasta como[Adaptive Forms Core Components repository]
Adicionar uma localidade add-localization-support-for-non-supported-locales
Para adicionar suporte a novos locais a um formulário adaptável com base em componentes principais, siga estas etapas:
Clonar o repositório Git do AEM as a Cloud Service
-
Abra a linha de comando e escolha um diretório para armazenar seu repositório do AEM as a Cloud Service, como
/cloud-service-repository/
. -
Execute o comando abaixo para clonar o repositório:
code language-shell git clone https://git.cloudmanager.adobe.com/<organization-name>/<program id>/
Para clonar o repositório Git, você precisa de algumas informações:
-
Nome da organização: isso identifica sua equipe ou projeto na Adobe Experience Manager as a Cloud Service (AEM as a Cloud Service).
-
ID do programa: especifica o programa associado ao seu repositório.
-
Credenciais: você precisa de um nome de usuário e senha (ou um token de acesso pessoal) para acessar o repositório com segurança.
Onde encontrar essas informações?
Para obter instruções passo a passo sobre como localizar esses detalhes, consulte o artigo da Adobe Experience League "Acessando o Git".
Seu projeto está pronto!
Quando o comando for concluído com sucesso, você verá uma nova pasta criada no diretório local. Essa pasta é nomeada com base no seu programa (por exemplo, id-do-programa). Esta pasta contém todos os arquivos e códigos baixados do repositório Git da AEM as a Cloud Service.
Neste guia, nos referimos a essa pasta como
[AEMaaCS project directory]
. -
Adicionar a nova localidade ao Serviço de localização do guia
-
Abra a pasta do repositório em um editor.
-
Localize o arquivo
Guide Localization Service.cfg.json
. Esse arquivo controla as localidades compatíveis com seu aplicativo AEM Forms. Você pode editar esse arquivo para adicionar um novo local.-
Arquivo existente: se o arquivo já existir, localize-o no diretório do projeto do AEM Forms. A localização típica é:
code language-shell [AEMaaCS project directory]/ui.config/src/main/content/jcr_root/apps/<appid>/osgiconfig/config`.
Substitua
<appid>
pela ID do aplicativo específica do seu projeto. Você pode encontrar<appid>
para seu projeto AEM no arquivoarchetype.properties
. -
Novo arquivo: se o arquivo não existir, você precisará criá-lo no mesmo local mencionado acima. Não copie e cole o nome do arquivo deste documento. Em vez disso, digite manualmente o nome. O nome de arquivo
Guide Localization Service.cfg.json
inclui espaços. Isso é intencional e não um erro de digitação na documentação.Um arquivo de amostra com a lista de localidades com suporte para OOTB é:
code language-none { "supportedLocales":[ "en", "fr", "de", "ja", "pt-br", "zh-cn", "zh-tw", "ko-kr", "it", "es" ] }
-
-
Adicione o código de localidade do idioma desejado ao arquivo.
-
Use a Lista de códigos ISO 639-1 para localizar o código de duas letras que representa o idioma desejado.
-
Inclua o código de localidade no arquivo
Guide Localization Service.cfg.json
. Veja alguns exemplos:-
Idiomas da esquerda para a direita:
- Inglês (Estados Unidos): en-US
- Espanhol (Espanha): es-ES
- Francês (França): fr-FR
-
Idiomas da direita para a esquerda:
- Árabe (Emirados Árabes Unidos): ar-ae
- Hebraico: ele (ou iw para referência histórica)
- Farsi: fa
-
-
-
Depois de fazer as alterações, verifique se o arquivo
Guide Localization Service.cfg.json
está formatado corretamente como um arquivo JSON válido. Erros na formatação JSON podem impedir que ela funcione corretamente. Salve o arquivo.
Aproveite a biblioteca de exemplo do cliente para facilitar a adição de local
O AEM Forms fornece uma biblioteca de cliente de exemplo útil, clientlib-it-custom-locale
, para simplificar a adição de novas localidades. Esta biblioteca faz parte do Repositório dos Componentes principais do Forms Adaptive, disponível no GitHub.
Antes de começarmos, verifique se você tem uma cópia local do [Repositório dos Componentes principais do Forms Adaptive]. Caso contrário, você pode cloná-lo facilmente usando o Git com o seguinte comando:
git clone https://github.com/adobe/aem-core-forms-components.git
Esse comando baixa o repositório inteiro, incluindo a biblioteca clientlib-it-custom-locale, para um diretório chamado aem-core-forms-components na máquina.
Integrar a biblioteca de exemplo do cliente
Agora, vamos incorporar a biblioteca clientlib-it-custom-locale
ao seu AEM as a Cloud Service, [diretório do projeto AEMaaCS]:
-
Localize a biblioteca de exemplo de cliente:
Em sua cópia local do [repositório dos Componentes principais do Forms adaptável], navegue até o seguinte caminho:
code language-none /aem-core-forms-components/it/apps/src/main/content/jcr_root/apps/forms-core-components-it/clientlibs
-
Copie e cole a biblioteca:
-
Copie a pasta
clientlib-it-custom-locale
. -
Navegue até o seguinte diretório no [diretório do projeto AEMaaCS]:
code language-none /ui.apps/src/main/content/jcr_root/apps/<app-id>/clientlib
Importante: substitua
<app-id>
pela ID real do seu aplicativo. -
Cole a pasta
clientlib-it-custom-locale
copiada neste diretório.
-
Crie um arquivo para o novo local:
-
Navegue até o Diretório de Localidade:
Em seu
[AEMaaCS project directory]
, navegue até o seguinte caminho:code language-none /ui.apps/src/main/content/jcr_root/apps/<program-id>/clientlibs/clientlib-it-custom-locale/resources/i18n/
Importante: substitua
<program-id>
pela ID do aplicativo real. -
Localize o arquivo de amostra no idioma inglês:
O AEM Forms fornece um arquivo de local em inglês de exemplo (.json) no GitHub.
O arquivo de idioma inglês inclui o conjunto padrão de cadeias de caracteres para referência. O arquivo específico de local deve imitar a estrutura do arquivo de idioma inglês.
Para idiomas como árabe, hebraico e farsi, o texto é lido da direita para a esquerda (RTL) em vez da esquerda para a direita (LTR) como inglês. Para garantir que seus formulários sejam exibidos corretamente nesses idiomas, recomendamos usar nossos arquivos de localidade de amostra como guia. Esses arquivos fornecem uma referência sobre como formatar texto, datas e outros elementos para idiomas RTL. Você pode encontrar os arquivos de código do idioma de exemplo para:
Ao aproveitar esses arquivos de amostra, você pode garantir que seus formulários forneçam uma experiência perfeita para usuários que trabalham em idiomas RTL.
-
Crie seu arquivo de local:
- Crie um novo arquivo .json no diretório
i18n
. - Nomeie o arquivo usando o código de localidade apropriado para o idioma desejado (por exemplo, fr-FR.json para francês e ar-ae.json para árabe). A estrutura desse arquivo deve refletir o arquivo de localidade em inglês.
- Crie um novo arquivo .json no diretório
-
Estrutura e tradução:
-
Abra o arquivo recém-criado em um editor de texto.
-
Substitua os valores em inglês pelas traduções correspondentes para o seu idioma de destino.
-
Depois de concluir a tradução das cadeias de caracteres, salve o arquivo.
-
Adicionar suporte de localidade ao dicionário
Esta etapa se aplica somente às localidades diferentes das seguintes comumente suportadas: inglês (en), alemão (de), espanhol (es), francês (fr), italiano (it), português brasileiro (pt-br), chinês (simplificado - zh_cn), chinês (tradicional - zh_tw), japonês (ja) e coreano (ko_kr).
-
Localize a pasta de configuração:
Navegue até o seguinte diretório no seu [diretório do projeto AEMaaCS]:
code language-none /ui.content/src/main/content/jcr_root/etc
-
Crie as pastas necessárias (se estiverem ausentes):
Se a pasta
etc
não existir na pastajcr_root
, crie-a. Dentro deetc
, crie outra pasta chamadalanguages
, se ela estiver ausente. -
Crie o arquivo de configuração de local:
Na pasta
languages
, crie um novo arquivo chamado.content.xml
. Não copie e cole o nome do arquivo deste documento. Em vez disso, digite manualmente o nome.Abra este arquivo e cole o conteúdo a seguir, substituindo [LOCALE_CODE] pelo código de localidade real (Por exemplo, ar-ae para Árabe).
code language-xml <?xml version="1.0" encoding="UTF-8"?> <jcr:root xmlns:jcr="http://www.jcp.org/jcr/1.0" xmlns:nt="http://www.jcp.org/jcr/nt/1.0" jcr:primaryType="nt:unstructured" languages="[de,es,fr,it,pt-br,zh-cn,zh-tw,ja,ko-kr,hi]"/>
AVISO: não substitua a lista existente. Em vez disso, anexe o novo código de localidade entre colchetes, separados por vírgulas, desta forma (usando ar-ae como exemplo):
code language-xml languages="[de,es,fr,it,pt-br,zh-cn,zh-tw,ja,ko-kr,hi,ar-ae]"
-
Incluir as Novas Pastas em filter.xml:
Navegue até o arquivo
/ui.content/src/main/content/meta-inf/vault/filter.xml
no seu [diretório do projeto AEMaaCS].Abra o arquivo e adicione a seguinte linha no final:
code language-none <filter root="/etc/languages"/>
-
Salve o arquivo.
Implante a localidade recém-criada no ambiente AEM
Agora você está pronto para usar o novo local com sua Forms adaptável. Você pode
-
Implante o AEM as a Cloud Service, [diretório do projeto AEMaaCS], no ambiente de desenvolvimento local para experimentar a nova configuração de localidade no computador local. Para implantar no ambiente de desenvolvimento local:
-
Certifique-se de que o ambiente de desenvolvimento local esteja em funcionamento. Se você ainda não tiver configurado um ambiente de desenvolvimento local, consulte o manual em Configurar ambiente de desenvolvimento local para o AEM Forms.
-
Abra a janela do terminal ou o prompt de comando.
-
Navegue até o [diretório do projeto AEMaaCS]
-
Execute o seguinte comando:
code language-none mvn -PautoInstallPackage clean install
-
-
Implante o AEM as a Cloud Service, [diretório do projeto AEMaaCS], no seu ambiente Cloud Service. Para implantar no ambiente de Cloud Service:
-
Confirme suas alterações:
Depois de adicionar a nova configuração de localidade, confirme suas alterações com uma mensagem clara do Git descrevendo a adição da localidade (Por exemplo, "Adicionado suporte para [Nome da localidade]").
-
Implante o código atualizado:
Acione uma implantação do seu código por meio do pipeline de pilha completa existente. Isso cria e implanta automaticamente o código atualizado com o novo suporte de localidade.
Se você ainda não tiver configurado um pipeline, consulte o manual sobre como configurar um pipeline para o AEM Forms as a Cloud Service.
-
Visualizar um formulário adaptável com a localidade recém-adicionada
Essas etapas orientam você na pré-visualização de um Formulário adaptável com a localidade recém-adicionada:
- Faça logon na instância as a Cloud Service do AEM Forms.
- Ir para Forms > Forms e Documentos.
- Selecione um formulário adaptável e clique em Adicionar dicionário e o assistente Adicionar dicionário ao projeto de tradução será exibido.
- Especifique o Título do Projeto e selecione os Idiomas de Destino no menu suspenso do assistente Adicionar Dicionário ao Projeto de Tradução.
- Clique em Concluído e execute o projeto de tradução criado.
- Ir para Forms > Forms e Documentos.
- Selecione o Formulário adaptável e escolha a opção Visualizar como HTML.
- Anexe
&afAcceptLang=<locale-name>
à URL de visualização e pressione a tecla Return. Substitua<locale-name>
pelo seu código de localidade atual. O formulário adaptável é exibido no local especificado.
Práticas recomendadas para oferecer suporte à nova localização best-practices
-
O Adobe recomenda criar um projeto de tradução após criar um Formulário adaptável. Isso simplifica o processo de localização.
-
Quando os componentes Caixa numérica e Seletor de data são convertidos em um local específico, podem ocorrer problemas de formatação. Para atenuar isso, uma opção Idioma foi incorporada à caixa de diálogo Configurar do componente seletor de datas e do componente Caixa Numérica.
-
Tratamento de novos campos:
-
Tradução Automática: se estiver usando tradução automática, você precisará recriar o dicionário e executar novamente o projeto de tradução🔗 depois de adicionar novos campos a um Formulário Adaptável existente. Os novos campos adicionados após o projeto de tradução inicial permanecem não traduzidos.
-
Tradução humana: para fluxos de trabalho de tradução humana, exporte o dicionário usando a interface do usuário em
[AEM Forms Server]/libs/cq/i18n/gui/translator.html
. Atualize o dicionário para os novos campos e faça upload da versão revisada.
-
Consulte também see-also
-
Adicionar um formulário adaptável de AEM à página do AEM Sites
-
Gerar uma versão de PDF (DoR) de um formulário adaptável AEM
-
Ativar o Adobe Analytics para um formulário adaptável para rastrear o uso do formulário
-
Conectar o formulário adaptável ao armazenamento de blobs do Microsoft Azure
-
Enviar dados do formulário adaptável para o fluxo de trabalho do AEM
-
Usar o Forms Portal para listar AEM Adaptive Forms em um site de AEM
-
Adicionar versões, comentários e anotações a um Formulário adaptável
-
Adição de um formulário adaptável a uma página do AEM Sites ou a um fragmento de experiência