UNPKG

matrix-react-sdk

Version:
115 lines (112 loc) 17.9 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _EventTilePreview = _interopRequireDefault(require("../elements/EventTilePreview")); var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore")); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _SettingLevel = require("../../../settings/SettingLevel"); var _languageHandler = require("../../../languageHandler"); var _SettingsSubsection = _interopRequireDefault(require("./shared/SettingsSubsection")); var _Field = _interopRequireDefault(require("../elements/Field")); var _FontWatcher = require("../../../settings/watchers/FontWatcher"); /* Copyright 2024 New Vector Ltd. Copyright 2021-2023 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. */ class FontScalingPanel extends _react.default.Component { constructor(props) { super(props); (0, _defineProperty2.default)(this, "MESSAGE_PREVIEW_TEXT", (0, _languageHandler._t)("common|preview_message")); /** * Font sizes available (in px) */ (0, _defineProperty2.default)(this, "sizes", [9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36]); (0, _defineProperty2.default)(this, "layoutWatcherRef", void 0); (0, _defineProperty2.default)(this, "unmounted", false); /** * Save the new font size * @param delta */ (0, _defineProperty2.default)(this, "onFontSizeChanged", async delta => { const parsedDelta = parseInt(delta, 10) || 0; this.setState({ fontSizeDelta: parsedDelta }); await _SettingsStore.default.setValue("fontSizeDelta", null, _SettingLevel.SettingLevel.DEVICE, parsedDelta); }); /** * Compute the difference between the selected font size and the browser font size * @param fontSize */ (0, _defineProperty2.default)(this, "computeDeltaFontSize", fontSize => { return fontSize - this.state.browserFontSize; }); this.state = { fontSizeDelta: _SettingsStore.default.getValue("fontSizeDelta", null), browserFontSize: _FontWatcher.FontWatcher.getBrowserDefaultFontSize(), useCustomFontSize: _SettingsStore.default.getValue("useCustomFontSize"), layout: _SettingsStore.default.getValue("layout") }; } async componentDidMount() { // Fetch the current user profile for the message preview const client = _MatrixClientPeg.MatrixClientPeg.safeGet(); const userId = client.getSafeUserId(); const profileInfo = await client.getProfileInfo(userId); this.layoutWatcherRef = _SettingsStore.default.watchSetting("layout", null, () => { // Update the layout for the preview window according to the user selection const value = _SettingsStore.default.getValue("layout"); if (this.state.layout !== value) { this.setState({ layout: value }); } }); if (this.unmounted) return; this.setState({ userId, displayName: profileInfo.displayname, avatarUrl: profileInfo.avatar_url }); } componentWillUnmount() { this.unmounted = true; if (this.layoutWatcherRef) { _SettingsStore.default.unwatchSetting(this.layoutWatcherRef); } } render() { return /*#__PURE__*/_react.default.createElement(_SettingsSubsection.default, { heading: (0, _languageHandler._t)("settings|appearance|font_size"), stretchContent: true, "data-testid": "mx_FontScalingPanel" }, /*#__PURE__*/_react.default.createElement(_Field.default, { element: "select", className: "mx_FontScalingPanel_Dropdown", label: (0, _languageHandler._t)("settings|appearance|font_size"), value: this.state.fontSizeDelta.toString(), onChange: e => this.onFontSizeChanged(e.target.value) }, this.sizes.map(size => /*#__PURE__*/_react.default.createElement("option", { key: size, value: this.computeDeltaFontSize(size) }, size === this.state.browserFontSize ? (0, _languageHandler._t)("settings|appearance|font_size_default", { fontSize: size }) : size))), /*#__PURE__*/_react.default.createElement(_EventTilePreview.default, { className: "mx_FontScalingPanel_preview", message: this.MESSAGE_PREVIEW_TEXT, layout: this.state.layout, userId: this.state.userId, displayName: this.state.displayName, avatarUrl: this.state.avatarUrl })); } } exports.default = FontScalingPanel; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_EventTilePreview","_SettingsStore","_MatrixClientPeg","_SettingLevel","_languageHandler","_SettingsSubsection","_Field","_FontWatcher","FontScalingPanel","React","Component","constructor","props","_defineProperty2","default","_t","delta","parsedDelta","parseInt","setState","fontSizeDelta","SettingsStore","setValue","SettingLevel","DEVICE","fontSize","state","browserFontSize","getValue","FontWatcher","getBrowserDefaultFontSize","useCustomFontSize","layout","componentDidMount","client","MatrixClientPeg","safeGet","userId","getSafeUserId","profileInfo","getProfileInfo","layoutWatcherRef","watchSetting","value","unmounted","displayName","displayname","avatarUrl","avatar_url","componentWillUnmount","unwatchSetting","render","createElement","heading","stretchContent","element","className","label","toString","onChange","e","onFontSizeChanged","target","sizes","map","size","key","computeDeltaFontSize","message","MESSAGE_PREVIEW_TEXT","exports"],"sources":["../../../../src/components/views/settings/FontScalingPanel.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021-2023 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 from \"react\";\n\nimport EventTilePreview from \"../elements/EventTilePreview\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport { Layout } from \"../../../settings/enums/Layout\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport { SettingLevel } from \"../../../settings/SettingLevel\";\nimport { _t } from \"../../../languageHandler\";\nimport SettingsSubsection from \"./shared/SettingsSubsection\";\nimport Field from \"../elements/Field\";\nimport { FontWatcher } from \"../../../settings/watchers/FontWatcher\";\n\ninterface IProps {}\n\ninterface IState {\n    browserFontSize: number;\n    // String displaying the current selected fontSize.\n    // Needs to be string for things like '1.' without\n    // trailing 0s.\n    fontSizeDelta: number;\n    useCustomFontSize: boolean;\n    layout: Layout;\n    // User profile data for the message preview\n    userId?: string;\n    displayName?: string;\n    avatarUrl?: string;\n}\n\nexport default class FontScalingPanel extends React.Component<IProps, IState> {\n    private readonly MESSAGE_PREVIEW_TEXT = _t(\"common|preview_message\");\n    /**\n     * Font sizes available (in px)\n     */\n    private readonly sizes = [9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36];\n    private layoutWatcherRef?: string;\n    private unmounted = false;\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            fontSizeDelta: SettingsStore.getValue<number>(\"fontSizeDelta\", null),\n            browserFontSize: FontWatcher.getBrowserDefaultFontSize(),\n            useCustomFontSize: SettingsStore.getValue(\"useCustomFontSize\"),\n            layout: SettingsStore.getValue(\"layout\"),\n        };\n    }\n\n    public async componentDidMount(): Promise<void> {\n        // Fetch the current user profile for the message preview\n        const client = MatrixClientPeg.safeGet();\n        const userId = client.getSafeUserId();\n        const profileInfo = await client.getProfileInfo(userId);\n        this.layoutWatcherRef = SettingsStore.watchSetting(\"layout\", null, () => {\n            // Update the layout for the preview window according to the user selection\n            const value = SettingsStore.getValue(\"layout\");\n            if (this.state.layout !== value) {\n                this.setState({\n                    layout: value,\n                });\n            }\n        });\n        if (this.unmounted) return;\n\n        this.setState({\n            userId,\n            displayName: profileInfo.displayname,\n            avatarUrl: profileInfo.avatar_url,\n        });\n    }\n\n    public componentWillUnmount(): void {\n        this.unmounted = true;\n        if (this.layoutWatcherRef) {\n            SettingsStore.unwatchSetting(this.layoutWatcherRef);\n        }\n    }\n\n    /**\n     * Save the new font size\n     * @param delta\n     */\n    private onFontSizeChanged = async (delta: string): Promise<void> => {\n        const parsedDelta = parseInt(delta, 10) || 0;\n        this.setState({ fontSizeDelta: parsedDelta });\n        await SettingsStore.setValue(\"fontSizeDelta\", null, SettingLevel.DEVICE, parsedDelta);\n    };\n\n    /**\n     * Compute the difference between the selected font size and the browser font size\n     * @param fontSize\n     */\n    private computeDeltaFontSize = (fontSize: number): number => {\n        return fontSize - this.state.browserFontSize;\n    };\n\n    public render(): React.ReactNode {\n        return (\n            <SettingsSubsection\n                heading={_t(\"settings|appearance|font_size\")}\n                stretchContent\n                data-testid=\"mx_FontScalingPanel\"\n            >\n                <Field\n                    element=\"select\"\n                    className=\"mx_FontScalingPanel_Dropdown\"\n                    label={_t(\"settings|appearance|font_size\")}\n                    value={this.state.fontSizeDelta.toString()}\n                    onChange={(e) => this.onFontSizeChanged(e.target.value)}\n                >\n                    {this.sizes.map((size) => (\n                        <option key={size} value={this.computeDeltaFontSize(size)}>\n                            {size === this.state.browserFontSize\n                                ? _t(\"settings|appearance|font_size_default\", { fontSize: size })\n                                : size}\n                        </option>\n                    ))}\n                </Field>\n                <EventTilePreview\n                    className=\"mx_FontScalingPanel_preview\"\n                    message={this.MESSAGE_PREVIEW_TEXT}\n                    layout={this.state.layout}\n                    userId={this.state.userId}\n                    displayName={this.state.displayName}\n                    avatarUrl={this.state.avatarUrl}\n                />\n            </SettingsSubsection>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}