UNPKG

matrix-react-sdk

Version:
156 lines (147 loc) 23.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _compoundWeb = require("@vector-im/compound-web"); var _KeyBindingsManager = require("../../../KeyBindingsManager"); var _KeyboardShortcuts = require("../../../accessibility/KeyboardShortcuts"); const _excluded = ["element", "onClick", "children", "kind", "disabled", "className", "onKeyDown", "onKeyUp", "triggerOnMouseDown", "title", "caption", "placement", "onTooltipOpenChange", "disableTooltip"]; /* Copyright 2024 New Vector Ltd. Copyright 2016 Jani Mustonen SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ 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; } /** * The kind of button, similar to how Bootstrap works. */ /** * This type construct allows us to specifically pass those props down to the element we’re creating that the element * actually supports. * * e.g., if element is set to "a", we’ll support href and target, if it’s set to "input", we support type. * * To remain compatible with existing code, we’ll continue to support InputHTMLAttributes<Element> */ /** * Type of props accepted by {@link AccessibleButton}. * * Extends props accepted by the underlying element specified using the `element` prop. */ /** * Type of the props passed to the element that is rendered by AccessibleButton. */ /** * AccessibleButton is a generic wrapper for any element that should be treated * as a button. Identifies the element as a button, setting proper tab * indexing and keyboard activation behavior. * * If a ref is passed, it will be forwarded to the rendered element as specified using the `element` prop. * * @param {Object} props react element properties * @returns {Object} rendered react */ const AccessibleButton = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) { let { element = "div", onClick, children, kind, disabled, className, onKeyDown, onKeyUp, triggerOnMouseDown, title, caption, placement = "right", onTooltipOpenChange, disableTooltip } = _ref, restProps = (0, _objectWithoutProperties2.default)(_ref, _excluded); const newProps = restProps; newProps["aria-label"] = newProps["aria-label"] ?? title; if (disabled) { newProps["aria-disabled"] = true; newProps["disabled"] = true; } else { if (triggerOnMouseDown) { newProps.onMouseDown = onClick ?? undefined; } else { newProps.onClick = onClick ?? undefined; } // We need to consume enter onKeyDown and space onKeyUp // otherwise we are risking also activating other keyboard focusable elements // that might receive focus as a result of the AccessibleButtonClick action // It's because we are using html buttons at a few places e.g. inside dialogs // And divs which we report as role button to assistive technologies. // Browsers handle space and enter key presses differently and we are only adjusting to the // inconsistencies here newProps.onKeyDown = e => { const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(e); switch (action) { case _KeyboardShortcuts.KeyBindingAction.Enter: e.stopPropagation(); e.preventDefault(); return onClick?.(e); case _KeyboardShortcuts.KeyBindingAction.Space: e.stopPropagation(); e.preventDefault(); break; default: onKeyDown?.(e); } }; newProps.onKeyUp = e => { const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(e); switch (action) { case _KeyboardShortcuts.KeyBindingAction.Enter: e.stopPropagation(); e.preventDefault(); break; case _KeyboardShortcuts.KeyBindingAction.Space: e.stopPropagation(); e.preventDefault(); return onClick?.(e); default: onKeyUp?.(e); break; } }; } // Pass through the ref - used for keyboard shortcut access to some buttons newProps.ref = ref; newProps.className = (0, _classnames.default)("mx_AccessibleButton", className, { mx_AccessibleButton_hasKind: kind, [`mx_AccessibleButton_kind_${kind}`]: kind, mx_AccessibleButton_disabled: disabled }); // React.createElement expects InputHTMLAttributes const button = /*#__PURE__*/_react.default.createElement(element, newProps, children); if (title) { return /*#__PURE__*/_react.default.createElement(_compoundWeb.Tooltip, { description: title, caption: caption, isTriggerInteractive: true, placement: placement, onOpenChange: onTooltipOpenChange, disabled: disableTooltip }, button); } return button; }); // Type assertion required due to forwardRef type workaround in react.d.ts AccessibleButton.defaultProps = { role: "button", tabIndex: 0 }; AccessibleButton.displayName = "AccessibleButton"; var _default = exports.default = AccessibleButton; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_compoundWeb","_KeyBindingsManager","_KeyboardShortcuts","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","AccessibleButton","forwardRef","_ref","ref","element","onClick","children","kind","disabled","className","onKeyDown","onKeyUp","triggerOnMouseDown","title","caption","placement","onTooltipOpenChange","disableTooltip","restProps","_objectWithoutProperties2","newProps","onMouseDown","undefined","action","getKeyBindingsManager","getAccessibilityAction","KeyBindingAction","Enter","stopPropagation","preventDefault","Space","classnames","mx_AccessibleButton_hasKind","mx_AccessibleButton_disabled","button","React","createElement","Tooltip","description","isTriggerInteractive","onOpenChange","defaultProps","role","tabIndex","displayName","_default","exports"],"sources":["../../../../src/components/views/elements/AccessibleButton.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2016 Jani Mustonen\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, { ComponentProps, forwardRef, FunctionComponent, HTMLAttributes, InputHTMLAttributes, Ref } from \"react\";\nimport classnames from \"classnames\";\nimport { Tooltip } from \"@vector-im/compound-web\";\n\nimport { getKeyBindingsManager } from \"../../../KeyBindingsManager\";\nimport { KeyBindingAction } from \"../../../accessibility/KeyboardShortcuts\";\n\nexport type ButtonEvent = React.MouseEvent<Element> | React.KeyboardEvent<Element> | React.FormEvent<Element>;\n\n/**\n * The kind of button, similar to how Bootstrap works.\n */\nexport type AccessibleButtonKind =\n    | \"primary\"\n    | \"primary_outline\"\n    | \"primary_sm\"\n    | \"secondary\"\n    | \"secondary_content\"\n    | \"content_inline\"\n    | \"danger\"\n    | \"danger_outline\"\n    | \"danger_sm\"\n    | \"danger_inline\"\n    | \"link\"\n    | \"link_inline\"\n    | \"link_sm\"\n    | \"confirm_sm\"\n    | \"cancel_sm\"\n    | \"icon\"\n    | \"icon_primary\"\n    | \"icon_primary_outline\";\n\n/**\n * This type construct allows us to specifically pass those props down to the element we’re creating that the element\n * actually supports.\n *\n * e.g., if element is set to \"a\", we’ll support href and target, if it’s set to \"input\", we support type.\n *\n * To remain compatible with existing code, we’ll continue to support InputHTMLAttributes<Element>\n */\ntype DynamicHtmlElementProps<T extends keyof JSX.IntrinsicElements> =\n    JSX.IntrinsicElements[T] extends HTMLAttributes<{}> ? DynamicElementProps<T> : DynamicElementProps<\"div\">;\ntype DynamicElementProps<T extends keyof JSX.IntrinsicElements> = Partial<\n    Omit<JSX.IntrinsicElements[T], \"ref\" | \"onClick\" | \"onMouseDown\" | \"onKeyUp\" | \"onKeyDown\">\n> &\n    Omit<InputHTMLAttributes<Element>, \"onClick\">;\n\ntype TooltipProps = ComponentProps<typeof Tooltip>;\n\n/**\n * Type of props accepted by {@link AccessibleButton}.\n *\n * Extends props accepted by the underlying element specified using the `element` prop.\n */\ntype Props<T extends keyof JSX.IntrinsicElements> = DynamicHtmlElementProps<T> & {\n    /**\n     * The base element type. \"div\" by default.\n     */\n    element?: T;\n    /**\n     * The kind of button, similar to how Bootstrap works.\n     */\n    kind?: AccessibleButtonKind;\n    /**\n     * Whether the button should be disabled.\n     */\n    disabled?: boolean;\n    /**\n     * Whether the button should trigger on mousedown event instead of on click event. Defaults to false (click event).\n     */\n    triggerOnMouseDown?: boolean;\n    /**\n     * Event handler for button activation. Should be implemented exactly like a normal `onClick` handler.\n     */\n    onClick: ((e: ButtonEvent) => void | Promise<void>) | null;\n    /**\n     * The tooltip to show on hover or focus.\n     */\n    title?: TooltipProps[\"label\"];\n    /**\n     * The caption is a secondary text displayed under the `title` of the tooltip.\n     * Only valid when used in conjunction with `title`.\n     */\n    caption?: TooltipProps[\"caption\"];\n    /**\n     * The placement of the tooltip.\n     */\n    placement?: TooltipProps[\"placement\"];\n    /**\n     * Callback for when the tooltip is opened or closed.\n     */\n    onTooltipOpenChange?: TooltipProps[\"onOpenChange\"];\n\n    /**\n     * Whether the tooltip should be disabled.\n     */\n    disableTooltip?: TooltipProps[\"disabled\"];\n};\n\nexport type ButtonProps<T extends keyof JSX.IntrinsicElements> = Props<T>;\n\n/**\n * Type of the props passed to the element that is rendered by AccessibleButton.\n */\ninterface RenderedElementProps extends React.InputHTMLAttributes<Element> {\n    ref?: React.Ref<Element>;\n}\n\n/**\n * AccessibleButton is a generic wrapper for any element that should be treated\n * as a button.  Identifies the element as a button, setting proper tab\n * indexing and keyboard activation behavior.\n *\n * If a ref is passed, it will be forwarded to the rendered element as specified using the `element` prop.\n *\n * @param {Object} props  react element properties\n * @returns {Object} rendered react\n */\nconst AccessibleButton = forwardRef(function <T extends keyof JSX.IntrinsicElements>(\n    {\n        element = \"div\" as T,\n        onClick,\n        children,\n        kind,\n        disabled,\n        className,\n        onKeyDown,\n        onKeyUp,\n        triggerOnMouseDown,\n        title,\n        caption,\n        placement = \"right\",\n        onTooltipOpenChange,\n        disableTooltip,\n        ...restProps\n    }: Props<T>,\n    ref: Ref<HTMLElement>,\n): JSX.Element {\n    const newProps: RenderedElementProps = restProps;\n    newProps[\"aria-label\"] = newProps[\"aria-label\"] ?? title;\n    if (disabled) {\n        newProps[\"aria-disabled\"] = true;\n        newProps[\"disabled\"] = true;\n    } else {\n        if (triggerOnMouseDown) {\n            newProps.onMouseDown = onClick ?? undefined;\n        } else {\n            newProps.onClick = onClick ?? undefined;\n        }\n        // We need to consume enter onKeyDown and space onKeyUp\n        // otherwise we are risking also activating other keyboard focusable elements\n        // that might receive focus as a result of the AccessibleButtonClick action\n        // It's because we are using html buttons at a few places e.g. inside dialogs\n        // And divs which we report as role button to assistive technologies.\n        // Browsers handle space and enter key presses differently and we are only adjusting to the\n        // inconsistencies here\n        newProps.onKeyDown = (e) => {\n            const action = getKeyBindingsManager().getAccessibilityAction(e);\n\n            switch (action) {\n                case KeyBindingAction.Enter:\n                    e.stopPropagation();\n                    e.preventDefault();\n                    return onClick?.(e);\n                case KeyBindingAction.Space:\n                    e.stopPropagation();\n                    e.preventDefault();\n                    break;\n                default:\n                    onKeyDown?.(e);\n            }\n        };\n        newProps.onKeyUp = (e) => {\n            const action = getKeyBindingsManager().getAccessibilityAction(e);\n\n            switch (action) {\n                case KeyBindingAction.Enter:\n                    e.stopPropagation();\n                    e.preventDefault();\n                    break;\n                case KeyBindingAction.Space:\n                    e.stopPropagation();\n                    e.preventDefault();\n                    return onClick?.(e);\n                default:\n                    onKeyUp?.(e);\n                    break;\n            }\n        };\n    }\n\n    // Pass through the ref - used for keyboard shortcut access to some buttons\n    newProps.ref = ref;\n\n    newProps.className = classnames(\"mx_AccessibleButton\", className, {\n        mx_AccessibleButton_hasKind: kind,\n        [`mx_AccessibleButton_kind_${kind}`]: kind,\n        mx_AccessibleButton_disabled: disabled,\n    });\n\n    // React.createElement expects InputHTMLAttributes\n    const button = React.createElement(element, newProps, children);\n\n    if (title) {\n        return (\n            <Tooltip\n                description={title}\n                caption={caption}\n                isTriggerInteractive={true}\n                placement={placement}\n                onOpenChange={onTooltipOpenChange}\n                disabled={disableTooltip}\n            >\n                {button}\n            </Tooltip>\n        );\n    }\n    return button;\n});\n\n// Type assertion required due to forwardRef type workaround in react.d.ts\n(AccessibleButton as FunctionComponent).defaultProps = {\n    role: \"button\",\n    tabIndex: 0,\n};\n(AccessibleButton as FunctionComponent).displayName = \"AccessibleButton\";\n\nexport default AccessibleButton;\n"],"mappings":"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","ignoreList":[]}