@guiexpert/angular-table 0.0.1

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 ADDED
@@ -0,0 +1,3 @@
1
+ # angular-table
2
+
3
+ This library was generated with [Nx](https://nx.dev).
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VpZXhwZXJ0LWFuZ3VsYXItdGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGFibGUvc3JjL2d1aWV4cGVydC1hbmd1bGFyLXRhYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
@@ -0,0 +1,6 @@
1
+ export * from './lib/angular-table/table.component';
2
+ export * from './lib/angular-table/component-renderer.if';
3
+ export * from './lib/angular-table/service/dom-service';
4
+ export * from './lib/angular-table/service/renderer-wrapper';
5
+ export * from './lib/angular-table/service/render-wrapper-factory';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGFibGUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyxvREFBb0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2FuZ3VsYXItdGFibGUvdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FuZ3VsYXItdGFibGUvY29tcG9uZW50LXJlbmRlcmVyLmlmJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FuZ3VsYXItdGFibGUvc2VydmljZS9kb20tc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hbmd1bGFyLXRhYmxlL3NlcnZpY2UvcmVuZGVyZXItd3JhcHBlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hbmd1bGFyLXRhYmxlL3NlcnZpY2UvcmVuZGVyLXdyYXBwZXItZmFjdG9yeSc7XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LXJlbmRlcmVyLmlmLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRhYmxlL3NyYy9saWIvYW5ndWxhci10YWJsZS9jb21wb25lbnQtcmVuZGVyZXIuaWYudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXJlYUlkZW50LCBBcmVhTW9kZWxJZiwgUmVuZGVyZXJDbGVhbnVwRm5UeXBlfSBmcm9tIFwiQGd1aWV4cGVydC90YWJsZVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbXBvbmVudFJlbmRlcmVySWY8VD4ge1xuXG4gIHNldERhdGEoXG4gICAgcm93SW5kZXg6IG51bWJlcixcbiAgICBjb2x1bW5JbmRleDogbnVtYmVyLFxuICAgIGFyZWFJZGVudDogQXJlYUlkZW50LFxuICAgIGFyZWFNb2RlbDogQXJlYU1vZGVsSWYsXG4gICAgY2VsbFZhbHVlOiBhbnkpOiBSZW5kZXJlckNsZWFudXBGblR5cGUgfCB1bmRlZmluZWQ7XG5cbn1cbiJdfQ==
@@ -0,0 +1,47 @@
1
+ import { Injectable, Renderer2 } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class DomService {
4
+ constructor(renderer) {
5
+ this.renderer = renderer;
6
+ }
7
+ setStyle(el, style, value) {
8
+ this.renderer.setStyle(el, style, value);
9
+ return el;
10
+ }
11
+ ;
12
+ appendText(parent, text) {
13
+ const div = this.renderer.createText(text);
14
+ this.renderer.appendChild(parent, div);
15
+ return div;
16
+ }
17
+ addClass(div, clazz) {
18
+ if (clazz.includes(' ')) {
19
+ clazz.split(' ').forEach(c => this.renderer.addClass(div, c));
20
+ }
21
+ else {
22
+ this.renderer.addClass(div, clazz);
23
+ }
24
+ return div;
25
+ }
26
+ appendChild(parent, child) {
27
+ this.renderer.appendChild(parent, child);
28
+ }
29
+ createElement(name) {
30
+ return this.renderer.createElement(name);
31
+ }
32
+ createText(text) {
33
+ return this.renderer.createText(text);
34
+ }
35
+ setAttribute(ele, key, value) {
36
+ this.renderer.setAttribute(ele, key, value);
37
+ }
38
+ }
39
+ DomService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DomService, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Injectable });
40
+ DomService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DomService, providedIn: "root" });
41
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DomService, decorators: [{
42
+ type: Injectable,
43
+ args: [{
44
+ providedIn: "root"
45
+ }]
46
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; } });
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9tLXNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGFibGUvc3JjL2xpYi9hbmd1bGFyLXRhYmxlL3NlcnZpY2UvZG9tLXNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBRSxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUM7O0FBT3BELE1BQU0sT0FBTyxVQUFVO0lBRXJCLFlBQ1csUUFBbUI7UUFBbkIsYUFBUSxHQUFSLFFBQVEsQ0FBVztJQUU5QixDQUFDO0lBRUQsUUFBUSxDQUFDLEVBQU8sRUFBRSxLQUFhLEVBQUUsS0FBVTtRQUN6QyxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ3pDLE9BQU8sRUFBRSxDQUFDO0lBQ1osQ0FBQztJQUFBLENBQUM7SUFHRixVQUFVLENBQUMsTUFBc0IsRUFBRSxJQUFZO1FBQzdDLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzNDLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxHQUFHLENBQUMsQ0FBQztRQUN2QyxPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUM7SUFHRCxRQUFRLENBQUMsR0FBbUIsRUFBRSxLQUFhO1FBQ3pDLElBQUksS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUN2QixLQUFLLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFBO1NBQzlEO2FBQU07WUFDTCxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUM7U0FDcEM7UUFDRCxPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUM7SUFFRCxXQUFXLENBQUMsTUFBbUIsRUFBRSxLQUFrQjtRQUNqRCxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVELGFBQWEsQ0FBSSxJQUFZO1FBQzNCLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVELFVBQVUsQ0FBQyxJQUFZO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELFlBQVksQ0FBQyxHQUFnQixFQUFFLEdBQVcsRUFBRSxLQUFhO1FBQ3ZELElBQUksQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDOUMsQ0FBQzs7d0dBM0NVLFVBQVU7NEdBQVYsVUFBVSxjQUZULE1BQU07NEZBRVAsVUFBVTtrQkFIdEIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGUsIFJlbmRlcmVyMn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7RG9tU2VydmljZUlmfSBmcm9tIFwiQGd1aWV4cGVydC90YWJsZVwiO1xuXG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogXCJyb290XCJcbn0pXG5leHBvcnQgY2xhc3MgRG9tU2VydmljZSBpbXBsZW1lbnRzIERvbVNlcnZpY2VJZiB7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcmVhZG9ubHkgcmVuZGVyZXI6IFJlbmRlcmVyMixcbiAgKSB7XG4gIH1cblxuICBzZXRTdHlsZShlbDogYW55LCBzdHlsZTogc3RyaW5nLCB2YWx1ZTogYW55KTogYW55IHtcbiAgICB0aGlzLnJlbmRlcmVyLnNldFN0eWxlKGVsLCBzdHlsZSwgdmFsdWUpO1xuICAgIHJldHVybiBlbDtcbiAgfTtcblxuXG4gIGFwcGVuZFRleHQocGFyZW50OiBIVE1MRGl2RWxlbWVudCwgdGV4dDogc3RyaW5nKTogSFRNTERpdkVsZW1lbnQge1xuICAgIGNvbnN0IGRpdiA9IHRoaXMucmVuZGVyZXIuY3JlYXRlVGV4dCh0ZXh0KTtcbiAgICB0aGlzLnJlbmRlcmVyLmFwcGVuZENoaWxkKHBhcmVudCwgZGl2KTtcbiAgICByZXR1cm4gZGl2O1xuICB9XG5cblxuICBhZGRDbGFzcyhkaXY6IEhUTUxEaXZFbGVtZW50LCBjbGF6ejogc3RyaW5nKSB7XG4gICAgaWYgKGNsYXp6LmluY2x1ZGVzKCcgJykpIHtcbiAgICAgIGNsYXp6LnNwbGl0KCcgJykuZm9yRWFjaChjID0+IHRoaXMucmVuZGVyZXIuYWRkQ2xhc3MoZGl2LCBjKSlcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5yZW5kZXJlci5hZGRDbGFzcyhkaXYsIGNsYXp6KTtcbiAgICB9XG4gICAgcmV0dXJuIGRpdjtcbiAgfVxuXG4gIGFwcGVuZENoaWxkKHBhcmVudDogSFRNTEVsZW1lbnQsIGNoaWxkOiBIVE1MRWxlbWVudCk6IHZvaWQge1xuICAgIHRoaXMucmVuZGVyZXIuYXBwZW5kQ2hpbGQocGFyZW50LCBjaGlsZCk7XG4gIH1cblxuICBjcmVhdGVFbGVtZW50PFQ+KG5hbWU6IHN0cmluZyk6IFQge1xuICAgIHJldHVybiB0aGlzLnJlbmRlcmVyLmNyZWF0ZUVsZW1lbnQobmFtZSk7XG4gIH1cblxuICBjcmVhdGVUZXh0KHRleHQ6IHN0cmluZyk6IEhUTUxFbGVtZW50IHtcbiAgICByZXR1cm4gdGhpcy5yZW5kZXJlci5jcmVhdGVUZXh0KHRleHQpO1xuICB9XG5cbiAgc2V0QXR0cmlidXRlKGVsZTogSFRNTEVsZW1lbnQsIGtleTogc3RyaW5nLCB2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5yZW5kZXJlci5zZXRBdHRyaWJ1dGUoZWxlLCBrZXksIHZhbHVlKTtcbiAgfVxuXG5cbn1cbiJdfQ==
@@ -0,0 +1,22 @@
1
+ import { ApplicationRef, EnvironmentInjector, Injectable, NgZone } from "@angular/core";
2
+ import { RendererWrapper } from "./renderer-wrapper";
3
+ import * as i0 from "@angular/core";
4
+ export class RenderWrapperFactory {
5
+ constructor(appRef, injector, zone) {
6
+ this.appRef = appRef;
7
+ this.injector = injector;
8
+ this.zone = zone;
9
+ }
10
+ create(componentType, cdr) {
11
+ return new RendererWrapper(componentType, this.appRef, this.injector, cdr, this.zone);
12
+ }
13
+ }
14
+ RenderWrapperFactory.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RenderWrapperFactory, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable });
15
+ RenderWrapperFactory.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RenderWrapperFactory, providedIn: "root" });
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RenderWrapperFactory, decorators: [{
17
+ type: Injectable,
18
+ args: [{
19
+ providedIn: "root"
20
+ }]
21
+ }], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: i0.NgZone }]; } });
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLXdyYXBwZXItZmFjdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci10YWJsZS9zcmMvbGliL2FuZ3VsYXItdGFibGUvc2VydmljZS9yZW5kZXItd3JhcHBlci1mYWN0b3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxjQUFjLEVBQXFCLG1CQUFtQixFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQU8sTUFBTSxlQUFlLENBQUM7QUFFL0csT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLG9CQUFvQixDQUFDOztBQUtuRCxNQUFNLE9BQU8sb0JBQW9CO0lBRS9CLFlBQ21CLE1BQXNCLEVBQ3RCLFFBQTZCLEVBQzdCLElBQVk7UUFGWixXQUFNLEdBQU4sTUFBTSxDQUFnQjtRQUN0QixhQUFRLEdBQVIsUUFBUSxDQUFxQjtRQUM3QixTQUFJLEdBQUosSUFBSSxDQUFRO0lBRS9CLENBQUM7SUFFRCxNQUFNLENBQ0osYUFBMkMsRUFDM0MsR0FBc0I7UUFFdEIsT0FBTyxJQUFJLGVBQWUsQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLEdBQUcsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEYsQ0FBQzs7a0hBZFUsb0JBQW9CO3NIQUFwQixvQkFBb0IsY0FGbkIsTUFBTTs0RkFFUCxvQkFBb0I7a0JBSGhDLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBcHBsaWNhdGlvblJlZiwgQ2hhbmdlRGV0ZWN0b3JSZWYsIEVudmlyb25tZW50SW5qZWN0b3IsIEluamVjdGFibGUsIE5nWm9uZSwgVHlwZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7Q29tcG9uZW50UmVuZGVyZXJJZn0gZnJvbSBcIi4uL2NvbXBvbmVudC1yZW5kZXJlci5pZlwiO1xuaW1wb3J0IHtSZW5kZXJlcldyYXBwZXJ9IGZyb20gXCIuL3JlbmRlcmVyLXdyYXBwZXJcIjtcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiBcInJvb3RcIlxufSlcbmV4cG9ydCBjbGFzcyBSZW5kZXJXcmFwcGVyRmFjdG9yeSB7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSByZWFkb25seSBhcHBSZWY6IEFwcGxpY2F0aW9uUmVmLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgaW5qZWN0b3I6IEVudmlyb25tZW50SW5qZWN0b3IsXG4gICAgcHJpdmF0ZSByZWFkb25seSB6b25lOiBOZ1pvbmVcbiAgKSB7XG4gIH1cblxuICBjcmVhdGU8VD4oXG4gICAgY29tcG9uZW50VHlwZTogVHlwZTxDb21wb25lbnRSZW5kZXJlcklmPFQ+PixcbiAgICBjZHI6IENoYW5nZURldGVjdG9yUmVmXG4gICkge1xuICAgIHJldHVybiBuZXcgUmVuZGVyZXJXcmFwcGVyKGNvbXBvbmVudFR5cGUsIHRoaXMuYXBwUmVmLCB0aGlzLmluamVjdG9yLCBjZHIsIHRoaXMuem9uZSk7XG4gIH1cblxufVxuIl19
@@ -0,0 +1,44 @@
1
+ import { createComponent, EventEmitter } from "@angular/core";
2
+ import { Subject, takeUntil } from "rxjs";
3
+ export class RendererWrapper {
4
+ constructor(componentType, appRef, injector, cdr, zone) {
5
+ this.componentType = componentType;
6
+ this.appRef = appRef;
7
+ this.injector = injector;
8
+ this.cdr = cdr;
9
+ this.zone = zone;
10
+ this.event$ = new EventEmitter();
11
+ this.closed$ = new Subject();
12
+ }
13
+ render(cellDiv, rowIndex, columnIndex, areaIdent, areaModel, cellValue, domService) {
14
+ const componentRef = createComponent(this.componentType, {
15
+ environmentInjector: this.injector
16
+ });
17
+ componentRef.instance.setData(rowIndex, columnIndex, areaIdent, areaModel, cellValue);
18
+ const emmiterNames = Object.keys(componentRef.instance)
19
+ .filter(key => {
20
+ // @ts-ignore
21
+ const t = componentRef.instance[key];
22
+ return t['subscribe'];
23
+ });
24
+ // @ts-ignore
25
+ const observables = (emmiterNames.map(key => componentRef.instance[key]));
26
+ observables.forEach(obs => obs
27
+ .pipe(takeUntil(this.closed$))
28
+ .subscribe((event) => {
29
+ console.info('RendererWrapper event >', event); // TODO hmm?
30
+ this.event$.next(event);
31
+ }));
32
+ cellDiv.appendChild(componentRef.location.nativeElement);
33
+ this.appRef.attachView(componentRef.hostView);
34
+ this.zone.run(() => {
35
+ this.cdr.detectChanges();
36
+ });
37
+ return () => {
38
+ // clean up:
39
+ this.appRef.detachView(componentRef.hostView);
40
+ this.closed$.next(Date.now());
41
+ };
42
+ }
43
+ }
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyZXItd3JhcHBlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci10YWJsZS9zcmMvbGliL2FuZ3VsYXItdGFibGUvc2VydmljZS9yZW5kZXJlci13cmFwcGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFHTCxlQUFlLEVBRWYsWUFBWSxFQUdiLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBQyxPQUFPLEVBQUUsU0FBUyxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBSXhDLE1BQU0sT0FBTyxlQUFlO0lBTTFCLFlBQ1UsYUFBMkMsRUFDM0MsTUFBc0IsRUFDdEIsUUFBNkIsRUFDN0IsR0FBc0IsRUFDYixJQUFZO1FBSnJCLGtCQUFhLEdBQWIsYUFBYSxDQUE4QjtRQUMzQyxXQUFNLEdBQU4sTUFBTSxDQUFnQjtRQUN0QixhQUFRLEdBQVIsUUFBUSxDQUFxQjtRQUM3QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQUNiLFNBQUksR0FBSixJQUFJLENBQVE7UUFSZixXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUNoQyxZQUFPLEdBQUcsSUFBSSxPQUFPLEVBQVUsQ0FBQztJQVNqRCxDQUFDO0lBRUQsTUFBTSxDQUNKLE9BQXVCLEVBQ3ZCLFFBQWdCLEVBQ2hCLFdBQW1CLEVBQ25CLFNBQW9CLEVBQ3BCLFNBQXNCLEVBQ3RCLFNBQWMsRUFDZCxVQUF3QjtRQUV4QixNQUFNLFlBQVksR0FBRyxlQUFlLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUN2RCxtQkFBbUIsRUFBRSxJQUFJLENBQUMsUUFBUTtTQUNuQyxDQUFDLENBQUM7UUFDSCxZQUFZLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FDM0IsUUFBUSxFQUNSLFdBQVcsRUFDWCxTQUFTLEVBQ1QsU0FBUyxFQUNULFNBQVMsQ0FBQyxDQUFDO1FBR2IsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDO2FBQ3BELE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUNaLGFBQWE7WUFDYixNQUFNLENBQUMsR0FBRyxZQUFZLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ3JDLE9BQU8sQ0FBQyxDQUFDLFdBQVcsQ0FBQyxDQUFBO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO1FBRUwsYUFBYTtRQUNiLE1BQU0sV0FBVyxHQUFpQixDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBRSxZQUFZLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBZ0IsQ0FBQyxDQUFDLENBQUM7UUFDeEcsV0FBVyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUc7YUFDM0IsSUFBSSxDQUNILFNBQVMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQ3hCO2FBQ0EsU0FBUyxDQUFDLENBQUMsS0FBVSxFQUFFLEVBQUU7WUFDeEIsT0FBTyxDQUFDLElBQUksQ0FBQyx5QkFBeUIsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLFlBQVk7WUFDNUQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDMUIsQ0FBQyxDQUFDLENBQ0gsQ0FBQztRQUVGLE9BQU8sQ0FBQyxXQUFXLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUV6RCxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFOUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFO1lBQ2pCLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLEdBQUcsRUFBRTtZQUNWLFlBQVk7WUFDWixJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDOUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUM7UUFDaEMsQ0FBQyxDQUFDO0lBQ0osQ0FBQztDQUdGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBcmVhSWRlbnQsIEFyZWFNb2RlbElmLCBDZWxsUmVuZGVyZXJJZiwgRG9tU2VydmljZUlmLCBSZW5kZXJlckNsZWFudXBGblR5cGV9IGZyb20gXCJAZ3VpZXhwZXJ0L3RhYmxlXCI7XG5pbXBvcnQge1xuICBBcHBsaWNhdGlvblJlZixcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gIGNyZWF0ZUNvbXBvbmVudCxcbiAgRW52aXJvbm1lbnRJbmplY3RvcixcbiAgRXZlbnRFbWl0dGVyLFxuICBOZ1pvbmUsXG4gIFR5cGVcbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7Q29tcG9uZW50UmVuZGVyZXJJZn0gZnJvbSBcIi4uL2NvbXBvbmVudC1yZW5kZXJlci5pZlwiO1xuaW1wb3J0IHtTdWJqZWN0LCB0YWtlVW50aWx9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQge09ic2VydmFibGV9IGZyb20gXCJyeGpzL2ludGVybmFsL09ic2VydmFibGVcIjtcblxuXG5leHBvcnQgY2xhc3MgUmVuZGVyZXJXcmFwcGVyPFQgZXh0ZW5kcyBDb21wb25lbnRSZW5kZXJlcklmPFQ+PlxuICBpbXBsZW1lbnRzIENlbGxSZW5kZXJlcklmIHtcblxuICBwdWJsaWMgcmVhZG9ubHkgZXZlbnQkID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG4gIHByaXZhdGUgcmVhZG9ubHkgY2xvc2VkJCA9IG5ldyBTdWJqZWN0PG51bWJlcj4oKTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGNvbXBvbmVudFR5cGU6IFR5cGU8Q29tcG9uZW50UmVuZGVyZXJJZjxUPj4sXG4gICAgcHJpdmF0ZSBhcHBSZWY6IEFwcGxpY2F0aW9uUmVmLFxuICAgIHByaXZhdGUgaW5qZWN0b3I6IEVudmlyb25tZW50SW5qZWN0b3IsXG4gICAgcHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgem9uZTogTmdab25lXG4gICkge1xuICB9XG5cbiAgcmVuZGVyKFxuICAgIGNlbGxEaXY6IEhUTUxEaXZFbGVtZW50LFxuICAgIHJvd0luZGV4OiBudW1iZXIsXG4gICAgY29sdW1uSW5kZXg6IG51bWJlcixcbiAgICBhcmVhSWRlbnQ6IEFyZWFJZGVudCxcbiAgICBhcmVhTW9kZWw6IEFyZWFNb2RlbElmLFxuICAgIGNlbGxWYWx1ZTogYW55LFxuICAgIGRvbVNlcnZpY2U6IERvbVNlcnZpY2VJZik6IFJlbmRlcmVyQ2xlYW51cEZuVHlwZSB8IHVuZGVmaW5lZCB7XG5cbiAgICBjb25zdCBjb21wb25lbnRSZWYgPSBjcmVhdGVDb21wb25lbnQodGhpcy5jb21wb25lbnRUeXBlLCB7XG4gICAgICBlbnZpcm9ubWVudEluamVjdG9yOiB0aGlzLmluamVjdG9yXG4gICAgfSk7XG4gICAgY29tcG9uZW50UmVmLmluc3RhbmNlLnNldERhdGEoXG4gICAgICByb3dJbmRleCxcbiAgICAgIGNvbHVtbkluZGV4LFxuICAgICAgYXJlYUlkZW50LFxuICAgICAgYXJlYU1vZGVsLFxuICAgICAgY2VsbFZhbHVlKTtcblxuXG4gICAgY29uc3QgZW1taXRlck5hbWVzID0gT2JqZWN0LmtleXMoY29tcG9uZW50UmVmLmluc3RhbmNlKVxuICAgICAgLmZpbHRlcihrZXkgPT4ge1xuICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgIGNvbnN0IHQgPSBjb21wb25lbnRSZWYuaW5zdGFuY2Vba2V5XTtcbiAgICAgICAgcmV0dXJuIHRbJ3N1YnNjcmliZSddXG4gICAgICB9KTtcblxuICAgIC8vIEB0cy1pZ25vcmVcbiAgICBjb25zdCBvYnNlcnZhYmxlczogT2JzZXJ2YWJsZVtdID0gKGVtbWl0ZXJOYW1lcy5tYXAoa2V5ID0+IChjb21wb25lbnRSZWYuaW5zdGFuY2Vba2V5XSBhcyBPYnNlcnZhYmxlKSkpO1xuICAgIG9ic2VydmFibGVzLmZvckVhY2gob2JzID0+IG9ic1xuICAgICAgLnBpcGUoXG4gICAgICAgIHRha2VVbnRpbCh0aGlzLmNsb3NlZCQpXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKChldmVudDogYW55KSA9PiB7XG4gICAgICAgIGNvbnNvbGUuaW5mbygnUmVuZGVyZXJXcmFwcGVyIGV2ZW50ID4nLCBldmVudCk7IC8vIFRPRE8gaG1tP1xuICAgICAgICB0aGlzLmV2ZW50JC5uZXh0KGV2ZW50KTtcbiAgICAgIH0pXG4gICAgKTtcblxuICAgIGNlbGxEaXYuYXBwZW5kQ2hpbGQoY29tcG9uZW50UmVmLmxvY2F0aW9uLm5hdGl2ZUVsZW1lbnQpO1xuXG4gICAgdGhpcy5hcHBSZWYuYXR0YWNoVmlldyhjb21wb25lbnRSZWYuaG9zdFZpZXcpO1xuXG4gICAgdGhpcy56b25lLnJ1bigoKSA9PiB7XG4gICAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgfSk7XG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgLy8gY2xlYW4gdXA6XG4gICAgICB0aGlzLmFwcFJlZi5kZXRhY2hWaWV3KGNvbXBvbmVudFJlZi5ob3N0Vmlldyk7XG4gICAgICB0aGlzLmNsb3NlZCQubmV4dChEYXRlLm5vdygpKTtcbiAgICB9O1xuICB9XG5cblxufVxuIl19
@@ -0,0 +1,104 @@
1
+ import { ChangeDetectionStrategy, Component, ElementRef, Input, NgZone, Output, Renderer2 } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { debounceTime, Subject, takeWhile } from "rxjs";
4
+ import { TableOptions, TableScope } from "@guiexpert/table";
5
+ import { DomService } from "./service/dom-service";
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "./service/dom-service";
8
+ export class TableComponent {
9
+ constructor(renderer, elementRef, zone, domService) {
10
+ this.renderer = renderer;
11
+ this.elementRef = elementRef;
12
+ this.zone = zone;
13
+ this.domService = domService;
14
+ this.tableReady = new Subject();
15
+ this.mouseMoved = new Subject();
16
+ this.mouseDragging = new Subject();
17
+ this.mouseDraggingEnded = new Subject();
18
+ this.contextmenu = new Subject();
19
+ this.mouseClicked = new Subject();
20
+ this.modelChanged = new Subject();
21
+ this.checkboxChanged = new Subject();
22
+ this.tableOptions = new TableOptions();
23
+ this.debounceMouseClickDelay = 150;
24
+ this.debounceMouseClick = new Subject();
25
+ this.alive = true;
26
+ this._if = true;
27
+ }
28
+ set tableIf(value) {
29
+ this._if = value;
30
+ Promise.resolve().then(this.initModel.bind(this));
31
+ }
32
+ onContextmenu(evt) {
33
+ this.contextmenu.next(evt);
34
+ }
35
+ onMouseMoved(evt) {
36
+ this.mouseMoved.next(evt);
37
+ }
38
+ // will be called by table-scope:
39
+ onMouseClicked(evt) {
40
+ this.debounceMouseClick.next(evt);
41
+ }
42
+ onCheckboxChanged(arr) {
43
+ this.checkboxChanged.next(arr);
44
+ }
45
+ onModelChanged(evt) {
46
+ this.modelChanged.next(evt);
47
+ }
48
+ ngOnInit() {
49
+ this.initModel();
50
+ this.debounceMouseClick
51
+ .pipe(debounceTime(this.debounceMouseClickDelay), takeWhile(() => this.alive))
52
+ .subscribe((value) => this.mouseClicked.next(value));
53
+ }
54
+ ngOnDestroy() {
55
+ this.alive = false;
56
+ }
57
+ initModel() {
58
+ this.zone.runOutsideAngular(this.init.bind(this));
59
+ }
60
+ init() {
61
+ if (this.tableModel) {
62
+ this.tableScope = new TableScope(this.elementRef.nativeElement, this.tableModel, this.domService, this.tableOptions, this);
63
+ this.tableScope.firstInit();
64
+ this.tableReady.next(this.tableScope.getApi());
65
+ }
66
+ }
67
+ onMouseDragging(evt) {
68
+ this.mouseDragging.next(evt);
69
+ }
70
+ onMouseDraggingEnd(evt) {
71
+ this.mouseDraggingEnded.next(evt);
72
+ }
73
+ }
74
+ TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: i1.DomService }], target: i0.ɵɵFactoryTarget.Component });
75
+ TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TableComponent, isStandalone: true, selector: "guiexpert-table", inputs: { tableModel: "tableModel", tableOptions: "tableOptions", debounceMouseClickDelay: "debounceMouseClickDelay", tableIf: "tableIf" }, outputs: { tableReady: "tableReady", mouseMoved: "mouseMoved", mouseDragging: "mouseDragging", mouseDraggingEnded: "mouseDraggingEnded", contextmenu: "contextmenu", mouseClicked: "mouseClicked", modelChanged: "modelChanged", checkboxChanged: "checkboxChanged" }, providers: [DomService], ngImport: i0, template: '', isInline: true, styles: [".ge-table-col-div{text-align:center;line-height:2.5;-webkit-user-select:none;user-select:none}.ge-table-label-div{padding:0;display:block;text-overflow:ellipsis;overflow:hidden}.ge-cell-error{color:#e00034}.ge-table-selected-range{background-color:#0098db66}.ge-table-col-resize-handle:hover{background-color:#0ff}.ge-table-drop-zone{background-color:#f4fff299}.ge-table-dragged-col-div{background-color:#e0ffff}.ge-table-focus-border{background-color:#0ff}.ge-table-label-div .ge-table-label{padding-left:10px;padding-right:10px}.ge-table-text-align-left{text-align:left}.ge-table-text-align-right{text-align:right}.ge-table-text-align-center{text-align:center}.ge-table-row-checkbox-div{padding-left:14px}.ge-table-header,.ge-table-footer{background-color:#e9e9e980}.ge-table-body-west,.ge-table-body-east{background-color:#f4f4f480}.ge-table-hover-column,.ge-table-hover-row{background-color:#e0ffff80}.ge-table-west-fixed-column-border,.ge-table-east-fixed-column-border,.ge-table-footer-border,.ge-table-header-border{background-color:#bbb}.ge-table-row-border{background-color:#ddd}.ge-table-column-border{background-color:#dadada}.ge-table-col-div.ge-table-col-div-0.ge-table-tree-cell{text-align:left}.ge-table-tree-cell .ge-table-label-div{padding-left:0;padding-right:10px;display:inline}.gt-tree-arrow-collapsed{color:red}.ge-table-col-tree{text-align:left}.ge-table-col-tree.ge-table-tree-deep-0{padding-left:16px}.ge-table-col-tree.ge-table-tree-deep-1{padding-left:36px}.ge-table-col-tree.ge-table-tree-deep-2{padding-left:56px}.ge-table-col-tree.ge-table-tree-deep-3{padding-left:76px}.ge-table-col-tree.ge-table-tree-deep-4{padding-left:96px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:116px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:136px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
76
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableComponent, decorators: [{
77
+ type: Component,
78
+ args: [{ selector: 'guiexpert-table', standalone: true, imports: [CommonModule], providers: [DomService], template: '', changeDetection: ChangeDetectionStrategy.OnPush, styles: [".ge-table-col-div{text-align:center;line-height:2.5;-webkit-user-select:none;user-select:none}.ge-table-label-div{padding:0;display:block;text-overflow:ellipsis;overflow:hidden}.ge-cell-error{color:#e00034}.ge-table-selected-range{background-color:#0098db66}.ge-table-col-resize-handle:hover{background-color:#0ff}.ge-table-drop-zone{background-color:#f4fff299}.ge-table-dragged-col-div{background-color:#e0ffff}.ge-table-focus-border{background-color:#0ff}.ge-table-label-div .ge-table-label{padding-left:10px;padding-right:10px}.ge-table-text-align-left{text-align:left}.ge-table-text-align-right{text-align:right}.ge-table-text-align-center{text-align:center}.ge-table-row-checkbox-div{padding-left:14px}.ge-table-header,.ge-table-footer{background-color:#e9e9e980}.ge-table-body-west,.ge-table-body-east{background-color:#f4f4f480}.ge-table-hover-column,.ge-table-hover-row{background-color:#e0ffff80}.ge-table-west-fixed-column-border,.ge-table-east-fixed-column-border,.ge-table-footer-border,.ge-table-header-border{background-color:#bbb}.ge-table-row-border{background-color:#ddd}.ge-table-column-border{background-color:#dadada}.ge-table-col-div.ge-table-col-div-0.ge-table-tree-cell{text-align:left}.ge-table-tree-cell .ge-table-label-div{padding-left:0;padding-right:10px;display:inline}.gt-tree-arrow-collapsed{color:red}.ge-table-col-tree{text-align:left}.ge-table-col-tree.ge-table-tree-deep-0{padding-left:16px}.ge-table-col-tree.ge-table-tree-deep-1{padding-left:36px}.ge-table-col-tree.ge-table-tree-deep-2{padding-left:56px}.ge-table-col-tree.ge-table-tree-deep-3{padding-left:76px}.ge-table-col-tree.ge-table-tree-deep-4{padding-left:96px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:116px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:136px}\n"] }]
79
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: i1.DomService }]; }, propDecorators: { tableReady: [{
80
+ type: Output
81
+ }], mouseMoved: [{
82
+ type: Output
83
+ }], mouseDragging: [{
84
+ type: Output
85
+ }], mouseDraggingEnded: [{
86
+ type: Output
87
+ }], contextmenu: [{
88
+ type: Output
89
+ }], mouseClicked: [{
90
+ type: Output
91
+ }], modelChanged: [{
92
+ type: Output
93
+ }], checkboxChanged: [{
94
+ type: Output
95
+ }], tableModel: [{
96
+ type: Input
97
+ }], tableOptions: [{
98
+ type: Input
99
+ }], debounceMouseClickDelay: [{
100
+ type: Input
101
+ }], tableIf: [{
102
+ type: Input
103
+ }] } });
104
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRhYmxlL3NyYy9saWIvYW5ndWxhci10YWJsZS90YWJsZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsVUFBVSxFQUNWLEtBQUssRUFDTCxNQUFNLEVBR04sTUFBTSxFQUNOLFNBQVMsRUFDVixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLFlBQVksRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBQ3RELE9BQU8sRUFNTCxZQUFZLEVBRVosVUFBVSxFQUNYLE1BQU0sa0JBQWtCLENBQUM7QUFDMUIsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHVCQUF1QixDQUFDOzs7QUFZakQsTUFBTSxPQUFPLGNBQWM7SUEwQ3pCLFlBQ21CLFFBQW1CLEVBQ25CLFVBQXNCLEVBQ3RCLElBQVksRUFDWixVQUFzQjtRQUh0QixhQUFRLEdBQVIsUUFBUSxDQUFXO1FBQ25CLGVBQVUsR0FBVixVQUFVLENBQVk7UUFDdEIsU0FBSSxHQUFKLElBQUksQ0FBUTtRQUNaLGVBQVUsR0FBVixVQUFVLENBQVk7UUEzQ3pDLGVBQVUsR0FBRyxJQUFJLE9BQU8sRUFBWSxDQUFDO1FBR3JDLGVBQVUsR0FBMEIsSUFBSSxPQUFPLEVBQWdCLENBQUM7UUFHaEUsa0JBQWEsR0FBMEIsSUFBSSxPQUFPLEVBQWdCLENBQUM7UUFHbkUsdUJBQWtCLEdBQTBCLElBQUksT0FBTyxFQUFnQixDQUFDO1FBR3hFLGdCQUFXLEdBQTBCLElBQUksT0FBTyxFQUFnQixDQUFDO1FBR2pFLGlCQUFZLEdBQTBCLElBQUksT0FBTyxFQUFnQixDQUFDO1FBR2xFLGlCQUFZLEdBQWdDLElBQUksT0FBTyxFQUFzQixDQUFDO1FBRzlFLG9CQUFlLEdBQW1CLElBQUksT0FBTyxFQUFTLENBQUM7UUFNdkQsaUJBQVksR0FBbUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUdsRCw0QkFBdUIsR0FBVyxHQUFHLENBQUM7UUFFOUIsdUJBQWtCLEdBQTBCLElBQUksT0FBTyxFQUFnQixDQUFDO1FBR3hFLFVBQUssR0FBRyxJQUFJLENBQUM7UUFDYixRQUFHLEdBQVksSUFBSSxDQUFDO0lBVTVCLENBQUM7SUFFRCxJQUNJLE9BQU8sQ0FBQyxLQUFjO1FBQ3hCLElBQUksQ0FBQyxHQUFHLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsYUFBYSxDQUFDLEdBQWlCO1FBQzdCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFFRCxZQUFZLENBQUMsR0FBaUI7UUFDNUIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDNUIsQ0FBQztJQUVELGlDQUFpQztJQUNqQyxjQUFjLENBQUMsR0FBaUI7UUFDOUIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQsaUJBQWlCLENBQUMsR0FBVTtRQUMxQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRUQsY0FBYyxDQUFDLEdBQXVCO1FBQ3BDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxrQkFBa0I7YUFDcEIsSUFBSSxDQUNILFlBQVksQ0FBQyxJQUFJLENBQUMsdUJBQXVCLENBQUMsRUFDMUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FDNUI7YUFDQSxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUNyQixDQUFDO0lBR08sU0FBUztRQUNmLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRU8sSUFBSTtRQUNWLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNuQixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksVUFBVSxDQUM5QixJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLFlBQVksRUFBRSxJQUFJLENBQ3pGLENBQUM7WUFDRixJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQzVCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztTQUNoRDtJQUNILENBQUM7SUFFRCxlQUFlLENBQUMsR0FBaUI7UUFDL0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVELGtCQUFrQixDQUFDLEdBQWlCO1FBQ2xDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDcEMsQ0FBQzs7NEdBakhVLGNBQWM7Z0dBQWQsY0FBYyxpZEFMZCxDQUFDLFVBQVUsQ0FBQywwQkFDYixFQUFFLDJ6REFGRixZQUFZOzRGQU1YLGNBQWM7a0JBVDFCLFNBQVM7K0JBQ0UsaUJBQWlCLGNBQ2YsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLGFBQ1osQ0FBQyxVQUFVLENBQUMsWUFDYixFQUFFLG1CQUVLLHVCQUF1QixDQUFDLE1BQU07dUtBSy9DLFVBQVU7c0JBRFQsTUFBTTtnQkFJUCxVQUFVO3NCQURULE1BQU07Z0JBSVAsYUFBYTtzQkFEWixNQUFNO2dCQUlQLGtCQUFrQjtzQkFEakIsTUFBTTtnQkFJUCxXQUFXO3NCQURWLE1BQU07Z0JBSVAsWUFBWTtzQkFEWCxNQUFNO2dCQUlQLFlBQVk7c0JBRFgsTUFBTTtnQkFJUCxlQUFlO3NCQURkLE1BQU07Z0JBSVAsVUFBVTtzQkFEVCxLQUFLO2dCQUlOLFlBQVk7c0JBRFgsS0FBSztnQkFJTix1QkFBdUI7c0JBRHRCLEtBQUs7Z0JBb0JGLE9BQU87c0JBRFYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIElucHV0LFxuICBOZ1pvbmUsXG4gIE9uRGVzdHJveSxcbiAgT25Jbml0LFxuICBPdXRwdXQsXG4gIFJlbmRlcmVyMlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtkZWJvdW5jZVRpbWUsIFN1YmplY3QsIHRha2VXaGlsZX0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7XG4gIEV2ZW50TGlzdGVuZXJJZixcbiAgR2VNb2RlbENoYW5nZUV2ZW50LFxuICBHZU1vdXNlRXZlbnQsXG4gIFRhYmxlQXBpLFxuICBUYWJsZU1vZGVsSWYsXG4gIFRhYmxlT3B0aW9ucyxcbiAgVGFibGVPcHRpb25zSWYsXG4gIFRhYmxlU2NvcGVcbn0gZnJvbSBcIkBndWlleHBlcnQvdGFibGVcIjtcbmltcG9ydCB7RG9tU2VydmljZX0gZnJvbSBcIi4vc2VydmljZS9kb20tc2VydmljZVwiO1xuXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2d1aWV4cGVydC10YWJsZScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBwcm92aWRlcnM6IFtEb21TZXJ2aWNlXSxcbiAgdGVtcGxhdGU6ICcnLFxuICBzdHlsZVVybHM6IFsnLi90YWJsZS5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3ksIEV2ZW50TGlzdGVuZXJJZiB7XG5cbiAgQE91dHB1dCgpXG4gIHRhYmxlUmVhZHkgPSBuZXcgU3ViamVjdDxUYWJsZUFwaT4oKTtcblxuICBAT3V0cHV0KClcbiAgbW91c2VNb3ZlZDogU3ViamVjdDxHZU1vdXNlRXZlbnQ+ID0gbmV3IFN1YmplY3Q8R2VNb3VzZUV2ZW50PigpO1xuXG4gIEBPdXRwdXQoKVxuICBtb3VzZURyYWdnaW5nOiBTdWJqZWN0PEdlTW91c2VFdmVudD4gPSBuZXcgU3ViamVjdDxHZU1vdXNlRXZlbnQ+KCk7XG5cbiAgQE91dHB1dCgpXG4gIG1vdXNlRHJhZ2dpbmdFbmRlZDogU3ViamVjdDxHZU1vdXNlRXZlbnQ+ID0gbmV3IFN1YmplY3Q8R2VNb3VzZUV2ZW50PigpO1xuXG4gIEBPdXRwdXQoKVxuICBjb250ZXh0bWVudTogU3ViamVjdDxHZU1vdXNlRXZlbnQ+ID0gbmV3IFN1YmplY3Q8R2VNb3VzZUV2ZW50PigpO1xuXG4gIEBPdXRwdXQoKVxuICBtb3VzZUNsaWNrZWQ6IFN1YmplY3Q8R2VNb3VzZUV2ZW50PiA9IG5ldyBTdWJqZWN0PEdlTW91c2VFdmVudD4oKTtcblxuICBAT3V0cHV0KClcbiAgbW9kZWxDaGFuZ2VkOiBTdWJqZWN0PEdlTW9kZWxDaGFuZ2VFdmVudD4gPSBuZXcgU3ViamVjdDxHZU1vZGVsQ2hhbmdlRXZlbnQ+KCk7XG5cbiAgQE91dHB1dCgpXG4gIGNoZWNrYm94Q2hhbmdlZDogU3ViamVjdDxhbnlbXT4gPSBuZXcgU3ViamVjdDxhbnlbXT4oKTtcblxuICBASW5wdXQoKVxuICB0YWJsZU1vZGVsPzogVGFibGVNb2RlbElmO1xuXG4gIEBJbnB1dCgpXG4gIHRhYmxlT3B0aW9uczogVGFibGVPcHRpb25zSWYgPSBuZXcgVGFibGVPcHRpb25zKCk7XG5cbiAgQElucHV0KClcbiAgZGVib3VuY2VNb3VzZUNsaWNrRGVsYXk6IG51bWJlciA9IDE1MDtcblxuICBwcml2YXRlIGRlYm91bmNlTW91c2VDbGljazogU3ViamVjdDxHZU1vdXNlRXZlbnQ+ID0gbmV3IFN1YmplY3Q8R2VNb3VzZUV2ZW50PigpO1xuXG4gIHByaXZhdGUgdGFibGVTY29wZT86IFRhYmxlU2NvcGU7XG4gIHByaXZhdGUgYWxpdmUgPSB0cnVlO1xuICBwcml2YXRlIF9pZjogYm9vbGVhbiA9IHRydWU7XG5cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IHJlbmRlcmVyOiBSZW5kZXJlcjIsXG4gICAgcHJpdmF0ZSByZWFkb25seSBlbGVtZW50UmVmOiBFbGVtZW50UmVmLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgem9uZTogTmdab25lLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgZG9tU2VydmljZTogRG9tU2VydmljZVxuICApIHtcblxuICB9XG5cbiAgQElucHV0KClcbiAgc2V0IHRhYmxlSWYodmFsdWU6IGJvb2xlYW4pIHtcbiAgICB0aGlzLl9pZiA9IHZhbHVlO1xuICAgIFByb21pc2UucmVzb2x2ZSgpLnRoZW4odGhpcy5pbml0TW9kZWwuYmluZCh0aGlzKSk7XG4gIH1cblxuICBvbkNvbnRleHRtZW51KGV2dDogR2VNb3VzZUV2ZW50KTogdm9pZCB7XG4gICAgdGhpcy5jb250ZXh0bWVudS5uZXh0KGV2dCk7XG4gIH1cblxuICBvbk1vdXNlTW92ZWQoZXZ0OiBHZU1vdXNlRXZlbnQpOiB2b2lkIHtcbiAgICB0aGlzLm1vdXNlTW92ZWQubmV4dChldnQpO1xuICB9XG5cbiAgLy8gd2lsbCBiZSBjYWxsZWQgYnkgdGFibGUtc2NvcGU6XG4gIG9uTW91c2VDbGlja2VkKGV2dDogR2VNb3VzZUV2ZW50KTogdm9pZCB7XG4gICAgdGhpcy5kZWJvdW5jZU1vdXNlQ2xpY2submV4dChldnQpO1xuICB9XG5cbiAgb25DaGVja2JveENoYW5nZWQoYXJyOiBhbnlbXSk6IHZvaWQge1xuICAgIHRoaXMuY2hlY2tib3hDaGFuZ2VkLm5leHQoYXJyKTtcbiAgfVxuXG4gIG9uTW9kZWxDaGFuZ2VkKGV2dDogR2VNb2RlbENoYW5nZUV2ZW50KTogdm9pZCB7XG4gICAgdGhpcy5tb2RlbENoYW5nZWQubmV4dChldnQpO1xuICB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5pbml0TW9kZWwoKTtcbiAgICB0aGlzLmRlYm91bmNlTW91c2VDbGlja1xuICAgICAgLnBpcGUoXG4gICAgICAgIGRlYm91bmNlVGltZSh0aGlzLmRlYm91bmNlTW91c2VDbGlja0RlbGF5KSxcbiAgICAgICAgdGFrZVdoaWxlKCgpID0+IHRoaXMuYWxpdmUpXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKCh2YWx1ZSkgPT4gdGhpcy5tb3VzZUNsaWNrZWQubmV4dCh2YWx1ZSkpO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5hbGl2ZSA9IGZhbHNlO1xuICB9XG5cblxuICBwcml2YXRlIGluaXRNb2RlbCgpIHtcbiAgICB0aGlzLnpvbmUucnVuT3V0c2lkZUFuZ3VsYXIodGhpcy5pbml0LmJpbmQodGhpcykpO1xuICB9XG5cbiAgcHJpdmF0ZSBpbml0KCkge1xuICAgIGlmICh0aGlzLnRhYmxlTW9kZWwpIHtcbiAgICAgIHRoaXMudGFibGVTY29wZSA9IG5ldyBUYWJsZVNjb3BlKFxuICAgICAgICB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgdGhpcy50YWJsZU1vZGVsLCB0aGlzLmRvbVNlcnZpY2UsIHRoaXMudGFibGVPcHRpb25zLCB0aGlzXG4gICAgICApO1xuICAgICAgdGhpcy50YWJsZVNjb3BlLmZpcnN0SW5pdCgpO1xuICAgICAgdGhpcy50YWJsZVJlYWR5Lm5leHQodGhpcy50YWJsZVNjb3BlLmdldEFwaSgpKTtcbiAgICB9XG4gIH1cblxuICBvbk1vdXNlRHJhZ2dpbmcoZXZ0OiBHZU1vdXNlRXZlbnQpOiB2b2lkIHtcbiAgICB0aGlzLm1vdXNlRHJhZ2dpbmcubmV4dChldnQpO1xuICB9XG5cbiAgb25Nb3VzZURyYWdnaW5nRW5kKGV2dDogR2VNb3VzZUV2ZW50KTogdm9pZCB7XG4gICAgdGhpcy5tb3VzZURyYWdnaW5nRW5kZWQubmV4dChldnQpO1xuICB9XG5cblxufVxuIl19
@@ -0,0 +1,215 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Injectable, Component, ChangeDetectionStrategy, Output, Input, EventEmitter, createComponent } from '@angular/core';
3
+ import { CommonModule } from '@angular/common';
4
+ import { Subject, debounceTime, takeWhile, takeUntil } from 'rxjs';
5
+ import { TableOptions, TableScope } from '@guiexpert/table';
6
+
7
+ class DomService {
8
+ constructor(renderer) {
9
+ this.renderer = renderer;
10
+ }
11
+ setStyle(el, style, value) {
12
+ this.renderer.setStyle(el, style, value);
13
+ return el;
14
+ }
15
+ ;
16
+ appendText(parent, text) {
17
+ const div = this.renderer.createText(text);
18
+ this.renderer.appendChild(parent, div);
19
+ return div;
20
+ }
21
+ addClass(div, clazz) {
22
+ if (clazz.includes(' ')) {
23
+ clazz.split(' ').forEach(c => this.renderer.addClass(div, c));
24
+ }
25
+ else {
26
+ this.renderer.addClass(div, clazz);
27
+ }
28
+ return div;
29
+ }
30
+ appendChild(parent, child) {
31
+ this.renderer.appendChild(parent, child);
32
+ }
33
+ createElement(name) {
34
+ return this.renderer.createElement(name);
35
+ }
36
+ createText(text) {
37
+ return this.renderer.createText(text);
38
+ }
39
+ setAttribute(ele, key, value) {
40
+ this.renderer.setAttribute(ele, key, value);
41
+ }
42
+ }
43
+ DomService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DomService, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Injectable });
44
+ DomService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DomService, providedIn: "root" });
45
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DomService, decorators: [{
46
+ type: Injectable,
47
+ args: [{
48
+ providedIn: "root"
49
+ }]
50
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; } });
51
+
52
+ class TableComponent {
53
+ constructor(renderer, elementRef, zone, domService) {
54
+ this.renderer = renderer;
55
+ this.elementRef = elementRef;
56
+ this.zone = zone;
57
+ this.domService = domService;
58
+ this.tableReady = new Subject();
59
+ this.mouseMoved = new Subject();
60
+ this.mouseDragging = new Subject();
61
+ this.mouseDraggingEnded = new Subject();
62
+ this.contextmenu = new Subject();
63
+ this.mouseClicked = new Subject();
64
+ this.modelChanged = new Subject();
65
+ this.checkboxChanged = new Subject();
66
+ this.tableOptions = new TableOptions();
67
+ this.debounceMouseClickDelay = 150;
68
+ this.debounceMouseClick = new Subject();
69
+ this.alive = true;
70
+ this._if = true;
71
+ }
72
+ set tableIf(value) {
73
+ this._if = value;
74
+ Promise.resolve().then(this.initModel.bind(this));
75
+ }
76
+ onContextmenu(evt) {
77
+ this.contextmenu.next(evt);
78
+ }
79
+ onMouseMoved(evt) {
80
+ this.mouseMoved.next(evt);
81
+ }
82
+ // will be called by table-scope:
83
+ onMouseClicked(evt) {
84
+ this.debounceMouseClick.next(evt);
85
+ }
86
+ onCheckboxChanged(arr) {
87
+ this.checkboxChanged.next(arr);
88
+ }
89
+ onModelChanged(evt) {
90
+ this.modelChanged.next(evt);
91
+ }
92
+ ngOnInit() {
93
+ this.initModel();
94
+ this.debounceMouseClick
95
+ .pipe(debounceTime(this.debounceMouseClickDelay), takeWhile(() => this.alive))
96
+ .subscribe((value) => this.mouseClicked.next(value));
97
+ }
98
+ ngOnDestroy() {
99
+ this.alive = false;
100
+ }
101
+ initModel() {
102
+ this.zone.runOutsideAngular(this.init.bind(this));
103
+ }
104
+ init() {
105
+ if (this.tableModel) {
106
+ this.tableScope = new TableScope(this.elementRef.nativeElement, this.tableModel, this.domService, this.tableOptions, this);
107
+ this.tableScope.firstInit();
108
+ this.tableReady.next(this.tableScope.getApi());
109
+ }
110
+ }
111
+ onMouseDragging(evt) {
112
+ this.mouseDragging.next(evt);
113
+ }
114
+ onMouseDraggingEnd(evt) {
115
+ this.mouseDraggingEnded.next(evt);
116
+ }
117
+ }
118
+ TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: DomService }], target: i0.ɵɵFactoryTarget.Component });
119
+ TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TableComponent, isStandalone: true, selector: "guiexpert-table", inputs: { tableModel: "tableModel", tableOptions: "tableOptions", debounceMouseClickDelay: "debounceMouseClickDelay", tableIf: "tableIf" }, outputs: { tableReady: "tableReady", mouseMoved: "mouseMoved", mouseDragging: "mouseDragging", mouseDraggingEnded: "mouseDraggingEnded", contextmenu: "contextmenu", mouseClicked: "mouseClicked", modelChanged: "modelChanged", checkboxChanged: "checkboxChanged" }, providers: [DomService], ngImport: i0, template: '', isInline: true, styles: [".ge-table-col-div{text-align:center;line-height:2.5;-webkit-user-select:none;user-select:none}.ge-table-label-div{padding:0;display:block;text-overflow:ellipsis;overflow:hidden}.ge-cell-error{color:#e00034}.ge-table-selected-range{background-color:#0098db66}.ge-table-col-resize-handle:hover{background-color:#0ff}.ge-table-drop-zone{background-color:#f4fff299}.ge-table-dragged-col-div{background-color:#e0ffff}.ge-table-focus-border{background-color:#0ff}.ge-table-label-div .ge-table-label{padding-left:10px;padding-right:10px}.ge-table-text-align-left{text-align:left}.ge-table-text-align-right{text-align:right}.ge-table-text-align-center{text-align:center}.ge-table-row-checkbox-div{padding-left:14px}.ge-table-header,.ge-table-footer{background-color:#e9e9e980}.ge-table-body-west,.ge-table-body-east{background-color:#f4f4f480}.ge-table-hover-column,.ge-table-hover-row{background-color:#e0ffff80}.ge-table-west-fixed-column-border,.ge-table-east-fixed-column-border,.ge-table-footer-border,.ge-table-header-border{background-color:#bbb}.ge-table-row-border{background-color:#ddd}.ge-table-column-border{background-color:#dadada}.ge-table-col-div.ge-table-col-div-0.ge-table-tree-cell{text-align:left}.ge-table-tree-cell .ge-table-label-div{padding-left:0;padding-right:10px;display:inline}.gt-tree-arrow-collapsed{color:red}.ge-table-col-tree{text-align:left}.ge-table-col-tree.ge-table-tree-deep-0{padding-left:16px}.ge-table-col-tree.ge-table-tree-deep-1{padding-left:36px}.ge-table-col-tree.ge-table-tree-deep-2{padding-left:56px}.ge-table-col-tree.ge-table-tree-deep-3{padding-left:76px}.ge-table-col-tree.ge-table-tree-deep-4{padding-left:96px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:116px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:136px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
120
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableComponent, decorators: [{
121
+ type: Component,
122
+ args: [{ selector: 'guiexpert-table', standalone: true, imports: [CommonModule], providers: [DomService], template: '', changeDetection: ChangeDetectionStrategy.OnPush, styles: [".ge-table-col-div{text-align:center;line-height:2.5;-webkit-user-select:none;user-select:none}.ge-table-label-div{padding:0;display:block;text-overflow:ellipsis;overflow:hidden}.ge-cell-error{color:#e00034}.ge-table-selected-range{background-color:#0098db66}.ge-table-col-resize-handle:hover{background-color:#0ff}.ge-table-drop-zone{background-color:#f4fff299}.ge-table-dragged-col-div{background-color:#e0ffff}.ge-table-focus-border{background-color:#0ff}.ge-table-label-div .ge-table-label{padding-left:10px;padding-right:10px}.ge-table-text-align-left{text-align:left}.ge-table-text-align-right{text-align:right}.ge-table-text-align-center{text-align:center}.ge-table-row-checkbox-div{padding-left:14px}.ge-table-header,.ge-table-footer{background-color:#e9e9e980}.ge-table-body-west,.ge-table-body-east{background-color:#f4f4f480}.ge-table-hover-column,.ge-table-hover-row{background-color:#e0ffff80}.ge-table-west-fixed-column-border,.ge-table-east-fixed-column-border,.ge-table-footer-border,.ge-table-header-border{background-color:#bbb}.ge-table-row-border{background-color:#ddd}.ge-table-column-border{background-color:#dadada}.ge-table-col-div.ge-table-col-div-0.ge-table-tree-cell{text-align:left}.ge-table-tree-cell .ge-table-label-div{padding-left:0;padding-right:10px;display:inline}.gt-tree-arrow-collapsed{color:red}.ge-table-col-tree{text-align:left}.ge-table-col-tree.ge-table-tree-deep-0{padding-left:16px}.ge-table-col-tree.ge-table-tree-deep-1{padding-left:36px}.ge-table-col-tree.ge-table-tree-deep-2{padding-left:56px}.ge-table-col-tree.ge-table-tree-deep-3{padding-left:76px}.ge-table-col-tree.ge-table-tree-deep-4{padding-left:96px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:116px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:136px}\n"] }]
123
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: DomService }]; }, propDecorators: { tableReady: [{
124
+ type: Output
125
+ }], mouseMoved: [{
126
+ type: Output
127
+ }], mouseDragging: [{
128
+ type: Output
129
+ }], mouseDraggingEnded: [{
130
+ type: Output
131
+ }], contextmenu: [{
132
+ type: Output
133
+ }], mouseClicked: [{
134
+ type: Output
135
+ }], modelChanged: [{
136
+ type: Output
137
+ }], checkboxChanged: [{
138
+ type: Output
139
+ }], tableModel: [{
140
+ type: Input
141
+ }], tableOptions: [{
142
+ type: Input
143
+ }], debounceMouseClickDelay: [{
144
+ type: Input
145
+ }], tableIf: [{
146
+ type: Input
147
+ }] } });
148
+
149
+ class RendererWrapper {
150
+ constructor(componentType, appRef, injector, cdr, zone) {
151
+ this.componentType = componentType;
152
+ this.appRef = appRef;
153
+ this.injector = injector;
154
+ this.cdr = cdr;
155
+ this.zone = zone;
156
+ this.event$ = new EventEmitter();
157
+ this.closed$ = new Subject();
158
+ }
159
+ render(cellDiv, rowIndex, columnIndex, areaIdent, areaModel, cellValue, domService) {
160
+ const componentRef = createComponent(this.componentType, {
161
+ environmentInjector: this.injector
162
+ });
163
+ componentRef.instance.setData(rowIndex, columnIndex, areaIdent, areaModel, cellValue);
164
+ const emmiterNames = Object.keys(componentRef.instance)
165
+ .filter(key => {
166
+ // @ts-ignore
167
+ const t = componentRef.instance[key];
168
+ return t['subscribe'];
169
+ });
170
+ // @ts-ignore
171
+ const observables = (emmiterNames.map(key => componentRef.instance[key]));
172
+ observables.forEach(obs => obs
173
+ .pipe(takeUntil(this.closed$))
174
+ .subscribe((event) => {
175
+ console.info('RendererWrapper event >', event); // TODO hmm?
176
+ this.event$.next(event);
177
+ }));
178
+ cellDiv.appendChild(componentRef.location.nativeElement);
179
+ this.appRef.attachView(componentRef.hostView);
180
+ this.zone.run(() => {
181
+ this.cdr.detectChanges();
182
+ });
183
+ return () => {
184
+ // clean up:
185
+ this.appRef.detachView(componentRef.hostView);
186
+ this.closed$.next(Date.now());
187
+ };
188
+ }
189
+ }
190
+
191
+ class RenderWrapperFactory {
192
+ constructor(appRef, injector, zone) {
193
+ this.appRef = appRef;
194
+ this.injector = injector;
195
+ this.zone = zone;
196
+ }
197
+ create(componentType, cdr) {
198
+ return new RendererWrapper(componentType, this.appRef, this.injector, cdr, this.zone);
199
+ }
200
+ }
201
+ RenderWrapperFactory.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RenderWrapperFactory, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable });
202
+ RenderWrapperFactory.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RenderWrapperFactory, providedIn: "root" });
203
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RenderWrapperFactory, decorators: [{
204
+ type: Injectable,
205
+ args: [{
206
+ providedIn: "root"
207
+ }]
208
+ }], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: i0.NgZone }]; } });
209
+
210
+ /**
211
+ * Generated bundle index. Do not edit.
212
+ */
213
+
214
+ export { DomService, RenderWrapperFactory, RendererWrapper, TableComponent };
215
+ //# sourceMappingURL=guiexpert-angular-table.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"guiexpert-angular-table.mjs","sources":["../../../../libs/angular-table/src/lib/angular-table/service/dom-service.ts","../../../../libs/angular-table/src/lib/angular-table/table.component.ts","../../../../libs/angular-table/src/lib/angular-table/service/renderer-wrapper.ts","../../../../libs/angular-table/src/lib/angular-table/service/render-wrapper-factory.ts","../../../../libs/angular-table/src/guiexpert-angular-table.ts"],"sourcesContent":["import {Injectable, Renderer2} from \"@angular/core\";\nimport {DomServiceIf} from \"@guiexpert/table\";\n\n\n@Injectable({\n providedIn: \"root\"\n})\nexport class DomService implements DomServiceIf {\n\n constructor(\n readonly renderer: Renderer2,\n ) {\n }\n\n setStyle(el: any, style: string, value: any): any {\n this.renderer.setStyle(el, style, value);\n return el;\n };\n\n\n appendText(parent: HTMLDivElement, text: string): HTMLDivElement {\n const div = this.renderer.createText(text);\n this.renderer.appendChild(parent, div);\n return div;\n }\n\n\n addClass(div: HTMLDivElement, clazz: string) {\n if (clazz.includes(' ')) {\n clazz.split(' ').forEach(c => this.renderer.addClass(div, c))\n } else {\n this.renderer.addClass(div, clazz);\n }\n return div;\n }\n\n appendChild(parent: HTMLElement, child: HTMLElement): void {\n this.renderer.appendChild(parent, child);\n }\n\n createElement<T>(name: string): T {\n return this.renderer.createElement(name);\n }\n\n createText(text: string): HTMLElement {\n return this.renderer.createText(text);\n }\n\n setAttribute(ele: HTMLElement, key: string, value: string): void {\n this.renderer.setAttribute(ele, key, value);\n }\n\n\n}\n","import {\n ChangeDetectionStrategy,\n Component,\n ElementRef,\n Input,\n NgZone,\n OnDestroy,\n OnInit,\n Output,\n Renderer2\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {debounceTime, Subject, takeWhile} from \"rxjs\";\nimport {\n EventListenerIf,\n GeModelChangeEvent,\n GeMouseEvent,\n TableApi,\n TableModelIf,\n TableOptions,\n TableOptionsIf,\n TableScope\n} from \"@guiexpert/table\";\nimport {DomService} from \"./service/dom-service\";\n\n\n@Component({\n selector: 'guiexpert-table',\n standalone: true,\n imports: [CommonModule],\n providers: [DomService],\n template: '',\n styleUrls: ['./table.component.css'],\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableComponent implements OnInit, OnDestroy, EventListenerIf {\n\n @Output()\n tableReady = new Subject<TableApi>();\n\n @Output()\n mouseMoved: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n @Output()\n mouseDragging: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n @Output()\n mouseDraggingEnded: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n @Output()\n contextmenu: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n @Output()\n mouseClicked: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n @Output()\n modelChanged: Subject<GeModelChangeEvent> = new Subject<GeModelChangeEvent>();\n\n @Output()\n checkboxChanged: Subject<any[]> = new Subject<any[]>();\n\n @Input()\n tableModel?: TableModelIf;\n\n @Input()\n tableOptions: TableOptionsIf = new TableOptions();\n\n @Input()\n debounceMouseClickDelay: number = 150;\n\n private debounceMouseClick: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n private tableScope?: TableScope;\n private alive = true;\n private _if: boolean = true;\n\n\n constructor(\n private readonly renderer: Renderer2,\n private readonly elementRef: ElementRef,\n private readonly zone: NgZone,\n private readonly domService: DomService\n ) {\n\n }\n\n @Input()\n set tableIf(value: boolean) {\n this._if = value;\n Promise.resolve().then(this.initModel.bind(this));\n }\n\n onContextmenu(evt: GeMouseEvent): void {\n this.contextmenu.next(evt);\n }\n\n onMouseMoved(evt: GeMouseEvent): void {\n this.mouseMoved.next(evt);\n }\n\n // will be called by table-scope:\n onMouseClicked(evt: GeMouseEvent): void {\n this.debounceMouseClick.next(evt);\n }\n\n onCheckboxChanged(arr: any[]): void {\n this.checkboxChanged.next(arr);\n }\n\n onModelChanged(evt: GeModelChangeEvent): void {\n this.modelChanged.next(evt);\n }\n\n ngOnInit(): void {\n this.initModel();\n this.debounceMouseClick\n .pipe(\n debounceTime(this.debounceMouseClickDelay),\n takeWhile(() => this.alive)\n )\n .subscribe((value) => this.mouseClicked.next(value));\n }\n\n ngOnDestroy(): void {\n this.alive = false;\n }\n\n\n private initModel() {\n this.zone.runOutsideAngular(this.init.bind(this));\n }\n\n private init() {\n if (this.tableModel) {\n this.tableScope = new TableScope(\n this.elementRef.nativeElement, this.tableModel, this.domService, this.tableOptions, this\n );\n this.tableScope.firstInit();\n this.tableReady.next(this.tableScope.getApi());\n }\n }\n\n onMouseDragging(evt: GeMouseEvent): void {\n this.mouseDragging.next(evt);\n }\n\n onMouseDraggingEnd(evt: GeMouseEvent): void {\n this.mouseDraggingEnded.next(evt);\n }\n\n\n}\n","import {AreaIdent, AreaModelIf, CellRendererIf, DomServiceIf, RendererCleanupFnType} from \"@guiexpert/table\";\nimport {\n ApplicationRef,\n ChangeDetectorRef,\n createComponent,\n EnvironmentInjector,\n EventEmitter,\n NgZone,\n Type\n} from \"@angular/core\";\nimport {ComponentRendererIf} from \"../component-renderer.if\";\nimport {Subject, takeUntil} from \"rxjs\";\nimport {Observable} from \"rxjs/internal/Observable\";\n\n\nexport class RendererWrapper<T extends ComponentRendererIf<T>>\n implements CellRendererIf {\n\n public readonly event$ = new EventEmitter<any>();\n private readonly closed$ = new Subject<number>();\n\n constructor(\n private componentType: Type<ComponentRendererIf<T>>,\n private appRef: ApplicationRef,\n private injector: EnvironmentInjector,\n private cdr: ChangeDetectorRef,\n private readonly zone: NgZone\n ) {\n }\n\n render(\n cellDiv: HTMLDivElement,\n rowIndex: number,\n columnIndex: number,\n areaIdent: AreaIdent,\n areaModel: AreaModelIf,\n cellValue: any,\n domService: DomServiceIf): RendererCleanupFnType | undefined {\n\n const componentRef = createComponent(this.componentType, {\n environmentInjector: this.injector\n });\n componentRef.instance.setData(\n rowIndex,\n columnIndex,\n areaIdent,\n areaModel,\n cellValue);\n\n\n const emmiterNames = Object.keys(componentRef.instance)\n .filter(key => {\n // @ts-ignore\n const t = componentRef.instance[key];\n return t['subscribe']\n });\n\n // @ts-ignore\n const observables: Observable[] = (emmiterNames.map(key => (componentRef.instance[key] as Observable)));\n observables.forEach(obs => obs\n .pipe(\n takeUntil(this.closed$)\n )\n .subscribe((event: any) => {\n console.info('RendererWrapper event >', event); // TODO hmm?\n this.event$.next(event);\n })\n );\n\n cellDiv.appendChild(componentRef.location.nativeElement);\n\n this.appRef.attachView(componentRef.hostView);\n\n this.zone.run(() => {\n this.cdr.detectChanges();\n });\n\n return () => {\n // clean up:\n this.appRef.detachView(componentRef.hostView);\n this.closed$.next(Date.now());\n };\n }\n\n\n}\n","import {ApplicationRef, ChangeDetectorRef, EnvironmentInjector, Injectable, NgZone, Type} from \"@angular/core\";\nimport {ComponentRendererIf} from \"../component-renderer.if\";\nimport {RendererWrapper} from \"./renderer-wrapper\";\n\n@Injectable({\n providedIn: \"root\"\n})\nexport class RenderWrapperFactory {\n\n constructor(\n private readonly appRef: ApplicationRef,\n private readonly injector: EnvironmentInjector,\n private readonly zone: NgZone\n ) {\n }\n\n create<T>(\n componentType: Type<ComponentRendererIf<T>>,\n cdr: ChangeDetectorRef\n ) {\n return new RendererWrapper(componentType, this.appRef, this.injector, cdr, this.zone);\n }\n\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["i1.DomService"],"mappings":"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"}
@@ -0,0 +1,215 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Injectable, Component, ChangeDetectionStrategy, Output, Input, EventEmitter, createComponent } from '@angular/core';
3
+ import { CommonModule } from '@angular/common';
4
+ import { Subject, debounceTime, takeWhile, takeUntil } from 'rxjs';
5
+ import { TableOptions, TableScope } from '@guiexpert/table';
6
+
7
+ class DomService {
8
+ constructor(renderer) {
9
+ this.renderer = renderer;
10
+ }
11
+ setStyle(el, style, value) {
12
+ this.renderer.setStyle(el, style, value);
13
+ return el;
14
+ }
15
+ ;
16
+ appendText(parent, text) {
17
+ const div = this.renderer.createText(text);
18
+ this.renderer.appendChild(parent, div);
19
+ return div;
20
+ }
21
+ addClass(div, clazz) {
22
+ if (clazz.includes(' ')) {
23
+ clazz.split(' ').forEach(c => this.renderer.addClass(div, c));
24
+ }
25
+ else {
26
+ this.renderer.addClass(div, clazz);
27
+ }
28
+ return div;
29
+ }
30
+ appendChild(parent, child) {
31
+ this.renderer.appendChild(parent, child);
32
+ }
33
+ createElement(name) {
34
+ return this.renderer.createElement(name);
35
+ }
36
+ createText(text) {
37
+ return this.renderer.createText(text);
38
+ }
39
+ setAttribute(ele, key, value) {
40
+ this.renderer.setAttribute(ele, key, value);
41
+ }
42
+ }
43
+ DomService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DomService, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Injectable });
44
+ DomService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DomService, providedIn: "root" });
45
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DomService, decorators: [{
46
+ type: Injectable,
47
+ args: [{
48
+ providedIn: "root"
49
+ }]
50
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; } });
51
+
52
+ class TableComponent {
53
+ constructor(renderer, elementRef, zone, domService) {
54
+ this.renderer = renderer;
55
+ this.elementRef = elementRef;
56
+ this.zone = zone;
57
+ this.domService = domService;
58
+ this.tableReady = new Subject();
59
+ this.mouseMoved = new Subject();
60
+ this.mouseDragging = new Subject();
61
+ this.mouseDraggingEnded = new Subject();
62
+ this.contextmenu = new Subject();
63
+ this.mouseClicked = new Subject();
64
+ this.modelChanged = new Subject();
65
+ this.checkboxChanged = new Subject();
66
+ this.tableOptions = new TableOptions();
67
+ this.debounceMouseClickDelay = 150;
68
+ this.debounceMouseClick = new Subject();
69
+ this.alive = true;
70
+ this._if = true;
71
+ }
72
+ set tableIf(value) {
73
+ this._if = value;
74
+ Promise.resolve().then(this.initModel.bind(this));
75
+ }
76
+ onContextmenu(evt) {
77
+ this.contextmenu.next(evt);
78
+ }
79
+ onMouseMoved(evt) {
80
+ this.mouseMoved.next(evt);
81
+ }
82
+ // will be called by table-scope:
83
+ onMouseClicked(evt) {
84
+ this.debounceMouseClick.next(evt);
85
+ }
86
+ onCheckboxChanged(arr) {
87
+ this.checkboxChanged.next(arr);
88
+ }
89
+ onModelChanged(evt) {
90
+ this.modelChanged.next(evt);
91
+ }
92
+ ngOnInit() {
93
+ this.initModel();
94
+ this.debounceMouseClick
95
+ .pipe(debounceTime(this.debounceMouseClickDelay), takeWhile(() => this.alive))
96
+ .subscribe((value) => this.mouseClicked.next(value));
97
+ }
98
+ ngOnDestroy() {
99
+ this.alive = false;
100
+ }
101
+ initModel() {
102
+ this.zone.runOutsideAngular(this.init.bind(this));
103
+ }
104
+ init() {
105
+ if (this.tableModel) {
106
+ this.tableScope = new TableScope(this.elementRef.nativeElement, this.tableModel, this.domService, this.tableOptions, this);
107
+ this.tableScope.firstInit();
108
+ this.tableReady.next(this.tableScope.getApi());
109
+ }
110
+ }
111
+ onMouseDragging(evt) {
112
+ this.mouseDragging.next(evt);
113
+ }
114
+ onMouseDraggingEnd(evt) {
115
+ this.mouseDraggingEnded.next(evt);
116
+ }
117
+ }
118
+ TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: DomService }], target: i0.ɵɵFactoryTarget.Component });
119
+ TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TableComponent, isStandalone: true, selector: "guiexpert-table", inputs: { tableModel: "tableModel", tableOptions: "tableOptions", debounceMouseClickDelay: "debounceMouseClickDelay", tableIf: "tableIf" }, outputs: { tableReady: "tableReady", mouseMoved: "mouseMoved", mouseDragging: "mouseDragging", mouseDraggingEnded: "mouseDraggingEnded", contextmenu: "contextmenu", mouseClicked: "mouseClicked", modelChanged: "modelChanged", checkboxChanged: "checkboxChanged" }, providers: [DomService], ngImport: i0, template: '', isInline: true, styles: [".ge-table-col-div{text-align:center;line-height:2.5;-webkit-user-select:none;user-select:none}.ge-table-label-div{padding:0;display:block;text-overflow:ellipsis;overflow:hidden}.ge-cell-error{color:#e00034}.ge-table-selected-range{background-color:#0098db66}.ge-table-col-resize-handle:hover{background-color:#0ff}.ge-table-drop-zone{background-color:#f4fff299}.ge-table-dragged-col-div{background-color:#e0ffff}.ge-table-focus-border{background-color:#0ff}.ge-table-label-div .ge-table-label{padding-left:10px;padding-right:10px}.ge-table-text-align-left{text-align:left}.ge-table-text-align-right{text-align:right}.ge-table-text-align-center{text-align:center}.ge-table-row-checkbox-div{padding-left:14px}.ge-table-header,.ge-table-footer{background-color:#e9e9e980}.ge-table-body-west,.ge-table-body-east{background-color:#f4f4f480}.ge-table-hover-column,.ge-table-hover-row{background-color:#e0ffff80}.ge-table-west-fixed-column-border,.ge-table-east-fixed-column-border,.ge-table-footer-border,.ge-table-header-border{background-color:#bbb}.ge-table-row-border{background-color:#ddd}.ge-table-column-border{background-color:#dadada}.ge-table-col-div.ge-table-col-div-0.ge-table-tree-cell{text-align:left}.ge-table-tree-cell .ge-table-label-div{padding-left:0;padding-right:10px;display:inline}.gt-tree-arrow-collapsed{color:red}.ge-table-col-tree{text-align:left}.ge-table-col-tree.ge-table-tree-deep-0{padding-left:16px}.ge-table-col-tree.ge-table-tree-deep-1{padding-left:36px}.ge-table-col-tree.ge-table-tree-deep-2{padding-left:56px}.ge-table-col-tree.ge-table-tree-deep-3{padding-left:76px}.ge-table-col-tree.ge-table-tree-deep-4{padding-left:96px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:116px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:136px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
120
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableComponent, decorators: [{
121
+ type: Component,
122
+ args: [{ selector: 'guiexpert-table', standalone: true, imports: [CommonModule], providers: [DomService], template: '', changeDetection: ChangeDetectionStrategy.OnPush, styles: [".ge-table-col-div{text-align:center;line-height:2.5;-webkit-user-select:none;user-select:none}.ge-table-label-div{padding:0;display:block;text-overflow:ellipsis;overflow:hidden}.ge-cell-error{color:#e00034}.ge-table-selected-range{background-color:#0098db66}.ge-table-col-resize-handle:hover{background-color:#0ff}.ge-table-drop-zone{background-color:#f4fff299}.ge-table-dragged-col-div{background-color:#e0ffff}.ge-table-focus-border{background-color:#0ff}.ge-table-label-div .ge-table-label{padding-left:10px;padding-right:10px}.ge-table-text-align-left{text-align:left}.ge-table-text-align-right{text-align:right}.ge-table-text-align-center{text-align:center}.ge-table-row-checkbox-div{padding-left:14px}.ge-table-header,.ge-table-footer{background-color:#e9e9e980}.ge-table-body-west,.ge-table-body-east{background-color:#f4f4f480}.ge-table-hover-column,.ge-table-hover-row{background-color:#e0ffff80}.ge-table-west-fixed-column-border,.ge-table-east-fixed-column-border,.ge-table-footer-border,.ge-table-header-border{background-color:#bbb}.ge-table-row-border{background-color:#ddd}.ge-table-column-border{background-color:#dadada}.ge-table-col-div.ge-table-col-div-0.ge-table-tree-cell{text-align:left}.ge-table-tree-cell .ge-table-label-div{padding-left:0;padding-right:10px;display:inline}.gt-tree-arrow-collapsed{color:red}.ge-table-col-tree{text-align:left}.ge-table-col-tree.ge-table-tree-deep-0{padding-left:16px}.ge-table-col-tree.ge-table-tree-deep-1{padding-left:36px}.ge-table-col-tree.ge-table-tree-deep-2{padding-left:56px}.ge-table-col-tree.ge-table-tree-deep-3{padding-left:76px}.ge-table-col-tree.ge-table-tree-deep-4{padding-left:96px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:116px}.ge-table-col-tree.ge-table-tree-deep-5{padding-left:136px}\n"] }]
123
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: DomService }]; }, propDecorators: { tableReady: [{
124
+ type: Output
125
+ }], mouseMoved: [{
126
+ type: Output
127
+ }], mouseDragging: [{
128
+ type: Output
129
+ }], mouseDraggingEnded: [{
130
+ type: Output
131
+ }], contextmenu: [{
132
+ type: Output
133
+ }], mouseClicked: [{
134
+ type: Output
135
+ }], modelChanged: [{
136
+ type: Output
137
+ }], checkboxChanged: [{
138
+ type: Output
139
+ }], tableModel: [{
140
+ type: Input
141
+ }], tableOptions: [{
142
+ type: Input
143
+ }], debounceMouseClickDelay: [{
144
+ type: Input
145
+ }], tableIf: [{
146
+ type: Input
147
+ }] } });
148
+
149
+ class RendererWrapper {
150
+ constructor(componentType, appRef, injector, cdr, zone) {
151
+ this.componentType = componentType;
152
+ this.appRef = appRef;
153
+ this.injector = injector;
154
+ this.cdr = cdr;
155
+ this.zone = zone;
156
+ this.event$ = new EventEmitter();
157
+ this.closed$ = new Subject();
158
+ }
159
+ render(cellDiv, rowIndex, columnIndex, areaIdent, areaModel, cellValue, domService) {
160
+ const componentRef = createComponent(this.componentType, {
161
+ environmentInjector: this.injector
162
+ });
163
+ componentRef.instance.setData(rowIndex, columnIndex, areaIdent, areaModel, cellValue);
164
+ const emmiterNames = Object.keys(componentRef.instance)
165
+ .filter(key => {
166
+ // @ts-ignore
167
+ const t = componentRef.instance[key];
168
+ return t['subscribe'];
169
+ });
170
+ // @ts-ignore
171
+ const observables = (emmiterNames.map(key => componentRef.instance[key]));
172
+ observables.forEach(obs => obs
173
+ .pipe(takeUntil(this.closed$))
174
+ .subscribe((event) => {
175
+ console.info('RendererWrapper event >', event); // TODO hmm?
176
+ this.event$.next(event);
177
+ }));
178
+ cellDiv.appendChild(componentRef.location.nativeElement);
179
+ this.appRef.attachView(componentRef.hostView);
180
+ this.zone.run(() => {
181
+ this.cdr.detectChanges();
182
+ });
183
+ return () => {
184
+ // clean up:
185
+ this.appRef.detachView(componentRef.hostView);
186
+ this.closed$.next(Date.now());
187
+ };
188
+ }
189
+ }
190
+
191
+ class RenderWrapperFactory {
192
+ constructor(appRef, injector, zone) {
193
+ this.appRef = appRef;
194
+ this.injector = injector;
195
+ this.zone = zone;
196
+ }
197
+ create(componentType, cdr) {
198
+ return new RendererWrapper(componentType, this.appRef, this.injector, cdr, this.zone);
199
+ }
200
+ }
201
+ RenderWrapperFactory.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RenderWrapperFactory, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable });
202
+ RenderWrapperFactory.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RenderWrapperFactory, providedIn: "root" });
203
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RenderWrapperFactory, decorators: [{
204
+ type: Injectable,
205
+ args: [{
206
+ providedIn: "root"
207
+ }]
208
+ }], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: i0.NgZone }]; } });
209
+
210
+ /**
211
+ * Generated bundle index. Do not edit.
212
+ */
213
+
214
+ export { DomService, RenderWrapperFactory, RendererWrapper, TableComponent };
215
+ //# sourceMappingURL=guiexpert-angular-table.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"guiexpert-angular-table.mjs","sources":["../../../../libs/angular-table/src/lib/angular-table/service/dom-service.ts","../../../../libs/angular-table/src/lib/angular-table/table.component.ts","../../../../libs/angular-table/src/lib/angular-table/service/renderer-wrapper.ts","../../../../libs/angular-table/src/lib/angular-table/service/render-wrapper-factory.ts","../../../../libs/angular-table/src/guiexpert-angular-table.ts"],"sourcesContent":["import {Injectable, Renderer2} from \"@angular/core\";\nimport {DomServiceIf} from \"@guiexpert/table\";\n\n\n@Injectable({\n providedIn: \"root\"\n})\nexport class DomService implements DomServiceIf {\n\n constructor(\n readonly renderer: Renderer2,\n ) {\n }\n\n setStyle(el: any, style: string, value: any): any {\n this.renderer.setStyle(el, style, value);\n return el;\n };\n\n\n appendText(parent: HTMLDivElement, text: string): HTMLDivElement {\n const div = this.renderer.createText(text);\n this.renderer.appendChild(parent, div);\n return div;\n }\n\n\n addClass(div: HTMLDivElement, clazz: string) {\n if (clazz.includes(' ')) {\n clazz.split(' ').forEach(c => this.renderer.addClass(div, c))\n } else {\n this.renderer.addClass(div, clazz);\n }\n return div;\n }\n\n appendChild(parent: HTMLElement, child: HTMLElement): void {\n this.renderer.appendChild(parent, child);\n }\n\n createElement<T>(name: string): T {\n return this.renderer.createElement(name);\n }\n\n createText(text: string): HTMLElement {\n return this.renderer.createText(text);\n }\n\n setAttribute(ele: HTMLElement, key: string, value: string): void {\n this.renderer.setAttribute(ele, key, value);\n }\n\n\n}\n","import {\n ChangeDetectionStrategy,\n Component,\n ElementRef,\n Input,\n NgZone,\n OnDestroy,\n OnInit,\n Output,\n Renderer2\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {debounceTime, Subject, takeWhile} from \"rxjs\";\nimport {\n EventListenerIf,\n GeModelChangeEvent,\n GeMouseEvent,\n TableApi,\n TableModelIf,\n TableOptions,\n TableOptionsIf,\n TableScope\n} from \"@guiexpert/table\";\nimport {DomService} from \"./service/dom-service\";\n\n\n@Component({\n selector: 'guiexpert-table',\n standalone: true,\n imports: [CommonModule],\n providers: [DomService],\n template: '',\n styleUrls: ['./table.component.css'],\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableComponent implements OnInit, OnDestroy, EventListenerIf {\n\n @Output()\n tableReady = new Subject<TableApi>();\n\n @Output()\n mouseMoved: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n @Output()\n mouseDragging: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n @Output()\n mouseDraggingEnded: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n @Output()\n contextmenu: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n @Output()\n mouseClicked: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n @Output()\n modelChanged: Subject<GeModelChangeEvent> = new Subject<GeModelChangeEvent>();\n\n @Output()\n checkboxChanged: Subject<any[]> = new Subject<any[]>();\n\n @Input()\n tableModel?: TableModelIf;\n\n @Input()\n tableOptions: TableOptionsIf = new TableOptions();\n\n @Input()\n debounceMouseClickDelay: number = 150;\n\n private debounceMouseClick: Subject<GeMouseEvent> = new Subject<GeMouseEvent>();\n\n private tableScope?: TableScope;\n private alive = true;\n private _if: boolean = true;\n\n\n constructor(\n private readonly renderer: Renderer2,\n private readonly elementRef: ElementRef,\n private readonly zone: NgZone,\n private readonly domService: DomService\n ) {\n\n }\n\n @Input()\n set tableIf(value: boolean) {\n this._if = value;\n Promise.resolve().then(this.initModel.bind(this));\n }\n\n onContextmenu(evt: GeMouseEvent): void {\n this.contextmenu.next(evt);\n }\n\n onMouseMoved(evt: GeMouseEvent): void {\n this.mouseMoved.next(evt);\n }\n\n // will be called by table-scope:\n onMouseClicked(evt: GeMouseEvent): void {\n this.debounceMouseClick.next(evt);\n }\n\n onCheckboxChanged(arr: any[]): void {\n this.checkboxChanged.next(arr);\n }\n\n onModelChanged(evt: GeModelChangeEvent): void {\n this.modelChanged.next(evt);\n }\n\n ngOnInit(): void {\n this.initModel();\n this.debounceMouseClick\n .pipe(\n debounceTime(this.debounceMouseClickDelay),\n takeWhile(() => this.alive)\n )\n .subscribe((value) => this.mouseClicked.next(value));\n }\n\n ngOnDestroy(): void {\n this.alive = false;\n }\n\n\n private initModel() {\n this.zone.runOutsideAngular(this.init.bind(this));\n }\n\n private init() {\n if (this.tableModel) {\n this.tableScope = new TableScope(\n this.elementRef.nativeElement, this.tableModel, this.domService, this.tableOptions, this\n );\n this.tableScope.firstInit();\n this.tableReady.next(this.tableScope.getApi());\n }\n }\n\n onMouseDragging(evt: GeMouseEvent): void {\n this.mouseDragging.next(evt);\n }\n\n onMouseDraggingEnd(evt: GeMouseEvent): void {\n this.mouseDraggingEnded.next(evt);\n }\n\n\n}\n","import {AreaIdent, AreaModelIf, CellRendererIf, DomServiceIf, RendererCleanupFnType} from \"@guiexpert/table\";\nimport {\n ApplicationRef,\n ChangeDetectorRef,\n createComponent,\n EnvironmentInjector,\n EventEmitter,\n NgZone,\n Type\n} from \"@angular/core\";\nimport {ComponentRendererIf} from \"../component-renderer.if\";\nimport {Subject, takeUntil} from \"rxjs\";\nimport {Observable} from \"rxjs/internal/Observable\";\n\n\nexport class RendererWrapper<T extends ComponentRendererIf<T>>\n implements CellRendererIf {\n\n public readonly event$ = new EventEmitter<any>();\n private readonly closed$ = new Subject<number>();\n\n constructor(\n private componentType: Type<ComponentRendererIf<T>>,\n private appRef: ApplicationRef,\n private injector: EnvironmentInjector,\n private cdr: ChangeDetectorRef,\n private readonly zone: NgZone\n ) {\n }\n\n render(\n cellDiv: HTMLDivElement,\n rowIndex: number,\n columnIndex: number,\n areaIdent: AreaIdent,\n areaModel: AreaModelIf,\n cellValue: any,\n domService: DomServiceIf): RendererCleanupFnType | undefined {\n\n const componentRef = createComponent(this.componentType, {\n environmentInjector: this.injector\n });\n componentRef.instance.setData(\n rowIndex,\n columnIndex,\n areaIdent,\n areaModel,\n cellValue);\n\n\n const emmiterNames = Object.keys(componentRef.instance)\n .filter(key => {\n // @ts-ignore\n const t = componentRef.instance[key];\n return t['subscribe']\n });\n\n // @ts-ignore\n const observables: Observable[] = (emmiterNames.map(key => (componentRef.instance[key] as Observable)));\n observables.forEach(obs => obs\n .pipe(\n takeUntil(this.closed$)\n )\n .subscribe((event: any) => {\n console.info('RendererWrapper event >', event); // TODO hmm?\n this.event$.next(event);\n })\n );\n\n cellDiv.appendChild(componentRef.location.nativeElement);\n\n this.appRef.attachView(componentRef.hostView);\n\n this.zone.run(() => {\n this.cdr.detectChanges();\n });\n\n return () => {\n // clean up:\n this.appRef.detachView(componentRef.hostView);\n this.closed$.next(Date.now());\n };\n }\n\n\n}\n","import {ApplicationRef, ChangeDetectorRef, EnvironmentInjector, Injectable, NgZone, Type} from \"@angular/core\";\nimport {ComponentRendererIf} from \"../component-renderer.if\";\nimport {RendererWrapper} from \"./renderer-wrapper\";\n\n@Injectable({\n providedIn: \"root\"\n})\nexport class RenderWrapperFactory {\n\n constructor(\n private readonly appRef: ApplicationRef,\n private readonly injector: EnvironmentInjector,\n private readonly zone: NgZone\n ) {\n }\n\n create<T>(\n componentType: Type<ComponentRendererIf<T>>,\n cdr: ChangeDetectorRef\n ) {\n return new RendererWrapper(componentType, this.appRef, this.injector, cdr, this.zone);\n }\n\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["i1.DomService"],"mappings":"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"}
package/index.d.ts ADDED
@@ -0,0 +1,5 @@
1
+ export * from './lib/angular-table/table.component';
2
+ export * from './lib/angular-table/component-renderer.if';
3
+ export * from './lib/angular-table/service/dom-service';
4
+ export * from './lib/angular-table/service/renderer-wrapper';
5
+ export * from './lib/angular-table/service/render-wrapper-factory';
@@ -0,0 +1,4 @@
1
+ import { AreaIdent, AreaModelIf, RendererCleanupFnType } from "@guiexpert/table";
2
+ export interface ComponentRendererIf<T> {
3
+ setData(rowIndex: number, columnIndex: number, areaIdent: AreaIdent, areaModel: AreaModelIf, cellValue: any): RendererCleanupFnType | undefined;
4
+ }
@@ -0,0 +1,16 @@
1
+ import { Renderer2 } from "@angular/core";
2
+ import { DomServiceIf } from "@guiexpert/table";
3
+ import * as i0 from "@angular/core";
4
+ export declare class DomService implements DomServiceIf {
5
+ readonly renderer: Renderer2;
6
+ constructor(renderer: Renderer2);
7
+ setStyle(el: any, style: string, value: any): any;
8
+ appendText(parent: HTMLDivElement, text: string): HTMLDivElement;
9
+ addClass(div: HTMLDivElement, clazz: string): HTMLDivElement;
10
+ appendChild(parent: HTMLElement, child: HTMLElement): void;
11
+ createElement<T>(name: string): T;
12
+ createText(text: string): HTMLElement;
13
+ setAttribute(ele: HTMLElement, key: string, value: string): void;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<DomService, never>;
15
+ static ɵprov: i0.ɵɵInjectableDeclaration<DomService>;
16
+ }
@@ -0,0 +1,13 @@
1
+ import { ApplicationRef, ChangeDetectorRef, EnvironmentInjector, NgZone, Type } from "@angular/core";
2
+ import { ComponentRendererIf } from "../component-renderer.if";
3
+ import { RendererWrapper } from "./renderer-wrapper";
4
+ import * as i0 from "@angular/core";
5
+ export declare class RenderWrapperFactory {
6
+ private readonly appRef;
7
+ private readonly injector;
8
+ private readonly zone;
9
+ constructor(appRef: ApplicationRef, injector: EnvironmentInjector, zone: NgZone);
10
+ create<T>(componentType: Type<ComponentRendererIf<T>>, cdr: ChangeDetectorRef): RendererWrapper<ComponentRendererIf<T>>;
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<RenderWrapperFactory, never>;
12
+ static ɵprov: i0.ɵɵInjectableDeclaration<RenderWrapperFactory>;
13
+ }
@@ -0,0 +1,14 @@
1
+ import { AreaIdent, AreaModelIf, CellRendererIf, DomServiceIf, RendererCleanupFnType } from "@guiexpert/table";
2
+ import { ApplicationRef, ChangeDetectorRef, EnvironmentInjector, EventEmitter, NgZone, Type } from "@angular/core";
3
+ import { ComponentRendererIf } from "../component-renderer.if";
4
+ export declare class RendererWrapper<T extends ComponentRendererIf<T>> implements CellRendererIf {
5
+ private componentType;
6
+ private appRef;
7
+ private injector;
8
+ private cdr;
9
+ private readonly zone;
10
+ readonly event$: EventEmitter<any>;
11
+ private readonly closed$;
12
+ constructor(componentType: Type<ComponentRendererIf<T>>, appRef: ApplicationRef, injector: EnvironmentInjector, cdr: ChangeDetectorRef, zone: NgZone);
13
+ render(cellDiv: HTMLDivElement, rowIndex: number, columnIndex: number, areaIdent: AreaIdent, areaModel: AreaModelIf, cellValue: any, domService: DomServiceIf): RendererCleanupFnType | undefined;
14
+ }
@@ -0,0 +1,41 @@
1
+ import { ElementRef, NgZone, OnDestroy, OnInit, Renderer2 } from '@angular/core';
2
+ import { Subject } from "rxjs";
3
+ import { EventListenerIf, GeModelChangeEvent, GeMouseEvent, TableApi, TableModelIf, TableOptionsIf } from "@guiexpert/table";
4
+ import { DomService } from "./service/dom-service";
5
+ import * as i0 from "@angular/core";
6
+ export declare class TableComponent implements OnInit, OnDestroy, EventListenerIf {
7
+ private readonly renderer;
8
+ private readonly elementRef;
9
+ private readonly zone;
10
+ private readonly domService;
11
+ tableReady: Subject<TableApi>;
12
+ mouseMoved: Subject<GeMouseEvent>;
13
+ mouseDragging: Subject<GeMouseEvent>;
14
+ mouseDraggingEnded: Subject<GeMouseEvent>;
15
+ contextmenu: Subject<GeMouseEvent>;
16
+ mouseClicked: Subject<GeMouseEvent>;
17
+ modelChanged: Subject<GeModelChangeEvent>;
18
+ checkboxChanged: Subject<any[]>;
19
+ tableModel?: TableModelIf;
20
+ tableOptions: TableOptionsIf;
21
+ debounceMouseClickDelay: number;
22
+ private debounceMouseClick;
23
+ private tableScope?;
24
+ private alive;
25
+ private _if;
26
+ constructor(renderer: Renderer2, elementRef: ElementRef, zone: NgZone, domService: DomService);
27
+ set tableIf(value: boolean);
28
+ onContextmenu(evt: GeMouseEvent): void;
29
+ onMouseMoved(evt: GeMouseEvent): void;
30
+ onMouseClicked(evt: GeMouseEvent): void;
31
+ onCheckboxChanged(arr: any[]): void;
32
+ onModelChanged(evt: GeModelChangeEvent): void;
33
+ ngOnInit(): void;
34
+ ngOnDestroy(): void;
35
+ private initModel;
36
+ private init;
37
+ onMouseDragging(evt: GeMouseEvent): void;
38
+ onMouseDraggingEnd(evt: GeMouseEvent): void;
39
+ static ɵfac: i0.ɵɵFactoryDeclaration<TableComponent, never>;
40
+ static ɵcmp: i0.ɵɵComponentDeclaration<TableComponent, "guiexpert-table", never, { "tableModel": "tableModel"; "tableOptions": "tableOptions"; "debounceMouseClickDelay": "debounceMouseClickDelay"; "tableIf": "tableIf"; }, { "tableReady": "tableReady"; "mouseMoved": "mouseMoved"; "mouseDragging": "mouseDragging"; "mouseDraggingEnded": "mouseDraggingEnded"; "contextmenu": "contextmenu"; "mouseClicked": "mouseClicked"; "modelChanged": "modelChanged"; "checkboxChanged": "checkboxChanged"; }, never, never, true>;
41
+ }
package/package.json ADDED
@@ -0,0 +1,33 @@
1
+ {
2
+ "name": "@guiexpert/angular-table",
3
+ "version": "0.0.1",
4
+ "peerDependencies": {
5
+ "@angular/common": "^14.2.0",
6
+ "@angular/core": "^14.2.0",
7
+ "@guiexpert/table": "0.0.1",
8
+ "rxjs": "~7.5.0"
9
+ },
10
+ "dependencies": {
11
+ "tslib": "^2.3.0"
12
+ },
13
+ "module": "fesm2015/guiexpert-angular-table.mjs",
14
+ "es2020": "fesm2020/guiexpert-angular-table.mjs",
15
+ "esm2020": "esm2020/guiexpert-angular-table.mjs",
16
+ "fesm2020": "fesm2020/guiexpert-angular-table.mjs",
17
+ "fesm2015": "fesm2015/guiexpert-angular-table.mjs",
18
+ "typings": "index.d.ts",
19
+ "exports": {
20
+ "./package.json": {
21
+ "default": "./package.json"
22
+ },
23
+ ".": {
24
+ "types": "./index.d.ts",
25
+ "esm2020": "./esm2020/guiexpert-angular-table.mjs",
26
+ "es2020": "./fesm2020/guiexpert-angular-table.mjs",
27
+ "es2015": "./fesm2015/guiexpert-angular-table.mjs",
28
+ "node": "./fesm2015/guiexpert-angular-table.mjs",
29
+ "default": "./fesm2020/guiexpert-angular-table.mjs"
30
+ }
31
+ },
32
+ "sideEffects": false
33
+ }