From 81c6ffce40993bd990f75b257db14cafd33962f6 Mon Sep 17 00:00:00 2001 From: Reinaldo Neto <47038980+reinaldonetof@users.noreply.github.com> Date: Wed, 11 May 2022 15:20:59 -0300 Subject: [PATCH] Chore: Evaluate RoomInfoView - TypeScript (#4107) * Chore: Evaluate RoomInfoView - TypeScript * refactor interfaces --- app/definitions/ILivechatVisitor.ts | 2 +- app/views/RoomInfoView/CustomFields.tsx | 2 +- app/views/RoomInfoView/Direct.tsx | 5 +++-- app/views/RoomInfoView/index.tsx | 24 ++++++++++++------------ 4 files changed, 17 insertions(+), 16 deletions(-) diff --git a/app/definitions/ILivechatVisitor.ts b/app/definitions/ILivechatVisitor.ts index 8a942909a..85f90102e 100644 --- a/app/definitions/ILivechatVisitor.ts +++ b/app/definitions/ILivechatVisitor.ts @@ -22,7 +22,7 @@ export interface IVisitorEmail { export interface ILivechatVisitor extends IRocketChatRecord { username: string; - ts: Date; + ts: Date | string; token: string; department?: string; name?: string; diff --git a/app/views/RoomInfoView/CustomFields.tsx b/app/views/RoomInfoView/CustomFields.tsx index 0034261bd..ccdf863d3 100644 --- a/app/views/RoomInfoView/CustomFields.tsx +++ b/app/views/RoomInfoView/CustomFields.tsx @@ -2,7 +2,7 @@ import React from 'react'; import Item from './Item'; -const CustomFields = ({ customFields }: { customFields: { [key: string]: string } }) => { +const CustomFields = ({ customFields }: { customFields?: { [key: string]: string } }) => { if (customFields) { return ( <> diff --git a/app/views/RoomInfoView/Direct.tsx b/app/views/RoomInfoView/Direct.tsx index a3dffced3..c5fee5d02 100644 --- a/app/views/RoomInfoView/Direct.tsx +++ b/app/views/RoomInfoView/Direct.tsx @@ -7,8 +7,9 @@ import { useTheme } from '../../theme'; import Timezone from './Timezone'; import CustomFields from './CustomFields'; import styles from './styles'; +import { IUserParsed } from '.'; -const Roles = ({ roles }: { roles: string[] }) => { +const Roles = ({ roles }: { roles?: string[] }) => { const { theme } = useTheme(); if (roles && roles.length) { @@ -29,7 +30,7 @@ const Roles = ({ roles }: { roles: string[] }) => { return null; }; -const Direct = ({ roomUser }: { roomUser: any }) => ( +const Direct = ({ roomUser }: { roomUser: IUserParsed }) => ( <> diff --git a/app/views/RoomInfoView/index.tsx b/app/views/RoomInfoView/index.tsx index a19217ef4..65798811c 100644 --- a/app/views/RoomInfoView/index.tsx +++ b/app/views/RoomInfoView/index.tsx @@ -93,7 +93,7 @@ interface IRoomInfoViewProps { roles: { [key: string]: string }; } -interface IUserParsed extends IUser { +export interface IUserParsed extends IUser { parsedRoles?: string[]; } @@ -104,8 +104,7 @@ export interface ILivechatVisitorModified extends ILivechatVisitor { interface IRoomInfoViewState { room: ISubscription; - // TODO: Could be IUserParsed or ILivechatVisitorModified - roomUser: any; + roomUser: IUserParsed | ILivechatVisitorModified; showEdit: boolean; } @@ -214,7 +213,7 @@ class RoomInfoView extends React.Component this.setHeader()); + this.setState({ roomUser: { ...visitor, ...params } as ILivechatVisitorModified }, () => this.setHeader()); } } } catch (error) { @@ -245,14 +244,14 @@ class RoomInfoView extends React.Component; + return ; } if (this.t === SubscriptionType.OMNICHANNEL) { - return ; + return ; } return ; }; @@ -424,20 +423,21 @@ class RoomInfoView extends React.Component - {this.renderAvatar(room, roomUser)} + {this.renderAvatar(room, roomUserParsed)} {renderRoomTitle({ room, type: this.t, - name: roomUser?.name, - username: roomUser?.username, - statusText: roomUser?.statusText, + name: roomUserParsed?.name, + username: roomUserParsed?.username, + statusText: roomUserParsed?.statusText, theme })}