export function capitalise0(name: undefined): undefined export function capitalise0(name: string): string export function capitalise0(name) { return name && name[0].toUpperCase() + name.slice(1) } export const debounce = void>( waitFor: number, fn: F ) => { let timeoutId: ReturnType return (...args: any[]) => { clearTimeout(timeoutId) timeoutId = setTimeout(() => fn(...args), waitFor) } } export function isIE(): boolean { return ( navigator.appName == 'Microsoft Internet Explorer' || (navigator.appName == 'Netscape' && new RegExp('Trident/.*rv:([0-9]{1,}[.0-9]{0,})').exec( navigator.userAgent ) != null) ) } export function inIframe(): boolean { try { return window.self !== window.top } catch (e) { return true } } export function softCatch( fn: (arg: ArgType) => ReturnType ): (arg: ArgType) => ReturnType | null { return function(...args) { try { return fn(...args) } catch (e) { // eslint-disable-next-line no-console console.warn(e) return null } } } export function mapOrApply(fn: (a: A) => B, x: A): B export function mapOrApply(fn: (a: A) => B, x: Array): Array export function mapOrApply(fn, x) { return Array.isArray(x) ? x.map(fn) : fn(x) } export function coerceArray(x: A | Array): Array { return Array.isArray(x) ? x : [x] } export function getSessionStorage() { // In some browsers like Brave, even just reading the variable sessionStorage // is throwing an error in the iframe, so we can't do things if sessionStorage !== undefined // and we need to wrap it in a try { } catch { } logic try { return window.sessionStorage } catch (e) { return undefined } }