Support cloning

This commit is contained in:
unknown 2018-08-06 22:49:05 +03:00
parent fd591b691f
commit d6262caeae
4 changed files with 33 additions and 26 deletions

View File

@ -99,7 +99,7 @@ class ClientViewVM {
store.dispatch(UpdateCurrentRoute(ClientScreen.route)), store.dispatch(UpdateCurrentRoute(ClientScreen.route)),
onActionSelected: (BuildContext context, EntityAction action) { onActionSelected: (BuildContext context, EntityAction action) {
final Completer<Null> completer = Completer<Null>(); final Completer<Null> completer = Completer<Null>();
var message = ''; String message;
switch (action) { switch (action) {
case EntityAction.archive: case EntityAction.archive:
store.dispatch(ArchiveClientRequest(completer, client.id)); store.dispatch(ArchiveClientRequest(completer, client.id));
@ -114,10 +114,10 @@ class ClientViewVM {
message = AppLocalization.of(context).successfullyRestoredClient; message = AppLocalization.of(context).successfullyRestoredClient;
break; break;
} }
return completer.future.then((_) { completer.future.then((_) {
if ([EntityAction.archive, EntityAction.delete].contains(action)) { if ([EntityAction.archive, EntityAction.delete].contains(action)) {
Navigator.of(context).pop(message); Navigator.of(context).pop(message);
} else { } else if (message != null){
Scaffold.of(context).showSnackBar(SnackBar( Scaffold.of(context).showSnackBar(SnackBar(
content: SnackBarRow( content: SnackBarRow(
message: message, message: message,

View File

@ -273,6 +273,11 @@ class _CustomAppBar extends StatelessWidget implements PreferredSizeWidget {
), ),
ActionMenuButton( ActionMenuButton(
customActions: [ customActions: [
ActionMenuChoice(
label: localization.clone,
icon: Icons.control_point_duplicate,
action: EntityAction.clone,
),
!invoice.isPublic !invoice.isPublic
? ActionMenuChoice( ? ActionMenuChoice(
action: EntityAction.markSent, action: EntityAction.markSent,

View File

@ -17,6 +17,7 @@ import 'package:url_launcher/url_launcher.dart';
class InvoiceViewScreen extends StatelessWidget { class InvoiceViewScreen extends StatelessWidget {
static const String route = '/invoice/view'; static const String route = '/invoice/view';
const InvoiceViewScreen({Key key}) : super(key: key); const InvoiceViewScreen({Key key}) : super(key: key);
@override @override
@ -152,13 +153,15 @@ class InvoiceViewVM {
store.dispatch(RestoreInvoiceRequest(completer, invoice.id)); store.dispatch(RestoreInvoiceRequest(completer, invoice.id));
message = AppLocalization.of(context).successfullyRestoredInvoice; message = AppLocalization.of(context).successfullyRestoredInvoice;
break; break;
case EntityAction.clone:
store.dispatch(
EditInvoice(context: context, invoice: invoice.clone));
break;
} }
if (message != null) { completer.future.then((_) {
return completer.future.then((_) { if ([EntityAction.archive, EntityAction.delete].contains(action)) {
if ([EntityAction.archive, EntityAction.delete]
.contains(action)) {
Navigator.of(context).pop(message); Navigator.of(context).pop(message);
} else { } else if (message != null) {
Scaffold.of(context).showSnackBar(SnackBar( Scaffold.of(context).showSnackBar(SnackBar(
content: SnackBarRow( content: SnackBarRow(
message: message, message: message,
@ -171,7 +174,6 @@ class InvoiceViewVM {
return ErrorDialog(error); return ErrorDialog(error);
}); });
}); });
}
}); });
} }
} }

View File

@ -92,7 +92,7 @@ class ProductEditVM {
}, },
onActionSelected: (BuildContext context, EntityAction action) { onActionSelected: (BuildContext context, EntityAction action) {
final Completer<Null> completer = Completer<Null>(); final Completer<Null> completer = Completer<Null>();
var message = ''; String message;
switch (action) { switch (action) {
case EntityAction.archive: case EntityAction.archive:
store.dispatch(ArchiveProductRequest(completer, product.id)); store.dispatch(ArchiveProductRequest(completer, product.id));
@ -110,10 +110,10 @@ class ProductEditVM {
store.dispatch(UpdateProduct(product.clone)); store.dispatch(UpdateProduct(product.clone));
break; break;
} }
return completer.future.then((_) { completer.future.then((_) {
if ([EntityAction.archive, EntityAction.delete].contains(action)) { if ([EntityAction.archive, EntityAction.delete].contains(action)) {
Navigator.of(context).pop(message); Navigator.of(context).pop(message);
} else if (message.isNotEmpty) { } else if (message != null) {
Scaffold.of(context).showSnackBar(SnackBar( Scaffold.of(context).showSnackBar(SnackBar(
content: SnackBarRow( content: SnackBarRow(
message: message, message: message,