@blare/angular2gridster
Version:
[](https://badge.fury.io/js/angular2gridster)
487 lines • 37.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/
import { Directive, ElementRef, Input, Output, EventEmitter, NgZone } from '@angular/core';
import { fromEvent } from 'rxjs';
import { GridsterPrototypeService } from './gridster-prototype.service';
import { GridListItem } from '../gridList/GridListItem';
import { Draggable } from '../utils/draggable';
import { utils } from '../utils/utils';
var GridsterItemPrototypeDirective = /** @class */ (function () {
function GridsterItemPrototypeDirective(zone, elementRef, gridsterPrototype) {
this.zone = zone;
this.elementRef = elementRef;
this.gridsterPrototype = gridsterPrototype;
this.drop = new EventEmitter();
this.start = new EventEmitter();
this.cancel = new EventEmitter();
this.enter = new EventEmitter();
this.out = new EventEmitter();
this.config = {};
this.x = 0;
this.y = 0;
this.autoSize = false;
this.isDragging = false;
this.subscribtions = [];
this.item = (new GridListItem()).setFromGridsterItemPrototype(this);
}
Object.defineProperty(GridsterItemPrototypeDirective.prototype, "dragAndDrop", {
// must be set to true because of item dragAndDrop configuration
get:
// must be set to true because of item dragAndDrop configuration
/**
* @return {?}
*/
function () {
return true;
},
enumerable: true,
configurable: true
});
Object.defineProperty(GridsterItemPrototypeDirective.prototype, "gridster", {
get: /**
* @return {?}
*/
function () {
return this.dragContextGridster;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.wSm = this.wSm || this.w;
this.hSm = this.hSm || this.h;
this.wMd = this.wMd || this.w;
this.hMd = this.hMd || this.h;
this.wLg = this.wLg || this.w;
this.hLg = this.hLg || this.h;
this.wXl = this.wXl || this.w;
this.hXl = this.hXl || this.h;
this.zone.runOutsideAngular(function () {
_this.enableDragDrop();
});
};
/**
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.subscribtions.forEach(function (sub) {
sub.unsubscribe();
});
};
/**
* @param {?} gridster
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.onDrop = /**
* @param {?} gridster
* @return {?}
*/
function (gridster) {
if (!this.config.helper) {
this.$element.parentNode.removeChild(this.$element);
}
this.drop.emit({
item: this.item,
gridster: gridster
});
};
/**
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.onCancel = /**
* @return {?}
*/
function () {
this.cancel.emit({ item: this.item });
};
/**
* @param {?} gridster
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.onEnter = /**
* @param {?} gridster
* @return {?}
*/
function (gridster) {
this.enter.emit({
item: this.item,
gridster: gridster
});
};
/**
* @param {?} gridster
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.onOver = /**
* @param {?} gridster
* @return {?}
*/
function (gridster) { };
/**
* @param {?} gridster
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.onOut = /**
* @param {?} gridster
* @return {?}
*/
function (gridster) {
this.out.emit({
item: this.item,
gridster: gridster
});
};
/**
* @param {?} gridster
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.getPositionToGridster = /**
* @param {?} gridster
* @return {?}
*/
function (gridster) {
/** @type {?} */
var relativeContainerCoords = this.getContainerCoordsToGridster(gridster);
return {
y: this.positionY - relativeContainerCoords.top,
x: this.positionX - relativeContainerCoords.left
};
};
/**
* @param {?} gridster
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.setDragContextGridster = /**
* @param {?} gridster
* @return {?}
*/
function (gridster) {
this.dragContextGridster = gridster;
};
/**
* @param {?} gridster
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.getContainerCoordsToGridster = /**
* @param {?} gridster
* @return {?}
*/
function (gridster) {
return {
left: gridster.gridsterRect.left - this.parentRect.left,
top: gridster.gridsterRect.top - this.parentRect.top
};
};
/**
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.enableDragDrop = /**
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var cursorToElementPosition;
/** @type {?} */
var draggable = new Draggable(this.elementRef.nativeElement);
/** @type {?} */
var dragStartSub = draggable.dragStart
.subscribe(function (event) {
_this.zone.run(function () {
_this.$element = _this.provideDragElement();
_this.containerRectange = _this.$element.parentElement.getBoundingClientRect();
_this.updateParentElementData();
_this.onStart(event);
cursorToElementPosition = event.getRelativeCoordinates(_this.$element);
});
});
/** @type {?} */
var dragSub = draggable.dragMove
.subscribe(function (event) {
_this.setElementPosition(_this.$element, {
x: event.clientX - cursorToElementPosition.x - _this.parentRect.left,
y: event.clientY - cursorToElementPosition.y - _this.parentRect.top
});
_this.onDrag(event);
});
/** @type {?} */
var dragStopSub = draggable.dragStop
.subscribe(function (event) {
_this.zone.run(function () {
_this.onStop(event);
_this.$element = null;
});
});
/** @type {?} */
var scrollSub = fromEvent(document, 'scroll')
.subscribe(function () {
if (_this.$element) {
_this.updateParentElementData();
}
});
this.subscribtions = this.subscribtions.concat([dragStartSub, dragSub, dragStopSub, scrollSub]);
};
/**
* @param {?} element
* @param {?} position
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.setElementPosition = /**
* @param {?} element
* @param {?} position
* @return {?}
*/
function (element, position) {
this.positionX = position.x;
this.positionY = position.y;
utils.setCssElementPosition(element, position);
};
/**
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.updateParentElementData = /**
* @return {?}
*/
function () {
this.parentRect = this.$element.parentElement.getBoundingClientRect();
this.parentOffset = {
left: this.$element.parentElement.offsetLeft,
top: this.$element.parentElement.offsetTop
};
};
/**
* @param {?} event
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.onStart = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.isDragging = true;
this.$element.style.pointerEvents = 'none';
this.$element.style.position = 'absolute';
this.gridsterPrototype.dragItemStart(this, event);
this.start.emit({ item: this.item });
};
/**
* @param {?} event
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.onDrag = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.gridsterPrototype.updatePrototypePosition(this, event);
};
/**
* @param {?} event
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.onStop = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.gridsterPrototype.dragItemStop(this, event);
this.isDragging = false;
this.$element.style.pointerEvents = 'auto';
this.$element.style.position = '';
utils.resetCSSElementPosition(this.$element);
if (this.config.helper) {
this.$element.parentNode.removeChild(this.$element);
}
};
/**
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.provideDragElement = /**
* @return {?}
*/
function () {
/** @type {?} */
var dragElement = this.elementRef.nativeElement;
if (this.config.helper) {
dragElement = (/** @type {?} */ ((dragElement).cloneNode(true)));
document.body.appendChild(this.fixStylesForBodyHelper(dragElement));
}
else {
this.fixStylesForRelativeElement(dragElement);
}
return dragElement;
};
/**
* @param {?} el
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.fixStylesForRelativeElement = /**
* @param {?} el
* @return {?}
*/
function (el) {
if (window.getComputedStyle(el).position === 'absolute') {
return el;
}
/** @type {?} */
var rect = this.elementRef.nativeElement.getBoundingClientRect();
this.containerRectange = el.parentElement.getBoundingClientRect();
el.style.position = 'absolute';
this.setElementPosition(el, {
x: rect.left - this.containerRectange.left,
y: rect.top - this.containerRectange.top
});
return el;
};
/**
* When element is cloned and append to body it should have position absolute and coords set by original
* relative prototype element position.
*/
/**
* When element is cloned and append to body it should have position absolute and coords set by original
* relative prototype element position.
* @param {?} el
* @return {?}
*/
GridsterItemPrototypeDirective.prototype.fixStylesForBodyHelper = /**
* When element is cloned and append to body it should have position absolute and coords set by original
* relative prototype element position.
* @param {?} el
* @return {?}
*/
function (el) {
/** @type {?} */
var bodyRect = document.body.getBoundingClientRect();
/** @type {?} */
var rect = this.elementRef.nativeElement.getBoundingClientRect();
el.style.position = 'absolute';
this.setElementPosition(el, {
x: rect.left - bodyRect.left,
y: rect.top - bodyRect.top
});
return el;
};
GridsterItemPrototypeDirective.decorators = [
{ type: Directive, args: [{
selector: '[ngxGridsterItemPrototype]'
},] }
];
/** @nocollapse */
GridsterItemPrototypeDirective.ctorParameters = function () { return [
{ type: NgZone },
{ type: ElementRef },
{ type: GridsterPrototypeService }
]; };
GridsterItemPrototypeDirective.propDecorators = {
drop: [{ type: Output }],
start: [{ type: Output }],
cancel: [{ type: Output }],
enter: [{ type: Output }],
out: [{ type: Output }],
data: [{ type: Input }],
config: [{ type: Input }],
w: [{ type: Input }],
wSm: [{ type: Input }],
wMd: [{ type: Input }],
wLg: [{ type: Input }],
wXl: [{ type: Input }],
h: [{ type: Input }],
hSm: [{ type: Input }],
hMd: [{ type: Input }],
hLg: [{ type: Input }],
hXl: [{ type: Input }]
};
return GridsterItemPrototypeDirective;
}());
export { GridsterItemPrototypeDirective };
if (false) {
/** @type {?} */
GridsterItemPrototypeDirective.prototype.drop;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.start;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.cancel;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.enter;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.out;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.data;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.config;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.x;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.y;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.w;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.wSm;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.wMd;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.wLg;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.wXl;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.h;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.hSm;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.hMd;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.hLg;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.hXl;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.positionX;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.positionY;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.autoSize;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.$element;
/**
* Mouse drag observable
* @type {?}
*/
GridsterItemPrototypeDirective.prototype.drag;
/**
* Subscribtion for drag observable
* @type {?}
*/
GridsterItemPrototypeDirective.prototype.dragSubscription;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.isDragging;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.item;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.containerRectange;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.dragContextGridster;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.parentRect;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.parentOffset;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.subscribtions;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.zone;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.elementRef;
/** @type {?} */
GridsterItemPrototypeDirective.prototype.gridsterPrototype;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gridster-item-prototype.directive.js","sourceRoot":"ng://@blare/angular2gridster/","sources":["lib/gridster-prototype/gridster-item-prototype.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, Output, HostBinding, EventEmitter, OnInit, OnDestroy,\n    NgZone} from '@angular/core';\nimport { Observable, Subscription, fromEvent } from 'rxjs';\n\nimport { GridsterPrototypeService } from './gridster-prototype.service';\nimport { GridListItem } from '../gridList/GridListItem';\nimport { GridsterService } from '../gridster.service';\nimport { DraggableEvent } from '../utils/DraggableEvent';\nimport { Draggable } from '../utils/draggable';\nimport { utils } from '../utils/utils';\n\n@Directive({\n    selector: '[ngxGridsterItemPrototype]'\n})\nexport class GridsterItemPrototypeDirective implements OnInit, OnDestroy {\n    @Output() drop = new EventEmitter();\n    @Output() start = new EventEmitter();\n    @Output() cancel = new EventEmitter();\n    @Output() enter = new EventEmitter();\n    @Output() out = new EventEmitter();\n\n    @Input() data: any;\n    @Input() config: any = {};\n\n    public x = 0;\n    public y = 0;\n    @Input() w: number;\n    @Input() wSm: number;\n    @Input() wMd: number;\n    @Input() wLg: number;\n    @Input() wXl: number;\n    @Input() h: number;\n    @Input() hSm: number;\n    @Input() hMd: number;\n    @Input() hLg: number;\n    @Input() hXl: number;\n\n    positionX: number;\n    positionY: number;\n\n    autoSize = false;\n\n    $element: HTMLElement;\n\n    /**\n     * Mouse drag observable\n     */\n    drag: Observable<any>;\n\n    /**\n     * Subscribtion for drag observable\n     */\n    dragSubscription: Subscription;\n\n    isDragging = false;\n\n    item: GridListItem;\n\n    containerRectange: ClientRect;\n\n    private dragContextGridster: GridsterService;\n    private parentRect: ClientRect;\n    private parentOffset: {left: number, top: number};\n\n    private subscribtions: Array<Subscription> = [];\n\n    // must be set to true because of item dragAndDrop configuration\n    get dragAndDrop(): boolean {\n        return true;\n    }\n\n    get gridster(): GridsterService {\n        return this.dragContextGridster;\n    }\n\n    constructor(private zone: NgZone,\n                private elementRef: ElementRef,\n                private gridsterPrototype: GridsterPrototypeService) {\n\n        this.item = (new GridListItem()).setFromGridsterItemPrototype(this);\n    }\n\n    ngOnInit() {\n        this.wSm = this.wSm || this.w;\n        this.hSm = this.hSm || this.h;\n        this.wMd = this.wMd || this.w;\n        this.hMd = this.hMd || this.h;\n        this.wLg = this.wLg || this.w;\n        this.hLg = this.hLg || this.h;\n        this.wXl = this.wXl || this.w;\n        this.hXl = this.hXl || this.h;\n        this.zone.runOutsideAngular(() => {\n            this.enableDragDrop();\n        });\n    }\n\n    ngOnDestroy() {\n        this.subscribtions.forEach((sub: Subscription) => {\n            sub.unsubscribe();\n        });\n    }\n\n    onDrop (gridster: GridsterService): void {\n        if (!this.config.helper) {\n            this.$element.parentNode.removeChild(this.$element);\n        }\n\n        this.drop.emit({\n            item: this.item,\n            gridster: gridster\n        });\n    }\n\n    onCancel (): void {\n        this.cancel.emit({item: this.item});\n    }\n\n    onEnter (gridster: GridsterService): void {\n        this.enter.emit({\n            item: this.item,\n            gridster: gridster\n        });\n    }\n\n    onOver (gridster: GridsterService): void {}\n\n    onOut (gridster: GridsterService): void {\n        this.out.emit({\n            item: this.item,\n            gridster: gridster\n        });\n    }\n\n    getPositionToGridster(gridster: GridsterService) {\n        const relativeContainerCoords = this.getContainerCoordsToGridster(gridster);\n\n        return {\n            y: this.positionY - relativeContainerCoords.top,\n            x: this.positionX - relativeContainerCoords.left\n        };\n    }\n\n    setDragContextGridster(gridster: GridsterService) {\n        this.dragContextGridster = gridster;\n    }\n\n    private getContainerCoordsToGridster(gridster: GridsterService): {top: number, left: number} {\n        return {\n            left: gridster.gridsterRect.left - this.parentRect.left,\n            top: gridster.gridsterRect.top - this.parentRect.top\n        };\n    }\n\n    private enableDragDrop() {\n        let cursorToElementPosition;\n        const draggable = new Draggable(this.elementRef.nativeElement);\n\n        const dragStartSub = draggable.dragStart\n            .subscribe((event: DraggableEvent) => {\n                this.zone.run(() => {\n                    this.$element = this.provideDragElement();\n                    this.containerRectange = this.$element.parentElement.getBoundingClientRect();\n                    this.updateParentElementData();\n                    this.onStart(event);\n\n                    cursorToElementPosition = event.getRelativeCoordinates(this.$element);\n                });\n            });\n\n        const dragSub = draggable.dragMove\n            .subscribe((event: DraggableEvent) => {\n\n                this.setElementPosition(this.$element, {\n                    x: event.clientX - cursorToElementPosition.x  - this.parentRect.left,\n                    y: event.clientY - cursorToElementPosition.y  - this.parentRect.top\n                });\n\n                this.onDrag(event);\n            });\n\n        const dragStopSub = draggable.dragStop\n            .subscribe((event: DraggableEvent) => {\n                this.zone.run(() => {\n                    this.onStop(event);\n                    this.$element = null;\n                });\n            });\n\n        const scrollSub = fromEvent(document, 'scroll')\n            .subscribe(() => {\n                if (this.$element) {\n                    this.updateParentElementData();\n                }\n            });\n\n        this.subscribtions = this.subscribtions.concat([dragStartSub, dragSub, dragStopSub, scrollSub]);\n    }\n\n    private setElementPosition(element: HTMLElement, position: {x: number, y: number}) {\n        this.positionX = position.x;\n        this.positionY = position.y;\n        utils.setCssElementPosition(element, position);\n    }\n\n    private updateParentElementData() {\n        this.parentRect = this.$element.parentElement.getBoundingClientRect();\n        this.parentOffset = {\n            left: this.$element.parentElement.offsetLeft,\n            top: this.$element.parentElement.offsetTop\n        };\n    }\n\n    private onStart (event: DraggableEvent): void {\n        this.isDragging = true;\n\n        this.$element.style.pointerEvents = 'none';\n        this.$element.style.position = 'absolute';\n\n        this.gridsterPrototype.dragItemStart(this, event);\n\n        this.start.emit({item: this.item});\n    }\n\n    private onDrag (event: DraggableEvent): void {\n        this.gridsterPrototype.updatePrototypePosition(this, event);\n    }\n\n    private onStop (event: DraggableEvent): void {\n        this.gridsterPrototype.dragItemStop(this, event);\n\n        this.isDragging = false;\n        this.$element.style.pointerEvents = 'auto';\n        this.$element.style.position = '';\n        utils.resetCSSElementPosition(this.$element);\n\n        if (this.config.helper) {\n            this.$element.parentNode.removeChild(this.$element);\n        }\n    }\n\n    private provideDragElement (): HTMLElement {\n        let dragElement = this.elementRef.nativeElement;\n\n        if (this.config.helper) {\n            dragElement = <any>(dragElement).cloneNode(true);\n\n            document.body.appendChild(this.fixStylesForBodyHelper(dragElement));\n        } else {\n            this.fixStylesForRelativeElement(dragElement);\n        }\n\n        return dragElement;\n    }\n\n    private fixStylesForRelativeElement(el: HTMLElement) {\n        if (window.getComputedStyle(el).position === 'absolute') {\n            return el;\n        }\n        const rect = this.elementRef.nativeElement.getBoundingClientRect();\n        this.containerRectange = el.parentElement.getBoundingClientRect();\n\n        el.style.position = 'absolute';\n        this.setElementPosition(el, {\n            x: rect.left - this.containerRectange.left,\n            y: rect.top - this.containerRectange.top\n        });\n\n        return el;\n    }\n\n    /**\n     * When element is cloned and append to body it should have position absolute and coords set by original\n     * relative prototype element position.\n     */\n    private fixStylesForBodyHelper (el: HTMLElement) {\n        const bodyRect = document.body.getBoundingClientRect();\n        const rect = this.elementRef.nativeElement.getBoundingClientRect();\n\n        el.style.position = 'absolute';\n        this.setElementPosition(el, {\n            x: rect.left - bodyRect.left,\n            y: rect.top - bodyRect.top\n        });\n\n        return el;\n    }\n\n}\n"]}