UNPKG

@uex/web-extensions

Version:

Uex extensions for Angular 6+ web projects

210 lines 16.7 kB
/** * @fileoverview added by tsickle * Generated from: lib/modules/drag-and-drop/drop-zone.directive.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Directive, ContentChildren, Input, Output, QueryList, ElementRef, EventEmitter } from '@angular/core'; import * as _ from 'lodash'; import { DragAndDropService } from './drag-and-drop.service'; import { DraggableDirective } from './draggable.directive'; export class DropZoneDirective { /** * @param {?} _service * @param {?} elementRef */ constructor(_service, elementRef) { this._service = _service; this.elementRef = elementRef; this.onDragEnter = new EventEmitter(); this.onDragLeave = new EventEmitter(); this.onDrop = new EventEmitter(); this.onRemove = new EventEmitter(); this.enabled = true; this.dragging_over = false; this.drop_zone = this._service.registerDropZone({ element: this._element }); } /** * @private * @param {?} enabled * @return {?} */ set _setEnabled(enabled) { if (_.isString(enabled) && _.isEmpty(enabled)) { this.enabled = true; } else { this.enabled = !!enabled; } this.drop_zone.setEnabled(this.enabled); } /** * @private * @param {?} restriction * @return {?} */ set _setDropZoneRestriction(restriction) { this.drop_zone_restriction = restriction; this.drop_zone.setRestriction(this.drop_zone_restriction); } /** * @return {?} */ ngOnInit() { this._drag_enter_subscription = this.drop_zone.onEnter.subscribe((/** * @param {?} event * @return {?} */ (event) => { if (this.dragging_over) { return; } this.dragging_over = true; if (this.drop_zone_drag_over_class) { this._element.classList.add(this.drop_zone_drag_over_class); } this.onDragEnter.emit(event); })); this._drag_leave_subscription = this.drop_zone.onLeave.subscribe((/** * @param {?} event * @return {?} */ (event) => { if (!this.dragging_over) { return; } this.dragging_over = false; if (this.drop_zone_drag_over_class) { this._element.classList.remove(this.drop_zone_drag_over_class); } this.onDragLeave.emit(event); })); this._drop_subscription = this.drop_zone.onDrop.subscribe((/** * @param {?} event * @return {?} */ (event) => { this.onDrop.emit(event); })); this._remove_subscription = this.drop_zone.onRemove.subscribe((/** * @param {?} event * @return {?} */ (event) => { this.onRemove.emit(event); })); } /** * @return {?} */ ngAfterViewInit() { this.drop_zone.setDraggableChildren(this._draggable_children.map((/** * @param {?} child * @return {?} */ (child) => child.draggable))); } /** * @return {?} */ ngOnDestroy() { if (this._drag_enter_subscription) { this._drag_enter_subscription.unsubscribe(); } if (this._drag_leave_subscription) { this._drag_leave_subscription.unsubscribe(); } if (this._drop_subscription) { this._drop_subscription.unsubscribe(); } if (this._remove_subscription) { this._remove_subscription.unsubscribe(); } this._service.unregisterDropZone(this.drop_zone); } /** * @private * @return {?} */ get _element() { return this.elementRef.nativeElement; } } DropZoneDirective.decorators = [ { type: Directive, args: [{ selector: '[uexDropZone]', host: { '[class.uex-drop-zone]': 'enabled', '[class.dragging-over]': 'dragging_over' } },] } ]; /** @nocollapse */ DropZoneDirective.ctorParameters = () => [ { type: DragAndDropService }, { type: ElementRef } ]; DropZoneDirective.propDecorators = { _draggable_children: [{ type: ContentChildren, args: [DraggableDirective,] }], _setEnabled: [{ type: Input, args: ['uexDropZone',] }], _setDropZoneRestriction: [{ type: Input, args: ['uexDropZoneExclude',] }], drop_zone_drag_over_class: [{ type: Input, args: ['uexDropZoneDragOverClass',] }], onDragEnter: [{ type: Output, args: ['onDragEnter',] }], onDragLeave: [{ type: Output, args: ['onDragLeave',] }], onDrop: [{ type: Output, args: ['onDrop',] }], onRemove: [{ type: Output, args: ['onRemove',] }] }; if (false) { /** * @type {?} * @private */ DropZoneDirective.prototype._draggable_children; /** @type {?} */ DropZoneDirective.prototype.drop_zone_drag_over_class; /** @type {?} */ DropZoneDirective.prototype.onDragEnter; /** @type {?} */ DropZoneDirective.prototype.onDragLeave; /** @type {?} */ DropZoneDirective.prototype.onDrop; /** @type {?} */ DropZoneDirective.prototype.onRemove; /** @type {?} */ DropZoneDirective.prototype.enabled; /** @type {?} */ DropZoneDirective.prototype.dragging_over; /** @type {?} */ DropZoneDirective.prototype.drop_zone_restriction; /** @type {?} */ DropZoneDirective.prototype.drop_zone; /** * @type {?} * @private */ DropZoneDirective.prototype._drag_enter_subscription; /** * @type {?} * @private */ DropZoneDirective.prototype._drag_leave_subscription; /** * @type {?} * @private */ DropZoneDirective.prototype._drop_subscription; /** * @type {?} * @private */ DropZoneDirective.prototype._remove_subscription; /** * @type {?} * @private */ DropZoneDirective.prototype._service; /** @type {?} */ DropZoneDirective.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-zone.directive.js","sourceRoot":"ng://@uex/web-extensions/","sources":["lib/modules/drag-and-drop/drop-zone.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ContentChildren, Input, Output, QueryList, ElementRef, EventEmitter, OnInit, AfterViewInit, OnDestroy } from '@angular/core';\r\n\r\nimport { Subscription } from 'rxjs';\r\nimport * as _ from 'lodash';\r\n\r\nimport { DragAndDropService, DragAndDropEvent } from './drag-and-drop.service';\r\n\r\nimport { DraggableDirective } from './draggable.directive';\r\nimport { DropZone } from './classes/drop-zone';\r\n\r\n@Directive({\r\n  selector: '[uexDropZone]',\r\n  host: {\r\n    '[class.uex-drop-zone]': 'enabled',\r\n    '[class.dragging-over]': 'dragging_over'\r\n  }\r\n})\r\nexport class DropZoneDirective implements OnInit, AfterViewInit, OnDestroy {\r\n  @ContentChildren(DraggableDirective) private _draggable_children: QueryList<DraggableDirective>;\r\n\r\n  @Input('uexDropZone') private set _setEnabled(enabled: boolean | string) {\r\n    if (_.isString(enabled) && _.isEmpty(enabled)) {\r\n      this.enabled = true;\r\n    } else {\r\n      this.enabled = !!enabled;\r\n    }\r\n\r\n    this.drop_zone.setEnabled(this.enabled);\r\n  }\r\n\r\n  @Input('uexDropZoneExclude') private set _setDropZoneRestriction(restriction: string | string[]) {\r\n    this.drop_zone_restriction = restriction;\r\n    this.drop_zone.setRestriction(this.drop_zone_restriction);\r\n  }\r\n  @Input('uexDropZoneDragOverClass') public drop_zone_drag_over_class: string;\r\n\r\n  @Output('onDragEnter') public onDragEnter: EventEmitter<DragEvent> = new EventEmitter();\r\n  @Output('onDragLeave') public onDragLeave: EventEmitter<DragEvent> = new EventEmitter();\r\n\r\n  @Output('onDrop') public onDrop: EventEmitter<DragAndDropEvent> = new EventEmitter();\r\n  @Output('onRemove') public onRemove: EventEmitter<DragAndDropEvent> = new EventEmitter();\r\n\r\n  constructor(\r\n    private _service: DragAndDropService,\r\n    public elementRef: ElementRef\r\n  ) {\r\n    this.drop_zone = this._service.registerDropZone({\r\n      element: this._element\r\n    });\r\n  }\r\n\r\n  public enabled = true;\r\n  public dragging_over = false;\r\n  public drop_zone_restriction: string | string[];\r\n\r\n  public drop_zone: DropZone;\r\n  private _drag_enter_subscription: Subscription;\r\n  private _drag_leave_subscription: Subscription;\r\n  private _drop_subscription: Subscription;\r\n  private _remove_subscription: Subscription;\r\n\r\n  public ngOnInit() {\r\n    this._drag_enter_subscription = this.drop_zone.onEnter.subscribe((event: DragEvent) => {\r\n      if (this.dragging_over) { return; }\r\n\r\n      this.dragging_over = true;\r\n      if (this.drop_zone_drag_over_class) { this._element.classList.add(this.drop_zone_drag_over_class); }\r\n\r\n      this.onDragEnter.emit(event);\r\n    });\r\n\r\n    this._drag_leave_subscription = this.drop_zone.onLeave.subscribe((event: DragEvent) => {\r\n      if (!this.dragging_over) { return; }\r\n\r\n      this.dragging_over = false;\r\n      if (this.drop_zone_drag_over_class) { this._element.classList.remove(this.drop_zone_drag_over_class); }\r\n\r\n      this.onDragLeave.emit(event);\r\n    });\r\n\r\n    this._drop_subscription = this.drop_zone.onDrop.subscribe((event: DragAndDropEvent) => {\r\n      this.onDrop.emit(event);\r\n    });\r\n\r\n    this._remove_subscription = this.drop_zone.onRemove.subscribe((event: DragAndDropEvent) => {\r\n      this.onRemove.emit(event);\r\n    });\r\n  }\r\n\r\n  public ngAfterViewInit() {\r\n    this.drop_zone.setDraggableChildren(this._draggable_children.map((child) => child.draggable));\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    if (this._drag_enter_subscription) { this._drag_enter_subscription.unsubscribe(); }\r\n    if (this._drag_leave_subscription) { this._drag_leave_subscription.unsubscribe(); }\r\n    if (this._drop_subscription) { this._drop_subscription.unsubscribe(); }\r\n    if (this._remove_subscription) { this._remove_subscription.unsubscribe(); }\r\n\r\n    this._service.unregisterDropZone(this.drop_zone);\r\n  }\r\n\r\n  private get _element (): HTMLElement {\r\n    return this.elementRef.nativeElement;\r\n  }\r\n}\r\n"]}