Skip to content

qirolab/Nuxt3-Laravel-Reverb-Chat

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 

Repository files navigation

Real-Time Chat App with Laravel Reverb and Nuxt 3

This repository contains the complete source code for a real-time chat application using Laravel Reverb for the backend (API) and Nuxt 3 for the frontend. This app demonstrates how to set up a chat interface with real-time messaging, typing indicators, and more using separate Laravel and Nuxt 3 projects.

Features

  • Real-Time Messaging using Laravel Reverb and Laravel Echo
  • Laravel Sanctum Authentication for secure API access
  • Typing Indicator with Echo Whisper events
  • Private Chat Channels for user-to-user communication
  • Nuxt 3 as the frontend framework with Vue 3 composition API
  • Laravel as the backend API with Reverb for broadcasting events

Tutorial

For a step-by-step guide, watch the full tutorial on YouTube:

Nuxt Sanctum Authentication with Laravel Sanctum

Installation

1. Clone the repository

git clone git@github.com:qirolab/Nuxt3-Laravel-Reverb-Chat.git

2. Setup Laravel

  1. Navigate to the Laravel folder and install dependencies:
cd laravel-api
composer install
  1. Copy the .env.example to .env:
cp .env.example .env
  1. Generate the application key:
php artisan key:generate
  1. Set up your database in the .env file and run migrations:
php artisan migrate
  1. Start the Laravel development server:
php artisan serve
  1. In a new terminal, run the Laravel Reverb server:
php artisan reverb:start

3. Setup Nuxt 3

  1. Navigate to the Nuxt app folder and install dependencies:
cd nuxt3-app
npm install
  1. Copy the .env.example to .env:
cp .env.example .env
  1. Make sure to set the NUXT_SANCTUM_API_URL in your .env file to point to your Laravel app URL.

  2. Run the Nuxt development server:

npm run dev

Project Structure

Laravel API

The Laravel backend is located in the laravel-api directory and is responsible for:

  • Handling user authentication via Laravel Sanctum.
  • Broadcasting real-time events using Laravel Reverb.
  • Managing chat messages and users.

Nuxt 3 App

The Nuxt 3 frontend is located in the nuxt3-app directory and handles:

  • Displaying real-time chat messages.
  • User authentication and routing.
  • Integrating with Laravel Echo to listen for broadcasted messages and typing events.

Support my work

If you found this demo helpful and want to support my work, check out some of my other products:

Ctrl+Alt+Cheat     Spec Coder     JavaScript Guide

Get $200 free credit for DigitalOcean! (Use this link to sign up)

DigitalOcean Referral Badge

License

This project is open-sourced software licensed under the MIT license.

Releases

No releases published

Packages

No packages published

Languages

  • PHP 58.4%
  • Blade 27.0%
  • Vue 11.3%
  • TypeScript 2.5%
  • Other 0.8%