12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- /**
- * @file
- * Dialog API inspired by HTML5 dialog element.
- *
- * @see http://www.whatwg.org/specs/web-apps/current-work/multipage/commands.html#the-dialog-element
- */
- (function($, Drupal, drupalSettings) {
- /**
- * Default dialog options.
- *
- * @type {object}
- *
- * @prop {bool} [autoOpen=true]
- * @prop {string} [dialogClass='']
- * @prop {string} [buttonClass='button']
- * @prop {string} [buttonPrimaryClass='button--primary']
- * @prop {function} close
- */
- drupalSettings.dialog = {
- autoOpen: true,
- dialogClass: '',
- // Drupal-specific extensions: see dialog.jquery-ui.js.
- buttonClass: 'button',
- buttonPrimaryClass: 'button--primary',
- // When using this API directly (when generating dialogs on the client
- // side), you may want to override this method and do
- // `jQuery(event.target).remove()` as well, to remove the dialog on
- // closing.
- close(event) {
- Drupal.dialog(event.target).close();
- Drupal.detachBehaviors(event.target, null, 'unload');
- },
- };
- /**
- * @typedef {object} Drupal.dialog~dialogDefinition
- *
- * @prop {boolean} open
- * Is the dialog open or not.
- * @prop {*} returnValue
- * Return value of the dialog.
- * @prop {function} show
- * Method to display the dialog on the page.
- * @prop {function} showModal
- * Method to display the dialog as a modal on the page.
- * @prop {function} close
- * Method to hide the dialog from the page.
- */
- /**
- * Polyfill HTML5 dialog element with jQueryUI.
- *
- * @param {HTMLElement} element
- * The element that holds the dialog.
- * @param {object} options
- * jQuery UI options to be passed to the dialog.
- *
- * @return {Drupal.dialog~dialogDefinition}
- * The dialog instance.
- */
- Drupal.dialog = function(element, options) {
- let undef;
- const $element = $(element);
- const dialog = {
- open: false,
- returnValue: undef,
- };
- function openDialog(settings) {
- settings = $.extend({}, drupalSettings.dialog, options, settings);
- // Trigger a global event to allow scripts to bind events to the dialog.
- $(window).trigger('dialog:beforecreate', [dialog, $element, settings]);
- $element.dialog(settings);
- dialog.open = true;
- $(window).trigger('dialog:aftercreate', [dialog, $element, settings]);
- }
- function closeDialog(value) {
- $(window).trigger('dialog:beforeclose', [dialog, $element]);
- $element.dialog('close');
- dialog.returnValue = value;
- dialog.open = false;
- $(window).trigger('dialog:afterclose', [dialog, $element]);
- }
- dialog.show = () => {
- openDialog({ modal: false });
- };
- dialog.showModal = () => {
- openDialog({ modal: true });
- };
- dialog.close = closeDialog;
- return dialog;
- };
- })(jQuery, Drupal, drupalSettings);
|