owncast/web/utils/format.ts

64 lines
1.9 KiB
TypeScript
Raw Normal View History

2021-07-20 07:02:02 +02:00
import UAParser from 'ua-parser-js';
2020-10-26 02:57:23 +01:00
export function formatIPAddress(ipAddress: string): string {
2021-07-20 07:02:02 +02:00
const ipAddressComponents = ipAddress.split(':');
2020-10-26 02:57:23 +01:00
// Wipe out the port component
ipAddressComponents[ipAddressComponents.length - 1] = '';
2021-07-20 07:02:02 +02:00
let ip = ipAddressComponents.join(':');
ip = ip.slice(0, ip.length - 1);
2020-10-27 00:13:25 +01:00
if (ip === '[::1]' || ip === '127.0.0.1') {
2021-07-20 07:02:02 +02:00
return 'Localhost';
2020-10-26 02:57:23 +01:00
}
return ip;
2020-10-28 08:53:24 +01:00
}
// check if obj is {}
export function isEmptyObject(obj) {
return !obj || (Object.keys(obj).length === 0 && obj.constructor === Object);
2020-10-28 08:53:24 +01:00
}
2020-11-03 02:23:32 +01:00
function padLeft(text, pad, size) {
2020-12-30 00:35:54 +01:00
return String(pad.repeat(size) + text).slice(-size);
}
2020-11-03 02:23:32 +01:00
export function parseSecondsToDurationString(seconds = 0) {
const finiteSeconds = Number.isFinite(+seconds) ? Math.abs(seconds) : 0;
const days = Math.floor(finiteSeconds / 86400);
const daysString = days > 0 ? `${days} day${days > 1 ? 's' : ''} ` : '';
const hours = Math.floor((finiteSeconds / 3600) % 24);
const hoursString = hours || days ? padLeft(`${hours}:`, '0', 3) : '';
const mins = Math.floor((finiteSeconds / 60) % 60);
const minString = padLeft(`${mins}:`, '0', 3);
const secs = Math.floor(finiteSeconds % 60);
const secsString = padLeft(`${secs}`, '0', 2);
return daysString + hoursString + minString + secsString;
}
2021-07-20 07:02:02 +02:00
export function formatUAstring(uaString: string) {
const parser = UAParser(uaString);
const { device, os, browser } = parser;
const { major: browserVersion, name } = browser;
const { version: osVersion, name: osName } = os;
const { model, type } = device;
if (uaString === 'libmpv') {
return 'mpv media player';
}
// Fallback to just displaying the raw agent string.
if (!name || !browserVersion || !osName) {
return uaString;
}
2021-07-20 07:02:02 +02:00
const deviceString = model || type ? ` (${model || type})` : '';
return `${name} ${browserVersion} on ${osName} ${osVersion}
${deviceString}`;
}