// 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( 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 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( AppLocalization.of(context)!.savedSettings); final oldSubdomain = state.company.subdomain; final newSubdomain = settingsUIState.company.subdomain; if (oldSubdomain != newSubdomain) { completer.future.then((_) { showRefreshDataDialog( context: navigatorKey.currentContext!); }); } store.dispatch(SaveCompanyRequest( completer: completer, company: settingsUIState.company)); break; case EntityType.group: final completer = snackBarCompleter( AppLocalization.of(context)!.savedSettings); store.dispatch(SaveGroupRequest( completer: completer, group: settingsUIState.group)); break; case EntityType.client: final completer = snackBarCompleter( 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; }