import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:invoiceninja_flutter/data/models/entities.dart'; import 'package:invoiceninja_flutter/redux/app/app_actions.dart'; import 'package:invoiceninja_flutter/redux/ui/pref_state.dart'; import 'package:invoiceninja_flutter/ui/app/entities/entity_actions_dialog.dart'; import 'package:invoiceninja_flutter/ui/app/live_text.dart'; import 'package:timeago/timeago.dart' as timeago; import 'package:flutter_redux/flutter_redux.dart'; import 'package:invoiceninja_flutter/redux/app/app_state.dart'; import 'package:invoiceninja_flutter/ui/app/history_drawer_vm.dart'; import 'package:invoiceninja_flutter/utils/icons.dart'; import 'package:invoiceninja_flutter/utils/localization.dart'; class HistoryDrawer extends StatelessWidget { const HistoryDrawer({ Key key, @required this.viewModel, }) : super(key: key); final AppDrawerVM viewModel; @override Widget build(BuildContext context) { final localization = AppLocalization.of(context); final store = StoreProvider.of(context); final state = store.state; final widgets = []; for (var history in state.uiState.historyList) { if (widgets.length > 50) { break; } final entity = state.getEntityMap(history.entityType)[history.id] as BaseEntity; if (entity == null || entity.isDeleted) { continue; } widgets.add(ListTile( key: ValueKey('__${history.id}_${history.entityType}__'), leading: Icon(getEntityIcon(history.entityType)), title: Text(entity.listDisplayName), subtitle: Text(localization.lookup('${history.entityType}')), // TODO this needs to be localized trailing: LiveText( () => timeago.format(history.dateTime, locale: 'en_short'), duration: Duration(minutes: 1), ), onTap: () => viewEntityById( context: context, entityId: history.id, entityType: history.entityType), onLongPress: () => showEntityActionsDialog( context: context, entities: [entity], ), )); } return Drawer( child: Scaffold( appBar: AppBar( automaticallyImplyLeading: false, title: Text(localization.history), actions: [ if (state.uiState.isHistoryFloated) Builder( builder: (context) => IconButton( icon: Icon(Icons.menu), onPressed: () { Navigator.pop(context); }, ), ) else FlatButton( child: Text( localization.close, style: TextStyle(color: Colors.white), ), onPressed: () { store.dispatch( UserSettingsChanged(sidebar: AppSidebar.history)); }, ) ], ), body: ListView( children: widgets, ), ), ); } }