@uex/web-extensions
Version:
Uex extensions for Angular 6+ web projects
210 lines • 16.7 kB
JavaScript
/**
* @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"]}