temp build

This commit is contained in:
Stephan D
2025-12-05 01:32:41 +01:00
parent 082d782a80
commit f71cc76f64
50 changed files with 853 additions and 707 deletions

View File

@@ -11,13 +11,11 @@ class PaymentInfoRow extends StatelessWidget {
});
@override
Widget build(BuildContext context) {
return Row(
children: [
Text(label, style: Theme.of(context).textTheme.bodySmall),
const SizedBox(width: 8),
Text(value, style: Theme.of(context).textTheme.bodySmall),
],
);
}
Widget build(BuildContext context) => Row(
children: [
Text(label, style: Theme.of(context).textTheme.bodySmall),
const SizedBox(width: 8),
Text(value, style: Theme.of(context).textTheme.bodySmall),
],
);
}

View File

@@ -1,36 +1,60 @@
import 'package:flutter/material.dart';
import 'package:pshared/models/payment/type.dart';
import 'package:provider/provider.dart';
import 'package:pshared/models/recipient/recipient.dart';
import 'package:pshared/provider/organizations.dart';
import 'package:pshared/provider/recipient/pmethods.dart';
import 'package:pshared/provider/recipient/provider.dart';
import 'package:pweb/pages/dashboard/payouts/single/adress_book/avatar.dart';
import 'package:pweb/pages/dashboard/payouts/single/adress_book/long_list/info_row.dart';
import 'package:pweb/utils/payment/label.dart';
class RecipientItem extends StatelessWidget {
final Recipient recipient;
final VoidCallback onTap;
class RecipientItem extends StatefulWidget {
static const double _horizontalPadding = 16.0;
static const double _verticalPadding = 8.0;
static const double _avatarRadius = 20;
static const double _spacingWidth = 12;
final Recipient recipient;
final VoidCallback onTap;
const RecipientItem({
super.key,
required this.recipient,
required this.onTap,
});
@override
State<RecipientItem> createState() => _RecipientItemState();
}
class _RecipientItemState extends State<RecipientItem> {
late PaymentMethodsProvider _methodsProvider;
@override
void initState() {
super.initState();
_methodsProvider = PaymentMethodsProvider();
_methodsProvider.updateProviders(
context.read<OrganizationsProvider>(),
context.read<RecipientsProvider>(),
);
}
@override
Widget build(BuildContext context) {
if (!_methodsProvider.isReady) return const Center(child: CircularProgressIndicator());
final recipient = widget.recipient;
return InkWell(
onTap: onTap,
onTap: widget.onTap,
child: Padding(
padding: const EdgeInsets.symmetric(
horizontal: _horizontalPadding,
vertical: _verticalPadding,
horizontal: RecipientItem._horizontalPadding,
vertical: RecipientItem._verticalPadding,
),
child: Row(
crossAxisAlignment: CrossAxisAlignment.start,
@@ -42,43 +66,20 @@ class RecipientItem extends StatelessWidget {
isVisible: false,
name: recipient.name,
avatarUrl: recipient.avatarUrl,
avatarRadius: _avatarRadius,
avatarRadius: RecipientItem._avatarRadius,
nameStyle: Theme.of(context).textTheme.bodyMedium,
),
title: Text(recipient.name),
subtitle: Text(recipient.email),
),
),
const SizedBox(width: _spacingWidth),
const SizedBox(width: RecipientItem._spacingWidth),
Column(
crossAxisAlignment: CrossAxisAlignment.end,
children: [
if (recipient.bank?.accountNumber.isNotEmpty == true)
PaymentInfoRow(
label: getPaymentTypeLabel(context, PaymentType.bankAccount),
value: recipient.bank!.accountNumber,
),
if (recipient.card?.pan.isNotEmpty == true)
PaymentInfoRow(
label: getPaymentTypeLabel(context, PaymentType.card),
value: recipient.card!.pan,
),
if (recipient.iban?.iban.isNotEmpty == true)
PaymentInfoRow(
label: getPaymentTypeLabel(context, PaymentType.iban),
value: recipient.iban!.iban,
),
if (recipient.wallet?.walletId.isNotEmpty == true)
PaymentInfoRow(
label: getPaymentTypeLabel(context, PaymentType.wallet),
value: recipient.wallet!.walletId,
),
if (recipient.cryptoAddress?.address.isNotEmpty == true)
PaymentInfoRow(
label: getPaymentTypeLabel(context, PaymentType.cryptoAddress),
value: recipient.cryptoAddress!.address,
),
],
children: _methodsProvider.methods.map((m) => PaymentInfoRow(
label: getPaymentTypeLabel(context, m.type),
value: _displayString(m),
)).toList(),
),
],
),

View File

@@ -3,11 +3,11 @@ import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:pshared/models/recipient/recipient.dart';
import 'package:pshared/provider/recipient/provider.dart';
import 'package:pweb/pages/address_book/page/search.dart';
import 'package:pweb/pages/dashboard/payouts/single/adress_book/long_list/long_list.dart';
import 'package:pweb/pages/dashboard/payouts/single/adress_book/long_list/widget.dart';
import 'package:pweb/pages/dashboard/payouts/single/adress_book/short_list.dart';
import 'package:pweb/providers/recipient.dart';
import 'package:pweb/generated/i18n/app_localizations.dart';
@@ -39,7 +39,7 @@ class _AdressBookPayoutState extends State<AdressBookPayout> {
@override
void initState() {
super.initState();
final provider = context.read<RecipientProvider>();
final provider = context.read<RecipientsProvider>();
_searchController = TextEditingController(text: provider.query);
_searchController.addListener(() {
@@ -57,7 +57,7 @@ class _AdressBookPayoutState extends State<AdressBookPayout> {
@override
Widget build(BuildContext context) {
final loc = AppLocalizations.of(context)!;
final provider = context.watch<RecipientProvider>();
final provider = context.watch<RecipientsProvider>();
if (provider.isLoading) {
return const Center(child: CircularProgressIndicator());
@@ -88,14 +88,14 @@ class _AdressBookPayoutState extends State<AdressBookPayout> {
const SizedBox(height: _spacingBetween),
Expanded(
child: _isExpanded
? LongListAdressBookPayout(
filteredRecipients: provider.filteredRecipients,
onSelected: widget.onSelected,
)
: ShortListAdressBookPayout(
recipients: provider.recipients,
onSelected: widget.onSelected,
),
? LongListAdressBookPayout(
filteredRecipients: provider.filteredRecipients,
onSelected: widget.onSelected,
)
: ShortListAdressBookPayout(
recipients: provider.recipients,
onSelected: widget.onSelected,
),
),
],
),