84 lines
2.5 KiB
Dart
84 lines
2.5 KiB
Dart
import 'package:flutter/material.dart';
|
|
import '../../../l10n/app_localizations.dart';
|
|
import 'package:kmobile/app.dart';
|
|
import 'package:shared_preferences/shared_preferences.dart';
|
|
|
|
/*class LanguageDialog extends StatelessWidget {
|
|
const LanguageDialog({super.key});
|
|
|
|
String getLocaleName(AppLocalizations localizations, String code) {
|
|
final localeCodeMap = {
|
|
'en': localizations.english,
|
|
'hi': localizations.hindi,
|
|
};
|
|
return localeCodeMap[code] ?? 'Unknown';
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Builder(
|
|
builder: (context) {
|
|
final localizations = AppLocalizations.of(context);
|
|
|
|
final supportedLocales = [const Locale('en'), const Locale('hi')];
|
|
|
|
return AlertDialog(
|
|
title: Text(localizations.language),
|
|
content: Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: supportedLocales.map((locale) {
|
|
return ListTile(
|
|
leading: const Icon(Icons.language),
|
|
title: Text(getLocaleName(localizations, locale.languageCode)),
|
|
onTap: () {
|
|
Navigator.pop(context);
|
|
KMobile.setLocale(context, locale);
|
|
},
|
|
);
|
|
}).toList(),
|
|
),
|
|
actions: [
|
|
TextButton(
|
|
onPressed: () => Navigator.pop(context),
|
|
child: Text(localizations.cancel),
|
|
),
|
|
],
|
|
);
|
|
},
|
|
);
|
|
}
|
|
}
|
|
*/
|
|
|
|
class LanguageDialog extends StatelessWidget {
|
|
const LanguageDialog({Key? key}) : super(key: key);
|
|
|
|
Future<void> _setLocale(BuildContext context, String langCode) async {
|
|
final prefs = await SharedPreferences.getInstance();
|
|
await prefs.setString('locale', langCode); // Save selected language
|
|
KMobile.setLocale(context, Locale(langCode)); // Update locale in app
|
|
Navigator.of(context).pop(); // Close the dialog
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return AlertDialog(
|
|
title: Text(AppLocalizations.of(context).selectLanguage),
|
|
content: Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: [
|
|
ListTile(
|
|
leading: const Icon(Icons.language),
|
|
title: const Text('English'),
|
|
onTap: () => _setLocale(context, 'en'),
|
|
),
|
|
ListTile(
|
|
leading: const Icon(Icons.language),
|
|
title: const Text('हिन्दी'),
|
|
onTap: () => _setLocale(context, 'hi'),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
} |