import { unionize, ofType, UnionOf } from "unionize";
import { Dispatch } from "../../../node_modules/redux";
import { favoriteService } from "../../services/services";
+import { RootState } from "../store";
+import { checkFavorite } from "./favorites-reducer";
export const favoritesActions = unionize({
+ TOGGLE_FAVORITE: ofType<{ resourceUuid: string }>(),
CHECK_PRESENCE_IN_FAVORITES: ofType<string[]>(),
UPDATE_FAVORITES: ofType<Record<string, boolean>>()
}, { tag: 'type', value: 'payload' });
export type FavoritesAction = UnionOf<typeof favoritesActions>;
-export const checkPresenceInFavorites = (userUuid: string, resourceUuids: string[]) =>
- (dispatch: Dispatch) => {
+export const toggleFavorite = (resourceUuid: string) =>
+ (dispatch: Dispatch, getState: () => RootState) => {
+ const userUuid = getState().auth.user!.uuid;
+ dispatch(favoritesActions.TOGGLE_FAVORITE({ resourceUuid }));
+ const isFavorite = checkFavorite(resourceUuid, getState().favorites);
+ const promise = isFavorite
+ ? favoriteService.delete({ userUuid, resourceUuid })
+ : favoriteService.create({ userUuid, resourceUuid });
+
+ promise
+ .then(fav => {
+ dispatch(favoritesActions.UPDATE_FAVORITES({ [resourceUuid]: !isFavorite }));
+ });
+ };
+
+export const checkPresenceInFavorites = (resourceUuids: string[]) =>
+ (dispatch: Dispatch, getState: () => RootState) => {
+ const userUuid = getState().auth.user!.uuid;
dispatch(favoritesActions.CHECK_PRESENCE_IN_FAVORITES(resourceUuids));
favoriteService
.checkPresenceInFavorites(userUuid, resourceUuids)
.addEqual("ownerUuid", parentUuid)
}).then(({ items: projects }) => {
dispatch(projectActions.PROJECTS_SUCCESS({ projects, parentItemId: parentUuid }));
- const { user } = getState().auth;
- dispatch<any>(checkPresenceInFavorites(user ? user.uuid : "", projects.map(project => project.uuid)));
+ dispatch<any>(checkPresenceInFavorites(projects.map(project => project.uuid)));
return projects;
});
};
import { projectActions } from "../../../store/project/project-action";
import { ShareIcon, NewProjectIcon } from "../../../components/icon/icon";
import { FavoriteActionText, FavoriteActionIcon } from "./favorite-action";
+import { favoritesActions, toggleFavorite } from "../../../store/favorites/favorites-actions";
export const projectActionSet: ContextMenuActionSet = [[{
icon: NewProjectIcon,
}, {
name: FavoriteActionText,
icon: FavoriteActionIcon,
- execute: (dispatch, resource) => { alert(resource); }
+ execute: (dispatch, resource) => {
+ dispatch<any>(toggleFavorite(resource.uuid));
+ }
}]];