Welcome to my personal starter kit! This setup is designed for developers who want a lightweight, modern, and efficient foundation for building Laravel applications with a React frontend powered by InertiaJs.

v1.0.0.0-alpha 2025-03-16 05:38 UTC

This package is auto-updated.

Last update: 2025-03-17 05:09:36 UTC


README

πŸš€ Introduction

Welcome to my personal starter kit YUI! This setup is designed for developers who want a lightweight, modern, and efficient foundation for building Laravel applications with a React frontend powered by Inertia.js.

This kit is JavaScript-first, using JSX instead of TSX, making it accessible to developers who prefer plain JavaScript over TypeScript. It includes React 19, TailwindCSS 4, and Breeze for simple authentication and scaffolding.

🎯 Features

βœ”οΈ React 19 + JSX – Simple, clean, and TypeScript-free
βœ”οΈ Laravel 12 + Breeze – Lightweight authentication with Inertia.js
βœ”οΈ Inertia.js – Create modern single-page React, Vue, and Svelte apps using classic server-side routing.
βœ”οΈ Orion – The simplest way to create REST API with Laravel
βœ”οΈ TanStack Query – Powerful asynchronous state management for TS/JS
βœ”οΈ Laravel-permission – Associate users with roles and permissions
βœ”οΈ TailwindCSS 4 – Modern styling with utility-first CSS
βœ”οΈ Vite-Powered – Lightning-fast HMR for smooth development
βœ”οΈ Pre-configured Testing – Includes PHPUnit & Pest
βœ”οΈ Quick Setup – Get started in minutes!

πŸ›  Getting Started

1️⃣ Install

laravel new --using=luis-developer-08/yui

2️⃣ Install Dependencies

npm install

3️⃣ Run Migrations

php artisan migrate --seed

4️⃣ Start Development

composer run dev

πŸŽ‰ Your application is now up and running!

⚑ Create Inertia Components Easily

This starter kit includes a custom Artisan command to quickly generate Inertia.js React components:

πŸ—οΈ Generate a New Component

php artisan make:inertia Components/MyComponent

This will create a new file at resources/js/Components/MyComponent.jsx with a basic component template.

πŸ“‚ File Structure

resources/js/Components/MyComponent.jsx

✨ Example Generated Component

import React from "react";

const MyComponent = () => {
    return <div>{/* MyComponent component */}</div>;
};

export default MyComponent;

This command ensures that components are placed in the correct directory and prevents overwriting existing files. It also automatically opens the newly created file for editing.

⚑ Create Orion Controllers Easily

This starter kit also includes a command to quickly generate Orion controllers along with their associated models:

πŸ—οΈ Generate a New Orion Controller

php artisan make:orion PostController

This will create:

  • app/Http/Controllers/Orion/PostController.php
  • app/Models/Post.php (if it doesn’t exist)
  • Adds a route in routes/api.php

πŸ“‚ File Structure

app/Http/Controllers/Orion/PostController.php
app/Models/Post.php

✨ Example Generated Controller

<?php

namespace App\Http\Controllers\Orion;

use Orion\Http\Controllers\Controller;
use App\Models\Post;

class PostController extends Controller
{
    protected $model = Post::class;
}

✨ Example Generated Model (if not existing)

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;

class Post extends Model
{
    use HasFactory;

    protected $guarded = [];
}

πŸ”— Auto-Registered Route in routes/api.php

Orion::resource('posts', \App\Http\Controllers\Orion\PostController::class);

This command ensures that controllers are correctly placed, models are created if missing, and routes are automatically registered.

πŸ“– Documentation

For more details on Laravel Breeze, visit the official Laravel Starter Kit docs.

🀝 Contributing

We welcome contributions! Check out the Laravel contribution guide to get involved.

πŸ“œ Code of Conduct

Be kind and respectful. Please follow Laravel's Code of Conduct.

βš–οΈ License

This starter kit is open-source under the MIT license.