UNPKG

matrix-react-sdk

Version:
157 lines (154 loc) 24.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.TabLocation = exports.Tab = void 0; exports.default = TabbedView; exports.useActiveTabWithDefault = useActiveTabWithDefault; var React = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _languageHandler = require("../../languageHandler"); var _AutoHideScrollbar = _interopRequireDefault(require("./AutoHideScrollbar")); var _PosthogTrackers = require("../../PosthogTrackers"); var _RovingTabIndex = require("../../accessibility/RovingTabIndex"); var _useWindowWidth = require("../../hooks/useWindowWidth"); 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 2019, 2020 , 2024 The Matrix.org Foundation C.I.C. Copyright 2019 New Vector Ltd Copyright 2017 Travis Ralston SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ /** * Represents a tab for the TabbedView. */ class Tab { /** * Creates a new tab. * @param {string} id The tab's ID. * @param {string} label The untranslated tab label. * @param {string|JSX.Element} icon An SVG element to use for the tab icon. Can also be a string for legacy icons, in which case it is the class for the tab icon. This should be a simple mask. * @param {React.ReactNode} body The JSX for the tab container. * @param {string} screenName The screen name to report to Posthog. */ constructor(id, label, icon, body, screenName) { this.id = id; this.label = label; this.icon = icon; this.body = body; this.screenName = screenName; } } exports.Tab = Tab; function useActiveTabWithDefault(tabs, defaultTabID, initialTabID) { const [activeTabId, setActiveTabId] = React.useState(initialTabID && tabs.some(t => t.id === initialTabID) ? initialTabID : defaultTabID); return [activeTabId, setActiveTabId]; } let TabLocation = exports.TabLocation = /*#__PURE__*/function (TabLocation) { TabLocation["LEFT"] = "left"; TabLocation["TOP"] = "top"; return TabLocation; }({}); function domIDForTabID(tabId) { return `mx_tabpanel_${tabId}`; } function TabPanel({ tab }) { return /*#__PURE__*/React.createElement("div", { className: "mx_TabbedView_tabPanel", key: tab.id, id: domIDForTabID(tab.id), "aria-labelledby": `${domIDForTabID(tab.id)}_label` }, /*#__PURE__*/React.createElement(_AutoHideScrollbar.default, { className: "mx_TabbedView_tabPanelContent" }, tab.body)); } function TabLabel({ tab, isActive, showToolip, onClick }) { const classes = (0, _classnames.default)("mx_TabbedView_tabLabel", { mx_TabbedView_tabLabel_active: isActive }); let tabIcon; if (tab.icon) { if (typeof tab.icon === "object") { tabIcon = tab.icon; } else if (typeof tab.icon === "string") { tabIcon = /*#__PURE__*/React.createElement("span", { className: `mx_TabbedView_maskedIcon ${tab.icon}` }); } } const id = domIDForTabID(tab.id); const label = (0, _languageHandler._t)(tab.label); return /*#__PURE__*/React.createElement(_RovingTabIndex.RovingAccessibleButton, { className: classes, onClick: onClick, "data-testid": `settings-tab-${tab.id}`, role: "tab", "aria-selected": isActive, "aria-controls": id, element: "li", title: showToolip ? label : undefined }, tabIcon, /*#__PURE__*/React.createElement("span", { className: "mx_TabbedView_tabLabel_text", id: `${id}_label` }, label)); } /** * A tabbed view component. Given objects representing content with titles, displays * them in a tabbed view where the user can select which one of the items to view at once. */ function TabbedView(props) { const tabLocation = props.tabLocation ?? TabLocation.LEFT; const getTabById = id => { return props.tabs.find(tab => tab.id === id); }; const windowWidth = (0, _useWindowWidth.useWindowWidth)(); const labels = props.tabs.map(tab => /*#__PURE__*/React.createElement(TabLabel, { key: "tab_label_" + tab.id, tab: tab, isActive: tab.id === props.activeTabId, onClick: () => props.onChange(tab.id) // This should be the same as the the CSS breakpoint at which the tab labels are hidden , showToolip: windowWidth < 1024 && tabLocation == TabLocation.LEFT })); const tab = getTabById(props.activeTabId); const panel = tab ? /*#__PURE__*/React.createElement(TabPanel, { tab: tab }) : null; const tabbedViewClasses = (0, _classnames.default)({ mx_TabbedView: true, mx_TabbedView_tabsOnLeft: tabLocation == TabLocation.LEFT, mx_TabbedView_tabsOnTop: tabLocation == TabLocation.TOP, mx_TabbedView_responsive: props.responsive }); const screenName = tab?.screenName ?? props.screenName; return /*#__PURE__*/React.createElement("div", { className: tabbedViewClasses }, screenName && /*#__PURE__*/React.createElement(_PosthogTrackers.PosthogScreenTracker, { screenName: screenName }), /*#__PURE__*/React.createElement(_RovingTabIndex.RovingTabIndexProvider, { handleLoop: true, handleHomeEnd: true, handleLeftRight: tabLocation == TabLocation.TOP, handleUpDown: tabLocation == TabLocation.LEFT }, ({ onKeyDownHandler }) => /*#__PURE__*/React.createElement("ul", { className: "mx_TabbedView_tabLabels", role: "tablist", "aria-orientation": tabLocation == TabLocation.LEFT ? "vertical" : "horizontal", onKeyDown: onKeyDownHandler }, labels)), panel); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_languageHandler","_AutoHideScrollbar","_PosthogTrackers","_RovingTabIndex","_useWindowWidth","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Tab","constructor","id","label","icon","body","screenName","exports","useActiveTabWithDefault","tabs","defaultTabID","initialTabID","activeTabId","setActiveTabId","useState","some","TabLocation","domIDForTabID","tabId","TabPanel","tab","createElement","className","key","TabLabel","isActive","showToolip","onClick","classes","classNames","mx_TabbedView_tabLabel_active","tabIcon","_t","RovingAccessibleButton","role","element","title","undefined","TabbedView","props","tabLocation","LEFT","getTabById","find","windowWidth","useWindowWidth","labels","map","onChange","panel","tabbedViewClasses","mx_TabbedView","mx_TabbedView_tabsOnLeft","mx_TabbedView_tabsOnTop","TOP","mx_TabbedView_responsive","responsive","PosthogScreenTracker","RovingTabIndexProvider","handleLoop","handleHomeEnd","handleLeftRight","handleUpDown","onKeyDownHandler","onKeyDown"],"sources":["../../../src/components/structures/TabbedView.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019, 2020 , 2024 The Matrix.org Foundation C.I.C.\nCopyright 2019 New Vector Ltd\nCopyright 2017 Travis Ralston\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 * as React from \"react\";\nimport classNames from \"classnames\";\n\nimport { _t, TranslationKey } from \"../../languageHandler\";\nimport AutoHideScrollbar from \"./AutoHideScrollbar\";\nimport { PosthogScreenTracker, ScreenName } from \"../../PosthogTrackers\";\nimport { NonEmptyArray } from \"../../@types/common\";\nimport { RovingAccessibleButton, RovingTabIndexProvider } from \"../../accessibility/RovingTabIndex\";\nimport { useWindowWidth } from \"../../hooks/useWindowWidth\";\n\n/**\n * Represents a tab for the TabbedView.\n */\nexport class Tab<T extends string> {\n    /**\n     * Creates a new tab.\n     * @param {string} id The tab's ID.\n     * @param {string} label The untranslated tab label.\n     * @param {string|JSX.Element} icon An SVG element to use for the tab icon. Can also be a string for legacy icons, in which case it is the class for the tab icon. This should be a simple mask.\n     * @param {React.ReactNode} body The JSX for the tab container.\n     * @param {string} screenName The screen name to report to Posthog.\n     */\n    public constructor(\n        public readonly id: T,\n        public readonly label: TranslationKey,\n        public readonly icon: string | JSX.Element | null,\n        public readonly body: React.ReactNode,\n        public readonly screenName?: ScreenName,\n    ) {}\n}\n\nexport function useActiveTabWithDefault<T extends string>(\n    tabs: NonEmptyArray<Tab<string>>,\n    defaultTabID: T,\n    initialTabID?: T,\n): [T, (tabId: T) => void] {\n    const [activeTabId, setActiveTabId] = React.useState(\n        initialTabID && tabs.some((t) => t.id === initialTabID) ? initialTabID : defaultTabID,\n    );\n\n    return [activeTabId, setActiveTabId];\n}\n\nexport enum TabLocation {\n    LEFT = \"left\",\n    TOP = \"top\",\n}\n\ninterface ITabPanelProps<T extends string> {\n    tab: Tab<T>;\n}\n\nfunction domIDForTabID(tabId: string): string {\n    return `mx_tabpanel_${tabId}`;\n}\n\nfunction TabPanel<T extends string>({ tab }: ITabPanelProps<T>): JSX.Element {\n    return (\n        <div\n            className=\"mx_TabbedView_tabPanel\"\n            key={tab.id}\n            id={domIDForTabID(tab.id)}\n            aria-labelledby={`${domIDForTabID(tab.id)}_label`}\n        >\n            <AutoHideScrollbar className=\"mx_TabbedView_tabPanelContent\">{tab.body}</AutoHideScrollbar>\n        </div>\n    );\n}\n\ninterface ITabLabelProps<T extends string> {\n    tab: Tab<T>;\n    isActive: boolean;\n    showToolip: boolean;\n    onClick: () => void;\n}\n\nfunction TabLabel<T extends string>({ tab, isActive, showToolip, onClick }: ITabLabelProps<T>): JSX.Element {\n    const classes = classNames(\"mx_TabbedView_tabLabel\", {\n        mx_TabbedView_tabLabel_active: isActive,\n    });\n\n    let tabIcon: JSX.Element | undefined;\n    if (tab.icon) {\n        if (typeof tab.icon === \"object\") {\n            tabIcon = tab.icon;\n        } else if (typeof tab.icon === \"string\") {\n            tabIcon = <span className={`mx_TabbedView_maskedIcon ${tab.icon}`} />;\n        }\n    }\n\n    const id = domIDForTabID(tab.id);\n\n    const label = _t(tab.label);\n    return (\n        <RovingAccessibleButton\n            className={classes}\n            onClick={onClick}\n            data-testid={`settings-tab-${tab.id}`}\n            role=\"tab\"\n            aria-selected={isActive}\n            aria-controls={id}\n            element=\"li\"\n            title={showToolip ? label : undefined}\n        >\n            {tabIcon}\n            <span className=\"mx_TabbedView_tabLabel_text\" id={`${id}_label`}>\n                {label}\n            </span>\n        </RovingAccessibleButton>\n    );\n}\n\ninterface IProps<T extends string> {\n    // An array of objects representign tabs that the tabbed view will display.\n    tabs: NonEmptyArray<Tab<T>>;\n    // The ID of the tab to show\n    activeTabId: T;\n    // The location of the tabs, dictating the layout of the TabbedView.\n    tabLocation?: TabLocation;\n    // A callback that is called when the active tab should change\n    onChange: (tabId: T) => void;\n    // The screen name to report to Posthog.\n    screenName?: ScreenName;\n    /**\n     * If true, the layout of the tabbed view will be responsive to the viewport size (eg, just showing icons\n     * instead of names of tabs).\n     * Only applies if `tabLocation === TabLocation.LEFT`.\n     * Default: false.\n     */\n    responsive?: boolean;\n}\n\n/**\n * A tabbed view component. Given objects representing content with titles, displays\n * them in a tabbed view where the user can select which one of the items to view at once.\n */\nexport default function TabbedView<T extends string>(props: IProps<T>): JSX.Element {\n    const tabLocation = props.tabLocation ?? TabLocation.LEFT;\n\n    const getTabById = (id: T): Tab<T> | undefined => {\n        return props.tabs.find((tab) => tab.id === id);\n    };\n\n    const windowWidth = useWindowWidth();\n\n    const labels = props.tabs.map((tab) => (\n        <TabLabel\n            key={\"tab_label_\" + tab.id}\n            tab={tab}\n            isActive={tab.id === props.activeTabId}\n            onClick={() => props.onChange(tab.id)}\n            // This should be the same as the the CSS breakpoint at which the tab labels are hidden\n            showToolip={windowWidth < 1024 && tabLocation == TabLocation.LEFT}\n        />\n    ));\n    const tab = getTabById(props.activeTabId);\n    const panel = tab ? <TabPanel tab={tab} /> : null;\n\n    const tabbedViewClasses = classNames({\n        mx_TabbedView: true,\n        mx_TabbedView_tabsOnLeft: tabLocation == TabLocation.LEFT,\n        mx_TabbedView_tabsOnTop: tabLocation == TabLocation.TOP,\n        mx_TabbedView_responsive: props.responsive,\n    });\n\n    const screenName = tab?.screenName ?? props.screenName;\n\n    return (\n        <div className={tabbedViewClasses}>\n            {screenName && <PosthogScreenTracker screenName={screenName} />}\n            <RovingTabIndexProvider\n                handleLoop\n                handleHomeEnd\n                handleLeftRight={tabLocation == TabLocation.TOP}\n                handleUpDown={tabLocation == TabLocation.LEFT}\n            >\n                {({ onKeyDownHandler }) => (\n                    <ul\n                        className=\"mx_TabbedView_tabLabels\"\n                        role=\"tablist\"\n                        aria-orientation={tabLocation == TabLocation.LEFT ? \"vertical\" : \"horizontal\"}\n                        onKeyDown={onKeyDownHandler}\n                    >\n                        {labels}\n                    </ul>\n                )}\n            </RovingTabIndexProvider>\n            {panel}\n        </div>\n    );\n}\n"],"mappings":"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","ignoreList":[]}