briceburg / silverstripe-flexiform
Add CMS configurable forms to your SilverStripe objects.
Installs: 124
Dependents: 1
Suggesters: 1
Security: 0
Stars: 18
Watchers: 5
Forks: 4
Open Issues: 6
Type:silverstripe-module
Requires
Suggests
- briceburg/silverstripe-flexifields: Useful additional fields for flexiform and beyond.
This package is not auto-updated.
Last update: 2025-01-14 05:20:05 UTC
README
Add CMS configurable forms to your SilverStripe objects.
Features
- Add forms to any DataObject or Page
- GridField based management of fields, options, submissions, actions, &c.
- 100% compatible with holder pages & VersionedGridfield
- Programmatically define initial fields and handlers + build them from the Environment Builder
- Many-many between Form and
FlexiFormField
, has_many betweenFlexiFormHandler
- reduced repetitiveness and improved consistency
- extraFields allows per-form customization without disturbing other forms using the same field
- Protection against form re-submissions
- Definable, friendly post URLs for logs and analytics
- Support for multiple forms per page
Requirements
The venerable GridFieldExtensions https://github.com/ajshort/silverstripe-gridfieldextensions
Tested in SilverStripe 3.1
Screenshots
Usage
- Add flexiforms to Pages and DataObjects by extending with
FlexiFormExtension
. E.g.
class Event extends DataObject { private static $extensions = array( 'FlexiFormExtension' ); }
Trigger the environment builder (/dev/build) after extending objects -- You will now see the Form tab when editing Event in the CMS.
- To display flexiforms, add $FlexiForm to your template. Here's a sample Event.ss;
<div class="event-content"> <% if not FlexiFormPosted %> $Content <% end_if %> $FlexiForm </div>
Here we use $FlexiFormPosted to hide $Content if a form has been posted.
Flexiform also provides a convenience wrapper around the standard $Form method. Calling $Form from a Page extended by FlexiFormExtension will output the associated flexiform. E.g.
<div class="event-content"> <% if not FlexiFormPosted %> $Content <% end_if %> $Form </div>
Works exactly the same as the first example.
Form Identifiers
Use Form Identifiers when you have multiple forms on a page, need to reference a form (e.g from another page), or want to control the post URL.
FlexiForm extends ContentController
to provide the $FlexiForm method to all
pages. By default it expects the controller's dataRecord to be an object
extended by FlexiFormExtension
. You can explicitly set the flexiform
object by calling the setFlexiFormObject method on your controller, or by passing
an Identifer to $FlexiForm.
Form Identifiers are defined in the Settings tab on flexiforms. The identifier is also used in post URLs for easy tacking of form submissions in server logs and analytics.
<!-- .ss template --> <div class="page-content"> $FlexiForm('newsletter_form') </div>
Shortcodes
Alternately, you can use the [flexiform] shortcode in content areas. This is especially useful for controlling placement of a form inside existing content.
Optionally pass a Form Identifier through the ID paramater.
Some WYSIWYG Content
Default Form: <br /> [FlexiForm]
Explicit Form: <br /> [flexiform id=registration_form]
Templates, Custom Form Classes
By default, flexiform uses Form.ss to render the form. You can change the template by
-
Simple Means: Adding a FlexiForm.ss to your theme
-
Powerful Means: Provide an alternate form class via $flexiform_form_class
class Event extends DataObject { private static $extensions = array( 'FlexiFormExtension' ); private static $flexi_form_class = 'EventForm'; } // attempts to use EventForm.ss by default, falling back to Form.ss class EventForm extends FlexiForm { // optional: provide a specific template // public function getTemplate() { return 'EventSpecificTemplate'; } }
Configuration
Most configuration is accomplished through the CMS -- however you can further tailor behavior through subclassing (protected properties, getters, and setters) and YAML Configuration.
See docs/CONFIGURATION.md for documentation and examples.