Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents
minLevel1
maxLevel3
outlinefalse
typelist
printablefalse

...

The <Trans> component should be used when you have react/HTML nodes integrated into within a sentence.

A few cases Examples of where the <Trans> component is needed:

When words nested inside a sentence require…

  • <link>

  • <abbr>

  • <strong>

  • <i><br>

Where the <Trans> component is not needed:

  • A whole word /or sentence is wrapped inside a react/HTML node.

How we use it - example

...

Conventions

  1. HTML values are kept out of the locale files

    • HTML values within translation key text can decrease readability.

  2. Hard coded text is not used outside the locale files

    • Using hard coded text within the <Trans> component means the text has to be maintained in two places. Therefore, we should avoid using hard coded text outside the locale JSON files for easy maintenance.

  3. Links used in the home page are kept inside the homeConfig.ts file

    • This is for easy alteration if links are changed

Adding a link with the <Trans> component

Our plain sentence in our JSON file, without any markup:

Code Block
languagejs
hello_msg: "Hello amazing world."

If we want We are going to add a link on the word ‘amazing’ to www.google.com.

We will first add the <Trans> In the file where we want to render our sentence., we will first add the <Trans>

Code Block
<Trans>

We will then state the i18nKey as a prop, this . This is the key we associate with our sentence in the JSON file.

Code Block
languagejs
<Trans i18nKey="hello_msg" />

Our sentence will now be rendered, but without any link yet.

To render the sentence with a link, the components prop is usedadded.

Code Block
languagejs
<Trans i18nKey="hello_msg" components={{linkToGoogle: <a href="https://www.google.com/"/>}} />

Now back in our JSON file, we edit our key where we want our link to be.

Code Block
languagejs
hello_msg: "Hello <linkToGoogle>amazing<linkToGoogle/> world"

Adding a link without the <Trans> component

A link can be added to a whole sentence without the <Trans> component.

Code Block
languagejs
<Link href='https://www.google.com/'>{t('hello_msg')}</Link>

Adding formatting to a word in a sentence

Our key in the JSON file:

Code Block
languagejs
"validation_missing_values": "The columns “Local code” and “Local meaning” must contain data. One or more cells in these columns is empty. Please fix and retry."

Now say we want to make the word “local code” and “local meaning” bold.

  • To do this we would use the <Trans> component again in the same way we did with links.

  • We use i18nkey as a prop to state the key.

  • We then use the components prop to reference the HTML value.

  • Any name can be used here to represent the <strong> HTML.

    • In this case, I have used the word ‘bold’ as it makes it clear what the HTML represents.

Code Block
<Trans 
  i18nKey="mappings.validation_missing_values"
  components={{bold: <strong/>}}>
</Trans>

Then, in the JSON file, the key is altered to include the HTML.

Code Block
"validation_missing_values": "The columns <bold>“Local code”</bold> and <bold>“Local meaning”</bold> must contain data. One or more cells in these columns is empty. Please fix and retry."

Adding line breaks in text

Our key in the JSON file:

Code Block
languagejs
"OpenRS": "OpenRS is a resource sharing initiative of the Open Library Foundation.<break/>The open source project is reinventing resource sharing to meet the needs of different types of consortia, using open standards and native integration to provide consortia with robust and extended functionality for consortial resource sharing."

Now say we want to break up the text to make it more readable.

  • To do this we would use the <Trans> component again in the same way we did with links.

    • We use i18nkey as a prop to state the key.

    • We then use the components prop to reference the HTML value.

  • Any name can be used here to represent the <br> HTML.

    • In this case, I have used the word ‘break’ as it makes it clear what the HTML represents.

Code Block
<Trans 
  i18nKey="openRS"
  components={{break: <br/>}}>
</Trans>

Then, in the JSON file, the key is altered to include the HTML.

Code Block
"openRS": "OpenRS is a resource sharing initiative of the Open Library Foundation.<br/>The open source project is reinventing resource sharing to meet the needs of different types of consortia, using open standards and native integration to provide consortia with robust and extended functionality for consortial resource sharing."