user2439903
user2439903

Reputation: 1307

ngx-translate: Translate strings in html

I am using ngx-translate lib to support I18N in my angular app. Can anyone help me to mark the below html snippet for translation?

<span *ngIf="Days < 0 && !shortSentence">
      Follow-up is <span [class.font-bold]="highlightContent">{{ InDays | positiveNumber }} days</span> past due
    </span>

I want to mark only the text content within span tag. How can I make it as parametrized translations?

Any help will be appreciated.

Thanks in advance.

Upvotes: 7

Views: 9978

Answers (1)

Martin Ad&#225;mek
Martin Ad&#225;mek

Reputation: 18389

This is how you can use parametric translation with filters:

// define translation with parameter
'TRANSLATION_KEY': '{{days}} days'

// use it in template
<span>{{ 'TRANSLATION_KEY' | translate: { days: followUpInDays | positiveNumber } }}</span>

If you want to have the whole sentence as a translation (including the HTML), you will need to use innerHTML property binding:

// define translation with parameter
'TRANSLATION_KEY': 'Follow-up is <span class="{{className}}">{{days}} days</span> past due'

// use it in template
<span *ngIf="Days < 0 && !shortSentence"
      [innerHTML]="'TRANSLATION_KEY' | translate: { className: (highlightContent ? 'font-bold' : ''), days: followUpInDays | positiveNumber }">
</span>

Upvotes: 11

Related Questions