SilverWare Select2 Module.

1.0.4 2017-10-08 06:06 UTC


Latest Stable Version Latest Unstable Version License

Provides Select2-powered dropdown and Ajax fields for SilverStripe v4. Intended to be used with SilverWare, however this module can also be installed into a regular SilverStripe v4 project.




Installation is via Composer:

$ composer require silverware/select2


As with all SilverStripe modules, configuration is via YAML. Extensions to LeftAndMain are applied via config.yml.



The Select2Field class is used exactly the same way as a regular old DropdownField:

use SilverWare\Select2\Forms\Select2Field;

$field = Select2Field::create(
  'Select2 Field',
    1 => 'An',
    2 => 'Array',
    3 => 'of',
    4 => 'Options'

Select2 Configuration

You can define any of the Select2 configuration settings by using the setConfig() method:

$field->setConfig('maximum-input-length', 20);

Alternatively, you can set the defaults for all Select2Field instances in your app by using YAML config:

    maximum-input-length: 20

NOTE: configuration setting names are defined using HTML attribute style, and not camel case, for example:

$field->setConfig('maximum-input-length', 20);  // this will work
$field->setConfig('maximumInputLength', 20);    // this will NOT work


The Select2AjaxField is used to search a DataList based on a search term entered by the user. The results are retrieved from the server via Ajax and rendered as dropdown options. This is very handy for cases where the number of available options in a regular dropdown would be prodigious.

The field is created like any other field:

use SilverWare\Select2\Forms\Select2AjaxField;

$field = Select2AjaxField::create(
  'Select2 Ajax Field'

But we do not pass an array of options to choose from to the constructor. Instead, we configure the field to search a DataList on the server-side. Here are the default settings:

$field->setDataClass(SiteTree::class);  // by default, the field searches for SiteTree records

$field->setIDField('ID');       // the name of the field which identifies the record
$field->setTextField('Title');  // the name of the field to use for the option text

  'Title'  // an array of fields to search based on the entered term

  'Title' => 'ASC'  // an array which defines the sort order of the results

$field->setLimit(256);  // the maximum number of records to return

As mentioned, these are the default settings, and the field will work out-of-the-box for SiteTree searches.


You can also optionally define a series of exclusion filters, which use the same format for the exclude method of DataList:

  'Title:ExactMatch' => 'Hide This Title'

Any records matching the defined exclusion filters will be excluded from the results.


By default, the field will render a regular series of dropdown options based on the $ID and $Title of the matching records, however you can apply more advanced formatting for both results and the current selection. For example:

$field->setFormatResult('<span>Found: <em>$Title</em></span>');
$field->setFormatSelection('<span>Selected: <strong>$Title</strong></span>');

HTML will be rendered as a jQuery object, so be sure to wrap it in an enclosing element such as a <span>.

Ajax Configuration

Any of the Select2 Ajax settings can be defined using the setAjaxConfig() method:

$field->setAjaxConfig('cache', false);
$field->setAjaxConfig('delay', 500);

Alternatively, you can set the defaults for all Select2AjaxField instances in your app by using YAML config:

    cache: false
    delay: 500

NOTE: configuration setting names are defined using HTML attribute style, and not camel case, for example:

$field->setAjaxConfig('data-type', 'json');  // this will work
$field->setAjaxConfig('dataType', 'json');   // this will NOT work


Please use the GitHub issue tracker for bug reports and feature requests.


Your contributions are gladly welcomed to help make this project better. Please see contributing for more information.



Colin Tucker Praxis Interactive
Colin Tucker Praxis Interactive


BSD-3-Clause © Praxis Interactive