13858-process-view-information-card
[arvados.git] / src / common / formatters.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 export const formatDate = (isoDate: string) => {
6     const date = new Date(isoDate);
7     const text = date.toLocaleString();
8     return text === 'Invalid Date' ? "" : text;
9 };
10
11 export const formatFileSize = (size?: number) => {
12     if (typeof size === "number") {
13         for (const { base, unit } of FILE_SIZES) {
14             if (size >= base) {
15                 return `${(size / base).toFixed()} ${unit}`;
16             }
17         }
18     }
19     return "";
20 };
21
22 export const formatProgress = (loaded: number, total: number) => {
23     const progress = loaded >= 0 && total > 0 ? loaded * 100 / total : 0;
24     return `${progress.toFixed(2)}%`;
25 };
26
27 export function formatUploadSpeed(prevLoaded: number, loaded: number, prevTime: number, currentTime: number) {
28     const speed = loaded > prevLoaded && currentTime > prevTime
29         ? (loaded - prevLoaded) / (currentTime - prevTime)
30         : 0;
31     return `${(speed / 1000).toFixed(2)} KB/s`;
32 }
33
34 const FILE_SIZES = [
35     {
36         base: 1000000000000,
37         unit: "TB"
38     },
39     {
40         base: 1000000000,
41         unit: "GB"
42     },
43     {
44         base: 1000000,
45         unit: "MB"
46     },
47     {
48         base: 1000,
49         unit: "KB"
50     },
51     {
52         base: 1,
53         unit: "B"
54     }
55 ];