UNPKG

@uex/web-extensions

Version:

Uex extensions for Angular 6+ web projects

224 lines 19.6 kB
/** * @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":"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","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"]}