@uex/web-extensions
Version:
Uex extensions for Angular 6+ web projects
224 lines • 19.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/modules/drag-and-drop/classes/draggable.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { EventEmitter } from '@angular/core';
export class Draggable {
/**
* @param {?} _service
* @param {?} id
* @param {?} element
*/
constructor(_service, id, element) {
this._service = _service;
this.id = id;
this.element = element;
this.enabled = true;
this.dragging = false;
this.name = '';
this.action = 'move';
this.use_placeholder = true;
this.placeholder_class = null;
this.data = null;
this.onStart = new EventEmitter();
this.onEnd = new EventEmitter();
this.$onStart = new EventEmitter();
this.$onEnd = new EventEmitter();
this._drag_placeholder = document.createElement('div');
this._onDragStart = (/**
* @param {?} event
* @return {?}
*/
(event) => {
event.stopPropagation();
if (!this.enabled || this.dragging) {
return;
}
event.dataTransfer.effectAllowed = this.action;
event.dataTransfer.dropEffect = this.action;
/** @type {?} */
const element = this.element;
/** @type {?} */
const parent = this.element.parentNode;
/** @type {?} */
const rects = element.getBoundingClientRect();
/** @type {?} */
const styles = window.getComputedStyle(element);
if (this.use_placeholder) {
this._drag_placeholder.classList.add('uex-drag-placeholder');
if (this.placeholder_class) {
this._drag_placeholder.classList.add(this.placeholder_class);
}
this._drag_placeholder.style.width = `${rects.width}px`;
this._drag_placeholder.style.height = `${rects.height}px`;
this._drag_placeholder.style.borderRadius = styles.borderRadius || null;
this._drag_placeholder.style.marginTop = styles.marginTop || null;
this._drag_placeholder.style.marginRight = styles.marginRight || null;
this._drag_placeholder.style.marginBottom = styles.marginBottom || null;
this._drag_placeholder.style.marginLeft = styles.marginLeft || null;
parent.insertBefore(this._drag_placeholder, element.nextSibling);
}
if (this.data) {
event.dataTransfer.setData('text/plain', JSON.stringify({ data: this.data }));
}
this._drag_start_event = event;
});
this._onDrag = (/**
* @param {?} event
* @return {?}
*/
(event) => {
if (!this.enabled) {
return;
}
if (!this.dragging) {
if (this.use_placeholder) {
this._drag_placeholder.style.display = 'block';
}
this.dragging = true;
this.$onStart.emit(this._drag_start_event);
}
});
this._onDragEnd = (/**
* @param {?} event
* @return {?}
*/
(event) => {
if (!this.dragging) {
return;
}
this._drag_start_event = null;
this.dragging = false;
event.dataTransfer.clearData();
if (this.use_placeholder) {
this._drag_placeholder.style.display = 'none';
if (this._drag_placeholder.parentNode) {
this._drag_placeholder.parentNode.removeChild(this._drag_placeholder);
}
}
this.$onEnd.emit(event);
});
this._service.addEventListener(this.element, 'dragstart', this._onDragStart);
this._service.addEventListener(this.element, 'drag', this._onDrag, true);
this._service.addEventListener(this.element, 'dragend', this._onDragEnd);
this._service.addEventListener(this.element, 'drop', this._onDragEnd);
}
/**
* @param {?} enabled
* @return {?}
*/
setEnabled(enabled) {
this.enabled = enabled;
}
/**
* @param {?} dragging
* @return {?}
*/
setDragging(dragging) {
this.dragging = dragging;
}
/**
* @param {?} name
* @return {?}
*/
setName(name) {
this.name = name;
}
/**
* @param {?} action
* @return {?}
*/
setAction(action) {
this.action = action;
}
/**
* @param {?} data
* @return {?}
*/
setData(data) {
this.data = data;
}
/**
* @param {?} use_placeholder
* @return {?}
*/
setUsePlaceholder(use_placeholder) {
this.use_placeholder = use_placeholder;
}
/**
* @param {?} placeholder_class
* @return {?}
*/
setPlaceholderClass(placeholder_class) {
this.placeholder_class = placeholder_class;
}
/**
* @return {?}
*/
destroy() {
this._service.removeEventListener(this.element, 'dragstart', this._onDragStart);
this._service.removeEventListener(this.element, 'drag', this._onDrag);
this._service.removeEventListener(document, 'dragend', this._onDragEnd);
this._service.removeEventListener(this.element, 'drop', this._onDragEnd);
}
}
if (false) {
/** @type {?} */
Draggable.prototype.enabled;
/** @type {?} */
Draggable.prototype.dragging;
/** @type {?} */
Draggable.prototype.name;
/** @type {?} */
Draggable.prototype.action;
/** @type {?} */
Draggable.prototype.use_placeholder;
/** @type {?} */
Draggable.prototype.placeholder_class;
/** @type {?} */
Draggable.prototype.data;
/** @type {?} */
Draggable.prototype.onStart;
/** @type {?} */
Draggable.prototype.onEnd;
/** @type {?} */
Draggable.prototype.$onStart;
/** @type {?} */
Draggable.prototype.$onEnd;
/**
* @type {?}
* @private
*/
Draggable.prototype._drag_placeholder;
/**
* @type {?}
* @private
*/
Draggable.prototype._drag_start_event;
/**
* @type {?}
* @private
*/
Draggable.prototype._onDragStart;
/**
* @type {?}
* @private
*/
Draggable.prototype._onDrag;
/**
* @type {?}
* @private
*/
Draggable.prototype._onDragEnd;
/**
* @type {?}
* @private
*/
Draggable.prototype._service;
/** @type {?} */
Draggable.prototype.id;
/** @type {?} */
Draggable.prototype.element;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"draggable.js","sourceRoot":"ng://@uex/web-extensions/","sources":["lib/modules/drag-and-drop/classes/draggable.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAI7C,MAAM,OAAO,SAAS;;;;;;IACpB,YACU,QAA4B,EACpB,EAAU,EACV,OAAoB;QAF5B,aAAQ,GAAR,QAAQ,CAAoB;QACpB,OAAE,GAAF,EAAE,CAAQ;QACV,YAAO,GAAP,OAAO,CAAa;QAQ/B,YAAO,GAAG,IAAI,CAAC;QACf,aAAQ,GAAG,KAAK,CAAC;QAEjB,SAAI,GAAG,EAAE,CAAC;QACV,WAAM,GAAe,MAAM,CAAC;QAC5B,oBAAe,GAAG,IAAI,CAAC;QACvB,sBAAiB,GAAW,IAAI,CAAC;QACjC,SAAI,GAAQ,IAAI,CAAC;QAEjB,YAAO,GAAmC,IAAI,YAAY,EAAE,CAAC;QAC7D,UAAK,GAAmC,IAAI,YAAY,EAAE,CAAC;QAE3D,aAAQ,GAA4B,IAAI,YAAY,EAAE,CAAC;QACvD,WAAM,GAA4B,IAAI,YAAY,EAAE,CAAC;QAEpD,sBAAiB,GAAgB,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAsC/D,iBAAY;;;;QAAG,CAAC,KAAgB,EAAQ,EAAE;YAChD,KAAK,CAAC,eAAe,EAAE,CAAC;YAExB,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE;gBAAE,OAAO;aAAE;YAE/C,KAAK,CAAC,YAAY,CAAC,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC;YAC/C,KAAK,CAAC,YAAY,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;;kBAEtC,OAAO,GAAG,IAAI,CAAC,OAAO;;kBACtB,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU;;kBAChC,KAAK,GAAG,OAAO,CAAC,qBAAqB,EAAE;;kBACvC,MAAM,GAAG,MAAM,CAAC,gBAAgB,CAAC,OAAO,CAAC;YAE/C,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxB,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;gBAE7D,IAAI,IAAI,CAAC,iBAAiB,EAAE;oBAC1B,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;iBAC9D;gBAED,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,KAAK,CAAC,KAAK,IAAI,CAAC;gBACxD,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,KAAK,CAAC,MAAM,IAAI,CAAC;gBAC1D,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,IAAI,CAAC;gBACxE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,IAAI,CAAC;gBAClE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,WAAW,GAAG,MAAM,CAAC,WAAW,IAAI,IAAI,CAAC;gBACtE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,IAAI,CAAC;gBACxE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC;gBAEpE,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;aAClE;YAED,IAAI,IAAI,CAAC,IAAI,EAAE;gBACb,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,EAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;aAC9E;YAED,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QACjC,CAAC,EAAA;QAEO,YAAO;;;;QAAG,CAAC,KAAgB,EAAQ,EAAE;YAC3C,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;gBAAE,OAAO;aAAE;YAE9B,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;gBAClB,IAAI,IAAI,CAAC,eAAe,EAAE;oBACxB,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;iBAChD;gBAED,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;aAC5C;QACH,CAAC,EAAA;QAEO,eAAU;;;;QAAG,CAAC,KAAgB,EAAQ,EAAE;YAC9C,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;gBAAE,OAAO;aAAE;YAE/B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAE9B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YAEtB,KAAK,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;YAE/B,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxB,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;gBAC9C,IAAI,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE;oBACrC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;iBACvE;aACF;YAED,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC,EAAA;QA/HC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAC7E,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACzE,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QACzE,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IACxE,CAAC;;;;;IAoBM,UAAU,CAAC,OAAgB;QAChC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;;;;;IAEM,WAAW,CAAC,QAAiB;QAClC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;;;;;IAEM,OAAO,CAAC,IAAY;QACzB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;;;;;IAEM,SAAS,CAAC,MAAkB;QACjC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;;;;;IAEM,OAAO,CAAC,IAAS;QACtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;;;;;IAEM,iBAAiB,CAAC,eAAwB;QAC/C,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;IACzC,CAAC;;;;;IAEM,mBAAmB,CAAC,iBAAyB;QAClD,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;IAC7C,CAAC;;;;IAEM,OAAO;QACZ,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAChF,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QACtE,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,QAAQ,EAAE,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QACxE,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC3E,CAAC;CAuEF;;;IA1HC,4BAAsB;;IACtB,6BAAwB;;IAExB,yBAAiB;;IACjB,2BAAmC;;IACnC,oCAA8B;;IAC9B,sCAAwC;;IACxC,yBAAwB;;IAExB,4BAAoE;;IACpE,0BAAkE;;IAElE,6BAA8D;;IAC9D,2BAA4D;;;;;IAE5D,sCAAuE;;;;;IACvE,sCAAqC;;;;;IAqCrC,iCAoCC;;;;;IAED,4BAWC;;;;;IAED,+BAiBC;;;;;IAnIC,6BAAoC;;IACpC,uBAA0B;;IAC1B,4BAAoC","sourcesContent":["import { EventEmitter } from '@angular/core';\r\n\r\nimport { DragAndDropService, DragAction, DragAndDropEvent } from '../drag-and-drop.service';\r\n\r\nexport class Draggable {\r\n  constructor(\r\n    private _service: DragAndDropService,\r\n    public readonly id: number,\r\n    public readonly element: HTMLElement\r\n  ) {\r\n    this._service.addEventListener(this.element, 'dragstart', this._onDragStart);\r\n    this._service.addEventListener(this.element, 'drag', this._onDrag, true);\r\n    this._service.addEventListener(this.element, 'dragend', this._onDragEnd);\r\n    this._service.addEventListener(this.element, 'drop', this._onDragEnd);\r\n  }\r\n\r\n  public enabled = true;\r\n  public dragging = false;\r\n\r\n  public name = '';\r\n  public action: DragAction = 'move';\r\n  public use_placeholder = true;\r\n  public placeholder_class: string = null;\r\n  public data: any = null;\r\n\r\n  public onStart: EventEmitter<DragAndDropEvent> = new EventEmitter();\r\n  public onEnd: EventEmitter<DragAndDropEvent> = new EventEmitter();\r\n\r\n  public $onStart: EventEmitter<DragEvent> = new EventEmitter();\r\n  public $onEnd: EventEmitter<DragEvent> = new EventEmitter();\r\n\r\n  private _drag_placeholder: HTMLElement = document.createElement('div');\r\n  private _drag_start_event: DragEvent;\r\n\r\n  public setEnabled(enabled: boolean): void {\r\n    this.enabled = enabled;\r\n  }\r\n\r\n  public setDragging(dragging: boolean): void {\r\n    this.dragging = dragging;\r\n  }\r\n\r\n  public setName(name: string): void {\r\n    this.name = name;\r\n  }\r\n\r\n  public setAction(action: DragAction): void {\r\n    this.action = action;\r\n  }\r\n\r\n  public setData(data: any): void {\r\n    this.data = data;\r\n  }\r\n\r\n  public setUsePlaceholder(use_placeholder: boolean): void {\r\n    this.use_placeholder = use_placeholder;\r\n  }\r\n\r\n  public setPlaceholderClass(placeholder_class: string): void {\r\n    this.placeholder_class = placeholder_class;\r\n  }\r\n\r\n  public destroy() {\r\n    this._service.removeEventListener(this.element, 'dragstart', this._onDragStart);\r\n    this._service.removeEventListener(this.element, 'drag', this._onDrag);\r\n    this._service.removeEventListener(document, 'dragend', this._onDragEnd);\r\n    this._service.removeEventListener(this.element, 'drop', this._onDragEnd);\r\n  }\r\n\r\n  private _onDragStart = (event: DragEvent): void => {\r\n    event.stopPropagation();\r\n\r\n    if (!this.enabled || this.dragging) { return; }\r\n\r\n    event.dataTransfer.effectAllowed = this.action;\r\n    event.dataTransfer.dropEffect = this.action;\r\n\r\n    const element = this.element;\r\n    const parent = this.element.parentNode;\r\n    const rects = element.getBoundingClientRect();\r\n    const styles = window.getComputedStyle(element);\r\n\r\n    if (this.use_placeholder) {\r\n      this._drag_placeholder.classList.add('uex-drag-placeholder');\r\n\r\n      if (this.placeholder_class) {\r\n        this._drag_placeholder.classList.add(this.placeholder_class);\r\n      }\r\n\r\n      this._drag_placeholder.style.width = `${rects.width}px`;\r\n      this._drag_placeholder.style.height = `${rects.height}px`;\r\n      this._drag_placeholder.style.borderRadius = styles.borderRadius || null;\r\n      this._drag_placeholder.style.marginTop = styles.marginTop || null;\r\n      this._drag_placeholder.style.marginRight = styles.marginRight || null;\r\n      this._drag_placeholder.style.marginBottom = styles.marginBottom || null;\r\n      this._drag_placeholder.style.marginLeft = styles.marginLeft || null;\r\n\r\n      parent.insertBefore(this._drag_placeholder, element.nextSibling);\r\n    }\r\n\r\n    if (this.data) {\r\n      event.dataTransfer.setData('text/plain', JSON.stringify({data: this.data }));\r\n    }\r\n\r\n    this._drag_start_event = event;\r\n  }\r\n\r\n  private _onDrag = (event: DragEvent): void => {\r\n    if (!this.enabled) { return; }\r\n\r\n    if (!this.dragging) {\r\n      if (this.use_placeholder) {\r\n        this._drag_placeholder.style.display = 'block';\r\n      }\r\n\r\n      this.dragging = true;\r\n      this.$onStart.emit(this._drag_start_event);\r\n    }\r\n  }\r\n\r\n  private _onDragEnd = (event: DragEvent): void => {\r\n    if (!this.dragging) { return; }\r\n\r\n    this._drag_start_event = null;\r\n\r\n    this.dragging = false;\r\n\r\n    event.dataTransfer.clearData();\r\n\r\n    if (this.use_placeholder) {\r\n      this._drag_placeholder.style.display = 'none';\r\n      if (this._drag_placeholder.parentNode) {\r\n        this._drag_placeholder.parentNode.removeChild(this._drag_placeholder);\r\n      }\r\n    }\r\n\r\n    this.$onEnd.emit(event);\r\n  }\r\n}\r\n"]}