opnform/client/lib/utils.js

99 lines
2.6 KiB
JavaScript
Raw Permalink Normal View History

export const hash = (str, seed = 0) => {
2023-12-09 14:47:03 +00:00
let h1 = 0xdeadbeef ^ seed,
h2 = 0x41c6ce57 ^ seed;
for (let i = 0, ch; i < str.length; i++) {
ch = str.charCodeAt(i);
h1 = Math.imul(h1 ^ ch, 2654435761);
h2 = Math.imul(h2 ^ ch, 1597334677);
}
h1 = Math.imul(h1 ^ (h1 >>> 16), 2246822507) ^ Math.imul(h2 ^ (h2 >>> 13), 3266489909);
h2 = Math.imul(h2 ^ (h2 >>> 16), 2246822507) ^ Math.imul(h1 ^ (h1 >>> 13), 3266489909);
return 4294967296 * (2097151 & h2) + (h1 >>> 0);
}
export const generateUUID = () => {
let d = new Date().getTime()// Timestamp
let d2 = ((typeof performance !== 'undefined') && performance.now && (performance.now() * 1000)) || 0// Time in microseconds since page-load or 0 if unsupported
return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
let r = Math.random() * 16// random number between 0 and 16
if (d > 0) { // Use timestamp until depleted
r = (d + r) % 16 | 0
d = Math.floor(d / 16)
} else { // Use microseconds since page-load if supported
r = (d2 + r) % 16 | 0
d2 = Math.floor(d2 / 16)
}
return (c === 'x' ? r : (r & 0x3 | 0x8)).toString(16)
})
}
2024-01-12 14:43:28 +00:00
/*
* Url and domain related utils
*/
/**
* Returns the appUrl with the given path appended.
* @param path
* @returns {string}
*/
export const appUrl = (path = '/') => {
let baseUrl = useRuntimeConfig().public.appUrl
if (!baseUrl) {
console.warn('appUrl not set in runtimeConfig')
return path
}
if (path.startsWith('/')) {
path = path.substring(1)
}
if (!baseUrl.endsWith('/')) {
baseUrl += '/'
}
return baseUrl + path
}
2024-01-12 14:43:28 +00:00
/**
* SSR compatible function to get current host
* @param path
* @returns {string}
*/
export const getHost = function () {
if (process.server) {
return getDomain(useNuxtApp().ssrContext?.event.context.siteConfigNitroOrigin) || useNuxtApp().ssrContext?.event.node.req.headers.host
2024-01-12 14:43:28 +00:00
} else {
return window.location.host
}
}
/**
* Extract domain from url
* @param url
* @returns {*}
*/
export const getDomain = function (url) {
if (url.includes('localhost')) return 'localhost'
2024-01-15 15:17:10 +00:00
try {
2024-01-15 15:41:50 +00:00
if (!url.startsWith('http')) url = 'https://' + url
2024-01-15 15:17:10 +00:00
return (new URL(url)).hostname
} catch (e) {
2024-01-15 15:41:50 +00:00
return url
2024-01-15 15:17:10 +00:00
}
2024-01-12 14:43:28 +00:00
}
/**
* Returns true if the app is running on a custom domain, false otherwise.
* @returns {boolean}
*/
export const customDomainUsed = function() {
const config = useRuntimeConfig()
if (!config.public.customDomainsEnabled) return false
const appDomain = getDomain(config.public.appUrl)
const host = getHost()
2024-01-12 14:43:28 +00:00
return host !== appDomain && getDomain(host) !== appDomain
2024-01-12 14:43:28 +00:00
}