laravel-admin / crud
Crud Package for Laravel Admin
Installs: 2 098
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 6
Forks: 1
Open Issues: 1
Type:laravel-package
Requires
- php: ^8.2
- laravel/framework: ^11.0
- dev-master
- v2.0.9
- v2.0.8
- v2.0.7
- v2.0.6
- v2.0.5
- v2.0.4
- v2.0.3
- v2.0.2
- v2.0.1
- v2.0.0
- v1.3.0
- v1.2.0
- v1.0.1
- v1.0.0
- v0.6.5
- v0.6.4
- v0.6.3
- v0.6.2
- v0.6.1
- v0.6.0
- v0.5.0
- v0.4.0
- v0.3.2
- v0.3.1
- v0.3.0
- 0.2.2
- v0.2.1
- v0.2.0
- 0.1.14
- 0.1.13
- 0.1.12
- 0.1.11
- 0.1.10
- 0.1.9
- 0.1.8
- 0.1.7
- 0.1.6
- 0.1.5
- 0.1.4
- 0.1.3
- 0.1.2
- 0.1.1
- 0.1.0
- dev-hotfix/2.0.9
- dev-develop
- dev-feature/show-view
- dev-feature/php80
- dev-feature/splitPageTranslationLayout
This package is not auto-updated.
Last update: 2024-11-13 17:23:55 UTC
README
This package is experimental, don't use it for production.
Installation
Install from Packagist:
composer require laravel-admin/crud
Add the service provider to your app.php config file
LaravelAdmin\Crud\CrudServiceProvider::class,
Usage
First create a migration, model and admin controller for your module. Add the admin controller as a resource to your routes, like:
Route::resource('blog', 'BlogController');
Resource controller
Setup your basic controller for crud methods as follow:
<?php
namespace App\Http\Controllers;
use LaravelAdmin\Crud\Controllers\ResourceController;
use App\Blog;
class BlogController extends ResourceController
{
protected $model = Blog::class;
protected $singular_name = "blog";
protected $plural_name = "blogs";
}
The ResourceController includes all the crud methods for a Laravel resource controller, like index, create, store, edit, update and destroy. At this point only the show method will not be used.
The view who will be rendered by index,create and edit are default bootstrap and compatible with the views which will be scaffoled by artisan make:auth.
The only thing you have to do is defining your fields and validation. Herefore you can override a couple of methods of the parent controller in your own controller.
Validation on store
protected function getValidationRulesOnStore()
{
return [
'title' => 'required|string|min:6',
'body' => 'required|string',
];
}
Defining your fields for the create form
protected function getFieldsForCreate()
{
return [
[
'id' => 'title',
'label' => 'Title',
'description' => 'This is the main title of the page',
'field' => 'text',
],
[
'id' => 'body',
'label' => 'Body',
'field' => 'textarea',
]
];
}
Manipulate your payload for store
This method is optional, by default the payload will be the fields which are defined in the getFieldsForCreate method. If you want to manipulate your data, like a password or date format you can implement this method
protected function getPayloadOnStore(array $data)
{
$payload = $this->getPayloadForStoreDefault($data);
// If password is given, lets encrypt it, otherwise remove the password from the payload
if (!empty($payload['password'])) $payload['password'] = bcrypt($payload['password']);
else unset($payload['password']);
return $payload
}
Edit model
For editing your model, the same methods as store are available:
- getValidationRulesOnUpdate
- getFieldsForEdit
- getPayloadOnUpdate
Note: If your settings for store and update are the same, you only have to define the methods for the update.
View your records
For generating the index view, you can define your fields with the getFieldsForList method.
protected function getFieldsForList()
{
return [
[
'id' => 'title',
'label' => 'Title',
],
[
'id' => 'created_at',
'label' => 'Created',
'formatter' => function($model)
{
return $model->created_at->format('Y-m-d');
}
]
];
}
Note: Each field has an optional formatter property. By default the property of the model defined in the id is shown. You can assign a accessor in the format field as string, or a callback as shown above.
More to come....
Layout module
This package includes a layout builder for your page.
Installation
Add the layout config file to your local config folder.
php artisan vendor:publish --provider="LaravelAdmin\Crud\CrudServiceProvider::class"
Add the Layout vue component to your view instance
import layout from '../../../vendor/laravel-admin/crud/resources/js/components/layout/Layout.vue';
Vue.component('layout', layout);
Build your components
Within the config file you can build your own components. Default one simple component is included in the config.
Each component is a combination of fields. The type of fields are:
- Textield (layout-text)
- Textarea (layout-textarea)
- Boolean (layout-boolean)
- Selectbox (layout-select)
- Wysiwyg (layout-wysiwyg) (TinyMCE)
- Media item (layout-media-item) (Only available if LaravelAdmin/MediaManager is available)
note: The selectbox field can have an options attribute, this can be an array or a callback.
Component drivers
Each component can have a custom driver when you need some extra logic before rendering it into a view.
Add a full namespaced class into the driver attribute of your component config to enable it.
The best practice is to extends the default component class:
\LaravelAdmin\Crud\Layout\Component
The following methods can be extended or overwritten:
- getContent
- getView
- isActive
- render
Field drivers
Also each field can have a custom driver, this can be useful when the content from the admin has to be formatted before sending it to the view.
The best practice is to extends the default field class:
\LaravelAdmin\Crud\Layout\Field
You can add methods or overwrite the toString method.
Views
Create your view in the folder which is defined in the layout config (default 'layout'). The name of the template is the same of the id of your component, like 'basic-text.blade.php'.
Note: If you use your own driver, you van set a custom view within the method 'getView'.
Create your admin controller
Within your module add a LayoutController file like this:
<?php
namespace App\Http\Controllers\Admin\Pages;
use LaravelAdmin\Crud\Controllers\LayoutController as BaseController;
class LayoutController extends BaseController
{
use Shared;
protected $model = \App\Models\Page::class;
protected $instance;
protected $singular_name = 'page';
protected $plural_name = 'pages';
}
Add the following route into your module routes:
Route::resource('pages.layout', 'Admin\Pages\LayoutController');
If your layout is in the translatable table, the route will be:
/admin/pages/1/layout/en
If not, it will be:
/admin/pages/1/layout
Render the layout
Add the following trait to the model which has a layout field:
\LaravelAdmin\Crud\Traits\HasLayout
There a several ways to render your layout. The most easy solutions is to render it directly from your view file:
{!! $model->layout()->render() !!}
If you want to use blade includes:
@foreach ($model->layout()->components() as $component)
@include($component->getView(), $component->getContent())
@endforeach
If you want to have executed the logic in your controller:
// Controller
public function show($id)
{
$model = \App\Models\Page::findOrFail($id);
$layout = $model->layout()->components();
return view('page', compact('model','layout'));
}
// View
{!! $layout->render() !!}