connor-lock05 / laravel-admin
Adds an admin panel to a Laravel Application allowing for a UI to modify model data
Installs: 36
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/connor-lock05/laravel-admin
Requires
- php: ^8.2
- laravel/framework: ^11.0
Suggests
- spatie/laravel-permission: Allows for use with Users and Roles
README
Table of Contents
Introduction
A Laravel Admin Panel for laravel applications providing a simple and easy to use interface to create, view, edit or delete model records.
Installation
You can install the package via Composer:
composer require connor-lock05/laravel-admin
Usage
Accessing the admin panel
To access the admin panel there are two available methods of authorisation.
- You can use the ConnorLock05\LaravelAdmin\Middleware\RoleAuthorisationmiddleware. This will use the logged-in user to check they have the correct rolesRequires the spatie/laravel-permission package to be installed 
- Or you can use the ConnorLock05\LaravelAdmin\Middleware\IpAuthorisationmiddleware. This will use the ip origin for the request compared to a comma separated list of ip addresses defined in your .env file DefineADMIN_ALLOWED_IPSin your .env to a list of allowed IPs. i.e (ADMIN_ALLOWED_IPS=127.0.0.1,127.0.0.2)
When using RoleAuthorisation
- Run through the installation process for spatie/laravel-permission here
- You will need to add authentication middleware before the RoleAuthorisation middleware to ensure a user is logged in. Do this in the laravel-admin.phpconfig file (See Configuration)
- You will need to create a role for the admin panel access and add this to your config file.
See how to customise the admin config here
By default, the 'Admin' role is allowed access to the admin panel.
Once logged in, visit /admin to get to the admin panel dashboard
Setting Up Models
To allow a model to be interacted with by the Admin panel, you need to use the ConnorLock05\LaravelAdmin\Traits\ModifiedByAdminPanel trait on a model
This will then require you to define two functions: getModifiableFields and getFieldsForIndexView
getModifiableFields
The getModifiableFields function defines what fields are editable by the admin panel and the data type of the field.
This function returns an associative array with strings (column names) as keys, and ConnorLock05\LaravelAdmin\Interfaces\Type as values.
There are several types defined:
- ConnorLock05\LaravelAdmin\Types\TextThis is a string field
- ConnorLock05\LaravelAdmin\Types\NumberThis is an integer field
- ConnorLock05\LaravelAdmin\Types\PasswordThis is a password field, the value won't be added to the field on edit and if a value is not provided it will not be updated
- ConnorLock05\LaravelAdmin\Types\PicklistThis is a select field, an array of options is provided on creation where keys are the option label and the value is the option value
- ConnorLock05\LaravelAdmin\Types\TextAreaThis is a text area field (intended for text column types)
- ConnorLock05\LaravelAdmin\Types\RelatedThis is a related field, a model is provided on instantiation alongside an optional 'referenceColumn' which is the column name for the field to use as the option label (primary key column is default)
Example
public static function getModifiableFields(): array { return [ 'title' => new Text(), 'user_id' => new Related(User::class, 'name'), 'body' => new TextArea() ]; }
getFieldsForIndexView
The getFieldsForIndexView function defines what fields are shown in the list on the index view.
This function returns a non-associative array of strings of column names to include
Example
public static function getFieldsForIndexView(): array { return [ 'name', 'email' ]; }
Customisation
Configuration
To publish the configuration for this package, run
php artisan vendor:publish --tag="admin-config"
Overriding Views
To publish the views for overriding, run:
php artisan vendor:publish --tag="admin-views"
Views will be published to resources/views/vendor/admin/
License
Laravel Admin is open-sourced software licensed under the MIT license.