UNPKG

matrix-react-sdk

Version:
165 lines (161 loc) 27.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.Alignment = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _reactDom = _interopRequireDefault(require("react-dom")); var _classnames = _interopRequireDefault(require("classnames")); var _UIStore = _interopRequireDefault(require("../../../stores/UIStore")); var _objects = require("../../../utils/objects"); function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } /* Copyright 2024 New Vector Ltd. Copyright 2019, 2020 The Matrix.org Foundation C.I.C. Copyright 2019 New Vector Ltd Copyright 2019 Michael Telatynski <7t3chguy@gmail.com> Copyright 2015, 2016 OpenMarket Ltd SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ let Alignment = exports.Alignment = /*#__PURE__*/function (Alignment) { Alignment[Alignment["Natural"] = 0] = "Natural"; Alignment[Alignment["Left"] = 1] = "Left"; Alignment[Alignment["Right"] = 2] = "Right"; Alignment[Alignment["Top"] = 3] = "Top"; Alignment[Alignment["Bottom"] = 4] = "Bottom"; Alignment[Alignment["InnerBottom"] = 5] = "InnerBottom"; Alignment[Alignment["TopRight"] = 6] = "TopRight"; return Alignment; }({}); // On top of the target, right aligned /** * @deprecated Use [compound tooltip](https://element-hq.github.io/compound-web/?path=/docs/tooltip--docs) instead */ class Tooltip extends _react.default.PureComponent { constructor(props) { super(props); (0, _defineProperty2.default)(this, "parent", null); // Add the parent's position to the tooltips, so it's correctly // positioned, also taking into account any window zoom (0, _defineProperty2.default)(this, "updatePosition", () => { // When the tooltip is hidden, no need to thrash the DOM with `style` attribute updates (performance) if (!this.props.visible || !this.parent) return; const parentBox = this.parent.getBoundingClientRect(); const width = _UIStore.default.instance.windowWidth; const spacing = 6; const parentWidth = this.props.maxParentWidth ? Math.min(parentBox.width, this.props.maxParentWidth) : parentBox.width; const baseTop = parentBox.top + window.scrollY; const centerTop = parentBox.top + window.scrollY + parentBox.height / 2; const right = width - parentBox.left - window.scrollX; const left = parentBox.right + window.scrollX; const horizontalCenter = parentBox.left - window.scrollX + parentWidth / 2; const style = {}; switch (this.props.alignment) { case Alignment.Natural: if (parentBox.right > width / 2) { style.right = right + spacing; style.top = centerTop; style.transform = "translateY(-50%)"; break; } // fall through to Right case Alignment.Right: style.left = left + spacing; style.top = centerTop; style.transform = "translateY(-50%)"; break; case Alignment.Left: style.right = right + spacing; style.top = centerTop; style.transform = "translateY(-50%)"; break; case Alignment.Top: style.top = baseTop - spacing; // Attempt to center the tooltip on the element while clamping // its horizontal translation to keep it on screen // eslint-disable-next-line max-len style.transform = `translate(max(10px, min(calc(${horizontalCenter}px - 50%), calc(100vw - 100% - 10px))), -100%)`; break; case Alignment.Bottom: style.top = baseTop + parentBox.height + spacing; // Attempt to center the tooltip on the element while clamping // its horizontal translation to keep it on screen // eslint-disable-next-line max-len style.transform = `translate(max(10px, min(calc(${horizontalCenter}px - 50%), calc(100vw - 100% - 10px))))`; break; case Alignment.InnerBottom: style.top = baseTop + parentBox.height - 50; // Attempt to center the tooltip on the element while clamping // its horizontal translation to keep it on screen // eslint-disable-next-line max-len style.transform = `translate(max(10px, min(calc(${horizontalCenter}px - 50%), calc(100vw - 100% - 10px))))`; break; case Alignment.TopRight: style.top = baseTop - spacing; style.right = width - parentBox.right - window.scrollX; style.transform = "translateY(-100%)"; break; } this.setState(style); }); this.state = {}; // Create a wrapper for the tooltips and attach it to the body element if (!Tooltip.container) { Tooltip.container = document.createElement("div"); Tooltip.container.className = "mx_Tooltip_wrapper"; document.body.appendChild(Tooltip.container); } } componentDidMount() { window.addEventListener("scroll", this.updatePosition, { passive: true, capture: true }); this.parent = _reactDom.default.findDOMNode(this)?.parentNode ?? null; this.updatePosition(); } componentDidUpdate(prevProps) { if ((0, _objects.objectHasDiff)(prevProps, this.props)) { this.updatePosition(); } } // Remove the wrapper element, as the tooltip has finished using it componentWillUnmount() { window.removeEventListener("scroll", this.updatePosition, { capture: true }); } render() { const tooltipClasses = (0, _classnames.default)("mx_Tooltip", this.props.tooltipClassName, { mx_Tooltip_visible: this.props.visible, mx_Tooltip_invisible: !this.props.visible }); const style = _objectSpread({}, this.state); // Hide the entire container when not visible. // This prevents flashing of the tooltip if it is not meant to be visible on first mount. style.display = this.props.visible ? "block" : "none"; const tooltip = /*#__PURE__*/_react.default.createElement("div", { id: this.props.id, role: this.props.role || "tooltip", className: tooltipClasses, style: style }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_Tooltip_chevron" }), this.props.label); return /*#__PURE__*/_react.default.createElement("div", { className: this.props.className }, /*#__PURE__*/_reactDom.default.createPortal(tooltip, Tooltip.container)); } } exports.default = Tooltip; (0, _defineProperty2.default)(Tooltip, "container", void 0); // XXX: This is because some components (Field) are unable to `import` the Tooltip class, // so we expose the Alignment options off of us statically. (0, _defineProperty2.default)(Tooltip, "Alignment", Alignment); (0, _defineProperty2.default)(Tooltip, "defaultProps", { visible: true, alignment: Alignment.Natural }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_reactDom","_classnames","_UIStore","_objects","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","Alignment","exports","Tooltip","React","PureComponent","constructor","props","visible","parent","parentBox","getBoundingClientRect","width","UIStore","instance","windowWidth","spacing","parentWidth","maxParentWidth","Math","min","baseTop","top","window","scrollY","centerTop","height","right","left","scrollX","horizontalCenter","style","alignment","Natural","transform","Right","Left","Top","Bottom","InnerBottom","TopRight","setState","state","container","document","createElement","className","body","appendChild","componentDidMount","addEventListener","updatePosition","passive","capture","ReactDOM","findDOMNode","parentNode","componentDidUpdate","prevProps","objectHasDiff","componentWillUnmount","removeEventListener","render","tooltipClasses","classNames","tooltipClassName","mx_Tooltip_visible","mx_Tooltip_invisible","display","tooltip","id","role","label","createPortal"],"sources":["../../../../src/components/views/elements/Tooltip.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019, 2020 The Matrix.org Foundation C.I.C.\nCopyright 2019 New Vector Ltd\nCopyright 2019 Michael Telatynski <7t3chguy@gmail.com>\nCopyright 2015, 2016 OpenMarket Ltd\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, { CSSProperties } from \"react\";\nimport ReactDOM from \"react-dom\";\nimport classNames from \"classnames\";\n\nimport UIStore from \"../../../stores/UIStore\";\nimport { objectHasDiff } from \"../../../utils/objects\";\n\nexport enum Alignment {\n    Natural, // Pick left or right\n    Left,\n    Right,\n    Top, // Centered\n    Bottom, // Centered\n    InnerBottom, // Inside the target, at the bottom\n    TopRight, // On top of the target, right aligned\n}\n\nexport interface ITooltipProps {\n    // Class applied to the element used to position the tooltip\n    className?: string;\n    // Class applied to the tooltip itself\n    tooltipClassName?: string;\n    // Whether the tooltip is visible or hidden.\n    // The hidden state allows animating the tooltip away via CSS.\n    // Defaults to visible if unset.\n    visible?: boolean;\n    // the react element to put into the tooltip\n    label: React.ReactNode;\n    alignment?: Alignment; // defaults to Natural\n    // id describing tooltip\n    // used to associate tooltip with target for a11y\n    id?: string;\n    // If the parent is over this width, act as if it is only this wide\n    maxParentWidth?: number;\n    // aria-role passed to the tooltip\n    role?: React.AriaRole;\n}\n\ntype State = Partial<Pick<CSSProperties, \"display\" | \"right\" | \"top\" | \"transform\" | \"left\">>;\n\n/**\n * @deprecated Use [compound tooltip](https://element-hq.github.io/compound-web/?path=/docs/tooltip--docs) instead\n */\nexport default class Tooltip extends React.PureComponent<ITooltipProps, State> {\n    private static container: HTMLElement;\n    private parent: Element | null = null;\n\n    // XXX: This is because some components (Field) are unable to `import` the Tooltip class,\n    // so we expose the Alignment options off of us statically.\n    public static readonly Alignment = Alignment;\n\n    public static readonly defaultProps = {\n        visible: true,\n        alignment: Alignment.Natural,\n    };\n\n    public constructor(props: ITooltipProps) {\n        super(props);\n\n        this.state = {};\n\n        // Create a wrapper for the tooltips and attach it to the body element\n        if (!Tooltip.container) {\n            Tooltip.container = document.createElement(\"div\");\n            Tooltip.container.className = \"mx_Tooltip_wrapper\";\n            document.body.appendChild(Tooltip.container);\n        }\n    }\n\n    public componentDidMount(): void {\n        window.addEventListener(\"scroll\", this.updatePosition, {\n            passive: true,\n            capture: true,\n        });\n\n        this.parent = (ReactDOM.findDOMNode(this)?.parentNode as Element) ?? null;\n\n        this.updatePosition();\n    }\n\n    public componentDidUpdate(prevProps: ITooltipProps): void {\n        if (objectHasDiff(prevProps, this.props)) {\n            this.updatePosition();\n        }\n    }\n\n    // Remove the wrapper element, as the tooltip has finished using it\n    public componentWillUnmount(): void {\n        window.removeEventListener(\"scroll\", this.updatePosition, {\n            capture: true,\n        });\n    }\n\n    // Add the parent's position to the tooltips, so it's correctly\n    // positioned, also taking into account any window zoom\n    private updatePosition = (): void => {\n        // When the tooltip is hidden, no need to thrash the DOM with `style` attribute updates (performance)\n        if (!this.props.visible || !this.parent) return;\n\n        const parentBox = this.parent.getBoundingClientRect();\n        const width = UIStore.instance.windowWidth;\n        const spacing = 6;\n        const parentWidth = this.props.maxParentWidth\n            ? Math.min(parentBox.width, this.props.maxParentWidth)\n            : parentBox.width;\n        const baseTop = parentBox.top + window.scrollY;\n        const centerTop = parentBox.top + window.scrollY + parentBox.height / 2;\n        const right = width - parentBox.left - window.scrollX;\n        const left = parentBox.right + window.scrollX;\n        const horizontalCenter = parentBox.left - window.scrollX + parentWidth / 2;\n\n        const style: State = {};\n        switch (this.props.alignment) {\n            case Alignment.Natural:\n                if (parentBox.right > width / 2) {\n                    style.right = right + spacing;\n                    style.top = centerTop;\n                    style.transform = \"translateY(-50%)\";\n                    break;\n                }\n            // fall through to Right\n            case Alignment.Right:\n                style.left = left + spacing;\n                style.top = centerTop;\n                style.transform = \"translateY(-50%)\";\n                break;\n            case Alignment.Left:\n                style.right = right + spacing;\n                style.top = centerTop;\n                style.transform = \"translateY(-50%)\";\n                break;\n            case Alignment.Top:\n                style.top = baseTop - spacing;\n                // Attempt to center the tooltip on the element while clamping\n                // its horizontal translation to keep it on screen\n                // eslint-disable-next-line max-len\n                style.transform = `translate(max(10px, min(calc(${horizontalCenter}px - 50%), calc(100vw - 100% - 10px))), -100%)`;\n                break;\n            case Alignment.Bottom:\n                style.top = baseTop + parentBox.height + spacing;\n                // Attempt to center the tooltip on the element while clamping\n                // its horizontal translation to keep it on screen\n                // eslint-disable-next-line max-len\n                style.transform = `translate(max(10px, min(calc(${horizontalCenter}px - 50%), calc(100vw - 100% - 10px))))`;\n                break;\n            case Alignment.InnerBottom:\n                style.top = baseTop + parentBox.height - 50;\n                // Attempt to center the tooltip on the element while clamping\n                // its horizontal translation to keep it on screen\n                // eslint-disable-next-line max-len\n                style.transform = `translate(max(10px, min(calc(${horizontalCenter}px - 50%), calc(100vw - 100% - 10px))))`;\n                break;\n            case Alignment.TopRight:\n                style.top = baseTop - spacing;\n                style.right = width - parentBox.right - window.scrollX;\n                style.transform = \"translateY(-100%)\";\n                break;\n        }\n\n        this.setState(style);\n    };\n\n    public render(): React.ReactNode {\n        const tooltipClasses = classNames(\"mx_Tooltip\", this.props.tooltipClassName, {\n            mx_Tooltip_visible: this.props.visible,\n            mx_Tooltip_invisible: !this.props.visible,\n        });\n\n        const style = { ...this.state };\n        // Hide the entire container when not visible.\n        // This prevents flashing of the tooltip if it is not meant to be visible on first mount.\n        style.display = this.props.visible ? \"block\" : \"none\";\n\n        const tooltip = (\n            <div id={this.props.id} role={this.props.role || \"tooltip\"} className={tooltipClasses} style={style}>\n                <div className=\"mx_Tooltip_chevron\" />\n                {this.props.label}\n            </div>\n        );\n\n        return <div className={this.props.className}>{ReactDOM.createPortal(tooltip, Tooltip.container)}</div>;\n    }\n}\n"],"mappings":"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","ignoreList":[]}