2023-03-02 04:26:55 +03:00
|
|
|
import { assertExists } from '@blocksuite/global/utils';
|
|
|
|
|
2023-03-01 10:40:01 +03:00
|
|
|
export function getUaHelper() {
|
2022-12-30 16:40:15 +03:00
|
|
|
let uaHelper = null;
|
|
|
|
(function (navigator) {
|
|
|
|
const getUa = () => {
|
|
|
|
const ua = navigator.userAgent;
|
|
|
|
const uas = ua.toLowerCase();
|
2023-03-02 04:26:55 +03:00
|
|
|
const mobile = /iPhone|iPad|iPod|Android/i.test(ua);
|
2022-12-30 16:40:15 +03:00
|
|
|
const android =
|
|
|
|
(mobile &&
|
|
|
|
(uas.indexOf('android') > -1 || uas.indexOf('linux') > -1)) ||
|
|
|
|
uas.indexOf('adr') > -1;
|
|
|
|
const ios = mobile && !android && /Mac OS/i.test(ua);
|
2023-03-10 21:06:40 +03:00
|
|
|
const mac = !mobile && /Mac OS/i.test(ua);
|
2022-12-30 16:40:15 +03:00
|
|
|
const iphone = ios && uas.indexOf('iphone') > -1;
|
|
|
|
const ipad = ios && !iphone;
|
|
|
|
const wx = /MicroMessenger/i.test(ua);
|
|
|
|
const chrome = /CriOS/i.test(ua) || /Chrome/i.test(ua);
|
|
|
|
const tiktok = mobile && /aweme/i.test(ua);
|
|
|
|
const weibo = mobile && /Weibo/i.test(ua);
|
|
|
|
const safari =
|
|
|
|
ios &&
|
|
|
|
!chrome &&
|
|
|
|
!wx &&
|
|
|
|
!weibo &&
|
|
|
|
!tiktok &&
|
|
|
|
/Safari|Macintosh/i.test(ua);
|
|
|
|
const firefox = /Firefox/.test(ua);
|
|
|
|
const win = /windows|win32|win64|wow32|wow64/.test(uas);
|
|
|
|
const linux = /linux/.test(uas);
|
|
|
|
return {
|
|
|
|
ua,
|
|
|
|
mobile,
|
|
|
|
android,
|
|
|
|
ios,
|
2023-03-10 21:06:40 +03:00
|
|
|
mac,
|
2022-12-30 16:40:15 +03:00
|
|
|
wx,
|
|
|
|
chrome,
|
|
|
|
iphone,
|
|
|
|
ipad,
|
|
|
|
safari,
|
|
|
|
tiktok,
|
|
|
|
weibo,
|
|
|
|
win,
|
|
|
|
linux,
|
|
|
|
firefox,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
class UaHelper {
|
|
|
|
private uaMap;
|
|
|
|
public isLinux = false;
|
|
|
|
public isMacOs = false;
|
|
|
|
public isSafari = false;
|
|
|
|
public isWindows = false;
|
|
|
|
public isFireFox = false;
|
2023-03-02 04:26:55 +03:00
|
|
|
public isMobile = false;
|
|
|
|
public isChrome = false;
|
2023-03-28 12:13:03 +03:00
|
|
|
public isIOS = false;
|
2023-03-02 04:26:55 +03:00
|
|
|
|
|
|
|
getChromeVersion = (): number => {
|
|
|
|
const raw = navigator.userAgent.match(/Chrom(e|ium)\/([0-9]+)\./);
|
|
|
|
assertExists(raw);
|
|
|
|
return parseInt(raw[2], 10);
|
|
|
|
};
|
2022-12-30 16:40:15 +03:00
|
|
|
|
|
|
|
constructor() {
|
|
|
|
this.uaMap = getUa();
|
|
|
|
this.initUaFlags();
|
|
|
|
}
|
|
|
|
|
|
|
|
public checkUseragent(isUseragent: keyof ReturnType<typeof getUa>) {
|
|
|
|
return Boolean(this.uaMap[isUseragent]);
|
|
|
|
}
|
|
|
|
|
|
|
|
private initUaFlags() {
|
|
|
|
this.isLinux = this.checkUseragent('linux');
|
2023-03-10 21:06:40 +03:00
|
|
|
this.isMacOs = this.checkUseragent('mac');
|
2022-12-30 16:40:15 +03:00
|
|
|
this.isSafari = this.checkUseragent('safari');
|
|
|
|
this.isWindows = this.checkUseragent('win');
|
|
|
|
this.isFireFox = this.checkUseragent('firefox');
|
2023-03-02 04:26:55 +03:00
|
|
|
this.isMobile = this.checkUseragent('mobile');
|
|
|
|
this.isChrome = this.checkUseragent('chrome');
|
2023-03-28 12:13:03 +03:00
|
|
|
this.isIOS = this.checkUseragent('ios');
|
2022-12-30 16:40:15 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
uaHelper = new UaHelper();
|
|
|
|
})(navigator);
|
|
|
|
|
|
|
|
return uaHelper;
|
|
|
|
}
|