barsa-user-workspace 0.0.0-watch
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -0
- package/esm2022/barsa-user-workspace.mjs +5 -0
- package/esm2022/lib/barsa-user-workspace.module.mjs +82 -0
- package/esm2022/lib/coercion/boolean-property.mjs +5 -0
- package/esm2022/lib/coercion/number-property.mjs +14 -0
- package/esm2022/lib/directives/drag-handle.mjs +29 -0
- package/esm2022/lib/directives/placeholder.mjs +31 -0
- package/esm2022/lib/directives/resize-handle.mjs +29 -0
- package/esm2022/lib/grid/grid.component.mjs +609 -0
- package/esm2022/lib/grid-item/grid-item.component.mjs +196 -0
- package/esm2022/lib/grid.definitions.mjs +3 -0
- package/esm2022/lib/grid.service.mjs +49 -0
- package/esm2022/lib/layout-container/layout-container.component.mjs +213 -0
- package/esm2022/lib/layout-grid-mapper.pipe.mjs +29 -0
- package/esm2022/lib/nav-container/nav-container.component.mjs +27 -0
- package/esm2022/lib/report-grid-layout/report-grid-layout.component.mjs +15 -0
- package/esm2022/lib/utils/client-rect.mjs +57 -0
- package/esm2022/lib/utils/grid.utils.mjs +225 -0
- package/esm2022/lib/utils/operators.mjs +17 -0
- package/esm2022/lib/utils/passive-listeners.mjs +29 -0
- package/esm2022/lib/utils/pointer.utils.mjs +110 -0
- package/esm2022/lib/utils/react-grid-layout.utils.mjs +493 -0
- package/esm2022/lib/utils/scroll.mjs +233 -0
- package/esm2022/lib/utils/transition-duration.mjs +34 -0
- package/esm2022/lib/utils.mjs +14 -0
- package/esm2022/public-api.mjs +15 -0
- package/esm2022/types.mjs +2 -0
- package/fesm2022/barsa-user-workspace.mjs +2469 -0
- package/fesm2022/barsa-user-workspace.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/barsa-user-workspace.module.d.ts +34 -0
- package/lib/coercion/boolean-property.d.ts +7 -0
- package/lib/coercion/number-property.d.ts +9 -0
- package/lib/directives/drag-handle.d.ts +15 -0
- package/lib/directives/placeholder.d.ts +17 -0
- package/lib/directives/resize-handle.d.ts +15 -0
- package/lib/grid/grid.component.d.ts +147 -0
- package/lib/grid-item/grid-item.component.d.ts +83 -0
- package/lib/grid.definitions.d.ts +61 -0
- package/lib/grid.service.d.ts +15 -0
- package/lib/layout-container/layout-container.component.d.ts +79 -0
- package/lib/layout-grid-mapper.pipe.d.ts +9 -0
- package/lib/nav-container/nav-container.component.d.ts +10 -0
- package/lib/report-grid-layout/report-grid-layout.component.d.ts +7 -0
- package/lib/utils/client-rect.d.ts +36 -0
- package/lib/utils/grid.utils.d.ts +45 -0
- package/lib/utils/operators.d.ts +6 -0
- package/lib/utils/passive-listeners.d.ts +12 -0
- package/lib/utils/pointer.utils.d.ts +29 -0
- package/lib/utils/react-grid-layout.utils.d.ts +177 -0
- package/lib/utils/scroll.d.ts +28 -0
- package/lib/utils/transition-duration.d.ts +6 -0
- package/lib/utils.d.ts +6 -0
- package/package.json +25 -0
- package/public-api.d.ts +12 -0
- package/types.d.ts +3 -0
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class LayoutGridMapperPipe {
|
|
4
|
+
transform(molist) {
|
|
5
|
+
const x = molist.map((c) => ({
|
|
6
|
+
id: c.Id,
|
|
7
|
+
x: +c.x,
|
|
8
|
+
y: +c.y,
|
|
9
|
+
w: +c.w,
|
|
10
|
+
h: +c.h,
|
|
11
|
+
minW: c.minW,
|
|
12
|
+
minH: c.minH,
|
|
13
|
+
maxW: c.maxW,
|
|
14
|
+
maxH: c.maxH,
|
|
15
|
+
ejrayOlgo: c.EjrayOlgo
|
|
16
|
+
}));
|
|
17
|
+
return x;
|
|
18
|
+
}
|
|
19
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LayoutGridMapperPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
20
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: LayoutGridMapperPipe, name: "layoutGridMapper" }); }
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LayoutGridMapperPipe, decorators: [{
|
|
23
|
+
type: Pipe,
|
|
24
|
+
args: [{
|
|
25
|
+
name: 'layoutGridMapper',
|
|
26
|
+
standalone: false
|
|
27
|
+
}]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LWdyaWQtbWFwcGVyLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS11c2VyLXdvcmtzcGFjZS9zcmMvbGliL2xheW91dC1ncmlkLW1hcHBlci5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsSUFBSSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVFwRCxNQUFNLE9BQU8sb0JBQW9CO0lBQzdCLFNBQVMsQ0FBQyxNQUE2QjtRQUNuQyxNQUFNLENBQUMsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ3pCLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRTtZQUNSLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ1AsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDUCxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNQLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ1AsSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJO1lBQ1osSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJO1lBQ1osSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJO1lBQ1osSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJO1lBQ1osU0FBUyxFQUFFLENBQUMsQ0FBQyxTQUFTO1NBQ3pCLENBQUMsQ0FBQyxDQUFDO1FBQ0osT0FBTyxDQUFDLENBQUM7SUFDYixDQUFDOytHQWZRLG9CQUFvQjs2R0FBcEIsb0JBQW9COzs0RkFBcEIsb0JBQW9CO2tCQUpoQyxJQUFJO21CQUFDO29CQUNGLElBQUksRUFBRSxrQkFBa0I7b0JBQ3hCLFVBQVUsRUFBRSxLQUFLO2lCQUNwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGVUcmFuc2Zvcm0sIFBpcGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWV0YW9iamVjdERhdGFNb2RlbCB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcclxuaW1wb3J0IHsgS3RkR3JpZExheW91dCB9IGZyb20gJy4vZ3JpZC5kZWZpbml0aW9ucyc7XHJcblxyXG5AUGlwZSh7XHJcbiAgICBuYW1lOiAnbGF5b3V0R3JpZE1hcHBlcicsXHJcbiAgICBzdGFuZGFsb25lOiBmYWxzZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTGF5b3V0R3JpZE1hcHBlclBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcclxuICAgIHRyYW5zZm9ybShtb2xpc3Q6IE1ldGFvYmplY3REYXRhTW9kZWxbXSk6IEt0ZEdyaWRMYXlvdXQge1xyXG4gICAgICAgIGNvbnN0IHggPSBtb2xpc3QubWFwKChjKSA9PiAoe1xyXG4gICAgICAgICAgICBpZDogYy5JZCxcclxuICAgICAgICAgICAgeDogK2MueCxcclxuICAgICAgICAgICAgeTogK2MueSxcclxuICAgICAgICAgICAgdzogK2MudyxcclxuICAgICAgICAgICAgaDogK2MuaCxcclxuICAgICAgICAgICAgbWluVzogYy5taW5XLFxyXG4gICAgICAgICAgICBtaW5IOiBjLm1pbkgsXHJcbiAgICAgICAgICAgIG1heFc6IGMubWF4VyxcclxuICAgICAgICAgICAgbWF4SDogYy5tYXhILFxyXG4gICAgICAgICAgICBlanJheU9sZ286IGMuRWpyYXlPbGdvXHJcbiAgICAgICAgfSkpO1xyXG4gICAgICAgIHJldHVybiB4O1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, inject } from '@angular/core';
|
|
2
|
+
import { Router } from '@angular/router';
|
|
3
|
+
import { BaseComponent } from 'barsa-novin-ray-core';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@fundamental-ngx/platform/icon-tab-bar";
|
|
6
|
+
export class NavContainerComponent extends BaseComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(...arguments);
|
|
9
|
+
this._router = inject(Router);
|
|
10
|
+
}
|
|
11
|
+
onTabSelect(e) {
|
|
12
|
+
console.log(e);
|
|
13
|
+
if (e.label === 'صفحه اصلی') {
|
|
14
|
+
this._router.navigate(['/home']);
|
|
15
|
+
}
|
|
16
|
+
if (e.label === 'برنامه ها') {
|
|
17
|
+
this._router.navigate(['/home/launchpad']);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NavContainerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
21
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: NavContainerComponent, selector: "buw-nav-container", providers: [], usesInheritance: true, ngImport: i0, template: "<div class=\"fd-shellbar fd-shellbar--xl\">\r\n <fdp-icon-tab-bar layoutMode=\"row\" maxContentHeight=\"250px\" (iconTabSelected)=\"onTabSelect($event)\">\r\n <fdp-icon-tab-bar-tab label=\"\u0635\u0641\u062D\u0647 \u0627\u0635\u0644\u06CC\" active> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632 \u06A9\u0627\u0631 \u0645\u0646\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u062A\u06CC\u06A9\u062A\u06CC\u0646\u06AF\">\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06311\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06312\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06313\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06314\"> </fdp-icon-tab-bar-tab>\r\n </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u0646\u0627\u0628\u0639 \u0627\u0646\u0633\u0627\u0646\u06CC\">\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06311\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06312\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06313\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06314\"> </fdp-icon-tab-bar-tab>\r\n </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u0631\u0647\u0627\">\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06311\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06312\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06313\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06314\"> </fdp-icon-tab-bar-tab>\r\n </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0627\u0628\u0632\u0627\u0631\u0647\u0627\"> </fdp-icon-tab-bar-tab>\r\n </fdp-icon-tab-bar>\r\n</div>", styles: [":host{display:block}:host ::ng-deep>div ul{background-color:transparent}:host ::ng-deep>div ul .fd-icon-tab-bar__tag{color:#fff}:host ::ng-deep>div ul fd-icon,:host ::ng-deep>div ul .fd-icon-tab-bar__arrow{color:#fff!important}:host ::ng-deep>div ul .fd-icon-tab-bar__tab[aria-selected=true]:after{background-color:#fff}\n"], dependencies: [{ kind: "component", type: i1.IconTabBarComponent, selector: "fdp-icon-tab-bar", inputs: ["stackContent", "iconTabType", "tabsConfig", "densityMode", "iconTabFont", "enableTabReordering", "showTotalTab", "multiClick", "layoutMode", "iconTabBackground", "iconTabSize", "colorAssociations", "maxContentHeight"], outputs: ["tabsConfigChange", "densityModeChange", "iconTabSelected", "iconTabReordered", "closeTab"] }, { kind: "component", type: i1.IconTabBarTabComponent, selector: "fdp-icon-tab-bar-tab", inputs: ["label", "color", "icon", "iconFont", "counter", "active", "badge", "closable", "id"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
22
|
+
}
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NavContainerComponent, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{ selector: 'buw-nav-container', providers: [], changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<div class=\"fd-shellbar fd-shellbar--xl\">\r\n <fdp-icon-tab-bar layoutMode=\"row\" maxContentHeight=\"250px\" (iconTabSelected)=\"onTabSelect($event)\">\r\n <fdp-icon-tab-bar-tab label=\"\u0635\u0641\u062D\u0647 \u0627\u0635\u0644\u06CC\" active> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632 \u06A9\u0627\u0631 \u0645\u0646\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u062A\u06CC\u06A9\u062A\u06CC\u0646\u06AF\">\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06311\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06312\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06313\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06314\"> </fdp-icon-tab-bar-tab>\r\n </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u0646\u0627\u0628\u0639 \u0627\u0646\u0633\u0627\u0646\u06CC\">\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06311\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06312\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06313\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06314\"> </fdp-icon-tab-bar-tab>\r\n </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u0631\u0647\u0627\">\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06311\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06312\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06313\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0645\u06CC\u0632\u06A9\u0627\u06314\"> </fdp-icon-tab-bar-tab>\r\n </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\"> </fdp-icon-tab-bar-tab>\r\n <fdp-icon-tab-bar-tab label=\"\u0627\u0628\u0632\u0627\u0631\u0647\u0627\"> </fdp-icon-tab-bar-tab>\r\n </fdp-icon-tab-bar>\r\n</div>", styles: [":host{display:block}:host ::ng-deep>div ul{background-color:transparent}:host ::ng-deep>div ul .fd-icon-tab-bar__tag{color:#fff}:host ::ng-deep>div ul fd-icon,:host ::ng-deep>div ul .fd-icon-tab-bar__arrow{color:#fff!important}:host ::ng-deep>div ul .fd-icon-tab-bar__tab[aria-selected=true]:after{background-color:#fff}\n"] }]
|
|
26
|
+
}] });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LWNvbnRhaW5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS11c2VyLXdvcmtzcGFjZS9zcmMvbGliL25hdi1jb250YWluZXIvbmF2LWNvbnRhaW5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS11c2VyLXdvcmtzcGFjZS9zcmMvbGliL25hdi1jb250YWluZXIvbmF2LWNvbnRhaW5lci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFxQixNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUYsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRXpDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7O0FBVXJELE1BQU0sT0FBTyxxQkFBc0IsU0FBUSxhQUFhO0lBUnhEOztRQVNJLFlBQU8sR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7S0FVNUI7SUFURyxXQUFXLENBQUMsQ0FBQztRQUNULE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDZixJQUFJLENBQUMsQ0FBQyxLQUFLLEtBQUssV0FBVyxFQUFFLENBQUM7WUFDMUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQ3JDLENBQUM7UUFDRCxJQUFJLENBQUMsQ0FBQyxLQUFLLEtBQUssV0FBVyxFQUFFLENBQUM7WUFDMUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUM7UUFDL0MsQ0FBQztJQUNMLENBQUM7K0dBVlEscUJBQXFCO21HQUFyQixxQkFBcUIsNENBSm5CLEVBQUUsaURDVGpCLGsxRUF5Qk07OzRGRFpPLHFCQUFxQjtrQkFSakMsU0FBUzsrQkFDSSxtQkFBbUIsYUFHbEIsRUFBRSxtQkFDSSx1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkRlc3Ryb3ksIE9uSW5pdCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcblxyXG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50IH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2J1dy1uYXYtY29udGFpbmVyJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9uYXYtY29udGFpbmVyLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL25hdi1jb250YWluZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIHByb3ZpZGVyczogW10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOYXZDb250YWluZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xyXG4gICAgX3JvdXRlciA9IGluamVjdChSb3V0ZXIpO1xyXG4gICAgb25UYWJTZWxlY3QoZSk6IHZvaWQge1xyXG4gICAgICAgIGNvbnNvbGUubG9nKGUpO1xyXG4gICAgICAgIGlmIChlLmxhYmVsID09PSAn2LXZgdit2Ycg2KfYtdmE24wnKSB7XHJcbiAgICAgICAgICAgIHRoaXMuX3JvdXRlci5uYXZpZ2F0ZShbJy9ob21lJ10pO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoZS5sYWJlbCA9PT0gJ9io2LHZhtin2YXZhyDZh9inJykge1xyXG4gICAgICAgICAgICB0aGlzLl9yb3V0ZXIubmF2aWdhdGUoWycvaG9tZS9sYXVuY2hwYWQnXSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJmZC1zaGVsbGJhciBmZC1zaGVsbGJhci0teGxcIj5cclxuICAgIDxmZHAtaWNvbi10YWItYmFyIGxheW91dE1vZGU9XCJyb3dcIiBtYXhDb250ZW50SGVpZ2h0PVwiMjUwcHhcIiAoaWNvblRhYlNlbGVjdGVkKT1cIm9uVGFiU2VsZWN0KCRldmVudClcIj5cclxuICAgICAgICA8ZmRwLWljb24tdGFiLWJhci10YWIgbGFiZWw9XCLYtdmB2K3ZhyDYp9i12YTbjFwiIGFjdGl2ZT4gPC9mZHAtaWNvbi10YWItYmFyLXRhYj5cclxuICAgICAgICA8ZmRwLWljb24tdGFiLWJhci10YWIgbGFiZWw9XCLZhduM2LIg2qnYp9ixINmF2YZcIj4gPC9mZHAtaWNvbi10YWItYmFyLXRhYj5cclxuICAgICAgICA8ZmRwLWljb24tdGFiLWJhci10YWIgbGFiZWw9XCLYqtuM2qnYqtuM2Ybar1wiPlxyXG4gICAgICAgICAgICA8ZmRwLWljb24tdGFiLWJhci10YWIgbGFiZWw9XCLZhduM2LLaqdin2LExXCI+IDwvZmRwLWljb24tdGFiLWJhci10YWI+XHJcbiAgICAgICAgICAgIDxmZHAtaWNvbi10YWItYmFyLXRhYiBsYWJlbD1cItmF24zYstqp2KfYsTJcIj4gPC9mZHAtaWNvbi10YWItYmFyLXRhYj5cclxuICAgICAgICAgICAgPGZkcC1pY29uLXRhYi1iYXItdGFiIGxhYmVsPVwi2YXbjNiy2qnYp9ixM1wiPiA8L2ZkcC1pY29uLXRhYi1iYXItdGFiPlxyXG4gICAgICAgICAgICA8ZmRwLWljb24tdGFiLWJhci10YWIgbGFiZWw9XCLZhduM2LLaqdin2LE0XCI+IDwvZmRwLWljb24tdGFiLWJhci10YWI+XHJcbiAgICAgICAgPC9mZHAtaWNvbi10YWItYmFyLXRhYj5cclxuICAgICAgICA8ZmRwLWljb24tdGFiLWJhci10YWIgbGFiZWw9XCLZhdmG2KfYqNi5INin2YbYs9in2YbbjFwiPlxyXG4gICAgICAgICAgICA8ZmRwLWljb24tdGFiLWJhci10YWIgbGFiZWw9XCLZhduM2LLaqdin2LExXCI+IDwvZmRwLWljb24tdGFiLWJhci10YWI+XHJcbiAgICAgICAgICAgIDxmZHAtaWNvbi10YWItYmFyLXRhYiBsYWJlbD1cItmF24zYstqp2KfYsTJcIj4gPC9mZHAtaWNvbi10YWItYmFyLXRhYj5cclxuICAgICAgICAgICAgPGZkcC1pY29uLXRhYi1iYXItdGFiIGxhYmVsPVwi2YXbjNiy2qnYp9ixM1wiPiA8L2ZkcC1pY29uLXRhYi1iYXItdGFiPlxyXG4gICAgICAgICAgICA8ZmRwLWljb24tdGFiLWJhci10YWIgbGFiZWw9XCLZhduM2LLaqdin2LE0XCI+IDwvZmRwLWljb24tdGFiLWJhci10YWI+XHJcbiAgICAgICAgPC9mZHAtaWNvbi10YWItYmFyLXRhYj5cclxuICAgICAgICA8ZmRwLWljb24tdGFiLWJhci10YWIgbGFiZWw9XCLZhduM2LLaqdin2LHZh9inXCI+XHJcbiAgICAgICAgICAgIDxmZHAtaWNvbi10YWItYmFyLXRhYiBsYWJlbD1cItmF24zYstqp2KfYsTFcIj4gPC9mZHAtaWNvbi10YWItYmFyLXRhYj5cclxuICAgICAgICAgICAgPGZkcC1pY29uLXRhYi1iYXItdGFiIGxhYmVsPVwi2YXbjNiy2qnYp9ixMlwiPiA8L2ZkcC1pY29uLXRhYi1iYXItdGFiPlxyXG4gICAgICAgICAgICA8ZmRwLWljb24tdGFiLWJhci10YWIgbGFiZWw9XCLZhduM2LLaqdin2LEzXCI+IDwvZmRwLWljb24tdGFiLWJhci10YWI+XHJcbiAgICAgICAgICAgIDxmZHAtaWNvbi10YWItYmFyLXRhYiBsYWJlbD1cItmF24zYstqp2KfYsTRcIj4gPC9mZHAtaWNvbi10YWItYmFyLXRhYj5cclxuICAgICAgICA8L2ZkcC1pY29uLXRhYi1iYXItdGFiPlxyXG4gICAgICAgIDxmZHAtaWNvbi10YWItYmFyLXRhYiBsYWJlbD1cItio2LHZhtin2YXZhyDZh9inXCI+IDwvZmRwLWljb24tdGFiLWJhci10YWI+XHJcbiAgICAgICAgPGZkcC1pY29uLXRhYi1iYXItdGFiIGxhYmVsPVwi2KfYqNiy2KfYsdmH2KdcIj4gPC9mZHAtaWNvbi10YWItYmFyLXRhYj5cclxuICAgIDwvZmRwLWljb24tdGFiLWJhcj5cclxuPC9kaXY+Il19
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { ReportViewBaseComponent } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "barsa-novin-ray-core";
|
|
5
|
+
import * as i2 from "../layout-container/layout-container.component";
|
|
6
|
+
import * as i3 from "../layout-grid-mapper.pipe";
|
|
7
|
+
export class ReportGridLayoutComponent extends ReportViewBaseComponent {
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ReportGridLayoutComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ReportGridLayoutComponent, selector: "buw-report-grid-layout", providers: [], usesInheritance: true, ngImport: i0, template: "<div style=\"position: relative\" dir=\"ltr\" fillEmptySpace [setMinHeight]=\"true\">\r\n <buw-layout-container [moDataList]=\"moDataList\" [layout]=\"moDataList | layoutGridMapper\"> </buw-layout-container>\r\n</div>\r\n", styles: [":host{display:block}:host ::ng-deep .grid-item-content{box-sizing:border-box;background:#ccc;border:1px solid;width:100%;height:100%;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}:host ::ng-deep .grid-item-remove-handle{position:absolute;cursor:pointer;display:flex;justify-content:center;width:20px;height:20px;top:0;right:0}:host ::ng-deep .grid-item-remove-handle:after{content:\"x\";color:#121212;font-size:16px;font-weight:300;font-family:Arial,sans-serif}\n"], dependencies: [{ kind: "directive", type: i1.FillEmptySpaceDirective, selector: "[fillEmptySpace]", inputs: ["containerDom", "decrement", "disable", "height", "dontUseTopBound", "setMinHeight"], exportAs: ["fillEmptySpace"] }, { kind: "component", type: i2.LayoutContainerComponent, selector: "buw-layout-container", inputs: ["layout", "moDataList"] }, { kind: "pipe", type: i3.LayoutGridMapperPipe, name: "layoutGridMapper" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
10
|
+
}
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ReportGridLayoutComponent, decorators: [{
|
|
12
|
+
type: Component,
|
|
13
|
+
args: [{ selector: 'buw-report-grid-layout', providers: [], changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<div style=\"position: relative\" dir=\"ltr\" fillEmptySpace [setMinHeight]=\"true\">\r\n <buw-layout-container [moDataList]=\"moDataList\" [layout]=\"moDataList | layoutGridMapper\"> </buw-layout-container>\r\n</div>\r\n", styles: [":host{display:block}:host ::ng-deep .grid-item-content{box-sizing:border-box;background:#ccc;border:1px solid;width:100%;height:100%;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}:host ::ng-deep .grid-item-remove-handle{position:absolute;cursor:pointer;display:flex;justify-content:center;width:20px;height:20px;top:0;right:0}:host ::ng-deep .grid-item-remove-handle:after{content:\"x\";color:#121212;font-size:16px;font-weight:300;font-family:Arial,sans-serif}\n"] }]
|
|
14
|
+
}] });
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3J0LWdyaWQtbGF5b3V0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLXVzZXItd29ya3NwYWNlL3NyYy9saWIvcmVwb3J0LWdyaWQtbGF5b3V0L3JlcG9ydC1ncmlkLWxheW91dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS11c2VyLXdvcmtzcGFjZS9zcmMvbGliL3JlcG9ydC1ncmlkLWxheW91dC9yZXBvcnQtZ3JpZC1sYXlvdXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFFdEYsT0FBTyxFQUFFLHVCQUF1QixFQUEyQixNQUFNLHNCQUFzQixDQUFDOzs7OztBQVV4RixNQUFNLE9BQU8seUJBQ1QsU0FBUSx1QkFBZ0Q7K0dBRC9DLHlCQUF5QjttR0FBekIseUJBQXlCLGlEQUp2QixFQUFFLGlEQ1JqQixrT0FHQTs7NEZEU2EseUJBQXlCO2tCQVJyQyxTQUFTOytCQUNJLHdCQUF3QixhQUd2QixFQUFFLG1CQUNJLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uRGVzdHJveSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBSZXBvcnRWaWV3QmFzZUNvbXBvbmVudCwgVWlSZXBvcnRWaWV3QmFzZVNldHRpbmcgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYnV3LXJlcG9ydC1ncmlkLWxheW91dCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vcmVwb3J0LWdyaWQtbGF5b3V0LmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL3JlcG9ydC1ncmlkLWxheW91dC5jb21wb25lbnQuc2NzcyddLFxyXG4gICAgcHJvdmlkZXJzOiBbXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgc3RhbmRhbG9uZTogZmFsc2VcclxufSlcclxuZXhwb3J0IGNsYXNzIFJlcG9ydEdyaWRMYXlvdXRDb21wb25lbnRcclxuICAgIGV4dGVuZHMgUmVwb3J0Vmlld0Jhc2VDb21wb25lbnQ8VWlSZXBvcnRWaWV3QmFzZVNldHRpbmc+XHJcbiAgICBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHt9XHJcbiIsIjxkaXYgc3R5bGU9XCJwb3NpdGlvbjogcmVsYXRpdmVcIiBkaXI9XCJsdHJcIiBmaWxsRW1wdHlTcGFjZSBbc2V0TWluSGVpZ2h0XT1cInRydWVcIj5cclxuICAgIDxidXctbGF5b3V0LWNvbnRhaW5lciBbbW9EYXRhTGlzdF09XCJtb0RhdGFMaXN0XCIgW2xheW91dF09XCJtb0RhdGFMaXN0IHwgbGF5b3V0R3JpZE1hcHBlclwiPiA8L2J1dy1sYXlvdXQtY29udGFpbmVyPlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Client rect utilities.
|
|
3
|
+
* This file is taken from Angular Material repository.
|
|
4
|
+
*/
|
|
5
|
+
/** Gets a mutable version of an element's bounding `ClientRect`. */
|
|
6
|
+
export function getMutableClientRect(element) {
|
|
7
|
+
const clientRect = element.getBoundingClientRect();
|
|
8
|
+
// We need to clone the `clientRect` here, because all the values on it are readonly
|
|
9
|
+
// and we need to be able to update them. Also we can't use a spread here, because
|
|
10
|
+
// the values on a `ClientRect` aren't own properties. See:
|
|
11
|
+
// https://developer.mozilla.org/en-US/docs/Web/API/Element/getBoundingClientRect#Notes
|
|
12
|
+
return {
|
|
13
|
+
top: clientRect.top,
|
|
14
|
+
right: clientRect.right,
|
|
15
|
+
bottom: clientRect.bottom,
|
|
16
|
+
left: clientRect.left,
|
|
17
|
+
width: clientRect.width,
|
|
18
|
+
height: clientRect.height
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Checks whether some coordinates are within a `ClientRect`.
|
|
23
|
+
* @param clientRect ClientRect that is being checked.
|
|
24
|
+
* @param x Coordinates along the X axis.
|
|
25
|
+
* @param y Coordinates along the Y axis.
|
|
26
|
+
*/
|
|
27
|
+
export function isInsideClientRect(clientRect, x, y) {
|
|
28
|
+
const { top, bottom, left, right } = clientRect;
|
|
29
|
+
return y >= top && y <= bottom && x >= left && x <= right;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Updates the top/left positions of a `ClientRect`, as well as their bottom/right counterparts.
|
|
33
|
+
* @param clientRect `ClientRect` that should be updated.
|
|
34
|
+
* @param top Amount to add to the `top` position.
|
|
35
|
+
* @param left Amount to add to the `left` position.
|
|
36
|
+
*/
|
|
37
|
+
export function adjustClientRect(clientRect, top, left) {
|
|
38
|
+
clientRect.top += top;
|
|
39
|
+
clientRect.bottom = clientRect.top + clientRect.height;
|
|
40
|
+
clientRect.left += left;
|
|
41
|
+
clientRect.right = clientRect.left + clientRect.width;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Checks whether the pointer coordinates are close to a ClientRect.
|
|
45
|
+
* @param rect ClientRect to check against.
|
|
46
|
+
* @param threshold Threshold around the ClientRect.
|
|
47
|
+
* @param pointerX Coordinates along the X axis.
|
|
48
|
+
* @param pointerY Coordinates along the Y axis.
|
|
49
|
+
*/
|
|
50
|
+
export function isPointerNearClientRect(rect, threshold, pointerX, pointerY) {
|
|
51
|
+
const { top, right, bottom, left, width, height } = rect;
|
|
52
|
+
const xThreshold = width * threshold;
|
|
53
|
+
const yThreshold = height * threshold;
|
|
54
|
+
return pointerY > top - yThreshold && pointerY < bottom + yThreshold &&
|
|
55
|
+
pointerX > left - xThreshold && pointerX < right + xThreshold;
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpZW50LXJlY3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS11c2VyLXdvcmtzcGFjZS9zcmMvbGliL3V0aWxzL2NsaWVudC1yZWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQWFILG9FQUFvRTtBQUNwRSxNQUFNLFVBQVUsb0JBQW9CLENBQUMsT0FBZ0I7SUFDakQsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLHFCQUFxQixFQUFFLENBQUM7SUFFbkQsb0ZBQW9GO0lBQ3BGLGtGQUFrRjtJQUNsRiwyREFBMkQ7SUFDM0QsdUZBQXVGO0lBQ3ZGLE9BQU87UUFDSCxHQUFHLEVBQUUsVUFBVSxDQUFDLEdBQUc7UUFDbkIsS0FBSyxFQUFFLFVBQVUsQ0FBQyxLQUFLO1FBQ3ZCLE1BQU0sRUFBRSxVQUFVLENBQUMsTUFBTTtRQUN6QixJQUFJLEVBQUUsVUFBVSxDQUFDLElBQUk7UUFDckIsS0FBSyxFQUFFLFVBQVUsQ0FBQyxLQUFLO1FBQ3ZCLE1BQU0sRUFBRSxVQUFVLENBQUMsTUFBTTtLQUM1QixDQUFDO0FBQ04sQ0FBQztBQUVEOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLGtCQUFrQixDQUFDLFVBQXNCLEVBQUUsQ0FBUyxFQUFFLENBQVM7SUFDM0UsTUFBTSxFQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBQyxHQUFHLFVBQVUsQ0FBQztJQUM5QyxPQUFPLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLE1BQU0sSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLENBQUM7QUFDOUQsQ0FBQztBQUVEOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLGdCQUFnQixDQUFDLFVBQXlCLEVBQUUsR0FBVyxFQUFFLElBQVk7SUFDakYsVUFBVSxDQUFDLEdBQUcsSUFBSSxHQUFHLENBQUM7SUFDdEIsVUFBVSxDQUFDLE1BQU0sR0FBRyxVQUFVLENBQUMsR0FBRyxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQUM7SUFFdkQsVUFBVSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUM7SUFDeEIsVUFBVSxDQUFDLEtBQUssR0FBRyxVQUFVLENBQUMsSUFBSSxHQUFHLFVBQVUsQ0FBQyxLQUFLLENBQUM7QUFDMUQsQ0FBQztBQUVEOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSx1QkFBdUIsQ0FBQyxJQUFtQixFQUNuQixTQUFpQixFQUNqQixRQUFnQixFQUNoQixRQUFnQjtJQUNwRCxNQUFNLEVBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUMsR0FBRyxJQUFJLENBQUM7SUFDdkQsTUFBTSxVQUFVLEdBQUcsS0FBSyxHQUFHLFNBQVMsQ0FBQztJQUNyQyxNQUFNLFVBQVUsR0FBRyxNQUFNLEdBQUcsU0FBUyxDQUFDO0lBRXRDLE9BQU8sUUFBUSxHQUFHLEdBQUcsR0FBRyxVQUFVLElBQUksUUFBUSxHQUFHLE1BQU0sR0FBRyxVQUFVO1FBQ2hFLFFBQVEsR0FBRyxJQUFJLEdBQUcsVUFBVSxJQUFJLFFBQVEsR0FBRyxLQUFLLEdBQUcsVUFBVSxDQUFDO0FBQ3RFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENsaWVudCByZWN0IHV0aWxpdGllcy5cbiAqIFRoaXMgZmlsZSBpcyB0YWtlbiBmcm9tIEFuZ3VsYXIgTWF0ZXJpYWwgcmVwb3NpdG9yeS5cbiAqL1xuXG4vKiBlc2xpbnQtZGlzYWJsZSAqL1xuXG5leHBvcnQgaW50ZXJmYWNlIEt0ZENsaWVudFJlY3Qge1xuICAgIHRvcDogbnVtYmVyO1xuICAgIGJvdHRvbTogbnVtYmVyO1xuICAgIGxlZnQ6IG51bWJlcjtcbiAgICByaWdodDogbnVtYmVyO1xuICAgIHdpZHRoOiBudW1iZXI7XG4gICAgaGVpZ2h0OiBudW1iZXI7XG59XG5cbi8qKiBHZXRzIGEgbXV0YWJsZSB2ZXJzaW9uIG9mIGFuIGVsZW1lbnQncyBib3VuZGluZyBgQ2xpZW50UmVjdGAuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0TXV0YWJsZUNsaWVudFJlY3QoZWxlbWVudDogRWxlbWVudCk6IEt0ZENsaWVudFJlY3Qge1xuICAgIGNvbnN0IGNsaWVudFJlY3QgPSBlbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xuXG4gICAgLy8gV2UgbmVlZCB0byBjbG9uZSB0aGUgYGNsaWVudFJlY3RgIGhlcmUsIGJlY2F1c2UgYWxsIHRoZSB2YWx1ZXMgb24gaXQgYXJlIHJlYWRvbmx5XG4gICAgLy8gYW5kIHdlIG5lZWQgdG8gYmUgYWJsZSB0byB1cGRhdGUgdGhlbS4gQWxzbyB3ZSBjYW4ndCB1c2UgYSBzcHJlYWQgaGVyZSwgYmVjYXVzZVxuICAgIC8vIHRoZSB2YWx1ZXMgb24gYSBgQ2xpZW50UmVjdGAgYXJlbid0IG93biBwcm9wZXJ0aWVzLiBTZWU6XG4gICAgLy8gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQVBJL0VsZW1lbnQvZ2V0Qm91bmRpbmdDbGllbnRSZWN0I05vdGVzXG4gICAgcmV0dXJuIHtcbiAgICAgICAgdG9wOiBjbGllbnRSZWN0LnRvcCxcbiAgICAgICAgcmlnaHQ6IGNsaWVudFJlY3QucmlnaHQsXG4gICAgICAgIGJvdHRvbTogY2xpZW50UmVjdC5ib3R0b20sXG4gICAgICAgIGxlZnQ6IGNsaWVudFJlY3QubGVmdCxcbiAgICAgICAgd2lkdGg6IGNsaWVudFJlY3Qud2lkdGgsXG4gICAgICAgIGhlaWdodDogY2xpZW50UmVjdC5oZWlnaHRcbiAgICB9O1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIHNvbWUgY29vcmRpbmF0ZXMgYXJlIHdpdGhpbiBhIGBDbGllbnRSZWN0YC5cbiAqIEBwYXJhbSBjbGllbnRSZWN0IENsaWVudFJlY3QgdGhhdCBpcyBiZWluZyBjaGVja2VkLlxuICogQHBhcmFtIHggQ29vcmRpbmF0ZXMgYWxvbmcgdGhlIFggYXhpcy5cbiAqIEBwYXJhbSB5IENvb3JkaW5hdGVzIGFsb25nIHRoZSBZIGF4aXMuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc0luc2lkZUNsaWVudFJlY3QoY2xpZW50UmVjdDogQ2xpZW50UmVjdCwgeDogbnVtYmVyLCB5OiBudW1iZXIpIHtcbiAgICBjb25zdCB7dG9wLCBib3R0b20sIGxlZnQsIHJpZ2h0fSA9IGNsaWVudFJlY3Q7XG4gICAgcmV0dXJuIHkgPj0gdG9wICYmIHkgPD0gYm90dG9tICYmIHggPj0gbGVmdCAmJiB4IDw9IHJpZ2h0O1xufVxuXG4vKipcbiAqIFVwZGF0ZXMgdGhlIHRvcC9sZWZ0IHBvc2l0aW9ucyBvZiBhIGBDbGllbnRSZWN0YCwgYXMgd2VsbCBhcyB0aGVpciBib3R0b20vcmlnaHQgY291bnRlcnBhcnRzLlxuICogQHBhcmFtIGNsaWVudFJlY3QgYENsaWVudFJlY3RgIHRoYXQgc2hvdWxkIGJlIHVwZGF0ZWQuXG4gKiBAcGFyYW0gdG9wIEFtb3VudCB0byBhZGQgdG8gdGhlIGB0b3BgIHBvc2l0aW9uLlxuICogQHBhcmFtIGxlZnQgQW1vdW50IHRvIGFkZCB0byB0aGUgYGxlZnRgIHBvc2l0aW9uLlxuICovXG5leHBvcnQgZnVuY3Rpb24gYWRqdXN0Q2xpZW50UmVjdChjbGllbnRSZWN0OiBLdGRDbGllbnRSZWN0LCB0b3A6IG51bWJlciwgbGVmdDogbnVtYmVyKSB7XG4gICAgY2xpZW50UmVjdC50b3AgKz0gdG9wO1xuICAgIGNsaWVudFJlY3QuYm90dG9tID0gY2xpZW50UmVjdC50b3AgKyBjbGllbnRSZWN0LmhlaWdodDtcblxuICAgIGNsaWVudFJlY3QubGVmdCArPSBsZWZ0O1xuICAgIGNsaWVudFJlY3QucmlnaHQgPSBjbGllbnRSZWN0LmxlZnQgKyBjbGllbnRSZWN0LndpZHRoO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIHRoZSBwb2ludGVyIGNvb3JkaW5hdGVzIGFyZSBjbG9zZSB0byBhIENsaWVudFJlY3QuXG4gKiBAcGFyYW0gcmVjdCBDbGllbnRSZWN0IHRvIGNoZWNrIGFnYWluc3QuXG4gKiBAcGFyYW0gdGhyZXNob2xkIFRocmVzaG9sZCBhcm91bmQgdGhlIENsaWVudFJlY3QuXG4gKiBAcGFyYW0gcG9pbnRlclggQ29vcmRpbmF0ZXMgYWxvbmcgdGhlIFggYXhpcy5cbiAqIEBwYXJhbSBwb2ludGVyWSBDb29yZGluYXRlcyBhbG9uZyB0aGUgWSBheGlzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNQb2ludGVyTmVhckNsaWVudFJlY3QocmVjdDogS3RkQ2xpZW50UmVjdCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aHJlc2hvbGQ6IG51bWJlcixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBwb2ludGVyWDogbnVtYmVyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHBvaW50ZXJZOiBudW1iZXIpOiBib29sZWFuIHtcbiAgICBjb25zdCB7dG9wLCByaWdodCwgYm90dG9tLCBsZWZ0LCB3aWR0aCwgaGVpZ2h0fSA9IHJlY3Q7XG4gICAgY29uc3QgeFRocmVzaG9sZCA9IHdpZHRoICogdGhyZXNob2xkO1xuICAgIGNvbnN0IHlUaHJlc2hvbGQgPSBoZWlnaHQgKiB0aHJlc2hvbGQ7XG5cbiAgICByZXR1cm4gcG9pbnRlclkgPiB0b3AgLSB5VGhyZXNob2xkICYmIHBvaW50ZXJZIDwgYm90dG9tICsgeVRocmVzaG9sZCAmJlxuICAgICAgICBwb2ludGVyWCA+IGxlZnQgLSB4VGhyZXNob2xkICYmIHBvaW50ZXJYIDwgcmlnaHQgKyB4VGhyZXNob2xkO1xufVxuIl19
|
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
import { compact, getFirstCollision, moveElement } from './react-grid-layout.utils';
|
|
2
|
+
import { ktdPointerClientX, ktdPointerClientY } from './pointer.utils';
|
|
3
|
+
/** Tracks items by id. This function is mean to be used in conjunction with the ngFor that renders the 'buw-grid-items' */
|
|
4
|
+
export function ktdTrackById(index, item) {
|
|
5
|
+
return item.id;
|
|
6
|
+
}
|
|
7
|
+
/** Given a layout, the gridHeight and the gap return the resulting rowHeight */
|
|
8
|
+
export function ktdGetGridItemRowHeight(layout, gridHeight, gap) {
|
|
9
|
+
const numberOfRows = layout.reduce((acc, cur) => Math.max(acc, Math.max(cur.y + cur.h, 0)), 0);
|
|
10
|
+
const gapTotalHeight = (numberOfRows - 1) * gap;
|
|
11
|
+
const gridHeightMinusGap = gridHeight - gapTotalHeight;
|
|
12
|
+
return gridHeightMinusGap / numberOfRows;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Call react-grid-layout utils 'compact()' function and return the compacted layout.
|
|
16
|
+
* @param layout to be compacted.
|
|
17
|
+
* @param compactType, type of compaction.
|
|
18
|
+
* @param cols, number of columns of the grid.
|
|
19
|
+
*/
|
|
20
|
+
export function ktdGridCompact(layout, compactType, cols) {
|
|
21
|
+
return (compact(layout, compactType, cols)
|
|
22
|
+
// Prune react-grid-layout compact extra properties.
|
|
23
|
+
.map((item) => ({
|
|
24
|
+
id: item.id,
|
|
25
|
+
x: item.x,
|
|
26
|
+
y: item.y,
|
|
27
|
+
w: item.w,
|
|
28
|
+
h: item.h,
|
|
29
|
+
minW: item.minW,
|
|
30
|
+
minH: item.minH,
|
|
31
|
+
maxW: item.maxW,
|
|
32
|
+
maxH: item.maxH
|
|
33
|
+
})));
|
|
34
|
+
}
|
|
35
|
+
function screenXToGridX(screenXPos, cols, width, gap) {
|
|
36
|
+
const widthMinusGaps = width - gap * (cols - 1);
|
|
37
|
+
const itemWidth = widthMinusGaps / cols;
|
|
38
|
+
const widthMinusOneItem = width - itemWidth;
|
|
39
|
+
const colWidthWithGap = widthMinusOneItem / (cols - 1);
|
|
40
|
+
return Math.round(screenXPos / colWidthWithGap);
|
|
41
|
+
}
|
|
42
|
+
function screenYToGridY(screenYPos, rowHeight, height, gap) {
|
|
43
|
+
return Math.round(screenYPos / (rowHeight + gap));
|
|
44
|
+
}
|
|
45
|
+
function screenWidthToGridWidth(gridScreenWidth, cols, width, gap) {
|
|
46
|
+
const widthMinusGaps = width - gap * (cols - 1);
|
|
47
|
+
const itemWidth = widthMinusGaps / cols;
|
|
48
|
+
const gridScreenWidthMinusFirst = gridScreenWidth - itemWidth;
|
|
49
|
+
return Math.round(gridScreenWidthMinusFirst / (itemWidth + gap)) + 1;
|
|
50
|
+
}
|
|
51
|
+
function screenHeightToGridHeight(gridScreenHeight, rowHeight, height, gap) {
|
|
52
|
+
const gridScreenHeightMinusFirst = gridScreenHeight - rowHeight;
|
|
53
|
+
return Math.round(gridScreenHeightMinusFirst / (rowHeight + gap)) + 1;
|
|
54
|
+
}
|
|
55
|
+
/** Returns a Dictionary where the key is the id and the value is the change applied to that item. If no changes Dictionary is empty. */
|
|
56
|
+
export function ktdGetGridLayoutDiff(gridLayoutA, gridLayoutB) {
|
|
57
|
+
const diff = {};
|
|
58
|
+
gridLayoutA.forEach((itemA) => {
|
|
59
|
+
const itemB = gridLayoutB.find((_itemB) => _itemB.id === itemA.id);
|
|
60
|
+
if (itemB != null) {
|
|
61
|
+
const posChanged = itemA.x !== itemB.x || itemA.y !== itemB.y;
|
|
62
|
+
const sizeChanged = itemA.w !== itemB.w || itemA.h !== itemB.h;
|
|
63
|
+
const change = posChanged && sizeChanged ? 'moveresize' : posChanged ? 'move' : sizeChanged ? 'resize' : null;
|
|
64
|
+
if (change) {
|
|
65
|
+
diff[itemB.id] = { change };
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
return diff;
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Given the grid config & layout data and the current drag position & information, returns the corresponding layout and drag item position
|
|
73
|
+
* @param gridItem grid item that is been dragged
|
|
74
|
+
* @param config current grid configuration
|
|
75
|
+
* @param compactionType type of compaction that will be performed
|
|
76
|
+
* @param draggingData contains all the information about the drag
|
|
77
|
+
*/
|
|
78
|
+
export function ktdGridItemDragging(gridItem, config, compactionType, draggingData) {
|
|
79
|
+
const { pointerDownEvent, pointerDragEvent, gridElemClientRect, dragElemClientRect, scrollDifference } = draggingData;
|
|
80
|
+
const gridItemId = gridItem.id;
|
|
81
|
+
const draggingElemPrevItem = config.layout.find((item) => item.id === gridItemId);
|
|
82
|
+
const clientStartX = ktdPointerClientX(pointerDownEvent);
|
|
83
|
+
const clientStartY = ktdPointerClientY(pointerDownEvent);
|
|
84
|
+
const clientX = ktdPointerClientX(pointerDragEvent);
|
|
85
|
+
const clientY = ktdPointerClientY(pointerDragEvent);
|
|
86
|
+
const offsetX = clientStartX - dragElemClientRect.left;
|
|
87
|
+
const offsetY = clientStartY - dragElemClientRect.top;
|
|
88
|
+
// Grid element positions taking into account the possible scroll total difference from the beginning.
|
|
89
|
+
const gridElementLeftPosition = gridElemClientRect.left + scrollDifference.left;
|
|
90
|
+
const gridElementTopPosition = gridElemClientRect.top + scrollDifference.top;
|
|
91
|
+
// Calculate position relative to the grid element.
|
|
92
|
+
const gridRelXPos = clientX - gridElementLeftPosition - offsetX;
|
|
93
|
+
const gridRelYPos = clientY - gridElementTopPosition - offsetY;
|
|
94
|
+
const rowHeightInPixels = config.rowHeight === 'fit'
|
|
95
|
+
? ktdGetGridItemRowHeight(config.layout, config.height ?? gridElemClientRect.height, config.gap)
|
|
96
|
+
: config.rowHeight;
|
|
97
|
+
// Get layout item position
|
|
98
|
+
const layoutItem = {
|
|
99
|
+
...draggingElemPrevItem,
|
|
100
|
+
x: screenXToGridX(gridRelXPos, config.cols, gridElemClientRect.width, config.gap),
|
|
101
|
+
y: screenYToGridY(gridRelYPos, rowHeightInPixels, gridElemClientRect.height, config.gap)
|
|
102
|
+
};
|
|
103
|
+
// Correct the values if they overflow, since 'moveElement' function doesn't do it
|
|
104
|
+
layoutItem.x = Math.max(0, layoutItem.x);
|
|
105
|
+
layoutItem.y = Math.max(0, layoutItem.y);
|
|
106
|
+
if (layoutItem.x + layoutItem.w > config.cols) {
|
|
107
|
+
layoutItem.x = Math.max(0, config.cols - layoutItem.w);
|
|
108
|
+
}
|
|
109
|
+
// Parse to LayoutItem array data in order to use 'react.grid-layout' utils
|
|
110
|
+
const layoutItems = config.layout;
|
|
111
|
+
const draggedLayoutItem = layoutItems.find((item) => item.id === gridItemId);
|
|
112
|
+
let newLayoutItems = moveElement(layoutItems, draggedLayoutItem, layoutItem.x, layoutItem.y, true, config.preventCollision, compactionType, config.cols);
|
|
113
|
+
newLayoutItems = compact(newLayoutItems, compactionType, config.cols);
|
|
114
|
+
return {
|
|
115
|
+
layout: newLayoutItems,
|
|
116
|
+
draggedItemPos: {
|
|
117
|
+
top: gridRelYPos,
|
|
118
|
+
left: gridRelXPos,
|
|
119
|
+
width: dragElemClientRect.width,
|
|
120
|
+
height: dragElemClientRect.height
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Given the grid config & layout data and the current drag position & information, returns the corresponding layout and drag item position
|
|
126
|
+
* @param gridItem grid item that is been dragged
|
|
127
|
+
* @param config current grid configuration
|
|
128
|
+
* @param compactionType type of compaction that will be performed
|
|
129
|
+
* @param draggingData contains all the information about the drag
|
|
130
|
+
*/
|
|
131
|
+
export function ktdGridItemResizing(gridItem, config, compactionType, draggingData) {
|
|
132
|
+
const { pointerDownEvent, pointerDragEvent, gridElemClientRect, dragElemClientRect, scrollDifference } = draggingData;
|
|
133
|
+
const gridItemId = gridItem.id;
|
|
134
|
+
const clientStartX = ktdPointerClientX(pointerDownEvent);
|
|
135
|
+
const clientStartY = ktdPointerClientY(pointerDownEvent);
|
|
136
|
+
const clientX = ktdPointerClientX(pointerDragEvent);
|
|
137
|
+
const clientY = ktdPointerClientY(pointerDragEvent);
|
|
138
|
+
// Get the difference between the mouseDown and the position 'right' of the resize element.
|
|
139
|
+
const resizeElemOffsetX = dragElemClientRect.width - (clientStartX - dragElemClientRect.left);
|
|
140
|
+
const resizeElemOffsetY = dragElemClientRect.height - (clientStartY - dragElemClientRect.top);
|
|
141
|
+
const draggingElemPrevItem = config.layout.find((item) => item.id === gridItemId);
|
|
142
|
+
const width = clientX + resizeElemOffsetX - (dragElemClientRect.left + scrollDifference.left);
|
|
143
|
+
const height = clientY + resizeElemOffsetY - (dragElemClientRect.top + scrollDifference.top);
|
|
144
|
+
const rowHeightInPixels = config.rowHeight === 'fit'
|
|
145
|
+
? ktdGetGridItemRowHeight(config.layout, config.height ?? gridElemClientRect.height, config.gap)
|
|
146
|
+
: config.rowHeight;
|
|
147
|
+
// Get layout item grid position
|
|
148
|
+
const layoutItem = {
|
|
149
|
+
...draggingElemPrevItem,
|
|
150
|
+
w: screenWidthToGridWidth(width, config.cols, gridElemClientRect.width, config.gap),
|
|
151
|
+
h: screenHeightToGridHeight(height, rowHeightInPixels, gridElemClientRect.height, config.gap)
|
|
152
|
+
};
|
|
153
|
+
layoutItem.w = limitNumberWithinRange(layoutItem.w, gridItem.minW ?? layoutItem.minW, gridItem.maxW ?? layoutItem.maxW);
|
|
154
|
+
layoutItem.h = limitNumberWithinRange(layoutItem.h, gridItem.minH ?? layoutItem.minH, gridItem.maxH ?? layoutItem.maxH);
|
|
155
|
+
if (layoutItem.x + layoutItem.w > config.cols) {
|
|
156
|
+
layoutItem.w = Math.max(1, config.cols - layoutItem.x);
|
|
157
|
+
}
|
|
158
|
+
if (config.preventCollision) {
|
|
159
|
+
const maxW = layoutItem.w;
|
|
160
|
+
const maxH = layoutItem.h;
|
|
161
|
+
let colliding = hasCollision(config.layout, layoutItem);
|
|
162
|
+
let shrunkDimension;
|
|
163
|
+
while (colliding) {
|
|
164
|
+
shrunkDimension = getDimensionToShrink(layoutItem, shrunkDimension);
|
|
165
|
+
layoutItem[shrunkDimension]--;
|
|
166
|
+
colliding = hasCollision(config.layout, layoutItem);
|
|
167
|
+
}
|
|
168
|
+
if (shrunkDimension === 'w') {
|
|
169
|
+
layoutItem.h = maxH;
|
|
170
|
+
colliding = hasCollision(config.layout, layoutItem);
|
|
171
|
+
while (colliding) {
|
|
172
|
+
layoutItem.h--;
|
|
173
|
+
colliding = hasCollision(config.layout, layoutItem);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
if (shrunkDimension === 'h') {
|
|
177
|
+
layoutItem.w = maxW;
|
|
178
|
+
colliding = hasCollision(config.layout, layoutItem);
|
|
179
|
+
while (colliding) {
|
|
180
|
+
layoutItem.w--;
|
|
181
|
+
colliding = hasCollision(config.layout, layoutItem);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
const newLayoutItems = config.layout.map((item) => (item.id === gridItemId ? layoutItem : item));
|
|
186
|
+
return {
|
|
187
|
+
layout: compact(newLayoutItems, compactionType, config.cols),
|
|
188
|
+
draggedItemPos: {
|
|
189
|
+
top: dragElemClientRect.top - gridElemClientRect.top,
|
|
190
|
+
left: dragElemClientRect.left - gridElemClientRect.left,
|
|
191
|
+
width,
|
|
192
|
+
height
|
|
193
|
+
}
|
|
194
|
+
};
|
|
195
|
+
}
|
|
196
|
+
function hasCollision(layout, layoutItem) {
|
|
197
|
+
return !!getFirstCollision(layout, layoutItem);
|
|
198
|
+
}
|
|
199
|
+
function getDimensionToShrink(layoutItem, lastShrunk) {
|
|
200
|
+
if (layoutItem.h <= 1) {
|
|
201
|
+
return 'w';
|
|
202
|
+
}
|
|
203
|
+
if (layoutItem.w <= 1) {
|
|
204
|
+
return 'h';
|
|
205
|
+
}
|
|
206
|
+
return lastShrunk === 'w' ? 'h' : 'w';
|
|
207
|
+
}
|
|
208
|
+
/**
|
|
209
|
+
* Given the current number and min/max values, returns the number within the range
|
|
210
|
+
* @param number can be any numeric value
|
|
211
|
+
* @param min minimum value of range
|
|
212
|
+
* @param max maximum value of range
|
|
213
|
+
*/
|
|
214
|
+
function limitNumberWithinRange(num, min = 1, max = Infinity) {
|
|
215
|
+
return Math.min(Math.max(num, min < 1 ? 1 : min), max);
|
|
216
|
+
}
|
|
217
|
+
/** Returns true if both item1 and item2 KtdGridLayoutItems are equivalent. */
|
|
218
|
+
export function ktdGridItemLayoutItemAreEqual(item1, item2) {
|
|
219
|
+
return (item1.id === item2.id &&
|
|
220
|
+
item1.x === item2.x &&
|
|
221
|
+
item1.y === item2.y &&
|
|
222
|
+
item1.w === item2.w &&
|
|
223
|
+
item1.h === item2.h);
|
|
224
|
+
}
|
|
225
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.utils.js","sourceRoot":"","sources":["../../../../../projects/barsa-user-workspace/src/lib/utils/grid.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { compact, CompactType, getFirstCollision, Layout, LayoutItem, moveElement } from './react-grid-layout.utils';\nimport {\n    KtdDraggingData,\n    KtdGridCfg,\n    KtdGridCompactType,\n    KtdGridItemRect,\n    KtdGridLayout,\n    KtdGridLayoutItem\n} from '../grid.definitions';\nimport { ktdPointerClientX, ktdPointerClientY } from './pointer.utils';\nimport { KtdDictionary } from '../../types';\nimport { KtdGridItemComponent } from '../grid-item/grid-item.component';\n\n/** Tracks items by id. This function is mean to be used in conjunction with the ngFor that renders the 'buw-grid-items' */\nexport function ktdTrackById(index: number, item: { id: string }): any {\n    return item.id;\n}\n\n/** Given a layout, the gridHeight and the gap return the resulting rowHeight */\nexport function ktdGetGridItemRowHeight(layout: KtdGridLayout, gridHeight: number, gap: number): number {\n    const numberOfRows = layout.reduce((acc, cur) => Math.max(acc, Math.max(cur.y + cur.h, 0)), 0);\n    const gapTotalHeight = (numberOfRows - 1) * gap;\n    const gridHeightMinusGap = gridHeight - gapTotalHeight;\n    return gridHeightMinusGap / numberOfRows;\n}\n\n/**\n * Call react-grid-layout utils 'compact()' function and return the compacted layout.\n * @param layout to be compacted.\n * @param compactType, type of compaction.\n * @param cols, number of columns of the grid.\n */\nexport function ktdGridCompact(layout: KtdGridLayout, compactType: KtdGridCompactType, cols: number): KtdGridLayout {\n    return (\n        compact(layout, compactType, cols)\n            // Prune react-grid-layout compact extra properties.\n            .map((item) => ({\n                id: item.id,\n                x: item.x,\n                y: item.y,\n                w: item.w,\n                h: item.h,\n                minW: item.minW,\n                minH: item.minH,\n                maxW: item.maxW,\n                maxH: item.maxH\n            }))\n    );\n}\n\nfunction screenXToGridX(screenXPos: number, cols: number, width: number, gap: number): number {\n    const widthMinusGaps = width - gap * (cols - 1);\n    const itemWidth = widthMinusGaps / cols;\n    const widthMinusOneItem = width - itemWidth;\n    const colWidthWithGap = widthMinusOneItem / (cols - 1);\n    return Math.round(screenXPos / colWidthWithGap);\n}\n\nfunction screenYToGridY(screenYPos: number, rowHeight: number, height: number, gap: number): number {\n    return Math.round(screenYPos / (rowHeight + gap));\n}\n\nfunction screenWidthToGridWidth(gridScreenWidth: number, cols: number, width: number, gap: number): number {\n    const widthMinusGaps = width - gap * (cols - 1);\n    const itemWidth = widthMinusGaps / cols;\n    const gridScreenWidthMinusFirst = gridScreenWidth - itemWidth;\n    return Math.round(gridScreenWidthMinusFirst / (itemWidth + gap)) + 1;\n}\n\nfunction screenHeightToGridHeight(gridScreenHeight: number, rowHeight: number, height: number, gap: number): number {\n    const gridScreenHeightMinusFirst = gridScreenHeight - rowHeight;\n    return Math.round(gridScreenHeightMinusFirst / (rowHeight + gap)) + 1;\n}\n\n/** Returns a Dictionary where the key is the id and the value is the change applied to that item. If no changes Dictionary is empty. */\nexport function ktdGetGridLayoutDiff(\n    gridLayoutA: KtdGridLayoutItem[],\n    gridLayoutB: KtdGridLayoutItem[]\n): KtdDictionary<{ change: 'move' | 'resize' | 'moveresize' }> {\n    const diff: KtdDictionary<{ change: 'move' | 'resize' | 'moveresize' }> = {};\n\n    gridLayoutA.forEach((itemA) => {\n        const itemB = gridLayoutB.find((_itemB) => _itemB.id === itemA.id);\n        if (itemB != null) {\n            const posChanged = itemA.x !== itemB.x || itemA.y !== itemB.y;\n            const sizeChanged = itemA.w !== itemB.w || itemA.h !== itemB.h;\n            const change: 'move' | 'resize' | 'moveresize' | null =\n                posChanged && sizeChanged ? 'moveresize' : posChanged ? 'move' : sizeChanged ? 'resize' : null;\n            if (change) {\n                diff[itemB.id] = { change };\n            }\n        }\n    });\n    return diff;\n}\n\n/**\n * Given the grid config & layout data and the current drag position & information, returns the corresponding layout and drag item position\n * @param gridItem grid item that is been dragged\n * @param config current grid configuration\n * @param compactionType type of compaction that will be performed\n * @param draggingData contains all the information about the drag\n */\nexport function ktdGridItemDragging(\n    gridItem: KtdGridItemComponent,\n    config: KtdGridCfg,\n    compactionType: CompactType,\n    draggingData: KtdDraggingData\n): { layout: KtdGridLayoutItem[]; draggedItemPos: KtdGridItemRect } {\n    const { pointerDownEvent, pointerDragEvent, gridElemClientRect, dragElemClientRect, scrollDifference } =\n        draggingData;\n\n    const gridItemId = gridItem.id;\n\n    const draggingElemPrevItem = config.layout.find((item) => item.id === gridItemId)!;\n\n    const clientStartX = ktdPointerClientX(pointerDownEvent);\n    const clientStartY = ktdPointerClientY(pointerDownEvent);\n    const clientX = ktdPointerClientX(pointerDragEvent);\n    const clientY = ktdPointerClientY(pointerDragEvent);\n\n    const offsetX = clientStartX - dragElemClientRect.left;\n    const offsetY = clientStartY - dragElemClientRect.top;\n\n    // Grid element positions taking into account the possible scroll total difference from the beginning.\n    const gridElementLeftPosition = gridElemClientRect.left + scrollDifference.left;\n    const gridElementTopPosition = gridElemClientRect.top + scrollDifference.top;\n\n    // Calculate position relative to the grid element.\n    const gridRelXPos = clientX - gridElementLeftPosition - offsetX;\n    const gridRelYPos = clientY - gridElementTopPosition - offsetY;\n\n    const rowHeightInPixels =\n        config.rowHeight === 'fit'\n            ? ktdGetGridItemRowHeight(config.layout, config.height ?? gridElemClientRect.height, config.gap)\n            : config.rowHeight;\n\n    // Get layout item position\n    const layoutItem: KtdGridLayoutItem = {\n        ...draggingElemPrevItem,\n        x: screenXToGridX(gridRelXPos, config.cols, gridElemClientRect.width, config.gap),\n        y: screenYToGridY(gridRelYPos, rowHeightInPixels, gridElemClientRect.height, config.gap)\n    };\n\n    // Correct the values if they overflow, since 'moveElement' function doesn't do it\n    layoutItem.x = Math.max(0, layoutItem.x);\n    layoutItem.y = Math.max(0, layoutItem.y);\n    if (layoutItem.x + layoutItem.w > config.cols) {\n        layoutItem.x = Math.max(0, config.cols - layoutItem.w);\n    }\n\n    // Parse to LayoutItem array data in order to use 'react.grid-layout' utils\n    const layoutItems: LayoutItem[] = config.layout;\n    const draggedLayoutItem: LayoutItem = layoutItems.find((item) => item.id === gridItemId)!;\n\n    let newLayoutItems: LayoutItem[] = moveElement(\n        layoutItems,\n        draggedLayoutItem,\n        layoutItem.x,\n        layoutItem.y,\n        true,\n        config.preventCollision,\n        compactionType,\n        config.cols\n    );\n\n    newLayoutItems = compact(newLayoutItems, compactionType, config.cols);\n\n    return {\n        layout: newLayoutItems,\n        draggedItemPos: {\n            top: gridRelYPos,\n            left: gridRelXPos,\n            width: dragElemClientRect.width,\n            height: dragElemClientRect.height\n        }\n    };\n}\n\n/**\n * Given the grid config & layout data and the current drag position & information, returns the corresponding layout and drag item position\n * @param gridItem grid item that is been dragged\n * @param config current grid configuration\n * @param compactionType type of compaction that will be performed\n * @param draggingData contains all the information about the drag\n */\nexport function ktdGridItemResizing(\n    gridItem: KtdGridItemComponent,\n    config: KtdGridCfg,\n    compactionType: CompactType,\n    draggingData: KtdDraggingData\n): { layout: KtdGridLayoutItem[]; draggedItemPos: KtdGridItemRect } {\n    const { pointerDownEvent, pointerDragEvent, gridElemClientRect, dragElemClientRect, scrollDifference } =\n        draggingData;\n    const gridItemId = gridItem.id;\n\n    const clientStartX = ktdPointerClientX(pointerDownEvent);\n    const clientStartY = ktdPointerClientY(pointerDownEvent);\n    const clientX = ktdPointerClientX(pointerDragEvent);\n    const clientY = ktdPointerClientY(pointerDragEvent);\n\n    // Get the difference between the mouseDown and the position 'right' of the resize element.\n    const resizeElemOffsetX = dragElemClientRect.width - (clientStartX - dragElemClientRect.left);\n    const resizeElemOffsetY = dragElemClientRect.height - (clientStartY - dragElemClientRect.top);\n\n    const draggingElemPrevItem = config.layout.find((item) => item.id === gridItemId)!;\n    const width = clientX + resizeElemOffsetX - (dragElemClientRect.left + scrollDifference.left);\n    const height = clientY + resizeElemOffsetY - (dragElemClientRect.top + scrollDifference.top);\n\n    const rowHeightInPixels =\n        config.rowHeight === 'fit'\n            ? ktdGetGridItemRowHeight(config.layout, config.height ?? gridElemClientRect.height, config.gap)\n            : config.rowHeight;\n\n    // Get layout item grid position\n    const layoutItem: KtdGridLayoutItem = {\n        ...draggingElemPrevItem,\n        w: screenWidthToGridWidth(width, config.cols, gridElemClientRect.width, config.gap),\n        h: screenHeightToGridHeight(height, rowHeightInPixels, gridElemClientRect.height, config.gap)\n    };\n\n    layoutItem.w = limitNumberWithinRange(\n        layoutItem.w,\n        gridItem.minW ?? layoutItem.minW,\n        gridItem.maxW ?? layoutItem.maxW\n    );\n    layoutItem.h = limitNumberWithinRange(\n        layoutItem.h,\n        gridItem.minH ?? layoutItem.minH,\n        gridItem.maxH ?? layoutItem.maxH\n    );\n\n    if (layoutItem.x + layoutItem.w > config.cols) {\n        layoutItem.w = Math.max(1, config.cols - layoutItem.x);\n    }\n\n    if (config.preventCollision) {\n        const maxW = layoutItem.w;\n        const maxH = layoutItem.h;\n\n        let colliding = hasCollision(config.layout, layoutItem);\n        let shrunkDimension: 'w' | 'h' | undefined;\n\n        while (colliding) {\n            shrunkDimension = getDimensionToShrink(layoutItem, shrunkDimension);\n            layoutItem[shrunkDimension]--;\n            colliding = hasCollision(config.layout, layoutItem);\n        }\n\n        if (shrunkDimension === 'w') {\n            layoutItem.h = maxH;\n\n            colliding = hasCollision(config.layout, layoutItem);\n            while (colliding) {\n                layoutItem.h--;\n                colliding = hasCollision(config.layout, layoutItem);\n            }\n        }\n        if (shrunkDimension === 'h') {\n            layoutItem.w = maxW;\n\n            colliding = hasCollision(config.layout, layoutItem);\n            while (colliding) {\n                layoutItem.w--;\n                colliding = hasCollision(config.layout, layoutItem);\n            }\n        }\n    }\n\n    const newLayoutItems: LayoutItem[] = config.layout.map((item): any => (item.id === gridItemId ? layoutItem : item));\n\n    return {\n        layout: compact(newLayoutItems, compactionType, config.cols),\n        draggedItemPos: {\n            top: dragElemClientRect.top - gridElemClientRect.top,\n            left: dragElemClientRect.left - gridElemClientRect.left,\n            width,\n            height\n        }\n    };\n}\n\nfunction hasCollision(layout: Layout, layoutItem: LayoutItem): boolean {\n    return !!getFirstCollision(layout, layoutItem);\n}\n\nfunction getDimensionToShrink(layoutItem, lastShrunk): 'w' | 'h' {\n    if (layoutItem.h <= 1) {\n        return 'w';\n    }\n    if (layoutItem.w <= 1) {\n        return 'h';\n    }\n\n    return lastShrunk === 'w' ? 'h' : 'w';\n}\n\n/**\n * Given the current number and min/max values, returns the number within the range\n * @param number can be any numeric value\n * @param min minimum value of range\n * @param max maximum value of range\n */\nfunction limitNumberWithinRange(num: number, min: number = 1, max: number = Infinity): any {\n    return Math.min(Math.max(num, min < 1 ? 1 : min), max);\n}\n\n/** Returns true if both item1 and item2 KtdGridLayoutItems are equivalent. */\nexport function ktdGridItemLayoutItemAreEqual(item1: KtdGridLayoutItem, item2: KtdGridLayoutItem): boolean {\n    return (\n        item1.id === item2.id &&\n        item1.x === item2.x &&\n        item1.y === item2.y &&\n        item1.w === item2.w &&\n        item1.h === item2.h\n    );\n}\n\n"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Observable } from 'rxjs';
|
|
2
|
+
import { filter } from 'rxjs/operators';
|
|
3
|
+
/** Runs source observable outside the zone */
|
|
4
|
+
export function ktdOutsideZone(zone) {
|
|
5
|
+
return (source) => {
|
|
6
|
+
return new Observable(observer => {
|
|
7
|
+
return zone.runOutsideAngular(() => source.subscribe(observer));
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
/** Rxjs operator that makes source observable to no emit any data */
|
|
12
|
+
export function ktdNoEmit() {
|
|
13
|
+
return (source$) => {
|
|
14
|
+
return source$.pipe(filter(() => false));
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3BlcmF0b3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtdXNlci13b3Jrc3BhY2Uvc3JjL2xpYi91dGlscy9vcGVyYXRvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBZ0IsTUFBTSxNQUFNLENBQUM7QUFDaEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXhDLDhDQUE4QztBQUM5QyxNQUFNLFVBQVUsY0FBYyxDQUFJLElBQVk7SUFDMUMsT0FBTyxDQUFDLE1BQXFCLEVBQUUsRUFBRTtRQUM3QixPQUFPLElBQUksVUFBVSxDQUFJLFFBQVEsQ0FBQyxFQUFFO1lBQ2hDLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFlLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztRQUNsRixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUMsQ0FBQztBQUNOLENBQUM7QUFHRCxxRUFBcUU7QUFDckUsTUFBTSxVQUFVLFNBQVM7SUFDckIsT0FBTyxDQUFDLE9BQXdCLEVBQW1CLEVBQUU7UUFDakQsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQzdDLENBQUMsQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ1pvbmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUsIFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgZmlsdGVyIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG4vKiogUnVucyBzb3VyY2Ugb2JzZXJ2YWJsZSBvdXRzaWRlIHRoZSB6b25lICovXG5leHBvcnQgZnVuY3Rpb24ga3RkT3V0c2lkZVpvbmU8VD4oem9uZTogTmdab25lKSB7XG4gICAgcmV0dXJuIChzb3VyY2U6IE9ic2VydmFibGU8VD4pID0+IHtcbiAgICAgICAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlPFQ+KG9ic2VydmVyID0+IHtcbiAgICAgICAgICAgIHJldHVybiB6b25lLnJ1bk91dHNpZGVBbmd1bGFyPFN1YnNjcmlwdGlvbj4oKCkgPT4gc291cmNlLnN1YnNjcmliZShvYnNlcnZlcikpO1xuICAgICAgICB9KTtcbiAgICB9O1xufVxuXG5cbi8qKiBSeGpzIG9wZXJhdG9yIHRoYXQgbWFrZXMgc291cmNlIG9ic2VydmFibGUgdG8gbm8gZW1pdCBhbnkgZGF0YSAqL1xuZXhwb3J0IGZ1bmN0aW9uIGt0ZE5vRW1pdCgpIHtcbiAgICByZXR1cm4gKHNvdXJjZSQ6IE9ic2VydmFibGU8YW55Pik6IE9ic2VydmFibGU8YW55PiA9PiB7XG4gICAgICAgIHJldHVybiBzb3VyY2UkLnBpcGUoZmlsdGVyKCgpID0+IGZhbHNlKSk7XG4gICAgfTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/** Cached result of whether the user's browser supports passive event listeners. */
|
|
2
|
+
let supportsPassiveEvents;
|
|
3
|
+
/**
|
|
4
|
+
* Checks whether the user's browser supports passive event listeners.
|
|
5
|
+
* See: https://github.com/WICG/EventListenerOptions/blob/gh-pages/explainer.md
|
|
6
|
+
*/
|
|
7
|
+
export function ktdSupportsPassiveEventListeners() {
|
|
8
|
+
if (supportsPassiveEvents == null && typeof window !== 'undefined') {
|
|
9
|
+
try {
|
|
10
|
+
window.addEventListener('test', null, Object.defineProperty({}, 'passive', {
|
|
11
|
+
get: () => supportsPassiveEvents = true
|
|
12
|
+
}));
|
|
13
|
+
}
|
|
14
|
+
finally {
|
|
15
|
+
supportsPassiveEvents = supportsPassiveEvents || false;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
return supportsPassiveEvents;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Normalizes an `AddEventListener` object to something that can be passed
|
|
22
|
+
* to `addEventListener` on any browser, no matter whether it supports the
|
|
23
|
+
* `options` parameter.
|
|
24
|
+
* @param options Object to be normalized.
|
|
25
|
+
*/
|
|
26
|
+
export function ktdNormalizePassiveListenerOptions(options) {
|
|
27
|
+
return ktdSupportsPassiveEventListeners() ? options : !!options.capture;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFzc2l2ZS1saXN0ZW5lcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS11c2VyLXdvcmtzcGFjZS9zcmMvbGliL3V0aWxzL3Bhc3NpdmUtbGlzdGVuZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG9GQUFvRjtBQUNwRixJQUFJLHFCQUE4QixDQUFDO0FBRW5DOzs7R0FHRztBQUNILE1BQU0sVUFBVSxnQ0FBZ0M7SUFDNUMsSUFBSSxxQkFBcUIsSUFBSSxJQUFJLElBQUksT0FBTyxNQUFNLEtBQUssV0FBVyxFQUFFLENBQUM7UUFDakUsSUFBSSxDQUFDO1lBQ0QsTUFBTSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxJQUFLLEVBQUUsTUFBTSxDQUFDLGNBQWMsQ0FBQyxFQUFFLEVBQUUsU0FBUyxFQUFFO2dCQUN4RSxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUMscUJBQXFCLEdBQUcsSUFBSTthQUMxQyxDQUFDLENBQUMsQ0FBQztRQUNSLENBQUM7Z0JBQVMsQ0FBQztZQUNQLHFCQUFxQixHQUFHLHFCQUFxQixJQUFJLEtBQUssQ0FBQztRQUMzRCxDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU8scUJBQXFCLENBQUM7QUFDakMsQ0FBQztBQUVEOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLGtDQUFrQyxDQUFDLE9BQWdDO0lBRS9FLE9BQU8sZ0NBQWdDLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQztBQUM1RSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqIENhY2hlZCByZXN1bHQgb2Ygd2hldGhlciB0aGUgdXNlcidzIGJyb3dzZXIgc3VwcG9ydHMgcGFzc2l2ZSBldmVudCBsaXN0ZW5lcnMuICovXG5sZXQgc3VwcG9ydHNQYXNzaXZlRXZlbnRzOiBib29sZWFuO1xuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIHRoZSB1c2VyJ3MgYnJvd3NlciBzdXBwb3J0cyBwYXNzaXZlIGV2ZW50IGxpc3RlbmVycy5cbiAqIFNlZTogaHR0cHM6Ly9naXRodWIuY29tL1dJQ0cvRXZlbnRMaXN0ZW5lck9wdGlvbnMvYmxvYi9naC1wYWdlcy9leHBsYWluZXIubWRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGt0ZFN1cHBvcnRzUGFzc2l2ZUV2ZW50TGlzdGVuZXJzKCk6IGJvb2xlYW4ge1xuICAgIGlmIChzdXBwb3J0c1Bhc3NpdmVFdmVudHMgPT0gbnVsbCAmJiB0eXBlb2Ygd2luZG93ICE9PSAndW5kZWZpbmVkJykge1xuICAgICAgICB0cnkge1xuICAgICAgICAgICAgd2luZG93LmFkZEV2ZW50TGlzdGVuZXIoJ3Rlc3QnLCBudWxsISwgT2JqZWN0LmRlZmluZVByb3BlcnR5KHt9LCAncGFzc2l2ZScsIHtcbiAgICAgICAgICAgICAgICBnZXQ6ICgpID0+IHN1cHBvcnRzUGFzc2l2ZUV2ZW50cyA9IHRydWVcbiAgICAgICAgICAgIH0pKTtcbiAgICAgICAgfSBmaW5hbGx5IHtcbiAgICAgICAgICAgIHN1cHBvcnRzUGFzc2l2ZUV2ZW50cyA9IHN1cHBvcnRzUGFzc2l2ZUV2ZW50cyB8fCBmYWxzZTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBzdXBwb3J0c1Bhc3NpdmVFdmVudHM7XG59XG5cbi8qKlxuICogTm9ybWFsaXplcyBhbiBgQWRkRXZlbnRMaXN0ZW5lcmAgb2JqZWN0IHRvIHNvbWV0aGluZyB0aGF0IGNhbiBiZSBwYXNzZWRcbiAqIHRvIGBhZGRFdmVudExpc3RlbmVyYCBvbiBhbnkgYnJvd3Nlciwgbm8gbWF0dGVyIHdoZXRoZXIgaXQgc3VwcG9ydHMgdGhlXG4gKiBgb3B0aW9uc2AgcGFyYW1ldGVyLlxuICogQHBhcmFtIG9wdGlvbnMgT2JqZWN0IHRvIGJlIG5vcm1hbGl6ZWQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBrdGROb3JtYWxpemVQYXNzaXZlTGlzdGVuZXJPcHRpb25zKG9wdGlvbnM6IEFkZEV2ZW50TGlzdGVuZXJPcHRpb25zKTpcbiAgICBBZGRFdmVudExpc3RlbmVyT3B0aW9ucyB8IGJvb2xlYW4ge1xuICAgIHJldHVybiBrdGRTdXBwb3J0c1Bhc3NpdmVFdmVudExpc3RlbmVycygpID8gb3B0aW9ucyA6ICEhb3B0aW9ucy5jYXB0dXJlO1xufVxuIl19
|