I am using angular 8 > In my case > If you want to translate typescript string into another language then use this >
First, make a service file to get translate value, Below is my code for globaltranslate.service.ts file
import { Injectable } from '@angular/core';
import {TranslateService} from '@ngx-translate/core';
constructor(public translate: TranslateService) {}
Then make a return function........
getTranslation(str) {
const currentLang = this.translate.currentLang; // get current language
const returnValue = this.translate.translations[currentLang][str]; // get converted string from current language
if (returnValue === undefined) {
return this.translate.translations.en_merch[str]; // if value is getting undefined then return default language string, en_merch is default english language file here
} else {
return returnValue;
}
}
And in component.ts file, you can import service file and use it like below code...
import {GlobaltranslateService} from '../../../../services/globaltranslate.service';
@Component({
selector: 'app',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css'],
providers: [GlobaltranslateService] // add service in provider
})
constructor(
private gTranslate: GlobaltranslateService // add service into constructor
) {}
const title = this.gTranslate.getTranslation('Title text'); // get return value by calling function 'getTranslation' in globaltranslateservice.
This solution is better for all projects of i18n and angular ngx translate
This also works on sweetalert2 strings like below code
Swal (
this.gTranslate.getTranslation('Warning'),
data.message,
'warning'
);
Thanks for reading, If you have any query please message.