i18n_extension_core 3.0.0 i18n_extension_core: ^3.0.0 copied to clipboard
Dart-only package for Translation and Internationalization (i18n), with Dart extensions. Easy to use for both large and small projects.
Sponsored by MyText.ai
3.0.0 #
-
Breaking Change: Language codes should now respect the BCP47 standard, when you define your translations.
For example, you should now useen-US
instead of the olden_us
format. Other valid code examples are:en
,es-419
,hi-Deva-IN
andzh-Hans-CN
. To help you upgrade, aTranslationsException
error will be thrown when you use the old code format, with a detailed error message such as:Locale "en_us" should be "en-US" (for translatable string "Hello!").
-
As a helper, in case you need it, we now provide function
DefaultLocale.normalizeLocale
to normalize language codes to the BCP47 standard (which is compatible with the Unicode Locale Identifier (ULI) syntax). It fixes casing (uppercase and lowercase), removes spaces, and turns underscores into hyphens. As such, it can be used to convert the old format language codes to the new ones. For example:DefaultLocale.normalizeLocale('en_us')
returns'en-US'
. -
You can now do string interpolation by using
{}
,{1}
, and{named}
, by using functionlocalizeArgs
:localizeArgs('Hello {student} and {teacher}', {'student': 'John', 'teacher': 'Mary'}); localizeArgs('Hello {student} and {teacher}', 'John', 'Mary'); localizeArgs('Hello {1} and {2}', 'John', 'Mary'); localizeArgs('Hello {1} and {2}', ['John', 'Mary']); localizeArgs('Hello {1} and {2}', {1: 'John', 2: 'Mary'}); localizeArgs('Hello {} and {}', 'John', 'Mary'); localizeArgs('Hello {} and {}', ['John', 'Mary']);
From the
i18n_extension
package, this functionality is accessible via theargs
extension. For example:'Hello {student} and {teacher}'.i18n.args({'student': 'John', 'teacher': 'Mary'}); 'Hello {student} and {teacher}'.i18n.args('John', 'Mary'); 'Hello {1} and {2}'.i18n.args('John', 'Mary'); 'Hello {1} and {2}'.i18n.args(['John', 'Mary']); 'Hello {1} and {2}'.i18n.args({1: 'John', 2: 'Mary'}); 'Hello {} and {}'.i18n.args('John', 'Mary'); 'Hello {} and {}'.i18n.args(['John', 'Mary']);
-
Previously, you could do string interpolation by using sprintf specifiers, like
%s
,%1$s
,%d
etc., and providing a list of values to fill them. This is still supported:localizeFill('Hello %s and %s', ['student', 'teacher']); localizeFill('Hello %1$s and %2$s', ['student', 'teacher']);
However now you can also provide the values directly, without having to wrap them in a list:
localizeFill('Hello %s and %s', 'student', 'teacher'); localizeFill('Hello %1$s and %2$s', 'student', 'teacher');
From the
i18n_extension
package, this functionality is accessible via thefill
extension. For example:'Hello %s and %s'.i18n.fill(['student', 'teacher']); 'Hello %1$s and %2$s'.i18n.fill(['student', 'teacher']); 'Hello %s and %s'.i18n.fill('student', 'teacher'); 'Hello %1$s and %2$s'.i18n.fill('student', 'teacher');
2.0.6 #
- Translations:
Translations.byText()
: SupportsString
themselves as translation-keys, organized per key.Translations.byLocale()
: SupportsString
themselves as translation-keys, organized per locale.Translations.byId<T>()
: Supports any object (of typeT
) as translation-keys.const ConstTranslations()
: Supports defining translations with aconst
Map.
1.0.0 #
- On Feb 11, 2024 I've created this Dart-only package to contain the core code of the i18n_extension package.