X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/9be874f7744b5ceb53f4be20d1748db34859468a..eadb2e4a0005b89cb2ca1977bb6f53652e911249:/src/services/collection-service/collection-service-files-response.ts?ds=sidebyside diff --git a/src/services/collection-service/collection-service-files-response.ts b/src/services/collection-service/collection-service-files-response.ts index 2e726d0b..6f8b3de3 100644 --- a/src/services/collection-service/collection-service-files-response.ts +++ b/src/services/collection-service/collection-service-files-response.ts @@ -5,6 +5,7 @@ import { CollectionDirectory, CollectionFile, CollectionFileType, createCollectionDirectory, createCollectionFile } from "../../models/collection-file"; import { getTagValue } from "~/common/xml"; import { getNodeChildren, Tree, mapTree } from '~/models/tree'; +import { escapeHashIfRequired } from "~/common/url"; export const sortFilesTree = (tree: Tree) => { return mapTree(node => { @@ -28,7 +29,7 @@ export const extractFilesData = (document: Document) => { const name = getTagValue(element, 'D:displayname', ''); const size = parseInt(getTagValue(element, 'D:getcontentlength', '0'), 10); const url = getTagValue(element, 'D:href', ''); - const nameSuffix = `/${name || ''}`; + const nameSuffix = `/${escapeHashIfRequired(name) || ''}`; const collectionUuidMatch = collectionUrlPrefix.exec(url); const collectionUuid = collectionUuidMatch ? collectionUuidMatch.pop() : ''; const directory = url @@ -50,9 +51,9 @@ export const extractFilesData = (document: Document) => { return getTagValue(element, 'D:resourcetype', '') ? createCollectionDirectory(data) : createCollectionFile({ ...data, size }); - }); }; -export const getFileFullPath = ({ name, path }: CollectionFile | CollectionDirectory) => - `${path}/${name}`; +export const getFileFullPath = ({ name, path }: CollectionFile | CollectionDirectory) => { + return `${path}/${name}`; +}; \ No newline at end of file