matrix-react-sdk
Version:
SDK for matrix.org using React
114 lines (109 loc) • 16.4 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.LOCAL_STORAGE_KEY = void 0;
exports.checkBrowserSupport = checkBrowserSupport;
exports.getBrowserSupport = getBrowserSupport;
var _logger = require("matrix-js-sdk/src/logger");
var _browserslist = _interopRequireDefault(require("browserslist"));
var _popOut = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/pop-out"));
var _parseUserAgent = require("./utils/device/parseUserAgent");
var _ToastStore = _interopRequireDefault(require("./stores/ToastStore"));
var _GenericToast = _interopRequireDefault(require("./components/views/toasts/GenericToast"));
var _languageHandler = require("./languageHandler");
var _SdkConfig = _interopRequireDefault(require("./SdkConfig"));
/*
Copyright 2024 New Vector Ltd.
Copyright 2024 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
const LOCAL_STORAGE_KEY = exports.LOCAL_STORAGE_KEY = "mx_accepts_unsupported_browser";
const TOAST_KEY = "unsupportedbrowser";
const SUPPORTED_DEVICE_TYPES = [_parseUserAgent.DeviceType.Web, _parseUserAgent.DeviceType.Desktop];
const SUPPORTED_BROWSER_QUERY = "last 2 Chrome versions, last 2 Firefox versions, last 2 Safari versions, last 2 Edge versions";
const LEARN_MORE_URL = "https://github.com/element-hq/element-web#supported-environments";
function onLearnMoreClick() {
onDismissClick();
window.open(LEARN_MORE_URL, "_blank", "noopener,noreferrer");
}
function onDismissClick() {
localStorage.setItem(LOCAL_STORAGE_KEY, String(true));
_ToastStore.default.sharedInstance().dismissToast(TOAST_KEY);
}
function getBrowserNameVersion(browser) {
const [browserName, browserVersion] = browser.split(" ");
const browserNameLc = browserName.toLowerCase();
return [browserNameLc, parseInt(browserVersion, 10)];
}
/**
* Function to check if the current browser is considered supported by our support policy.
* Based on user agent parsing so may be inaccurate if the user has fingerprint prevention turned up to 11.
*/
function getBrowserSupport() {
const browsers = (0, _browserslist.default)(SUPPORTED_BROWSER_QUERY).sort();
const minimumBrowserVersions = new Map();
for (const browser of browsers) {
const [browserName, browserVersion] = getBrowserNameVersion(browser);
// We sorted the browsers so will encounter the minimum version first
if (minimumBrowserVersions.has(browserName)) continue;
minimumBrowserVersions.set(browserName, browserVersion);
}
const details = (0, _parseUserAgent.parseUserAgent)(navigator.userAgent);
let supported = true;
if (!SUPPORTED_DEVICE_TYPES.includes(details.deviceType)) {
_logger.logger.warn("Browser unsupported, unsupported device type", details.deviceType);
supported = false;
}
if (details.client) {
// We don't care about the browser version for desktop devices
// We ship our own browser (electron) for desktop devices
if (details.deviceType === _parseUserAgent.DeviceType.Desktop) {
return supported;
}
const [browserName, browserVersion] = getBrowserNameVersion(details.client);
const minimumVersion = minimumBrowserVersions.get(browserName);
// Check both with the sub-version cut off and without as some browsers have less granular versioning e.g. Safari
if (!minimumVersion || browserVersion < minimumVersion) {
_logger.logger.warn("Browser unsupported, unsupported user agent", details.client);
supported = false;
}
} else {
_logger.logger.warn("Browser unsupported, unknown client", navigator.userAgent);
supported = false;
}
return supported;
}
/**
* Shows a user warning toast if the user's browser is not supported.
*/
function checkBrowserSupport() {
const supported = getBrowserSupport();
if (supported) return;
if (localStorage.getItem(LOCAL_STORAGE_KEY)) {
_logger.logger.warn("Browser unsupported, but user has previously accepted");
return;
}
const brand = _SdkConfig.default.get().brand;
_ToastStore.default.sharedInstance().addOrReplaceToast({
key: TOAST_KEY,
title: (0, _languageHandler._t)("unsupported_browser|title", {
brand
}),
props: {
description: (0, _languageHandler._t)("unsupported_browser|description", {
brand
}),
secondaryLabel: (0, _languageHandler._t)("action|learn_more"),
SecondaryIcon: _popOut.default,
onSecondaryClick: onLearnMoreClick,
primaryLabel: (0, _languageHandler._t)("action|dismiss"),
onPrimaryClick: onDismissClick
},
component: _GenericToast.default,
priority: 40
});
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_logger","require","_browserslist","_interopRequireDefault","_popOut","_parseUserAgent","_ToastStore","_GenericToast","_languageHandler","_SdkConfig","LOCAL_STORAGE_KEY","exports","TOAST_KEY","SUPPORTED_DEVICE_TYPES","DeviceType","Web","Desktop","SUPPORTED_BROWSER_QUERY","LEARN_MORE_URL","onLearnMoreClick","onDismissClick","window","open","localStorage","setItem","String","ToastStore","sharedInstance","dismissToast","getBrowserNameVersion","browser","browserName","browserVersion","split","browserNameLc","toLowerCase","parseInt","getBrowserSupport","browsers","browserlist","sort","minimumBrowserVersions","Map","has","set","details","parseUserAgent","navigator","userAgent","supported","includes","deviceType","logger","warn","client","minimumVersion","get","checkBrowserSupport","getItem","brand","SdkConfig","addOrReplaceToast","key","title","_t","props","description","secondaryLabel","SecondaryIcon","PopOutIcon","onSecondaryClick","primaryLabel","onPrimaryClick","component","GenericToast","priority"],"sources":["../src/SupportedBrowser.ts"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2024 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport { logger } from \"matrix-js-sdk/src/logger\";\nimport browserlist from \"browserslist\";\nimport PopOutIcon from \"@vector-im/compound-design-tokens/assets/web/icons/pop-out\";\n\nimport { DeviceType, parseUserAgent } from \"./utils/device/parseUserAgent\";\nimport ToastStore from \"./stores/ToastStore\";\nimport GenericToast from \"./components/views/toasts/GenericToast\";\nimport { _t } from \"./languageHandler\";\nimport SdkConfig from \"./SdkConfig\";\n\nexport const LOCAL_STORAGE_KEY = \"mx_accepts_unsupported_browser\";\nconst TOAST_KEY = \"unsupportedbrowser\";\n\nconst SUPPORTED_DEVICE_TYPES = [DeviceType.Web, DeviceType.Desktop];\nconst SUPPORTED_BROWSER_QUERY =\n    \"last 2 Chrome versions, last 2 Firefox versions, last 2 Safari versions, last 2 Edge versions\";\nconst LEARN_MORE_URL = \"https://github.com/element-hq/element-web#supported-environments\";\n\nfunction onLearnMoreClick(): void {\n    onDismissClick();\n    window.open(LEARN_MORE_URL, \"_blank\", \"noopener,noreferrer\");\n}\n\nfunction onDismissClick(): void {\n    localStorage.setItem(LOCAL_STORAGE_KEY, String(true));\n    ToastStore.sharedInstance().dismissToast(TOAST_KEY);\n}\n\nfunction getBrowserNameVersion(browser: string): [name: string, version: number] {\n    const [browserName, browserVersion] = browser.split(\" \");\n    const browserNameLc = browserName.toLowerCase();\n    return [browserNameLc, parseInt(browserVersion, 10)];\n}\n\n/**\n * Function to check if the current browser is considered supported by our support policy.\n * Based on user agent parsing so may be inaccurate if the user has fingerprint prevention turned up to 11.\n */\nexport function getBrowserSupport(): boolean {\n    const browsers = browserlist(SUPPORTED_BROWSER_QUERY).sort();\n    const minimumBrowserVersions = new Map<string, number>();\n    for (const browser of browsers) {\n        const [browserName, browserVersion] = getBrowserNameVersion(browser);\n        // We sorted the browsers so will encounter the minimum version first\n        if (minimumBrowserVersions.has(browserName)) continue;\n        minimumBrowserVersions.set(browserName, browserVersion);\n    }\n\n    const details = parseUserAgent(navigator.userAgent);\n\n    let supported = true;\n    if (!SUPPORTED_DEVICE_TYPES.includes(details.deviceType)) {\n        logger.warn(\"Browser unsupported, unsupported device type\", details.deviceType);\n        supported = false;\n    }\n\n    if (details.client) {\n        // We don't care about the browser version for desktop devices\n        // We ship our own browser (electron) for desktop devices\n        if (details.deviceType === DeviceType.Desktop) {\n            return supported;\n        }\n\n        const [browserName, browserVersion] = getBrowserNameVersion(details.client);\n        const minimumVersion = minimumBrowserVersions.get(browserName);\n        // Check both with the sub-version cut off and without as some browsers have less granular versioning e.g. Safari\n        if (!minimumVersion || browserVersion < minimumVersion) {\n            logger.warn(\"Browser unsupported, unsupported user agent\", details.client);\n            supported = false;\n        }\n    } else {\n        logger.warn(\"Browser unsupported, unknown client\", navigator.userAgent);\n        supported = false;\n    }\n\n    return supported;\n}\n\n/**\n * Shows a user warning toast if the user's browser is not supported.\n */\nexport function checkBrowserSupport(): void {\n    const supported = getBrowserSupport();\n    if (supported) return;\n\n    if (localStorage.getItem(LOCAL_STORAGE_KEY)) {\n        logger.warn(\"Browser unsupported, but user has previously accepted\");\n        return;\n    }\n\n    const brand = SdkConfig.get().brand;\n    ToastStore.sharedInstance().addOrReplaceToast({\n        key: TOAST_KEY,\n        title: _t(\"unsupported_browser|title\", { brand }),\n        props: {\n            description: _t(\"unsupported_browser|description\", { brand }),\n            secondaryLabel: _t(\"action|learn_more\"),\n            SecondaryIcon: PopOutIcon,\n            onSecondaryClick: onLearnMoreClick,\n            primaryLabel: _t(\"action|dismiss\"),\n            onPrimaryClick: onDismissClick,\n        },\n        component: GenericToast,\n        priority: 40,\n    });\n}\n"],"mappings":"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","ignoreList":[]}