* Move ResizerNotifier into SDKContext so we don't have to pass it into RoomView * Fix test * Unused import * Add tests * Remove a bunch of resizeNotifier props * Remove more resizeNotifier props * Add resizenotifier to test * Add more sdkcontext wrappers in tests * More sdkcontext wrappers * Even more sdkcontext wrappers * Add test to make sonarcloud happy * Context isn't always there unlike props * Test actual resizing too * Remove commented line
55 lines
1.7 KiB
TypeScript
55 lines
1.7 KiB
TypeScript
/*
|
|
Copyright 2024 New Vector Ltd.
|
|
Copyright 2015-2023 The Matrix.org Foundation C.I.C.
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
|
|
Please see LICENSE files in the repository root for full details.
|
|
*/
|
|
|
|
import React, { type ReactNode } from "react";
|
|
import { type Room } from "matrix-js-sdk/src/matrix";
|
|
|
|
import AppsDrawer from "./AppsDrawer";
|
|
import SettingsStore from "../../../settings/SettingsStore";
|
|
import AutoHideScrollbar from "../../structures/AutoHideScrollbar";
|
|
import { UIFeature } from "../../../settings/UIFeature";
|
|
import LegacyCallViewForRoom from "../voip/LegacyCallViewForRoom";
|
|
import { objectHasDiff } from "../../../utils/objects";
|
|
|
|
interface IProps {
|
|
// js-sdk room object
|
|
room: Room;
|
|
userId: string;
|
|
showApps: boolean; // Render apps
|
|
children?: ReactNode;
|
|
}
|
|
|
|
export default class AuxPanel extends React.Component<IProps> {
|
|
public static defaultProps = {
|
|
showApps: true,
|
|
};
|
|
|
|
public shouldComponentUpdate(nextProps: IProps): boolean {
|
|
return objectHasDiff(this.props, nextProps);
|
|
}
|
|
|
|
public render(): React.ReactNode {
|
|
const callView = <LegacyCallViewForRoom roomId={this.props.room.roomId} showApps={this.props.showApps} />;
|
|
|
|
let appsDrawer;
|
|
if (SettingsStore.getValue(UIFeature.Widgets)) {
|
|
appsDrawer = (
|
|
<AppsDrawer room={this.props.room} userId={this.props.userId} showApps={this.props.showApps} />
|
|
);
|
|
}
|
|
|
|
return (
|
|
<AutoHideScrollbar role="region" className="mx_AuxPanel">
|
|
{this.props.children}
|
|
{appsDrawer}
|
|
{callView}
|
|
</AutoHideScrollbar>
|
|
);
|
|
}
|
|
}
|