Skip to content

Nuxt 3 SPA boilerplate for consume all of Laravel Breeze API default installation (sign in, create account, confirm email, forgot password, reset password, get user data) with auth-guarded dashboard and all redirects.

License

Notifications You must be signed in to change notification settings

volkar/nuxt3-ui-sanctum-breeze-auth

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Nuxt 3 UI for Laravel Breeze auth

Nuxt 3 SPA

Nuxt 3 SPA boilerplate for consume all of Laravel Breeze API default installation (sign in, create account, confirm email, forgot password, reset password, get user data) with auth-guarded dashboard and all redirects.

Features

  • Sign in, crete account, forgot password, reset password and get user data functionality
  • Page guards for authenticated/guest only users with redirect to their default endpoint if status mismatches
  • Simple dashboard for authenticated users
  • Middleware for users with confirmed emails (enabled by default on dashboard page)
  • Displays field errors and success messages
  • Page loading animation and form sending animation
  • Composable to retrieve data from API with cache
  • Adaptive main menu
  • Dark and Light color schemes and switch
  • Markup and styles styles from Amethyst Lite
  • Base layout and default styles in app.vue, content styles in AppMain.vue

Includes

Screenshots

Index page Index page Create account Create account Email verification Email verification Email verified / dashboard Dashboard Sign in Sign in Forgot password Forgot password Light color scheme Light color scheme Mobile version Mobile version

Installation

Install Laravel Breeze (API version), do all that standard stuff with migrations and database connection.

Copy this project to folder of your choice

git clone https://github.com/volkar/nuxt3-ui-sanctum-breeze-auth.git

Go to folder

cd nuxt3-ui-sanctum-breeze-auth

Install dependencies

npm install

Email-verified users

If you want to keep verified email only users to be able to access dashboard page, modify /app/Models/User.php and add MustVerifyEmail to the users:

namespace App\Models;

use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;

class User extends Authenticatable implements MustVerifyEmail
{
    use HasFactory, Notifiable;

    // ...

Email-unverified users

Or if you want to allow unverified users to access dashboard - change middleware at /pages/dashboard.vue

middleware: ["sanctum:verified"]

to

middleware: ["sanctum:auth"],

CORS

Assumed that laravel will run on 127.0.0.1:8000 (default php artisan serve port) and nuxt will run on 127.0.0.1:3000 (default npm run dev port)

Open laravel's .env and edit/add this lines:

APP_URL=http://127.0.0.1:8000
FRONTEND_URL=http://127.0.0.1:3000
SANCTUM_STATEFUL_DOMAINS="127.0.0.1:3000,127.0.0.1"

SESSION_DOMAIN=127.0.0.1

Run laravel

php artisan serve

It will run on http://127.0.0.1:8000 by default.

Run Nuxt

npm run dev

It will run on http://127.0.0.1:3000 by default. Open http://127.0.0.1:3000 in browser and you good to go!

Cached data composable

The example page pages\data.vue uses the composable useApiGetCached for Laravel's endpoint api/user with a cache time of 10 seconds. New data will only be fetched from the API after this time has elapsed.

There is another composable useApiGet without cache to fetch data on every request without cache.

Contact me

You always welcome to write me

About

Nuxt 3 SPA boilerplate for consume all of Laravel Breeze API default installation (sign in, create account, confirm email, forgot password, reset password, get user data) with auth-guarded dashboard and all redirects.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published