PHPackages                             doode/laravel-formbuilder - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. doode/laravel-formbuilder

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

doode/laravel-formbuilder
=========================

Laravel Package for Creating a Drag-and-Drop Form Builder Using JQuery Form Builder

1.0.1(4y ago)114131[1 issues](https://github.com/vitormicillo/laravel-formbuilder/issues)MITJavaScriptPHP ^7.2.5|^8.0

Since Aug 3Pushed 4y ago1 watchersCompare

[ Source](https://github.com/vitormicillo/laravel-formbuilder)[ Packagist](https://packagist.org/packages/doode/laravel-formbuilder)[ RSS](/packages/doode-laravel-formbuilder/feed)WikiDiscussions main Synced 3d ago

READMEChangelog (2)DependenciesVersions (3)Used By (0)

Laravel Form Builder Package
============================

[](#laravel-form-builder-package)

A [Laravel](https://laravel.com) package for creating a drag-and-drop form builder using the [JQuery Form Builder](https://formbuilder.online).

All contributions are welcomed! (but please start a discussion to make sure the PR is warranted first)

Screenshot:

[![alt text](https://camo.githubusercontent.com/a5c711aa05ef1cd63391e3e5123ef658bbd78fc86419ea2e0a24af2bb47bc351/68747470733a2f2f7777772e646f6f64652e636f6d2e62722f696d616765732f666f726d6275696c6465722e706e67 "Form Builder Screenshot")](https://camo.githubusercontent.com/a5c711aa05ef1cd63391e3e5123ef658bbd78fc86419ea2e0a24af2bb47bc351/68747470733a2f2f7777772e646f6f64652e636f6d2e62722f696d616765732f666f726d6275696c6465722e706e67)

The form fields are saved as JSON and stored in your database. A member of your site can create, edit and delete forms. Forms belong to the users that created them and each form has a unique link that can be shared publicly.

The JSON version of the form can be used to render the form for users to fill.

Example JSON Form:

```
[{"type":"header","subtype":"h1","label":"Demo Form 01"},{"type":"paragraph","subtype":"p","label":"This demo form is a potluck sign-up sheet"},{"type":"text","label":"Name","className":"form-control","name":"name","subtype":"text"},{"type":"radio-group","label":"Food Category","name":"foodcategory","other":true,"values":[{"label":"Appetizer","value":"Appetizer"},{"label":"Beverage","value":"Beverage"},{"label":"Salad","value":"Salad"},{"label":"Main","value":"Main"},{"label":"Dessert","value":"Dessert"}]},{"type":"number","label":"How many will it serve","className":"form-control","name":"numberserved","min":"1","max":"50","step":"1"},{"type":"text","label":"Dish Name","className":"form-control","name":"dishname","subtype":"text"},{"type":"checkbox-group","label":"Dietary Restrictions","description":"Which of the following does your dish contain?","name":"dietaryrestrictions","values":[{"label":"Alcohol","value":"Alcohol"},{"label":"Carbs","value":"Carbs"},{"label":"Dairy","value":"Dairy"},{"label":"Egg","value":"Egg"},{"label":"Fish","value":"Fish"},{"label":"Gluten","value":"Gluten"}]},{"type":"textarea","label":"Comment","className":"form-control","name":"comment","subtype":"textarea"}]
```

Form permission options

- Public - Anyone can submit the form without authentication
- Private - Only authenticated members of your site can access the form. Provide the option for users to edit their previous submissions.

Requirements
------------

[](#requirements)

- Laravel 7+
- Bootstrap 4+
- MySQL/MariaDB
- [Laravel Authentication](https://laravel.com/docs/7.x/authentication#authentication-quickstart)

```
composer require laravel/ui
php artisan ui bootstrap --auth
```

*If you are looking for a managed web host, with easy laravel site creation, then I highly recommend [Linux Zone](https://www.linuxzone.co.uk). With Linux Zone you are free to manage your files and database any way you want.*

Dependencies Included with Package
----------------------------------

[](#dependencies-included-with-package)

- jQuery UI - User interface actions built on jQuery. [View jQuery ui Documentation](https://jqueryui.com/)
- jQuery Formbuilder - Drag and drop full-featured form editing. [View jQuery Formbuilder Documentation](https://formbuilder.online)
- clipboard.js - Copy text to clipboard. [View Clipboard Documentation](https://clipboardjs.com/)
- parsley.js - JavaScript form validation library. [View Parsley Documentation](http://parsleyjs.org/)
- moment.js - Parse, validate, manipulate, and display dates and times in JavaScript. [View Moment Documentation](https://momentjs.com/)
- footable - A responsive table plugin built on jQuery and made for Bootstrap. [View FooTable Documentation](https://fooplugins.github.io/FooTable/)
- sweetalert - A beautiful replacement for site error/warning/confirmation messages. [View SweetAlert Documentation](https://sweetalert.js.org/)

Roadmap
=======

[](#roadmap)

This custom package takes a couple steps to install but I will try to make it as simple as possible.

### Step One:

[](#step-one)

Edit your composer.json file manually or simply type

```
composer require doode/laravel-formbuilder
```

### Step Two:

[](#step-two)

Ensure you have all your dependencies installed

```
composer install
```

*Note: The package will automatically register itself using [Laravels](https://laravel.com) package discovery feature for versions 6 and above. This means you do not need to update your config/app.php file.*

### Step Three:

[](#step-three)

We need to add the additional database tables so run the following command

```
php artisan migrate
```

### Step Four:

[](#step-four)

Create the form package's configuration file. This will place a formbuilder.php file in your config folder. In the configuration file you can change the url path for the package's routes, layout template to use and script / style output sections.

Run the following command:

```
php artisan vendor:publish --tag formbuilder-config
```

### Step Five:

[](#step-five)

Update your blade template file. In the default laravel install the template file is located here: /resources/views/layouts/app.blade.php

You need to add tags for the new styles and scripts At the top of the blade file, just above the closing head tag:

```
@stack('styles')
```

At the bottom of the blade file, just above the closing the closing body tag:

```
@stack('scripts')
```

*Note: If you ever need to change which files are called using these @stack values, you can update the config file.*

### Step Six:

[](#step-six)

Publish the custom blade view files by running

```
php artisan vendor:publish --tag formbuilder-views
```

Publish the public assets by running

```
php artisan vendor:publish --tag formbuilder-public
```

Or you can publish everything at once with

```
php artisan vendor:publish --provider="doode\FormBuilder\FormBuilderServiceProvider"
```

### Step Seven:

[](#step-seven)

In order to properly link to attachments, you need to run the storage:link command which makes the storage folder publicly accessibly

```
php artisan storage:link
```

Accessing The Application
-------------------------

[](#accessing-the-application)

Done! Now to access the form application.

To view submissions:

Using The Trait
---------------

[](#using-the-trait)

You can access forms and submissions that belong to a user in your application. To use the trait add a use statement to your user model class.

```
use doode\FormBuilder\Traits\HasFormBuilderTraits;

class User extends Authenticatable
{
    use HasFormBuilderTraits;
}
```

You can now access the user's forms and submissions by running

```
$user = User::first(); or User::find($id);

// get the user's forms
$user->forms;

// get the user's submissions
$user->submissions;

// or use static methods on the doode\FormBuilder\Models\Form class
$user_forms = Form::getForUser($user); // returns a paginated resultset

// the doode\FormBuilder\Models\Submission class also has a static method for getting the submissions
// that belong to a user
$my_submissions = Submission::getForUser($user); // returns a paginated resultset
```

Using Events
------------

[](#using-events)

The package dispatches a number of events when records are created or updated so that you can listen to these events and perform custom tasks in your application's logic

Precautions
-----------

[](#precautions)

1. Make sure you have a table name users with a colum id {bigSignedInteger} in your database.
2. Once you have submission(s) on a form , dont attempt to edit the form again bacause it will break the display of earlier submissions 3. I'm working on this to improve usability.

---

This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!

License
-------

[](#license)

Copyright © Doode

All Doode packages are open-sourced software licensed under the [MIT license](LICENSE.md).

###  Health Score

29

—

LowBetter than 60% of packages

Maintenance18

Infrequent updates — may be unmaintained

Popularity20

Limited adoption so far

Community10

Small or concentrated contributor base

Maturity57

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 66.7% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~0 days

Total

2

Last Release

1743d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/a02673fdbe18e08e7285e31b6f6e03274ef5c44e50b1504b71a1b6a4bf6db4a8?d=identicon)[doode](/maintainers/doode)

---

Top Contributors

[![vitormicillo](https://avatars.githubusercontent.com/u/1921806?v=4)](https://github.com/vitormicillo "vitormicillo (2 commits)")[![renovate-bot](https://avatars.githubusercontent.com/u/25180681?v=4)](https://github.com/renovate-bot "renovate-bot (1 commits)")

### Embed Badge

![Health badge](/badges/doode-laravel-formbuilder/health.svg)

```
[![Health](https://phpackages.com/badges/doode-laravel-formbuilder/health.svg)](https://phpackages.com/packages/doode-laravel-formbuilder)
```

###  Alternatives

[angle/chrono

The easiest way to measure PHP code execution time.

2815.2k](/packages/angle-chrono)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
