2018-08-15 05:17:10 +01:00
|
|
|
import format from 'date-fns/format';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the human readable filesize for a given number of bytes. This
|
|
|
|
* uses 1024 as the base, so the response is denoted accordingly.
|
|
|
|
*
|
|
|
|
* @param {Number} bytes
|
|
|
|
* @return {String}
|
|
|
|
*/
|
2018-12-16 22:11:56 +00:00
|
|
|
export function readableSize (bytes) {
|
2018-08-15 05:17:10 +01:00
|
|
|
if (Math.abs(bytes) < 1024) {
|
|
|
|
return `${bytes} Bytes`;
|
|
|
|
}
|
|
|
|
|
2018-12-16 22:11:56 +00:00
|
|
|
let u = -1;
|
|
|
|
const units = ['KiB', 'MiB', 'GiB', 'TiB'];
|
2018-08-15 05:17:10 +01:00
|
|
|
|
|
|
|
do {
|
|
|
|
bytes /= 1024;
|
|
|
|
u++;
|
|
|
|
} while (Math.abs(bytes) >= 1024 && u < units.length - 1);
|
|
|
|
|
|
|
|
return `${bytes.toFixed(1)} ${units[u]}`;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format the given date as a human readable string.
|
|
|
|
*
|
|
|
|
* @param {String} date
|
|
|
|
* @return {String}
|
|
|
|
*/
|
2018-12-16 22:11:56 +00:00
|
|
|
export function formatDate (date) {
|
2018-08-15 05:17:10 +01:00
|
|
|
return format(date, 'MMM D, YYYY [at] HH:MM');
|
|
|
|
}
|