X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/7f2055dd51e545eb9f9998d001ec6badfa9f0bb7..03731a3886079e7056c84b963602a6a57ad1d7ce:/src/common/formatters.ts diff --git a/src/common/formatters.ts b/src/common/formatters.ts index 737ca96f..1fbf1710 100644 --- a/src/common/formatters.ts +++ b/src/common/formatters.ts @@ -2,30 +2,49 @@ // // SPDX-License-Identifier: AGPL-3.0 -export const formatDate = (isoDate?: string | null) => { +import { PropertyValue } from "models/search-bar"; +import { Vocabulary, getTagKeyLabel, getTagValueLabel } from "models/vocabulary"; + +export const formatDate = (isoDate?: string | null, utc: boolean = false) => { if (isoDate) { const date = new Date(isoDate); - const text = date.toLocaleString(); - return text === 'Invalid Date' ? "" : text; + let text: string; + if (utc) { + text = date.toUTCString(); + } + else { + text = date.toLocaleString(); + } + return text === 'Invalid Date' ? "(none)" : text; } - return ""; + 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}`; } } } - return ""; + if ((typeof size === "string" && size === '') || size === undefined) { + return ''; + } + return "0 B"; }; -export const formatTime = (time: number) => { +export const formatTime = (time: number, seconds?: boolean) => { const minutes = Math.floor(time / (1000 * 60) % 60).toFixed(0); const hours = Math.floor(time / (1000 * 60 * 60)).toFixed(0); + if (seconds) { + const seconds = Math.floor(time / (1000) % 60).toFixed(0); + return hours + "h " + minutes + "m " + seconds + "s"; + } + return hours + "h " + minutes + "m"; }; @@ -42,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" }, { @@ -67,3 +87,29 @@ const FILE_SIZES = [ unit: "B" } ]; + +export const formatPropertyValue = (pv: PropertyValue, vocabulary?: Vocabulary) => { + if (vocabulary && pv.keyID && pv.valueID) { + return `${getTagKeyLabel(pv.keyID, vocabulary)}: ${getTagValueLabel(pv.keyID, pv.valueID!, vocabulary)}`; + } + if (pv.key) { + return pv.value + ? `${pv.key}: ${pv.value}` + : pv.key; + } + return ""; +}; + +export const formatContainerCost = (cost: number): string => { + const decimalPlaces = 3; + + const factor = Math.pow(10, decimalPlaces); + const rounded = Math.round(cost*factor)/factor; + if (cost > 0 && rounded === 0) { + // Display min value of 0.001 + return `$${1/factor}`; + } else { + // Otherwise use rounded value to proper decimal places + return `$${rounded}`; + } +};