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.
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.
This package assumes you have the following assets available in your project:
- Bootstrap 5 - for styling the generated tables and UI components
- htmx - for handling AJAX requests
- Toastify JS - for alert notifications
- SweetAlert2 - for alert notifications
-
composer require andreazorzi/laravel-advance-model
-
npm install bootstrap@5 htmx.org toastify-js sweetalert2
This package automatically adds routes to your route files. You need to add placeholder comments for this to work:
- 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
});
});
- 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.
php artisan advance:create-model <ClassName> {--type=<creation_type>} {--force}
# 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
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 |
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 |
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)
The generated controllers include several advanced response methods:
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
]);
}
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");',
]);
}
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
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.