This project is a real-time chat application built with React, Next.js, Reverb, and Laraship. The application leverages Laraship as the backend, Reverb for real-time capabilities, and Next.js as the frontend framework. Media files are stored securely using Amazon S3.
Are you seeking a dedicated, experienced Laravel development team to bring your web projects to life? Look no further than Corals. Our team of seasoned Laravel developers is here to collaborate with you and deliver top-notch, customized solutions that exceed your expectations.
Ready to take your project to the next level with our expert Laravel team? Reach out to us at info@corals.io or fill out the form on our website to discuss your project requirements and kickstart a successful collaboration.
- Real-time messaging: Instant message delivery and receipt across all connected clients.
- Multiple attachments: Send images, documents, videos, and other file types stored securely on S3.
- Typing indicators: See when another user is typing a message.
- Seen Indicator: double ✓✓ when the message read.
- Emojis: Integrate emojis into your messages for expressive communication.
- Conversation search: Easily search through conversations to find specific messages.
- Delete messages: Remove unwanted messages from conversations with delete functionality.
- User authentication: Secure user login and registration powered by Laraship.
- Scalable architecture: Designed to scale with your application's growth.
- Mobile responsive design: Fully functional on both desktop and mobile devices.
- Easy to extend and customize: Modular design for adding new features and customizations.
- Node.js (>= 18.x)
- Composer (for Laraship)
- PHP (>= 8.2)
- Laraship (>= 10.x)
- MySQL or another supported database
- Amazon S3 for media storage
-
Clone the repository:
git clone https://github.com/coralsio/laraship.git cd laraship
-
Install dependencies:
composer install
-
Set up your environment file:
cp .env.example .env php artisan key:generate
-
Configure your database and S3 settings in the
.env
file:DB_CONNECTION= DB_HOST= DB_PORT= DB_DATABASE= DB_USERNAME= DB_PASSWORD= AWS_KEY= AWS_SECRET= AWS_REGION= AWS_BUCKET= REVERB_APP_ID=your-reverb-app-id REVERB_APP_KEY=your-reverb-app-key REVERB_HOST=your-reverb-host REVERB_PORT=8080 REVERB_SCHEME=http
-
Run migrations:
php artisan migrate
-
Install Laraship Messaging Module
composer require corals/messaging
Next, install the Messaging module from the /modules section in the laraship admin panel.
check corals messaging module features https://github.com/coralsio/messaging
6. Install and Start Reverb
bash php artisan reverb:install php artisan reverb:start
-
clone the frontend repository
git clone https://github.com/coralsio/real-time-chat.git cd real-time-chat
-
Install dependencies:
npm install
-
Update .env file for the following
NEXT_PUBLIC_REVERB_APP_ID=your-reverb-app-id NEXT_PUBLIC_REVERB_APP_KEY=your-reverb-app-key NEXT_PUBLIC_REVERB_HOST=your-reverb-host NEXT_PUBLIC_REVERB_PORT=8080 NEXT_PUBLIC_REVERB_SCHEME=http NEXT_IMAGE_DOMAINS=your-laraship-domain,your-aws-bucket-dowmin , specify the allowed image domains. To include
multiple domains, separate them with commas.
- Start the Next.js development server:
npm run dev
-
Start the Laraship Backend:
php artisan serve
-
Start the React/Next.js Frontend:
npm run dev
-
Open your browser and navigate to:
http://localhost:3000
- Log in or register a new account.
- Navigate to the chat page.
- Start a new conversation or join an existing one.
- Send a message and see it appear in real-time for all participants.
- Multiple Attachments: Click on the attachment icon to upload and send multiple files like images, documents, and videos. All media files are stored securely on Amazon S3.
- Is Typing Functionality: A "User is typing..." indicator will appear when another user is typing a message in the conversation.
- Emojis: Click on the emoji icon to browse and insert emojis into your messages.
- Conversation Search: Use the search bar within the chat interface to search through your conversation history.
- Delete Messages: Hover over a message and click the delete icon to remove it from the conversation.
Contributions are welcome! Please feel free to submit a Pull Request or open an Issue to discuss any changes.
This project is licensed under the MIT License - see the LICENSE file for details.