This module enables Selectize (which is bundled with the PW core) on all Select and AsmSelect inputfields in the PW admin. As described below in the readme, Selectize is initialised/destroyed as the revelant select is focused/blurred in order to support select options that change after the page is loaded. Therefore Selectize is styled to match the AdminThemeUikit select as closely as possible to minimise the visual change as the select is focused and blurred. I'm developing on Windows so I'm not sure how the module will render on other operating systems. It doesn't help that the PW admin uses different fonts depending on the OS - I wish PW would bundle its own webfont for a standardised appearance everywhere.
Incidentally, I was a bit disappointed with the state of the Selectize project. I had to fix or work around a number of bugs and shortcomings, including things you would think would just work out of the box such as disabled options, matching the width of the replaced select, or the standard select behaviour where a selection is required when there is no empty option. The Selectize issues repo is full of arbitrarily closed bug reports and pull requests and there are no updates for the last 6 years. I've tried to catch everything that would affect this module but I wouldn't be surprised if there are still some bugs.
Selectize All
Enables Selectize on all InputfieldSelect and InputfieldAsmSelect fields in the ProcessWire admin.
The module activates Selectize on the <select> element when it is focused, and destroys Selectize when the element is blurred. This allows Selectize to work on selects where the options are changed dynamically after page load depending on other field values, e.g. the "Select File" field in the CKEditor link modal or a dependent select in Page Edit.
Only AdminThemeUikit is tested and supported.
Usage
In the module config you can choose if Selectize should be used with InputfieldSelect, InputfieldAsmSelect, or both.
If you want to disable the module for a specific Select or AsmSelect inputfield you can hook SelectizeAll::allowSelectize. This method receives the Inputfield object as the first argument.
Example:
$wire->addHookAfter('SelectizeAll::allowSelectize', function(HookEvent $event) {
$inputfield = $event->arguments(0);
// You can also get any associated Page and Field objects via $inputfield->hasPage and $inputfield->hasField
// Disable the module for the inputfield named "template"
if($inputfield->name === 'template') $event->return = false;
});
https://github.com/Toutouwai/SelectizeAll https://processwire.com/modules/selectize-all/