showBottomModal static method
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(),
),
),
)
],
));
});
}