@nativescript/localize
: ~5.0.0
This is a plugin for NativeScript that implements internationalization (i18n) using the native capabilitiesof each platform. It is inspired from nativescript-i18n
A lot of thanks goes out to Ludovic Fabrèges (@lfabreges) for developing and maintaining this plugin in the past. When he had to abandon it due to shifted priorities, he was kind enough to move the repo to me.
tns plugin add nativescript-localize
Create a folder i18n
in the app
folder with the following structure:
app
| i18n
| en.json <-- english language
| fr.default.json <-- french language (default)
| es.js
You need to set the default langage and make sure it containsthe application name to avoid any error.
import { NgModule, NO_ERRORS_SCHEMA } from "@angular/core";
import { NativeScriptLocalizeModule } from "nativescript-localize/angular";
import { NativeScriptModule } from "nativescript-angular/nativescript.module";
import { AppComponent } from "./app.component";
@NgModule({
declarations: [AppComponent],
bootstrap: [AppComponent],
imports: [
NativeScriptModule,
NativeScriptLocalizeModule
],
schemas: [NO_ERRORS_SCHEMA]
})
export class AppModule { }
<Label text="{{ 'Hello world !' | L }}"/>
<Label text="{{ 'I am %s' | L:'user name' }}"/>
import { localize } from "nativescript-localize";
console.log(localize("Hello world !"));
const application = require("application");
const localize = require("nativescript-localize");
application.setResources({ L: localize });
<Label text="{{ L('Hello world !') }}"/>
<Label text="{{ L('I am %s', 'user name') }}"/>
const localize = require("nativescript-localize");
console.log(localize("Hello world !"));
const page = args.object;
page.bindingContext = new Observable();
import { localize } from "nativescript-localize";
Vue.filter("L", localize);
<Label :text="'Hello world !'|L"></Label>
<Label :text="'I am %s'|L('user name')"></Label>
Each file is imported using require
, use the file format of your choice:
{
"app.name": "My app",
"ios.info.plist": {
"NSLocationWhenInUseUsageDescription": "This will be added to InfoPlist.strings"
},
"user": {
"name": "user.name",
"email": "user.email"
},
"array": [
"split the translation into ",
"multiples lines"
],
"sprintf": "format me %s",
"sprintf with numbered placeholders": "format me %2$s one more time %1$s"
}
const i18n = {
"app.name": "My app"
};
module.exports = i18n;
Add the .default
extension to the default language file to set it as the fallback language:
fr.default.json
The app.name
key is used to localize the application name:
{
"app.name": "My app"
}
Keys starting with ios.info.plist.
are used to localize iOS properties:
{
"ios.info.plist.NSLocationWhenInUseUsageDescription": "This will be added to InfoPlist.strings"
}
This plugin uses the native capabilities of each platform, language selection is therefore made by the OS.
import { overrideLocale } from "nativescript-localize/localize";
const localeOverriddenSuccessfully = overrideLocale("en-GB"); // or "nl-NL", etc (or even just the part before the hyphen)
In your app.ts / main.ts / app.js
import { on, launchEvent } from '@nativescript/core/application';
import { androidLaunchEventLocalizationHandler } from 'nativescript-localize/localize';
on(launchEvent, (args) => {
if (args.android) {
androidLaunchEventLocalizationHandler();
}
});
And in your settings page where user chooses the language:
import { overrideLocale } from "nativescript-localize/localize";
const localeOverriddenSuccessfully = overrideLocale("en-GB"); // or "nl-NL", etc (or even just the part before the hyphen)
Important: In both cases, after calling override Locale, you must ask the user to restart the app
For Example:
import { android as _android } from '@nativescript/core/application';
import { overrideLocale } from 'nativescript-localize/localize';
alert({
title: 'Switch Language',
message: 'The application needs to be restarted to change language',
okButtonText: 'Quit!'
}).then(() => {
L.localize.overrideLocale(selectedLang);
if (isAndroid) {
_android.foregroundActivity.finish();
} else {
exit(0);
}
});
Important: In case you are using Android app bundle to release your android app, add this toApp_Resources/Android/app.gradle to make sure all lanugages are bundled in the split apks
android {
// there maybe other code here //
bundle {
language {
enableSplit = false
}
}
}
Tip: you can get the default language on user's phone by using this
import { device } from '@nativescript/core/platform';
console.log("user's language is", device.language.split('-')[0]);
Tip: overrideLocale method stores the language in a special key in app-settings,you can access it like this,
import { getString } from '@nativescript/core/application-settings';
console.log(getString('__app__language__')); // only available after the first time you use overrideLocale(langName);
As a workaround, you can trigger a change detection from within your component constructor:
constructor(
private readonly params: ModalDialogParams,
private readonly changeDetectorRef: ChangeDetectorRef,
) {
setTimeout(() => this.changeDetectorRef.detectChanges(), 0);
}
For unknown reasons, the very first creation of it resets the application locale to the device default. Therefore, you have to set the desired locale back.This is native bug and the workaround is
<WebView url="https://someurl.com" @loaded="webViewLoaded"/>
import {overrideLocale, androidLaunchEventLocalizationHandler} from "nativescript-localize/localize";
import {getString} from '@nativescript/core/application-settings';
const locale = getString('__app__language__')
function webViewLoaded(){
overrideLocale(locale)
androidLaunchEventLocalizationHandler()
}
NativeScript 可以使用 Javascript,CSS, XML 创建真正的 Native 跨平台应用,支持 iOS Android,NativeScript 将您的跨平台代码翻译成目标平台的代码。 UI 使用 XML 描述,CSS 样式,在编译时将 UI 转化成本地原生代码,最终得到正在的 Native 原生应用。 Telerik 公开了用于创建安卓、iOS和Windows Unive
NativeScript Command-Line Interface The NativeScript CLI lets you create, build, and deploy NativeScript-based apps on iOS and Android devices. Get it using: npm install -g nativescript What is Native
NativeScript-Snackbar �� �� �� NativeScript plugin for Material Design SnackBar component. Installation: NativeScript 7+:tns plugin add @nstudio/nativescript-snackbar NativeScript version prior to 7:t
Nativescript-Ripple This plugin aims to bring a native (or close to native) ripple implementation on Android and iOS. The android version uses a RippleDrawable and conserves the previous background, a
NativeScript-FloatingActionButton NativeScript plugin for Material Design Floating Action Button UI component. Installation Nativescript 7+: ns plugin add @nstudio/nativescript-floatingactionbutton Na
NativeScript CardView A NativeScript plugin to provide an XML widget to implement the Material Design CardView component. Installation NativeScript 7+: ns plugin add @nstudio/nativescript-cardview Nat