UNPKG

matrix-react-sdk

Version:
180 lines (172 loc) 30.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _AutoHideScrollbar = _interopRequireDefault(require("./AutoHideScrollbar")); var _UIStore = _interopRequireWildcard(require("../../stores/UIStore")); const _excluded = ["children", "trackHorizontalOverflow", "verticalScrollsHorizontally"]; /* Copyright 2018-2024 New Vector Ltd. 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; } class IndicatorScrollbar extends _react.default.Component { // ts in milliseconds to recheck this._likelyTrackpadUser constructor(props) { super(props); (0, _defineProperty2.default)(this, "autoHideScrollbar", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2.default)(this, "scrollElement", void 0); (0, _defineProperty2.default)(this, "likelyTrackpadUser", null); (0, _defineProperty2.default)(this, "checkAgainForTrackpad", 0); (0, _defineProperty2.default)(this, "collectScroller", scroller => { this.props.wrappedRef?.(scroller); if (scroller && !this.scrollElement) { this.scrollElement = scroller; // Using the passive option to not block the main thread // https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#improving_scrolling_performance_with_passive_listeners this.scrollElement.addEventListener("scroll", this.checkOverflow, { passive: true }); this.checkOverflow(); } }); (0, _defineProperty2.default)(this, "checkOverflow", () => { if (!this.scrollElement) return; const hasTopOverflow = this.scrollElement.scrollTop > 0; const hasBottomOverflow = this.scrollElement.scrollHeight > this.scrollElement.scrollTop + this.scrollElement.clientHeight; const hasLeftOverflow = this.scrollElement.scrollLeft > 0; const hasRightOverflow = this.scrollElement.scrollWidth > this.scrollElement.scrollLeft + this.scrollElement.clientWidth; if (hasTopOverflow) { this.scrollElement.classList.add("mx_IndicatorScrollbar_topOverflow"); } else { this.scrollElement.classList.remove("mx_IndicatorScrollbar_topOverflow"); } if (hasBottomOverflow) { this.scrollElement.classList.add("mx_IndicatorScrollbar_bottomOverflow"); } else { this.scrollElement.classList.remove("mx_IndicatorScrollbar_bottomOverflow"); } if (hasLeftOverflow) { this.scrollElement.classList.add("mx_IndicatorScrollbar_leftOverflow"); } else { this.scrollElement.classList.remove("mx_IndicatorScrollbar_leftOverflow"); } if (hasRightOverflow) { this.scrollElement.classList.add("mx_IndicatorScrollbar_rightOverflow"); } else { this.scrollElement.classList.remove("mx_IndicatorScrollbar_rightOverflow"); } if (this.props.trackHorizontalOverflow) { this.setState({ // Offset from absolute position of the container leftIndicatorOffset: hasLeftOverflow ? `${this.scrollElement.scrollLeft}px` : "0", // Negative because we're coming from the right rightIndicatorOffset: hasRightOverflow ? `-${this.scrollElement.scrollLeft}px` : "0" }); } }); (0, _defineProperty2.default)(this, "onMouseWheel", e => { if (this.props.verticalScrollsHorizontally && this.scrollElement) { // xyThreshold is the amount of horizontal motion required for the component to // ignore the vertical delta in a scroll. Used to stop trackpads from acting in // strange ways. Should be positive. const xyThreshold = 0; // yRetention is the factor multiplied by the vertical delta to try and reduce // the harshness of the scroll behaviour. Should be a value between 0 and 1. const yRetention = 1.0; // whenever we see horizontal scrolling, assume the user is on a trackpad // for at least the next 1 minute. const now = new Date().getTime(); if (Math.abs(e.deltaX) > 0) { this.likelyTrackpadUser = true; this.checkAgainForTrackpad = now + 1 * 60 * 1000; } else { // if we haven't seen any horizontal scrolling for a while, assume // the user might have plugged in a mousewheel if (this.likelyTrackpadUser && now >= this.checkAgainForTrackpad) { this.likelyTrackpadUser = false; } } // don't mess with the horizontal scroll for trackpad users // See https://github.com/vector-im/element-web/issues/10005 if (this.likelyTrackpadUser) { return; } if (Math.abs(e.deltaX) <= xyThreshold) { // we are vertically scrolling. // HACK: We increase the amount of scroll to counteract smooth scrolling browsers. // Smooth scrolling browsers (Firefox) use the relative area to determine the scroll // amount, which means the likely small area of content results in a small amount of // movement - not what people expect. We pick arbitrary values for when to apply more // scroll, and how much to apply. On Windows 10, Chrome scrolls 100 units whereas // Firefox scrolls just 3 due to smooth scrolling. const additionalScroll = e.deltaY < 0 ? -50 : 50; // noinspection JSSuspiciousNameCombination const val = Math.abs(e.deltaY) < 25 ? e.deltaY + additionalScroll : e.deltaY; this.scrollElement.scrollLeft += val * yRetention; } } }); this.state = { leftIndicatorOffset: "0", rightIndicatorOffset: "0" }; } componentDidUpdate(prevProps) { const prevLen = _react.default.Children.count(prevProps.children); const curLen = _react.default.Children.count(this.props.children); // check overflow only if amount of children changes. // if we don't guard here, we end up with an infinite // render > componentDidUpdate > checkOverflow > setState > render loop if (prevLen !== curLen) { this.checkOverflow(); } } componentDidMount() { this.checkOverflow(); _UIStore.default.instance.on(_UIStore.UI_EVENTS.Resize, this.checkOverflow); } componentWillUnmount() { this.scrollElement?.removeEventListener("scroll", this.checkOverflow); _UIStore.default.instance.off(_UIStore.UI_EVENTS.Resize, this.checkOverflow); } render() { // eslint-disable-next-line @typescript-eslint/no-unused-vars const _this$props = this.props, { children, trackHorizontalOverflow, verticalScrollsHorizontally } = _this$props, otherProps = (0, _objectWithoutProperties2.default)(_this$props, _excluded); const leftIndicatorStyle = { left: this.state.leftIndicatorOffset }; const rightIndicatorStyle = { right: this.state.rightIndicatorOffset }; const leftOverflowIndicator = trackHorizontalOverflow ? /*#__PURE__*/_react.default.createElement("div", { className: "mx_IndicatorScrollbar_leftOverflowIndicator", style: leftIndicatorStyle }) : null; const rightOverflowIndicator = trackHorizontalOverflow ? /*#__PURE__*/_react.default.createElement("div", { className: "mx_IndicatorScrollbar_rightOverflowIndicator", style: rightIndicatorStyle }) : null; return /*#__PURE__*/_react.default.createElement(_AutoHideScrollbar.default, (0, _extends2.default)({}, otherProps, { ref: this.autoHideScrollbar, wrappedRef: this.collectScroller, onWheel: this.onMouseWheel }), leftOverflowIndicator, children, rightOverflowIndicator); } } exports.default = IndicatorScrollbar; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_AutoHideScrollbar","_interopRequireDefault","_UIStore","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","IndicatorScrollbar","React","Component","constructor","props","_defineProperty2","createRef","scroller","wrappedRef","scrollElement","addEventListener","checkOverflow","passive","hasTopOverflow","scrollTop","hasBottomOverflow","scrollHeight","clientHeight","hasLeftOverflow","scrollLeft","hasRightOverflow","scrollWidth","clientWidth","classList","add","remove","trackHorizontalOverflow","setState","leftIndicatorOffset","rightIndicatorOffset","verticalScrollsHorizontally","xyThreshold","yRetention","now","Date","getTime","Math","abs","deltaX","likelyTrackpadUser","checkAgainForTrackpad","additionalScroll","deltaY","val","state","componentDidUpdate","prevProps","prevLen","Children","count","children","curLen","componentDidMount","UIStore","instance","on","UI_EVENTS","Resize","componentWillUnmount","removeEventListener","off","render","_this$props","otherProps","_objectWithoutProperties2","leftIndicatorStyle","left","rightIndicatorStyle","right","leftOverflowIndicator","createElement","className","style","rightOverflowIndicator","_extends2","ref","autoHideScrollbar","collectScroller","onWheel","onMouseWheel","exports"],"sources":["../../../src/components/structures/IndicatorScrollbar.tsx"],"sourcesContent":["/*\nCopyright 2018-2024 New Vector 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, { createRef } from \"react\";\n\nimport AutoHideScrollbar, { IProps as AutoHideScrollbarProps } from \"./AutoHideScrollbar\";\nimport UIStore, { UI_EVENTS } from \"../../stores/UIStore\";\n\nexport type IProps<T extends keyof JSX.IntrinsicElements> = Omit<AutoHideScrollbarProps<T>, \"onWheel\" | \"element\"> & {\n    element?: T;\n    // If true, the scrollbar will append mx_IndicatorScrollbar_leftOverflowIndicator\n    // and mx_IndicatorScrollbar_rightOverflowIndicator elements to the list for positioning\n    // by the parent element.\n    trackHorizontalOverflow?: boolean;\n\n    // If true, when the user tries to use their mouse wheel in the component it will\n    // scroll horizontally rather than vertically. This should only be used on components\n    // with no vertical scroll opportunity.\n    verticalScrollsHorizontally?: boolean;\n\n    children: React.ReactNode;\n};\n\ninterface IState {\n    leftIndicatorOffset: string;\n    rightIndicatorOffset: string;\n}\n\nexport default class IndicatorScrollbar<T extends keyof JSX.IntrinsicElements> extends React.Component<\n    IProps<T>,\n    IState\n> {\n    private autoHideScrollbar = createRef<AutoHideScrollbar<any>>();\n    private scrollElement?: HTMLDivElement;\n    private likelyTrackpadUser: boolean | null = null;\n    private checkAgainForTrackpad = 0; // ts in milliseconds to recheck this._likelyTrackpadUser\n\n    public constructor(props: IProps<T>) {\n        super(props);\n\n        this.state = {\n            leftIndicatorOffset: \"0\",\n            rightIndicatorOffset: \"0\",\n        };\n    }\n\n    private collectScroller = (scroller: HTMLDivElement): void => {\n        this.props.wrappedRef?.(scroller);\n        if (scroller && !this.scrollElement) {\n            this.scrollElement = scroller;\n            // Using the passive option to not block the main thread\n            // https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#improving_scrolling_performance_with_passive_listeners\n            this.scrollElement.addEventListener(\"scroll\", this.checkOverflow, { passive: true });\n            this.checkOverflow();\n        }\n    };\n\n    public componentDidUpdate(prevProps: IProps<T>): void {\n        const prevLen = React.Children.count(prevProps.children);\n        const curLen = React.Children.count(this.props.children);\n        // check overflow only if amount of children changes.\n        // if we don't guard here, we end up with an infinite\n        // render > componentDidUpdate > checkOverflow > setState > render loop\n        if (prevLen !== curLen) {\n            this.checkOverflow();\n        }\n    }\n\n    public componentDidMount(): void {\n        this.checkOverflow();\n        UIStore.instance.on(UI_EVENTS.Resize, this.checkOverflow);\n    }\n\n    private checkOverflow = (): void => {\n        if (!this.scrollElement) return;\n        const hasTopOverflow = this.scrollElement.scrollTop > 0;\n        const hasBottomOverflow =\n            this.scrollElement.scrollHeight > this.scrollElement.scrollTop + this.scrollElement.clientHeight;\n        const hasLeftOverflow = this.scrollElement.scrollLeft > 0;\n        const hasRightOverflow =\n            this.scrollElement.scrollWidth > this.scrollElement.scrollLeft + this.scrollElement.clientWidth;\n\n        if (hasTopOverflow) {\n            this.scrollElement.classList.add(\"mx_IndicatorScrollbar_topOverflow\");\n        } else {\n            this.scrollElement.classList.remove(\"mx_IndicatorScrollbar_topOverflow\");\n        }\n        if (hasBottomOverflow) {\n            this.scrollElement.classList.add(\"mx_IndicatorScrollbar_bottomOverflow\");\n        } else {\n            this.scrollElement.classList.remove(\"mx_IndicatorScrollbar_bottomOverflow\");\n        }\n        if (hasLeftOverflow) {\n            this.scrollElement.classList.add(\"mx_IndicatorScrollbar_leftOverflow\");\n        } else {\n            this.scrollElement.classList.remove(\"mx_IndicatorScrollbar_leftOverflow\");\n        }\n        if (hasRightOverflow) {\n            this.scrollElement.classList.add(\"mx_IndicatorScrollbar_rightOverflow\");\n        } else {\n            this.scrollElement.classList.remove(\"mx_IndicatorScrollbar_rightOverflow\");\n        }\n\n        if (this.props.trackHorizontalOverflow) {\n            this.setState({\n                // Offset from absolute position of the container\n                leftIndicatorOffset: hasLeftOverflow ? `${this.scrollElement.scrollLeft}px` : \"0\",\n\n                // Negative because we're coming from the right\n                rightIndicatorOffset: hasRightOverflow ? `-${this.scrollElement.scrollLeft}px` : \"0\",\n            });\n        }\n    };\n\n    public componentWillUnmount(): void {\n        this.scrollElement?.removeEventListener(\"scroll\", this.checkOverflow);\n        UIStore.instance.off(UI_EVENTS.Resize, this.checkOverflow);\n    }\n\n    private onMouseWheel = (e: React.WheelEvent): void => {\n        if (this.props.verticalScrollsHorizontally && this.scrollElement) {\n            // xyThreshold is the amount of horizontal motion required for the component to\n            // ignore the vertical delta in a scroll. Used to stop trackpads from acting in\n            // strange ways. Should be positive.\n            const xyThreshold = 0;\n\n            // yRetention is the factor multiplied by the vertical delta to try and reduce\n            // the harshness of the scroll behaviour. Should be a value between 0 and 1.\n            const yRetention = 1.0;\n\n            // whenever we see horizontal scrolling, assume the user is on a trackpad\n            // for at least the next 1 minute.\n            const now = new Date().getTime();\n            if (Math.abs(e.deltaX) > 0) {\n                this.likelyTrackpadUser = true;\n                this.checkAgainForTrackpad = now + 1 * 60 * 1000;\n            } else {\n                // if we haven't seen any horizontal scrolling for a while, assume\n                // the user might have plugged in a mousewheel\n                if (this.likelyTrackpadUser && now >= this.checkAgainForTrackpad) {\n                    this.likelyTrackpadUser = false;\n                }\n            }\n\n            // don't mess with the horizontal scroll for trackpad users\n            // See https://github.com/vector-im/element-web/issues/10005\n            if (this.likelyTrackpadUser) {\n                return;\n            }\n\n            if (Math.abs(e.deltaX) <= xyThreshold) {\n                // we are vertically scrolling.\n                // HACK: We increase the amount of scroll to counteract smooth scrolling browsers.\n                // Smooth scrolling browsers (Firefox) use the relative area to determine the scroll\n                // amount, which means the likely small area of content results in a small amount of\n                // movement - not what people expect. We pick arbitrary values for when to apply more\n                // scroll, and how much to apply. On Windows 10, Chrome scrolls 100 units whereas\n                // Firefox scrolls just 3 due to smooth scrolling.\n\n                const additionalScroll = e.deltaY < 0 ? -50 : 50;\n\n                // noinspection JSSuspiciousNameCombination\n                const val = Math.abs(e.deltaY) < 25 ? e.deltaY + additionalScroll : e.deltaY;\n                this.scrollElement.scrollLeft += val * yRetention;\n            }\n        }\n    };\n\n    public render(): React.ReactNode {\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        const { children, trackHorizontalOverflow, verticalScrollsHorizontally, ...otherProps } = this.props;\n\n        const leftIndicatorStyle = { left: this.state.leftIndicatorOffset };\n        const rightIndicatorStyle = { right: this.state.rightIndicatorOffset };\n        const leftOverflowIndicator = trackHorizontalOverflow ? (\n            <div className=\"mx_IndicatorScrollbar_leftOverflowIndicator\" style={leftIndicatorStyle} />\n        ) : null;\n        const rightOverflowIndicator = trackHorizontalOverflow ? (\n            <div className=\"mx_IndicatorScrollbar_rightOverflowIndicator\" style={rightIndicatorStyle} />\n        ) : null;\n\n        return (\n            <AutoHideScrollbar\n                {...otherProps}\n                ref={this.autoHideScrollbar}\n                wrappedRef={this.collectScroller}\n                onWheel={this.onMouseWheel}\n            >\n                {leftOverflowIndicator}\n                {children}\n                {rightOverflowIndicator}\n            </AutoHideScrollbar>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}