pull/28949/merge
R Midhun Suresh 2025-01-08 18:13:22 +00:00 committed by GitHub
commit c5cf0d16a7
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 45 additions and 34 deletions

View File

@ -7,14 +7,14 @@ Please see LICENSE files in the repository root for full details.
*/ */
import classNames from "classnames"; import classNames from "classnames";
import React, { useEffect, useRef } from "react"; import React, { ComponentProps, JSXElementConstructor, useEffect, useRef } from "react";
type FlexProps = { type FlexProps<T extends keyof JSX.IntrinsicElements | JSXElementConstructor<any>> = {
/** /**
* The type of the HTML element * The type of the HTML element
* @default div * @default div
*/ */
as?: string; as?: T;
/** /**
* The CSS class name. * The CSS class name.
*/ */
@ -30,7 +30,7 @@ type FlexProps = {
*/ */
direction?: "row" | "column" | "row-reverse" | "column-reverse"; direction?: "row" | "column" | "row-reverse" | "column-reverse";
/** /**
* The alingment of the flex children * The alignment of the flex children
* @default start * @default start
*/ */
align?: "start" | "center" | "end" | "baseline" | "stretch"; align?: "start" | "center" | "end" | "baseline" | "stretch";
@ -48,12 +48,12 @@ type FlexProps = {
* the on click event callback * the on click event callback
*/ */
onClick?: (e: React.MouseEvent) => void; onClick?: (e: React.MouseEvent) => void;
}; } & ComponentProps<T>;
/** /**
* A flexbox container helper * A flexbox container helper
*/ */
export function Flex({ export function Flex<T extends keyof JSX.IntrinsicElements | JSXElementConstructor<any> = "div">({
as = "div", as = "div",
display = "flex", display = "flex",
direction = "row", direction = "row",
@ -63,7 +63,7 @@ export function Flex({
className, className,
children, children,
...props ...props
}: React.PropsWithChildren<FlexProps>): JSX.Element { }: React.PropsWithChildren<FlexProps<T>>): JSX.Element {
const ref = useRef<HTMLElement>(); const ref = useRef<HTMLElement>();
useEffect(() => { useEffect(() => {

View File

@ -17,6 +17,7 @@ import { ThreePidInviteTileView } from "./tiles/ThreePidInviteTileView";
import { MemberListHeaderView } from "./MemberListHeaderView"; import { MemberListHeaderView } from "./MemberListHeaderView";
import BaseCard from "../../right_panel/BaseCard"; import BaseCard from "../../right_panel/BaseCard";
import { _t } from "../../../../languageHandler"; import { _t } from "../../../../languageHandler";
import { RovingTabIndexProvider } from "../../../../accessibility/RovingTabIndex";
interface IProps { interface IProps {
roomId: string; roomId: string;
@ -55,26 +56,36 @@ const MemberListView: React.FC<IProps> = (props: IProps) => {
header={_t("common|people")} header={_t("common|people")}
onClose={props.onClose} onClose={props.onClose}
> >
<Flex align="stretch" direction="column" className="mx_MemberListView_container"> <RovingTabIndexProvider handleUpDown scrollIntoView>
<Form.Root> {({ onKeyDownHandler }) => (
<MemberListHeaderView vm={vm} /> <Flex
</Form.Root> tabIndex={0}
<AutoSizer> onKeyDown={onKeyDownHandler}
{({ height, width }) => ( align="stretch"
<List direction="column"
rowRenderer={rowRenderer} className="mx_MemberListView_container"
// All the member tiles will have a height of 56px. >
// The additional empty div at the end of the list should have a height of 32px. <Form.Root>
rowHeight={({ index }) => (index === memberCount ? 32 : 56)} <MemberListHeaderView vm={vm} />
// The +1 refers to the additional empty div that we render at the end of the list. </Form.Root>
rowCount={memberCount + 1} <AutoSizer>
// Subtract the height of MemberlistHeaderView so that the parent div does not overflow. {({ height, width }) => (
height={height - 113} <List
width={width} rowRenderer={rowRenderer}
/> // All the member tiles will have a height of 56px.
)} // The additional empty div at the end of the list should have a height of 32px.
</AutoSizer> rowHeight={({ index }) => (index === memberCount ? 32 : 56)}
</Flex> // The +1 refers to the additional empty div that we render at the end of the list.
rowCount={memberCount + 1}
// Subtract the height of MemberlistHeaderView so that the parent div does not overflow.
height={height - 113}
width={width}
/>
)}
</AutoSizer>
</Flex>
)}
</RovingTabIndexProvider>
</BaseCard> </BaseCard>
); );
}; };

View File

@ -7,7 +7,7 @@ Please see LICENSE files in the repository root for full details.
import React from "react"; import React from "react";
import AccessibleButton from "../../../../elements/AccessibleButton"; import { RovingAccessibleButton } from "../../../../../../accessibility/RovingTabIndex";
interface Props { interface Props {
avatarJsx: JSX.Element; avatarJsx: JSX.Element;
@ -23,7 +23,7 @@ export function MemberTileLayout(props: Props): JSX.Element {
return ( return (
// The wrapping div is required to make the magic mouse listener work, for some reason. // The wrapping div is required to make the magic mouse listener work, for some reason.
<div> <div>
<AccessibleButton className="mx_MemberTileView" title={props.title} onClick={props.onClick}> <RovingAccessibleButton className="mx_MemberTileView" title={props.title} onClick={props.onClick}>
<div className="mx_MemberTileView_left"> <div className="mx_MemberTileView_left">
<div className="mx_MemberTileView_avatar"> <div className="mx_MemberTileView_avatar">
{props.avatarJsx} {props.presenceJsx} {props.avatarJsx} {props.presenceJsx}
@ -34,7 +34,7 @@ export function MemberTileLayout(props: Props): JSX.Element {
{props.userLabelJsx} {props.userLabelJsx}
{props.e2eIconJsx} {props.e2eIconJsx}
</div> </div>
</AccessibleButton> </RovingAccessibleButton>
</div> </div>
); );
} }

View File

@ -7,7 +7,7 @@ exports[`MemberTileView RoomMemberTileView should display an verified E2EIcon wh
aria-label="@userId:matrix.org (power 0)" aria-label="@userId:matrix.org (power 0)"
class="mx_AccessibleButton mx_MemberTileView" class="mx_AccessibleButton mx_MemberTileView"
role="button" role="button"
tabindex="0" tabindex="-1"
> >
<div <div
class="mx_MemberTileView_left" class="mx_MemberTileView_left"
@ -76,7 +76,7 @@ exports[`MemberTileView RoomMemberTileView should display an warning E2EIcon whe
aria-label="@userId:matrix.org (power 0)" aria-label="@userId:matrix.org (power 0)"
class="mx_AccessibleButton mx_MemberTileView" class="mx_AccessibleButton mx_MemberTileView"
role="button" role="button"
tabindex="0" tabindex="-1"
> >
<div <div
class="mx_MemberTileView_left" class="mx_MemberTileView_left"
@ -145,7 +145,7 @@ exports[`MemberTileView RoomMemberTileView should not display an E2EIcon when th
aria-label="@userId:matrix.org (power 0)" aria-label="@userId:matrix.org (power 0)"
class="mx_AccessibleButton mx_MemberTileView" class="mx_AccessibleButton mx_MemberTileView"
role="button" role="button"
tabindex="0" tabindex="-1"
> >
<div <div
class="mx_MemberTileView_left" class="mx_MemberTileView_left"
@ -195,7 +195,7 @@ exports[`MemberTileView ThreePidInviteTileView renders ThreePidInvite correctly
<div <div
class="mx_AccessibleButton mx_MemberTileView" class="mx_AccessibleButton mx_MemberTileView"
role="button" role="button"
tabindex="0" tabindex="-1"
> >
<div <div
class="mx_MemberTileView_left" class="mx_MemberTileView_left"