X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/9e53e34ec65cdd0934aa46465ff4ac758c013529..bcc074c282de71fe63d2ce23127b58f92c90037c:/src/services/collection-service/collection-service-files-response.ts diff --git a/src/services/collection-service/collection-service-files-response.ts b/src/services/collection-service/collection-service-files-response.ts index a4b527a2..5e6f7b83 100644 --- a/src/services/collection-service/collection-service-files-response.ts +++ b/src/services/collection-service/collection-service-files-response.ts @@ -2,16 +2,10 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { createCollectionFilesTree, CollectionDirectory, CollectionFile, CollectionFileType, createCollectionDirectory, createCollectionFile } from "../../models/collection-file"; +import { CollectionDirectory, CollectionFile, CollectionFileType, createCollectionDirectory, createCollectionFile } from "../../models/collection-file"; import { getTagValue } from "~/common/xml"; import { getNodeChildren, Tree, mapTree } from '~/models/tree'; -export const parseFilesResponse = (document: Document) => { - const files = extractFilesData(document); - const tree = createCollectionFilesTree(files); - return sortFilesTree(tree); -}; - export const sortFilesTree = (tree: Tree) => { return mapTree(node => { const children = getNodeChildren(node.id)(tree); @@ -26,7 +20,7 @@ export const sortFilesTree = (tree: Tree) }; export const extractFilesData = (document: Document) => { - const collectionUrlPrefix = /\/c=([0-9a-zA-Z\-]*)/; + const collectionUrlPrefix = /\/c=([^\/]*)/; return Array .from(document.getElementsByTagName('D:response')) .slice(1) // omit first element which is collection itself @@ -41,22 +35,21 @@ export const extractFilesData = (document: Document) => { .replace(collectionUrlPrefix, '') .replace(nameSuffix, ''); - + const parentPath = directory.replace(/\/$/, ''); const data = { url, id: [ collectionUuid ? collectionUuid : '', - directory ? '/' + directory : '', + directory ? parentPath : '', '/' + name ].join(''), name, - path: directory, + path: parentPath, }; return getTagValue(element, 'D:resourcetype', '') ? createCollectionDirectory(data) : createCollectionFile({ ...data, size }); - }); };