Skip to content
/ former Public

A powerful form builder, for Laravel and other frameworks (stand-alone too)

Notifications You must be signed in to change notification settings

formers/former

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

b5e454a · Nov 22, 2017
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Former

A Laravelish way to create and format forms

Build Status Latest Stable Version Total Downloads )

THIS BRANCH IS OLD AND WILL BE DELETED IN EARLY 2018. Please verify your composer.json is not pointing to this branch.

Former outputs form elements in HTML compatible with your favorite CSS framework (Bootstrap and Foundation are currently supported). Former also handles repopulation after validation errors, including automatically rendering error text with affected fields.

Introduction

Former provides a fluent method of form creation, allowing you to do:

Former::horizontal_open()
  ->id('MyForm')
  ->rules(['name' => 'required'])
  ->method('GET');

  Former::xlarge_text('name') # Bootstrap sizing
    ->class('myclass') # arbitrary attribute support
    ->value('Joseph')
    ->required(); # HTML5 validation

  Former::textarea('comments')
    ->rows(10)->columns(20)
    ->autofocus();

  Former::actions()
    ->large_primary_submit('Submit') # Combine Bootstrap directives like "lg and btn-primary"
    ->large_inverse_reset('Reset');

Former::close();

Every time you call a method that doesn't actually exist, Former assumes you're trying to set an attribute and creates it magically. That's why you can do in the above example ->rows(10) ; in case you want to set attributes that contain dashes, just replace them by underscores : ->data_foo('bar') equals data-foo="bar". Now of course in case you want to set an attribute that actually contains an underscore you can always use the fallback method setAttribute('data_foo', 'bar'). You're welcome.

This is the core of it, but Former offers a lot more. I invite you to consult the wiki to see the extent of what Former does.


Installation

Require Former package using Composer:

composer require anahkiasen/former   # For Laravel 4, use anahkiasen/former:~3.5

Then run "composer update". Next modify your config/app.php. In the providers array add :

Former\FormerServiceProvider::class

Add then alias Former's main class by adding its facade to the aliases array in the same file :

'Former' => 'Former\Facades\Former',

If you don't use Laravel, you can add Former to your Composer file, then use it with:

use Former\Facades\Former;

Table of contents