invoice/lib/redux/payment/payment_selectors.dart

145 lines
4.8 KiB
Dart

import 'package:invoiceninja_flutter/redux/app/app_state.dart';
import 'package:memoize/memoize.dart';
import 'package:built_collection/built_collection.dart';
import 'package:invoiceninja_flutter/data/models/models.dart';
import 'package:invoiceninja_flutter/redux/ui/list_ui_state.dart';
var memoizedPaymentsByInvoice = memo3((int invoiceId,
BuiltMap<int, PaymentEntity> paymentMap, BuiltList<int> paymentList) =>
paymentsByInvoiceSelector(invoiceId, paymentMap, paymentList));
List<PaymentEntity> paymentsByInvoiceSelector(int invoiceId,
BuiltMap<int, PaymentEntity> paymentMap, BuiltList<int> paymentList) {
return paymentList
.map((paymentId) => paymentMap[paymentId])
.where((payment) => payment.invoiceId == invoiceId && !payment.isDeleted)
.toList();
}
InvoiceEntity paymentInvoiceSelector(int paymentId, AppState state) {
final payment =
state.paymentState.map[paymentId] ?? PaymentEntity(id: paymentId);
return state.invoiceState.map[payment.invoiceId] ??
InvoiceEntity(id: payment.invoiceId);
}
ClientEntity paymentClientSelector(int paymentId, AppState state) {
final invoice = paymentInvoiceSelector(paymentId, state);
return state.clientState.map[invoice.clientId] ??
ClientEntity(id: invoice.clientId);
}
var memoizedDropdownPaymentList = memo2(
(BuiltMap<int, PaymentEntity> paymentMap, BuiltList<int> paymentList) =>
dropdownPaymentsSelector(paymentMap, paymentList));
List<int> dropdownPaymentsSelector(
BuiltMap<int, PaymentEntity> paymentMap, BuiltList<int> paymentList) {
final list =
paymentList.where((paymentId) => paymentMap[paymentId].isActive).toList();
list.sort((paymentAId, paymentBId) {
final paymentA = paymentMap[paymentAId];
final paymentB = paymentMap[paymentBId];
return paymentA.compareTo(paymentB, PaymentFields.paymentDate, true);
});
return list;
}
var memoizedFilteredPaymentList = memo5(
(BuiltMap<int, PaymentEntity> paymentMap,
BuiltList<int> paymentList,
BuiltMap<int, InvoiceEntity> invoiceMap,
BuiltMap<int, ClientEntity> clientMap,
ListUIState paymentListState) =>
filteredPaymentsSelector(
paymentMap, paymentList, invoiceMap, clientMap, paymentListState));
List<int> filteredPaymentsSelector(
BuiltMap<int, PaymentEntity> paymentMap,
BuiltList<int> paymentList,
BuiltMap<int, InvoiceEntity> invoiceMap,
BuiltMap<int, ClientEntity> clientMap,
ListUIState paymentListState) {
final list = paymentList.where((paymentId) {
final payment = paymentMap[paymentId];
if (!payment.matchesStates(paymentListState.stateFilters)) {
return false;
}
final invoice =
invoiceMap[payment.invoiceId] ?? InvoiceEntity(id: payment.invoiceId);
final client =
clientMap[invoice.clientId] ?? ClientEntity(id: invoice.clientId);
if (paymentListState.filterEntityId != null) {
if (paymentListState.filterEntityType == EntityType.client &&
invoice.clientId != paymentListState.filterEntityId) {
return false;
} else if (paymentListState.filterEntityType == EntityType.invoice &&
payment.invoiceId != paymentListState.filterEntityId) {
return false;
}
} else if (invoice.isDeleted || !client.isActive) {
return false;
}
return payment.matchesFilter(paymentListState.filter);
}).toList();
list.sort((paymentAId, paymentBId) {
final paymentA = paymentMap[paymentAId];
final paymentB = paymentMap[paymentBId];
return paymentA.compareTo(
paymentB, paymentListState.sortField, paymentListState.sortAscending);
});
return list;
}
var memoizedPaymentStatsForClient = memo5((int clientId,
BuiltMap<int, PaymentEntity> paymentMap,
BuiltMap<int, InvoiceEntity> invoiceMap,
String activeLabel,
String archivedLabel) =>
invoiceStatsForClient(
clientId, paymentMap, invoiceMap, activeLabel, archivedLabel));
String invoiceStatsForClient(
int clientId,
BuiltMap<int, PaymentEntity> paymentMap,
BuiltMap<int, InvoiceEntity> invoiceMap,
String activeLabel,
String archivedLabel) {
int countActive = 0;
int countArchived = 0;
paymentMap.forEach((paymentId, payment) {
if (invoiceMap.containsKey(payment.invoiceId) &&
invoiceMap[payment.invoiceId].clientId == clientId) {
if (payment.isActive) {
countActive++;
} else if (payment.isArchived) {
countArchived++;
}
}
});
String str = '';
if (countActive > 0) {
str = '$countActive $activeLabel';
if (countArchived > 0) {
str += '';
}
}
if (countArchived > 0) {
str += '$countArchived $archivedLabel';
}
return str;
}
bool hasPaymentChanges(
PaymentEntity payment, BuiltMap<int, PaymentEntity> paymentMap) =>
payment.isNew || payment != paymentMap[payment.id];