All Projects → spatie → Laravel Html

spatie / Laravel Html

Licence: mit
Painless html generation

Projects that are alternatives of or similar to Laravel Html

Laravel Bootstrap Table List
Bootstrap table list generator for Laravel.
Stars: ✭ 16 (-96.83%)
Mutual labels:  laravel, generation
Vue Formulate
⚡️ The easiest way to build forms with Vue.
Stars: ✭ 1,947 (+286.31%)
Mutual labels:  generation, form
Laravel Honeypot
Preventing spam submitted through forms
Stars: ✭ 728 (+44.44%)
Mutual labels:  laravel, form
Laravel Table
Generate tables from Eloquent models.
Stars: ✭ 101 (-79.96%)
Mutual labels:  laravel, generation
Laravel Nova Nested Form
This package allows you to include your nested relationships' forms into a parent form.
Stars: ✭ 169 (-66.47%)
Mutual labels:  laravel, form
Formvuelar
Vue form components with server-side validation in mind
Stars: ✭ 263 (-47.82%)
Mutual labels:  laravel, form
Laraform
Reactive Form Builder for Vue.js with Laravel Support
Stars: ✭ 259 (-48.61%)
Mutual labels:  laravel, form
Tall Forms
Laravel Livewire (TALL-stack) form generator with realtime validation, file uploads, array fields, blade form input components and more.
Stars: ✭ 321 (-36.31%)
Mutual labels:  laravel, form
Ambientum
Docker native solution for running Laravel projects. From Development to Production
Stars: ✭ 487 (-3.37%)
Mutual labels:  laravel
Code6
码小六 - GitHub 代码泄露监控系统
Stars: ✭ 494 (-1.98%)
Mutual labels:  laravel
Smartwiki
因个人精力有限,不在维护此项目,推荐用MinDoc代替
Stars: ✭ 486 (-3.57%)
Mutual labels:  laravel
Laravel Moderation
A simple Content Moderation System for Laravel 5.* that allows you to Approve or Reject resources like posts, comments, users, etc.
Stars: ✭ 487 (-3.37%)
Mutual labels:  laravel
Column Sortable
Package for handling column sorting in Laravel 5/6/7/8
Stars: ✭ 496 (-1.59%)
Mutual labels:  laravel
Validator.js
⁉️轻量级的 JavaScript 表单验证,字符串验证。没有依赖,支持 UMD ,~3kb。
Stars: ✭ 486 (-3.57%)
Mutual labels:  form
Restful Api Specification
RESTful API 设计规范
Stars: ✭ 498 (-1.19%)
Mutual labels:  laravel
Laravel Blade Javascript
A Blade directive to export variables to JavaScript
Stars: ✭ 485 (-3.77%)
Mutual labels:  laravel
Laravel Web Push Demo
Laravel Web Push Notifications Demo
Stars: ✭ 486 (-3.57%)
Mutual labels:  laravel
Laravel Cascade Soft Deletes
Cascading deletes for Eloquent models that implement soft deletes
Stars: ✭ 498 (-1.19%)
Mutual labels:  laravel
Squire
A library of static Eloquent models for common fixture data.
Stars: ✭ 496 (-1.59%)
Mutual labels:  laravel
Laravel Scout Mysql Driver
Laravel Scout MySQL Driver
Stars: ✭ 491 (-2.58%)
Mutual labels:  laravel

Painless html generation

Latest Version on Packagist MIT Licensed Test Status Code Style Status Total Downloads

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.

Support us

We invest a lot of resources into creating best in class open source packages. You can support us by buying one of our paid products.

We highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using. You'll find our address on our contact page. We publish all received postcards on our virtual postcard wall.

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, Kruikstraat 22, 2018 Antwerp, Belgium.

All postcards are published on our website.

Installation

You can install the package via composer:

composer require spatie/laravel-html

Next, you must install the service provider:

// config/app.php
'providers' => [
    ...
    Spatie\Html\HtmlServiceProvider::class,
];

And optionally register an alias for the facade.

// config/app.php
'aliases' => [
    ...
    'Html' => Spatie\Html\Facades\Html::class,
];

Usage

Concepts

Elements—classes under the Spatie\Html\Elements namespace—are generally created via a Spatie\Html\Html builder instance.

html()->span()->text('Hello world!');

Element attributes and contents are modified via with fluent methods which return a new instance. This means element instances are immutable.

$icon = html()->span()->class('fa');

$icon->class('fa-eye'); // '<span class="fa fa-eye"></span>'
$icon->class('fa-eye-slash'); // '<span class="fa fa-eye-slash"></span>'

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.

// This will try to resolve an initial value, and fall back to '[email protected]'
$email = html()->email('email', '[email protected]');

// This will always have '[email protected]' as it's value
$email = html()->email('email')->value('[email protected]');

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 the Html 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

$ composer test

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

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.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].