Make room model mandatory on the RoomHeader (#11355)

* Remove oobData from RoomHeader

It is never used as the RoomHeader is not shown unless a Room model exists

* Make room model mandatory on the RoomHeader
This commit is contained in:
Germain 2023-08-02 16:29:19 +01:00 committed by GitHub
parent 40442508de
commit d94808a197
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 8 additions and 76 deletions

View file

@ -297,7 +297,7 @@ function LocalRoomView(props: LocalRoomViewProps): ReactElement {
<div className="mx_RoomView mx_RoomView--local"> <div className="mx_RoomView mx_RoomView--local">
<ErrorBoundary> <ErrorBoundary>
{SettingsStore.getValue("feature_new_room_decoration_ui") ? ( {SettingsStore.getValue("feature_new_room_decoration_ui") ? (
<RoomHeader room={context.room} /> <RoomHeader room={room} />
) : ( ) : (
<LegacyRoomHeader <LegacyRoomHeader
room={context.room} room={context.room}
@ -345,16 +345,15 @@ interface ILocalRoomCreateLoaderProps {
* @return {ReactElement} * @return {ReactElement}
*/ */
function LocalRoomCreateLoader(props: ILocalRoomCreateLoaderProps): ReactElement { function LocalRoomCreateLoader(props: ILocalRoomCreateLoaderProps): ReactElement {
const context = useContext(RoomContext);
const text = _t("We're creating a room with %(names)s", { names: props.names }); const text = _t("We're creating a room with %(names)s", { names: props.names });
return ( return (
<div className="mx_RoomView mx_RoomView--local"> <div className="mx_RoomView mx_RoomView--local">
<ErrorBoundary> <ErrorBoundary>
{SettingsStore.getValue("feature_new_room_decoration_ui") ? ( {SettingsStore.getValue("feature_new_room_decoration_ui") ? (
<RoomHeader room={context.room} /> <RoomHeader room={props.localRoom} />
) : ( ) : (
<LegacyRoomHeader <LegacyRoomHeader
room={context.room} room={props.localRoom}
searchInfo={undefined} searchInfo={undefined}
inRoom={true} inRoom={true}
onSearchClick={null} onSearchClick={null}
@ -2470,7 +2469,7 @@ export class RoomView extends React.Component<IRoomProps, IRoomState> {
)} )}
<ErrorBoundary> <ErrorBoundary>
{SettingsStore.getValue("feature_new_room_decoration_ui") ? ( {SettingsStore.getValue("feature_new_room_decoration_ui") ? (
<RoomHeader room={this.state.room} oobData={this.props.oobData} /> <RoomHeader room={this.state.room} />
) : ( ) : (
<LegacyRoomHeader <LegacyRoomHeader
room={this.state.room} room={this.state.room}

View file

@ -51,7 +51,7 @@ export const WaitingForThirdPartyRoomView: React.FC<Props> = ({ roomView, resize
<div className="mx_RoomView mx_RoomView--local"> <div className="mx_RoomView mx_RoomView--local">
<ErrorBoundary> <ErrorBoundary>
{SettingsStore.getValue("feature_new_room_decoration_ui") ? ( {SettingsStore.getValue("feature_new_room_decoration_ui") ? (
<RoomHeader room={context.room} /> <RoomHeader room={context.room!} />
) : ( ) : (
<LegacyRoomHeader <LegacyRoomHeader
room={context.room} room={context.room}

View file

@ -18,16 +18,14 @@ import React from "react";
import { Body as BodyText } from "@vector-im/compound-web"; import { Body as BodyText } from "@vector-im/compound-web";
import type { Room } from "matrix-js-sdk/src/models/room"; import type { Room } from "matrix-js-sdk/src/models/room";
import { IOOBData } from "../../../stores/ThreepidInviteStore";
import { useRoomName } from "../../../hooks/useRoomName"; import { useRoomName } from "../../../hooks/useRoomName";
import DecoratedRoomAvatar from "../avatars/DecoratedRoomAvatar"; import DecoratedRoomAvatar from "../avatars/DecoratedRoomAvatar";
import { RightPanelPhases } from "../../../stores/right-panel/RightPanelStorePhases"; import { RightPanelPhases } from "../../../stores/right-panel/RightPanelStorePhases";
import RightPanelStore from "../../../stores/right-panel/RightPanelStore"; import RightPanelStore from "../../../stores/right-panel/RightPanelStore";
import { useTopic } from "../../../hooks/room/useTopic"; import { useTopic } from "../../../hooks/room/useTopic";
import RoomAvatar from "../avatars/RoomAvatar";
export default function RoomHeader({ room, oobData }: { room?: Room; oobData?: IOOBData }): JSX.Element { export default function RoomHeader({ room }: { room: Room }): JSX.Element {
const roomName = useRoomName(room, oobData); const roomName = useRoomName(room);
const roomTopic = useTopic(room); const roomTopic = useTopic(room);
return ( return (
@ -40,11 +38,7 @@ export default function RoomHeader({ room, oobData }: { room?: Room; oobData?: I
: rightPanel.setCard({ phase: RightPanelPhases.RoomSummary }); : rightPanel.setCard({ phase: RightPanelPhases.RoomSummary });
}} }}
> >
{room ? ( <DecoratedRoomAvatar room={room} avatarSize={40} displayBadge={false} />
<DecoratedRoomAvatar room={room} oobData={oobData} avatarSize={40} displayBadge={false} />
) : (
<RoomAvatar oobData={oobData} width={40} height={40} />
)}
<div className="mx_RoomHeader_info"> <div className="mx_RoomHeader_info">
<BodyText <BodyText
as="div" as="div"

View file

@ -46,28 +46,11 @@ describe("Roomeader", () => {
setCardSpy = jest.spyOn(RightPanelStore.instance, "setCard"); setCardSpy = jest.spyOn(RightPanelStore.instance, "setCard");
}); });
it("renders with no props", () => {
const { asFragment } = render(<RoomHeader />);
expect(asFragment()).toMatchSnapshot();
});
it("renders the room header", () => { it("renders the room header", () => {
const { container } = render(<RoomHeader room={room} />); const { container } = render(<RoomHeader room={room} />);
expect(container).toHaveTextContent(ROOM_ID); expect(container).toHaveTextContent(ROOM_ID);
}); });
it("display the out-of-band room name", () => {
const OOB_NAME = "My private room";
const { container } = render(
<RoomHeader
oobData={{
name: OOB_NAME,
}}
/>,
);
expect(container).toHaveTextContent(OOB_NAME);
});
it("renders the room topic", async () => { it("renders the room topic", async () => {
const TOPIC = "Hello World!"; const TOPIC = "Hello World!";

View file

@ -1,44 +0,0 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`Roomeader renders with no props 1`] = `
<DocumentFragment>
<header
class="mx_RoomHeader light-panel"
>
<span
class="mx_BaseAvatar"
role="presentation"
>
<span
aria-hidden="true"
class="mx_BaseAvatar_initial"
style="font-size: 26px; width: 40px; line-height: 40px;"
>
?
</span>
<img
alt=""
aria-hidden="true"
class="mx_BaseAvatar_image"
data-testid="avatar-img"
loading="lazy"
src=""
style="width: 40px; height: 40px;"
/>
</span>
<div
class="mx_RoomHeader_info"
>
<div
aria-level="1"
dir="auto"
role="heading"
style="font: var(--cpd-font-body-lg-semibold); letter-spacing: var(--cpd-font-letter-spacing-body-lg);"
title="Join Room"
>
Join Room
</div>
</div>
</header>
</DocumentFragment>
`;