Extract float-input component
[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     if (isoDate) {
7         const date = new Date(isoDate);
8         const text = date.toLocaleString();
9         return text === 'Invalid Date' ? "" : text;
10     }
11     return "";
12 };
13
14 export const formatFileSize = (size?: number) => {
15     if (typeof size === "number") {
16         for (const { base, unit } of FILE_SIZES) {
17             if (size >= base) {
18                 return `${(size / base).toFixed()} ${unit}`;
19             }
20         }
21     }
22     return "";
23 };
24
25 export const formatTime = (time: number) => {
26     const minutes = Math.floor(time / (1000 * 60) % 60).toFixed(0);
27     const hours = Math.floor(time / (1000 * 60 * 60)).toFixed(0);
28
29     return hours + "h " + minutes + "m";
30 };
31
32 export const getTimeDiff = (endTime: string, startTime: string) => {
33     return new Date(endTime).getTime() - new Date(startTime).getTime();
34 };
35
36 export const formatProgress = (loaded: number, total: number) => {
37     const progress = loaded >= 0 && total > 0 ? loaded * 100 / total : 0;
38     return `${progress.toFixed(2)}%`;
39 };
40
41 export function formatUploadSpeed(prevLoaded: number, loaded: number, prevTime: number, currentTime: number) {
42     const speed = loaded > prevLoaded && currentTime > prevTime
43         ? (loaded - prevLoaded) / (currentTime - prevTime)
44         : 0;
45     return `${(speed / 1000).toFixed(2)} KB/s`;
46 }
47
48 const FILE_SIZES = [
49     {
50         base: 1000000000000,
51         unit: "TB"
52     },
53     {
54         base: 1000000000,
55         unit: "GB"
56     },
57     {
58         base: 1000000,
59         unit: "MB"
60     },
61     {
62         base: 1000,
63         unit: "KB"
64     },
65     {
66         base: 1,
67         unit: "B"
68     }
69 ];