owncast/webroot/js/utils.js

88 lines
2.4 KiB
JavaScript
Raw Normal View History

2020-06-14 09:24:26 +02:00
function getLocalStorage(key) {
try {
return localStorage.getItem(key);
} catch (e) {
}
return null;
}
function setLocalStorage(key, value) {
try {
2020-06-14 10:10:26 +02:00
if (value !== "" && value !== null) {
localStorage.setItem(key, value);
} else {
localStorage.removeItem(key);
}
2020-06-14 09:24:26 +02:00
return true;
} catch (e) {}
return false;
}
2020-06-14 10:10:26 +02:00
function clearLocalStorage(key) {
localStorage.removeItem(key);
}
2020-06-14 09:24:26 +02:00
function jumpToBottom(id) {
const div = document.querySelector(id);
div.scrollTo({
2020-06-14 10:10:26 +02:00
top: div.scrollHeight,// - div.clientHeight,
2020-06-14 09:24:26 +02:00
left: 0,
behavior: 'smooth'
});
}
function uuidv4() {
return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
const r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8);
return v.toString(16);
});
2020-06-15 06:14:42 +02:00
}
function setVHvar() {
var vh = window.innerHeight * 0.01;
2020-06-15 06:14:42 +02:00
// Then we set the value in the --vh custom property to the root of the document
document.documentElement.style.setProperty('--vh', `${vh}px`);
console.log("== new vh", vh)
2020-06-15 06:14:42 +02:00
}
// delayed
2020-06-15 06:14:42 +02:00
function mobileVHhack() {
setTimeout(setVHvar, 100);
2020-06-15 09:15:23 +02:00
}
function isAndroidMobile() {
var isAndroid = navigator.userAgent.toLowerCase().indexOf("android") > -1;
//&& ua.indexOf("mobile");
return isAndroid;
}
2020-06-16 00:45:55 +02:00
// Trying to determine if browser is mobile/tablet.
// Source: https://developer.mozilla.org/en-US/docs/Web/HTTP/Browser_detection_using_the_user_agent
function hasTouchScreen() {
var hasTouchScreen = false;
if ("maxTouchPoints" in navigator) {
hasTouchScreen = navigator.maxTouchPoints > 0;
} else if ("msMaxTouchPoints" in navigator) {
hasTouchScreen = navigator.msMaxTouchPoints > 0;
} else {
var mQ = window.matchMedia && matchMedia("(pointer:coarse)");
if (mQ && mQ.media === "(pointer:coarse)") {
hasTouchScreen = !!mQ.matches;
} else if ('orientation' in window) {
hasTouchScreen = true; // deprecated, but good fallback
} else {
// Only as a last resort, fall back to user agent sniffing
var UA = navigator.userAgent;
hasTouchScreen = (
/\b(BlackBerry|webOS|iPhone|IEMobile)\b/i.test(UA) ||
/\b(Android|Windows Phone|iPad|iPod)\b/i.test(UA)
);
}
}
return hasTouchScreen;
}
2020-06-16 00:45:55 +02:00
function handleOrientationChange(event) {
console.log("====orientation change 123", event, window.screen.orientation, window.orientation)
mobileVHhack();
2020-06-16 00:45:55 +02:00
}