UNPKG

matrix-react-sdk

Version:
83 lines (80 loc) 14.9 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _languageHandler = require("../../../languageHandler"); var _actions = require("../../../dispatcher/actions"); var _theme = require("../../../theme"); var _Dropdown = _interopRequireDefault(require("../elements/Dropdown")); var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore")); var _SettingLevel = require("../../../settings/SettingLevel"); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _PosthogTrackers = _interopRequireDefault(require("../../../PosthogTrackers")); var _useTheme = require("../../../hooks/useTheme"); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } /* Copyright 2024 New Vector Ltd. Copyright 2022 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 MATCH_SYSTEM_THEME_ID = "MATCH_SYSTEM_THEME_ID"; const QuickThemeSwitcher = ({ requestClose }) => { const orderedThemes = (0, _react.useMemo)(_theme.getOrderedThemes, []); const themeState = (0, _useTheme.useTheme)(); const nonHighContrast = (0, _theme.findNonHighContrastTheme)(themeState.theme); const theme = nonHighContrast ? nonHighContrast : themeState.theme; const { systemThemeActivated } = themeState; const themeOptions = [{ id: MATCH_SYSTEM_THEME_ID, name: (0, _languageHandler._t)("theme|match_system") }, ...orderedThemes]; const selectedTheme = systemThemeActivated ? MATCH_SYSTEM_THEME_ID : theme; const onOptionChange = async newTheme => { _PosthogTrackers.default.trackInteraction("WebQuickSettingsThemeDropdown"); try { if (newTheme === MATCH_SYSTEM_THEME_ID) { await _SettingsStore.default.setValue("use_system_theme", null, _SettingLevel.SettingLevel.DEVICE, true); } else { // The settings watcher doesn't fire until the echo comes back from the // server, so to make the theme change immediately we need to manually // do the dispatch now // XXX: The local echoed value appears to be unreliable, in particular // when settings custom themes(!) so adding forceTheme to override // the value from settings. _dispatcher.default.dispatch({ action: _actions.Action.RecheckTheme, forceTheme: newTheme }); await Promise.all([_SettingsStore.default.setValue("theme", null, _SettingLevel.SettingLevel.DEVICE, newTheme), _SettingsStore.default.setValue("use_system_theme", null, _SettingLevel.SettingLevel.DEVICE, false)]); } } catch (_error) { _dispatcher.default.dispatch({ action: _actions.Action.RecheckTheme }); } requestClose(); }; return /*#__PURE__*/_react.default.createElement("div", { className: "mx_QuickThemeSwitcher" }, /*#__PURE__*/_react.default.createElement("h4", { className: "mx_QuickThemeSwitcher_heading" }, (0, _languageHandler._t)("common|theme")), /*#__PURE__*/_react.default.createElement(_Dropdown.default, { id: "mx_QuickSettingsButton_themePickerDropdown", onOptionChange: onOptionChange, value: selectedTheme, label: (0, _languageHandler._t)("common|theme") }, themeOptions.map(theme => /*#__PURE__*/_react.default.createElement("div", { key: theme.id }, theme.name)))); }; var _default = exports.default = QuickThemeSwitcher; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_languageHandler","_actions","_theme","_Dropdown","_interopRequireDefault","_SettingsStore","_SettingLevel","_dispatcher","_PosthogTrackers","_useTheme","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","MATCH_SYSTEM_THEME_ID","QuickThemeSwitcher","requestClose","orderedThemes","useMemo","getOrderedThemes","themeState","useTheme","nonHighContrast","findNonHighContrastTheme","theme","systemThemeActivated","themeOptions","id","name","_t","selectedTheme","onOptionChange","newTheme","PosthogTrackers","trackInteraction","SettingsStore","setValue","SettingLevel","DEVICE","dis","dispatch","action","Action","RecheckTheme","forceTheme","Promise","all","_error","createElement","className","value","label","map","key","_default","exports"],"sources":["../../../../src/components/views/spaces/QuickThemeSwitcher.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 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 React, { ReactElement, useMemo } from \"react\";\n\nimport { _t } from \"../../../languageHandler\";\nimport { Action } from \"../../../dispatcher/actions\";\nimport { findNonHighContrastTheme, getOrderedThemes } from \"../../../theme\";\nimport Dropdown from \"../elements/Dropdown\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport { SettingLevel } from \"../../../settings/SettingLevel\";\nimport dis from \"../../../dispatcher/dispatcher\";\nimport { RecheckThemePayload } from \"../../../dispatcher/payloads/RecheckThemePayload\";\nimport PosthogTrackers from \"../../../PosthogTrackers\";\nimport { NonEmptyArray } from \"../../../@types/common\";\nimport { useTheme } from \"../../../hooks/useTheme\";\n\ntype Props = {\n    requestClose: () => void;\n};\n\nconst MATCH_SYSTEM_THEME_ID = \"MATCH_SYSTEM_THEME_ID\";\n\nconst QuickThemeSwitcher: React.FC<Props> = ({ requestClose }) => {\n    const orderedThemes = useMemo(getOrderedThemes, []);\n\n    const themeState = useTheme();\n    const nonHighContrast = findNonHighContrastTheme(themeState.theme);\n    const theme = nonHighContrast ? nonHighContrast : themeState.theme;\n    const { systemThemeActivated } = themeState;\n\n    const themeOptions = [\n        {\n            id: MATCH_SYSTEM_THEME_ID,\n            name: _t(\"theme|match_system\"),\n        },\n        ...orderedThemes,\n    ];\n\n    const selectedTheme = systemThemeActivated ? MATCH_SYSTEM_THEME_ID : theme;\n\n    const onOptionChange = async (newTheme: string): Promise<void> => {\n        PosthogTrackers.trackInteraction(\"WebQuickSettingsThemeDropdown\");\n\n        try {\n            if (newTheme === MATCH_SYSTEM_THEME_ID) {\n                await SettingsStore.setValue(\"use_system_theme\", null, SettingLevel.DEVICE, true);\n            } else {\n                // The settings watcher doesn't fire until the echo comes back from the\n                // server, so to make the theme change immediately we need to manually\n                // do the dispatch now\n                // XXX: The local echoed value appears to be unreliable, in particular\n                // when settings custom themes(!) so adding forceTheme to override\n                // the value from settings.\n                dis.dispatch<RecheckThemePayload>({ action: Action.RecheckTheme, forceTheme: newTheme });\n                await Promise.all([\n                    SettingsStore.setValue(\"theme\", null, SettingLevel.DEVICE, newTheme),\n                    SettingsStore.setValue(\"use_system_theme\", null, SettingLevel.DEVICE, false),\n                ]);\n            }\n        } catch (_error) {\n            dis.dispatch<RecheckThemePayload>({ action: Action.RecheckTheme });\n        }\n\n        requestClose();\n    };\n\n    return (\n        <div className=\"mx_QuickThemeSwitcher\">\n            <h4 className=\"mx_QuickThemeSwitcher_heading\">{_t(\"common|theme\")}</h4>\n            <Dropdown\n                id=\"mx_QuickSettingsButton_themePickerDropdown\"\n                onOptionChange={onOptionChange}\n                value={selectedTheme}\n                label={_t(\"common|theme\")}\n            >\n                {\n                    themeOptions.map((theme) => <div key={theme.id}>{theme.name}</div>) as NonEmptyArray<\n                        ReactElement & { key: string }\n                    >\n                }\n            </Dropdown>\n        </div>\n    );\n};\n\nexport default QuickThemeSwitcher;\n"],"mappings":"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","ignoreList":[]}