purplespider/silverstripe-bootstrap-form-templates

Bootstap 5 form templates for Silverstripe 4

Installs: 86

Dependents: 0

Suggesters: 0

Security: 0

Stars: 1

Watchers: 2

Forks: 1

Open Issues: 0

Language:Scheme

Type:silverstripe-vendormodule

1.0.3 2024-01-09 15:37 UTC

This package is auto-updated.

Last update: 2025-01-09 17:48:37 UTC


README

Introduction

This module aims to be a (mostly) unopinionated set of form templates to mark up Silverstripe frontend forms (both custom and Userforms) to be compatible with Bootstrap 5's form styles.

Maintainer Contact

Requirements

  • Silverstripe 4
  • Bootstrap 5 already installed in your theme

Installation

  1. Install using composer:
composer require purplespider/silverstripe-bootstrap-form-templates ^1
  1. Run dev/build

  2. Add as the FIRST theme in your app/_config/theme.yml:

    - purplespider/silverstripe-bootstrap-form-templates:bootstrap-form-templates

e.g.:

---
Name: mytheme
---
SilverStripe\View\SSViewer:
  themes:
    - purplespider/silverstripe-bootstrap-form-templates:bootstrap-form-templates
    - '$public'
    - 'simple'
    - '$default'
  1. To make Bootstrap's validation error styling work, add this SCSS to your theme:
form {
    .error.message {
        @extend .invalid-feedback;
        display: block;
    }
    
    .form-control,
    .form-select,
    .form-check-input {
        &.error {
            @extend .is-invalid;
        }
    }
}

Opinionated SCSS (optional)

These are some opionated styles that I like to start with:

// Opinionated Styles
form {
    max-width: 400px !important;
    margin-top: $spacer * 2;

    // "Required" label
    .help-text {
        color: $gray-500;
        padding-left: .25em;
        font-weight: normal;
    }
    
    // Add spacing between different fields
    .form-group {
        margin-bottom: $spacer * 2 !important; // Overrides "mb-3"
    }

    // Style field labels
    .form-label {
        font-weight: $font-weight-bold;
        color: $gray-700;
    }

    // Style Headings, e.g. HeaderField
    .FormHeading {
        border-bottom: 2px solid $gray-200;
        padding-bottom: $spacer / 2;
        margin-top: $spacer * 4;
        margin-bottom: $spacer * 2;
    }

    // Adds a "required" legend
    &:after {
        content: "* indicates required";
        display: block;
        margin-top: $spacer * 2;
    }
}

Using Rows & Columns for Form Layout

By grouping fields into a row using a FieldGroup, you can then apply col classes to fields, e.g.

FieldGroup::create(
    TextField::create('FirstName', 'First Name')->addExtraClass('col'),
    TextField::create('Surname', 'Last Name')->addExtraClass('col'),
)->addExtraClass('row');

How It Works

For full control, this module provides a complete set of form field templates, which override the default ones provided by Silverstripe and Userforms.

The templates are added as an extra theme to your site, so that they do not affect the form field in the CMS.

Handling of RightTitle and Description

Any Description text is added after the field, as per the default templates.

As the Userforms module uses RightTitle and not Description, this is also added after the field for consistency. So in your custom coded forms, you can use either (but you shouldn't use both).

Alternative Install (By Copying)

Rather than installing this via composer as a module that can't be edited, you can also just copy the files into your theme, allowing to then make any customisations (e.g. moving Description before the field.)

To do so, just copy the PurpleSpider and SilverStripe directories (within themes\bootstrap-form-templates\templates) into your theme's templates directory.

TODO

Please note: This module is currently a work-in-progress. I've still to:

  • Check certain form fields for WAI compliance, such as radio and checkbox groups.
  • Add styles for Userforms multi-page forms.
  • Refine handling of "required" labels.
  • Refine the ability to use FormGroup and addExtraClass to layout fields in rows and columns.