showBottomModal static method

dynamic showBottomModal(
  1. BuildContext context, {
  2. double? height,
})

Show a bottom modal to switch languages

Implementation

static showBottomModal(BuildContext context, {double? height}) async {
  List<Map<String, String>> list = await getLanguageList();
  Map<String, dynamic>? currentLang = await currentLanguage();
  showModalBottomSheet(
      // ignore: use_build_context_synchronously
      context: context,
      builder: (BuildContext context) {
        return SafeArea(
            child: Column(
          mainAxisSize: MainAxisSize.min,
          children: [
            Text("Select your language".tr())
                .headingMedium(
                    color: NyColor(light: Colors.black, dark: Colors.white)
                        .toColor(context))
                .alignCenter()
                .paddingOnly(top: 16, bottom: 8),
            Flexible(
              fit: FlexFit.tight,
              child: SizedBox(
                height: height ?? MediaQuery.of(context).size.height / 2,
                child: ListView(
                  children: list.map((Map<String, String> meta) {
                    MapEntry<String, String> data = meta.entries.first;
                    bool isChecked = false;
                    if (currentLang != null &&
                        data.key == currentLang.entries.first.key) {
                      isChecked = true;
                    }
                    return ListTile(
                      title: Text(
                        data.value,
                        style: TextStyle(
                            color: NyColor(
                                    light: Colors.black, dark: Colors.white)
                                .toColor(context)),
                      ),
                      trailing: isChecked ? const Icon(Icons.check) : null,
                      onTap: () async {
                        await NyLocalization.instance
                            .setLanguage(context, language: data.key);

                        // store the language
                        await storeLanguage(object: {data.key: data.value});

                        updateState(state,
                            data: {"action": "refresh-page", "data": {}});
                        // ignore: use_build_context_synchronously
                        Navigator.pop(context);
                      },
                    );
                  }).toList(),
                ),
              ),
            )
          ],
        ));
      });
}