lilessam / eloquent-fields
Simple eloquent model fields generator package for Laravel 5.5
Installs: 65
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 1
pkg:composer/lilessam/eloquent-fields
Requires
- php: >=7.1.0
- illuminate/support: ~5.0
This package is not auto-updated.
Last update: 2025-10-26 10:26:40 UTC
README
Eloquent-Fields Generator Package For Laravel
This package actually contains a helper function and a trait. Its basic target is to reduce time that developers spend writing Creation & Update forms markup for Eloquent Models.
It's basic idea is to use the FormGenerator trait in your model and write a tiny array with your fields' preferences. Then you can use the helper function to generate a creation or update form.
Installing.
Via composer
composer require lilessam/eloquent-fields dev-master
Then in your model use the trait Lilessam\EloquentFields\Traits\FormGenerator like the following:
<?php namespace App; use Illuminate\Database\Eloquent\Model; use Lilessam\EloquentFields\Traits\FormGenerator; class Fee extends Model { use FormGenerator; }
How to use it?
By defining a static array in your model called $fields and its structure should be as following example.
public static $fields = [ 'field_name_attribute' => [ // Field name attribute should be the column name in DB as well to retreive its value in update form generation. 'label' => 'اسم الحقل', // Field Label. 'input' => 'input', // Field Type. 'type' => 'text' // Field Input Type. ], ];
This will generate a bootstrap form-group div contains this field.
Then you can generate a creation form fields in your view files like the following example:
<form class="form-horizontal" method="post"> {!! generate_fields('App\Fee') !!} {!! csrf_field() !!} <button type="submit" class="btn btn-primary">حفظ!</button> </form>
And you can create an update form fields by passing a second parameter contains the object id.
<form class="form-horizontal" method="post"> {!! generate_fields('App\Fee', 1) !!} {!! csrf_field() !!} <button type="submit" class="btn btn-primary">حفظ!</button> </form>
So this actually will generate an update form fields for the row which its id is 1.
Full Guide
$fields array writing rules.
- Must provide
label. - Must provide
inputwhich can beinput,selectortextarea.
If the input index is input you must provide a type index to provide the input type like text or number or date etc.
If the input type is select you can provide an options index which will contain an array for the select dropdown options. Or you can provide a relation index which will get options from a relation in the eloquent model.
Relation array
There's three types of Eloquent Relatioships supported till now in the package. You have to provide a type index in the relation array to specify the relation type based on the following:
belongsToits type will beonebecause we will only select one option in this case.hasManyOrbelongsToMany: their type will bemanybecause we will select multiple values.
If the type index in the relation array is one you will need to provide
modelindex which will be the relation model.columnwhich is the foreign key.selectFromwhich will be the column we need to display in the option from the relation model.valueFromwhich will be the column from the relational model that will be the value of the option of the select dropdown.
If the type index in the relation array is many you will need to provide
nameindex which will be the name of the relation. For example if my model isUserand it has manyRoleso the name of the relation will berolesor whatever the name of the relation you created in theUsermodel.
You will also need to provide a selectFrom and valueFrom as well.
If the input is a select you can provide a valueFallback which will be a static method returns all the options in the dropdown and then you need to provide a valueCallback which will return the selected options collection.
Additional Preferences
There are multiple additional things that can be very usefull in all your fields specifications.
label_classeswhich is the label class attribute value. You can override the default classes which arecontrol-label col-md-4.input_div_classeswhich is the class attribute of the div that contains the input code. By default it'scol-md-6.input_classes:which is the class attribute of the input itself. By default it'sform-control.input_idwhich is the id attribute of the input itself. By default it's the field name.inject_attributeswhich allows you to add additional attributes to the input. It just takes the string and put it in the input tag.
Examples.
A normal text field:
'name' => [ 'label' => 'Your name', 'input' => 'input', 'type' => 'text' ],
A number field:
'age' => [ 'label' => 'Your age', 'input' => 'input', 'type' => 'number' ],
If the model belongs to a role and we wanna make a select field for the roles.
'role_id' => [ 'label' =>'Role', 'input' => 'select', 'relation' => [ 'model' => 'App\Role', 'type' => 'one', 'column' => 'role_id', 'selectFrom' => 'name', 'valueFrom' => 'id', // This is how selectFrom and valueFrom works // <option value="{{ $role->id }}">{{ $role->name }}</option> ], ],
What if the model belongs to many roles?
'roles[]' => [ 'label' => 'Roles', 'input' => 'select', 'relation' => [ 'name' => 'roles', 'model' => 'App\Role', 'type' => 'many', 'selectFrom' => 'name', 'valueFrom' => 'id' ], 'inject_attributes' => 'multiple' ],
A full example how should be the $fields array of a user model.
<?php namespace App; use Illuminate\Database\Eloquent\Model; use Lilessam\EloquentFields\Traits\FormGenerator; class User extends Model { use FormGenerator; public static $fields = [ 'name' => [ 'label' => 'Your name', 'input' => 'input', 'type' => 'text', ], 'age' => [ 'label' => 'Your age', 'input' => 'input', 'type' => 'number', ], 'roles[]' => [ 'label' => 'Roles', 'input' => 'select', 'relation' => [ 'name' => 'roles', 'model' => 'App\Role', 'type' => 'many', 'selectFrom' => 'name', 'valueFrom' => 'id', ], 'inject_attributes' => 'multiple' ], ]; public function roles() { return $this->belongsToMany('App\Role'); } }
Example for valueCallbacks and valueFallbacks.
public static $fields = [ 'exception_ids[]' => [ 'label' => 'المنتجات المستثناة', 'input' => 'select', 'valueCallback' => 'getExceptionsValues', 'valueFallback' => 'getAllProducts', 'selectFrom' => 'name_ar', 'valueFrom' => 'id', 'inject_attributes' => 'multiple' ], ]; public function getExceptionsValues() { $results = []; $exception_ids = $this->exception_ids ? json_decode($this->exception_ids) : []; foreach ($exception_ids as $exception_id) { $product = Product::find($exception_id); $results[] = $product; } return $results; } public static function getAllProducts() { return Product::latest()->get(); }
Example for manual belongsTo relation with createValueCallbacks and updateValueFallbacks.
/** * The attributes that are building the model forms. * * @var array */ public static $fields = [ 'name_ar' => [ 'label' => 'الاسم بالعربية', ], 'name_en' => [ 'label' => 'الاسم بالإنجليزية', ], 'category_id' => [ 'label' => 'التصنيف الأساسي', 'input' => 'select', 'options' => [ '' => 'لا تصنيف', ], 'selectFrom' => 'name_ar', 'valueFrom' => 'id', 'valueCallback' => 'getCurrentValue', // Can be replaced with 'column' => 'category_id' for belongsTo relation 'updateValueFallback' => 'getUpdateCategories', 'createValueFallback' => 'getAllCategories', ], ]; /** * Get dropdown categories for EloquentFields. * * @return self */ public function getUpdateCategories() { return static::where('id', '!=', $this->id)->get(); } /** * Get all dropdown categories for EloquentFields Creation. * * @return self */ public static function getAllCategories() { return static::latest()->get(); } /** * Get Current value for the manual relation. * @return mixed */ public function getCurrentValue() { return $this->category_id; }
Then you can just call generate_fields('App\User') to generate a creation form fields or generate_fields('App\User', 1) to generate an update form fields for User whose id is 1.
Notice that you can pass a third parameter to generate_fields parameter to except one or many fields from being generated in the form.
So if we called generate_fields('App\User', null, 'age') a creation form will be created without age field. You can also pass an array so generate_fields('App\User', null, ['age', 'roles']) will create a creation form without roles and age fields.