import 'dart:async'; import 'package:built_collection/built_collection.dart'; import 'package:invoiceninja_flutter/redux/app/app_actions.dart'; import 'package:invoiceninja_flutter/redux/credit/credit_actions.dart'; import 'package:invoiceninja_flutter/redux/credit/credit_selectors.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:invoiceninja_flutter/ui/app/tables/entity_list.dart'; import 'package:invoiceninja_flutter/ui/credit/credit_list_item.dart'; import 'package:invoiceninja_flutter/ui/credit/credit_presenter.dart'; import 'package:invoiceninja_flutter/ui/invoice/invoice_list_vm.dart'; import 'package:invoiceninja_flutter/utils/completers.dart'; import 'package:invoiceninja_flutter/utils/localization.dart'; import 'package:redux/redux.dart'; import 'package:invoiceninja_flutter/data/models/models.dart'; import 'package:invoiceninja_flutter/redux/app/app_state.dart'; class CreditListBuilder extends StatelessWidget { const CreditListBuilder({Key key}) : super(key: key); static const String route = '/credits/edit'; @override Widget build(BuildContext context) { return StoreConnector( converter: CreditListVM.fromStore, builder: (context, viewModel) { return EntityList( onClearMultiselect: viewModel.onClearMultiselect, entityType: EntityType.credit, presenter: CreditPresenter(), state: viewModel.state, entityList: viewModel.invoiceList, tableColumns: viewModel.tableColumns, onRefreshed: viewModel.onRefreshed, onSortColumn: viewModel.onSortColumn, itemBuilder: (BuildContext context, index) { final state = viewModel.state; final invoiceId = viewModel.invoiceList[index]; final invoice = viewModel.invoiceMap[invoiceId]; final listUIState = state.getListState(EntityType.credit); final isInMultiselect = listUIState.isInMultiselect(); return CreditListItem( user: state.user, filter: viewModel.filter, credit: invoice, client: viewModel.clientMap[invoice.clientId] ?? ClientEntity(), isChecked: isInMultiselect && listUIState.isSelected(invoice.id), ); }); }); } } class CreditListVM extends EntityListVM { CreditListVM({ @required AppState state, @required List invoiceList, @required BuiltMap invoiceMap, @required BuiltMap clientMap, @required String filter, @required bool isLoading, @required Function(BuildContext) onRefreshed, @required Function(BuildContext, List, EntityAction) onEntityAction, @required List tableColumns, @required EntityType entityType, @required Function(String) onSortColumn, @required Function onClearMultiselect, }) : super( state: state, invoiceList: invoiceList, invoiceMap: invoiceMap, clientMap: clientMap, filter: filter, isLoading: isLoading, onRefreshed: onRefreshed, tableColumns: tableColumns, entityType: entityType, onSortColumn: onSortColumn, onClearMultiselect: onClearMultiselect, ); static CreditListVM fromStore(Store store) { Future _handleRefresh(BuildContext context) { if (store.state.isLoading) { return Future(null); } final completer = snackBarCompleter( context, AppLocalization.of(context).refreshComplete); store.dispatch(RefreshData(completer: completer)); return completer.future; } final state = store.state; return CreditListVM( state: state, invoiceList: memoizedFilteredCreditList( state.getUISelection(EntityType.credit), state.creditState.map, state.creditState.list, state.clientState.map, state.creditListState, state.staticState, state.userState.map), invoiceMap: state.creditState.map, clientMap: state.clientState.map, isLoading: state.isLoading, filter: state.creditListState.filter, onRefreshed: (context) => _handleRefresh(context), onEntityAction: (BuildContext context, List credits, EntityAction action) => handleCreditAction(context, credits, action), tableColumns: state.userCompany.settings.getTableColumns(EntityType.credit) ?? CreditPresenter.getDefaultTableFields(state.userCompany), entityType: EntityType.credit, onSortColumn: (field) => store.dispatch(SortCredits(field)), onClearMultiselect: () => store.dispatch(ClearCreditMultiselect()), ); } }