X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/d0166a21891dca8719bcedc252a640d1b8037f40..4a24786b1ab2199d3841226eed83be56a83645fc:/src/store/collection-panel/collection-panel-action.ts?ds=sidebyside diff --git a/src/store/collection-panel/collection-panel-action.ts b/src/store/collection-panel/collection-panel-action.ts index 1a23fbe2..ee95590c 100644 --- a/src/store/collection-panel/collection-panel-action.ts +++ b/src/store/collection-panel/collection-panel-action.ts @@ -3,16 +3,17 @@ // SPDX-License-Identifier: AGPL-3.0 import { unionize, ofType, UnionOf } from "unionize"; -import { CommonResourceService } from "../../common/api/common-resource-service"; import { Dispatch } from "redux"; import { ResourceKind } from "../../models/resource"; import { CollectionResource } from "../../models/collection"; +import { collectionPanelFilesAction } from "./collection-panel-files/collection-panel-files-actions"; +import { createTree } from "../../models/tree"; import { RootState } from "../store"; import { ServiceRepository } from "../../services/services"; export const collectionPanelActions = unionize({ LOAD_COLLECTION: ofType<{ uuid: string, kind: ResourceKind }>(), - LOAD_COLLECTION_SUCCESS: ofType<{ item: CollectionResource }>(), + LOAD_COLLECTION_SUCCESS: ofType<{ item: CollectionResource }>() }, { tag: 'type', value: 'payload' }); export type CollectionPanelAction = UnionOf; @@ -20,10 +21,15 @@ export type CollectionPanelAction = UnionOf; export const loadCollection = (uuid: string, kind: ResourceKind) => (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { dispatch(collectionPanelActions.LOAD_COLLECTION({ uuid, kind })); - return new CommonResourceService(services.apiClient, "collections") + 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 })); + return services.collectionFilesService.getFiles(item.uuid); + }) + .then(files => { + dispatch(collectionPanelFilesAction.SET_COLLECTION_FILES(files)); }); };