syntro / silverstripe-bootstrap-forms
Silverstripe module adding formfields for use in the frontend
Installs: 2 196
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 2
Type:silverstripe-vendormodule
Requires
- php: ^7.4.0 || ^8
- giggsey/libphonenumber-for-php: ^8.0
- silverstripe/cms: ^4 || ^5
- silverstripe/framework: ^4 || ^5
Requires (Dev)
This package is auto-updated.
Last update: 2025-01-10 05:10:00 UTC
README
Silverstripe module for adding bootstrap forms to the frontend more easily.
Introduction
Creating forms compatible with the Bootstrap CSS framework using the provided form fields by Silverstripe is not an easy thing to do. Silverstripes' internally used form fields are not intended to be frontend fields in the first place, meaning the framework is very opinionated about how these fields are rendered in the admin UI and imposes these standards for frontend fields. These standards however are not very compatible with Bootstrap, especially Bootstrap v5.
To counter this, this module introduces a new set of fields, which behave like
the originals, but render in a bootstrap compatible way. They also add a separate
holderClasses
attribute, which allows the easy formatting of forms using
spacing classes.
Installation
To install this module, run the following command:
composer require syntro/silverstripe-bootstrap-forms
Usage
Quick Start
The following fields are available currently:
use Syntro\SilverstripeBootstrapForms\Forms\CheckboxField; use Syntro\SilverstripeBootstrapForms\Forms\CheckboxSetField; use Syntro\SilverstripeBootstrapForms\Forms\DropdownField; use Syntro\SilverstripeBootstrapForms\Forms\EmailField; use Syntro\SilverstripeBootstrapForms\Forms\OptionsetField; use Syntro\SilverstripeBootstrapForms\Forms\TextareaField; use Syntro\SilverstripeBootstrapForms\Forms\TextField; // does not have the HolderClass trait use Syntro\SilverstripeBootstrapForms\Forms\FieldGroup;
All fields have an extra set of methods, analogous the extraClass
ones:
holderClass()
setupDefaultHolderClasses()
hasHolderClass($class)
addHolderClass($class)
removeHolderClass($class)
They behave the exact same way as their xxxExtraClass
counterparts, but they
control the class on the outer (holder) div.
Example
To create a good looking multi-column form, simply add the correct classes:
FieldGroup::create( TextField::create('Name', 'Your Name')->addHolderClass('col'), EmailField::create('Email', 'Email')->addHolderClass('col'), DropdownField::create( 'choose', 'Choose an option', [ 'yes' => 'Yes', 'no' => 'No' ] )->addHolderClass('col'), )->addExtraClass('row row-cols-1 row-cols-md-3'),
Docs
no docs yet
Contributing
See CONTRIBUTION.md for mor info.