import 'package:flutter/material.dart'; import 'package:kmobile/data/models/user.dart'; import 'package:kmobile/l10n/app_localizations.dart'; import 'package:kmobile/features/account_opening/screens/create_deposit_screen.dart'; class AccountOpeningScreen extends StatefulWidget { final List users; final int selectedIndex; const AccountOpeningScreen({ super.key, required this.users, required this.selectedIndex, }); @override State createState() => _AccountOpeningScreenState(); } class _AccountOpeningScreenState extends State { User? _selectedAccount; List _filteredUsers = []; final _formKey = GlobalKey(); bool _isLoading = false; @override void initState() { super.initState(); _filteredUsers = widget.users .where((user) => ['SA', 'SB', 'CA', 'CC'].contains(user.accountType)) .toList(); // Pre-fill the account number if possible if (widget.users.isNotEmpty && widget.selectedIndex < widget.users.length) { if (_filteredUsers.isNotEmpty) { if (_filteredUsers.contains(widget.users[widget.selectedIndex])) { _selectedAccount = widget.users[widget.selectedIndex]; } else { _selectedAccount = _filteredUsers.first; } } else { _selectedAccount = widget.users[widget.selectedIndex]; } } else { if (_filteredUsers.isNotEmpty) { _selectedAccount = _filteredUsers.first; } } } @override Widget build(BuildContext context) { final l10n = AppLocalizations.of(context); return Scaffold( appBar: AppBar( title: Text(l10n.accountOpeningDeposit), centerTitle: false, ), body: SingleChildScrollView( padding: const EdgeInsets.all(16.0), child: Form( key: _formKey, child: Column( crossAxisAlignment: CrossAxisAlignment.stretch, children: [ Card( elevation: 2, child: Padding( padding: const EdgeInsets.all(16.0), child: Text( "Select your source account to proceed with opening a new FD, TD, or RD account. Your KYC details will be verified.", style: Theme.of(context).textTheme.titleMedium, ), ), ), const SizedBox(height: 16), Card( elevation: 2, child: Padding( padding: const EdgeInsets.all(16.0), child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ DropdownButtonFormField( value: _selectedAccount, decoration: InputDecoration( labelText: l10n.accountNumber, border: const OutlineInputBorder(), contentPadding: const EdgeInsets.symmetric( vertical: 20, horizontal: 12), ), items: _filteredUsers.map((user) { return DropdownMenuItem( value: user, child: Text(user.accountNo.toString()), ); }).toList(), onChanged: (User? newUser) { setState(() { _selectedAccount = newUser; }); }, validator: (value) { if (value == null) { return l10n.accountNumberRequired; } return null; }, ), ], ), ), ), const SizedBox(height: 24), ElevatedButton( onPressed: _isLoading ? null : () async { if (_formKey.currentState!.validate() && _selectedAccount != null) { // Simulating API response final mockResponse = { "addressline1": "DATA CENTRE KCCB CIVIL BAZAR D/SHALA DHA", "addressline2": "RAMSHALA KANGRA", "cifNo": "30022497139", "customername": "Mr. RAJAT KUMAR MAHARANA", "idno": "536652226333 61", "nationality": "IN", "pincode": "176047" }; Navigator.push( context, MaterialPageRoute( builder: (context) => CreateDepositScreen( selectedAccount: _selectedAccount!, initialData: mockResponse, ), ), ); } }, style: ElevatedButton.styleFrom( backgroundColor: Theme.of(context).colorScheme.primaryContainer, foregroundColor: Theme.of(context).colorScheme.onPrimaryContainer, minimumSize: const Size(double.infinity, 50), elevation: 4, shape: RoundedRectangleBorder( borderRadius: BorderRadius.circular(8), ), ), child: _isLoading ? const SizedBox( height: 20, width: 20, child: CircularProgressIndicator( strokeWidth: 2, ), ) : Text( l10n.proceedButton, style: const TextStyle( fontSize: 16, fontWeight: FontWeight.bold), ), ), ], ), ), ), ); } }