invoice/lib/ui/settings/client_portal_vm.dart

117 lines
4.4 KiB
Dart

// Flutter imports:
import 'package:flutter/material.dart';
import 'package:flutter/widgets.dart';
// Package imports:
import 'package:flutter_redux/flutter_redux.dart';
import 'package:redux/redux.dart';
// Project imports:
import 'package:invoiceninja_flutter/constants.dart';
import 'package:invoiceninja_flutter/data/models/client_model.dart';
import 'package:invoiceninja_flutter/data/models/company_model.dart';
import 'package:invoiceninja_flutter/data/models/entities.dart';
import 'package:invoiceninja_flutter/data/models/group_model.dart';
import 'package:invoiceninja_flutter/data/models/settings_model.dart';
import 'package:invoiceninja_flutter/main_app.dart';
import 'package:invoiceninja_flutter/redux/app/app_state.dart';
import 'package:invoiceninja_flutter/redux/client/client_actions.dart';
import 'package:invoiceninja_flutter/redux/company/company_actions.dart';
import 'package:invoiceninja_flutter/redux/group/group_actions.dart';
import 'package:invoiceninja_flutter/redux/settings/settings_actions.dart';
import 'package:invoiceninja_flutter/ui/settings/client_portal.dart';
import 'package:invoiceninja_flutter/utils/completers.dart';
import 'package:invoiceninja_flutter/utils/dialogs.dart';
import 'package:invoiceninja_flutter/utils/localization.dart';
class ClientPortalScreen extends StatelessWidget {
const ClientPortalScreen({Key? key}) : super(key: key);
static const String route = '/$kSettings/$kSettingsClientPortal';
@override
Widget build(BuildContext context) {
return StoreConnector<AppState, ClientPortalVM>(
converter: ClientPortalVM.fromStore,
builder: (context, viewModel) {
return ClientPortal(
viewModel: viewModel,
key: ValueKey(viewModel.state.settingsUIState.updatedAt),
);
},
);
}
}
class ClientPortalVM {
ClientPortalVM({
required this.state,
required this.settings,
required this.company,
required this.onCompanyChanged,
required this.onSettingsChanged,
required this.onSavePressed,
});
static ClientPortalVM fromStore(Store<AppState> store) {
final state = store.state;
return ClientPortalVM(
state: state,
settings: state.uiState.settingsUIState.settings,
company: state.uiState.settingsUIState.company,
onSettingsChanged: (settings) =>
store.dispatch(UpdateSettings(settings: settings)),
onCompanyChanged: (company) =>
store.dispatch(UpdateCompany(company: company)),
onSavePressed: (context) {
if (!state.isProPlan && !state.isTrial) {
return;
}
Debouncer.runOnComplete(
() {
final settingsUIState = store.state.uiState.settingsUIState;
switch (settingsUIState.entityType) {
case EntityType.company:
final completer = snackBarCompleter<Null>(
context, AppLocalization.of(context)!.savedSettings);
final oldSubdomain = state.company!.subdomain;
final newSubdomain = settingsUIState.company.subdomain;
if (oldSubdomain != newSubdomain) {
completer.future.then((value) {
showRefreshDataDialog(
context: navigatorKey.currentContext!);
} as FutureOr<Null> Function(Null));
}
store.dispatch(SaveCompanyRequest(
completer: completer, company: settingsUIState.company));
break;
case EntityType.group:
final completer = snackBarCompleter<GroupEntity>(
context, AppLocalization.of(context)!.savedSettings);
store.dispatch(SaveGroupRequest(
completer: completer, group: settingsUIState.group));
break;
case EntityType.client:
final completer = snackBarCompleter<ClientEntity>(
context, AppLocalization.of(context)!.savedSettings);
store.dispatch(SaveClientRequest(
completer: completer, client: settingsUIState.client));
break;
}
},
);
});
}
final AppState state;
final CompanyEntity company;
final SettingsEntity settings;
final Function(BuildContext) onSavePressed;
final Function(CompanyEntity) onCompanyChanged;
final Function(SettingsEntity) onSettingsChanged;
}