//
// SPDX-License-Identifier: AGPL-3.0
-export const formatDate = (isoDate: string) => {
- const date = new Date(isoDate);
- const text = date.toLocaleString();
- return text === 'Invalid Date' ? "" : text;
+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);
+ let text: string;
+ if (utc) {
+ text = date.toUTCString();
+ }
+ else {
+ text = date.toLocaleString();
+ }
+ return text === 'Invalid Date' ? "(none)" : text;
+ }
+ 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";
};
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"
},
{
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 "";
+};