toolshed-8.x-1.x-dev/js/DragDrop.js
js/DragDrop.js
"use strict";
(({
Toolshed
}) => {
/**
* Object wrapping a DOM element to implement a droppable container for
* accepting draggable instances.
*/
class Droppable {
/**
* Create a new instance of a droppable for containing draggables.
*
* @param {Element} el
* DOM element to treat as the droppable.
* @param {Object} opts
* Configuration options to control how this droppable behaves.
*/
constructor(el, opts = {}) {
this.el = el;
this.opts = {
...opts
};
this.id = el.dataset.containerId;
this.items = [];
this.children = [];
}
getId() {
return this.id;
}
getItems() {
return this.items;
}
getChildren() {
return this.children;
}
attachItem(item, pos) {
const el = item.getElement();
if ((pos || pos === 0) && this.items.length > pos) {
this.el.insertBefore(el, this.items[pos].getElement());
this.items.splice(pos, 0, el);
} else {
this.el.appendChild(item.getElement());
this.items.push(item);
pos = this.items.length - 1;
}
item.attach(this, pos);
}
detachItem(item) {
for (let i = 0; i < this.items.length; ++i) {
if (this.items[i] === item) {
this.items.splice(i, 1);
break;
}
}
this.el.removeChild(item.getElement());
item.detach();
}
}
/**
* A element that is draggable and can get placed into {Droppable} objects.
*/
class Draggable {
/**
* Get the active dragging object instance, if there is a dragging action
* in progress. There will only be a single draggable actively being dragged
* at any given time.
*
* @return {Draggable|null}
* Return the draggable instance if there is one, otherwise return {null}.
*/
static get dragging() {
return this._dragging;
}
/**
* Get the currently active dragging tracking to this draggable object.
* This property is global because there should only be 1 active dragging
* activity for the entire application, even if it is accross multiple
* drag and drop sets.
*
* @param {Draggable|null} draggable
* Set the {Draggable} element as actively being dragged. Passing {null}
* as the parameter here is the same as unsetting cancelling any current
* dragging activity and clearing this property.
*/
static set dragging(draggable) {
if (this._dragging) {
const oldDrag = this._dragging;
oldDrag.cancelDrag(false);
}
this._dragging = draggable;
}
/**
* Construct a new draggable handler.
*
* @param {Element} el
* The element to attach the draggable behaviors to.
* @param {Object} opts
* The options for the draggable behaviors.
*/
constructor(el, opts = {}) {
this.el = el;
this.opts = {
inputSelector: 'input.drag-parent',
...opts
};
this.parent = null;
this.pos = 0;
this.input = this.el.querySelector(this.opts.inputSelector);
}
getElement() {
return this.el;
}
attach(droppable, pos) {
this.parent = droppable;
this.pos = pos;
this.input.value = `${droppable.getId()}:${pos}`;
}
detach() {
this.parent = null;
this.pos = 0;
this.input.value = '';
}
/**
* Cancel the dragging action if it's been dragged.
*/
cancelDrag() {
if (this.placeholder) {
this.placeholder.parentNode.removeChild(this.placeholder);
}
}
}
// Export the drag and drop definitions to the Toolshed namespace.
Toolshed.Droppable = Droppable;
Toolshed.Draggable = Draggable;
})(Drupal);
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"file":"DragDrop.js","names":["Toolshed","Droppable","constructor","el","opts","id","dataset","containerId","items","children","getId","getItems","getChildren","attachItem","item","pos","getElement","length","insertBefore","splice","appendChild","push","attach","detachItem","i","removeChild","detach","Draggable","dragging","_dragging","draggable","oldDrag","cancelDrag","inputSelector","parent","input","querySelector","droppable","value","placeholder","parentNode","Drupal"],"sources":["DragDrop.es6.js"],"sourcesContent":["(({ Toolshed }) => {\n  /**\n   * Object wrapping a DOM element to implement a droppable container for\n   * accepting draggable instances.\n   */\n  class Droppable {\n    /**\n     * Create a new instance of a droppable for containing draggables.\n     *\n     * @param {Element} el\n     *   DOM element to treat as the droppable.\n     * @param {Object} opts\n     *   Configuration options to control how this droppable behaves.\n     */\n    constructor(el, opts = {}) {\n      this.el = el;\n      this.opts = {\n        ...opts,\n      };\n\n      this.id = el.dataset.containerId;\n      this.items = [];\n      this.children = [];\n    }\n\n    getId() {\n      return this.id;\n    }\n\n    getItems() {\n      return this.items;\n    }\n\n    getChildren() {\n      return this.children;\n    }\n\n    attachItem(item, pos) {\n      const el = item.getElement();\n\n      if ((pos || pos === 0) && this.items.length > pos) {\n        this.el.insertBefore(el, this.items[pos].getElement());\n        this.items.splice(pos, 0, el);\n      }\n      else {\n        this.el.appendChild(item.getElement());\n        this.items.push(item);\n        pos = this.items.length - 1;\n      }\n\n      item.attach(this, pos);\n    }\n\n    detachItem(item) {\n      for (let i = 0; i < this.items.length; ++i) {\n        if (this.items[i] === item) {\n          this.items.splice(i, 1);\n          break;\n        }\n      }\n\n      this.el.removeChild(item.getElement());\n      item.detach();\n    }\n  }\n\n  /**\n   * A element that is draggable and can get placed into {Droppable} objects.\n   */\n  class Draggable {\n    /**\n     * Get the active dragging object instance, if there is a dragging action\n     * in progress. There will only be a single draggable actively being dragged\n     * at any given time.\n     *\n     * @return {Draggable|null}\n     *   Return the draggable instance if there is one, otherwise return {null}.\n     */\n    static get dragging() {\n      return this._dragging;\n    }\n\n    /**\n     * Get the currently active dragging tracking to this draggable object.\n     * This property is global because there should only be 1 active dragging\n     * activity for the entire application, even if it is accross multiple\n     * drag and drop sets.\n     *\n     * @param {Draggable|null} draggable\n     *   Set the {Draggable} element as actively being dragged. Passing {null}\n     *   as the parameter here is the same as unsetting cancelling any current\n     *   dragging activity and clearing this property.\n     */\n    static set dragging(draggable) {\n      if (this._dragging) {\n        const oldDrag = this._dragging;\n\n        oldDrag.cancelDrag(false);\n      }\n\n      this._dragging = draggable;\n    }\n\n    /**\n     * Construct a new draggable handler.\n     *\n     * @param {Element} el\n     *   The element to attach the draggable behaviors to.\n     * @param {Object} opts\n     *   The options for the draggable behaviors.\n     */\n    constructor(el, opts = {}) {\n      this.el = el;\n      this.opts = {\n        inputSelector: 'input.drag-parent',\n        ...opts,\n      };\n\n      this.parent = null;\n      this.pos = 0;\n      this.input = this.el.querySelector(this.opts.inputSelector);\n    }\n\n    getElement() {\n      return this.el;\n    }\n\n    attach(droppable, pos) {\n      this.parent = droppable;\n      this.pos = pos;\n      this.input.value = `${droppable.getId()}:${pos}`;\n    }\n\n    detach() {\n      this.parent = null;\n      this.pos = 0;\n      this.input.value = '';\n    }\n\n    /**\n     * Cancel the dragging action if it's been dragged.\n     */\n    cancelDrag() {\n      if (this.placeholder) {\n        this.placeholder.parentNode.removeChild(this.placeholder);\n      }\n    }\n  }\n\n  // Export the drag and drop definitions to the Toolshed namespace.\n  Toolshed.Droppable = Droppable;\n  Toolshed.Draggable = Draggable;\n})(Drupal);\n"],"mappings":"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"}
