vormiaphp / ui-livewireflux-admin
Vormia UI Livewire Flux Admin - Admin panel components and routes for Laravel applications using Livewire Volt and Flux
Package info
github.com/vormiaphp/ui-livewireflux-admin
pkg:composer/vormiaphp/ui-livewireflux-admin
Requires
- php: ^8.2
- laravel/fortify: ^1.0 || ^2.0
- laravel/framework: ^12.0
- livewire/flux: ^1.0 || ^2.0
- livewire/livewire: ^4.0
- vormiaphp/vormia: ^5.0
README
A Laravel package that provides a complete admin panel solution with pre-built components, routes, and views for managing categories, inheritance, locations, availability, and admin users. Built with Livewire Volt and Flux for a modern, reactive admin interface.
What is This Package?
Vormia UI Livewire Flux Admin is a comprehensive admin panel package for Laravel applications that includes:
- AdminPanel View Component - A reusable Blade component for consistent admin panel layouts
- Pre-configured Admin Routes - Complete CRUD routes for all admin sections
- Livewire Volt Components - Single-file components for categories, inheritance, locations, availability, and admin management
- Automatic Sidebar Integration - Sidebar menu injection (requires livewire/flux)
- Role Management - See
docs/ROLE-ON-REGISTRATION.mdfor assigning roles on registration
This package is designed to work seamlessly with the Vormia ecosystem and follows Laravel best practices.
Prerequisites
This package runs on Vormia v5. Required dependencies (installed automatically when you require this package):
- vormiaphp/vormia ^5.0 (no less)
- livewire/flux ^1.0
- laravel/fortify ^2.0
Volt is not required — with Vormia v5 / Livewire 4, Volt is bundled with Livewire.
Installation Process
Step 1: Install the Package
composer require vormiaphp/ui-livewireflux-admin
Step 2: Run the Installation Command
php artisan ui-livewireflux-admin:install
This command will:
- ✅ Check for required dependencies
- ✅ Copy all package files to your application
- ✅ Inject routes into
routes/web.php - ✅ Inject sidebar menu
- ✅ Copy
EnsureUserIsActive.php— seedocs/FORTIFY-IS-ACTIVE.mdto register it in Fortify - ✅ Clear application caches
Step 3: Verify Installation
After installation, verify that:
- Files were copied to
app/View/Components/AdminPanel.php - Routes were added to
routes/web.php - Sidebar menu was added
- Caches were cleared
Manual Configuration (If Needed)
Routes Not Injected Automatically
If the routes were not automatically injected into routes/web.php, manually add them:
- Open
routes/web.php - If you have configured your own starterkit, add the Volt import at the top of the file:
use Livewire\Volt\Volt;
- Find the
Route::middleware(['auth'])->group(function () { ... });block - Add the routes from
vendor/vormiaphp/ui-livewireflux-admin/src/stubs/reference/routes-to-add.phpinside this block
Example:
<?php use Livewire\Volt\Volt; // Add this if you have configured your own starterkit Route::middleware(['auth'])->group(function () { // ... existing routes ... // Add admin routes here Route::group(['prefix' => 'admin'], function () { // Routes from routes-to-add.php }); });
Sidebar Menu Not Injected
If the sidebar menu wasn't injected:
- Open your sidebar file. The package checks (in order):
resources/views/layouts/app/sidebar.blade.php, thenresources/views/components/layouts/app/sidebar.blade.php - Find the Platform
flux:sidebar.group(the group containing the Dashboard menu item) - Add the code from
vendor/vormiaphp/ui-livewireflux-admin/src/stubs/reference/sidebar-menu-to-add.blade.phpinside the Platform group, before the closing</flux:sidebar.group>tag
Example:
<flux:sidebar.group :heading="__('Platform')" class="grid"> <flux:sidebar.item icon="home" :href="route('dashboard')" wire:navigate> {{ __('Dashboard') }} </flux:sidebar.item> <!-- Add admin menu items here, before the closing tag --> </flux:sidebar.group>
Role Attachment Not Working
To attach roles to new users (e.g. in registration), use the Role model from the Vormia package (Vormia\Vormia\Models\Role) and look up by name:
use Vormia\Vormia\Models\Role; // In your user registration logic $user = User::create([...]); $defaultRole = Role::where('name', 'user')->first(); if ($defaultRole) { $user->roles()->attach($defaultRole); }
What You Get
1. AdminPanel Component
A reusable Blade component for consistent admin panel layouts:
<x-admin-panel header="Categories" desc="Manage your categories" :button="$createButton" > <!-- Your content here --> </x-admin-panel>
Location: app/View/Components/AdminPanel.php and resources/views/components/admin-panel.blade.php
2. Admin Routes
Pre-configured routes for all admin sections:
- Categories:
/admin/categories,/admin/categories/create,/admin/categories/edit/{id} - Inheritance:
/admin/inheritance,/admin/inheritance/create,/admin/inheritance/edit/{id} - Countries:
/admin/countries,/admin/countries/create,/admin/countries/edit/{id} - Cities:
/admin/cities,/admin/cities/create,/admin/cities/edit/{id} - Availability:
/admin/availabilities,/admin/availabilities/create,/admin/availabilities/edit/{id} - Admins:
/admin/admins,/admin/admins/create,/admin/admins/edit/{id}
All routes are protected by auth middleware.
3. Livewire Volt Components
Single-file components for each admin section:
resources/views/livewire/admin/admins/- Admin user managementresources/views/livewire/admin/control/categories/- Category managementresources/views/livewire/admin/control/inheritance/- Inheritance managementresources/views/livewire/admin/control/locations/- Location management (countries/cities)resources/views/livewire/admin/control/availability/- Availability management
Each section includes:
index.php/index.blade.php- List viewcreate.php/create.blade.php- Create formedit.php/edit.blade.php- Edit form
4. Sidebar Menu Integration
The sidebar automatically includes:
- Countries navigation link
- Cities navigation link
- Availability navigation link
- Inheritance navigation link
- Admins navigation link (for super admins only)
5. Role Management
Role models live in the Vormia package (Vormia\Vormia\Models\Role). To assign roles to new users on registration, see docs/ROLE-ON-REGISTRATION.md.
What to Be Aware Of
⚠️ Important Considerations
-
File Overwrites
- The installation process will copy files to your application
- If files already exist, you'll be prompted to overwrite them
- Always backup your files before updating
-
Middleware Requirements
- All admin routes require
authmiddleware - Ensure your application has this middleware configured
- All admin routes require
-
Role models
- Roles are referenced from the Vormia package:
Vormia\Vormia\Models\Role. Seedocs/ROLE-ON-REGISTRATION.mdfor how to assign roles on registration.
- Roles are referenced from the Vormia package:
-
Sidebar File Location
- The package checks (in order):
resources/views/layouts/app/sidebar.blade.php, thenresources/views/components/layouts/app/sidebar.blade.php - Menu items are inserted inside the Platform
flux:sidebar.group, before the closing</flux:sidebar.group>tag - If your sidebar is elsewhere, add the menu manually
- The package checks (in order):
-
Route Injection
- Routes are injected into
routes/web.php - The package looks for:
Route::middleware(['auth'])->group(function () { ... }); - If this pattern doesn't exist, routes won't be injected automatically
- Routes are injected into
-
Custom Modifications
- Any custom modifications to package files will be lost when updating
- Consider extending components instead of modifying them directly
- Backups are created during updates (stored in
storage/app/ui-livewireflux-admin-backups/)
-
Dependencies
- The package requires
vormiaphp/vormia,livewire/flux, andlaravel/fortify. Volt is not required (this package targets Vormia v5 / Livewire 4).
- The package requires
Help, Update, and Uninstallation
Getting Help
Display comprehensive help information:
php artisan ui-livewireflux-admin:help
This command shows:
- Available commands
- Usage examples
- Package features
- Requirements
- Troubleshooting tips
Checking Dependencies
Verify that all required and optional dependencies are installed:
php artisan ui-livewireflux-admin:check-dependencies
This command checks for:
- ✅ vormiaphp/vormia (required)
- ✅ livewire/flux (required)
- ✅ laravel/fortify (required)
Updating the Package
Update all package files to the latest version:
php artisan ui-livewireflux-admin:update
What happens:
- Creates a backup of existing files in
storage/app/ui-livewireflux-admin-backups/ - Replaces all package files with fresh copies
- Clears application caches
Force update (skip confirmation):
php artisan ui-livewireflux-admin:update --force
⚠️ Warning: This will overwrite any custom modifications to package files. Always backup your changes first!
Uninstalling the Package
Remove all package files and configurations:
php artisan ui-livewireflux-admin:uninstall
What gets removed:
app/View/Components/AdminPanel.phpapp/Actions/Fortify/EnsureUserIsActive.php(if copied)resources/views/components/admin-panel.blade.phpresources/views/livewire/admin/directory- Routes from
routes/web.php - Sidebar menu items from
sidebar.blade.php
Force uninstall (skip confirmation):
php artisan ui-livewireflux-admin:uninstall --force
⚠️ Warning: This action cannot be undone! Make sure you have backups before uninstalling.
Manual Route Removal:
If you need to manually remove routes, simply delete routes based on their names from routes/web.php:
admin.categories.index,admin.categories.create,admin.categories.editadmin.inheritance.index,admin.inheritance.create,admin.inheritance.editadmin.countries.index,admin.countries.create,admin.countries.editadmin.cities.index,admin.cities.create,admin.cities.editadmin.availabilities.index,admin.availabilities.create,admin.availabilities.editadmin.admins.index,admin.admins.create,admin.admins.edit
After uninstallation:
- Remove the package from
composer.json:composer remove vormiaphp/ui-livewireflux-admin
- Run
composer updateto clean up dependencies
Package Structure
UILivewireFlux-Admin/
├── src/
│ ├── Console/
│ │ └── Commands/
│ │ ├── InstallCommand.php
│ │ ├── UpdateCommand.php
│ │ ├── UninstallCommand.php
│ │ ├── HelpCommand.php
│ │ └── CheckDependenciesCommand.php
│ ├── stubs/ # Files copied to Laravel app
│ │ ├── app/
│ │ │ ├── View/
│ │ │ │ └── Components/
│ │ │ │ └── AdminPanel.php
│ │ │ └── Actions/
│ │ │ └── Fortify/
│ │ │ └── EnsureUserIsActive.php
│ │ └── resources/
│ │ └── views/
│ │ ├── components/
│ │ │ └── admin-panel.blade.php
│ │ └── livewire/
│ │ └── admin/
│ │ ├── admins/
│ │ └── control/
│ │ ├── availability/
│ │ ├── categories/
│ │ ├── inheritance/
│ │ └── locations/
│ ├── UILivewireFlux.php
│ └── UILivewireFluxAdminServiceProvider.php
├── src/
│ └── stubs/
│ └── reference/
│ ├── routes-to-add.php # Routes snippet
│ └── sidebar-menu-to-add.blade.php # Sidebar snippet
├── composer.json
└── README.md
Usage Examples
Using the AdminPanel Component
<x-admin-panel header="Manage Categories" desc="Create, edit, and delete categories" :button=" <a href='{{ route('admin.categories.create') }}' class='btn btn-primary'> Create Category </a> " > <!-- Your table or content here --> <table> <!-- ... --> </table> </x-admin-panel>
Accessing Admin Routes
All routes are accessible via their named routes:
route('admin.categories.index') route('admin.categories.create') route('admin.categories.edit', ['id' => 1])
Troubleshooting
Installation Fails
Problem: Installation command fails with dependency errors.
Solution:
- Ensure
vormiaphp/vormia,livewire/flux, andlaravel/fortifyare installed. Volt is not required (this package runs on Vormia v5). - Run
php artisan ui-livewireflux-admin:check-dependenciesto verify - Check that your PHP version is >= 8.2
- Check that your Laravel version is >= 12.0
Routes Not Working
Problem: Admin routes return 404 or are not accessible.
Solution:
- Verify routes were injected into
routes/web.php - Check that the middleware group exists:
Route::middleware(['auth'])->group(...) - Run
php artisan route:clearandphp artisan route:cache - Verify you're logged in and have the required permissions
Sidebar Menu Not Appearing
Problem: Sidebar menu items are not visible.
Solution:
- Check if
livewire/fluxis installed:composer show livewire/flux - Verify the sidebar file exists at
resources/views/layouts/app/sidebar.blade.phporresources/views/components/layouts/app/sidebar.blade.php - Add the menu code inside the Platform
flux:sidebar.group(before</flux:sidebar.group>) fromvendor/vormiaphp/ui-livewireflux-admin/src/stubs/reference/sidebar-menu-to-add.blade.php - Clear view cache:
php artisan view:clear
Role Attachment Not Working
Problem: New users are not getting the expected role.
Solution:
Use Vormia\Vormia\Models\Role from the Vormia package and attach by role model (e.g. look up by name). See docs/ROLE-ON-REGISTRATION.md for how to update CreateNewUser to attach roles on registration.
Changelog
v3.0.0 (2025-03-01)
- Major release with improvements and updates
License
MIT
Support
For issues, questions, or contributions, please visit: