intentor / laravel-form
Form helpers for Laravel 5.
Installs: 775
Dependents: 0
Suggesters: 0
Security: 0
Stars: 10
Watchers: 3
Forks: 3
Open Issues: 0
Language:HTML
Requires
- php: >=5.4.0
- laravel/framework: ~5.1
This package is not auto-updated.
Last update: 2024-12-07 18:34:54 UTC
README
Form helpers for Laravel 5
Currently the project is DISCONTINUED. However, feel free to fork it and continue its development!
Contents
Introduction
Laravel Form provides a series of helpers for form creation in PHP pages and Blade templates.
Compatible with Laravel 5.
Installation
Laravel 5.0
At composer.json
of your Laravel installation, add the following require line:
{ "require": { "intentor/laravel-form": "~1.0" } }
Run composer update
to add the package to your Laravel app.
At config/app.php
, add the Service Provider and the Facade:
'providers' => [ 'Intentor\LaravelForm\ServiceProvider', ] //... 'aliases' => [ 'Form' => 'Intentor\LaravelForm\Facade' ]
Laravel 5.1+
At composer.json
of your Laravel installation, add the following require line:
{ "require": { "intentor/laravel-form": "~2.0" } }
Run composer update
to add the package to your Laravel app.
At config/app.php
, add the Service Provider and the Facade:
'providers' => [ Intentor\LaravelForm\ServiceProvider::class, ] //... 'aliases' => [ 'Form' => Intentor\LaravelForm\Facade::class, ]
Quick start
To create a form, you can user either Blade helpers or the Form
Facade.
Using Blade helpers:
@form_open(action('SomeController@action')) @form_close
Using Facades:
{!! Form::open(action('SomeController@action')) !!} {!! Form::close() !!}
Any controls you want to create must be placed between the opening and closing of the form.
Using Blade helpers:
@form_open(action('SomeController@action')) @form_text('name', 'Name') @form_buttons('Send', 'Reset') @form_close
Using Facades:
{!! Form::open(action('SomeController@action')) !!} {!! Form::text('name', 'Name') !!} {!! Form::buttons('Send', 'Reset') !!} {!! Form::close() !!}
Helpers
open
Opens a form. See Themes for more details on form themes.
Blade helper
@form_open($url, $method = 'POST', $theme = null, $includeCsrfToken = true, $attributes = [])
Facade
{!! Form::open($url, $method = 'POST', $theme = null, $includeCsrfToken = true, $attributes = []) !!}
Parameters
- string
$url
Action URL. - string
$method
Form method. - bool
$theme
Controls' theme. It's a subfolder on the partials.form folder. - bool
$includeCsrfToken
Indicates whether the CSRF token should be included. - array
$attributes
Form attributes.
model
Opens a form for a model. See Themes for more details on form themes.
Blade helper
@form_
Facade
{!! Form::model($model, $url, $method = 'POST', $theme = null, $includeCsrfToken = true, $attributes = []) !!}
Parameters
- object
$model
Model object. - string
$url
Action URL. - string
$method
Form method. - bool
$theme
Controls' theme. It's a subfolder on the partials.form folder. - bool
$includeCsrfToken
Indicates whether the CSRF token should be included. - array
$attributes
Form attributes.
close
Closes a from.
Blade helper
@form_close
Facade
{!! Form::close() !!}
Parameters
None.
label
Creates a label.
Blade helper
@form_label($text, $field = null, $attributes = [])
Facade
{!! Form::label($text, $field = null, $attributes = []) !!}
Parameters
- string
$text
Label text. - string
$field
Related field name. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
readonly
Creates a readonly control.
Blade helper
@form_readonly($label, $text, $attributes = [])
Facade
{!! Form::readonly($label, $text, $attributes = []) !!}
Parameters
- string
$label
Label text. - string
$text
Field text. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
hidden
Creates a hidden field.
Blade helper
@form_hidden($name, $value = null, $attributes = [])
Facade
{!! Form::hidden($name, $value = null, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$value
Field value. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
text
Creates a text field.
Blade helper
@form_text($name, $label = null, $attributes = [])
Facade
{!! Form::text($name, $label = null, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
textarea
Creates a textarea field.
Blade helper
@form_textarea($name, $label = null, $attributes = [])
Facade
{!! Form::textarea($name, $label = null, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
Creates an e-mail field.
Blade helper
@form_email($name, $label = null, $attributes = [])
Facade
{!! Form::email($name, $label = null, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
url
Creates an URL field.
Blade helper
@form_url($name, $label = null, $attributes = [])
Facade
{!! Form::url($name, $label = null, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
number
Creates a number field.
Blade helper
@form_number($name, $label = null, $min = 0, $max = 9999, $step = 1, $attributes = [])
Facade
{!! Form::number($name, $label = null, $min = 0, $max = 9999, $step = 1, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - int
$min
Minimum number. - int
$max
Maximum number. - int
$step
Combined with the min value, defines the acceptable numbers in the range. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
password
Creates a password field.
Blade helper
@form_password($name, $label = null, $attributes = [])
Facade
{!! Form::password($name, $label = null, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
checkbox
Creates a checkbox field.
Blade helper
@form_checkbox($name, $label = null, $value = 1, $attributes = [])
Facade
{!! Form::checkbox($name, $label = null, $value = 1, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - string
$value
Field value. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
radio
Creates a radio field.
Blade helper
@form_radio($name, $label = null, $attributes = [])
Facade
{!! Form::radio($name, $label = null, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
checkboxGroup
Creates a checkbox group.
Blade helper
@form_checkbox_group($name, $label = null, $list = [], $selected = [], $attributes = [])
Facade
{!! Form::checkboxGroup($name, $label = null, $list = [], $selected = [], $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - array
$list
Item's list. Format: [ 'value' => '', 'text' => '' ]. Use modelToList to generate a list from models. - array
$selected
Selected values. Format: [ 'value', 'value', ... ]. Use modelToSelected to generate values from models. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
radioGroup
Creates a radio group.
Blade helper
@form_radio_group($name, $label = null, $list = [], $selected = null, $attributes = [])
Facade
{!! Form::radioGroup($name, $label = null, $list = [], $selected = null, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - array
$list
Item's list. Format: [ 'value' => '', 'text' => '' ]. Use modelToList to generate a list from models. - string
$selected
Selected value. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
dropdown
Creates a dropdown field.
Blade helper
@form_dropdown($name, $label = null, $list = [], $empty = null, $selected = null, $attributes = [])
Facade
{!! Form::dropdown($name, $label = null, $list = [], $empty = null, $selected = null, $attributes = []) !!}
Parameters
- string
$name
Field name. - string
$label
Field label. - array
$list
Item's list. Format: [ 'value' => 'text', 'text' => '' ]. Use modelToList to generate a list from models. - string
$empty
Empty value text. If no text is provided, there will not be an empty option. - string
$selected
Selected value. - array
$attributes
Element attributes. Format: [ 'attribute' => 'value' ].
submit
Creates a submit button.
Blade helper
@form_submit($label)
Facade
{!! Form::submit($label) !!}
Parameters
- string
$label
Control label.
reset
Creates a reset button.
Blade helper
@form_reset($label)
Facade
{!! Form::reset($label) !!}
Parameters
- string
$label
Control label.
buttons
Creates form buttons (submit and reset).
Blade helper
@form_buttons($submitLabel, $resetLabel = null)
Facade
{!! Form::buttons($submitLabel, $resetLabel = null) !!}
Parameters
- string
$submitLabel
Submit button label. - string
$resetLabel
Reset button label. If no label is given, the button is not created.
Utilities
modelToList
Generates an array compatible with lists (dropdowns, checkbox groups, etc.).
Facade
Form::modelToList($model, $valueField, $textField)
Parameters
- object
$model
Model to be converted. - string
$valueField
Field on data that is the value. - string
$textField
Field on data that is the text.
modelToSelected
Generates an array of selected values.
Facade
Form::modelToSelected($model, $valueField)
Parameters
- object
$model
Model to be converted. - string
$valueField
Field on data that is the value.
Themes
Themes are a way to customize the look of forms using partial views.
Available themes
There are three different themes available:
- default: a simple form theme without any third party dependencies.
- horizontal: default Bootstrap horizontal form (Requires Bootstrap 3).
- vertical: default Bootstrap vertical form (Requires Bootstrap 3).
All themes are subfolders at src/resources/views/partials/form
folder.
Creating a custom theme
To create a custom theme, copy a base theme from vendor/intentor/laravel-form/src/resources/views/partials/form
at your local Laravel installation to the resources/views/partials/form
of your app.
Each helper has its own Blade template file, which can then be customized.
Note: the name of the theme's folder is the name that must be used when setting the theme.
Changelog
Please see CHANGELOG.md.
Support
Found a bug? Please create an issue on the GitHub project page or send a pull request if you have a fix or extension.
You can also send me a message at support@intentor.com.br to discuss more obscure matters about the component.
License
Licensed under the The MIT License (MIT). Please see LICENSE for more information.