| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | // Copyright 2021 Signal Messenger, LLC
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { ReactNode } from 'react'; | 
					
						
							| 
									
										
										
										
											2022-11-14 11:48:51 -07:00
										 |  |  | import React, { useCallback } from 'react'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { ListRowRenderer } from 'react-virtualized'; | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  | import classNames from 'classnames'; | 
					
						
							| 
									
										
										
										
											2021-10-07 19:52:48 -04:00
										 |  |  | import { get, pick } from 'lodash'; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  | import { missingCaseError } from '../util/missingCaseError'; | 
					
						
							| 
									
										
										
										
											2022-09-15 12:17:15 -07:00
										 |  |  | import { assertDev } from '../util/assert'; | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  | import type { ParsedE164Type } from '../util/libphonenumberInstance'; | 
					
						
							| 
									
										
										
										
											2021-11-02 18:01:13 -05:00
										 |  |  | import type { LocalizerType, ThemeType } from '../types/Util'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import { ScrollBehavior } from '../types/Util'; | 
					
						
							| 
									
										
										
										
											2021-10-12 18:59:08 -05:00
										 |  |  | import { getConversationListWidthBreakpoint } from './_util'; | 
					
						
							| 
									
										
										
										
											2021-11-17 15:11:21 -06:00
										 |  |  | import type { PreferredBadgeSelectorType } from '../state/selectors/badges'; | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  | import type { LookupConversationWithoutUuidActionsType } from '../util/lookupConversationWithoutUuid'; | 
					
						
							| 
									
										
										
										
											2022-06-16 15:12:50 -04:00
										 |  |  | import type { ShowConversationType } from '../state/ducks/conversations'; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { PropsData as ConversationListItemPropsType } from './conversationList/ConversationListItem'; | 
					
						
							| 
									
										
										
										
											2022-09-26 10:24:52 -06:00
										 |  |  | import type { ContactCheckboxDisabledReason } from './conversationList/ContactCheckbox'; | 
					
						
							| 
									
										
										
										
											2021-11-17 15:11:21 -06:00
										 |  |  | import type { ContactListItemConversationType as ContactListItemPropsType } from './conversationList/ContactListItem'; | 
					
						
							| 
									
										
										
										
											2022-09-26 10:24:52 -06:00
										 |  |  | import type { GroupListItemConversationType } from './conversationList/GroupListItem'; | 
					
						
							|  |  |  | import { ConversationListItem } from './conversationList/ConversationListItem'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import { ContactListItem } from './conversationList/ContactListItem'; | 
					
						
							|  |  |  | import { ContactCheckbox as ContactCheckboxComponent } from './conversationList/ContactCheckbox'; | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  | import { PhoneNumberCheckbox as PhoneNumberCheckboxComponent } from './conversationList/PhoneNumberCheckbox'; | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  | import { UsernameCheckbox as UsernameCheckboxComponent } from './conversationList/UsernameCheckbox'; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  | import { CreateNewGroupButton } from './conversationList/CreateNewGroupButton'; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | import { StartNewConversation as StartNewConversationComponent } from './conversationList/StartNewConversation'; | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  | import { SearchResultsLoadingFakeHeader as SearchResultsLoadingFakeHeaderComponent } from './conversationList/SearchResultsLoadingFakeHeader'; | 
					
						
							|  |  |  | import { SearchResultsLoadingFakeRow as SearchResultsLoadingFakeRowComponent } from './conversationList/SearchResultsLoadingFakeRow'; | 
					
						
							| 
									
										
										
										
											2021-11-11 17:17:29 -08:00
										 |  |  | import { UsernameSearchResultListItem } from './conversationList/UsernameSearchResultListItem'; | 
					
						
							| 
									
										
										
										
											2022-09-26 10:24:52 -06:00
										 |  |  | import { GroupListItem } from './conversationList/GroupListItem'; | 
					
						
							| 
									
										
										
										
											2022-11-14 11:48:51 -07:00
										 |  |  | import { ListView } from './ListView'; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  | export enum RowType { | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  |   ArchiveButton = 'ArchiveButton', | 
					
						
							|  |  |  |   Blank = 'Blank', | 
					
						
							|  |  |  |   Contact = 'Contact', | 
					
						
							|  |  |  |   ContactCheckbox = 'ContactCheckbox', | 
					
						
							|  |  |  |   PhoneNumberCheckbox = 'PhoneNumberCheckbox', | 
					
						
							|  |  |  |   UsernameCheckbox = 'UsernameCheckbox', | 
					
						
							|  |  |  |   Conversation = 'Conversation', | 
					
						
							|  |  |  |   CreateNewGroup = 'CreateNewGroup', | 
					
						
							|  |  |  |   Header = 'Header', | 
					
						
							|  |  |  |   MessageSearchResult = 'MessageSearchResult', | 
					
						
							|  |  |  |   SearchResultsLoadingFakeHeader = 'SearchResultsLoadingFakeHeader', | 
					
						
							|  |  |  |   SearchResultsLoadingFakeRow = 'SearchResultsLoadingFakeRow', | 
					
						
							| 
									
										
										
										
											2022-09-26 10:24:52 -06:00
										 |  |  |   // this could later be expanded to SelectSingleConversation
 | 
					
						
							|  |  |  |   SelectSingleGroup = 'SelectSingleGroup', | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  |   StartNewConversation = 'StartNewConversation', | 
					
						
							|  |  |  |   UsernameSearchResult = 'UsernameSearchResult', | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type ArchiveButtonRowType = { | 
					
						
							|  |  |  |   type: RowType.ArchiveButton; | 
					
						
							|  |  |  |   archivedConversationsCount: number; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  | type BlankRowType = { type: RowType.Blank }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | type ContactRowType = { | 
					
						
							|  |  |  |   type: RowType.Contact; | 
					
						
							|  |  |  |   contact: ContactListItemPropsType; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |   isClickable?: boolean; | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |   hasContextMenu?: boolean; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type ContactCheckboxRowType = { | 
					
						
							|  |  |  |   type: RowType.ContactCheckbox; | 
					
						
							|  |  |  |   contact: ContactListItemPropsType; | 
					
						
							|  |  |  |   isChecked: boolean; | 
					
						
							|  |  |  |   disabledReason?: ContactCheckboxDisabledReason; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  | type PhoneNumberCheckboxRowType = { | 
					
						
							|  |  |  |   type: RowType.PhoneNumberCheckbox; | 
					
						
							|  |  |  |   phoneNumber: ParsedE164Type; | 
					
						
							|  |  |  |   isChecked: boolean; | 
					
						
							|  |  |  |   isFetching: boolean; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  | type UsernameCheckboxRowType = { | 
					
						
							|  |  |  |   type: RowType.UsernameCheckbox; | 
					
						
							|  |  |  |   username: string; | 
					
						
							|  |  |  |   isChecked: boolean; | 
					
						
							|  |  |  |   isFetching: boolean; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | type ConversationRowType = { | 
					
						
							|  |  |  |   type: RowType.Conversation; | 
					
						
							|  |  |  |   conversation: ConversationListItemPropsType; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  | type CreateNewGroupRowType = { | 
					
						
							|  |  |  |   type: RowType.CreateNewGroup; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | type MessageRowType = { | 
					
						
							|  |  |  |   type: RowType.MessageSearchResult; | 
					
						
							|  |  |  |   messageId: string; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type HeaderRowType = { | 
					
						
							|  |  |  |   type: RowType.Header; | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |   getHeaderText: (i18n: LocalizerType) => string; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  | // Exported for tests across multiple files
 | 
					
						
							|  |  |  | export function _testHeaderText(row: Row | void): string | null { | 
					
						
							|  |  |  |   if (row?.type === RowType.Header) { | 
					
						
							|  |  |  |     return row.getHeaderText(((key: string) => key) as LocalizerType); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return null; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  | type SearchResultsLoadingFakeHeaderType = { | 
					
						
							|  |  |  |   type: RowType.SearchResultsLoadingFakeHeader; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type SearchResultsLoadingFakeRowType = { | 
					
						
							|  |  |  |   type: RowType.SearchResultsLoadingFakeRow; | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-26 10:24:52 -06:00
										 |  |  | type SelectSingleGroupRowType = { | 
					
						
							|  |  |  |   type: RowType.SelectSingleGroup; | 
					
						
							|  |  |  |   group: GroupListItemConversationType; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | type StartNewConversationRowType = { | 
					
						
							|  |  |  |   type: RowType.StartNewConversation; | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  |   phoneNumber: ParsedE164Type; | 
					
						
							|  |  |  |   isFetching: boolean; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-11 17:17:29 -08:00
										 |  |  | type UsernameRowType = { | 
					
						
							|  |  |  |   type: RowType.UsernameSearchResult; | 
					
						
							|  |  |  |   username: string; | 
					
						
							|  |  |  |   isFetchingUsername: boolean; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | export type Row = | 
					
						
							|  |  |  |   | ArchiveButtonRowType | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |   | BlankRowType | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   | ContactRowType | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |   | ContactCheckboxRowType | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  |   | PhoneNumberCheckboxRowType | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  |   | UsernameCheckboxRowType | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   | ConversationRowType | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |   | CreateNewGroupRowType | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   | MessageRowType | 
					
						
							|  |  |  |   | HeaderRowType | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |   | SearchResultsLoadingFakeHeaderType | 
					
						
							|  |  |  |   | SearchResultsLoadingFakeRowType | 
					
						
							| 
									
										
										
										
											2021-11-11 17:17:29 -08:00
										 |  |  |   | StartNewConversationRowType | 
					
						
							| 
									
										
										
										
											2022-09-26 10:24:52 -06:00
										 |  |  |   | SelectSingleGroupRowType | 
					
						
							| 
									
										
										
										
											2021-11-11 17:17:29 -08:00
										 |  |  |   | UsernameRowType; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  | export type PropsType = { | 
					
						
							|  |  |  |   dimensions?: { | 
					
						
							|  |  |  |     width: number; | 
					
						
							|  |  |  |     height: number; | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   rowCount: number; | 
					
						
							|  |  |  |   // If `getRow` is called with an invalid index, it should return `undefined`. However,
 | 
					
						
							|  |  |  |   //   this should only happen if there is a bug somewhere. For example, an inaccurate
 | 
					
						
							|  |  |  |   //   `rowCount`.
 | 
					
						
							|  |  |  |   getRow: (index: number) => undefined | Row; | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |   scrollBehavior?: ScrollBehavior; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   scrollToRowIndex?: number; | 
					
						
							|  |  |  |   shouldRecomputeRowHeights: boolean; | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |   scrollable?: boolean; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-17 15:11:21 -06:00
										 |  |  |   getPreferredBadge: PreferredBadgeSelectorType; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   i18n: LocalizerType; | 
					
						
							| 
									
										
										
										
											2021-11-02 18:01:13 -05:00
										 |  |  |   theme: ThemeType; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |   blockConversation: (conversationId: string) => void; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   onClickArchiveButton: () => void; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |   onClickContactCheckbox: ( | 
					
						
							|  |  |  |     conversationId: string, | 
					
						
							|  |  |  |     disabledReason: undefined | ContactCheckboxDisabledReason | 
					
						
							|  |  |  |   ) => void; | 
					
						
							|  |  |  |   onSelectConversation: (conversationId: string, messageId?: string) => void; | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |   onOutgoingAudioCallInConversation: (conversationId: string) => void; | 
					
						
							|  |  |  |   onOutgoingVideoCallInConversation: (conversationId: string) => void; | 
					
						
							|  |  |  |   removeConversation?: (conversationId: string) => void; | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  |   renderMessageSearchResult?: (id: string) => JSX.Element; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |   showChooseGroupMembers: () => void; | 
					
						
							| 
									
										
										
										
											2022-06-16 15:12:50 -04:00
										 |  |  |   showConversation: ShowConversationType; | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  | } & LookupConversationWithoutUuidActionsType; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-12 18:59:08 -05:00
										 |  |  | const NORMAL_ROW_HEIGHT = 76; | 
					
						
							| 
									
										
										
										
											2022-09-26 10:24:52 -06:00
										 |  |  | const SELECT_ROW_HEIGHT = 52; | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  | const HEADER_ROW_HEIGHT = 40; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | export function ConversationList({ | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   dimensions, | 
					
						
							| 
									
										
										
										
											2021-11-17 15:11:21 -06:00
										 |  |  |   getPreferredBadge, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   getRow, | 
					
						
							|  |  |  |   i18n, | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |   blockConversation, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   onClickArchiveButton, | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |   onClickContactCheckbox, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   onSelectConversation, | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |   onOutgoingAudioCallInConversation, | 
					
						
							|  |  |  |   onOutgoingVideoCallInConversation, | 
					
						
							|  |  |  |   removeConversation, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   renderMessageSearchResult, | 
					
						
							|  |  |  |   rowCount, | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |   scrollBehavior = ScrollBehavior.Default, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   scrollToRowIndex, | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |   scrollable = true, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   shouldRecomputeRowHeights, | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |   showChooseGroupMembers, | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  |   lookupConversationWithoutUuid, | 
					
						
							|  |  |  |   showUserNotFoundModal, | 
					
						
							|  |  |  |   setIsFetchingUUID, | 
					
						
							|  |  |  |   showConversation, | 
					
						
							| 
									
										
										
										
											2021-11-02 18:01:13 -05:00
										 |  |  |   theme, | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | }: PropsType): JSX.Element | null { | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   const calculateRowHeight = useCallback( | 
					
						
							| 
									
										
										
										
											2022-11-14 11:48:51 -07:00
										 |  |  |     (index: number): number => { | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |       const row = getRow(index); | 
					
						
							|  |  |  |       if (!row) { | 
					
						
							| 
									
										
										
										
											2022-09-15 12:17:15 -07:00
										 |  |  |         assertDev(false, `Expected a row at index ${index}`); | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |         return NORMAL_ROW_HEIGHT; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       switch (row.type) { | 
					
						
							|  |  |  |         case RowType.Header: | 
					
						
							|  |  |  |         case RowType.SearchResultsLoadingFakeHeader: | 
					
						
							|  |  |  |           return HEADER_ROW_HEIGHT; | 
					
						
							| 
									
										
										
										
											2022-09-26 10:24:52 -06:00
										 |  |  |         case RowType.SelectSingleGroup: | 
					
						
							| 
									
										
										
										
											2023-01-25 16:51:08 -07:00
										 |  |  |         case RowType.ContactCheckbox: | 
					
						
							|  |  |  |         case RowType.Contact: | 
					
						
							|  |  |  |         case RowType.CreateNewGroup: | 
					
						
							| 
									
										
										
										
											2022-09-26 10:24:52 -06:00
										 |  |  |           return SELECT_ROW_HEIGHT; | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |         default: | 
					
						
							|  |  |  |           return NORMAL_ROW_HEIGHT; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     [getRow] | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const renderRow: ListRowRenderer = useCallback( | 
					
						
							|  |  |  |     ({ key, index, style }) => { | 
					
						
							|  |  |  |       const row = getRow(index); | 
					
						
							|  |  |  |       if (!row) { | 
					
						
							| 
									
										
										
										
											2022-09-15 12:17:15 -07:00
										 |  |  |         assertDev(false, `Expected a row at index ${index}`); | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |         return <div key={key} style={style} />; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |       let result: ReactNode; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |       switch (row.type) { | 
					
						
							|  |  |  |         case RowType.ArchiveButton: | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           result = ( | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |             <button | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |               aria-label={i18n('icu:archivedConversations')} | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |               className="module-conversation-list__item--archive-button" | 
					
						
							|  |  |  |               onClick={onClickArchiveButton} | 
					
						
							|  |  |  |               type="button" | 
					
						
							|  |  |  |             > | 
					
						
							| 
									
										
										
										
											2021-10-06 10:45:25 -05:00
										 |  |  |               <div className="module-conversation-list__item--archive-button__icon" /> | 
					
						
							|  |  |  |               <span className="module-conversation-list__item--archive-button__text"> | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |                 {i18n('icu:archivedConversations')} | 
					
						
							| 
									
										
										
										
											2021-10-06 10:45:25 -05:00
										 |  |  |               </span> | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |               <span className="module-conversation-list__item--archive-button__archived-count"> | 
					
						
							|  |  |  |                 {row.archivedConversationsCount} | 
					
						
							|  |  |  |               </span> | 
					
						
							|  |  |  |             </button> | 
					
						
							|  |  |  |           ); | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           break; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         case RowType.Blank: | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  |           result = undefined; | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           break; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         case RowType.Contact: { | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |           const { isClickable = true, hasContextMenu = false } = row; | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           result = ( | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |             <ContactListItem | 
					
						
							|  |  |  |               {...row.contact} | 
					
						
							| 
									
										
										
										
											2021-11-17 15:11:21 -06:00
										 |  |  |               badge={getPreferredBadge(row.contact.badges)} | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |               onClick={isClickable ? onSelectConversation : undefined} | 
					
						
							|  |  |  |               i18n={i18n} | 
					
						
							| 
									
										
										
										
											2021-11-17 15:11:21 -06:00
										 |  |  |               theme={theme} | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |               hasContextMenu={hasContextMenu} | 
					
						
							|  |  |  |               onAudioCall={ | 
					
						
							|  |  |  |                 isClickable ? onOutgoingAudioCallInConversation : undefined | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               onVideoCall={ | 
					
						
							|  |  |  |                 isClickable ? onOutgoingVideoCallInConversation : undefined | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               onBlock={isClickable ? blockConversation : undefined} | 
					
						
							|  |  |  |               onRemove={isClickable ? removeConversation : undefined} | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |             /> | 
					
						
							|  |  |  |           ); | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           break; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         } | 
					
						
							|  |  |  |         case RowType.ContactCheckbox: | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           result = ( | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |             <ContactCheckboxComponent | 
					
						
							|  |  |  |               {...row.contact} | 
					
						
							| 
									
										
										
										
											2021-11-17 15:11:21 -06:00
										 |  |  |               badge={getPreferredBadge(row.contact.badges)} | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |               isChecked={row.isChecked} | 
					
						
							|  |  |  |               disabledReason={row.disabledReason} | 
					
						
							|  |  |  |               onClick={onClickContactCheckbox} | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |               i18n={i18n} | 
					
						
							| 
									
										
										
										
											2021-11-17 15:11:21 -06:00
										 |  |  |               theme={theme} | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |             /> | 
					
						
							|  |  |  |           ); | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           break; | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  |         case RowType.PhoneNumberCheckbox: | 
					
						
							|  |  |  |           result = ( | 
					
						
							|  |  |  |             <PhoneNumberCheckboxComponent | 
					
						
							|  |  |  |               phoneNumber={row.phoneNumber} | 
					
						
							|  |  |  |               lookupConversationWithoutUuid={lookupConversationWithoutUuid} | 
					
						
							|  |  |  |               showUserNotFoundModal={showUserNotFoundModal} | 
					
						
							|  |  |  |               setIsFetchingUUID={setIsFetchingUUID} | 
					
						
							|  |  |  |               toggleConversationInChooseMembers={conversationId => | 
					
						
							|  |  |  |                 onClickContactCheckbox(conversationId, undefined) | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               isChecked={row.isChecked} | 
					
						
							|  |  |  |               isFetching={row.isFetching} | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  |               i18n={i18n} | 
					
						
							|  |  |  |               theme={theme} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           ); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case RowType.UsernameCheckbox: | 
					
						
							|  |  |  |           result = ( | 
					
						
							|  |  |  |             <UsernameCheckboxComponent | 
					
						
							|  |  |  |               username={row.username} | 
					
						
							|  |  |  |               lookupConversationWithoutUuid={lookupConversationWithoutUuid} | 
					
						
							|  |  |  |               showUserNotFoundModal={showUserNotFoundModal} | 
					
						
							|  |  |  |               setIsFetchingUUID={setIsFetchingUUID} | 
					
						
							|  |  |  |               toggleConversationInChooseMembers={conversationId => | 
					
						
							|  |  |  |                 onClickContactCheckbox(conversationId, undefined) | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               isChecked={row.isChecked} | 
					
						
							|  |  |  |               isFetching={row.isFetching} | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  |               i18n={i18n} | 
					
						
							|  |  |  |               theme={theme} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           ); | 
					
						
							|  |  |  |           break; | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |         case RowType.Conversation: { | 
					
						
							|  |  |  |           const itemProps = pick(row.conversation, [ | 
					
						
							|  |  |  |             'acceptedMessageRequest', | 
					
						
							|  |  |  |             'avatarPath', | 
					
						
							| 
									
										
										
										
											2021-11-02 18:01:13 -05:00
										 |  |  |             'badges', | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |             'color', | 
					
						
							|  |  |  |             'draftPreview', | 
					
						
							| 
									
										
										
										
											2023-01-12 19:24:59 -05:00
										 |  |  |             'groupId', | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |             'id', | 
					
						
							|  |  |  |             'isMe', | 
					
						
							|  |  |  |             'isSelected', | 
					
						
							| 
									
										
										
										
											2022-01-31 14:01:34 -08:00
										 |  |  |             'isPinned', | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |             'lastMessage', | 
					
						
							|  |  |  |             'lastUpdated', | 
					
						
							|  |  |  |             'markedUnread', | 
					
						
							|  |  |  |             'muteExpiresAt', | 
					
						
							|  |  |  |             'phoneNumber', | 
					
						
							|  |  |  |             'profileName', | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |             'removalStage', | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |             'sharedGroupNames', | 
					
						
							|  |  |  |             'shouldShowDraft', | 
					
						
							|  |  |  |             'title', | 
					
						
							|  |  |  |             'type', | 
					
						
							| 
									
										
										
										
											2021-11-15 14:01:58 -06:00
										 |  |  |             'typingContactId', | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |             'unblurredAvatarPath', | 
					
						
							|  |  |  |             'unreadCount', | 
					
						
							| 
									
										
										
										
											2023-05-23 17:59:07 -04:00
										 |  |  |             'unreadMentionsCount', | 
					
						
							| 
									
										
										
										
											2023-01-12 14:18:08 -08:00
										 |  |  |             'uuid', | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           ]); | 
					
						
							| 
									
										
										
										
											2021-11-02 18:01:13 -05:00
										 |  |  |           const { badges, title, unreadCount, lastMessage } = itemProps; | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           result = ( | 
					
						
							| 
									
										
										
										
											2023-04-21 17:23:30 -04:00
										 |  |  |             <ConversationListItem | 
					
						
							|  |  |  |               {...itemProps} | 
					
						
							|  |  |  |               buttonAriaLabel={i18n('icu:ConversationList__aria-label', { | 
					
						
							| 
									
										
										
										
											2021-10-07 19:52:48 -04:00
										 |  |  |                 lastMessage: | 
					
						
							|  |  |  |                   get(lastMessage, 'text') || | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |                   i18n('icu:ConversationList__last-message-undefined'), | 
					
						
							| 
									
										
										
										
											2021-10-07 19:52:48 -04:00
										 |  |  |                 title, | 
					
						
							| 
									
										
										
										
											2023-04-03 12:03:00 -07:00
										 |  |  |                 unreadCount, | 
					
						
							| 
									
										
										
										
											2021-10-07 19:52:48 -04:00
										 |  |  |               })} | 
					
						
							| 
									
										
										
										
											2023-04-21 17:23:30 -04:00
										 |  |  |               key={key} | 
					
						
							|  |  |  |               badge={getPreferredBadge(badges)} | 
					
						
							|  |  |  |               onClick={onSelectConversation} | 
					
						
							|  |  |  |               i18n={i18n} | 
					
						
							|  |  |  |               theme={theme} | 
					
						
							|  |  |  |             /> | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |           ); | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           break; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         case RowType.CreateNewGroup: | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           result = ( | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |             <CreateNewGroupButton | 
					
						
							|  |  |  |               i18n={i18n} | 
					
						
							|  |  |  |               onClick={showChooseGroupMembers} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           ); | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           break; | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |         case RowType.Header: { | 
					
						
							|  |  |  |           const headerText = row.getHeaderText(i18n); | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           result = ( | 
					
						
							| 
									
										
										
										
											2021-10-07 19:52:48 -04:00
										 |  |  |             <div | 
					
						
							|  |  |  |               className="module-conversation-list__item--header" | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |               aria-label={headerText} | 
					
						
							| 
									
										
										
										
											2021-10-07 19:52:48 -04:00
										 |  |  |             > | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |               {headerText} | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |             </div> | 
					
						
							|  |  |  |           ); | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           break; | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |         case RowType.MessageSearchResult: | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  |           result = <>{renderMessageSearchResult?.(row.messageId)}</>; | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           break; | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |         case RowType.SearchResultsLoadingFakeHeader: | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           result = <SearchResultsLoadingFakeHeaderComponent />; | 
					
						
							|  |  |  |           break; | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |         case RowType.SearchResultsLoadingFakeRow: | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           result = <SearchResultsLoadingFakeRowComponent />; | 
					
						
							|  |  |  |           break; | 
					
						
							| 
									
										
										
										
											2022-09-26 10:24:52 -06:00
										 |  |  |         case RowType.SelectSingleGroup: | 
					
						
							|  |  |  |           result = ( | 
					
						
							|  |  |  |             <GroupListItem | 
					
						
							|  |  |  |               i18n={i18n} | 
					
						
							|  |  |  |               group={row.group} | 
					
						
							|  |  |  |               onSelectGroup={onSelectConversation} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           ); | 
					
						
							|  |  |  |           break; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |         case RowType.StartNewConversation: | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           result = ( | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |             <StartNewConversationComponent | 
					
						
							|  |  |  |               i18n={i18n} | 
					
						
							|  |  |  |               phoneNumber={row.phoneNumber} | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  |               isFetching={row.isFetching} | 
					
						
							|  |  |  |               lookupConversationWithoutUuid={lookupConversationWithoutUuid} | 
					
						
							|  |  |  |               showUserNotFoundModal={showUserNotFoundModal} | 
					
						
							|  |  |  |               setIsFetchingUUID={setIsFetchingUUID} | 
					
						
							|  |  |  |               showConversation={showConversation} | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |             /> | 
					
						
							|  |  |  |           ); | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |           break; | 
					
						
							| 
									
										
										
										
											2021-11-11 17:17:29 -08:00
										 |  |  |         case RowType.UsernameSearchResult: | 
					
						
							|  |  |  |           result = ( | 
					
						
							|  |  |  |             <UsernameSearchResultListItem | 
					
						
							|  |  |  |               i18n={i18n} | 
					
						
							|  |  |  |               username={row.username} | 
					
						
							|  |  |  |               isFetchingUsername={row.isFetchingUsername} | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  |               lookupConversationWithoutUuid={lookupConversationWithoutUuid} | 
					
						
							|  |  |  |               showUserNotFoundModal={showUserNotFoundModal} | 
					
						
							|  |  |  |               setIsFetchingUUID={setIsFetchingUUID} | 
					
						
							|  |  |  |               showConversation={showConversation} | 
					
						
							| 
									
										
										
										
											2021-11-11 17:17:29 -08:00
										 |  |  |             /> | 
					
						
							|  |  |  |           ); | 
					
						
							|  |  |  |           break; | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |         default: | 
					
						
							|  |  |  |           throw missingCaseError(row); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |       return ( | 
					
						
							| 
									
										
										
										
											2021-10-07 19:52:48 -04:00
										 |  |  |         <span aria-rowindex={index + 1} role="row" style={style} key={key}> | 
					
						
							| 
									
										
										
										
											2021-10-12 11:23:13 -04:00
										 |  |  |           <span role="gridcell" aria-colindex={1}> | 
					
						
							| 
									
										
										
										
											2021-10-07 19:52:48 -04:00
										 |  |  |             {result} | 
					
						
							| 
									
										
										
										
											2021-10-12 11:23:13 -04:00
										 |  |  |           </span> | 
					
						
							| 
									
										
										
										
											2021-08-11 09:23:21 -07:00
										 |  |  |         </span> | 
					
						
							|  |  |  |       ); | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |     }, | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |       blockConversation, | 
					
						
							| 
									
										
										
										
											2021-11-17 15:11:21 -06:00
										 |  |  |       getPreferredBadge, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |       getRow, | 
					
						
							|  |  |  |       i18n, | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |       lookupConversationWithoutUuid, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |       onClickArchiveButton, | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |       onClickContactCheckbox, | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |       onOutgoingAudioCallInConversation, | 
					
						
							|  |  |  |       onOutgoingVideoCallInConversation, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |       onSelectConversation, | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |       removeConversation, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |       renderMessageSearchResult, | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |       setIsFetchingUUID, | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |       showChooseGroupMembers, | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  |       showConversation, | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |       showUserNotFoundModal, | 
					
						
							| 
									
										
										
										
											2021-11-02 18:01:13 -05:00
										 |  |  |       theme, | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |     ] | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 16:56:56 -07:00
										 |  |  |   if (dimensions == null) { | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |     return null; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 16:56:56 -07:00
										 |  |  |   const widthBreakpoint = getConversationListWidthBreakpoint(dimensions.width); | 
					
						
							| 
									
										
										
										
											2021-10-12 18:59:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |   return ( | 
					
						
							| 
									
										
										
										
											2022-11-14 11:48:51 -07:00
										 |  |  |     <ListView | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |       className={classNames( | 
					
						
							|  |  |  |         'module-conversation-list', | 
					
						
							| 
									
										
										
										
											2021-10-12 18:59:08 -05:00
										 |  |  |         `module-conversation-list--width-${widthBreakpoint}` | 
					
						
							| 
									
										
										
										
											2021-04-02 17:32:55 -05:00
										 |  |  |       )} | 
					
						
							| 
									
										
										
										
											2023-07-25 16:56:56 -07:00
										 |  |  |       width={dimensions.width} | 
					
						
							|  |  |  |       height={dimensions.height} | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |       rowCount={rowCount} | 
					
						
							| 
									
										
										
										
											2022-11-14 11:48:51 -07:00
										 |  |  |       calculateRowHeight={calculateRowHeight} | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |       rowRenderer={renderRow} | 
					
						
							|  |  |  |       scrollToIndex={scrollToRowIndex} | 
					
						
							| 
									
										
										
										
											2022-11-14 11:48:51 -07:00
										 |  |  |       shouldRecomputeRowHeights={shouldRecomputeRowHeights} | 
					
						
							|  |  |  |       scrollable={scrollable} | 
					
						
							|  |  |  |       scrollBehavior={scrollBehavior} | 
					
						
							| 
									
										
										
										
											2021-02-23 14:34:28 -06:00
										 |  |  |     /> | 
					
						
							|  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | } |