| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 | /** * @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) {  'use strict';  /**   * 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: function (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) {    var undef;    var $element = $(element);    var dialog = {      open: false,      returnValue: undef,      show: function () {        openDialog({modal: false});      },      showModal: function () {        openDialog({modal: true});      },      close: closeDialog    };    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]);    }    return dialog;  };})(jQuery, Drupal, drupalSettings);
 |