MeshCentral/public/novnc/core/util/browser.js

153 lines
4.8 KiB
JavaScript
Raw Normal View History

2020-06-06 21:55:47 -04:00
/*
* noVNC: HTML5 VNC client
2021-11-29 15:08:15 -05:00
* Copyright (C) 2019 The noVNC Authors
2020-06-06 21:55:47 -04:00
* Licensed under MPL 2.0 (see LICENSE.txt)
*
* See README.md for usage and integration instructions.
2021-11-29 15:08:15 -05:00
*
* Browser feature support detection
2020-06-06 21:55:47 -04:00
*/
import * as Log from './logging.js';
// Touch detection
export let isTouchDevice = ('ontouchstart' in document.documentElement) ||
// requried for Chrome debugger
(document.ontouchstart !== undefined) ||
// required for MS Surface
(navigator.maxTouchPoints > 0) ||
(navigator.msMaxTouchPoints > 0);
window.addEventListener('touchstart', function onFirstTouch() {
isTouchDevice = true;
window.removeEventListener('touchstart', onFirstTouch, false);
}, false);
// The goal is to find a certain physical width, the devicePixelRatio
// brings us a bit closer but is not optimal.
export let dragThreshold = 10 * (window.devicePixelRatio || 1);
let _supportsCursorURIs = false;
try {
const target = document.createElement('canvas');
target.style.cursor = 'url("") 2 2, default';
2021-11-29 15:08:15 -05:00
if (target.style.cursor.indexOf("url") === 0) {
2020-06-06 21:55:47 -04:00
Log.Info("Data URI scheme cursor supported");
_supportsCursorURIs = true;
} else {
Log.Warn("Data URI scheme cursor not supported");
}
} catch (exc) {
Log.Error("Data URI scheme cursor test exception: " + exc);
}
export const supportsCursorURIs = _supportsCursorURIs;
2021-11-29 15:08:15 -05:00
let _hasScrollbarGutter = true;
2020-06-06 21:55:47 -04:00
try {
2021-11-29 15:08:15 -05:00
// Create invisible container
const container = document.createElement('div');
container.style.visibility = 'hidden';
container.style.overflow = 'scroll'; // forcing scrollbars
document.body.appendChild(container);
// Create a div and place it in the container
const child = document.createElement('div');
container.appendChild(child);
// Calculate the difference between the container's full width
// and the child's width - the difference is the scrollbars
const scrollbarWidth = (container.offsetWidth - child.offsetWidth);
// Clean up
container.parentNode.removeChild(container);
_hasScrollbarGutter = scrollbarWidth != 0;
} catch (exc) {
Log.Error("Scrollbar test exception: " + exc);
2020-06-06 21:55:47 -04:00
}
2021-11-29 15:08:15 -05:00
export const hasScrollbarGutter = _hasScrollbarGutter;
/*
* The functions for detection of platforms and browsers below are exported
* but the use of these should be minimized as much as possible.
*
* It's better to use feature detection than platform detection.
*/
2020-06-06 21:55:47 -04:00
2023-07-05 06:20:10 -04:00
/* OS */
2020-06-06 21:55:47 -04:00
export function isMac() {
2023-07-05 06:20:10 -04:00
return !!(/mac/i).exec(navigator.platform);
2020-06-06 21:55:47 -04:00
}
export function isWindows() {
2023-07-05 06:20:10 -04:00
return !!(/win/i).exec(navigator.platform);
2020-06-06 21:55:47 -04:00
}
export function isIOS() {
2023-07-05 06:20:10 -04:00
return (!!(/ipad/i).exec(navigator.platform) ||
2020-06-06 21:55:47 -04:00
!!(/iphone/i).exec(navigator.platform) ||
!!(/ipod/i).exec(navigator.platform));
}
2023-07-05 06:20:10 -04:00
export function isAndroid() {
/* Android sets navigator.platform to Linux :/ */
return !!navigator.userAgent.match('Android ');
}
export function isChromeOS() {
/* ChromeOS sets navigator.platform to Linux :/ */
return !!navigator.userAgent.match(' CrOS ');
}
/* Browser */
2020-06-06 21:55:47 -04:00
export function isSafari() {
2023-07-05 06:20:10 -04:00
return !!navigator.userAgent.match('Safari/...') &&
!navigator.userAgent.match('Chrome/...') &&
!navigator.userAgent.match('Chromium/...') &&
!navigator.userAgent.match('Epiphany/...');
2020-06-06 21:55:47 -04:00
}
export function isFirefox() {
2023-07-05 06:20:10 -04:00
return !!navigator.userAgent.match('Firefox/...') &&
!navigator.userAgent.match('Seamonkey/...');
}
export function isChrome() {
return !!navigator.userAgent.match('Chrome/...') &&
!navigator.userAgent.match('Chromium/...') &&
!navigator.userAgent.match('Edg/...') &&
!navigator.userAgent.match('OPR/...');
}
export function isChromium() {
return !!navigator.userAgent.match('Chromium/...');
2020-06-06 21:55:47 -04:00
}
2023-07-05 06:20:10 -04:00
export function isOpera() {
return !!navigator.userAgent.match('OPR/...');
}
export function isEdge() {
return !!navigator.userAgent.match('Edg/...');
}
/* Engine */
export function isGecko() {
return !!navigator.userAgent.match('Gecko/...');
}
export function isWebKit() {
return !!navigator.userAgent.match('AppleWebKit/...') &&
!navigator.userAgent.match('Chrome/...');
}
export function isBlink() {
return !!navigator.userAgent.match('Chrome/...');
}