-
Notifications
You must be signed in to change notification settings - Fork 0
/
formatDuration.ts
32 lines (31 loc) · 962 Bytes
/
formatDuration.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
/**
* Returns the human-readable format of the given number of milliseconds.
* @param ms - The number of milliseconds.
* @returns The human-readable format of the given number of milliseconds.
* @public
* @example
* ```typescript
* formatDuration(1001); // '1 second, 1 millisecond'
* formatDuration(34325055574);
* // '397 days, 6 hours, 44 minutes, 15 seconds, 574 milliseconds'
* ```
* @public
* @since 0.1.14
* @category Date
*/
const formatDuration = (ms: number) => {
// eslint-disable-next-line no-param-reassign
if (ms < 0) ms = -ms;
const time = {
day: Math.floor(ms / 86400000),
hour: Math.floor(ms / 3600000) % 24,
minute: Math.floor(ms / 60000) % 60,
second: Math.floor(ms / 1000) % 60,
millisecond: Math.floor(ms) % 1000,
};
return Object.entries(time)
.filter((val) => val[1] !== 0)
.map(([key, val]) => `${val} ${key}${val !== 1 ? "s" : ""}`)
.join(", ");
};
export default formatDuration;