matrix-react-sdk
Version:
SDK for matrix.org using React
299 lines (293 loc) • 49.9 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 _classnames = _interopRequireDefault(require("classnames"));
var _reResizable = require("re-resizable");
var _AppTile = _interopRequireDefault(require("../elements/AppTile"));
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var ScalarMessaging = _interopRequireWildcard(require("../../../ScalarMessaging"));
var _WidgetUtils = _interopRequireDefault(require("../../../utils/WidgetUtils"));
var _WidgetEchoStore = _interopRequireDefault(require("../../../stores/WidgetEchoStore"));
var _ResizeHandle = _interopRequireDefault(require("../elements/ResizeHandle"));
var _resizer = _interopRequireDefault(require("../../../resizer/resizer"));
var _percentage = _interopRequireDefault(require("../../../resizer/distributors/percentage"));
var _WidgetLayoutStore = require("../../../stores/widgets/WidgetLayoutStore");
var _numbers = require("../../../utils/numbers");
var _UIStore = _interopRequireDefault(require("../../../stores/UIStore"));
var _Spinner = _interopRequireDefault(require("../elements/Spinner"));
var _SdkConfig = _interopRequireDefault(require("../../../SdkConfig"));
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 2018-2024 New Vector Ltd.
Copyright 2017 Vector Creations 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 AppsDrawer extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "unmounted", false);
(0, _defineProperty2.default)(this, "resizeContainer", void 0);
(0, _defineProperty2.default)(this, "resizer", void 0);
(0, _defineProperty2.default)(this, "dispatcherRef", void 0);
(0, _defineProperty2.default)(this, "onIsResizing", resizing => {
// This one is the vertical, ie. change height of apps drawer
this.setState({
resizingVertical: resizing
});
if (!resizing) {
this.relaxResizer();
}
});
(0, _defineProperty2.default)(this, "collectResizer", ref => {
if (this.resizeContainer) {
this.resizer.detach();
}
if (ref) {
this.resizer.container = ref;
this.resizer.attach();
}
this.resizeContainer = ref;
this.loadResizerPreferences();
});
(0, _defineProperty2.default)(this, "getAppsHash", apps => apps.map(app => app.id).join("~"));
(0, _defineProperty2.default)(this, "relaxResizer", () => {
const distributors = this.resizer.getDistributors();
// relax all items if they had any overconstrained flexboxes
distributors.forEach(d => d.start());
distributors.forEach(d => d.finish());
});
(0, _defineProperty2.default)(this, "loadResizerPreferences", () => {
const distributions = _WidgetLayoutStore.WidgetLayoutStore.instance.getResizerDistributions(this.props.room, _WidgetLayoutStore.Container.Top);
if (this.state.apps && this.topApps().length - 1 === distributions.length) {
distributions.forEach((size, i) => {
const distributor = this.resizer.forHandleAt(i);
if (distributor) {
distributor.size = size;
distributor.finish();
}
});
} else if (this.state.apps) {
const distributors = this.resizer.getDistributors();
distributors.forEach(d => d.item.clearSize());
distributors.forEach(d => d.start());
distributors.forEach(d => d.finish());
}
});
(0, _defineProperty2.default)(this, "onAction", action => {
const hideWidgetKey = this.props.room.roomId + "_hide_widget_drawer";
switch (action.action) {
case "appsDrawer":
// Note: these booleans are awkward because localstorage is fundamentally
// string-based. We also do exact equality on the strings later on.
if (action.show) {
localStorage.setItem(hideWidgetKey, "false");
} else {
// Store hidden state of widget
// Don't show if previously hidden
localStorage.setItem(hideWidgetKey, "true");
}
break;
}
});
(0, _defineProperty2.default)(this, "getApps", () => ({
[_WidgetLayoutStore.Container.Top]: _WidgetLayoutStore.WidgetLayoutStore.instance.getContainerWidgets(this.props.room, _WidgetLayoutStore.Container.Top),
[_WidgetLayoutStore.Container.Center]: _WidgetLayoutStore.WidgetLayoutStore.instance.getContainerWidgets(this.props.room, _WidgetLayoutStore.Container.Center)
}));
(0, _defineProperty2.default)(this, "topApps", () => this.state.apps[_WidgetLayoutStore.Container.Top]);
(0, _defineProperty2.default)(this, "centerApps", () => this.state.apps[_WidgetLayoutStore.Container.Center]);
(0, _defineProperty2.default)(this, "updateApps", () => {
if (this.unmounted) return;
this.setState({
apps: this.getApps()
});
});
this.state = {
apps: this.getApps(),
resizingVertical: false,
resizingHorizontal: false,
resizing: false
};
this.resizer = this.createResizer();
this.props.resizeNotifier.on("isResizing", this.onIsResizing);
}
componentDidMount() {
ScalarMessaging.startListening();
_WidgetLayoutStore.WidgetLayoutStore.instance.on(_WidgetLayoutStore.WidgetLayoutStore.emissionForRoom(this.props.room), this.updateApps);
this.dispatcherRef = _dispatcher.default.register(this.onAction);
}
componentWillUnmount() {
this.unmounted = true;
ScalarMessaging.stopListening();
_WidgetLayoutStore.WidgetLayoutStore.instance.off(_WidgetLayoutStore.WidgetLayoutStore.emissionForRoom(this.props.room), this.updateApps);
if (this.dispatcherRef) _dispatcher.default.unregister(this.dispatcherRef);
if (this.resizeContainer) {
this.resizer.detach();
}
this.props.resizeNotifier.off("isResizing", this.onIsResizing);
}
createResizer() {
// This is the horizontal one, changing the distribution of the width between the app tiles
// (ie. a vertical resize handle because, the handle itself is vertical...)
const classNames = {
handle: "mx_ResizeHandle",
vertical: "mx_ResizeHandle--vertical",
reverse: "mx_ResizeHandle_reverse"
};
const collapseConfig = {
onResizeStart: () => {
this.resizeContainer?.classList.add("mx_AppsDrawer--resizing");
this.setState({
resizingHorizontal: true
});
},
onResizeStop: () => {
this.resizeContainer?.classList.remove("mx_AppsDrawer--resizing");
_WidgetLayoutStore.WidgetLayoutStore.instance.setResizerDistributions(this.props.room, _WidgetLayoutStore.Container.Top, this.topApps().slice(1).map((_, i) => this.resizer.forHandleAt(i).size));
this.setState({
resizingHorizontal: false
});
}
};
// pass a truthy container for now, we won't call attach until we update it
const resizer = new _resizer.default(null, _percentage.default, collapseConfig);
resizer.setClassNames(classNames);
return resizer;
}
componentDidUpdate(prevProps, prevState) {
if (prevProps.userId !== this.props.userId || prevProps.room !== this.props.room) {
// Room has changed, update apps
this.updateApps();
} else if (this.getAppsHash(this.topApps()) !== this.getAppsHash(prevState.apps[_WidgetLayoutStore.Container.Top])) {
this.loadResizerPreferences();
}
}
isResizing() {
return this.state.resizingVertical || this.state.resizingHorizontal;
}
render() {
if (!this.props.showApps) return /*#__PURE__*/_react.default.createElement("div", null);
const widgetIsMaxmised = this.centerApps().length > 0;
const appsToDisplay = widgetIsMaxmised ? this.centerApps() : this.topApps();
const apps = appsToDisplay.map((app, index, arr) => {
return /*#__PURE__*/_react.default.createElement(_AppTile.default, {
key: app.id,
app: app,
fullWidth: arr.length < 2,
room: this.props.room,
userId: this.props.userId,
creatorUserId: app.creatorUserId,
widgetPageTitle: _WidgetUtils.default.getWidgetDataTitle(app),
waitForIframeLoad: app.waitForIframeLoad,
pointerEvents: this.isResizing() ? "none" : undefined
});
});
if (apps.length === 0) {
return /*#__PURE__*/_react.default.createElement("div", null);
}
let spinner;
if (apps.length === 0 && _WidgetEchoStore.default.roomHasPendingWidgets(this.props.room.roomId, _WidgetUtils.default.getRoomWidgets(this.props.room))) {
spinner = /*#__PURE__*/_react.default.createElement(_Spinner.default, null);
}
const classes = (0, _classnames.default)({
"mx_AppsDrawer": true,
"mx_AppsDrawer--maximised": widgetIsMaxmised,
"mx_AppsDrawer--resizing": this.state.resizing,
"mx_AppsDrawer--2apps": apps.length === 2,
"mx_AppsDrawer--3apps": apps.length === 3
});
const appContainers = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AppsContainer",
ref: this.collectResizer
}, apps.map((app, i) => {
if (i < 1) return app;
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, {
key: app.key
}, /*#__PURE__*/_react.default.createElement(_ResizeHandle.default, {
reverse: i > apps.length / 2
}), app);
}));
let drawer;
if (widgetIsMaxmised) {
drawer = appContainers;
} else {
drawer = /*#__PURE__*/_react.default.createElement(PersistentVResizer, {
room: this.props.room,
minHeight: 100,
maxHeight: this.props.maxHeight - 50,
className: "mx_AppsDrawer_resizer",
handleWrapperClass: "mx_AppsDrawer_resizer_container",
handleClass: "mx_AppsDrawer_resizer_container_handle",
resizeNotifier: this.props.resizeNotifier
}, appContainers);
}
return /*#__PURE__*/_react.default.createElement("div", {
role: this.props.role,
className: classes
}, drawer, spinner);
}
}
exports.default = AppsDrawer;
(0, _defineProperty2.default)(AppsDrawer, "defaultProps", {
showApps: true
});
const PersistentVResizer = ({
room,
minHeight,
maxHeight,
className,
handleWrapperClass,
handleClass,
resizeNotifier,
children
}) => {
let defaultHeight = _WidgetLayoutStore.WidgetLayoutStore.instance.getContainerHeight(room, _WidgetLayoutStore.Container.Top);
// Arbitrary defaults to avoid NaN problems. 100 px or 3/4 of the visible window.
if (!minHeight) minHeight = 100;
if (!maxHeight) maxHeight = _UIStore.default.instance.windowHeight / 4 * 3;
// Convert from percentage to height. Note that the default height is 280px.
if (defaultHeight) {
defaultHeight = (0, _numbers.clamp)(defaultHeight, 0, 100);
defaultHeight = (0, _numbers.percentageWithin)(defaultHeight / 100, minHeight, maxHeight);
} else {
defaultHeight = _SdkConfig.default.get().default_widget_container_height ?? 280;
}
return /*#__PURE__*/_react.default.createElement(_reResizable.Resizable
// types do not support undefined height/width
// but resizable code checks specifically for undefined on Size prop
, {
size: {
height: Math.min(defaultHeight, maxHeight),
width: undefined
},
minHeight: minHeight,
maxHeight: maxHeight,
onResizeStart: () => {
resizeNotifier.startResizing();
},
onResize: () => {
resizeNotifier.notifyTimelineHeightChanged();
},
onResizeStop: (e, dir, ref, d) => {
let newHeight = defaultHeight + d.height;
newHeight = (0, _numbers.percentageOf)(newHeight, minHeight, maxHeight) * 100;
_WidgetLayoutStore.WidgetLayoutStore.instance.setContainerHeight(room, _WidgetLayoutStore.Container.Top, newHeight);
resizeNotifier.stopResizing();
},
className: className,
handleWrapperClass: handleWrapperClass,
handleClasses: {
bottom: handleClass
},
enable: {
bottom: true
}
}, children);
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_reResizable","_AppTile","_dispatcher","ScalarMessaging","_interopRequireWildcard","_WidgetUtils","_WidgetEchoStore","_ResizeHandle","_resizer","_percentage","_WidgetLayoutStore","_numbers","_UIStore","_Spinner","_SdkConfig","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","AppsDrawer","React","Component","constructor","props","_defineProperty2","resizing","setState","resizingVertical","relaxResizer","ref","resizeContainer","resizer","detach","container","attach","loadResizerPreferences","apps","map","app","id","join","distributors","getDistributors","forEach","d","start","finish","distributions","WidgetLayoutStore","instance","getResizerDistributions","room","Container","Top","state","topApps","length","size","distributor","forHandleAt","item","clearSize","action","hideWidgetKey","roomId","show","localStorage","setItem","getContainerWidgets","Center","unmounted","getApps","resizingHorizontal","createResizer","resizeNotifier","on","onIsResizing","componentDidMount","startListening","emissionForRoom","updateApps","dispatcherRef","dis","register","onAction","componentWillUnmount","stopListening","off","unregister","classNames","handle","vertical","reverse","collapseConfig","onResizeStart","classList","add","onResizeStop","remove","setResizerDistributions","slice","_","Resizer","PercentageDistributor","setClassNames","componentDidUpdate","prevProps","prevState","userId","getAppsHash","isResizing","render","showApps","createElement","widgetIsMaxmised","centerApps","appsToDisplay","index","arr","key","fullWidth","creatorUserId","widgetPageTitle","WidgetUtils","getWidgetDataTitle","waitForIframeLoad","pointerEvents","undefined","spinner","WidgetEchoStore","roomHasPendingWidgets","getRoomWidgets","classes","appContainers","className","collectResizer","Fragment","drawer","PersistentVResizer","minHeight","maxHeight","handleWrapperClass","handleClass","role","exports","children","defaultHeight","getContainerHeight","UIStore","windowHeight","clamp","percentageWithin","SdkConfig","default_widget_container_height","Resizable","height","Math","min","width","startResizing","onResize","notifyTimelineHeightChanged","dir","newHeight","percentageOf","setContainerHeight","stopResizing","handleClasses","bottom","enable"],"sources":["../../../../src/components/views/rooms/AppsDrawer.tsx"],"sourcesContent":["/*\nCopyright 2018-2024 New Vector Ltd.\nCopyright 2017 Vector Creations 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, { AriaRole } from \"react\";\nimport classNames from \"classnames\";\nimport { Resizable, Size } from \"re-resizable\";\nimport { Room } from \"matrix-js-sdk/src/matrix\";\nimport { IWidget } from \"matrix-widget-api\";\n\nimport AppTile from \"../elements/AppTile\";\nimport dis from \"../../../dispatcher/dispatcher\";\nimport * as ScalarMessaging from \"../../../ScalarMessaging\";\nimport WidgetUtils from \"../../../utils/WidgetUtils\";\nimport WidgetEchoStore from \"../../../stores/WidgetEchoStore\";\nimport ResizeNotifier from \"../../../utils/ResizeNotifier\";\nimport ResizeHandle from \"../elements/ResizeHandle\";\nimport Resizer, { IConfig } from \"../../../resizer/resizer\";\nimport PercentageDistributor from \"../../../resizer/distributors/percentage\";\nimport { Container, WidgetLayoutStore } from \"../../../stores/widgets/WidgetLayoutStore\";\nimport { clamp, percentageOf, percentageWithin } from \"../../../utils/numbers\";\nimport UIStore from \"../../../stores/UIStore\";\nimport { ActionPayload } from \"../../../dispatcher/payloads\";\nimport Spinner from \"../elements/Spinner\";\nimport SdkConfig from \"../../../SdkConfig\";\n\ninterface IProps {\n    userId: string;\n    room: Room;\n    resizeNotifier: ResizeNotifier;\n    showApps?: boolean; // Should apps be rendered\n    maxHeight: number;\n    role?: AriaRole;\n}\n\ninterface IState {\n    apps: {\n        [Container.Top]: IWidget[];\n        [Container.Center]: IWidget[];\n        [Container.Right]?: IWidget[];\n    };\n    resizingVertical: boolean; // true when changing the height of the apps drawer\n    resizingHorizontal: boolean; // true when changing the distribution of the width between widgets\n    resizing: boolean;\n}\n\nexport default class AppsDrawer extends React.Component<IProps, IState> {\n    private unmounted = false;\n    private resizeContainer?: HTMLDivElement;\n    private resizer: Resizer<IConfig>;\n    private dispatcherRef?: string;\n    public static defaultProps: Partial<IProps> = {\n        showApps: true,\n    };\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            apps: this.getApps(),\n            resizingVertical: false,\n            resizingHorizontal: false,\n            resizing: false,\n        };\n\n        this.resizer = this.createResizer();\n\n        this.props.resizeNotifier.on(\"isResizing\", this.onIsResizing);\n    }\n\n    public componentDidMount(): void {\n        ScalarMessaging.startListening();\n        WidgetLayoutStore.instance.on(WidgetLayoutStore.emissionForRoom(this.props.room), this.updateApps);\n        this.dispatcherRef = dis.register(this.onAction);\n    }\n\n    public componentWillUnmount(): void {\n        this.unmounted = true;\n        ScalarMessaging.stopListening();\n        WidgetLayoutStore.instance.off(WidgetLayoutStore.emissionForRoom(this.props.room), this.updateApps);\n        if (this.dispatcherRef) dis.unregister(this.dispatcherRef);\n        if (this.resizeContainer) {\n            this.resizer.detach();\n        }\n        this.props.resizeNotifier.off(\"isResizing\", this.onIsResizing);\n    }\n\n    private onIsResizing = (resizing: boolean): void => {\n        // This one is the vertical, ie. change height of apps drawer\n        this.setState({ resizingVertical: resizing });\n        if (!resizing) {\n            this.relaxResizer();\n        }\n    };\n\n    private createResizer(): Resizer<IConfig> {\n        // This is the horizontal one, changing the distribution of the width between the app tiles\n        // (ie. a vertical resize handle because, the handle itself is vertical...)\n        const classNames = {\n            handle: \"mx_ResizeHandle\",\n            vertical: \"mx_ResizeHandle--vertical\",\n            reverse: \"mx_ResizeHandle_reverse\",\n        };\n        const collapseConfig = {\n            onResizeStart: () => {\n                this.resizeContainer?.classList.add(\"mx_AppsDrawer--resizing\");\n                this.setState({ resizingHorizontal: true });\n            },\n            onResizeStop: () => {\n                this.resizeContainer?.classList.remove(\"mx_AppsDrawer--resizing\");\n                WidgetLayoutStore.instance.setResizerDistributions(\n                    this.props.room,\n                    Container.Top,\n                    this.topApps()\n                        .slice(1)\n                        .map((_, i) => this.resizer.forHandleAt(i)!.size),\n                );\n                this.setState({ resizingHorizontal: false });\n            },\n        };\n        // pass a truthy container for now, we won't call attach until we update it\n        const resizer = new Resizer(null, PercentageDistributor, collapseConfig);\n        resizer.setClassNames(classNames);\n        return resizer;\n    }\n\n    private collectResizer = (ref: HTMLDivElement): void => {\n        if (this.resizeContainer) {\n            this.resizer.detach();\n        }\n\n        if (ref) {\n            this.resizer.container = ref;\n            this.resizer.attach();\n        }\n        this.resizeContainer = ref;\n        this.loadResizerPreferences();\n    };\n\n    private getAppsHash = (apps: IWidget[]): string => apps.map((app) => app.id).join(\"~\");\n\n    public componentDidUpdate(prevProps: IProps, prevState: IState): void {\n        if (prevProps.userId !== this.props.userId || prevProps.room !== this.props.room) {\n            // Room has changed, update apps\n            this.updateApps();\n        } else if (this.getAppsHash(this.topApps()) !== this.getAppsHash(prevState.apps[Container.Top])) {\n            this.loadResizerPreferences();\n        }\n    }\n\n    private relaxResizer = (): void => {\n        const distributors = this.resizer.getDistributors();\n\n        // relax all items if they had any overconstrained flexboxes\n        distributors.forEach((d) => d.start());\n        distributors.forEach((d) => d.finish());\n    };\n\n    private loadResizerPreferences = (): void => {\n        const distributions = WidgetLayoutStore.instance.getResizerDistributions(this.props.room, Container.Top);\n        if (this.state.apps && this.topApps().length - 1 === distributions.length) {\n            distributions.forEach((size, i) => {\n                const distributor = this.resizer.forHandleAt(i);\n                if (distributor) {\n                    distributor.size = size;\n                    distributor.finish();\n                }\n            });\n        } else if (this.state.apps) {\n            const distributors = this.resizer.getDistributors();\n            distributors.forEach((d) => d.item.clearSize());\n            distributors.forEach((d) => d.start());\n            distributors.forEach((d) => d.finish());\n        }\n    };\n\n    private isResizing(): boolean {\n        return this.state.resizingVertical || this.state.resizingHorizontal;\n    }\n\n    private onAction = (action: ActionPayload): void => {\n        const hideWidgetKey = this.props.room.roomId + \"_hide_widget_drawer\";\n        switch (action.action) {\n            case \"appsDrawer\":\n                // Note: these booleans are awkward because localstorage is fundamentally\n                // string-based. We also do exact equality on the strings later on.\n                if (action.show) {\n                    localStorage.setItem(hideWidgetKey, \"false\");\n                } else {\n                    // Store hidden state of widget\n                    // Don't show if previously hidden\n                    localStorage.setItem(hideWidgetKey, \"true\");\n                }\n\n                break;\n        }\n    };\n\n    private getApps = (): IState[\"apps\"] => ({\n        [Container.Top]: WidgetLayoutStore.instance.getContainerWidgets(this.props.room, Container.Top),\n        [Container.Center]: WidgetLayoutStore.instance.getContainerWidgets(this.props.room, Container.Center),\n    });\n    private topApps = (): IWidget[] => this.state.apps[Container.Top];\n    private centerApps = (): IWidget[] => this.state.apps[Container.Center];\n\n    private updateApps = (): void => {\n        if (this.unmounted) return;\n        this.setState({\n            apps: this.getApps(),\n        });\n    };\n\n    public render(): React.ReactNode {\n        if (!this.props.showApps) return <div />;\n        const widgetIsMaxmised: boolean = this.centerApps().length > 0;\n        const appsToDisplay = widgetIsMaxmised ? this.centerApps() : this.topApps();\n        const apps = appsToDisplay.map((app, index, arr) => {\n            return (\n                <AppTile\n                    key={app.id}\n                    app={app}\n                    fullWidth={arr.length < 2}\n                    room={this.props.room}\n                    userId={this.props.userId}\n                    creatorUserId={app.creatorUserId}\n                    widgetPageTitle={WidgetUtils.getWidgetDataTitle(app)}\n                    waitForIframeLoad={app.waitForIframeLoad}\n                    pointerEvents={this.isResizing() ? \"none\" : undefined}\n                />\n            );\n        });\n\n        if (apps.length === 0) {\n            return <div />;\n        }\n\n        let spinner;\n        if (\n            apps.length === 0 &&\n            WidgetEchoStore.roomHasPendingWidgets(this.props.room.roomId, WidgetUtils.getRoomWidgets(this.props.room))\n        ) {\n            spinner = <Spinner />;\n        }\n\n        const classes = classNames({\n            \"mx_AppsDrawer\": true,\n            \"mx_AppsDrawer--maximised\": widgetIsMaxmised,\n            \"mx_AppsDrawer--resizing\": this.state.resizing,\n            \"mx_AppsDrawer--2apps\": apps.length === 2,\n            \"mx_AppsDrawer--3apps\": apps.length === 3,\n        });\n        const appContainers = (\n            <div className=\"mx_AppsContainer\" ref={this.collectResizer}>\n                {apps.map((app, i) => {\n                    if (i < 1) return app;\n                    return (\n                        <React.Fragment key={app.key}>\n                            <ResizeHandle reverse={i > apps.length / 2} />\n                            {app}\n                        </React.Fragment>\n                    );\n                })}\n            </div>\n        );\n\n        let drawer;\n        if (widgetIsMaxmised) {\n            drawer = appContainers;\n        } else {\n            drawer = (\n                <PersistentVResizer\n                    room={this.props.room}\n                    minHeight={100}\n                    maxHeight={this.props.maxHeight - 50}\n                    className=\"mx_AppsDrawer_resizer\"\n                    handleWrapperClass=\"mx_AppsDrawer_resizer_container\"\n                    handleClass=\"mx_AppsDrawer_resizer_container_handle\"\n                    resizeNotifier={this.props.resizeNotifier}\n                >\n                    {appContainers}\n                </PersistentVResizer>\n            );\n        }\n\n        return (\n            <div role={this.props.role} className={classes}>\n                {drawer}\n                {spinner}\n            </div>\n        );\n    }\n}\n\ninterface IPersistentResizerProps {\n    room: Room;\n    minHeight: number;\n    maxHeight: number;\n    className: string;\n    handleWrapperClass: string;\n    handleClass: string;\n    resizeNotifier: ResizeNotifier;\n    children: React.ReactNode;\n}\n\nconst PersistentVResizer: React.FC<IPersistentResizerProps> = ({\n    room,\n    minHeight,\n    maxHeight,\n    className,\n    handleWrapperClass,\n    handleClass,\n    resizeNotifier,\n    children,\n}) => {\n    let defaultHeight = WidgetLayoutStore.instance.getContainerHeight(room, Container.Top);\n\n    // Arbitrary defaults to avoid NaN problems. 100 px or 3/4 of the visible window.\n    if (!minHeight) minHeight = 100;\n    if (!maxHeight) maxHeight = (UIStore.instance.windowHeight / 4) * 3;\n\n    // Convert from percentage to height. Note that the default height is 280px.\n    if (defaultHeight) {\n        defaultHeight = clamp(defaultHeight, 0, 100);\n        defaultHeight = percentageWithin(defaultHeight / 100, minHeight, maxHeight);\n    } else {\n        defaultHeight = SdkConfig.get().default_widget_container_height ?? 280;\n    }\n\n    return (\n        <Resizable\n            // types do not support undefined height/width\n            // but resizable code checks specifically for undefined on Size prop\n            size={{ height: Math.min(defaultHeight, maxHeight), width: undefined } as unknown as Size}\n            minHeight={minHeight}\n            maxHeight={maxHeight}\n            onResizeStart={() => {\n                resizeNotifier.startResizing();\n            }}\n            onResize={() => {\n                resizeNotifier.notifyTimelineHeightChanged();\n            }}\n            onResizeStop={(e, dir, ref, d) => {\n                let newHeight = defaultHeight! + d.height;\n                newHeight = percentageOf(newHeight, minHeight, maxHeight) * 100;\n\n                WidgetLayoutStore.instance.setContainerHeight(room, Container.Top, newHeight);\n\n                resizeNotifier.stopResizing();\n            }}\n            className={className}\n            handleWrapperClass={handleWrapperClass}\n            handleClasses={{ bottom: handleClass }}\n            enable={{ bottom: true }}\n        >\n            {children}\n        </Resizable>\n    );\n};\n"],"mappings":"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","ignoreList":[]}