- if (resource.isTrashed) {
- dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Restoring from trash..." }));
- return services.groupsService.untrash(resource.uuid).then(() => {
- dispatch<any>(activateSidePanelTreeItem(resource.uuid));
- dispatch(trashPanelActions.REQUEST_ITEMS());
- dispatch(snackbarActions.CLOSE_SNACKBAR());
- dispatch(snackbarActions.OPEN_SNACKBAR({
- message: "Restored from trash",
- hideDuration: 2000
- }));
- });
- } else {
- dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Moving to trash..." }));
- return services.groupsService.trash(resource.uuid).then(() => {
- dispatch<any>(loadSidePanelTreeProjects(resource.ownerUuid!!));
- dispatch(snackbarActions.CLOSE_SNACKBAR());
- dispatch(snackbarActions.OPEN_SNACKBAR({
- message: "Added to trash",
- hideDuration: 2000
- }));
- });
+ let errorMessage = '';
+ let successMessage = '';
+ try {
+ if (isTrashed) {
+ errorMessage = 'Could not restore project from trash';
+ successMessage = 'Restored from trash';
+ await services.groupsService.untrash(uuid);
+ dispatch<any>(isMulti ? navigateToTrash : navigateTo(uuid));
+ dispatch<any>(activateSidePanelTreeItem(uuid));
+ } else {
+ errorMessage = 'Could not move project to trash';
+ successMessage = 'Added to trash';
+ await services.groupsService.trash(uuid);
+ dispatch<any>(loadSidePanelTreeProjects(ownerUuid));
+ dispatch<any>(navigateTo(ownerUuid));
+ }
+ } catch (e) {
+ dispatch(
+ snackbarActions.OPEN_SNACKBAR({
+ message: errorMessage,
+ kind: SnackbarKind.ERROR,
+ })
+ );