matrix-react-sdk
Version:
SDK for matrix.org using React
98 lines (95 loc) • 13.6 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _reResizable = require("re-resizable");
var _PosthogAnalytics = require("../../PosthogAnalytics.ts");
/*
Copyright 2024 New Vector Ltd.
Copyright 2019 The Matrix.org Foundation C.I.C.
Copyright 2018 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.
*/
class MainSplit extends _react.default.Component {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "onResizeStart", () => {
this.props.resizeNotifier.startResizing();
});
(0, _defineProperty2.default)(this, "onResize", () => {
this.props.resizeNotifier.notifyRightHandleResized();
});
(0, _defineProperty2.default)(this, "onResizeStop", (event, direction, elementRef, delta) => {
const newSize = this.loadSidePanelSize().width + delta.width;
this.props.resizeNotifier.stopResizing();
window.localStorage.setItem(this.sizeSettingStorageKey, newSize.toString());
_PosthogAnalytics.PosthogAnalytics.instance.trackEvent({
eventName: "WebPanelResize",
panel: "right",
roomType: this.props.analyticsRoomType,
size: newSize
});
});
}
get sizeSettingStorageKey() {
let key = "mx_rhs_size";
if (!!this.props.sizeKey) {
key += `_${this.props.sizeKey}`;
}
return key;
}
loadSidePanelSize() {
let rhsSize = parseInt(window.localStorage.getItem(this.sizeSettingStorageKey), 10);
if (isNaN(rhsSize)) {
rhsSize = this.props.defaultSize;
}
return {
height: "100%",
width: rhsSize
};
}
render() {
const bodyView = _react.default.Children.only(this.props.children);
const panelView = this.props.panel;
const hasResizer = !this.props.collapsedRhs && panelView;
let children;
if (hasResizer) {
children = /*#__PURE__*/_react.default.createElement(_reResizable.Resizable, {
key: this.props.sizeKey,
defaultSize: this.loadSidePanelSize(),
minWidth: 264,
maxWidth: "50%",
enable: {
top: false,
right: false,
bottom: false,
left: true,
topRight: false,
bottomRight: false,
bottomLeft: false,
topLeft: false
},
onResizeStart: this.onResizeStart,
onResize: this.onResize,
onResizeStop: this.onResizeStop,
className: "mx_RightPanel_ResizeWrapper",
handleClasses: {
left: "mx_ResizeHandle--horizontal"
}
}, panelView);
}
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MainSplit"
}, bodyView, children);
}
}
exports.default = MainSplit;
(0, _defineProperty2.default)(MainSplit, "defaultProps", {
defaultSize: 320
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_reResizable","_PosthogAnalytics","MainSplit","React","Component","constructor","args","_defineProperty2","default","props","resizeNotifier","startResizing","notifyRightHandleResized","event","direction","elementRef","delta","newSize","loadSidePanelSize","width","stopResizing","window","localStorage","setItem","sizeSettingStorageKey","toString","PosthogAnalytics","instance","trackEvent","eventName","panel","roomType","analyticsRoomType","size","key","sizeKey","rhsSize","parseInt","getItem","isNaN","defaultSize","height","render","bodyView","Children","only","children","panelView","hasResizer","collapsedRhs","createElement","Resizable","minWidth","maxWidth","enable","top","right","bottom","left","topRight","bottomRight","bottomLeft","topLeft","onResizeStart","onResize","onResizeStop","className","handleClasses","exports"],"sources":["../../../src/components/structures/MainSplit.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019 The Matrix.org Foundation C.I.C.\nCopyright 2018 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, { ReactNode } from \"react\";\nimport { NumberSize, Resizable } from \"re-resizable\";\nimport { Direction } from \"re-resizable/lib/resizer\";\nimport { WebPanelResize } from \"@matrix-org/analytics-events/types/typescript/WebPanelResize\";\n\nimport ResizeNotifier from \"../../utils/ResizeNotifier\";\nimport { PosthogAnalytics } from \"../../PosthogAnalytics.ts\";\n\ninterface IProps {\n    resizeNotifier: ResizeNotifier;\n    collapsedRhs?: boolean;\n    panel?: JSX.Element;\n    children: ReactNode;\n    /**\n     * A unique identifier for this panel split.\n     *\n     * This is appended to the key used to store the panel size in localStorage, allowing the widths of different\n     * panels to be stored.\n     */\n    sizeKey?: string;\n    /**\n     * The size to use for the panel component if one isn't persisted in storage. Defaults to 320.\n     */\n    defaultSize: number;\n\n    analyticsRoomType: WebPanelResize[\"roomType\"];\n}\n\nexport default class MainSplit extends React.Component<IProps> {\n    public static defaultProps = {\n        defaultSize: 320,\n    };\n\n    private onResizeStart = (): void => {\n        this.props.resizeNotifier.startResizing();\n    };\n\n    private onResize = (): void => {\n        this.props.resizeNotifier.notifyRightHandleResized();\n    };\n\n    private get sizeSettingStorageKey(): string {\n        let key = \"mx_rhs_size\";\n        if (!!this.props.sizeKey) {\n            key += `_${this.props.sizeKey}`;\n        }\n        return key;\n    }\n\n    private onResizeStop = (\n        event: MouseEvent | TouchEvent,\n        direction: Direction,\n        elementRef: HTMLElement,\n        delta: NumberSize,\n    ): void => {\n        const newSize = this.loadSidePanelSize().width + delta.width;\n        this.props.resizeNotifier.stopResizing();\n        window.localStorage.setItem(this.sizeSettingStorageKey, newSize.toString());\n\n        PosthogAnalytics.instance.trackEvent<WebPanelResize>({\n            eventName: \"WebPanelResize\",\n            panel: \"right\",\n            roomType: this.props.analyticsRoomType,\n            size: newSize,\n        });\n    };\n\n    private loadSidePanelSize(): { height: string | number; width: number } {\n        let rhsSize = parseInt(window.localStorage.getItem(this.sizeSettingStorageKey)!, 10);\n\n        if (isNaN(rhsSize)) {\n            rhsSize = this.props.defaultSize;\n        }\n\n        return {\n            height: \"100%\",\n            width: rhsSize,\n        };\n    }\n\n    public render(): React.ReactNode {\n        const bodyView = React.Children.only(this.props.children);\n        const panelView = this.props.panel;\n\n        const hasResizer = !this.props.collapsedRhs && panelView;\n\n        let children;\n        if (hasResizer) {\n            children = (\n                <Resizable\n                    key={this.props.sizeKey}\n                    defaultSize={this.loadSidePanelSize()}\n                    minWidth={264}\n                    maxWidth=\"50%\"\n                    enable={{\n                        top: false,\n                        right: false,\n                        bottom: false,\n                        left: true,\n                        topRight: false,\n                        bottomRight: false,\n                        bottomLeft: false,\n                        topLeft: false,\n                    }}\n                    onResizeStart={this.onResizeStart}\n                    onResize={this.onResize}\n                    onResizeStop={this.onResizeStop}\n                    className=\"mx_RightPanel_ResizeWrapper\"\n                    handleClasses={{ left: \"mx_ResizeHandle--horizontal\" }}\n                >\n                    {panelView}\n                </Resizable>\n            );\n        }\n\n        return (\n            <div className=\"mx_MainSplit\">\n                {bodyView}\n                {children}\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}