invoice/lib/ui/settings/tax_settings.dart

179 lines
6.3 KiB
Dart

// Flutter imports:
import 'package:flutter/material.dart';
// Package imports:
import 'package:material_design_icons_flutter/material_design_icons_flutter.dart';
// Project imports:
import 'package:invoiceninja_flutter/ui/app/buttons/elevated_button.dart';
import 'package:invoiceninja_flutter/ui/app/edit_scaffold.dart';
import 'package:invoiceninja_flutter/ui/app/form_card.dart';
import 'package:invoiceninja_flutter/ui/app/forms/app_dropdown_button.dart';
import 'package:invoiceninja_flutter/ui/app/forms/app_form.dart';
import 'package:invoiceninja_flutter/ui/app/forms/bool_dropdown_button.dart';
import 'package:invoiceninja_flutter/ui/app/invoice/tax_rate_dropdown.dart';
import 'package:invoiceninja_flutter/ui/settings/tax_settings_vm.dart';
import 'package:invoiceninja_flutter/utils/localization.dart';
class TaxSettings extends StatefulWidget {
const TaxSettings({
Key key,
@required this.viewModel,
}) : super(key: key);
final TaxSettingsVM viewModel;
@override
_TaxSettingsState createState() => _TaxSettingsState();
}
class _TaxSettingsState extends State<TaxSettings> {
static final GlobalKey<FormState> _formKey =
GlobalKey<FormState>(debugLabel: '_taxSettings');
FocusScopeNode _focusNode;
@override
void initState() {
super.initState();
_focusNode = FocusScopeNode();
}
@override
void dispose() {
_focusNode.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
final localization = AppLocalization.of(context);
final viewModel = widget.viewModel;
final settings = viewModel.settings;
final company = viewModel.company;
final state = viewModel.state;
return EditScaffold(
title: localization.taxSettings,
onSavePressed: viewModel.onSavePressed,
body: AppForm(
formKey: _formKey,
focusNode: _focusNode,
children: <Widget>[
if (!state.settingsUIState.isFiltered)
FormCard(
children: <Widget>[
NumberOfRatesSelector(
label: localization.invoiceTaxRates,
numberOfRates: company.numberOfInvoiceTaxRates,
onChanged: (value) => viewModel.onCompanyChanged(company
.rebuild((b) => b..numberOfInvoiceTaxRates = value)),
),
NumberOfRatesSelector(
label: localization.itemTaxRates,
numberOfRates: company.numberOfItemTaxRates,
onChanged: (value) => viewModel.onCompanyChanged(
company.rebuild((b) => b..numberOfItemTaxRates = value)),
),
SizedBox(height: 16),
BoolDropdownButton(
iconData: MdiIcons.percent,
label: localization.inclusiveTaxes,
value: settings.enableInclusiveTaxes,
onChanged: (value) => viewModel.onSettingsChanged(
settings.rebuild((b) => b..enableInclusiveTaxes = value)),
helpLabel:
'\n${localization.exclusive}: 100 + 10% = 100 + 10\n${localization.inclusive}: 100 + 10% = 90.91 + 9.09',
),
],
),
if (state.taxRateState.list.isNotEmpty)
FormCard(
children: <Widget>[
if (company.enableFirstInvoiceTaxRate)
TaxRateDropdown(
onSelected: (taxRate) =>
viewModel.onSettingsChanged(settings.rebuild((b) => b
..defaultTaxName1 = taxRate.name
..defaultTaxRate1 = taxRate.rate)),
labelText: localization.defaultTaxRate,
initialTaxName: settings.defaultTaxName1,
initialTaxRate: settings.defaultTaxRate1,
),
if (company.enableSecondInvoiceTaxRate)
TaxRateDropdown(
onSelected: (taxRate) =>
viewModel.onSettingsChanged(settings.rebuild((b) => b
..defaultTaxName2 = taxRate.name
..defaultTaxRate2 = taxRate.rate)),
labelText: localization.defaultTaxRate,
initialTaxName: settings.defaultTaxName2,
initialTaxRate: settings.defaultTaxRate2,
),
if (company.enableThirdInvoiceTaxRate)
TaxRateDropdown(
onSelected: (taxRate) =>
viewModel.onSettingsChanged(settings.rebuild((b) => b
..defaultTaxName3 = taxRate.name
..defaultTaxRate3 = taxRate.rate)),
labelText: localization.defaultTaxRate,
initialTaxName: settings.defaultTaxName3,
initialTaxRate: settings.defaultTaxRate3,
),
],
),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 16.0),
child: AppButton(
iconData: Icons.settings,
label: localization.configureRates.toUpperCase(),
onPressed: () => viewModel.onConfigureRatesPressed(context),
),
),
],
),
);
}
}
class NumberOfRatesSelector extends StatelessWidget {
const NumberOfRatesSelector({
@required this.label,
@required this.numberOfRates,
@required this.onChanged,
});
final String label;
final int numberOfRates;
final Function(int) onChanged;
@override
Widget build(BuildContext context) {
final localization = AppLocalization.of(context);
return AppDropdownButton(
labelText: label,
value: numberOfRates == null ? '' : '$numberOfRates',
onChanged: (dynamic value) =>
onChanged(value == null || value.isEmpty ? null : int.parse(value)),
items: [
DropdownMenuItem(
child: Text(localization.disabled),
value: '0',
),
DropdownMenuItem(
child: Text(localization.oneTaxRate),
value: '1',
),
DropdownMenuItem(
child: Text(localization.twoTaxRates),
value: '2',
),
DropdownMenuItem(
child: Text(localization.threeTaxRates),
value: '3',
),
],
);
}
}