Overview
The New Chat feature allows users to initiate conversations with other users or join group conversations, providing a seamless way to start new communications.- Allows users to initiate conversations with other users or join group conversations.
- Enables users to expand their network, join group discussions, and create new chat threads without navigating through complex menus.
- Your app will provide an intuitive interface for users to discover and connect with other users, join groups, and start new conversations with proper navigation and state management.
Prerequisites
- React v18.2.0+
- CometChat React UI Kit v6.1.0+
- CometChat Chat SDK JavaScript v4.0.13+
- Project setup with initialized CometChat credentials (App ID, Auth Key, Region)
- TypeScript support (recommended)
- User authentication and basic chat functionality implemented
- User and group management components available
Components
| Component / Class | Role | 
|---|---|
| CometChatNewChatView | Main container for new chat creation interface | 
| CometChatUsers | Displays list of available users for chat creation | 
| CometChatGroups | Shows available groups for joining | 
| CometChatJoinGroup | Handles protected group joining process | 
| CometChatSelector | Navigation component with new chat button | 
Integration Steps
1. New Chat State Management Setup
File: CometChatHome.tsx2. New Chat View Component Integration
File: CometChatHome.tsx3. New Chat View Implementation
File: CometChatHome.tsx4. User Selection and Chat Creation
File: CometChatHome.tsxImplementation Flow
- Fetch Data / Available Users and Groups
- Load User/Group Data / Associated Information
- Create Conversation / Action Handler
- Live Updates / State Management
Customization Options
- Override CSS styles
- Configure tabs
- Customize list UI
- Add search
- Handle group types
- Adjust navigation
Filtering / Edge Cases
- User availability
- Group permissions
- Duplicate chats prevention
- Blocking logic
- Membership checks
- Empty states
Error Handling & State Management
Context-Specific Notes
- Public vs private groups
- Different state logic for user/group chats
- Mobile responsiveness
- Navigation flow control
- Group type handling
Summary / Feature Matrix
| Feature | Component / Method | File Reference | 
|---|---|---|
| Open new chat view | onNewChatClicked() | CometChatHome.tsx | 
| New chat interface | CometChatNewChatView | CometChatHome.tsx | 
| User selection | CometChatUsers | CometChatHome.tsx | 
| Group selection | CometChatGroups | CometChatHome.tsx | 
| Group joining | joinGroup() | CometChatHome.tsx | 
| State management | showNewChatstate | appReducer.ts | 
| Chat creation | setNewChat() | CometChatHome.tsx | 
| Navigation handling | setShowNewChat(false) | CometChatHome.tsx | 
Next Steps & Further Reading
- CometChat React UI Kit Documentation
- Sample App Repository
- User Management Features
- Group Management Features