Lägg till en språkinställning för adaptiv Forms baserat på kärnkomponenter supporting-new-locales-for-adaptive-forms-localization
Språkstöd för höger-till-vänster-språk är tillgängligt i det tidiga adopterprogrammet. Du kan skriva till aem-forms-ea@adobe.com från ditt officiella e-post-id för att gå med i det tidiga adopterprogrammet och begära åtkomst till funktionen.
AEM Forms har stöd för engelska (en), spanska (es), franska (fr), italienska (it), tyska (de), japanska (ja), portugisiska-brasilianska (pt-BR), kinesiska (zh-CN), kinesiska-taiwanesiska (zh-TW) och koreanska (ko-KR). Du kan även lägga till stöd för fler språkområden, som Hindi(hi_IN). Du kan också presentera Adaptiv Forms på höger-till-vänster-språk (RTL) som arabiska, persiska och urdu genom att lägga till dessa språkområden.
Hur avgör AEM Forms språkområdet för ett adaptivt formulär?
Att förstå hur AEM Forms väljer språkområde för återgivning av ett adaptivt formulär är avgörande för en korrekt lokalisering. Här följer en beskrivning av urvalsprocessen:
Prioritetsbaserad språkinställning
AEM Forms prioriterar följande metoder för att fastställa språkområdet för ett adaptivt formulär:
-
URL-språkväljare ([locale]):
Systemet prioriterar det språkområde som anges i URL:en med väljaren [locale] . Det här formatet möjliggör cachelagring för bättre prestanda.
Format: URL:en har följande format: http:/[AEM Forms Server URL]/content/forms/af/[afName].[locale].html?wcmmode=disabled.
Exempel: https://[server]/content/forms/af/contact-us.hi.html återger formuläret på hindi.
-
afAcceptLang-begärandeparameter:
Om du vill åsidosätta användarens språkområde i webbläsaren kan du använda parametern
afAcceptLang
i URL:en.Exempel: https://[server]/forms/af/survey.ca-fr.html?afAcceptLang=ca-fr tvingar formuläret att återges på kanadensisk franska.
-
Användarens språkområde (Accept-Language Header):
Om ingen annan språkinställning har angetts hanterar AEM Forms användarens språkområde i webbläsaren som har skickats med rubriken
Accept-Language
.
Reservmekanism:
-
Om ett klientbibliotek (processen för att lägga till ett nytt språk, som förklaras senare i det här dokumentet) för det begärda språket inte är tillgängligt söker AEM Forms efter ett bibliotek baserat på språkkoden i språkinställningen.
Exempel: Om en_ZA (sydafrikansk engelska) begärs och det inte finns något en_ZA-bibliotek, används en (engelska) om tillgängligt.
Om inget lämpligt klientbibliotek hittas används standardordlistan (mest
en
) för formulärets redigeringsspråk.Om det inte finns någon språkområdesinformation visas det adaptiva formuläret på det ursprungliga språk som användes under utvecklingen.
Krav för att lägga till en språkinställning
Innan du börjar lägga till en ny språkinställning för din adaptiva Forms måste du ha följande:
Programvara:
-
Oformaterad textredigerare (IDE): En integrerad utvecklingsmiljö (IDE) som Microsoft Visual Studio Code fungerar, men en vanlig textredigerare har avancerade funktioner för enklare redigering.
-
Git: Det här versionskontrollsystemet krävs för att hantera kodändringar. Om du inte har det installerat hämtar du det från https://git-scm.com.
Koddatabas:
Klona den adaptiva Forms Core Components-databasen: Du behöver ett klientbibliotek från den här databasen för att lägga till en språkinställning. Så här klonar du databasen:
-
Öppna kommandoraden eller terminalfönstret.
-
Navigera till önskad plats på datorn där du vill lagra databasen (till exempel /adaptive-forms-core-components).
-
Kör följande kommando för att klona databasen:
code language-none git clone https://github.com/adobe/aem-core-forms-components.git
Det här kommandot hämtar databasen och skapar en mapp med namnet
aem-core-forms-components
på datorn. I den här guiden ser vi den här mappen som[Adaptive Forms Core Components repository]
Lägga till en språkinställning add-localization-support-for-non-supported-locales
Följ de här stegen för att lägga till stöd för nya språkområden i ett adaptivt formulär baserat på kärnkomponenter:
Klona din AEM as a Cloud Service Git-databas
-
Öppna kommandoraden och välj en katalog där AEM as a Cloud Service-databasen ska lagras, t.ex.
/cloud-service-repository/
. -
Kör följande kommando för att klona databasen:
code language-shell git clone https://git.cloudmanager.adobe.com/<organization-name>/<program id>/
För att klona din Git-databas behöver du viss information:
-
Organisationsnamn: Detta identifierar ditt team eller projekt inom Adobe Experience Manager as a Cloud Service (AEM as a Cloud Service).
-
Program-ID: Detta anger det program som är associerat med din databas.
-
Autentiseringsuppgifter: Du behöver ett användarnamn och ett lösenord (eller en personlig åtkomsttoken) för att komma åt databasen på ett säkert sätt.
Var hittar du den här informationen?
Stegvisa instruktioner om hur du hittar dessa uppgifter finns i Adobe Experience League-artikeln Accessing Git.
Projektet är klart!
När kommandot har slutförts visas en ny mapp som har skapats i din lokala katalog. Den här mappen namnges efter programmet (till exempel program-id). Den här mappen innehåller alla filer och all kod som hämtats från din AEM as a Cloud Service Git-databas.
I hela den här guiden ser vi den här mappen som
[AEMaaCS project directory]
. -
Lägg till den nya språkinställningen i tjänsten för guidelokalisering
-
Öppna databasmappen i en redigerare.
-
Leta reda på filen
Guide Localization Service.cfg.json
. Den här filen kontrollerar de språkområden som stöds av ditt AEM Forms-program. Du kan redigera den här filen om du vill lägga till en ny språkinställning.-
Befintlig fil: Om filen redan finns letar du reda på den i AEM Forms projektkatalog. Den typiska platsen är:
code language-shell [AEMaaCS project directory]/ui.config/src/main/content/jcr_root/apps/<appid>/osgiconfig/config`.
Ersätt
<appid>
med ditt projektspecifika program-ID. Du kan hitta<appid>
för ditt AEM projekt i filenarchetype.properties
. -
Ny fil: Om filen inte finns måste du skapa den på samma plats som anges ovan. Kopiera inte filnamnet från det här dokumentet, utan skriv in namnet manuellt. Filnamnet
Guide Localization Service.cfg.json
innehåller blanksteg. Detta är avsiktligt och inte ett stavfel i dokumentationen.En exempelfil med en lista över språk som stöds av OOTB är:
code language-none { "supportedLocales":[ "en", "fr", "de", "ja", "pt-br", "zh-cn", "zh-tw", "ko-kr", "it", "es" ] }
-
-
Lägg till språkkoden för det språk du vill använda i filen.
-
Använd List of ISO 639-1 codes för att hitta den tvåbokstavskod som representerar det språk du vill använda.
-
Inkludera språkkoden i filen
Guide Localization Service.cfg.json
. Här är några exempel:-
Vänster till höger-språk:
- Engelska (USA): en-US
- Spanska (Spanien): es-ES
- Franska (Frankrike): fr-FR
-
Höger till vänster-språk:
- Arabiska (Förenade Arabemiraten): ar-ae
- Hebreiska: han (eller iw for history reference)
- Persiska: fa
-
-
-
När du har gjort ändringar kontrollerar du att filen
Guide Localization Service.cfg.json
är korrekt formaterad som en giltig JSON-fil. JSON-formateringsfel kan förhindra att det fungerar som det ska. Spara filen.
Utnyttja exempelbiblioteket för enkel språkinställning
AEM Forms tillhandahåller ett användbart exempel på klientbibliotek, clientlib-it-custom-locale
, för att förenkla tillägg av nya språkområden. Det här biblioteket ingår i databasen för adaptiva Forms Core-komponenter, som finns på GitHub.
Kontrollera att du har en lokal kopia av databasen [Adaptive Forms Core Components] innan vi börjar. Annars kan du enkelt klona den med Git med följande kommando:
git clone https://github.com/adobe/aem-core-forms-components.git
Det här kommandot hämtar hela databasen, inklusive clientlib-it-custom-locale-biblioteket, till en katalog med namnet aem-core-forms-components på datorn.
Integrera exempelklientbiblioteket
Nu ska vi lägga in biblioteket clientlib-it-custom-locale
i din AEM as a Cloud Service, [AEMaaCS-projektkatalog]:
-
Leta reda på exempelklientbiblioteket:
Gå till följande sökväg i den lokala kopian av [adaptiva Forms Core Components-databasen]:
code language-none /aem-core-forms-components/it/apps/src/main/content/jcr_root/apps/forms-core-components-it/clientlibs
-
Kopiera och klistra in biblioteket:
-
Kopiera mappen
clientlib-it-custom-locale
. -
Navigera till följande katalog i din [AEMaaCS-projektkatalog]:
code language-none /ui.apps/src/main/content/jcr_root/apps/<app-id>/clientlib
Viktigt: Ersätt
<app-id>
med ditt programs faktiska ID. -
Klistra in den kopierade mappen
clientlib-it-custom-locale
i den här katalogen.
-
Skapa en fil för din nya språkinställning:
-
Navigera till språkkatalogen:
Navigera till följande sökväg i din
[AEMaaCS project directory]
:code language-none /ui.apps/src/main/content/jcr_root/apps/<program-id>/clientlibs/clientlib-it-custom-locale/resources/i18n/
Viktigt: Ersätt
<program-id>
med ditt faktiska program-ID. -
Leta reda på exempelfilen för engelska:
AEM Forms tillhandahåller en exempelfil för engelska språk (.json) på GitHub.
Den engelska språkfilen innehåller standarduppsättningen med strängar för referens. Den språkområdesspecifika filen bör härma strukturen i den engelska språkfilen.
För språk som arabiska, hebreiska och farsi läses texten från höger till vänster (RTL) i stället för från vänster till höger (LTR) som engelska. För att formulären ska visas på rätt sätt på dessa språk rekommenderar vi att du använder våra exempelspråkfiler som vägledning. Dessa filer innehåller en referens för hur du formaterar text, datum och andra element för RTL-språk. Du kan hitta exempelfilerna för språkområdet för:
Genom att utnyttja dessa exempelfiler kan du säkerställa att formulären blir en smidig upplevelse för användare som arbetar på RTL-språk.
-
Skapa din språkfil:
- Skapa en ny .json-fil i katalogen
i18n
. - Namnge filen med rätt språkkod för det språk du vill arbeta med (t.ex. fr-FR.json för franska och ar-ae.json för arabiska). Strukturen i den här filen ska spegla den engelska språkfilen.
- Skapa en ny .json-fil i katalogen
-
Struktur och översättning:
-
Öppna den nya filen i en textredigerare.
-
Ersätt de engelska värdena med motsvarande översättningar för målspråket.
-
När du är klar med översättningen av strängarna sparar du filen.
-
Lägg till språkstöd i ordlistan
Det här steget gäller endast för andra språk än de som stöds vanligtvis: engelska (en), tyska (de), spanska (es), franska (fr), italienska (it), brasiliansk portugisiska (pt-br), kinesiska (förenklad - zh_cn), kinesiska (traditionell - zh_tw), japanska (ja) och koreanska (ko_kr).
-
Hitta konfigurationsmappen:
Navigera till följande katalog i din [AEMaaCS-projektkatalog]:
code language-none /ui.content/src/main/content/jcr_root/etc
-
Skapa nödvändiga mappar (om de saknas):
Om mappen
etc
inte finns i mappenjcr_root
skapar du den. Ietc
skapar du en annan mapp med namnetlanguages
om den saknas. -
Skapa språkkonfigurationsfilen:
Skapa en ny fil med namnet
.content.xml
i mappenlanguages
. Kopiera inte filnamnet från det här dokumentet, utan skriv in namnet manuellt.Öppna den här filen och klistra in följande innehåll och ersätt [LOCALE_CODE] med den faktiska språkkoden (t.ex. ar-ae för arabiska).
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]"/>
VARNING: Ersätt inte den befintliga listan. Lägg i stället till den nya språkkoden inom hakparenteser, avgränsade med kommatecken, som detta (med ar-ae som exempel):
code language-xml languages="[de,es,fr,it,pt-br,zh-cn,zh-tw,ja,ko-kr,hi,ar-ae]"
-
Inkludera de nya mapparna i filter.xml:
Navigera till filen
/ui.content/src/main/content/meta-inf/vault/filter.xml
i [AEMaaCS-projektkatalogen].Öppna filen och lägg till följande rad i slutet:
code language-none <filter root="/etc/languages"/>
-
Spara filen.
Distribuera den nyligen skapade språkinställningen till AEM
Nu kan du börja använda det nya språkområdet med din adaptiva Forms. Du kan
-
Distribuera AEM as a Cloud Service, [AEMaaCS-projektkatalogen], till din lokala utvecklingsmiljö och testa den nya språkkonfigurationen på din lokala dator. Så här distribuerar du till din lokala utvecklingsmiljö:
-
Kontrollera att den lokala utvecklingsmiljön är igång och körs. Om du inte redan har konfigurerat en lokal utvecklingsmiljö läser du i guiden Konfigurera lokal utvecklingsmiljö för AEM Forms.
-
Öppna terminalfönstret eller kommandotolken.
-
Navigera till [AEMaaCS-projektkatalogen]
-
Kör följande kommando:
code language-none mvn -PautoInstallPackage clean install
-
-
Distribuera AEM as a Cloud Service, [AEMaaCS-projektkatalogen], till din Cloud Service. Så här distribuerar du till din Cloud Service:
-
Genomför dina ändringar:
När du har lagt till den nya språkkonfigurationen verkställer du ändringarna med ett tydligt Git-meddelande som beskriver språktillägget (till exempel"Tillagt stöd för [språknamn]").
-
Distribuera den uppdaterade koden:
Utlös en distribution av koden via den befintliga pipelinen för hela stacken. Detta skapar och distribuerar automatiskt den uppdaterade koden med det nya språkstödet.
Om du inte redan har konfigurerat en pipeline kan du läsa guiden Konfigurera en pipeline för AEM Forms as a Cloud Service.
-
Förhandsgranska ett anpassat formulär med nyligen tillagda språk
Med de här stegen får du hjälp att förhandsgranska ett adaptivt formulär med den nya språkinställningen:
- Logga in på din AEM Forms as a Cloud Service-instans.
- Gå till Forms > Forms och dokument.
- Välj ett anpassat formulär och klicka på guiden Lägg till ordlista och Lägg till ordlista i översättningsprojekt visas.
- Ange Projektnamn och välj Målspråk i listrutan i guiden Lägg till ordlista i översättningsprojekt.
- Klicka på Klar och kör det skapade översättningsprojektet.
- Gå till Forms > Forms och dokument.
- Markera det anpassade formuläret och välj alternativet Förhandsgranska som HTML.
- Lägg till
&afAcceptLang=<locale-name>
i förhandsgransknings-URL:en och tryck på returtangenten. Ersätt<locale-name>
med den faktiska språkkoden. Det anpassningsbara formuläret visas på det angivna språket.
De bästa sätten att stödja ny lokalisering best-practices
-
Adobe rekommenderar att du skapar ett översättningsprojekt när du har skapat ett adaptivt formulär. Detta effektiviserar lokaliseringsprocessen.
-
När komponenterna Numerisk ruta och Datumväljare översätts till ett visst språkområde kan det uppstå formateringsproblem. För att minska detta har ett Language-alternativ integrerats i dialogrutan Konfigurera för datumväljarkomponenten och Numeric Box-komponenten.
-
Hantera nya fält:
-
Maskinöversättning: Om du använder maskinöversättning måste du återskapa ordlistan och köra översättningsprojektet igen när du har lagt till nya fält i ett befintligt adaptivt formulär. Nya fält som läggs till efter det inledande översättningsprojektet förblir oöversatta.
-
Översättning av människor: Exportera ordboken med användargränssnittet på
[AEM Forms Server]/libs/cq/i18n/gui/translator.html
för arbetsflöden för översättning av människor. Uppdatera ordlistan för de nya fälten och överför den reviderade versionen.
-
Se även see-also
-
Aktivera Adobe Analytics för ett adaptivt formulär för att spåra formuläranvändning
-
Använd Forms Portal för att lista AEM Adaptive Forms på en AEM webbplats
-
Lägga till versioner, kommentarer och anteckningar i ett adaptivt formulär
-
Lägga till ett anpassat formulär på en AEM Sites-sida eller ett Experience Fragment