X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/75db1e88374315f84fdfb30faee84253e1383a28..5f254216d287fe601863e113508110e0c6245e3d:/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 b8a7970d..1a4f990c 100644 --- a/src/services/collection-service/collection-service-files-response.ts +++ b/src/services/collection-service/collection-service-files-response.ts @@ -26,7 +26,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 @@ -35,13 +35,20 @@ export const extractFilesData = (document: Document) => { const size = parseInt(getTagValue(element, 'D:getcontentlength', '0'), 10); const url = getTagValue(element, 'D:href', ''); const nameSuffix = `/${name || ''}`; + const collectionUuidMatch = collectionUrlPrefix.exec(url); + const collectionUuid = collectionUuidMatch ? collectionUuidMatch.pop() : ''; const directory = url .replace(collectionUrlPrefix, '') .replace(nameSuffix, ''); + const data = { url, - id: `${directory}/${name}`, + id: [ + collectionUuid ? collectionUuid : '', + directory ? '/' + directory : '', + '/' + name + ].join(''), name, path: directory, }; @@ -52,3 +59,6 @@ export const extractFilesData = (document: Document) => { }); }; + +export const getFileFullPath = ({ name, path }: CollectionFile | CollectionDirectory) => + `${path}/${name}`;