import 'dart:async'; import 'package:redux/redux.dart'; import 'package:flutter/material.dart'; import 'package:flutter/foundation.dart'; import 'package:flutter/widgets.dart'; import 'package:flutter_redux/flutter_redux.dart'; import 'package:built_collection/built_collection.dart'; import 'package:invoiceninja_flutter/utils/completers.dart'; import 'package:invoiceninja_flutter/utils/localization.dart'; import 'package:invoiceninja_flutter/redux/payment/payment_selectors.dart'; import 'package:invoiceninja_flutter/data/models/models.dart'; import 'package:invoiceninja_flutter/ui/payment/payment_list.dart'; import 'package:invoiceninja_flutter/redux/app/app_state.dart'; import 'package:invoiceninja_flutter/redux/payment/payment_actions.dart'; class PaymentListBuilder extends StatelessWidget { const PaymentListBuilder({Key key}) : super(key: key); @override Widget build(BuildContext context) { return StoreConnector( converter: PaymentListVM.fromStore, builder: (context, viewModel) { return PaymentList( viewModel: viewModel, ); }, ); } } class PaymentListVM { final UserEntity user; final List paymentList; final BuiltMap paymentMap; final String filter; final bool isLoading; final bool isLoaded; final Function(BuildContext, PaymentEntity) onPaymentTap; final Function(BuildContext, PaymentEntity, DismissDirection) onDismissed; final Function(BuildContext) onRefreshed; final Function(BuildContext, PaymentEntity, EntityAction) onEntityAction; PaymentListVM({ @required this.user, @required this.paymentList, @required this.paymentMap, @required this.filter, @required this.isLoading, @required this.isLoaded, @required this.onPaymentTap, @required this.onDismissed, @required this.onRefreshed, @required this.onEntityAction, }); static PaymentListVM fromStore(Store store) { Future _handleRefresh(BuildContext context) { if (store.state.isLoading) { return Future(null); } final completer = snackBarCompleter( context, AppLocalization.of(context).refreshComplete); store.dispatch(LoadPayments(completer: completer, force: true)); return completer.future; } final state = store.state; return PaymentListVM( user: state.user, paymentList: memoizedFilteredPaymentList(state.paymentState.map, state.paymentState.list, state.paymentListState), paymentMap: state.paymentState.map, isLoading: state.isLoading, isLoaded: state.paymentState.isLoaded, filter: state.paymentUIState.listUIState.filter, onPaymentTap: (context, payment) { store.dispatch(ViewPayment(paymentId: payment.id, context: context)); }, onEntityAction: (context, payment, action) { switch (action) { case EntityAction.restore: store.dispatch(RestorePaymentRequest( popCompleter( context, AppLocalization.of(context).restoredPayment), payment.id)); break; case EntityAction.archive: store.dispatch(ArchivePaymentRequest( popCompleter( context, AppLocalization.of(context).archivedPayment), payment.id)); break; case EntityAction.delete: store.dispatch(DeletePaymentRequest( popCompleter( context, AppLocalization.of(context).deletedPayment), payment.id)); break; } }, onRefreshed: (context) => _handleRefresh(context), onDismissed: (BuildContext context, PaymentEntity payment, DismissDirection direction) { final localization = AppLocalization.of(context); if (direction == DismissDirection.endToStart) { if (payment.isDeleted || payment.isArchived) { store.dispatch(RestorePaymentRequest( snackBarCompleter(context, localization.restoredPayment), payment.id)); } else { store.dispatch(ArchivePaymentRequest( snackBarCompleter(context, localization.archivedPayment), payment.id)); } } else if (direction == DismissDirection.startToEnd) { if (payment.isDeleted) { store.dispatch(RestorePaymentRequest( snackBarCompleter(context, localization.restoredPayment), payment.id)); } else { store.dispatch(DeletePaymentRequest( snackBarCompleter(context, localization.deletedPayment), payment.id)); } } }); } }