X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/2e60bb998178752c3a126f077cbb891b597ed91e..2ddeeb1b278734e895128feb2caa2bf720192b3d:/src/store/collection-panel/collection-panel-action.ts diff --git a/src/store/collection-panel/collection-panel-action.ts b/src/store/collection-panel/collection-panel-action.ts index 083e548c9e..461c47c42e 100644 --- a/src/store/collection-panel/collection-panel-action.ts +++ b/src/store/collection-panel/collection-panel-action.ts @@ -6,28 +6,37 @@ import { unionize, ofType, UnionOf } from "unionize"; import { Dispatch } from "redux"; import { ResourceKind } from "../../models/resource"; import { CollectionResource } from "../../models/collection"; +import { collectionPanelFilesAction, loadCollectionFiles } from "./collection-panel-files/collection-panel-files-actions"; +import { createTree } from "../../models/tree"; import { RootState } from "../store"; import { ServiceRepository } from "../../services/services"; -import { LinkClass, LinkResource } from "../../models/link"; +import { TagResource, TagProperty } from "../../models/tag"; +import { snackbarActions } from "../snackbar/snackbar-actions"; export const collectionPanelActions = unionize({ - LOAD_COLLECTION: ofType<{ uuid: string, kind: ResourceKind }>(), + LOAD_COLLECTION: ofType<{ uuid: string }>(), LOAD_COLLECTION_SUCCESS: ofType<{ item: CollectionResource }>(), LOAD_COLLECTION_TAGS: ofType<{ uuid: string }>(), - LOAD_COLLECTION_TAGS_SUCCESS: ofType<{ tags: LinkResource[] }>(), + LOAD_COLLECTION_TAGS_SUCCESS: ofType<{ tags: TagResource[] }>(), CREATE_COLLECTION_TAG: ofType<{ data: any }>(), - CREATE_COLLECTION_TAG_SUCCESS: ofType<{ tag: LinkResource }>() + CREATE_COLLECTION_TAG_SUCCESS: ofType<{ tag: TagResource }>(), + DELETE_COLLECTION_TAG: ofType<{ uuid: string }>(), + DELETE_COLLECTION_TAG_SUCCESS: ofType<{ uuid: string }>() }, { tag: 'type', value: 'payload' }); export type CollectionPanelAction = UnionOf; -export const loadCollection = (uuid: string, kind: ResourceKind) => +export const COLLECTION_TAG_FORM_NAME = 'collectionTagForm'; + +export const loadCollection = (uuid: string) => (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { - dispatch(collectionPanelActions.LOAD_COLLECTION({ uuid, kind })); + dispatch(collectionPanelActions.LOAD_COLLECTION({ uuid })); + dispatch(collectionPanelFilesAction.SET_COLLECTION_FILES({ files: createTree() })); return services.collectionService .get(uuid) .then(item => { - dispatch(collectionPanelActions.LOAD_COLLECTION_SUCCESS({ item: item as CollectionResource })); + dispatch(collectionPanelActions.LOAD_COLLECTION_SUCCESS({ item })); + dispatch(loadCollectionFiles(uuid)); }); }; @@ -42,18 +51,32 @@ export const loadCollectionTags = (uuid: string) => }; -export const createCollectionTag = (uuid: string, data: {}) => +export const createCollectionTag = (data: TagProperty) => (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { - const linkResource = { - key: 'testowanie', - value: 'by Arturo' - }; - - dispatch(collectionPanelActions.CREATE_COLLECTION_TAG({ data: linkResource })); + dispatch(collectionPanelActions.CREATE_COLLECTION_TAG({ data })); + const item = getState().collectionPanel.item; + const uuid = item ? item.uuid : ''; return services.tagService - .create(uuid, linkResource) + .create(uuid, data) .then(tag => { - console.log('tag: ', tag); dispatch(collectionPanelActions.CREATE_COLLECTION_TAG_SUCCESS({ tag })); + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: "Tag has been successfully added.", + hideDuration: 2000 + })); }); }; + +export const deleteCollectionTag = (uuid: string) => + (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + dispatch(collectionPanelActions.DELETE_COLLECTION_TAG({ uuid })); + return services.linkService + .delete(uuid) + .then(tag => { + dispatch(collectionPanelActions.DELETE_COLLECTION_TAG_SUCCESS({ uuid: tag.uuid })); + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: "Tag has been successfully deleted.", + hideDuration: 2000 + })); + }); + }; \ No newline at end of file