haveno-app/lib/widgets/add_payment_method_form.dart

85 lines
2.9 KiB
Dart
Raw Normal View History

2024-07-14 15:34:24 +00:00
import 'package:flutter/material.dart';
2024-07-15 19:14:30 +00:00
import 'package:haveno_flutter_app/utils/payment_utils.dart';
import 'package:haveno_flutter_app/widgets/add_payment_account_form.dart';
2024-07-14 15:34:24 +00:00
import 'package:provider/provider.dart';
2024-07-15 19:14:30 +00:00
import 'package:haveno_flutter_app/providers/payment_accounts_provider.dart';// Import the utils file
2024-07-14 15:34:24 +00:00
class PaymentMethodSelectionForm extends StatefulWidget {
2024-07-15 19:14:30 +00:00
final String accountType;
PaymentMethodSelectionForm({required this.accountType});
2024-07-14 15:34:24 +00:00
@override
_PaymentMethodSelectionFormState createState() =>
_PaymentMethodSelectionFormState();
}
class _PaymentMethodSelectionFormState
extends State<PaymentMethodSelectionForm> {
String? _selectedPaymentMethod;
@override
Widget build(BuildContext context) {
final paymentAccountsProvider =
Provider.of<PaymentAccountsProvider>(context);
2024-07-15 19:14:30 +00:00
final paymentMethods = widget.accountType == 'FIAT'
? paymentAccountsProvider.paymentMethods
: paymentAccountsProvider.cryptoCurrencyPaymentMethods;
2024-07-14 15:34:24 +00:00
return Padding(
padding: MediaQuery.of(context).viewInsets,
child: Container(
padding: EdgeInsets.all(16.0),
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
const Text('Select Payment Method', style: TextStyle(fontSize: 18)),
const SizedBox(height: 16.0),
DropdownButtonFormField<String>(
decoration: const InputDecoration(
labelText: 'Payment Method',
border: OutlineInputBorder(),
),
2024-07-15 19:14:30 +00:00
items: paymentMethods?.map((method) {
2024-07-14 15:34:24 +00:00
return DropdownMenuItem<String>(
value: method.id,
2024-07-15 19:14:30 +00:00
child: Text(getPaymentMethodLabel(method.id)),
2024-07-14 15:34:24 +00:00
);
}).toList(),
onChanged: (value) {
setState(() {
_selectedPaymentMethod = value;
});
if (value != null) {
paymentAccountsProvider
.getPaymentAcountForm(value)
.then((form) {
Navigator.pop(context);
showModalBottomSheet(
context: context,
isScrollControlled: true,
builder: (BuildContext context) {
return DynamicPaymentAccountForm(
paymentAccountForm: form,
2024-07-15 19:14:30 +00:00
paymentMethodLabel: getPaymentMethodLabel(value),
2024-07-14 15:34:24 +00:00
paymentMethodId: value);
},
);
});
}
},
validator: (value) {
if (value == null || value.isEmpty) {
return 'Please select a payment method';
}
return null;
},
),
],
),
),
);
}
}