yaddabristol / crud

Extendable CRUD controller for Laravel
0 stars 0 forks source link

CRUD

Extendable CRUD controller for quick development.

Requirements

Installation

Usage

CRUD is designed to let you use the full power of Laravel without having to write tedious controllers and form and list views. The basic steps for creating a new section are as follows:

  1. Create a database table

    php artisan make:migration create_things_table --create=things
  2. Create a Model

    php artisan make:model Thing
  3. Create a Controller

    php artisan make:controller ThingController
  4. Update your controller so that it extends the CRUD controller. E.g.

    <?php
    
    namespace App\Http\Controllers;
    
    use Illuminate\Http\Request;
    use Yaddabristol\Crud\Controllers\CrudController;
    
    class ThingController extends CrudController {
        // ...
    }

Controller Configuration

You'll want to override some of these things in your controller. See the source code of Controllers\CrudController for more info.

protected $model = Thing::class;
protected $views_dir = 'thing_views';
protected $name_singular = 'Thing';
protected $name_plural = 'Things';
protected $route = 'admin';
protected $rules = [];
protected $messages = [];
protected $paginate = false;
protected $settings = [
  'perpage' => 20,
  'orderby' => 'id',
  'order' => 'ASC'
];
protected $searchables = ['id'];
protected $group_by = 'id';
protected $has_files = false;
protected $form_fields = [];
protected $table_columns = ['id'];

Form Generation

To automatically generate a form add something like the following to your form.blade.php

@include('crud::partials.autoform', [
  'fields' => $form_fields,
  'model'  => $item
])

Then populate the form_fields attribute of your controller with an array of fields. E.g.

protected $form_fields = [
    'your_field_name' => [
        'type' => 'text',
        'label' => 'A Text Field',
        'placeholder' => 'Put some text here',
        'help_text' => 'This is a field for entering text',
        'required' => true
    ]
];

Available Options

Images

The image field type assumes the use of Laravel Stapler for attaching images to models. If you don't want to use that, you can easily override the image field type or create your own. Just copy crud/src/Views/fields/image.blade.php to {YOUR_APP}/resources/views/fields/image.blade.php.

Usage Notes

Default Values

To add default values in a create form, set protected $attributes = []; on your model.

Gotchas

Models

Remember to set up the fillable attribute on your Model, otherwise it will fail with a mass assignment exception on _token.

File uploads

If you add a file/image field to a form, you'll need to set protected $has_files = true; on your controller.

Development

Need to add line to base-install under autoload - PSR4 when developing from the packages folder: "Yaddabristol\\Crud\\": "packages/yadda/crud/src/".

You'll need to require the laravelcollective/html package from your base install as you'll be developing in the packages folder and it won't automatically register it's requirements

Documentation

To generate the docs use apigen:

apigen generate -s src -d docs

Todo