2024-07-14 15:34:24 +00:00
|
|
|
import 'package:flutter/material.dart';
|
2024-09-20 17:16:54 +00:00
|
|
|
import 'package:haveno/utils/payment_utils.dart';
|
|
|
|
import 'package:haveno/widgets/add_payment_account_form.dart';
|
2024-07-14 15:34:24 +00:00
|
|
|
import 'package:provider/provider.dart';
|
2024-09-20 17:16:54 +00:00
|
|
|
import 'package:haveno/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;
|
|
|
|
},
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|