Laravel CRUD Generator
Laravel >=5.1
PHP >= 5.5.9
-
Run
composer require appzcoder/crud-generator
-
Add service provider to /config/app.php file.
'providers' => [ ... Appzcoder\CrudGenerator\CrudGeneratorServiceProvider::class, ],
-
Install laravelcollective/html package for form & html.
- Run
// For laravel 5.1 composer require laravelcollective/html // For laravel 5.2 composer require laravelcollective/html:5.2.*-dev
- Add service provider & aliases to /config/app.php file.
'providers' => [ ... Collective\Html\HtmlServiceProvider::class, ], // Use the lines below for "laravelcollective/html" package otherwise remove it. 'aliases' => [ ... 'Form' => Collective\Html\FormFacade::class, 'HTML' => Collective\Html\HtmlFacade::class, ],
-
Run composer update
Note: You need to have a database configured for this operation.
php artisan crud:generate Person --fields="name:string, email:string, age:number, message:text"
You can also easily include route, set primary key, set views directory etc through options --route, --pk, --view-path as bellows:
php artisan crud:generate Person --fields="name:string:required, email:string, age:number, message:text:required" --route=yes --pk=id --view-path="admin" --namespace=Admin
For controller generator:
php artisan crud:controller PersonController --crud-name=Person --view-path="directory"
For model generator:
php artisan crud:model Person --fillable="['name', 'email', 'message']"
For migration generator:
php artisan crud:migration person --schema="name:string, email:string, age:number, message:text"
For view generator:
php artisan crud:view Person --fields="name:string, email:string, age:number, message:text" --view-path="directory"
By default, the generator will attempt to append the crud route to your routes.php file. If you don't want the route added, you can use the 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('person', 'PersonController');
These fields are supported for migration and view's form:
- string
- char
- varchar
- password
- date
- datetime
- time
- timestamp
- text
- mediumtext
- longtext
- json
- jsonb
- binary
- number
- integer
- bigint
- mediumint
- tinyint
- smallint
- boolean
- decimal
- double
- float
##Author