X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/e13e7dd672160e4ab5569c24133f4f6032db4a9a..e09a9e644ad7937bb3800ca8096f444f6ff4411b:/src/store/favorites/favorites-actions.ts diff --git a/src/store/favorites/favorites-actions.ts b/src/store/favorites/favorites-actions.ts index 9e1b3ef1..da454ed7 100644 --- a/src/store/favorites/favorites-actions.ts +++ b/src/store/favorites/favorites-actions.ts @@ -2,27 +2,43 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { unionize, ofType, UnionOf } from "unionize"; +import { unionize, ofType, UnionOf } from "common/unionize"; import { Dispatch } from "redux"; import { RootState } from "../store"; +import { getUserUuid } from "common/getuser"; import { checkFavorite } from "./favorites-reducer"; -import { snackbarActions } from "../snackbar/snackbar-actions"; -import { ServiceRepository } from "~/services/services"; +import { snackbarActions, SnackbarKind } from "../snackbar/snackbar-actions"; +import { ServiceRepository } from "services/services"; +import { progressIndicatorActions } from "store/progress-indicator/progress-indicator-actions"; +import { MultiSelectMenuActionNames } from "views-components/multiselect-toolbar/ms-menu-actions"; +import { addDisabledButton, removeDisabledButton } from "store/multiselect/multiselect-actions"; +import { loadFavoritesTree} from "store/side-panel-tree/side-panel-tree-actions"; export const favoritesActions = unionize({ TOGGLE_FAVORITE: ofType<{ resourceUuid: string }>(), CHECK_PRESENCE_IN_FAVORITES: ofType(), UPDATE_FAVORITES: ofType>() -}, { tag: 'type', value: 'payload' }); +}); export type FavoritesAction = UnionOf; export const toggleFavorite = (resource: { uuid: string; name: string }) => (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository): Promise => { - const userUuid = getState().auth.user!.uuid; + const userUuid = getUserUuid(getState()); + if (!userUuid) { + return Promise.reject("No user"); + } + dispatch(progressIndicatorActions.START_WORKING("toggleFavorite")); + dispatch(addDisabledButton(MultiSelectMenuActionNames.ADD_TO_FAVORITES)) dispatch(favoritesActions.TOGGLE_FAVORITE({ resourceUuid: resource.uuid })); - dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Working..." })); const isFavorite = checkFavorite(resource.uuid, getState().favorites); + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: isFavorite + ? "Removing from favorites..." + : "Adding to favorites...", + kind: SnackbarKind.INFO + })); + const promise: any = isFavorite ? services.favoriteService.delete({ userUuid, resourceUuid: resource.uuid }) : services.favoriteService.create({ userUuid, resource }); @@ -35,14 +51,23 @@ export const toggleFavorite = (resource: { uuid: string; name: string }) => message: isFavorite ? "Removed from favorites" : "Added to favorites", - hideDuration: 2000 + hideDuration: 2000, + kind: SnackbarKind.SUCCESS })); + dispatch(removeDisabledButton(MultiSelectMenuActionNames.ADD_TO_FAVORITES)) + dispatch(progressIndicatorActions.STOP_WORKING("toggleFavorite")); + dispatch(loadFavoritesTree()) + }) + .catch((e: any) => { + dispatch(progressIndicatorActions.STOP_WORKING("toggleFavorite")); + throw e; }); }; -export const checkPresenceInFavorites = (resourceUuids: string[]) => +export const updateFavorites = (resourceUuids: string[]) => (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { - const userUuid = getState().auth.user!.uuid; + const userUuid = getUserUuid(getState()); + if (!userUuid) { return; } dispatch(favoritesActions.CHECK_PRESENCE_IN_FAVORITES(resourceUuids)); services.favoriteService .checkPresenceInFavorites(userUuid, resourceUuids) @@ -50,4 +75,3 @@ export const checkPresenceInFavorites = (resourceUuids: string[]) => dispatch(favoritesActions.UPDATE_FAVORITES(results)); }); }; -