invoice/lib/redux/client/client_actions.dart

416 lines
9.9 KiB
Dart

import 'dart:async';
import 'package:built_collection/built_collection.dart';
import 'package:flutter/widgets.dart';
import 'package:flutter_redux/flutter_redux.dart';
import 'package:invoiceninja_flutter/data/models/models.dart';
import 'package:invoiceninja_flutter/redux/app/app_actions.dart';
import 'package:invoiceninja_flutter/redux/app/app_state.dart';
import 'package:invoiceninja_flutter/utils/completers.dart';
import 'package:invoiceninja_flutter/utils/localization.dart';
import 'package:invoiceninja_flutter/utils/platforms.dart';
class ViewClientList extends AbstractNavigatorAction implements PersistUI {
ViewClientList({
@required NavigatorState navigator,
this.force = false,
}) : super(navigator: navigator);
final bool force;
}
class ViewClient extends AbstractNavigatorAction
implements PersistUI, PersistPrefs {
ViewClient({
@required NavigatorState navigator,
@required this.clientId,
this.force = false,
}) : super(navigator: navigator);
final String clientId;
final bool force;
}
class EditClient extends AbstractNavigatorAction
implements PersistUI, PersistPrefs {
EditClient(
{@required this.client,
@required NavigatorState navigator,
this.contact,
this.completer,
this.cancelCompleter,
this.force = false})
: super(navigator: navigator);
final ClientEntity client;
final ContactEntity contact;
final Completer completer;
final Completer cancelCompleter;
final bool force;
}
class EditContact implements PersistUI {
EditContact([this.contact]);
final ContactEntity contact;
}
class UpdateClient implements PersistUI {
UpdateClient(this.client);
final ClientEntity client;
}
class LoadClient {
LoadClient({this.completer, this.clientId, this.loadActivities = false});
final Completer completer;
final String clientId;
final bool loadActivities;
}
class LoadClientActivity {
LoadClientActivity({this.completer, this.clientId});
final Completer completer;
final String clientId;
}
class LoadClients {
LoadClients({this.completer, this.force = false});
final Completer completer;
final bool force;
}
class LoadClientRequest implements StartLoading {}
class LoadClientFailure implements StopLoading {
LoadClientFailure(this.error);
final dynamic error;
@override
String toString() {
return 'LoadClientFailure{error: $error}';
}
}
class LoadClientSuccess implements StopLoading, PersistData {
LoadClientSuccess(this.client);
final ClientEntity client;
@override
String toString() {
return 'LoadClientSuccess{client: $client}';
}
}
class LoadClientsRequest implements StartLoading {}
class LoadClientsFailure implements StopLoading {
LoadClientsFailure(this.error);
final dynamic error;
@override
String toString() {
return 'LoadClientsFailure{error: $error}';
}
}
class LoadClientsSuccess implements StopLoading, PersistData {
LoadClientsSuccess(this.clients);
final BuiltList<ClientEntity> clients;
@override
String toString() {
return 'LoadClientsSuccess{clients: $clients}';
}
}
class AddContact implements PersistUI {
AddContact([this.contact]);
final ContactEntity contact;
}
class UpdateContact implements PersistUI {
UpdateContact({this.index, this.contact});
final int index;
final ContactEntity contact;
}
class DeleteContact implements PersistUI {
DeleteContact(this.index);
final int index;
}
class SaveClientRequest implements StartSaving {
SaveClientRequest({this.completer, this.client});
final Completer completer;
final ClientEntity client;
}
class SaveClientSuccess implements StopSaving, PersistData, PersistUI {
SaveClientSuccess(this.client);
final ClientEntity client;
}
class AddClientSuccess implements StopSaving, PersistData, PersistUI {
AddClientSuccess(this.client);
final ClientEntity client;
}
class SaveClientFailure implements StopSaving {
SaveClientFailure(this.error);
final Object error;
}
class ArchiveClientRequest implements StartSaving {
ArchiveClientRequest(this.completer, this.clientIds);
final Completer completer;
final List<String> clientIds;
}
class ArchiveClientSuccess implements StopSaving, PersistData {
ArchiveClientSuccess(this.clients);
final List<ClientEntity> clients;
}
class ArchiveClientFailure implements StopSaving {
ArchiveClientFailure(this.clients);
final List<ClientEntity> clients;
}
class DeleteClientRequest implements StartSaving {
DeleteClientRequest(this.completer, this.clientIds);
final Completer completer;
final List<String> clientIds;
}
class DeleteClientSuccess implements StopSaving, PersistData {
DeleteClientSuccess(this.clients);
final List<ClientEntity> clients;
}
class DeleteClientFailure implements StopSaving {
DeleteClientFailure(this.clients);
final List<ClientEntity> clients;
}
class RestoreClientRequest implements StartSaving {
RestoreClientRequest(this.completer, this.clientIds);
final Completer completer;
final List<String> clientIds;
}
class RestoreClientSuccess implements StopSaving, PersistData {
RestoreClientSuccess(this.clients);
final List<ClientEntity> clients;
}
class RestoreClientFailure implements StopSaving {
RestoreClientFailure(this.clients);
final List<ClientEntity> clients;
}
class FilterClients implements PersistUI {
FilterClients(this.filter);
final String filter;
}
class SortClients implements PersistUI {
SortClients(this.field);
final String field;
}
class FilterClientsByEntity implements PersistUI {
FilterClientsByEntity({this.entityId, this.entityType});
final String entityId;
final EntityType entityType;
}
class FilterClientsByState implements PersistUI {
FilterClientsByState(this.state);
final EntityState state;
}
class FilterClientsByCustom1 implements PersistUI {
FilterClientsByCustom1(this.value);
final String value;
}
class FilterClientsByCustom2 implements PersistUI {
FilterClientsByCustom2(this.value);
final String value;
}
class FilterClientsByCustom3 implements PersistUI {
FilterClientsByCustom3(this.value);
final String value;
}
class FilterClientsByCustom4 implements PersistUI {
FilterClientsByCustom4(this.value);
final String value;
}
void handleClientAction(
BuildContext context, List<BaseEntity> clients, EntityAction action) {
assert(
[
EntityAction.restore,
EntityAction.archive,
EntityAction.delete,
EntityAction.toggleMultiselect
].contains(action) ||
clients.length <= 1,
'Cannot perform this action on more than one client');
if (clients.isEmpty) {
return;
}
final store = StoreProvider.of<AppState>(context);
final state = store.state;
final localization = AppLocalization.of(context);
final clientIds = clients.map((client) => client.id).toList();
final client = clients[0];
switch (action) {
case EntityAction.edit:
editEntity(context: context, entity: client);
break;
case EntityAction.newInvoice:
if (isNotMobile(context)) {
filterEntitiesByType(
context: context,
entityType: EntityType.invoice,
filterEntity: client);
}
createEntity(
context: context,
entity: InvoiceEntity(state: state, client: client));
break;
case EntityAction.newQuote:
if (isNotMobile(context)) {
filterEntitiesByType(
context: context,
entityType: EntityType.quote,
filterEntity: client);
}
createEntity(
context: context,
entity: InvoiceEntity(state: state, client: client, isQuote: true));
break;
case EntityAction.newExpense:
if (isNotMobile(context)) {
filterEntitiesByType(
context: context,
entityType: EntityType.expense,
filterEntity: client);
}
createEntity(
context: context,
entity: ExpenseEntity(state: state, client: client));
break;
case EntityAction.newPayment:
if (isNotMobile(context)) {
filterEntitiesByType(
context: context,
entityType: EntityType.payment,
filterEntity: client);
}
createEntity(
context: context,
entity: PaymentEntity(state: state)
.rebuild((b) => b.clientId = client.id));
break;
case EntityAction.newProject:
if (isNotMobile(context)) {
filterEntitiesByType(
context: context,
entityType: EntityType.project,
filterEntity: client);
}
createEntity(
context: context,
entity: ProjectEntity(state: state)
.rebuild((b) => b.clientId = client.id));
break;
case EntityAction.restore:
store.dispatch(RestoreClientRequest(
snackBarCompleter<Null>(context, localization.restoredClient),
clientIds));
break;
case EntityAction.archive:
store.dispatch(ArchiveClientRequest(
snackBarCompleter<Null>(context, localization.archivedClient),
clientIds));
break;
case EntityAction.delete:
store.dispatch(DeleteClientRequest(
snackBarCompleter<Null>(context, localization.deletedClient),
clientIds));
break;
case EntityAction.toggleMultiselect:
if (!store.state.clientListState.isInMultiselect()) {
store.dispatch(StartClientMultiselect());
}
if (clients.isEmpty) {
break;
}
for (final client in clients) {
if (!state.clientListState.isSelected(client.id)) {
store.dispatch(AddToClientMultiselect(entity: client));
} else {
store.dispatch(RemoveFromClientMultiselect(entity: client));
}
}
break;
}
}
class StartClientMultiselect {}
class AddToClientMultiselect {
AddToClientMultiselect({@required this.entity});
final BaseEntity entity;
}
class RemoveFromClientMultiselect {
RemoveFromClientMultiselect({@required this.entity});
final BaseEntity entity;
}
class ClearClientMultiselect {}