X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/bcb55ad2005ab4dc8c97624c1f56d410c36d15c2..7b94876543bd53cf2ab676e3f6dab0f9e4fffd3f:/src/common/formatters.ts diff --git a/src/common/formatters.ts b/src/common/formatters.ts index 55fb0507..6d0a7e49 100644 --- a/src/common/formatters.ts +++ b/src/common/formatters.ts @@ -2,8 +2,8 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { PropertyValue } from "~/models/search-bar"; -import { Vocabulary, getTagKeyLabel, getTagValueLabel } from "~/models/vocabulary"; +import { PropertyValue } from "models/search-bar"; +import { Vocabulary, getTagKeyLabel, getTagValueLabel } from "models/vocabulary"; export const formatDate = (isoDate?: string | null, utc: boolean = false) => { if (isoDate) { @@ -20,14 +20,19 @@ export const formatDate = (isoDate?: string | null, utc: boolean = false) => { return "(none)"; }; -export const formatFileSize = (size?: number) => { +export const formatFileSize = (size?: number | string) => { if (typeof size === "number") { + if (size === 0) { return "0 B"; } + for (const { base, unit } of FILE_SIZES) { if (size >= base) { return `${(size / base).toFixed()} ${unit}`; } } } + if ((typeof size === "string" && size === '') || size === undefined) { + return ''; + } return "0 B"; }; @@ -56,24 +61,25 @@ export function formatUploadSpeed(prevLoaded: number, loaded: number, prevTime: const speed = loaded > prevLoaded && currentTime > prevTime ? (loaded - prevLoaded) / (currentTime - prevTime) : 0; - return `${(speed / 1000).toFixed(2)} KB/s`; + + return `${(speed / 1000).toFixed(2)} MB/s`; } const FILE_SIZES = [ { - base: 1000000000000, + base: 1099511627776, unit: "TB" }, { - base: 1000000000, + base: 1073741824, unit: "GB" }, { - base: 1000000, + base: 1048576, unit: "MB" }, { - base: 1000, + base: 1024, unit: "KB" }, {