X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/e13e7dd672160e4ab5569c24133f4f6032db4a9a..f45dd93f467fe02c33908c0b4b3ff8ba01827bc9:/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 4545096f7a..581a6fa661 100644 --- a/src/services/collection-service/collection-service-files-response.ts +++ b/src/services/collection-service/collection-service-files-response.ts @@ -14,14 +14,17 @@ export const parseFilesResponse = (document: Document) => { export const sortFilesTree = (tree: Tree) => { return mapTree(node => { - const children = getNodeChildren(node.id)(tree).map(id => getNode(id)(tree)) as TreeNode[]; + const children = getNodeChildren(node.id)(tree) + .map(id => getNode(id)(tree)) + .filter(node => node !== undefined) as TreeNode[]; + children.sort((a, b) => a.value.type !== b.value.type ? a.value.type === CollectionFileType.DIRECTORY ? -1 : 1 : a.value.name.localeCompare(b.value.name) ); - return { ...node, children: children.map(child => child.id) } as TreeNode; - })(tree); + return { ...node, children: children.map(child => child.id) }; + })(tree) as Tree; }; export const extractFilesData = (document: Document) => { @@ -32,14 +35,14 @@ export const extractFilesData = (document: Document) => { .map(element => { const name = getTagValue(element, 'D:displayname', ''); const size = parseInt(getTagValue(element, 'D:getcontentlength', '0'), 10); - const pathname = getTagValue(element, 'D:href', ''); + const url = getTagValue(element, 'D:href', ''); const nameSuffix = `/${name || ''}`; - const directory = pathname + const directory = url .replace(collectionUrlPrefix, '') .replace(nameSuffix, ''); const data = { - url: pathname, + url, id: `${directory}/${name}`, name, path: directory,