projects
/
arvados-workbench2.git
/ blobdiff
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Introduce service repository
[arvados-workbench2.git]
/
src
/
store
/
favorites
/
favorites-actions.ts
diff --git
a/src/store/favorites/favorites-actions.ts
b/src/store/favorites/favorites-actions.ts
index 225c9b35c36ce934721c1c10f5cb2883a15e4594..38229dff8390424fd26686da2158d6f59b22ceea 100644
(file)
--- a/
src/store/favorites/favorites-actions.ts
+++ b/
src/store/favorites/favorites-actions.ts
@@
-4,9
+4,10
@@
import { unionize, ofType, UnionOf } from "unionize";
import { Dispatch } from "redux";
import { unionize, ofType, UnionOf } from "unionize";
import { Dispatch } from "redux";
-import { favoriteService } from "../../services/services";
import { RootState } from "../store";
import { checkFavorite } from "./favorites-reducer";
import { RootState } from "../store";
import { checkFavorite } from "./favorites-reducer";
+import { snackbarActions } from "../snackbar/snackbar-actions";
+import { ServiceRepository } from "../../services/services";
export const favoritesActions = unionize({
TOGGLE_FAVORITE: ofType<{ resourceUuid: string }>(),
export const favoritesActions = unionize({
TOGGLE_FAVORITE: ofType<{ resourceUuid: string }>(),
@@
-17,27
+18,35
@@
export const favoritesActions = unionize({
export type FavoritesAction = UnionOf<typeof favoritesActions>;
export const toggleFavorite = (resource: { uuid: string; name: string }) =>
export type FavoritesAction = UnionOf<typeof favoritesActions>;
export const toggleFavorite = (resource: { uuid: string; name: string }) =>
- (dispatch: Dispatch, getState: () => RootState
)
=> {
+ (dispatch: Dispatch, getState: () => RootState
, services: ServiceRepository): Promise<any>
=> {
const userUuid = getState().auth.user!.uuid;
dispatch(favoritesActions.TOGGLE_FAVORITE({ resourceUuid: resource.uuid }));
const userUuid = getState().auth.user!.uuid;
dispatch(favoritesActions.TOGGLE_FAVORITE({ resourceUuid: resource.uuid }));
+ dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Working..." }));
const isFavorite = checkFavorite(resource.uuid, getState().favorites);
const isFavorite = checkFavorite(resource.uuid, getState().favorites);
- const promise = isFavorite
- ? favoriteService.delete({ userUuid, resourceUuid: resource.uuid })
- : favoriteService.create({ userUuid, resource });
+ const promise
: any
= isFavorite
+ ?
services.
favoriteService.delete({ userUuid, resourceUuid: resource.uuid })
+ :
services.
favoriteService.create({ userUuid, resource });
- promise
- .then(
fav
=> {
+
return
promise
+ .then(
()
=> {
dispatch(favoritesActions.UPDATE_FAVORITES({ [resource.uuid]: !isFavorite }));
dispatch(favoritesActions.UPDATE_FAVORITES({ [resource.uuid]: !isFavorite }));
+ dispatch(snackbarActions.CLOSE_SNACKBAR());
+ dispatch(snackbarActions.OPEN_SNACKBAR({
+ message: isFavorite
+ ? "Removed from favorites"
+ : "Added to favorites",
+ hideDuration: 2000
+ }));
});
};
export const checkPresenceInFavorites = (resourceUuids: string[]) =>
});
};
export const checkPresenceInFavorites = (resourceUuids: string[]) =>
- (dispatch: Dispatch, getState: () => RootState) => {
+ (dispatch: Dispatch, getState: () => RootState
, services: ServiceRepository
) => {
const userUuid = getState().auth.user!.uuid;
dispatch(favoritesActions.CHECK_PRESENCE_IN_FAVORITES(resourceUuids));
const userUuid = getState().auth.user!.uuid;
dispatch(favoritesActions.CHECK_PRESENCE_IN_FAVORITES(resourceUuids));
- favoriteService
+
services.
favoriteService
.checkPresenceInFavorites(userUuid, resourceUuids)
.checkPresenceInFavorites(userUuid, resourceUuids)
- .then(
results
=> {
+ .then(
(results: any)
=> {
dispatch(favoritesActions.UPDATE_FAVORITES(results));
});
};
dispatch(favoritesActions.UPDATE_FAVORITES(results));
});
};