Package Data | |
---|---|
Maintainer Username: | abskomol |
Maintainer Contact: | abskomol@gmail.com (Abu Baker Siddique) |
Package Create Date: | 2016-11-19 |
Package Last Update: | 2017-05-14 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-11-19 03:12:13 |
Package Statistics | |
---|---|
Total Downloads: | 34 |
Monthly Downloads: | 2 |
Daily Downloads: | 0 |
Total Stars: | 1 |
Total Watchers: | 2 |
Total Forks: | 0 |
Total Open Issues: | 0 |
A CRUD generator for enterprise application.
Inspired by appzcoder/crud-generator
Laravel >=5.1
PHP >= 5.5.9
Run
composer require tirjok/crud
Add the service provider to config/app.php.
'providers' => [
...
Tirjok\CrudGenerator\CrudGeneratorServiceProvider::class,
],
Install laravelcollective/html helper package.
composer require laravelcollective/html
'providers' => [
...
Collective\Html\HtmlServiceProvider::class,
],
'aliases' => [
...
'Form' => Collective\Html\FormFacade::class,
'HTML' => Collective\Html\HtmlFacade::class,
],
Run composer dump-autoload
Publish vendor files of this package.
php artisan vendor:publish --provider="Tirjok\CrudGenerator\CrudGeneratorServiceProvider"
Note: You should have configured database for this operation.
php artisan crud:generate Posts --fields="title#string; content#text; category#select#options=technology,tips,health" --view-path=admin --namespace=Admin --route-group=admin
Options:
| Option | Description |
| --- | --- |
| --fields
| Fields name for the form & migration. e.g. --fields="title#string; content#text; category#select#options=technology,tips,health; user_id#integer#unsigned"
|
| --route
| Include Crud route to routes.php? yes or no |
| --pk
| The name of the primary key |
| --sd
| Add soft delete to migration and model? yes or no. Default no
|
| --view-path
| The name of the view path |
| --namespace
| The namespace of the CRUD |
| --route-group
| Prefix of the route group |
| --pagination
| The amount of models per page for index pages |
| --indexes
| The fields to add an index to. append "#unique" to a field name to add a unique index. Create composite fields by separating fieldnames with a pipe (--indexes="title,field1|field2#unique"
will create normal index on title, and unique composite on fld1 and fld2) |
| --filters
| The fields to add filter. append "#like" to a field name to add a like query, otherwise it will be equal query. e.g "title#like;color"
|
| --foreign-keys
| Any foreign keys for the table. e.g. --foreign-keys="user_id#id#users#cascade"
where user_id is the column name, id is the name of the field on the foreign table, users is the name of the foreign table, and cascade is the operation 'ON DELETE' together with 'ON UPDATE' |
| --validations
| Validation rules for the form "col_name#rules_set" e.g. "title#min:10|max:30|required"
- See https://laravel.com/docs/master/validation#available-validation-rules |
| --relationships
| The relationships for the model. e.g. --relationships="comments#hasMany#App\Comment"
in the format |
| --localize
| Allow to localize. e.g. localize=yes |
| --locales
| Locales language type. e.g. locals=en |
For controller:
php artisan crud:controller PostsController --crud-name=posts --model-name=Post --view-path="directory" --route-group=admin
For model:
php artisan crud:model Post --fillable="['title', 'body']"
For migration:
php artisan crud:migration posts --schema="title#string; body#text"
For view:
php artisan crud:view posts --fields="title#string; body#text" --view-path="directory" --route-group=admin
For service:
php artisan crud:service PostService --model-name=Post --namespace=admin
For repository:
php artisan crud:repository PostRepository --model-name=Post --filters=title#like --namespace=admin
By default, the generator will attempt to append the crud route to your Route
file. If you don't want the route added, you can use this option --route=no
.
After creating all resources, run migrate command. If necessary, include the route for your crud as well.
php artisan migrate
If you chose not to add the crud route in automatically (see above), you will need to include the route manually.
Route::resource('posts', 'PostsController');
These fields are supported for migration and view's form:
You can customize the generator's stub files/templates to achieve your need.
Make sure you've published package's assets.
php artisan vendor:publish --provider="Tirjok\CrudGenerator\CrudGeneratorServiceProvider"
Turn on custom_template support on config/crudgenerator.php
'custom_template' => true,
From the directory resources/crud-generator/ you can modify or customize the stub files.