import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:flutter_redux/flutter_redux.dart'; import 'package:invoiceninja_flutter/data/models/models.dart'; import 'package:invoiceninja_flutter/redux/app/app_state.dart'; import 'package:invoiceninja_flutter/ui/app/dismissible_entity.dart'; import 'package:invoiceninja_flutter/ui/app/entity_state_label.dart'; import 'package:invoiceninja_flutter/utils/formatting.dart'; class ClientListItem extends StatelessWidget { const ClientListItem({ @required this.user, @required this.onEntityAction, @required this.onTap, @required this.onLongPress, //@required this.onCheckboxChanged, @required this.client, @required this.filter, this.onCheckboxChanged, this.isChecked = false, }); final UserEntity user; final Function(EntityAction) onEntityAction; final GestureTapCallback onTap; final GestureTapCallback onLongPress; //final ValueChanged onCheckboxChanged; final ClientEntity client; final String filter; final Function(bool) onCheckboxChanged; final bool isChecked; static final clientItemKey = (int id) => Key('__client_item_${id}__'); @override Widget build(BuildContext context) { //var localization = AppLocalization.of(context); final store = StoreProvider.of(context); final uiState = store.state.uiState; final clientUIState = uiState.clientUIState; final filterMatch = filter != null && filter.isNotEmpty ? client.matchesFilterValue(filter) : null; final listUIState = clientUIState.listUIState; final isInMultiselect = listUIState.isInMultiselect(); final showCheckbox = onCheckboxChanged != null || isInMultiselect; return DismissibleEntity( isSelected: client.id == (uiState.isEditing ? clientUIState.editing.id : clientUIState.selectedId), userCompany: store.state.userCompany, onEntityAction: onEntityAction, entity: client, //entityKey: clientItemKey, child: ListTile( onTap: isInMultiselect ? () => onEntityAction(EntityAction.toggleMultiselect) : onTap, onLongPress: onLongPress, leading: showCheckbox ? IgnorePointer( ignoring: listUIState.isInMultiselect(), child: Checkbox( value: isChecked, materialTapTargetSize: MaterialTapTargetSize.shrinkWrap, onChanged: (value) => onCheckboxChanged(value), activeColor: Theme.of(context).accentColor, ), ) : null, title: Container( width: MediaQuery.of(context).size.width, child: Row( children: [ Expanded( child: Text( client.displayName, style: Theme.of(context).textTheme.title, ), ), Text(formatNumber(client.balance, context, clientId: client.id), style: Theme.of(context).textTheme.title), ], ), ), subtitle: (filterMatch == null && client.isActive) ? null : Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ filterMatch != null ? Text( filterMatch, maxLines: 3, overflow: TextOverflow.ellipsis, ) : SizedBox(), EntityStateLabel(client), ], ), ), ); } }