UNPKG

@rybos/angular2gridster

Version:

[![npm version](https://badge.fury.io/js/angular2gridster.svg)](https://badge.fury.io/js/angular2gridster)

137 lines 25 kB
import { Injectable } from '@angular/core'; import { Subject, merge } from 'rxjs'; import { takeUntil, switchMap, map, scan, filter, share, tap } from 'rxjs/operators'; import { utils } from '../utils/utils'; import * as i0 from "@angular/core"; export class GridsterPrototypeService { constructor() { this.isDragging = false; this.dragSubject = new Subject(); this.dragStartSubject = new Subject(); this.dragStopSubject = new Subject(); } observeDropOver(gridster) { return this.dragStopSubject.pipe(filter((data) => { const gridsterEl = gridster.gridsterComponent.$element; const isOverNestedGridster = [].slice.call(gridsterEl.querySelectorAll('gridster')) .reduce((isOverGridster, nestedGridsterEl) => { return isOverGridster || this.isOverGridster(data.item, nestedGridsterEl, data.event, gridster.options); }, false); if (isOverNestedGridster) { return false; } return this.isOverGridster(data.item, gridsterEl, data.event, gridster.options); }), tap((data) => { // TODO: what we should provide as a param? // prototype.drop.emit({item: prototype.item}); data.item.onDrop(gridster); })); } observeDropOut(gridster) { return this.dragStopSubject.pipe(filter((data) => { const gridsterEl = gridster.gridsterComponent.$element; return !this.isOverGridster(data.item, gridsterEl, data.event, gridster.options); }), tap((data) => { // TODO: what we should provide as a param? data.item.onCancel(); })); } observeDragOver(gridster) { const over = this.dragSubject.pipe(map((data) => { const gridsterEl = gridster.gridsterComponent.$element; return { item: data.item, event: data.event, isOver: this.isOverGridster(data.item, gridsterEl, data.event, gridster.options), isDrop: false }; })); const drop = this.dragStopSubject.pipe(map((data) => { const gridsterEl = gridster.gridsterComponent.$element; return { item: data.item, event: data.event, isOver: this.isOverGridster(data.item, gridsterEl, data.event, gridster.options), isDrop: true }; })); const dragExt = merge( // dragStartSubject is connected in case when item prototype is placed above gridster // and drag enter is not fired this.dragStartSubject.pipe(map(() => ({ item: null, isOver: false, isDrop: false }))), over, drop).pipe(scan((prev, next) => { return { item: next.item, event: next.event, isOver: next.isOver, isEnter: prev.isOver === false && next.isOver === true, isOut: prev.isOver === true && next.isOver === false && !prev.isDrop, isDrop: next.isDrop }; }), filter((data) => { return !data.isDrop; }), share()); const dragEnter = this.createDragEnterObservable(dragExt, gridster); const dragOut = this.createDragOutObservable(dragExt, gridster); const dragOver = dragEnter .pipe(switchMap(() => this.dragSubject.pipe(takeUntil(dragOut))), map((data) => data.item)); return { dragEnter, dragOut, dragOver }; } dragItemStart(item, event) { this.isDragging = true; this.dragStartSubject.next({ item, event }); } dragItemStop(item, event) { this.isDragging = false; this.dragStopSubject.next({ item, event }); } updatePrototypePosition(item, event) { this.dragSubject.next({ item, event }); } /** * Creates observable that is fired on dragging over gridster container. */ createDragOverObservable(dragIsOver, gridster) { return dragIsOver.pipe(filter((data) => data.isOver && !data.isEnter && !data.isOut), map((data) => data.item), tap((item) => item.onOver(gridster))); } /** * Creates observable that is fired on drag enter gridster container. */ createDragEnterObservable(dragIsOver, gridster) { return dragIsOver.pipe(filter((data) => data.isEnter), map((data) => data.item), tap((item) => item.onEnter(gridster))); } /** * Creates observable that is fired on drag out gridster container. */ createDragOutObservable(dragIsOver, gridster) { return dragIsOver.pipe(filter((data) => data.isOut), map((data) => data.item), tap((item) => item.onOut(gridster))); } /** * Checks whether "element" position fits inside "containerEl" position. * It checks if "element" is totally covered by "containerEl" area. */ isOverGridster(item, gridsterEl, event, options) { const el = item.$element; const parentItem = gridsterEl.parentElement && gridsterEl.parentElement.closest('gridster-item'); if (parentItem) { return this.isOverGridster(item, parentItem, event, options); } switch (options.tolerance) { case 'fit': return utils.isElementFitContainer(el, gridsterEl); case 'intersect': return utils.isElementIntersectContainer(el, gridsterEl); case 'touch': return utils.isElementTouchContainer(el, gridsterEl); default: return utils.isCursorAboveElement(event, gridsterEl); } } } GridsterPrototypeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: GridsterPrototypeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); GridsterPrototypeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: GridsterPrototypeService }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: GridsterPrototypeService, decorators: [{ type: Injectable }], ctorParameters: function () { return []; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gridster-prototype.service.js","sourceRoot":"","sources":["../../../../../projects/angular2gridster/src/lib/gridster-prototype/gridster-prototype.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { Observable, Subject, merge } from 'rxjs';\r\nimport { takeUntil, switchMap, map, scan, filter, share, tap } from 'rxjs/operators';\r\n\r\nimport { GridsterService } from '../gridster.service';\r\nimport { GridsterItemPrototypeDirective } from './gridster-item-prototype.directive';\r\nimport { utils } from '../utils/utils';\r\nimport { DraggableEvent } from '../utils/DraggableEvent';\r\n\r\n@Injectable()\r\nexport class GridsterPrototypeService {\r\n\r\n    private isDragging = false;\r\n\r\n    private dragSubject = new Subject<any>();\r\n\r\n    private dragStartSubject = new Subject<any>();\r\n\r\n    private dragStopSubject = new Subject<any>();\r\n\r\n    constructor() {}\r\n\r\n    observeDropOver (gridster: GridsterService) {\r\n        return this.dragStopSubject.pipe(\r\n            filter((data) => {\r\n                const gridsterEl = gridster.gridsterComponent.$element;\r\n                const isOverNestedGridster = [].slice.call(gridsterEl.querySelectorAll('gridster'))\r\n                    .reduce((isOverGridster, nestedGridsterEl) => {\r\n                        return isOverGridster ||\r\n                            this.isOverGridster(data.item, nestedGridsterEl, data.event, gridster.options);\r\n                    }, false);\r\n\r\n                if (isOverNestedGridster) {\r\n                    return false;\r\n                }\r\n\r\n                return this.isOverGridster(data.item, gridsterEl, data.event, gridster.options);\r\n            }),\r\n            tap((data) => {\r\n                // TODO: what we should provide as a param?\r\n                // prototype.drop.emit({item: prototype.item});\r\n                data.item.onDrop(gridster);\r\n            })\r\n        );\r\n    }\r\n\r\n    observeDropOut (gridster: GridsterService) {\r\n        return this.dragStopSubject.pipe(\r\n            filter((data) => {\r\n                const gridsterEl = gridster.gridsterComponent.$element;\r\n\r\n                return !this.isOverGridster(data.item, gridsterEl, data.event, gridster.options);\r\n            }),\r\n            tap((data) => {\r\n                // TODO: what we should provide as a param?\r\n                data.item.onCancel();\r\n            })\r\n        );\r\n    }\r\n\r\n    observeDragOver(gridster: GridsterService): {\r\n        dragOver: Observable<GridsterItemPrototypeDirective>,\r\n        dragEnter: Observable<GridsterItemPrototypeDirective>,\r\n        dragOut: Observable<GridsterItemPrototypeDirective>\r\n    } {\r\n        const over = this.dragSubject.pipe(\r\n            map((data) => {\r\n                const gridsterEl = gridster.gridsterComponent.$element;\r\n\r\n                return {\r\n                  item: data.item,\r\n                  event: data.event,\r\n                  isOver: this.isOverGridster(data.item, gridsterEl, data.event, gridster.options),\r\n                  isDrop: false\r\n                };\r\n            })\r\n        );\r\n\r\n        const drop = this.dragStopSubject.pipe(\r\n            map((data) => {\r\n                const gridsterEl = gridster.gridsterComponent.$element;\r\n\r\n                return {\r\n                    item: data.item,\r\n                    event: data.event,\r\n                    isOver: this.isOverGridster(data.item, gridsterEl, data.event, gridster.options),\r\n                    isDrop: true\r\n                };\r\n            })\r\n        );\r\n\r\n        const dragExt = merge(\r\n                // dragStartSubject is connected in case when item prototype is placed above gridster\r\n                // and drag enter is not fired\r\n                this.dragStartSubject.pipe(map(() => ({ item: null, isOver: false, isDrop: false }))),\r\n                over,\r\n                drop\r\n            ).pipe(\r\n                scan((prev: any, next: any) => {\r\n                    return {\r\n                        item: next.item,\r\n                        event: next.event,\r\n                        isOver: next.isOver,\r\n                        isEnter: prev.isOver === false && next.isOver === true,\r\n                        isOut: prev.isOver === true && next.isOver === false && !prev.isDrop,\r\n                        isDrop: next.isDrop\r\n                    };\r\n                }),\r\n                filter((data: any) => {\r\n                    return !data.isDrop;\r\n                }),\r\n                share()\r\n            );\r\n\r\n        const dragEnter = this.createDragEnterObservable(dragExt, gridster);\r\n        const dragOut = this.createDragOutObservable(dragExt, gridster);\r\n        const dragOver = dragEnter\r\n            .pipe(\r\n                switchMap(() => this.dragSubject.pipe(takeUntil(dragOut))),\r\n                map((data: any) => data.item)\r\n            );\r\n\r\n        return { dragEnter, dragOut, dragOver };\r\n    }\r\n\r\n    dragItemStart(item: GridsterItemPrototypeDirective, event: DraggableEvent) {\r\n        this.isDragging = true;\r\n        this.dragStartSubject.next({ item, event });\r\n    }\r\n\r\n    dragItemStop(item: GridsterItemPrototypeDirective, event: DraggableEvent) {\r\n        this.isDragging = false;\r\n        this.dragStopSubject.next({ item, event });\r\n    }\r\n\r\n    updatePrototypePosition(item: GridsterItemPrototypeDirective, event: DraggableEvent) {\r\n        this.dragSubject.next({ item, event });\r\n    }\r\n\r\n    /**\r\n     * Creates observable that is fired on dragging over gridster container.\r\n     */\r\n    private createDragOverObservable (\r\n        dragIsOver: Observable<{item: GridsterItemPrototypeDirective, isOver: boolean}>,\r\n        gridster: GridsterService\r\n    ) {\r\n        return dragIsOver.pipe(\r\n            filter((data: any) => data.isOver && !data.isEnter && !data.isOut),\r\n            map((data: any): GridsterItemPrototypeDirective => data.item),\r\n            tap((item) => item.onOver(gridster))\r\n        );\r\n    }\r\n    /**\r\n     * Creates observable that is fired on drag enter gridster container.\r\n     */\r\n    private createDragEnterObservable (\r\n        dragIsOver: Observable<{item: GridsterItemPrototypeDirective, isOver: boolean}>,\r\n        gridster: GridsterService\r\n    ) {\r\n        return dragIsOver.pipe(\r\n            filter((data: any) => data.isEnter),\r\n            map((data: any): GridsterItemPrototypeDirective => data.item),\r\n            tap((item) => item.onEnter(gridster))\r\n        );\r\n    }\r\n    /**\r\n     * Creates observable that is fired on drag out gridster container.\r\n     */\r\n    private createDragOutObservable (\r\n        dragIsOver: Observable<{item: GridsterItemPrototypeDirective,\r\n        isOver: boolean}>,\r\n        gridster: GridsterService\r\n    ) {\r\n        return dragIsOver.pipe(\r\n            filter((data: any) => data.isOut),\r\n            map((data: any): GridsterItemPrototypeDirective => data.item),\r\n            tap((item) => item.onOut(gridster))\r\n        );\r\n    }\r\n\r\n    /**\r\n     * Checks whether \"element\" position fits inside \"containerEl\" position.\r\n     * It checks if \"element\" is totally covered by \"containerEl\" area.\r\n     */\r\n    private isOverGridster(item: GridsterItemPrototypeDirective, gridsterEl: HTMLElement, event, options): boolean {\r\n        const el = item.$element;\r\n        const parentItem = <HTMLElement>gridsterEl.parentElement &&\r\n            <HTMLElement>gridsterEl.parentElement.closest('gridster-item');\r\n\r\n        if (parentItem) {\r\n            return this.isOverGridster(item, parentItem, event, options);\r\n        }\r\n\r\n        switch (options.tolerance) {\r\n            case 'fit':\r\n                return utils.isElementFitContainer(el, gridsterEl);\r\n            case 'intersect':\r\n                return utils.isElementIntersectContainer(el, gridsterEl);\r\n            case 'touch':\r\n                return utils.isElementTouchContainer(el, gridsterEl);\r\n            default:\r\n                return utils.isCursorAboveElement(event, gridsterEl);\r\n        }\r\n    }\r\n}\r\n"]}