Download the PHP package magentron/laravel-html without Composer
On this page you can find all versions of the php package magentron/laravel-html. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package laravel-html
Painless html generation
This is a fork of spatie/laravel-html by Jeroen Derks, a.k.a Magentron. This fork was created in order to have PHP 5.6.x compatibility.
This package helps you generate HTML using a clean, simple and easy to read API. All elements can be dynamically generated and put together. The HTML builder helps you generate dynamically assigned form elements based on your selected model, the session or a default value.
Documentation
You'll find full documentation here.
Upgrading to 2.0
Version 2.0 was tagged because it could break some very specific cases, but you most likely don't have any work upgrading! Check out "Upgrading" for a detailed explanation.
Generating elements
For example creating a new span
element with a class is super easy with the fluent methods for elements:
Building forms
Here's a quick example that builds a basic form with an e-mail input:
The generated HTML will look like this:
Notice how the hidden _method
and _token
fields were automatically added and filled? You'll never forget to add csrf_field()
again because now you simply wont have to anymore!
Another common use case might be to fill an input element based on the value that was previously submitted (using $request->old()
). Worry no more, this has been taken care of as well. The above code will automatically fill in the email
field if $session->old('email')
exists. Amazing.
Models in the HTML builder
The HTML builder can also generate elements based on a model:
The value of the name
field will automatically be filled with the model's name
property if available:
A "model" can be any object that implements ArrayAccess
— anything from a complex Eloquent model to a plain array.
Postcardware
You're free to use this package (it's MIT-licensed), but if it makes it to your production environment we highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using.
Our address is: Spatie, Samberstraat 69D, 2060 Antwerp, Belgium.
All postcards are published on our website.
Installation
You can install the package via composer:
Next, you must install the service provider:
And optionally register an alias for the facade.
Usage
Concepts
Elements—classes under the Spatie\Html\Elements
namespace—are generally created via a Spatie\Html\Html
builder instance.
Element attributes and contents are modified via with fluent methods which return a new instance. This means element instances are immutable.
Element classes don't have any knowledge of the outside world. Any coupling to other concepts, like requests and sessions, should happen in the builder class, not on the element classes.
By convention, we assume that builder methods will modify values to our advantage (like pulling old values from the session on a failed form request), and element methods will be deterministic.
Upgrading
From v1 to v2
Version 2 was created because the typehints in version 1 was holding the package back in some cases (like multiple select which requires an array of values instead of a string which was assumed).
Luckily, bumping the version number in composer.json
and running composer update
should be non-breaking. Here are some caveats to look out for:
- The package now ships with a
html()
function by default, which returns an instance of theHtml
builder class. If you've defined your own method, you'll need to remove it. - Various type hints have been removed throughout the package, if you've extended a class to override its methods, you'll need to update them accordingly (everything still behaves the same!)
Changelog
Please see CHANGELOG for more information what has changed recently.
Testing
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
Credits
- Sebastian De Deyne
- Freek Van der Herten
- All Contributors
About Spatie
Spatie is a webdesign agency based in Antwerp, Belgium. You'll find an overview of all our open source projects on our website.
License
The MIT License (MIT). Please see License File for more information.
All versions of laravel-html with dependencies
illuminate/http Version ~5.4.0|~5.5.0|~5.6.0
illuminate/support Version ~5.4.0|~5.5.0|~5.6.0