Skip to content
Branch: master
Find file History
juliemturner and wobba Add Video demo (#165)
Add link to PnP YouTube video demoing solution.
Latest commit a5240f1 May 18, 2019

Multilingual Pages


To see a live demo of the soultion check out the video posted on the PnP YouTube channel.

Multilingual Application Customizer

This solution contains a application customizer and a web part that when used together provide a client side solution to managing multilingual pages in a SharePoint site collection.

The application customizer includes a custom footer extension that will add a the multilingual functionality for viewers and additional functionality for editors (those with edit item rights to the Site Pages library).

After addition the app to your site collection, navigate to the site pages library. Assuming you've set up your languages properly, see Languages Configuration, then after the multilingual extension loads on the page it will configure the folders for you.

Screenshot of site pages library with language folders

  1. When an "editor" creates a new page in the site pages library it will then have an indicator that the page is not in a language folder and will ask the user if they would like to move it to one. The user can select the language they want to start from and then click Move Page.

Screenshot of page in root of site pages library

  1. The user will receive a message asking them to confirm. This option is only available to users with editing rights.

Screenshot of page move confirmation

If the page is in a language folder but not configured for multilingual a notification icon i will show for users who have edit rights. Clicking that icon will put the page in edit mode.

Screenshot of multilingual not configured icon

Once the page is moved, or created specifically in a language folder, the"Language Details" button will be shown in the footer when the page is in edit mode. Clicking it will reveal the language configuration panel.

Screenshot of language details button Screenshot of page details configuration page

The language folder you start the translation in becomes the master language. You can change your master language on a page by page basis.

Screenshot of configured page details

  1. Select the languages you would like to translate this page to.
  2. If desired, turn on the redirector page setting to have the system create a page in the root of the site pages library with the same name but the redirector web part added, and configured, based on the languages you selected.
  3. Click Apply Language Changes to save this configuration.

Publish the page to make it visible to viewers.

When a translated page is not in edit mode the users see a navigation selector in the footer of the page. It will show the currently selected language and when the user hovers over the area a selector of the languages the page has been translated to.

Screenshot of language selector

  1. Note a redirector page has been created in the root of the site pages library with the same name. Opening that page in edit mode with the query string ?Stay=True will halt the redirector from firing so that it can be manually modified. The redirector web part is also available in the gallery so it can be manually deployed independent of the multilingual solution.

When multilingual application customizer first ran it not only created the language folders but also 4 additional site columns that were then added to the Site Page content type. You can configure the view to see them.

Screenshot of site pages metadata

  1. Note that the Language Variant site column is set to a list of the languages that the page represent. This field can be the News web part to filter local news by language or in a search based solution such as the highlighted content or pnp search web part. News rollup do not yet support filtering so duplicate articles would be displayed.

Copies of the original page are now in each of the folders for the languages selected.

Screenshot of japanese language folder

  1. Here we can see the Japanese version of the page. An editor can modify this page and publish it for viewers to see.

Screenshot of non-master language page details

  1. The editor can view the page page details. Because this is not the master language, modifying the properties is disabled.
  2. The user can see metadata about each of the pages by clicking on the i icon.

The editor should make all required changed and then Publish the page when it's ready for the users to view that translation.

Screenshot of master page details after change

  1. We can now see, if we navigate back to the master language page and view the language details, that the Japanese version of the page has been modified since the last synchronization occurred.
  2. Because the Japanese version has changed the solution will not overwrite it and allows the editor to send a comment to the person who last modified the page informing them that the master page has changed.
  3. In the instance where all the translations should be abandoned a Replace Existing Pages toggle exists which will reset all the translations back to the master language page.

Multilingual Redirector

The Multilingual Redirector web parts job is to redirect the user to the page appropriate to the users current language as configured in SharePoint. The web part is either automatically added to a page by Apply Language Changes from the language detail screen or by manually adding the web part to a page and configuring it.

Screenshot of multilingual redirector web part

  1. To modify or create a redirector page add the ?Stay=True query string parameter to the page url where you have the redirector web part. This will keep the page from automatically redirecting to another page based on your current language.

Screenshot of multilingual redirector web part properties

  1. Each language supported can point to a different version of the page.

Used SharePoint Framework Version


Applies to


Languages Configuration

Languages that the solution supports will be defined in a SharePoint Online Tenant Property. The powershell that creates the property is included in the deployment folder in the LanguageConfigTenantProperty.ps1 file. You will need tenant admin privileges to create this property but everyone has rights to read the property.

The value of the custom property is a stringified JSON object that represents the languages that the tenant will support:

  • Language code (ISO 639-1) - this is a two part code, e.g. en-US
  • Description

Please see an example file in the languages.json file.


Solution Author(s)
MultilingualPages Dave Feldman (Takeda) - @bostonmusicdave
Scot Hillier (Scot Hillier Technical Solutions) - @scothillier
Julie Turner (Sympraxis Consulting) - @jfj1997

Version history

Version Date Comments
1.6.3 May 14, 2019 Fix issue with redirectorPageUrl being undefined.
1.6.2 April 9, 2019 Generalize move page message.
1.6.1 April 8, 2019 Initial release



Minimal Path to Awesome

  • Clone this repository
  • Move to right solution folder
  • Run PowerShell script to set up supported languages, details in Prerequisites
  • in the command line run:
    • npm install
    • gulp serve


This solution contains a application customizer and a web part that when used together provide a client side solution to managing multilingual pages in a SharePoint site collection.

This extension and web part illustrates the following concepts:

  • create folder structure and site columns to support multilingual pages
  • provide viewers a way to switch to language variants of a page
  • provide editors a management solution for creating and updating language variations of a page
  • provide properties that can be leveraged in various out of the box and custom web parts to provide content surfacing filtered by language.
  • provide a web part that can be configured to automatically redirect to the appropriate language variant based on the users/sites current UI language setting in SharePoint. This URL then can be used in links shared with the entire organization.

You can’t perform that action at this time.