im_localized 0.0.14 copy "im_localized: ^0.0.14" to clipboard
im_localized: ^0.0.14 copied to clipboard

Flutter ICU compatible Localization library with support for JSONs, runtime parsing and injecting

example/lib/main.dart

import 'package:flutter/material.dart';
import 'l10n/localization.dart';

void main() async {
  WidgetsFlutterBinding.ensureInitialized();

  runApp(
    const MyApp(),
  );
}

class MyApp extends StatefulWidget {
  const MyApp({
    super.key,
  });

  @override
  State<MyApp> createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  List<Map<String, String>> localizations = initialTranslations;

  @override
  void initState() {
    localizations = initialTranslations;
    super.initState();
  }

  void _injectLanguages() {
    localizations = [
        {
          "@@locale": "en",
          LocaleKeys.languageFlag: "English",
          LocaleKeys.hiMessage: "Hello {name}!",
          LocaleKeys.itemCounter:
              "{ count, plural, =0{no items} =1{one item} other{there are # items}}",
        },
        {
          "@@locale": "es",
          LocaleKeys.languageFlag: "Spanish",
          LocaleKeys.hiMessage: "¡Buenos días {name}!",
          LocaleKeys.itemCounter:
              "{ count, plural, =0{sin artículos} =1{un artículo} other{hay # artículos}}",
        },
      ];
    setState(() {
      localizations = localizations;
    });
  }

  @override
  Widget build(BuildContext context) {
    return ImLocalizedApp.fromList(
      /// initial translations loaded from RAM
      initialTranslations: localizations,

      /// save locale changes to local storage
      localeStorage: SharedPreferencesLocaleStorage(),

      // /// save injected translations to local storage
      // translationsStorage: SharedPreferencesTranslationsStorage(),

      app: AppWidget(injectLanguages: _injectLanguages,),
    );
  }
}

class AppWidget extends StatefulWidget {
  const AppWidget({super.key, required this.injectLanguages});
  final Function injectLanguages;
  @override
  State<AppWidget> createState() => _AppWidgetState();
}

class _AppWidgetState extends State<AppWidget> {
  int _count = 0;

  void _incrementCounter() {
    setState(() {
      _count++;
    });
  }

  Widget _buildLanguageSelector() {
    return DropdownButton<Locale>(
      value: context.locale,
      onChanged: (Locale? locale) {
        if (locale != null) {
          context.setLocale(locale);
        }
      },
      items: context.supportedLocales
          .map<DropdownMenuItem<Locale>>((Locale locale) {
        return DropdownMenuItem<Locale>(
          value: locale,
          child: Text(LocaleKeys.languageFlag.translate(locale: locale)),
        );
      }).toList(),
    );
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      home: Scaffold(
        appBar: AppBar(
          backgroundColor: Theme.of(context).colorScheme.inversePrimary,
          title: Text(
            LocaleKeys.hiMessage.translate(args: {'name': 'Sara'}),
            style: Theme.of(context).textTheme.headlineMedium,
          ),
          actions: [_buildLanguageSelector()],
        ),
        body: Column(
          children: [
            Center(
              child: Padding(
                padding: const EdgeInsets.all(16.0),
                child: Text(
                  LocaleKeys.itemCounter.translate(args: {'count': _count}),
                  textAlign: TextAlign.center,
                  style: Theme.of(context).textTheme.headlineMedium,
                ),
              ),
            ),
            Expanded(
              child: ListView.builder(
                padding: const EdgeInsets.all(16) +
                    EdgeInsets.only(
                        bottom: MediaQuery.of(context).padding.bottom),
                itemCount: _count,
                itemBuilder: (context, index) => Card(
                  child: Padding(
                    padding: const EdgeInsets.all(8.0),
                    child: Text('${index + 1}'),
                  ),
                ),
              ),
            )
          ],
        ),
        bottomNavigationBar: Container(
          color: Theme.of(context).primaryColorLight,
          child: SafeArea(
            child: Row(
              mainAxisAlignment: MainAxisAlignment.spaceEvenly,
              children: [
                IconButton(
                  onPressed: _incrementCounter,
                  icon: const Icon(Icons.add),
                ),
                IconButton(
                  onPressed: () => widget.injectLanguages(),
                  icon: const Icon(Icons.cloud_download),
                ),
              ],
            ),
          ),
        ),
      ),
    );
  }
}
4
likes
50
points
67
downloads

Publisher

unverified uploader

Weekly Downloads

Flutter ICU compatible Localization library with support for JSONs, runtime parsing and injecting

Repository (GitHub)
View/report issues

License

BSD-3-Clause (license)

Dependencies

args, collection, flutter, flutter_localizations, intl, logger, path, shared_preferences

More

Packages that depend on im_localized