import 'dart:async'; import 'package:invoiceninja_flutter/ui/app/snackbar_row.dart'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:invoiceninja_flutter/redux/ui/ui_actions.dart'; import 'package:invoiceninja_flutter/utils/completers.dart'; import 'package:invoiceninja_flutter/ui/design/design_screen.dart'; import 'package:invoiceninja_flutter/utils/localization.dart'; import 'package:redux/redux.dart'; import 'package:flutter_redux/flutter_redux.dart'; import 'package:invoiceninja_flutter/redux/design/design_actions.dart'; import 'package:invoiceninja_flutter/data/models/design_model.dart'; import 'package:invoiceninja_flutter/data/models/models.dart'; import 'package:invoiceninja_flutter/ui/design/view/design_view.dart'; import 'package:invoiceninja_flutter/redux/app/app_state.dart'; class DesignViewScreen extends StatelessWidget { const DesignViewScreen({Key key}) : super(key: key); static const String route = '/design/view'; @override Widget build(BuildContext context) { return StoreConnector( converter: (Store store) { return DesignViewVM.fromStore(store); }, builder: (context, vm) { return DesignView( viewModel: vm, ); }, ); } } class DesignViewVM { DesignViewVM({ @required this.state, @required this.design, @required this.company, @required this.onEntityAction, @required this.onRefreshed, @required this.isSaving, @required this.isLoading, @required this.isDirty, }); factory DesignViewVM.fromStore(Store store) { final state = store.state; final design = state.designState.map[state.designUIState.selectedId] ?? DesignEntity(id: state.designUIState.selectedId); Future _handleRefresh(BuildContext context) { final completer = snackBarCompleter( context, AppLocalization.of(context).refreshComplete); store.dispatch(LoadDesign(completer: completer, designId: design.id)); return completer.future; } return DesignViewVM( state: state, company: state.selectedCompany, isSaving: state.isSaving, isLoading: state.isLoading, isDirty: design.isNew, design: design, onRefreshed: (context) => _handleRefresh(context), onEntityAction: (BuildContext context, EntityAction action) => handleDesignAction(context, design, action), ); } final AppState state; final DesignEntity design; final CompanyEntity company; final Function(BuildContext, EntityAction) onEntityAction; final Function(BuildContext) onRefreshed; final bool isSaving; final bool isLoading; final bool isDirty; }