PMJJBY screen and creation done

This commit is contained in:
2026-02-26 18:13:38 +05:30
parent bade0f112f
commit e12a73c564
9 changed files with 605 additions and 18 deletions

View File

@@ -1,4 +1,7 @@
import 'package:flutter/material.dart';
import 'package:kmobile/api/services/yojna_service.dart';
import 'package:kmobile/di/injection.dart';
import 'package:kmobile/features/yojna/screens/pmjjby_screen.dart';
import 'package:kmobile/l10n/app_localizations.dart';
class PMMainScreen extends StatefulWidget {
@@ -23,6 +26,74 @@ class _PMMainScreenState extends State<PMMainScreen> {
super.dispose();
}
Future<void> _handleCreate() async {
if (_accountController.text.isEmpty) {
ScaffoldMessenger.of(context).showSnackBar(
const SnackBar(content: Text('Please enter account number')),
);
return;
}
if (_selectedScheme == null) {
ScaffoldMessenger.of(context).showSnackBar(
const SnackBar(content: Text('Please select a scheme first')),
);
return;
}
final String schemeCode = _selectedScheme!.contains('PMJJBY') ? '02' : '01';
// Show loading
ScaffoldMessenger.of(context).showSnackBar(
const SnackBar(
content: Row(
children: [
CircularProgressIndicator(),
SizedBox(width: 16),
Text('Fetching details...'),
],
),
duration: Duration(seconds: 2),
),
);
try {
final response = await getIt<YojnaService>().fetchpmydetails(
scheme: schemeCode,
action: 'C',
accountno: _accountController.text,
);
if (mounted) {
Map<String, dynamic>? data;
if (response is Map<String, dynamic>) {
data = response;
} else if (response is List && response.isNotEmpty && response[0] is Map<String, dynamic>) {
data = response[0] as Map<String, dynamic>;
}
if (data != null && data.isNotEmpty) {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => PMJJBYScreen(initialData: data),
),
);
} else {
ScaffoldMessenger.of(context).showSnackBar(
const SnackBar(content: Text('Failed to fetch details or no data found.')),
);
}
}
} catch (e) {
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(content: Text('Error: ${e.toString()}')),
);
}
}
}
@override
Widget build(BuildContext context) {
return Scaffold(
@@ -58,23 +129,48 @@ class _PMMainScreenState extends State<PMMainScreen> {
decoration: const InputDecoration(
labelText: 'Account Number',
border: OutlineInputBorder(),
contentPadding:
EdgeInsets.symmetric(vertical: 20, horizontal: 12),
),
keyboardType: TextInputType.number,
),
const SizedBox(height: 16),
DropdownButtonFormField<String>(
value: _selectedScheme,
isExpanded: true,
isDense: false,
itemHeight: null,
decoration: const InputDecoration(
labelText: 'Scheme',
labelText: 'Select Scheme',
border: OutlineInputBorder(),
contentPadding:
EdgeInsets.symmetric(vertical: 12, horizontal: 12),
),
selectedItemBuilder: (BuildContext context) {
return _schemes.map((String scheme) {
return Container(
alignment: Alignment.centerLeft,
child: Text(
scheme,
style: const TextStyle(fontSize: 14),
softWrap: true,
maxLines: 2,
overflow: TextOverflow.visible,
),
);
}).toList();
},
items: _schemes.map((String scheme) {
return DropdownMenuItem<String>(
value: scheme,
child: Text(
scheme,
style: const TextStyle(fontSize: 12),
overflow: TextOverflow.ellipsis,
child: Padding(
padding: const EdgeInsets.symmetric(vertical: 12.0),
child: Text(
scheme,
style: const TextStyle(fontSize: 15),
softWrap: true,
),
),
);
}).toList(),
@@ -83,7 +179,6 @@ class _PMMainScreenState extends State<PMMainScreen> {
_selectedScheme = newValue;
});
},
isExpanded: true,
),
],
),
@@ -94,9 +189,7 @@ class _PMMainScreenState extends State<PMMainScreen> {
children: [
Expanded(
child: ElevatedButton(
onPressed: () {
// Action for Create button
},
onPressed: _handleCreate,
style: ElevatedButton.styleFrom(
backgroundColor:
Theme.of(context).colorScheme.primaryContainer,