2017 © Pedro Peláez
 

library form-builder

The form builder service for laravel app

image

ilyasavich/form-builder

The form builder service for laravel app

  • Thursday, May 24, 2018
  • by IlyaSavich
  • Repository
  • 1 Watchers
  • 1 Stars
  • 28 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 21 Versions
  • 4 % Grown

The README.md

Laravel Form Builder

The form builder service for Laravel, (*1)

Installation

Require

composer require ilyasavich/form-builder

Register Provider and Facade

in app.php config

'providers' => [
    // ...
    Savich\FormBuilder\FormServiceProvider::class,
],

Publish config

php artisan vendor:publish --provider="Savich\FormBuilder\FormServiceProvider" --tag=config

Usage

To create new form first of all extending base Form class and overwrite method make. This method implements form building logic, (*2)

use Savich\FormBuilder\Form;
use Savich\FormBuilder\FormBuilder;

class UserForm extends Form
{
    protected function make(FormBuilder $builder): FormBuilder
    {
    }
}

Create inputs

The package provide to create all available html inputs. To add new input in your form class you need call add method of builder instance. It signature, (*3)

public function add(string $inputNamespace, string $name, $value = null, array $options = []) : Input

To create simple input write ..., (*4)

use Savich\FormBuilder\Form;
use Savich\FormBuilder\FormBuilder;
use Savich\FormBuilder\Inputs\EmailInput;

class UserForm extends Form
{
    protected function make(FormBuilder $builder): FormBuilder
    {
        $builder->add(EmailInput::class, 'email');
    }
}

Customization

Attributes

Here are several methods to customize input, (*5)

// you can set input attributes in different ways
// also you can specify default input value

$value = 'Hello World!';
$attributes = ['class' => 'form-control'];
$builder->add(TextInput::class, 'input_name', $value)->attributes($attributes);
$builder->add(TextInput::class, 'input_name', $value, $attributes);

Labels

$builder->add(TextInput::class, 'input_name')->label('My Label');

Group customization

By default inputs will generating in such format, (*6)

$builder->add(TextInput::class, 'input_name');

// generated view



If you don't need to wrap input by group, (*7)

$builder->add(TextInput::class, 'input_name')->withoutGroup();

// generated view

<input type="text" name="input_name">

You can customize group attributes, (*8)

$builder->add(TextInput::class, 'input_name')->groupAttributes(['class' => 'my-class', 'inputID']);

// generated view



Overwrite views

If you need specific input generating you can overwrite default view by your custom, (*9)

$builder->add(TextInput::class, 'input_name')->view('path.to.view');

In case where you need to overwrite view without group you can ..., (*10)

//this will overwrite code inside form-group div
$builder->add(TextInput::class, 'input_name')->internalView('path.to.view');

When you need to overwrite only group you can ... In view you have $input object that is an instance of your input class., (*11)

$builder->add(TextInput::class, 'input_name')->view('path.to.view');

// in resources.views.path.to.view
// in withoutGroupView there path to internal view, you can specify custom or there will be default


generateGroupAttributes() !!}> // write custom stuff ... @include($input->withoutGroupView)

Available input properties

The you can find list of available properties of $input object, (*12)

Name Description
$name Input name
$value Input value
$attributes Input attributes
$label Input label in html
$view Path to input group view. Will be null if you don't set it in view() method
$defaultView Path to default group view. You can set it in config file
$groupAttributes Array of group attributes
$before Array of inputs that must be inserted inside group before current
$after Array of inputs that must be inserted inside group after current
$withoutGroup Can be set by call withoutGroup() method. Indicates that need generate input without wrapping group
$withoutGroupView Path to view inside group
$model Model that will be binding for input

Create simple form

For example you need to create simple login form with at least two inputs. Ok, it will something like that, (*13)

use Savich\FormBuilder\Form;
use Savich\FormBuilder\FormBuilder;

class LoginForm extends Form
{
    protected function make(FormBuilder $builder)
    {
        $builder->email('email')->label('Email');
        $builder->password('password')->label('Password');

        $builder->submit('Save');
    }
}

After that you need to add this form in controller action, (*14)

class LoginController extends Controller
{
    public function showLoginForm(LoginForm $form)
    {
        $formHtml = $form->create();

        return view('login')->with('form', $formHtml);
    }
}

And, finally, render form in view file, (*15)

in resources/views/login.blade.php

{!! $form !!}

Lets create action for submitting login form. In our controller, (*16)

class LoginController extends Controller
{
    // ...

    public function login(LoginForm $form)
    {
        $form->request(); // access to request

        // login logic
    }
}

The Versions

24/05 2018

dev-master

9999999-dev

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

24/05 2018

v1.1.1

1.1.1.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

24/05 2018

v1.1.0

1.1.0.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

22/05 2018

v1.0.14

1.0.14.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

22/05 2018

v1.0.13

1.0.13.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

22/05 2018

v1.0.12

1.0.12.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

22/05 2018

v1.0.11

1.0.11.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

19/05 2018

v1.0.9

1.0.9.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

19/05 2018

v1.0.8

1.0.8.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

19/04 2018

v1.0.7

1.0.7.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

12/04 2018

v1.0.6

1.0.6.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

31/03 2018

v1.0.5

1.0.5.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

27/03 2018

v1.0.4

1.0.4.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

26/03 2018

v1.0.3

1.0.3.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

26/03 2018

v1.0.2

1.0.2.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

26/03 2018

v1.0.1

1.0.1.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

03/04 2017

v1.0.0

1.0.0.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

28/03 2017

v0.0.4

0.0.4.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

28/03 2017

v0.0.3

0.0.3.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

28/03 2017

v0.0.2

0.0.2.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich

28/03 2017

v0.0.1

0.0.1.0

The form builder service for laravel app

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar IlyaSavich