Skip to content

andreazorzi/laravel-advance-model

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Laravel Advance Model

Latest Version on Packagist Total Downloads

A Laravel package that generates complete CRUD resources with a single command. Creates models, controllers, views, routes, and more with Bootstrap 5 UI and htmx functionality for modern web applications.

What This Package Does

This package extends Laravel's model generation by creating a complete set of files for CRUD operations:

  • Model with factory
  • Controller with advanced response methods
  • Blade views with Bootstrap 5 styling
  • Routes (both web and request)
  • Modal components for UI interactions

All generated views use Bootstrap 5 for styling and htmx for seamless AJAX interactions.

Requirements

Frontend Dependencies

This package assumes you have the following assets available in your project:

Installation

  1. Install the package:

    composer require andreazorzi/laravel-advance-model
  2. Install frontend dependencies:

    npm install bootstrap@5 htmx.org toastify-js sweetalert2

Setup

Route Files Configuration

This package automatically adds routes to your route files. You need to add placeholder comments for this to work:

  1. Create or modify routes/request.php:
<?php

use Illuminate\Support\Facades\Route;
// End Controllers Imports

Route::prefix('admin')->group(function () {
    Route::middleware(['auth'])->group(function () {
        Route::resource('users', UserController::class);
        // End Models Routes
    });
});
  1. Modify routes/web.php:
<?php

use Illuminate\Support\Facades\Route;

Route::prefix('admin')->group(function () {
    Route::middleware(['auth'])->group(function () {
        Route::view('users', 'backoffice.users')->name('backoffice.users');
        // End Models Routes
    });
});

Important: The package will automatically add new routes above these placeholder comments.

Usage

Basic Command

php artisan advance:create-model <ClassName> {--type=<creation_type>} {--force}

Examples

# Create a complete User model with all files
php artisan advance:create-model User --type=complete

# Create only model and factory
php artisan advance:create-model Product --type=only-model

# Force overwrite existing files
php artisan advance:create-model Order --type=complete --force

Creation Types

TYPE FILES GENERATED
only-model Model, Factory
with-controller Model, Factory, Controller, Request classes
with-page Model, Factory, Controller, Request classes, Blade views, Filter, Routes
complete All of the above + Modal components

Detailed File Generation Table

CREATION TYPE MODEL FACTORY CONTROLLER REQUESTS VIEW FILTER WEB MODAL
only-model x x
with-controller x x x x
with-page x x x x x x x
complete x x x x x x x x

Generated File Structure

When you run php artisan advance:create-model User --type=complete, the following files are created:

app/
├── Models/User.php
└── Http/
    └── Controllers/UserController.php

database/
└── factories/UserFactory.php

resources/
├── views/backoffice/users.blade.php
└── components/backoffice/modal/users.blade.php

routes/
├── web.php (modified)
└── request.php (modified)

Advanced Controller Features

The generated controllers include several advanced response methods:

Alert Notifications

Display toast notifications using Toastify JS:

// In your controller
public function store(StoreUserRequest $request)
{
    // Your logic here...
    
    return $this->alert([
        "status" => "success", // success, danger, info, warning
        "message" => "User created successfully!",
        "duration" => 3000, // milliseconds (-1 for no auto-close)
        "gravity" => 'bottom', // optional
        "position" => 'center', // optional
        "beforeshow" => 'console.log("Alert about to show");', // optional
        "callback" => 'refreshTable();', // optional: run after alert dismissed
    ]);
}

SweetAlert Modal

Display modal alerts using SweetAlert2:

public function destroy(User $user)
{
    return $this->sweetAlert([
        "status" => "warning",
        "title" => "Delete User",
        "message" => "Are you sure you want to delete this user?",
        "confirm" => [
            "text" => "Yes, delete!",
            "color" => "#DC3545",
            "disable" => false
        ],
        "cancel" => [
            "text" => "Cancel",
            "color" => "#6C757D", 
            "disable" => true
        ],
        "beforeshow" => 'console.log("Modal opening");',
        "onsuccess" => 'deleteUser(' . $user->id . ');',
        "oncancel" => 'console.log("Cancelled");',
    ]);
}

Modal Components

Return Blade view modals for forms and content:

public function edit(User $user)
{
    return $this->modal("users", ["user" => $user]);
}

This returns the view: resources/views/components/backoffice/modal/users.blade.php

The MIT License (MIT)

Copyright © 2024 Andrea Zorzi [email protected]

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published