pierresilva / laravel-generator by pierresilva

Laravel 5 crud Generator
17
1
3
Package Data
Maintainer Username: pierresilva
Maintainer Contact: pierre.silva@lab3studio.com (Pierre Silva)
Package Create Date: 2017-01-16
Package Last Update: 2017-01-23
Language: PHP
License: MIT
Last Refreshed: 2025-01-03 03:04:23
Package Statistics
Total Downloads: 17
Monthly Downloads: 0
Daily Downloads: 0
Total Stars: 1
Total Watchers: 3
Total Forks: 0
Total Open Issues: 0

Laravel 5 CRUD Generator

Requirements

Laravel >=5.1
PHP >= 5.5.9

Installation

  1. Run

    composer require pierresilva/laravel-generator
    
  2. Add the service provider to config/app.php.

    'providers' => [
        ...
    
        pierresilva\LaravelGenerator\LaravelGeneratorServiceProvider::class,
    ],
    
  3. Install laravelcollective/html helper package.

    • Run
    composer require laravelcollective/html
    
    • Add service provider & aliases to config/app.php.
    'providers' => [
        ...
    
        Collective\Html\HtmlServiceProvider::class,
    ],
    
    'aliases' => [
        ...
    
        'Form' => Collective\Html\FormFacade::class,
        'HTML' => Collective\Html\HtmlFacade::class,
    ],
    
  4. Run composer dump-autoload

  5. Publish vendor files of this package.

    php artisan vendor:publish --provider="pierresilva\LaravelGenerator\LaravelGeneratorServiceProvider"
    

Note: You should have configured database for this operation.

Commands

Crud command:

php artisan generate:crud Posts --fields="title#string; content#text; category#select#options=technology,tips,health" --view-path=admin --controller-namespace=Admin --route-group=admin

Crud fields from a JSON file:

{
   "fields": [
        {
            "name": "title",
            "type": "string"
        },
        {
            "name": "content",
            "type": "text"
        },
        {
            "name": "category",
            "type": "select",
            "options": ["technology", "tips", "health"]
        }
   ]
}
php artisan generate:crud Posts --fields_from_file="/path/to/fields.json" --view-path=admin --controller-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" | | --fields_from_file | Fields from a JSON file. e.g. --fields_from_file="/path/to/fields.json" | | --route | Include Crud route to routes.php? yes or no | | --pk | The name of the primary key | | --view-path | The name of the view path | | --controller-namespace | The namespace of the controller - sub directories will be created | | --model-namespace | The namespace that the model will be placed in - directories will be created | | --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) | | --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 |


Other commands (optional):

For controller:

php artisan generate:controller PostsController --crud-name=posts --model-name=Post --view-path="directory" --route-group=admin

For model:

php artisan generate:model Post --fillable="['title', 'body']"

For migration:

php artisan generate:migration posts --schema="title#string; body#text"

For view:

php artisan generate:view posts --fields="title#string; body#text" --view-path="directory" --route-group=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');

Supported Field Types

These fields are supported for migration and view's form:

Form Field Types:

  • text
  • textarea
  • password
  • email
  • number
  • date
  • datetime
  • time
  • radio
  • select
  • file

Migration Field Types:

  • string
  • char
  • varchar
  • date
  • datetime
  • time
  • timestamp
  • text
  • mediumtext
  • longtext
  • json
  • jsonb
  • binary
  • integer
  • bigint
  • mediumint
  • tinyint
  • smallint
  • boolean
  • decimal
  • double
  • float
  • enum

Custom Generator's Stub Templates

You can customize the generator's stub files/templates to achieve your need.

  1. Make sure you've published package's assets.

    php artisan vendor:publish --provider="pierresilva\LaravelGenerator\LaravelGeneratorServiceProvider"
    
  2. Turn on custom_template support on config/laravelgenerator.php

    'custom_template' => true,
    
  3. From the directory resources/laravel-generator/ you can modify or customize the stub files.

Author

Pierre Silva