invoice/lib/redux/reports/reports_state.dart

131 lines
4.5 KiB
Dart

import 'package:invoiceninja_flutter/constants.dart';
import 'package:invoiceninja_flutter/data/models/company_model.dart';
import 'package:invoiceninja_flutter/data/models/dashboard_model.dart';
import 'package:built_value/built_value.dart';
import 'package:built_value/serializer.dart';
import 'package:invoiceninja_flutter/utils/dates.dart';
import 'package:invoiceninja_flutter/utils/formatting.dart';
part 'reports_state.g.dart';
abstract class ReportsUIState
implements Built<ReportsUIState, ReportsUIStateBuilder> {
factory ReportsUIState() {
return _$ReportsUIState._(
report: kReportActivity,
dateRange: DateRange.last30Days,
customStartDate: '',
customEndDate: convertDateTimeToSqlDate(),
currencyId: kCurrencyAll,
offset: 0,
);
}
ReportsUIState._();
String get report;
DateRange get dateRange;
String get customStartDate;
String get customEndDate;
int get offset;
String get currencyId;
static Serializer<ReportsUIState> get serializer =>
_$reportsUIStateSerializer;
bool matchesCurrency(String match) {
if (currencyId == null ||
currencyId.isEmpty ||
currencyId == kCurrencyAll) {
return true;
}
return currencyId == match;
}
String startDate(CompanyEntity company) {
final today = DateTime.now();
final firstDayOfMonth = DateTime.utc(today.year, today.month, 1);
final firstDayOfYear = DateTime.utc(
today.year, int.tryParse(company.firstMonthOfYear) ?? 0, 1);
switch (dateRange) {
case DateRange.last7Days:
final date = today.subtract(Duration(days: 7 * (1 + offset)));
return convertDateTimeToSqlDate(date);
case DateRange.last30Days:
final date = today.subtract(Duration(days: 30 * (1 + offset)));
return convertDateTimeToSqlDate(date);
case DateRange.thisMonth:
final date = addMonths(firstDayOfMonth, offset * -1);
return convertDateTimeToSqlDate(date);
case DateRange.lastMonth:
final date = addMonths(firstDayOfMonth, (1 + offset) * -1);
return convertDateTimeToSqlDate(date);
case DateRange.thisYear:
final date = addYears(firstDayOfYear, offset * -1);
return convertDateTimeToSqlDate(date);
case DateRange.lastYear:
final date = addYears(firstDayOfYear, (1 + offset) * -1);
return convertDateTimeToSqlDate(date);
default:
final startDate = customStartDate.isEmpty
? DateTime.now()
: DateTime.parse(customStartDate);
final endDate = customEndDate.isEmpty
? DateTime.now()
: DateTime.parse(customEndDate);
final days = endDate.difference(startDate).inDays;
return convertDateTimeToSqlDate(
startDate.subtract(Duration(days: days * offset)));
}
}
String endDate(CompanyEntity company) {
final today = DateTime.now();
final firstDayOfMonth = DateTime.utc(today.year, today.month, 1);
final firstDayOfYear = DateTime.utc(
today.year, int.tryParse(company.firstMonthOfYear) ?? 0, 1);
switch (dateRange) {
case DateRange.last7Days:
final date = today.subtract(Duration(days: 7 * offset));
return convertDateTimeToSqlDate(date);
case DateRange.last30Days:
final date = today.subtract(Duration(days: 30 * offset));
return convertDateTimeToSqlDate(date);
case DateRange.thisMonth:
final date = addMonths(firstDayOfMonth, (offset - 1) * -1)
.subtract(Duration(days: 1));
return convertDateTimeToSqlDate(date);
case DateRange.lastMonth:
final date =
addMonths(firstDayOfMonth, offset * -1).subtract(Duration(days: 1));
return convertDateTimeToSqlDate(date);
case DateRange.thisYear:
final date = addYears(firstDayOfYear, (offset - 1) * -1)
.subtract(Duration(days: 1));
return convertDateTimeToSqlDate(date);
case DateRange.lastYear:
final date =
addYears(firstDayOfYear, offset * -1).subtract(Duration(days: 1));
return convertDateTimeToSqlDate(date);
default:
final startDate = customStartDate.isEmpty
? DateTime.now()
: DateTime.parse(customStartDate);
final endDate = customEndDate.isEmpty
? DateTime.now()
: DateTime.parse(customEndDate);
final days = endDate.difference(startDate).inDays;
return convertDateTimeToSqlDate(
endDate.subtract(Duration(days: days * offset)));
}
}
}