invoice/lib/ui/reports/tax_report.dart

245 lines
7.8 KiB
Dart

import 'package:built_collection/built_collection.dart';
import 'package:invoiceninja_flutter/utils/enums.dart';
import 'package:invoiceninja_flutter/constants.dart';
import 'package:invoiceninja_flutter/data/models/tax_rate_model.dart';
import 'package:invoiceninja_flutter/data/models/company_model.dart';
import 'package:invoiceninja_flutter/data/models/models.dart';
import 'package:invoiceninja_flutter/redux/reports/reports_state.dart';
import 'package:invoiceninja_flutter/redux/static/static_state.dart';
import 'package:invoiceninja_flutter/ui/reports/reports_screen.dart';
import 'package:memoize/memoize.dart';
enum TaxRateReportFields {
client,
number,
amount,
date,
tax_name,
tax_rate,
tax_amount,
tax_paid,
currency
}
var memoizedTaxReport = memo9((
UserCompanyEntity userCompany,
ReportsUIState reportsUIState,
BuiltMap<String, TaxRateEntity> taxRateMap,
BuiltMap<String, InvoiceEntity> invoiceMap,
BuiltMap<String, InvoiceEntity> creditMap,
BuiltMap<String, ClientEntity> clientMap,
BuiltMap<String, PaymentEntity> paymentMap,
BuiltMap<String, UserEntity> userMap,
StaticState staticState,
) =>
taxReport(userCompany, reportsUIState, taxRateMap, invoiceMap, creditMap,
clientMap, paymentMap, userMap, staticState));
ReportResult taxReport(
UserCompanyEntity userCompany,
ReportsUIState reportsUIState,
BuiltMap<String, TaxRateEntity> taxRateMap,
BuiltMap<String, InvoiceEntity> invoiceMap,
BuiltMap<String, InvoiceEntity> creditMap,
BuiltMap<String, ClientEntity> clientMap,
BuiltMap<String, PaymentEntity> paymentMap,
BuiltMap<String, UserEntity> userMap,
StaticState staticState,
) {
final List<List<ReportElement>> data = [];
BuiltList<TaxRateReportFields> columns;
final reportSettings = userCompany.settings.reportSettings;
final taxRateReportSettings =
reportSettings != null && reportSettings.containsKey(kReportTax)
? reportSettings[kReportTax]
: ReportSettingsEntity();
final defaultColumns = [
TaxRateReportFields.tax_name,
TaxRateReportFields.tax_amount,
TaxRateReportFields.tax_paid,
TaxRateReportFields.amount,
TaxRateReportFields.date,
TaxRateReportFields.number,
];
if (taxRateReportSettings.columns.isNotEmpty) {
columns = BuiltList(taxRateReportSettings.columns
.map((e) => EnumUtils.fromString(TaxRateReportFields.values, e))
.where((element) => element != null)
.toList());
} else {
columns = BuiltList(defaultColumns);
}
for (var invoiceId in invoiceMap.keys) {
final invoice = invoiceMap[invoiceId];
if (invoice.isActive && invoice.isSent) {
final client = clientMap[invoice.clientId];
final precision = staticState.currencyMap[client.currencyId].precision;
final taxes = invoice.getTaxes(precision);
for (final key in taxes.keys) {
bool skip = false;
final List<ReportElement> row = [];
final String taxName = taxes[key]['name'];
final double taxRate = taxes[key]['rate'];
if (taxRate == null || taxRate == 0) {
continue;
}
for (var column in columns) {
dynamic value = '';
switch (column) {
case TaxRateReportFields.client:
value = client.displayName;
break;
case TaxRateReportFields.number:
value = invoice.number;
break;
case TaxRateReportFields.date:
value = invoice.date;
break;
case TaxRateReportFields.amount:
value = invoice.amount;
break;
case TaxRateReportFields.tax_name:
value = taxName;
break;
case TaxRateReportFields.tax_rate:
value = taxRate;
break;
case TaxRateReportFields.tax_amount:
value = taxes[key]['amount'] ?? 0.0;
break;
case TaxRateReportFields.tax_paid:
value = taxes[key]['paid'] ?? 0.0;
break;
case TaxRateReportFields.currency:
value = staticState.currencyMap[client.currencyId]?.name ??
staticState.currencyMap[client.settings.currencyId]?.name;
break;
}
if (!ReportResult.matchField(
value: value,
userCompany: userCompany,
reportsUIState: reportsUIState,
column: EnumUtils.parse(column),
)) {
skip = true;
}
if (value.runtimeType == bool) {
row.add(invoice.getReportBool(value: value));
} else if (value.runtimeType == double || value.runtimeType == int) {
row.add(invoice.getReportDouble(
value: value, currencyId: client.settings.currencyId));
} else {
row.add(invoice.getReportString(value: value));
}
}
if (!skip) {
data.add(row);
}
}
}
}
for (var creditId in creditMap.keys) {
final credit = creditMap[creditId];
if (credit.isActive && credit.isSent) {
final client = clientMap[credit.clientId];
final precision = staticState.currencyMap[client.currencyId].precision;
final taxes = credit.getTaxes(precision);
for (final key in taxes.keys) {
bool skip = false;
final List<ReportElement> row = [];
final String taxName = taxes[key]['name'];
final double taxRate = taxes[key]['rate'];
if (taxRate == null || taxRate == 0) {
continue;
}
for (var column in columns) {
dynamic value = '';
switch (column) {
case TaxRateReportFields.client:
value = client.displayName;
break;
case TaxRateReportFields.number:
value = credit.number;
break;
case TaxRateReportFields.date:
value = credit.date;
break;
case TaxRateReportFields.amount:
value = credit.amount * -1;
break;
case TaxRateReportFields.tax_name:
value = taxName;
break;
case TaxRateReportFields.tax_rate:
value = taxRate;
break;
case TaxRateReportFields.tax_amount:
value = (taxes[key]['amount'] ?? 0.0) * -1;
break;
case TaxRateReportFields.tax_paid:
value = (taxes[key]['paid'] ?? 0.0) * -1;
break;
case TaxRateReportFields.currency:
value = staticState.currencyMap[client.currencyId]?.name ??
staticState.currencyMap[client.settings.currencyId]?.name;
break;
}
if (!ReportResult.matchField(
value: value,
userCompany: userCompany,
reportsUIState: reportsUIState,
column: EnumUtils.parse(column),
)) {
skip = true;
}
if (value.runtimeType == bool) {
row.add(credit.getReportBool(value: value));
} else if (value.runtimeType == double || value.runtimeType == int) {
row.add(credit.getReportDouble(
value: value, currencyId: client.settings.currencyId));
} else {
row.add(credit.getReportString(value: value));
}
}
if (!skip) {
data.add(row);
}
}
}
}
final selectedColumns = columns.map((item) => EnumUtils.parse(item)).toList();
data.sort((rowA, rowB) =>
sortReportTableRows(rowA, rowB, taxRateReportSettings, selectedColumns));
return ReportResult(
allColumns:
TaxRateReportFields.values.map((e) => EnumUtils.parse(e)).toList(),
columns: columns.map((item) => EnumUtils.parse(item)).toList(),
defaultColumns:
defaultColumns.map((item) => EnumUtils.parse(item)).toList(),
data: data,
);
}