@alauda-fe/common
Version:
Alauda frontend team common codes.
229 lines • 38.6 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { DOCUMENT } from '@angular/common';
import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, ElementRef, EventEmitter, Inject, Input, NgZone, Output, QueryList, Renderer2, ViewChild, } from '@angular/core';
import { NEVER, Observable, startWith, switchMap, merge, iif, exhaustMap, take, map, Subject, takeUntil, filter, distinctUntilChanged, } from 'rxjs';
import { isEqual, ObservableInput } from '../../../core/public-api';
import { GRID_DRAG_HANDLER, } from '../../directives/drag-handler.directive';
import { GridItemPlaceholderDirective, GRID_ITEM_PLACEHOLDER, } from '../../directives/placeholder.directive';
import { GRID_REMOVE_HANDLER, } from '../../directives/remove-handler.directive';
import { GRID_RESIZE_HANDLER, } from '../../directives/resize-handler.directive';
import { GridLayoutService } from '../../grid-layout.service';
import { parseRenderItemToPixels } from '../../utils/grid.utils';
import { accessPointerMoveThreshold, getMouseClick$, getMouseDown$, getMouseEnd$, getMouseMove$, } from '../../utils/mouse.utils';
import { runOutsideZone$ } from '../../utils/operator';
import * as i0 from "@angular/core";
import * as i1 from "../../grid-layout.service";
import * as i2 from "@alauda/ui";
const _c0 = ["resizeElem"];
const _c1 = ["removeElem"];
const _c2 = ["*"];
const ANIMATION_DURATION_MS = 250;
export class GridItemComponent {
constructor(elementRef, document, renderer, ngZone, layoutService) {
this.elementRef = elementRef;
this.document = document;
this.renderer = renderer;
this.ngZone = ngZone;
this.layoutService = layoutService;
/** CSS transition style */
this.transition = `transform ${ANIMATION_DURATION_MS}ms ease, width ${ANIMATION_DURATION_MS}ms ease, height ${ANIMATION_DURATION_MS}ms ease`;
/** Minimum amount of pixels that the user should move before it starts the drag sequence. */
this.dragStartThreshold = 0;
/** Whether the item is draggable or not. Defaults to true. */
this.draggable = true;
/** Whether the item is resizable or not. Defaults to true. */
this.resizable = true;
this.removable = true;
this.destroy$$ = new Subject();
this.dragStartSubject = new Subject();
this.resizeStartSubject = new Subject();
this.dragStart$ = this.dragStartSubject.asObservable();
this.resizeStart$ = this.resizeStartSubject.asObservable();
this.remove = new EventEmitter();
}
ngOnInit() {
this.layoutService.gridRenderItemsData$$
.pipe(map(({ data, animation }) => ({ data: data?.[this.id], animation })), distinctUntilChanged((a, b) => isEqual(a.data, b.data)), takeUntil(this.destroy$$))
.subscribe(({ data, animation }) => {
this.setStyles(parseRenderItemToPixels(data), animation);
});
}
ngAfterContentInit() {
this.setupDragStartListener();
this.setupResizeStartListener();
this.setupRemoveListener();
}
ngOnDestroy() {
this.destroy$$.next();
this.destroy$$.complete();
}
setStyles({ top, left, width, height, }, animation) {
this.renderer.setStyle(this.elementRef.nativeElement, 'transform', `translateX(${left}) translateY(${top})`);
this.renderer.setStyle(this.elementRef.nativeElement, 'transition', animation ? this.transition : 'none');
requestAnimationFrame(() => {
this.renderer.setStyle(this.elementRef.nativeElement, 'display', `block`);
if (width != null) {
this.renderer.setStyle(this.elementRef.nativeElement, 'width', width);
}
if (height != null) {
this.renderer.setStyle(this.elementRef.nativeElement, 'height', height);
}
});
}
setupDragStartListener() {
const document = this.document.documentElement;
this.draggable$
.pipe(takeUntil(this.destroy$$), startWith(this.draggable), switchMap(draggable => {
if (!draggable) {
return NEVER;
}
return this.dragHandles.changes.pipe(startWith(this.dragHandles), switchMap((dragHandles) => iif(() => dragHandles.length > 0, merge(...dragHandles
.toArray()
.map(dragHandle => getMouseDown$(dragHandle.element.nativeElement))), getMouseDown$(this.elementRef.nativeElement)).pipe(exhaustMap(startEvent => {
// Prevent browser default drag/drop action, we handle all scenes
if (startEvent.target &&
startEvent.target.draggable &&
startEvent.type === 'mousedown') {
startEvent.preventDefault();
startEvent.stopImmediatePropagation();
}
return getMouseMove$(this.document.documentElement).pipe(takeUntil(getMouseEnd$(document)), runOutsideZone$(this.ngZone), filter(moveEvent => {
moveEvent.preventDefault();
return accessPointerMoveThreshold(startEvent, moveEvent, this.dragStartThreshold);
}), take(1), map(() => startEvent));
}))));
}))
.subscribe(this.dragStartSubject);
}
setupRemoveListener() {
this.removable$
.pipe(takeUntil(this.destroy$$), startWith(this.removable), switchMap(removable => {
if (!removable) {
this.renderer.setStyle(this.removeElem.nativeElement, 'display', 'none');
return NEVER;
}
return this.removeHandles.changes.pipe(startWith(this.removeHandles), switchMap((removeHandles) => {
if (removeHandles.length > 0) {
this.renderer.setStyle(this.removeElem.nativeElement, 'display', 'none');
return merge(...removeHandles
.toArray()
.map(removeHandle => getMouseClick$(removeHandle.element.nativeElement)));
}
this.renderer.setStyle(this.removeElem.nativeElement, 'display', 'block');
return getMouseDown$(this.removeElem.nativeElement);
}));
}))
.subscribe(evt => {
evt.preventDefault();
this.remove.emit(this.id);
});
}
setupResizeStartListener() {
this.resizable$
.pipe(takeUntil(this.destroy$$), startWith(this.resizable), switchMap(resizable => {
if (!resizable) {
this.renderer.setStyle(this.resizeElem.nativeElement, 'display', 'none');
return NEVER;
}
return this.resizeHandles.changes.pipe(startWith(this.resizeHandles), switchMap((resizeHandles) => {
if (resizeHandles.length > 0) {
this.renderer.setStyle(this.resizeElem.nativeElement, 'display', 'none');
return merge(...resizeHandles
.toArray()
.map(resizeHandle => getMouseDown$(resizeHandle.element.nativeElement)));
}
this.renderer.setStyle(this.resizeElem.nativeElement, 'display', 'block');
return getMouseDown$(this.resizeElem.nativeElement);
}));
}))
.subscribe(this.resizeStartSubject);
}
static { this.ɵfac = function GridItemComponent_Factory(t) { return new (t || GridItemComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(DOCUMENT), i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.NgZone), i0.ɵɵdirectiveInject(i1.GridLayoutService)); }; }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: GridItemComponent, selectors: [["acl-grid-item"]], contentQueries: function GridItemComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
i0.ɵɵcontentQuery(dirIndex, GRID_ITEM_PLACEHOLDER, 5);
i0.ɵɵcontentQuery(dirIndex, GRID_DRAG_HANDLER, 5);
i0.ɵɵcontentQuery(dirIndex, GRID_RESIZE_HANDLER, 5);
i0.ɵɵcontentQuery(dirIndex, GRID_REMOVE_HANDLER, 5);
} if (rf & 2) {
let _t;
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.placeholder = _t.first);
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.dragHandles = _t);
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.resizeHandles = _t);
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.removeHandles = _t);
} }, viewQuery: function GridItemComponent_Query(rf, ctx) { if (rf & 1) {
i0.ɵɵviewQuery(_c0, 7, ElementRef);
i0.ɵɵviewQuery(_c1, 7, ElementRef);
} if (rf & 2) {
let _t;
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.resizeElem = _t.first);
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.removeElem = _t.first);
} }, inputs: { id: "id", minW: "minW", minH: "minH", maxW: "maxW", maxH: "maxH", transition: "transition", dragStartThreshold: "dragStartThreshold", draggable: "draggable", resizable: "resizable", removable: "removable" }, outputs: { remove: "remove" }, ngContentSelectors: _c2, decls: 6, vars: 0, consts: [["resizeElem", ""], ["removeElem", ""], [1, "grid-item-default-resize-icon"], [1, "grid-item-default-remove"], ["icon", "xmark"]], template: function GridItemComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵprojectionDef();
i0.ɵɵprojection(0);
i0.ɵɵelement(1, "div", 2, 0);
i0.ɵɵelementStart(3, "div", 3, 1);
i0.ɵɵelement(5, "aui-icon", 4);
i0.ɵɵelementEnd();
} }, dependencies: [i2.IconComponent], styles: ["[_nghost-%COMP%]{display:none;position:absolute;z-index:1;overflow:hidden}[_nghost-%COMP%] div[_ngcontent-%COMP%]{position:absolute;user-select:none;z-index:10}[_nghost-%COMP%] div.grid-item-default-remove[_ngcontent-%COMP%]{position:absolute;top:12px;right:12px}[_nghost-%COMP%] div.grid-item-default-remove[_ngcontent-%COMP%] aui-icon[_ngcontent-%COMP%]{font-size:16px}[_nghost-%COMP%] div.grid-item-default-remove[_ngcontent-%COMP%] aui-icon[_ngcontent-%COMP%]:hover{cursor:pointer}[_nghost-%COMP%] div.grid-item-default-resize-icon[_ngcontent-%COMP%]{cursor:se-resize;width:20px;height:20px;bottom:0;right:0;color:inherit}[_nghost-%COMP%] div.grid-item-default-resize-icon[_ngcontent-%COMP%]:after{content:\"\";position:absolute;right:8px;bottom:8px;width:12px;height:12px;border-right:2px solid rgb(var(--aui-color-n-4));border-bottom:2px solid rgb(var(--aui-color-n-4))}.display-none[_ngcontent-%COMP%]{display:none!important}"], changeDetection: 0 }); }
}
__decorate([
ObservableInput(),
__metadata("design:type", Observable)
], GridItemComponent.prototype, "draggable$", void 0);
__decorate([
ObservableInput(),
__metadata("design:type", Observable)
], GridItemComponent.prototype, "resizable$", void 0);
__decorate([
ObservableInput(),
__metadata("design:type", Observable)
], GridItemComponent.prototype, "removable$", void 0);
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(GridItemComponent, [{
type: Component,
args: [{ selector: 'acl-grid-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>\n<div\n #resizeElem\n class=\"grid-item-default-resize-icon\"\n></div>\n<div\n #removeElem\n class=\"grid-item-default-remove\"\n>\n <aui-icon icon=\"xmark\"></aui-icon>\n</div>\n", styles: [":host{display:none;position:absolute;z-index:1;overflow:hidden}:host div{position:absolute;user-select:none;z-index:10}:host div.grid-item-default-remove{position:absolute;top:12px;right:12px}:host div.grid-item-default-remove aui-icon{font-size:16px}:host div.grid-item-default-remove aui-icon:hover{cursor:pointer}:host div.grid-item-default-resize-icon{cursor:se-resize;width:20px;height:20px;bottom:0;right:0;color:inherit}:host div.grid-item-default-resize-icon:after{content:\"\";position:absolute;right:8px;bottom:8px;width:12px;height:12px;border-right:2px solid rgb(var(--aui-color-n-4));border-bottom:2px solid rgb(var(--aui-color-n-4))}.display-none{display:none!important}\n"] }]
}], () => [{ type: i0.ElementRef }, { type: Document, decorators: [{
type: Inject,
args: [DOCUMENT]
}] }, { type: i0.Renderer2 }, { type: i0.NgZone }, { type: i1.GridLayoutService }], { id: [{
type: Input
}], dragHandles: [{
type: ContentChildren,
args: [GRID_DRAG_HANDLER, { descendants: true }]
}], resizeHandles: [{
type: ContentChildren,
args: [GRID_RESIZE_HANDLER, { descendants: true }]
}], removeHandles: [{
type: ContentChildren,
args: [GRID_REMOVE_HANDLER, { descendants: true }]
}], resizeElem: [{
type: ViewChild,
args: ['resizeElem', { static: true, read: ElementRef }]
}], removeElem: [{
type: ViewChild,
args: ['removeElem', { static: true, read: ElementRef }]
}], placeholder: [{
type: ContentChild,
args: [GRID_ITEM_PLACEHOLDER]
}], minW: [{
type: Input
}], minH: [{
type: Input
}], maxW: [{
type: Input
}], maxH: [{
type: Input
}], transition: [{
type: Input
}], dragStartThreshold: [{
type: Input
}], draggable: [{
type: Input
}], draggable$: [], resizable: [{
type: Input
}], resizable$: [], removable: [{
type: Input
}], removable$: [], remove: [{
type: Output
}] }); })();
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(GridItemComponent, { className: "GridItemComponent" }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/grid-layout/components/grid-items/component.ts","../../../../../../../libs/common/src/grid-layout/components/grid-items/template.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,eAAe,EACf,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EACL,MAAM,EAGN,MAAM,EACN,SAAS,EACT,SAAS,EACT,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,KAAK,EACL,UAAU,EACV,SAAS,EACT,SAAS,EACT,KAAK,EACL,GAAG,EACH,UAAU,EACV,IAAI,EACJ,GAAG,EACH,OAAO,EACP,SAAS,EACT,MAAM,EACN,oBAAoB,GACrB,MAAM,MAAM,CAAC;AAEd,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AACpE,OAAO,EAEL,iBAAiB,GAClB,MAAM,yCAAyC,CAAC;AACjD,OAAO,EACL,4BAA4B,EAC5B,qBAAqB,GACtB,MAAM,wCAAwC,CAAC;AAChD,OAAO,EAEL,mBAAmB,GACpB,MAAM,2CAA2C,CAAC;AACnD,OAAO,EAEL,mBAAmB,GACpB,MAAM,2CAA2C,CAAC;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EACL,0BAA0B,EAC1B,cAAc,EACd,aAAa,EACb,YAAY,EACZ,aAAa,GACd,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;;;;;;;AAEvD,MAAM,qBAAqB,GAAG,GAAG,CAAC;AAQlC,MAAM,OAAO,iBAAiB;IAgE5B,YACS,UAAsB,EACM,QAAkB,EACpC,QAAmB,EACnB,MAAc,EACd,aAAgC;QAJ1C,eAAU,GAAV,UAAU,CAAY;QACM,aAAQ,GAAR,QAAQ,CAAU;QACpC,aAAQ,GAAR,QAAQ,CAAW;QACnB,WAAM,GAAN,MAAM,CAAQ;QACd,kBAAa,GAAb,aAAa,CAAmB;QA1CnD,2BAA2B;QAE3B,eAAU,GACR,aAAa,qBAAqB,kBAAkB,qBAAqB,mBAAmB,qBAAqB,SAAS,CAAC;QAE7H,6FAA6F;QAE7F,uBAAkB,GAAG,CAAC,CAAC;QAEvB,8DAA8D;QAE9D,cAAS,GAAG,IAAI,CAAC;QAKjB,8DAA8D;QAE9D,cAAS,GAAG,IAAI,CAAC;QAMjB,cAAS,GAAG,IAAI,CAAC;QAKjB,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEf,qBAAgB,GAAG,IAAI,OAAO,EAAc,CAAC;QAC7C,uBAAkB,GAAG,IAAI,OAAO,EAAc,CAAC;QAEhE,eAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC;QAClD,iBAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QAWtD,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;IAHzB,CAAC;IAKJ,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,qBAAqB;aACrC,IAAI,CACH,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC,EACpE,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,EACvD,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,CAAC,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,EAAE,EAAE;YACjC,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,CAAC;QAC3D,CAAC,CAAC,CAAC;IACP,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED,SAAS,CACP,EACE,GAAG,EACH,IAAI,EACJ,KAAK,EACL,MAAM,GAMP,EACD,SAAkB;QAElB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,WAAW,EACX,cAAc,IAAI,gBAAgB,GAAG,GAAG,CACzC,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,YAAY,EACZ,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CACrC,CAAC;QACF,qBAAqB,CAAC,GAAG,EAAE;YACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;YAC1E,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;gBAClB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;YACxE,CAAC;YACD,IAAI,MAAM,IAAI,IAAI,EAAE,CAAC;gBACnB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;YAC1E,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,sBAAsB;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC;QAC/C,IAAI,CAAC,UAAU;aACZ,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,SAAS,CAAC,SAAS,CAAC,EAAE;YACpB,IAAI,CAAC,SAAS,EAAE,CAAC;gBACf,OAAO,KAAK,CAAC;YACf,CAAC;YACD,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAClC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,EAC3B,SAAS,CAAC,CAAC,WAAgD,EAAE,EAAE,CAC7D,GAAG,CACD,GAAG,EAAE,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAC5B,KAAK,CACH,GAAG,WAAW;iBACX,OAAO,EAAE;iBACT,GAAG,CAAC,UAAU,CAAC,EAAE,CAChB,aAAa,CAAC,UAAU,CAAC,OAAO,CAAC,aAAa,CAAC,CAChD,CACJ,EACD,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAC7C,CAAC,IAAI,CACJ,UAAU,CAAC,UAAU,CAAC,EAAE;gBACtB,iEAAiE;gBACjE,IACE,UAAU,CAAC,MAAM;oBAChB,UAAU,CAAC,MAAsB,CAAC,SAAS;oBAC5C,UAAU,CAAC,IAAI,KAAK,WAAW,EAC/B,CAAC;oBACD,UAAU,CAAC,cAAc,EAAE,CAAC;oBAC5B,UAAU,CAAC,wBAAwB,EAAE,CAAC;gBACxC,CAAC;gBAED,OAAO,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,IAAI,CACtD,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,EACjC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,EAC5B,MAAM,CAAC,SAAS,CAAC,EAAE;oBACjB,SAAS,CAAC,cAAc,EAAE,CAAC;oBAC3B,OAAO,0BAA0B,CAC/B,UAAU,EACV,SAAS,EACT,IAAI,CAAC,kBAAkB,CACxB,CAAC;gBACJ,CAAC,CAAC,EACF,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,CACtB,CAAC;YACJ,CAAC,CAAC,CACH,CACF,CACF,CAAC;QACJ,CAAC,CAAC,CACH;aACA,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IACtC,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,UAAU;aACZ,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,SAAS,CAAC,SAAS,CAAC,EAAE;YACpB,IAAI,CAAC,SAAS,EAAE,CAAC;gBACf,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,SAAS,EACT,MAAM,CACP,CAAC;gBACF,OAAO,KAAK,CAAC;YACf,CAAC;YACD,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CACpC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,EAC7B,SAAS,CACP,CAAC,aAAoD,EAAE,EAAE;gBACvD,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC7B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,SAAS,EACT,MAAM,CACP,CAAC;oBAEF,OAAO,KAAK,CACV,GAAG,aAAa;yBACb,OAAO,EAAE;yBACT,GAAG,CAAC,YAAY,CAAC,EAAE,CAClB,cAAc,CAAC,YAAY,CAAC,OAAO,CAAC,aAAa,CAAC,CACnD,CACJ,CAAC;gBACJ,CAAC;gBACD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,SAAS,EACT,OAAO,CACR,CAAC;gBACF,OAAO,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;YACtD,CAAC,CACF,CACF,CAAC;QACJ,CAAC,CAAC,CACH;aACA,SAAS,CAAC,GAAG,CAAC,EAAE;YACf,GAAG,CAAC,cAAc,EAAE,CAAC;YACrB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,wBAAwB;QAC9B,IAAI,CAAC,UAAU;aACZ,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,SAAS,CAAC,SAAS,CAAC,EAAE;YACpB,IAAI,CAAC,SAAS,EAAE,CAAC;gBACf,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,SAAS,EACT,MAAM,CACP,CAAC;gBACF,OAAO,KAAK,CAAC;YACf,CAAC;YACD,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CACpC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,EAC7B,SAAS,CACP,CAAC,aAAoD,EAAE,EAAE;gBACvD,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC7B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,SAAS,EACT,MAAM,CACP,CAAC;oBAEF,OAAO,KAAK,CACV,GAAG,aAAa;yBACb,OAAO,EAAE;yBACT,GAAG,CAAC,YAAY,CAAC,EAAE,CAClB,aAAa,CAAC,YAAY,CAAC,OAAO,CAAC,aAAa,CAAC,CAClD,CACJ,CAAC;gBACJ,CAAC;gBACD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,SAAS,EACT,OAAO,CACR,CAAC;gBACF,OAAO,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;YACtD,CAAC,CACF,CACF,CAAC;QACJ,CAAC,CAAC,CACH;aACA,SAAS,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IACxC,CAAC;kFA/RU,iBAAiB,4DAkElB,QAAQ;oEAlEP,iBAAiB;wCAmBd,qBAAqB;wCAflB,iBAAiB;wCAGjB,mBAAmB;wCAGnB,mBAAmB;;;;;;;;mCAGW,UAAU;mCAGV,UAAU;;;;;;;YCvF3D,kBAAyB;YACzB,4BAGO;YACP,iCAGC;YACC,8BAAkC;YACpC,iBAAM;;;ADsGJ;IADC,eAAe,EAAE;8BACL,UAAU;qDAAU;AAOjC;IADC,eAAe,EAAE;8BACN,UAAU;qDAAU;AAMhC;IADC,eAAe,EAAE;8BACN,UAAU;qDAAU;iFAtDrB,iBAAiB;cAN7B,SAAS;2BACE,eAAe,mBAGR,uBAAuB,CAAC,MAAM;;sBAoE5C,MAAM;uBAAC,QAAQ;kGAhElB,EAAE;kBADD,KAAK;YAIW,WAAW;kBAD3B,eAAe;mBAAC,iBAAiB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;YAIxC,aAAa;kBAD7B,eAAe;mBAAC,mBAAmB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;YAI1C,aAAa;kBAD7B,eAAe;mBAAC,mBAAmB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;YAI3D,UAAU;kBADT,SAAS;mBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE;YAI3D,UAAU;kBADT,SAAS;mBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE;YAI3D,WAAW;kBADV,YAAY;mBAAC,qBAAqB;YAG1B,IAAI;kBAAZ,KAAK;YACG,IAAI;kBAAZ,KAAK;YACG,IAAI;kBAAZ,KAAK;YACG,IAAI;kBAAZ,KAAK;YAIN,UAAU;kBADT,KAAK;YAMN,kBAAkB;kBADjB,KAAK;YAKN,SAAS;kBADR,KAAK;YAIN,UAAU,MAIV,SAAS;kBADR,KAAK;YAIN,UAAU,MAGV,SAAS;kBADR,KAAK;YAIN,UAAU,MAmBV,MAAM;kBADL,MAAM;;kFAxEI,iBAAiB","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  ViewChild,\n} from '@angular/core';\nimport {\n  NEVER,\n  Observable,\n  startWith,\n  switchMap,\n  merge,\n  iif,\n  exhaustMap,\n  take,\n  map,\n  Subject,\n  takeUntil,\n  filter,\n  distinctUntilChanged,\n} from 'rxjs';\n\nimport { isEqual, ObservableInput } from '../../../core/public-api';\nimport {\n  GridDragHandlerDirective,\n  GRID_DRAG_HANDLER,\n} from '../../directives/drag-handler.directive';\nimport {\n  GridItemPlaceholderDirective,\n  GRID_ITEM_PLACEHOLDER,\n} from '../../directives/placeholder.directive';\nimport {\n  GridRemoveHandlerDirective,\n  GRID_REMOVE_HANDLER,\n} from '../../directives/remove-handler.directive';\nimport {\n  GridResizeHandlerDirective,\n  GRID_RESIZE_HANDLER,\n} from '../../directives/resize-handler.directive';\nimport { GridLayoutService } from '../../grid-layout.service';\nimport { parseRenderItemToPixels } from '../../utils/grid.utils';\nimport {\n  accessPointerMoveThreshold,\n  getMouseClick$,\n  getMouseDown$,\n  getMouseEnd$,\n  getMouseMove$,\n} from '../../utils/mouse.utils';\nimport { runOutsideZone$ } from '../../utils/operator';\n\nconst ANIMATION_DURATION_MS = 250;\n\n@Component({\n  selector: 'acl-grid-item',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class GridItemComponent implements OnInit, OnDestroy, AfterContentInit {\n  @Input()\n  id!: string;\n\n  @ContentChildren(GRID_DRAG_HANDLER, { descendants: true })\n  private readonly dragHandles: QueryList<GridDragHandlerDirective>;\n\n  @ContentChildren(GRID_RESIZE_HANDLER, { descendants: true })\n  private readonly resizeHandles: QueryList<GridResizeHandlerDirective>;\n\n  @ContentChildren(GRID_REMOVE_HANDLER, { descendants: true })\n  private readonly removeHandles: QueryList<GridRemoveHandlerDirective>;\n\n  @ViewChild('resizeElem', { static: true, read: ElementRef })\n  resizeElem: ElementRef;\n\n  @ViewChild('removeElem', { static: true, read: ElementRef })\n  removeElem: ElementRef;\n\n  @ContentChild(GRID_ITEM_PLACEHOLDER)\n  placeholder: GridItemPlaceholderDirective;\n\n  @Input() minW?: number;\n  @Input() minH?: number;\n  @Input() maxW?: number;\n  @Input() maxH?: number;\n\n  /** CSS transition style */\n  @Input()\n  transition =\n    `transform ${ANIMATION_DURATION_MS}ms ease, width ${ANIMATION_DURATION_MS}ms ease, height ${ANIMATION_DURATION_MS}ms ease`;\n\n  /** Minimum amount of pixels that the user should move before it starts the drag sequence. */\n  @Input()\n  dragStartThreshold = 0;\n\n  /** Whether the item is draggable or not. Defaults to true. */\n  @Input()\n  draggable = true;\n\n  @ObservableInput()\n  draggable$!: Observable<boolean>;\n\n  /** Whether the item is resizable or not. Defaults to true. */\n  @Input()\n  resizable = true;\n\n  @ObservableInput()\n  resizable$: Observable<boolean>;\n\n  @Input()\n  removable = true;\n\n  @ObservableInput()\n  removable$: Observable<boolean>;\n\n  destroy$$ = new Subject<void>();\n\n  private readonly dragStartSubject = new Subject<MouseEvent>();\n  private readonly resizeStartSubject = new Subject<MouseEvent>();\n\n  dragStart$ = this.dragStartSubject.asObservable();\n  resizeStart$ = this.resizeStartSubject.asObservable();\n\n  constructor(\n    public elementRef: ElementRef,\n    @Inject(DOCUMENT) private readonly document: Document,\n    private readonly renderer: Renderer2,\n    private readonly ngZone: NgZone,\n    private readonly layoutService: GridLayoutService,\n  ) {}\n\n  @Output()\n  remove = new EventEmitter();\n\n  ngOnInit() {\n    this.layoutService.gridRenderItemsData$$\n      .pipe(\n        map(({ data, animation }) => ({ data: data?.[this.id], animation })),\n        distinctUntilChanged((a, b) => isEqual(a.data, b.data)),\n        takeUntil(this.destroy$$),\n      )\n      .subscribe(({ data, animation }) => {\n        this.setStyles(parseRenderItemToPixels(data), animation);\n      });\n  }\n\n  ngAfterContentInit() {\n    this.setupDragStartListener();\n    this.setupResizeStartListener();\n    this.setupRemoveListener();\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  setStyles(\n    {\n      top,\n      left,\n      width,\n      height,\n    }: {\n      top: string;\n      left: string;\n      width?: string;\n      height?: string;\n    },\n    animation: boolean,\n  ) {\n    this.renderer.setStyle(\n      this.elementRef.nativeElement,\n      'transform',\n      `translateX(${left}) translateY(${top})`,\n    );\n\n    this.renderer.setStyle(\n      this.elementRef.nativeElement,\n      'transition',\n      animation ? this.transition : 'none',\n    );\n    requestAnimationFrame(() => {\n      this.renderer.setStyle(this.elementRef.nativeElement, 'display', `block`);\n      if (width != null) {\n        this.renderer.setStyle(this.elementRef.nativeElement, 'width', width);\n      }\n      if (height != null) {\n        this.renderer.setStyle(this.elementRef.nativeElement, 'height', height);\n      }\n    });\n  }\n\n  private setupDragStartListener() {\n    const document = this.document.documentElement;\n    this.draggable$\n      .pipe(\n        takeUntil(this.destroy$$),\n        startWith(this.draggable),\n        switchMap(draggable => {\n          if (!draggable) {\n            return NEVER;\n          }\n          return this.dragHandles.changes.pipe(\n            startWith(this.dragHandles),\n            switchMap((dragHandles: QueryList<GridDragHandlerDirective>) =>\n              iif(\n                () => dragHandles.length > 0,\n                merge(\n                  ...dragHandles\n                    .toArray()\n                    .map(dragHandle =>\n                      getMouseDown$(dragHandle.element.nativeElement),\n                    ),\n                ),\n                getMouseDown$(this.elementRef.nativeElement),\n              ).pipe(\n                exhaustMap(startEvent => {\n                  // Prevent browser default drag/drop action, we handle all scenes\n                  if (\n                    startEvent.target &&\n                    (startEvent.target as HTMLElement).draggable &&\n                    startEvent.type === 'mousedown'\n                  ) {\n                    startEvent.preventDefault();\n                    startEvent.stopImmediatePropagation();\n                  }\n\n                  return getMouseMove$(this.document.documentElement).pipe(\n                    takeUntil(getMouseEnd$(document)),\n                    runOutsideZone$(this.ngZone),\n                    filter(moveEvent => {\n                      moveEvent.preventDefault();\n                      return accessPointerMoveThreshold(\n                        startEvent,\n                        moveEvent,\n                        this.dragStartThreshold,\n                      );\n                    }),\n                    take(1),\n                    map(() => startEvent),\n                  );\n                }),\n              ),\n            ),\n          );\n        }),\n      )\n      .subscribe(this.dragStartSubject);\n  }\n\n  private setupRemoveListener() {\n    this.removable$\n      .pipe(\n        takeUntil(this.destroy$$),\n        startWith(this.removable),\n        switchMap(removable => {\n          if (!removable) {\n            this.renderer.setStyle(\n              this.removeElem.nativeElement,\n              'display',\n              'none',\n            );\n            return NEVER;\n          }\n          return this.removeHandles.changes.pipe(\n            startWith(this.removeHandles),\n            switchMap(\n              (removeHandles: QueryList<GridRemoveHandlerDirective>) => {\n                if (removeHandles.length > 0) {\n                  this.renderer.setStyle(\n                    this.removeElem.nativeElement,\n                    'display',\n                    'none',\n                  );\n\n                  return merge(\n                    ...removeHandles\n                      .toArray()\n                      .map(removeHandle =>\n                        getMouseClick$(removeHandle.element.nativeElement),\n                      ),\n                  );\n                }\n                this.renderer.setStyle(\n                  this.removeElem.nativeElement,\n                  'display',\n                  'block',\n                );\n                return getMouseDown$(this.removeElem.nativeElement);\n              },\n            ),\n          );\n        }),\n      )\n      .subscribe(evt => {\n        evt.preventDefault();\n        this.remove.emit(this.id);\n      });\n  }\n\n  private setupResizeStartListener() {\n    this.resizable$\n      .pipe(\n        takeUntil(this.destroy$$),\n        startWith(this.resizable),\n        switchMap(resizable => {\n          if (!resizable) {\n            this.renderer.setStyle(\n              this.resizeElem.nativeElement,\n              'display',\n              'none',\n            );\n            return NEVER;\n          }\n          return this.resizeHandles.changes.pipe(\n            startWith(this.resizeHandles),\n            switchMap(\n              (resizeHandles: QueryList<GridResizeHandlerDirective>) => {\n                if (resizeHandles.length > 0) {\n                  this.renderer.setStyle(\n                    this.resizeElem.nativeElement,\n                    'display',\n                    'none',\n                  );\n\n                  return merge(\n                    ...resizeHandles\n                      .toArray()\n                      .map(resizeHandle =>\n                        getMouseDown$(resizeHandle.element.nativeElement),\n                      ),\n                  );\n                }\n                this.renderer.setStyle(\n                  this.resizeElem.nativeElement,\n                  'display',\n                  'block',\n                );\n                return getMouseDown$(this.resizeElem.nativeElement);\n              },\n            ),\n          );\n        }),\n      )\n      .subscribe(this.resizeStartSubject);\n  }\n}\n","<ng-content></ng-content>\n<div\n  #resizeElem\n  class=\"grid-item-default-resize-icon\"\n></div>\n<div\n  #removeElem\n  class=\"grid-item-default-remove\"\n>\n  <aui-icon icon=\"xmark\"></aui-icon>\n</div>\n"]}