diff --git a/assets/images/boi_logo.png b/assets/images/boi_logo.png new file mode 100644 index 0000000..78cd499 Binary files /dev/null and b/assets/images/boi_logo.png differ diff --git a/lib/features/service/screens/branch_locator_screen.dart b/lib/features/service/screens/branch_locator_screen.dart new file mode 100644 index 0000000..651f477 --- /dev/null +++ b/lib/features/service/screens/branch_locator_screen.dart @@ -0,0 +1,43 @@ +import '../../../l10n/app_localizations.dart'; +import 'package:flutter/material.dart'; + +class BranchLocatorScreen extends StatelessWidget { + const BranchLocatorScreen({super.key}); + + @override + Widget build(BuildContext context) { + return Scaffold( + appBar: AppBar( + title: Text(AppLocalizations.of(context).branchLocator), + ), + body: Center( + child: Column( + mainAxisAlignment: MainAxisAlignment.center, + children: [ + Icon( + Icons.location_on, + size: 80, + color: Theme.of(context).primaryColor, + ), + const SizedBox(height: 16), + Text( + AppLocalizations.of(context).findnearbybranched, + style: const TextStyle(fontSize: 20, fontWeight: FontWeight.bold), + ), + const SizedBox(height: 24), + ElevatedButton.icon( + icon: const Icon(Icons.search), + label: Text( AppLocalizations.of(context).searchbranch), + onPressed: () { + // Place API here + ScaffoldMessenger.of(context).showSnackBar( + SnackBar(content: Text( AppLocalizations.of(context).branchsearchsoon)), + ); + }, + ), + ], + ), + ), + ); + } +} \ No newline at end of file diff --git a/lib/features/service/screens/service_screen.dart b/lib/features/service/screens/service_screen.dart index 859157b..c3d583e 100644 --- a/lib/features/service/screens/service_screen.dart +++ b/lib/features/service/screens/service_screen.dart @@ -1,3 +1,5 @@ +import 'package:kmobile/features/service/screens/branch_locator_screen.dart'; + import '../../../l10n/app_localizations.dart'; import 'package:flutter/material.dart'; @@ -70,7 +72,13 @@ class _ServiceScreen extends State { ServiceManagementTile( icon: Symbols.missing_controller, label: AppLocalizations.of(context).branchLocator, - onTap: () {}, + onTap: () { + Navigator.push( + context, + MaterialPageRoute( + builder: (context) => const BranchLocatorScreen()) + ); + }, ), const Divider(height: 1), ], diff --git a/lib/l10n/app_en.arb b/lib/l10n/app_en.arb index a4a8d6e..f0b46c4 100644 --- a/lib/l10n/app_en.arb +++ b/lib/l10n/app_en.arb @@ -246,6 +246,9 @@ "proceed": "Proceed", "plsValidateBeneficiary": "Please validate beneficiary details first", "accno7to20": "Account number must be between 7 and 20 digits", - "validateBeneficiaryproceeding": "Please validate beneficiary before proceeding" + "validateBeneficiaryproceeding": "Please validate beneficiary before proceeding", + "findnearbybranched": "Find nearby branches", + "searchbranch": "Search Branch", + "branchsearchsoon": "Branch search coming soon..." } diff --git a/lib/l10n/app_hi.arb b/lib/l10n/app_hi.arb index e25ae27..e084093 100644 --- a/lib/l10n/app_hi.arb +++ b/lib/l10n/app_hi.arb @@ -246,5 +246,8 @@ "proceed": "आगे बढ़ना", "plsValidateBeneficiary": "कृपया पहले लाभार्थी विवरण सत्यापित करें", "accno7to20": "खाता संख्या सात से बीस अंकों के बीच होनी चाहिए", - "validateBeneficiaryproceeding": "कृपया आगे बढ़ने से पहले लाभार्थी को पट्टे पर मान्य करें" + "validateBeneficiaryproceeding": "कृपया आगे बढ़ने से पहले लाभार्थी को पट्टे पर मान्य करें", + "findnearbybranched": "आस-पास की शाखाएँ खोजें", + "searchbranch": "शाखा खोजें", + "branchsearchsoon": "शाखा खोज सुविधा जल्द ही आ रही है..." } diff --git a/lib/l10n/app_localizations.dart b/lib/l10n/app_localizations.dart index 3ed7425..763f13a 100644 --- a/lib/l10n/app_localizations.dart +++ b/lib/l10n/app_localizations.dart @@ -62,8 +62,7 @@ import 'app_localizations_hi.dart'; /// be consistent with the languages listed in the AppLocalizations.supportedLocales /// property. abstract class AppLocalizations { - AppLocalizations(String locale) - : localeName = intl.Intl.canonicalizedLocale(locale.toString()); + AppLocalizations(String locale) : localeName = intl.Intl.canonicalizedLocale(locale.toString()); final String localeName; @@ -71,8 +70,7 @@ abstract class AppLocalizations { return Localizations.of(context, AppLocalizations)!; } - static const LocalizationsDelegate delegate = - _AppLocalizationsDelegate(); + static const LocalizationsDelegate delegate = _AppLocalizationsDelegate(); /// A list of this localizations delegate along with the default localizations /// delegates. @@ -84,8 +82,7 @@ abstract class AppLocalizations { /// Additional delegates can be added by appending to this list in /// MaterialApp. This list does not have to be used at all if a custom list /// of delegates is preferred or required. - static const List> localizationsDelegates = - >[ + static const List> localizationsDelegates = >[ delegate, GlobalMaterialLocalizations.delegate, GlobalCupertinoLocalizations.delegate, @@ -1507,10 +1504,27 @@ abstract class AppLocalizations { /// In en, this message translates to: /// **'Please validate beneficiary before proceeding'** String get validateBeneficiaryproceeding; + + /// No description provided for @findnearbybranched. + /// + /// In en, this message translates to: + /// **'Find nearby branches'** + String get findnearbybranched; + + /// No description provided for @searchbranch. + /// + /// In en, this message translates to: + /// **'Search Branch'** + String get searchbranch; + + /// No description provided for @branchsearchsoon. + /// + /// In en, this message translates to: + /// **'Branch search coming soon...'** + String get branchsearchsoon; } -class _AppLocalizationsDelegate - extends LocalizationsDelegate { +class _AppLocalizationsDelegate extends LocalizationsDelegate { const _AppLocalizationsDelegate(); @override @@ -1519,25 +1533,25 @@ class _AppLocalizationsDelegate } @override - bool isSupported(Locale locale) => - ['en', 'hi'].contains(locale.languageCode); + bool isSupported(Locale locale) => ['en', 'hi'].contains(locale.languageCode); @override bool shouldReload(_AppLocalizationsDelegate old) => false; } AppLocalizations lookupAppLocalizations(Locale locale) { + + // Lookup logic when only language code is specified. switch (locale.languageCode) { - case 'en': - return AppLocalizationsEn(); - case 'hi': - return AppLocalizationsHi(); + case 'en': return AppLocalizationsEn(); + case 'hi': return AppLocalizationsHi(); } throw FlutterError( - 'AppLocalizations.delegate failed to load unsupported locale "$locale". This is likely ' - 'an issue with the localizations generation tool. Please file an issue ' - 'on GitHub with a reproducible sample app and the gen-l10n configuration ' - 'that was used.'); + 'AppLocalizations.delegate failed to load unsupported locale "$locale". This is likely ' + 'an issue with the localizations generation tool. Please file an issue ' + 'on GitHub with a reproducible sample app and the gen-l10n configuration ' + 'that was used.' + ); } diff --git a/lib/l10n/app_localizations_en.dart b/lib/l10n/app_localizations_en.dart index 83d8401..ceba208 100644 --- a/lib/l10n/app_localizations_en.dart +++ b/lib/l10n/app_localizations_en.dart @@ -486,8 +486,7 @@ class AppLocalizationsEn extends AppLocalizations { String get otpVerification => 'OTP Verification'; @override - String get otpSentMessage => - 'Enter the 4-digit OTP sent to your mobile number'; + String get otpSentMessage => 'Enter the 4-digit OTP sent to your mobile number'; @override String get verifyOtp => 'Verify OTP'; @@ -505,15 +504,13 @@ class AppLocalizationsEn extends AppLocalizations { String get tpinRequired => 'TPIN Required'; @override - String get tpinRequiredMessage => - 'You need to set your TPIN to continue with secure transactions'; + String get tpinRequiredMessage => 'You need to set your TPIN to continue with secure transactions'; @override String get setTpinTitle => 'Set TPIN'; @override - String get tpinInfo => - 'Your TPIN is a 6-digit code used to authorize transactions. Keep it safe and do not share it with anyone.'; + String get tpinInfo => 'Your TPIN is a 6-digit code used to authorize transactions. Keep it safe and do not share it with anyone.'; @override String get tpinFailed => 'Failed to set TPIN. Please try again.'; @@ -567,8 +564,7 @@ class AppLocalizationsEn extends AppLocalizations { String get enableFingerprintLogin => 'Enable Fingerprint Login?'; @override - String get enableFingerprintMessage => - 'Would you like to enable fingerprint authentication for faster login?'; + String get enableFingerprintMessage => 'Would you like to enable fingerprint authentication for faster login?'; @override String get no => 'No'; @@ -589,8 +585,7 @@ class AppLocalizationsEn extends AppLocalizations { String get loading => 'Loading......'; @override - String get enableFingerprintQuick => - 'Enable fingerprint authentication for quick login?'; + String get enableFingerprintQuick => 'Enable fingerprint authentication for quick login?'; @override String get kccb => 'KCCB'; @@ -692,15 +687,13 @@ class AppLocalizationsEn extends AppLocalizations { String get invalidRtgs => 'Invalid Amount for RTGS'; @override - String get invalidRtgsPopUp => - 'RTGS transactions require a minimum amount of 200,000. Please enter a higher amount or select NEFT as the transaction mode.'; + String get invalidRtgsPopUp => 'RTGS transactions require a minimum amount of 200,000. Please enter a higher amount or select NEFT as the transaction mode.'; @override String get correctTpin => 'Please Enter the correct TPIN'; @override - String get insufficientFund => - 'Your account does not have sufficient balance'; + String get insufficientFund => 'Your account does not have sufficient balance'; @override String get creditedTo => 'Credited To'; @@ -712,13 +705,20 @@ class AppLocalizationsEn extends AppLocalizations { String get proceed => 'Proceed'; @override - String get plsValidateBeneficiary => - 'Please validate beneficiary details first'; + String get plsValidateBeneficiary => 'Please validate beneficiary details first'; @override String get accno7to20 => 'Account number must be between 7 and 20 digits'; @override - String get validateBeneficiaryproceeding => - 'Please validate beneficiary before proceeding'; + String get validateBeneficiaryproceeding => 'Please validate beneficiary before proceeding'; + + @override + String get findnearbybranched => 'Find nearby branches'; + + @override + String get searchbranch => 'Search Branch'; + + @override + String get branchsearchsoon => 'Branch search coming soon...'; } diff --git a/lib/l10n/app_localizations_hi.dart b/lib/l10n/app_localizations_hi.dart index cf78143..75a9f5e 100644 --- a/lib/l10n/app_localizations_hi.dart +++ b/lib/l10n/app_localizations_hi.dart @@ -52,8 +52,7 @@ class AppLocalizationsHi extends AppLocalizations { String get enableBiometric => 'बायोमेट्रिक प्रमाणीकरण सक्षम करें'; @override - String get useBiometricPrompt => - 'तेज़ लॉगिन के लिए फिंगरप्रिंट/फेस आईडी का उपयोग करें?'; + String get useBiometricPrompt => 'तेज़ लॉगिन के लिए फिंगरप्रिंट/फेस आईडी का उपयोग करें?'; @override String get later => 'बाद में'; @@ -487,8 +486,7 @@ class AppLocalizationsHi extends AppLocalizations { String get otpVerification => 'ओटीपी सत्यापन'; @override - String get otpSentMessage => - 'अपने मोबाइल नंबर पर भेजा गया 4-अंकों का ओटीपी दर्ज करें'; + String get otpSentMessage => 'अपने मोबाइल नंबर पर भेजा गया 4-अंकों का ओटीपी दर्ज करें'; @override String get verifyOtp => 'ओटीपी सत्यापित करें'; @@ -506,15 +504,13 @@ class AppLocalizationsHi extends AppLocalizations { String get tpinRequired => 'टी-पिन आवश्यक है'; @override - String get tpinRequiredMessage => - 'सुरक्षित लेनदेन के लिए टी-पिन सेट करना आवश्यक है'; + String get tpinRequiredMessage => 'सुरक्षित लेनदेन के लिए टी-पिन सेट करना आवश्यक है'; @override String get setTpinTitle => 'टी-पिन सेट करें'; @override - String get tpinInfo => - 'आपका टी-पिन 6 अंकों का कोड है जिसका उपयोग लेन-देन को प्रमाणित करने के लिए किया जाता है। इसे सुरक्षित रखें और किसी से साझा न करें।'; + String get tpinInfo => 'आपका टी-पिन 6 अंकों का कोड है जिसका उपयोग लेन-देन को प्रमाणित करने के लिए किया जाता है। इसे सुरक्षित रखें और किसी से साझा न करें।'; @override String get tpinFailed => 'टी-पिन सेट करने में विफल। कृपया पुनः प्रयास करें।'; @@ -568,8 +564,7 @@ class AppLocalizationsHi extends AppLocalizations { String get enableFingerprintLogin => 'फिंगरप्रिंट लॉगिन सक्षम करें?'; @override - String get enableFingerprintMessage => - 'क्या आप तेज लॉगिन के लिए फिंगरप्रिंट प्रमाणीकरण सक्षम करना चाहेंगे?'; + String get enableFingerprintMessage => 'क्या आप तेज लॉगिन के लिए फिंगरप्रिंट प्रमाणीकरण सक्षम करना चाहेंगे?'; @override String get no => 'नहीं'; @@ -578,8 +573,7 @@ class AppLocalizationsHi extends AppLocalizations { String get yes => 'हाँ'; @override - String get authenticateToEnable => - 'फिंगरप्रिंट लॉगिन सक्षम करने के लिए प्रमाणीकरण करें'; + String get authenticateToEnable => 'फिंगरप्रिंट लॉगिन सक्षम करने के लिए प्रमाणीकरण करें'; @override String get exitApp => 'ऐप बंद करें'; @@ -591,8 +585,7 @@ class AppLocalizationsHi extends AppLocalizations { String get loading => 'लोड हो रहा है......'; @override - String get enableFingerprintQuick => - 'तेज़ लॉगिन के लिए फिंगरप्रिंट प्रमाणीकरण सक्षम करें?'; + String get enableFingerprintQuick => 'तेज़ लॉगिन के लिए फिंगरप्रिंट प्रमाणीकरण सक्षम करें?'; @override String get kccb => 'केसीसीबी'; @@ -694,8 +687,7 @@ class AppLocalizationsHi extends AppLocalizations { String get invalidRtgs => 'RTGS के लिए अमान्य राशि'; @override - String get invalidRtgsPopUp => - 'RTGS लेनदेन के लिए न्यूनतम 2,00,000 रुपये की राशि की आवश्यकता होती है। कृपया अधिक राशि दर्ज करें या लेनदेन मोड के रूप में NEFT चुनें'; + String get invalidRtgsPopUp => 'RTGS लेनदेन के लिए न्यूनतम 2,00,000 रुपये की राशि की आवश्यकता होती है। कृपया अधिक राशि दर्ज करें या लेनदेन मोड के रूप में NEFT चुनें'; @override String get correctTpin => 'कृपया सही टी-पिन दर्ज करें'; @@ -713,13 +705,20 @@ class AppLocalizationsHi extends AppLocalizations { String get proceed => 'आगे बढ़ना'; @override - String get plsValidateBeneficiary => - 'कृपया पहले लाभार्थी विवरण सत्यापित करें'; + String get plsValidateBeneficiary => 'कृपया पहले लाभार्थी विवरण सत्यापित करें'; @override String get accno7to20 => 'खाता संख्या सात से बीस अंकों के बीच होनी चाहिए'; @override - String get validateBeneficiaryproceeding => - 'कृपया आगे बढ़ने से पहले लाभार्थी को पट्टे पर मान्य करें'; + String get validateBeneficiaryproceeding => 'कृपया आगे बढ़ने से पहले लाभार्थी को पट्टे पर मान्य करें'; + + @override + String get findnearbybranched => 'आस-पास की शाखाएँ खोजें'; + + @override + String get searchbranch => 'शाखा खोजें'; + + @override + String get branchsearchsoon => 'शाखा खोज सुविधा जल्द ही आ रही है...'; } diff --git a/lib/widgets/bank_logos.dart b/lib/widgets/bank_logos.dart index 8c99a17..91e602c 100644 --- a/lib/widgets/bank_logos.dart +++ b/lib/widgets/bank_logos.dart @@ -64,7 +64,15 @@ Widget getBankLogo(String? bankName) { width: 40, height: 40, ); - } else { + } + if (bankName != null && bankName.toLowerCase().contains('bank of india')) { + return Image.asset( + 'assets/images/boi_logo.png', + width: 40, + height: 40, + ); + } + else { return const Icon( Icons.account_balance, size: 40, diff --git a/pubspec.yaml b/pubspec.yaml index a39f1ba..4979312 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -96,6 +96,7 @@ flutter: - assets/images/BankofBaroda_logo.png - assets/images/canaraBank_logo.png - assets/images/kotak_logo.png + - assets/images/boi_logo.png - assets/images/kmobile_splash.jpg - assets/images/kmobile_splash2.png - assets/images/icon.svg