A more advanced dialog for CodeMirror allowing for multiple inputs and buttons.
To create a new dialog, use the following command:
cm.openAdvancedDialog(template, opts);
The first parameter is an html template or DOM node much like the vanilla dialog, and the second is an options object with the following properties:
- shrinkEditor (bool) - If set to true, the editor will shrink to make room for the dialog in order to prevent the dialog obscuring any text.
- inputBehaviours (object) - an object with behaviours for each input in the order that they appear in the template.
- closeOnEnter (bool) - if true, the dialog will close if the user hits enter when this field has focus
- closeOnBlur (bool) - if true, the dialog will close if this field loses focus
- callback (function) - a callback function that will be executed if the user hits enter when this field has focus. The function receives two parameters - the first is an array of the input fields in the dialog and the second is the DOM event.
- buttonBehaviours (object) - an object with behaviours for each button in the order that they appear in the template.
- callback (function) - a callback function that will be executed if the user hits enter when this field has focus. The function receives two parameters - the first is an array of the input fields in the dialog and the second is the DOM event.
- onClose (function) - a callback that is fired after the dialog is closed. It is passed a single parameter, which is a reference to the dialog DOM element (after is is removed from the DOM).
You can install either manually or via npm. The latter is very simple:
npm install --save codemirror-advancedsearch
If you want to install manually, however, you will need to include both dist/advanced-dialog.js
and dist/dialog.css
in your page.
Obviously you need to include CodeMirror in the page. You also need to include addons/display/panel.js
from the CodeMirror default installation.
Implemented a build step using Babel to make the addon compatible with browsers that don't yet support ES6 features. The correct file to include is now dist/advanced-dialog.js.
The onInput
, onKeyDown
and onKeyUp
behaviours for input boxes now match the signature of the callback, in that they each are passed two parameters: an array of the inputs in the dialog, and the DOM event that triggered the function call.