cobalt/web/src/lib/device.ts
wukko d27bed7add
web: respect reduced motion & transparency preferences
also cleaned up settings & device libs
2024-07-12 18:49:29 +06:00

41 lines
934 B
TypeScript

const ua = navigator.userAgent.toLowerCase();
const iPhone = ua.includes("iphone os");
const iPad = !iPhone && ua.includes("mac os") && navigator.maxTouchPoints > 0;
const iOS = iPhone || iPad;
const android = ua.includes("android") || ua.includes("diordna");
const mobile = iOS || android;
const language = navigator.language.toLowerCase().slice(0, 2);
const installed = window.matchMedia('(display-mode: standalone)').matches;
const reducedMotion = window.matchMedia(`(prefers-reduced-motion: reduce)`).matches;
const reducedTransparency = window.matchMedia(`(prefers-reduced-transparency: reduce)`).matches;
const device = {
is: {
iPhone,
iPad,
iOS,
android,
mobile,
},
prefers: {
language,
reducedMotion,
reducedTransparency,
},
userAgent: navigator.userAgent,
}
const app = {
is: {
installed
}
}
export { device, app };