import React from 'react'; import Animated from 'react-native-reanimated'; import { TSupportedThemes } from '../../theme'; import { TUserStatus, ILastMessage, SubscriptionType, IOmnichannelSource } from '../../definitions'; export interface ILeftActionsProps { transX: Animated.SharedValue; isRead: boolean; width: number; onToggleReadPress(): void; displayMode: string; } export interface IRightActionsProps { transX: Animated.SharedValue; favorite: boolean; width: number; toggleFav(): void; onHidePress(): void; displayMode: string; } export interface ITitleProps { name: string; hideUnreadStatus: boolean; alert: boolean; } export interface IUpdatedAtProps { date: string; hideUnreadStatus: boolean; alert: boolean; } export interface IWrapperProps { accessibilityLabel: string; avatar: string; type: string; rid: string; children: React.ReactElement; displayMode: string; prid: string; showLastMessage: boolean; status: TUserStatus; isGroupChat: boolean; teamMain: boolean; showAvatar: boolean; sourceType: IOmnichannelSource; } export interface ITypeIconProps { type: string; status: TUserStatus; prid: string; isGroupChat: boolean; teamMain: boolean; theme?: TSupportedThemes; size?: number; style?: object; sourceType: IOmnichannelSource; } interface IRoomItemTouchables { toggleFav?: (rid: string, favorite: boolean) => Promise; toggleRead?: (rid: string, tIsRead: boolean) => Promise; hideChannel?: (rid: string, type: SubscriptionType) => Promise; onPress: (item?: any) => void; onLongPress?: (item?: any) => void; } interface IBaseRoomItem extends IRoomItemTouchables { [key: string]: any; showLastMessage?: boolean; useRealName: boolean; isFocused?: boolean; displayMode: string; showAvatar: boolean; swipeEnabled: boolean; autoJoin?: boolean; username?: string; } export interface IRoomItemContainerProps extends IBaseRoomItem { item: any; id?: string; getRoomTitle: (item: any) => string; getRoomAvatar: (item: any) => string; getIsRead?: (item: any) => boolean; } export interface IRoomItemProps extends IBaseRoomItem { rid: string; type: SubscriptionType; prid: string; name: string; avatar: string; testID: string; status: TUserStatus; isGroupChat: boolean; isRead: boolean; teamMain: boolean; date: string; accessibilityLabel: string; lastMessage: ILastMessage; favorite: boolean; alert: boolean; hideUnreadStatus: boolean; unread: number; userMentions: number; groupMentions: number; tunread: []; tunreadUser: []; tunreadGroup: []; size?: number; sourceType: IOmnichannelSource; hideMentionStatus?: boolean; touchableRef: React.RefObject; } export interface ILastMessageProps { lastMessage: ILastMessage; type: SubscriptionType; showLastMessage: boolean; username: string; useRealName: boolean; alert: boolean; } export interface ITouchableRef { close: () => void; } export interface ITouchableProps extends IRoomItemTouchables { children: JSX.Element; type: SubscriptionType; testID: string; favorite: boolean; isRead: boolean; rid: string; isFocused: boolean; swipeEnabled: boolean; displayMode: string; } export interface IIconOrAvatar { avatar: string; type: string; rid: string; showAvatar: boolean; displayMode: string; prid: string; status: TUserStatus; isGroupChat: boolean; teamMain: boolean; showLastMessage: boolean; sourceType: IOmnichannelSource; }