UNPKG

matrix-react-sdk

Version:
140 lines (134 loc) 22.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.LayoutSwitcher = LayoutSwitcher; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _react = _interopRequireWildcard(require("react")); var _compoundWeb = require("@vector-im/compound-web"); var _SettingsSubsection = _interopRequireDefault(require("./shared/SettingsSubsection")); var _languageHandler = require("../../../languageHandler"); var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore")); var _SettingLevel = require("../../../settings/SettingLevel"); var _useSettings = require("../../../hooks/useSettings"); var _Layout = require("../../../settings/enums/Layout"); var _EventTilePreview = _interopRequireDefault(require("../elements/EventTilePreview")); var _MatrixClientContext = require("../../../contexts/MatrixClientContext"); 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 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. */ /** * A section to switch between different message layouts. */ function LayoutSwitcher() { return /*#__PURE__*/_react.default.createElement(_SettingsSubsection.default, { heading: (0, _languageHandler._t)("common|message_layout"), legacy: false, "data-testid": "layoutPanel" }, /*#__PURE__*/_react.default.createElement(LayoutSelector, null), /*#__PURE__*/_react.default.createElement(ToggleCompactLayout, null)); } /** * A selector to choose the layout of the messages. */ function LayoutSelector() { return /*#__PURE__*/_react.default.createElement(_compoundWeb.Root, { className: "mx_LayoutSwitcher_LayoutSelector", onChange: async evt => { // We don't have any file in the form, we can cast it as string safely const newLayout = new FormData(evt.currentTarget).get("layout"); await _SettingsStore.default.setValue("layout", null, _SettingLevel.SettingLevel.DEVICE, newLayout); } }, /*#__PURE__*/_react.default.createElement(LayoutRadio, { layout: _Layout.Layout.Group, label: (0, _languageHandler._t)("common|modern") }), /*#__PURE__*/_react.default.createElement(LayoutRadio, { layout: _Layout.Layout.Bubble, label: (0, _languageHandler._t)("settings|appearance|layout_bubbles") }), /*#__PURE__*/_react.default.createElement(LayoutRadio, { layout: _Layout.Layout.IRC, label: (0, _languageHandler._t)("settings|appearance|layout_irc") })); } /** * A radio button to select a layout. */ /** * A radio button to select a layout. * @param layout * @param label */ function LayoutRadio({ layout, label }) { const currentLayout = (0, _useSettings.useSettingValue)("layout"); const eventTileInfo = useEventTileInfo(); return /*#__PURE__*/_react.default.createElement(_compoundWeb.Field, { name: "layout", className: "mxLayoutSwitcher_LayoutSelector_LayoutRadio" }, /*#__PURE__*/_react.default.createElement(_compoundWeb.Label, { "aria-label": label }, /*#__PURE__*/_react.default.createElement("div", { className: "mxLayoutSwitcher_LayoutSelector_LayoutRadio_inline" }, /*#__PURE__*/_react.default.createElement(_compoundWeb.RadioControl, { name: "layout", value: layout, defaultChecked: currentLayout === layout }), /*#__PURE__*/_react.default.createElement("span", null, label)), /*#__PURE__*/_react.default.createElement("hr", { className: "mxLayoutSwitcher_LayoutSelector_LayoutRadio_separator" }), /*#__PURE__*/_react.default.createElement(_EventTilePreview.default, (0, _extends2.default)({ message: (0, _languageHandler._t)("common|preview_message"), layout: layout, className: "mxLayoutSwitcher_LayoutSelector_LayoutRadio_EventTilePreview" }, eventTileInfo)))); } /** * Fetch the information to display in the event tile preview. */ function useEventTileInfo() { const matrixClient = (0, _MatrixClientContext.useMatrixClientContext)(); const userId = matrixClient.getSafeUserId(); const [eventTileInfo, setEventTileInfo] = (0, _react.useState)({ userId }); (0, _react.useEffect)(() => { const run = async () => { const profileInfo = await matrixClient.getProfileInfo(userId); setEventTileInfo({ userId, displayName: profileInfo.displayname, avatarUrl: profileInfo.avatar_url }); }; run(); }, [userId, matrixClient, setEventTileInfo]); return eventTileInfo; } /** * A toggleable setting to enable or disable the compact layout. */ function ToggleCompactLayout() { const compactLayoutEnabled = (0, _useSettings.useSettingValue)("useCompactLayout"); const layout = (0, _useSettings.useSettingValue)("layout"); return /*#__PURE__*/_react.default.createElement(_compoundWeb.Root, { onChange: async evt => { const checked = new FormData(evt.currentTarget).get("compactLayout") === "on"; await _SettingsStore.default.setValue("useCompactLayout", null, _SettingLevel.SettingLevel.DEVICE, checked); } }, /*#__PURE__*/_react.default.createElement(_compoundWeb.InlineField, { name: "compactLayout", control: /*#__PURE__*/_react.default.createElement(_compoundWeb.ToggleControl, { disabled: layout !== _Layout.Layout.Group, name: "compactLayout", defaultChecked: compactLayoutEnabled }) }, /*#__PURE__*/_react.default.createElement(_compoundWeb.Label, null, (0, _languageHandler._t)("settings|appearance|compact_layout")), /*#__PURE__*/_react.default.createElement(_compoundWeb.HelpMessage, null, (0, _languageHandler._t)("settings|appearance|compact_layout_description")))); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_compoundWeb","_SettingsSubsection","_interopRequireDefault","_languageHandler","_SettingsStore","_SettingLevel","_useSettings","_Layout","_EventTilePreview","_MatrixClientContext","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","LayoutSwitcher","createElement","heading","_t","legacy","LayoutSelector","ToggleCompactLayout","Root","className","onChange","evt","newLayout","FormData","currentTarget","SettingsStore","setValue","SettingLevel","DEVICE","LayoutRadio","layout","Layout","Group","label","Bubble","IRC","currentLayout","useSettingValue","eventTileInfo","useEventTileInfo","Field","name","Label","RadioControl","value","defaultChecked","_extends2","message","matrixClient","useMatrixClientContext","userId","getSafeUserId","setEventTileInfo","useState","useEffect","run","profileInfo","getProfileInfo","displayName","displayname","avatarUrl","avatar_url","compactLayoutEnabled","checked","InlineField","control","ToggleControl","disabled","HelpMessage"],"sources":["../../../../src/components/views/settings/LayoutSwitcher.tsx"],"sourcesContent":["/*\n * Copyright 2024 New Vector Ltd.\n * Copyright 2024 The Matrix.org Foundation C.I.C.\n *\n * SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\n * Please see LICENSE files in the repository root for full details.\n */\n\nimport React, { JSX, useEffect, useState } from \"react\";\nimport { Field, HelpMessage, InlineField, Label, RadioControl, Root, ToggleControl } from \"@vector-im/compound-web\";\n\nimport SettingsSubsection from \"./shared/SettingsSubsection\";\nimport { _t } from \"../../../languageHandler\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport { SettingLevel } from \"../../../settings/SettingLevel\";\nimport { useSettingValue } from \"../../../hooks/useSettings\";\nimport { Layout } from \"../../../settings/enums/Layout\";\nimport EventTilePreview from \"../elements/EventTilePreview\";\nimport { useMatrixClientContext } from \"../../../contexts/MatrixClientContext\";\n\n/**\n * A section to switch between different message layouts.\n */\nexport function LayoutSwitcher(): JSX.Element {\n    return (\n        <SettingsSubsection heading={_t(\"common|message_layout\")} legacy={false} data-testid=\"layoutPanel\">\n            <LayoutSelector />\n            <ToggleCompactLayout />\n        </SettingsSubsection>\n    );\n}\n\n/**\n * A selector to choose the layout of the messages.\n */\nfunction LayoutSelector(): JSX.Element {\n    return (\n        <Root\n            className=\"mx_LayoutSwitcher_LayoutSelector\"\n            onChange={async (evt) => {\n                // We don't have any file in the form, we can cast it as string safely\n                const newLayout = new FormData(evt.currentTarget).get(\"layout\") as string | null;\n                await SettingsStore.setValue(\"layout\", null, SettingLevel.DEVICE, newLayout);\n            }}\n        >\n            <LayoutRadio layout={Layout.Group} label={_t(\"common|modern\")} />\n            <LayoutRadio layout={Layout.Bubble} label={_t(\"settings|appearance|layout_bubbles\")} />\n            <LayoutRadio layout={Layout.IRC} label={_t(\"settings|appearance|layout_irc\")} />\n        </Root>\n    );\n}\n\n/**\n * A radio button to select a layout.\n */\ninterface LayoutRadioProps {\n    /**\n     * The value of the layout.\n     */\n    layout: Layout;\n    /**\n     * The label to display for the layout.\n     */\n    label: string;\n}\n\n/**\n * A radio button to select a layout.\n * @param layout\n * @param label\n */\nfunction LayoutRadio({ layout, label }: LayoutRadioProps): JSX.Element {\n    const currentLayout = useSettingValue<Layout>(\"layout\");\n    const eventTileInfo = useEventTileInfo();\n\n    return (\n        <Field name=\"layout\" className=\"mxLayoutSwitcher_LayoutSelector_LayoutRadio\">\n            <Label aria-label={label}>\n                <div className=\"mxLayoutSwitcher_LayoutSelector_LayoutRadio_inline\">\n                    <RadioControl name=\"layout\" value={layout} defaultChecked={currentLayout === layout} />\n                    <span>{label}</span>\n                </div>\n                <hr className=\"mxLayoutSwitcher_LayoutSelector_LayoutRadio_separator\" />\n                <EventTilePreview\n                    message={_t(\"common|preview_message\")}\n                    layout={layout}\n                    className=\"mxLayoutSwitcher_LayoutSelector_LayoutRadio_EventTilePreview\"\n                    {...eventTileInfo}\n                />\n            </Label>\n        </Field>\n    );\n}\n\ntype EventTileInfo = {\n    /**\n     * The ID of the user to display.\n     */\n    userId: string;\n    /**\n     * The display name of the user to display.\n     */\n    displayName?: string;\n    /**\n     * The avatar URL of the user to display.\n     */\n    avatarUrl?: string;\n};\n\n/**\n * Fetch the information to display in the event tile preview.\n */\nfunction useEventTileInfo(): EventTileInfo {\n    const matrixClient = useMatrixClientContext();\n    const userId = matrixClient.getSafeUserId();\n    const [eventTileInfo, setEventTileInfo] = useState<EventTileInfo>({ userId });\n\n    useEffect(() => {\n        const run = async (): Promise<void> => {\n            const profileInfo = await matrixClient.getProfileInfo(userId);\n            setEventTileInfo({\n                userId,\n                displayName: profileInfo.displayname,\n                avatarUrl: profileInfo.avatar_url,\n            });\n        };\n\n        run();\n    }, [userId, matrixClient, setEventTileInfo]);\n    return eventTileInfo;\n}\n\n/**\n * A toggleable setting to enable or disable the compact layout.\n */\nfunction ToggleCompactLayout(): JSX.Element {\n    const compactLayoutEnabled = useSettingValue<boolean>(\"useCompactLayout\");\n    const layout = useSettingValue<Layout>(\"layout\");\n\n    return (\n        <Root\n            onChange={async (evt) => {\n                const checked = new FormData(evt.currentTarget).get(\"compactLayout\") === \"on\";\n                await SettingsStore.setValue(\"useCompactLayout\", null, SettingLevel.DEVICE, checked);\n            }}\n        >\n            <InlineField\n                name=\"compactLayout\"\n                control={\n                    <ToggleControl\n                        disabled={layout !== Layout.Group}\n                        name=\"compactLayout\"\n                        defaultChecked={compactLayoutEnabled}\n                    />\n                }\n            >\n                <Label>{_t(\"settings|appearance|compact_layout\")}</Label>\n                <HelpMessage>{_t(\"settings|appearance|compact_layout_description\")}</HelpMessage>\n            </InlineField>\n        </Root>\n    );\n}\n"],"mappings":"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","ignoreList":[]}