invoice/lib/ui/company_gateway/company_gateway_list.dart

98 lines
4.4 KiB
Dart

import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:flutter_redux/flutter_redux.dart';
import 'package:invoiceninja_flutter/data/models/company_gateway_model.dart';
import 'package:invoiceninja_flutter/data/models/models.dart';
import 'package:invoiceninja_flutter/redux/app/app_state.dart';
import 'package:invoiceninja_flutter/redux/company_gateway/company_gateway_actions.dart';
import 'package:invoiceninja_flutter/ui/app/entities/entity_actions_dialog.dart';
import 'package:invoiceninja_flutter/ui/app/help_text.dart';
import 'package:invoiceninja_flutter/ui/app/loading_indicator.dart';
import 'package:invoiceninja_flutter/ui/company_gateway/company_gateway_list_item.dart';
import 'package:invoiceninja_flutter/ui/company_gateway/company_gateway_list_vm.dart';
import 'package:invoiceninja_flutter/utils/localization.dart';
class CompanyGatewayList extends StatelessWidget {
const CompanyGatewayList({
Key key,
@required this.viewModel,
}) : super(key: key);
final CompanyGatewayListVM viewModel;
@override
Widget build(BuildContext context) {
final store = StoreProvider.of<AppState>(context);
final state = store.state;
final listUIState = state.uiState.companyGatewayUIState.listUIState;
final isInMultiselect = listUIState.isInMultiselect();
void showDialog(CompanyGatewayEntity companyGateway) =>
showEntityActionsDialog(
entities: [companyGateway],
context: context,
);
return Column(
children: <Widget>[
Flexible(
fit: FlexFit.tight,
child: !viewModel.isLoaded
? LoadingIndicator()
: RefreshIndicator(
onRefresh: () => viewModel.onRefreshed(context),
child: viewModel.companyGatewayList.isEmpty
? HelpText(AppLocalization.of(context).noRecordsFound)
: ReorderableListView(
onReorder: (oldIndex, newIndex) {
// https://stackoverflow.com/a/54164333/497368
// These two lines are workarounds for ReorderableListView problems
if (newIndex >
viewModel.companyGatewayList.length) {
newIndex = viewModel.companyGatewayList.length;
}
if (oldIndex < newIndex) {
newIndex--;
}
viewModel.onSortChanged(oldIndex, newIndex);
},
children: viewModel.companyGatewayList
.map((companyGatewayId) {
final companyGateway =
viewModel.companyGatewayMap[companyGatewayId];
return CompanyGatewayListItem(
key: ValueKey(
'__company_gateway_$companyGatewayId'),
user: viewModel.userCompany.user,
filter: viewModel.filter,
companyGateway: companyGateway,
onTap: () => viewModel.onCompanyGatewayTap(
context, companyGateway),
onRemovePressed:
viewModel.state.settingsUIState.isFiltered
? () => viewModel
.onRemovePressed(companyGatewayId)
: null,
onEntityAction: (EntityAction action) {
if (action == EntityAction.more) {
showDialog(companyGateway);
} else {
handleCompanyGatewayAction(
context, [companyGateway], action);
}
},
isChecked: isInMultiselect &&
listUIState.isSelected(companyGateway.id));
}).toList(),
),
),
),
Expanded(
child: SizedBox(),
),
],
);
}
}