entity_browser-8.x-2.x-dev/js/entity_browser.command_queue.js
js/entity_browser.command_queue.js
/**
* @file entity_browser.command_queue.js
*/
(function ($, Drupal, once) {
'use strict';
/**
* Namespace for command queue functionality.
*
* Command queue provides functionality to queue ajax commands in front-end
* and execute them in one ajax request in backend. All commands triggered
* during ajax request execution, will be queue and executed after response
* from previous ajax request is received.
*
* @type {Object}
*/
Drupal.entityBrowserCommandQueue = {};
/**
* Queue container for keeping commands for next queue execution. (protected)
*
* @type {Object}
*/
var commandsQueue = {};
/**
* Registers behaviours related to Ajax commands execution.
*/
Drupal.behaviors.entityBrowserCommandQueue = {
attach: function (context) {
$(once('register-execute-commands', '[name="ajax_commands_handler"]', context))
.bind('execute-commands', Drupal.entityBrowserCommandQueue.executeCommands);
}
};
/**
* Action to queue command for future execution.
*
* @param {string} commandName
* Command name, that will be executed.
* @param {Array} commandParam
* Params for command. If command already exists in queue params will be
* added to end of list.
*/
Drupal.entityBrowserCommandQueue.queueCommand = function (commandName, commandParam) {
if (!commandsQueue[commandName]) {
commandsQueue[commandName] = [];
}
commandsQueue[commandName].push(commandParam);
};
/**
* Handler for executing queued commands over Ajax.
*
* @param {object} event
* Event object.
* @param {boolean} addedCommand
* Execution of queued commands is triggered after new command is added.
*/
Drupal.entityBrowserCommandQueue.executeCommands = function (event, addedCommand) {
var handler = $(this);
var handlerElement = handler[0];
var runningAjax = Drupal.entityBrowserCommandQueue.isAjaxRunning(handlerElement, 'execute_js_commands');
var filledQueue = !$.isEmptyObject(commandsQueue);
if (!runningAjax && filledQueue) {
handler.val(JSON.stringify(commandsQueue));
// Clear Queue after command is set to handler element.
commandsQueue = {};
// Trigger event to execute event with defined command.
handler.trigger('execute_js_commands');
}
else if (!addedCommand && filledQueue) {
setTimeout($.proxy(Drupal.entityBrowserCommandQueue.executeCommands, handlerElement), 200);
}
};
/**
* Search is there current Ajax request executing for current event.
*
* @param {element} handlerElement
* Element on what event is triggered.
* @param {string} eventName
* Event name.
*
* @return {boolean}
* Returns true if ajax event is still running for element.
*/
Drupal.entityBrowserCommandQueue.isAjaxRunning = function (handlerElement, eventName) {
var ajax_list = Drupal.ajax.instances;
for (var i = 0; i < ajax_list.length; i++) {
if (ajax_list[i] && ajax_list[i].event === eventName && ajax_list[i].element === handlerElement && ajax_list[i].ajaxing) {
return true;
}
}
return false;
};
}(jQuery, Drupal, once));
