@tots/table 15.0.0 → 15.0.2

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.
@@ -8,10 +8,11 @@ export class BasePrintColumnComponent {
8
8
  const view = this.viewContainerRef.createComponent(this.column.component);
9
9
  view.instance.column = this.column;
10
10
  view.instance.item = this.item;
11
+ view.instance.onAction = this.onAction;
11
12
  }
12
13
  }
13
14
  BasePrintColumnComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: BasePrintColumnComponent, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
14
- BasePrintColumnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: BasePrintColumnComponent, selector: "tots-base-print-column", inputs: { column: "column", item: "item" }, ngImport: i0, template: "<div #contentColumn></div>", styles: [""] });
15
+ BasePrintColumnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: BasePrintColumnComponent, selector: "tots-base-print-column", inputs: { column: "column", item: "item", onAction: "onAction" }, ngImport: i0, template: "<div #contentColumn></div>", styles: [""] });
15
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: BasePrintColumnComponent, decorators: [{
16
17
  type: Component,
17
18
  args: [{ selector: 'tots-base-print-column', template: "<div #contentColumn></div>" }]
@@ -19,5 +20,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
19
20
  type: Input
20
21
  }], item: [{
21
22
  type: Input
23
+ }], onAction: [{
24
+ type: Input
22
25
  }] } });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1wcmludC1jb2x1bW4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbHVtbnMvYmFzZS1wcmludC1jb2x1bW4vYmFzZS1wcmludC1jb2x1bW4uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbHVtbnMvYmFzZS1wcmludC1jb2x1bW4vYmFzZS1wcmludC1jb2x1bW4uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQW9CLE1BQU0sZUFBZSxDQUFDOztBQVFuRSxNQUFNLE9BQU8sd0JBQXdCO0lBS25DLFlBQ1ksZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFDMUMsQ0FBQztJQUVMLFFBQVE7UUFDTixNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDcEUsSUFBSSxDQUFDLFFBQVMsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUNwQyxJQUFJLENBQUMsUUFBUyxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ3hDLENBQUM7O3FIQWJVLHdCQUF3Qjt5R0FBeEIsd0JBQXdCLDBHQ1JyQyw0QkFBMEI7MkZEUWIsd0JBQXdCO2tCQUxwQyxTQUFTOytCQUNFLHdCQUF3Qjt1R0FNekIsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRvdHNDb2x1bW4gfSBmcm9tICcuLi8uLi9lbnRpdGllcy90b3RzLWNvbHVtbic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3RvdHMtYmFzZS1wcmludC1jb2x1bW4nLFxuICB0ZW1wbGF0ZVVybDogJy4vYmFzZS1wcmludC1jb2x1bW4uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9iYXNlLXByaW50LWNvbHVtbi5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQmFzZVByaW50Q29sdW1uQ29tcG9uZW50IHtcblxuICBASW5wdXQoKSBjb2x1bW4hOiBUb3RzQ29sdW1uO1xuICBASW5wdXQoKSBpdGVtOiBhbnk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJvdGVjdGVkIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWZcbiAgKSB7IH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBjb25zdCB2aWV3ID0gdGhpcy52aWV3Q29udGFpbmVyUmVmLmNyZWF0ZUNvbXBvbmVudCh0aGlzLmNvbHVtbi5jb21wb25lbnQpO1xuICAgICg8YW55PnZpZXcuaW5zdGFuY2UpLmNvbHVtbiA9IHRoaXMuY29sdW1uO1xuICAgICg8YW55PnZpZXcuaW5zdGFuY2UpLml0ZW0gPSB0aGlzLml0ZW07XG4gIH1cbn1cbiIsIjxkaXYgI2NvbnRlbnRDb2x1bW4+PC9kaXY+Il19
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1wcmludC1jb2x1bW4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbHVtbnMvYmFzZS1wcmludC1jb2x1bW4vYmFzZS1wcmludC1jb2x1bW4uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbHVtbnMvYmFzZS1wcmludC1jb2x1bW4vYmFzZS1wcmludC1jb2x1bW4uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQW9CLE1BQU0sZUFBZSxDQUFDOztBQVVuRSxNQUFNLE9BQU8sd0JBQXdCO0lBTW5DLFlBQ1ksZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFDMUMsQ0FBQztJQUVMLFFBQVE7UUFDTixNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDcEUsSUFBSSxDQUFDLFFBQVMsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUNwQyxJQUFJLENBQUMsUUFBUyxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQ2hDLElBQUksQ0FBQyxRQUFTLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDaEQsQ0FBQzs7cUhBZlUsd0JBQXdCO3lHQUF4Qix3QkFBd0IsZ0lDVnJDLDRCQUEwQjsyRkRVYix3QkFBd0I7a0JBTHBDLFNBQVM7K0JBQ0Usd0JBQXdCO3VHQU16QixNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBUb3RzQWN0aW9uVGFibGUgfSBmcm9tICcuLi8uLi9lbnRpdGllcy90b3RzLWFjdGlvbi10YWJsZSc7XG5pbXBvcnQgeyBUb3RzQ29sdW1uIH0gZnJvbSAnLi4vLi4vZW50aXRpZXMvdG90cy1jb2x1bW4nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0b3RzLWJhc2UtcHJpbnQtY29sdW1uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Jhc2UtcHJpbnQtY29sdW1uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYmFzZS1wcmludC1jb2x1bW4uY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIEJhc2VQcmludENvbHVtbkNvbXBvbmVudCB7XG5cbiAgQElucHV0KCkgY29sdW1uITogVG90c0NvbHVtbjtcbiAgQElucHV0KCkgaXRlbTogYW55O1xuICBASW5wdXQoKSBvbkFjdGlvbiE6IFN1YmplY3Q8VG90c0FjdGlvblRhYmxlPjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcm90ZWN0ZWQgdmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZlxuICApIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IHZpZXcgPSB0aGlzLnZpZXdDb250YWluZXJSZWYuY3JlYXRlQ29tcG9uZW50KHRoaXMuY29sdW1uLmNvbXBvbmVudCk7XG4gICAgKDxhbnk+dmlldy5pbnN0YW5jZSkuY29sdW1uID0gdGhpcy5jb2x1bW47XG4gICAgKDxhbnk+dmlldy5pbnN0YW5jZSkuaXRlbSA9IHRoaXMuaXRlbTtcbiAgICAoPGFueT52aWV3Lmluc3RhbmNlKS5vbkFjdGlvbiA9IHRoaXMub25BY3Rpb247XG4gIH1cbn1cbiIsIjxkaXYgI2NvbnRlbnRDb2x1bW4+PC9kaXY+Il19
@@ -0,0 +1,21 @@
1
+ import { Component } from '@angular/core';
2
+ import { TotsBaseColumnComponent } from '../tots-base-column.component';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@angular/material/icon";
6
+ import * as i3 from "@angular/material/button";
7
+ import * as i4 from "@angular/material/menu";
8
+ export class MoreMenuColumnComponent extends TotsBaseColumnComponent {
9
+ clickButton(itemAction, $event) {
10
+ this.onAction.next({ key: itemAction.key, item: this.item });
11
+ $event.preventDefault();
12
+ return false;
13
+ }
14
+ }
15
+ MoreMenuColumnComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: MoreMenuColumnComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
16
+ MoreMenuColumnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: MoreMenuColumnComponent, selector: "tots-more-menu-column", usesInheritance: true, ngImport: i0, template: "<button mat-icon-button [matMenuTriggerFor]=\"actions\" (click)=\"$event.stopPropagation()\"><mat-icon>more_vert</mat-icon></button>\n<mat-menu #actions=\"matMenu\">\n <button mat-menu-item *ngFor=\"let button of column.extra?.actions\" (click)=\"clickButton(button, $event)\">\n <mat-icon *ngIf=\"button.icon\">{{ button.icon }}</mat-icon> {{ button.title }}\n </button>\n</mat-menu>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i4.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }] });
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: MoreMenuColumnComponent, decorators: [{
18
+ type: Component,
19
+ args: [{ selector: 'tots-more-menu-column', template: "<button mat-icon-button [matMenuTriggerFor]=\"actions\" (click)=\"$event.stopPropagation()\"><mat-icon>more_vert</mat-icon></button>\n<mat-menu #actions=\"matMenu\">\n <button mat-menu-item *ngFor=\"let button of column.extra?.actions\" (click)=\"clickButton(button, $event)\">\n <mat-icon *ngIf=\"button.icon\">{{ button.icon }}</mat-icon> {{ button.title }}\n </button>\n</mat-menu>" }]
20
+ }] });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9yZS1tZW51LWNvbHVtbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL3RhYmxlL3NyYy9saWIvY29sdW1ucy9tb3JlLW1lbnUtY29sdW1uL21vcmUtbWVudS1jb2x1bW4uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbHVtbnMvbW9yZS1tZW51LWNvbHVtbi9tb3JlLW1lbnUtY29sdW1uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUMsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sK0JBQStCLENBQUM7Ozs7OztBQU94RSxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsdUJBQXVCO0lBRWxFLFdBQVcsQ0FBQyxVQUFlLEVBQUUsTUFBZTtRQUMxQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLEdBQUcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUM3RCxNQUFNLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDeEIsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDOztvSEFOVSx1QkFBdUI7d0dBQXZCLHVCQUF1QixvRkNUcEMsK1lBS1c7MkZESUUsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLHVCQUF1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVG90c0FjdGlvblRhYmxlIH0gZnJvbSAnLi4vLi4vZW50aXRpZXMvdG90cy1hY3Rpb24tdGFibGUnO1xuaW1wb3J0IHsgVG90c0Jhc2VDb2x1bW5Db21wb25lbnQgfSBmcm9tICcuLi90b3RzLWJhc2UtY29sdW1uLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3RvdHMtbW9yZS1tZW51LWNvbHVtbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9tb3JlLW1lbnUtY29sdW1uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbW9yZS1tZW51LWNvbHVtbi5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIE1vcmVNZW51Q29sdW1uQ29tcG9uZW50IGV4dGVuZHMgVG90c0Jhc2VDb2x1bW5Db21wb25lbnQge1xuXG4gIGNsaWNrQnV0dG9uKGl0ZW1BY3Rpb246IGFueSwgJGV2ZW50OiBVSUV2ZW50KSB7XG4gICAgdGhpcy5vbkFjdGlvbi5uZXh0KHsga2V5OiBpdGVtQWN0aW9uLmtleSwgaXRlbTogdGhpcy5pdGVtIH0pO1xuICAgICRldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuIiwiPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gW21hdE1lbnVUcmlnZ2VyRm9yXT1cImFjdGlvbnNcIiAoY2xpY2spPVwiJGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXCI+PG1hdC1pY29uPm1vcmVfdmVydDwvbWF0LWljb24+PC9idXR0b24+XG48bWF0LW1lbnUgI2FjdGlvbnM9XCJtYXRNZW51XCI+XG4gICAgPGJ1dHRvbiBtYXQtbWVudS1pdGVtICpuZ0Zvcj1cImxldCBidXR0b24gb2YgY29sdW1uLmV4dHJhPy5hY3Rpb25zXCIgKGNsaWNrKT1cImNsaWNrQnV0dG9uKGJ1dHRvbiwgJGV2ZW50KVwiPlxuICAgICAgICA8bWF0LWljb24gKm5nSWY9XCJidXR0b24uaWNvblwiPnt7IGJ1dHRvbi5pY29uIH19PC9tYXQtaWNvbj4ge3sgYnV0dG9uLnRpdGxlIH19XG4gICAgPC9idXR0b24+XG48L21hdC1tZW51PiJdfQ==
@@ -7,7 +7,7 @@ export class TotsBaseColumnComponent {
7
7
  }
8
8
  }
9
9
  TotsBaseColumnComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsBaseColumnComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
10
- TotsBaseColumnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsBaseColumnComponent, selector: "tots-base-column", inputs: { column: "column", item: "item" }, ngImport: i0, template: '', isInline: true });
10
+ TotsBaseColumnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsBaseColumnComponent, selector: "tots-base-column", inputs: { column: "column", item: "item", onAction: "onAction" }, ngImport: i0, template: '', isInline: true });
11
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsBaseColumnComponent, decorators: [{
12
12
  type: Component,
13
13
  args: [{
@@ -18,5 +18,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
18
18
  type: Input
19
19
  }], item: [{
20
20
  type: Input
21
+ }], onAction: [{
22
+ type: Input
21
23
  }] } });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy1iYXNlLWNvbHVtbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL3RhYmxlL3NyYy9saWIvY29sdW1ucy90b3RzLWJhc2UtY29sdW1uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFnQixLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFJdkUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDOztBQU0vRCxNQUFNLE9BQU8sdUJBQXVCO0lBS2hDLFlBQVk7UUFDUixPQUFPLGVBQWUsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDL0UsQ0FBQzs7b0hBUFEsdUJBQXVCO3dHQUF2Qix1QkFBdUIsb0dBRnRCLEVBQUU7MkZBRUgsdUJBQXVCO2tCQUpuQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFFBQVEsRUFBRSxFQUFFO2lCQUNmOzhCQUdZLE1BQU07c0JBQWQsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7IFRvdHNBY3Rpb25UYWJsZSB9IGZyb20gXCIuLi9lbnRpdGllcy90b3RzLWFjdGlvbi10YWJsZVwiO1xuaW1wb3J0IHsgVG90c0NvbHVtbiB9IGZyb20gXCIuLi9lbnRpdGllcy90b3RzLWNvbHVtblwiO1xuaW1wb3J0IHsgVG90c1RhYmxlSGVscGVyIH0gZnJvbSBcIi4uL2hlbHBlcnMvdG90cy10YWJsZS1oZWxwZXJcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICd0b3RzLWJhc2UtY29sdW1uJyxcbiAgICB0ZW1wbGF0ZTogJydcbn0pXG5leHBvcnQgY2xhc3MgVG90c0Jhc2VDb2x1bW5Db21wb25lbnR7XG5cbiAgICBASW5wdXQoKSBjb2x1bW4hOiBUb3RzQ29sdW1uO1xuICAgIEBJbnB1dCgpIGl0ZW06IGFueTtcblxuICAgIGdldEl0ZW1WYWx1ZSgpOiBhbnkge1xuICAgICAgICByZXR1cm4gVG90c1RhYmxlSGVscGVyLmdldEl0ZW1WYWx1ZUJ5S2V5KHRoaXMuaXRlbSwgdGhpcy5jb2x1bW4uZmllbGRfa2V5KTtcbiAgICB9XG59XG4iXX0=
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy1iYXNlLWNvbHVtbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL3RhYmxlL3NyYy9saWIvY29sdW1ucy90b3RzLWJhc2UtY29sdW1uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFnQixLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFJdkUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDOztBQU0vRCxNQUFNLE9BQU8sdUJBQXVCO0lBTWhDLFlBQVk7UUFDUixPQUFPLGVBQWUsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDL0UsQ0FBQzs7b0hBUlEsdUJBQXVCO3dHQUF2Qix1QkFBdUIsMEhBRnRCLEVBQUU7MkZBRUgsdUJBQXVCO2tCQUpuQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFFBQVEsRUFBRSxFQUFFO2lCQUNmOzhCQUdZLE1BQU07c0JBQWQsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tIFwicnhqc1wiO1xuaW1wb3J0IHsgVG90c0FjdGlvblRhYmxlIH0gZnJvbSBcIi4uL2VudGl0aWVzL3RvdHMtYWN0aW9uLXRhYmxlXCI7XG5pbXBvcnQgeyBUb3RzQ29sdW1uIH0gZnJvbSBcIi4uL2VudGl0aWVzL3RvdHMtY29sdW1uXCI7XG5pbXBvcnQgeyBUb3RzVGFibGVIZWxwZXIgfSBmcm9tIFwiLi4vaGVscGVycy90b3RzLXRhYmxlLWhlbHBlclwiO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3RvdHMtYmFzZS1jb2x1bW4nLFxuICAgIHRlbXBsYXRlOiAnJ1xufSlcbmV4cG9ydCBjbGFzcyBUb3RzQmFzZUNvbHVtbkNvbXBvbmVudHtcblxuICAgIEBJbnB1dCgpIGNvbHVtbiE6IFRvdHNDb2x1bW47XG4gICAgQElucHV0KCkgaXRlbTogYW55O1xuICAgIEBJbnB1dCgpIG9uQWN0aW9uITogU3ViamVjdDxUb3RzQWN0aW9uVGFibGU+O1xuXG4gICAgZ2V0SXRlbVZhbHVlKCk6IGFueSB7XG4gICAgICAgIHJldHVybiBUb3RzVGFibGVIZWxwZXIuZ2V0SXRlbVZhbHVlQnlLZXkodGhpcy5pdGVtLCB0aGlzLmNvbHVtbi5maWVsZF9rZXkpO1xuICAgIH1cbn1cbiJdfQ==
@@ -1,5 +1,5 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
- import { tap } from 'rxjs';
2
+ import { Subject, tap } from 'rxjs';
3
3
  import { TotsTableConfig } from '../../entities/tots-table-config';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
@@ -11,7 +11,9 @@ export class TotsTableComponent {
11
11
  this.config = new TotsTableConfig();
12
12
  this.pageIndex = 0;
13
13
  this.pageSize = 50;
14
+ this.hasPagination = true;
14
15
  this.onAction = new EventEmitter();
16
+ this.privateActions = new Subject();
15
17
  this.isLoading = true;
16
18
  this.displayColumns = [];
17
19
  }
@@ -34,23 +36,28 @@ export class TotsTableComponent {
34
36
  }
35
37
  loadConfig() {
36
38
  this.loadColumns();
39
+ this.privateActions.subscribe(action => {
40
+ this.onAction.emit(action);
41
+ });
37
42
  }
38
43
  loadColumns() {
39
44
  this.displayColumns = this.config.columns.filter(c => c.is_show || c.is_show == undefined).map(c => c.key);
40
45
  }
41
46
  }
42
47
  TotsTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
43
- TotsTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsTableComponent, selector: "tots-table", inputs: { config: "config", pageIndex: "pageIndex", pageSize: "pageSize" }, outputs: { onAction: "onAction" }, ngImport: i0, template: "<div class=\"tots-table-container\">\n <table *ngIf=\"dataItems\" mat-table [dataSource]=\"dataItems!.data\">\n \n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.key\">\n <!-- TH-->\n <th mat-header-cell *matHeaderCellDef>{{ column.title }}</th>\n <!-- TD -->\n <td mat-cell *matCellDef=\"let item\"><tots-base-print-column [column]=\"column\" [item]=\"item\"></tots-base-print-column></td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayColumns;\" (click)=\"onClickRow(row)\"></tr>\n \n <!-- Row shown when there is no matching data. -->\n <tr class=\"mat-row\" *matNoDataRow><td class=\"mat-cell\" colspan=\"100\">No data matching</td></tr>\n\n <!-- Paginator -->\n <mat-paginator *ngIf=\"dataItems\" [pageIndex]=\"pageIndex\" [length]=\"dataItems!.total\" [pageSize]=\"pageSize\" [pageSizeOptions]=\"[5, 10, 25, 50, 100]\" (page)=\"onPageChange($event)\"></mat-paginator>\n </table>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i2.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i2.MatNoDataRow, selector: "ng-template[matNoDataRow]" }, { kind: "component", type: i3.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: i4.BasePrintColumnComponent, selector: "tots-base-print-column", inputs: ["column", "item"] }] });
48
+ TotsTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsTableComponent, selector: "tots-table", inputs: { config: "config", pageIndex: "pageIndex", pageSize: "pageSize", hasPagination: "hasPagination" }, outputs: { onAction: "onAction" }, ngImport: i0, template: "<div class=\"tots-table-container\">\n <table *ngIf=\"dataItems\" mat-table [dataSource]=\"dataItems!.data\">\n \n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.key\">\n <!-- TH-->\n <th mat-header-cell *matHeaderCellDef>{{ column.title }}</th>\n <!-- TD -->\n <td mat-cell *matCellDef=\"let item\"><tots-base-print-column [column]=\"column\" [item]=\"item\"></tots-base-print-column></td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayColumns;\" (click)=\"onClickRow(row)\"></tr>\n \n <!-- Row shown when there is no matching data. -->\n <tr class=\"mat-row\" *matNoDataRow><td class=\"mat-cell\" colspan=\"100\">No data matching</td></tr>\n\n <!-- Paginator -->\n <mat-paginator *ngIf=\"dataItems && hasPagination\" [pageIndex]=\"pageIndex\" [length]=\"dataItems!.total\" [pageSize]=\"pageSize\" [pageSizeOptions]=\"[5, 10, 25, 50, 100]\" (page)=\"onPageChange($event)\"></mat-paginator>\n </table>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i2.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i2.MatNoDataRow, selector: "ng-template[matNoDataRow]" }, { kind: "component", type: i3.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: i4.BasePrintColumnComponent, selector: "tots-base-print-column", inputs: ["column", "item", "onAction"] }] });
44
49
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableComponent, decorators: [{
45
50
  type: Component,
46
- args: [{ selector: 'tots-table', template: "<div class=\"tots-table-container\">\n <table *ngIf=\"dataItems\" mat-table [dataSource]=\"dataItems!.data\">\n \n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.key\">\n <!-- TH-->\n <th mat-header-cell *matHeaderCellDef>{{ column.title }}</th>\n <!-- TD -->\n <td mat-cell *matCellDef=\"let item\"><tots-base-print-column [column]=\"column\" [item]=\"item\"></tots-base-print-column></td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayColumns;\" (click)=\"onClickRow(row)\"></tr>\n \n <!-- Row shown when there is no matching data. -->\n <tr class=\"mat-row\" *matNoDataRow><td class=\"mat-cell\" colspan=\"100\">No data matching</td></tr>\n\n <!-- Paginator -->\n <mat-paginator *ngIf=\"dataItems\" [pageIndex]=\"pageIndex\" [length]=\"dataItems!.total\" [pageSize]=\"pageSize\" [pageSizeOptions]=\"[5, 10, 25, 50, 100]\" (page)=\"onPageChange($event)\"></mat-paginator>\n </table>\n</div>" }]
51
+ args: [{ selector: 'tots-table', template: "<div class=\"tots-table-container\">\n <table *ngIf=\"dataItems\" mat-table [dataSource]=\"dataItems!.data\">\n \n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.key\">\n <!-- TH-->\n <th mat-header-cell *matHeaderCellDef>{{ column.title }}</th>\n <!-- TD -->\n <td mat-cell *matCellDef=\"let item\"><tots-base-print-column [column]=\"column\" [item]=\"item\"></tots-base-print-column></td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayColumns;\" (click)=\"onClickRow(row)\"></tr>\n \n <!-- Row shown when there is no matching data. -->\n <tr class=\"mat-row\" *matNoDataRow><td class=\"mat-cell\" colspan=\"100\">No data matching</td></tr>\n\n <!-- Paginator -->\n <mat-paginator *ngIf=\"dataItems && hasPagination\" [pageIndex]=\"pageIndex\" [length]=\"dataItems!.total\" [pageSize]=\"pageSize\" [pageSizeOptions]=\"[5, 10, 25, 50, 100]\" (page)=\"onPageChange($event)\"></mat-paginator>\n </table>\n</div>" }]
47
52
  }], propDecorators: { config: [{
48
53
  type: Input
49
54
  }], pageIndex: [{
50
55
  type: Input
51
56
  }], pageSize: [{
52
57
  type: Input
58
+ }], hasPagination: [{
59
+ type: Input
53
60
  }], onAction: [{
54
61
  type: Output
55
62
  }] } });
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy10YWJsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL3RhYmxlL3NyYy9saWIvY29tcG9uZW50cy90b3RzLXRhYmxlL3RvdHMtdGFibGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS90b3RzLXRhYmxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHL0UsT0FBTyxFQUFXLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVwQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7Ozs7OztBQU9uRSxNQUFNLE9BQU8sa0JBQWtCO0lBTC9CO1FBT1csV0FBTSxHQUFHLElBQUksZUFBZSxFQUFFLENBQUM7UUFDL0IsY0FBUyxHQUFXLENBQUMsQ0FBQztRQUN0QixhQUFRLEdBQVcsRUFBRSxDQUFDO1FBRXJCLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBbUIsQ0FBQztRQUV6RCxjQUFTLEdBQUcsSUFBSSxDQUFDO1FBRWpCLG1CQUFjLEdBQWtCLEVBQUUsQ0FBQztLQThCcEM7SUE1QkMsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNsQixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVELFVBQVUsQ0FBQyxJQUFTO1FBQ2xCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQWdCO1FBQzNCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUN4RCxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztRQUN0QixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRTtZQUNqQixJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxHQUFHLENBQUMsQ0FBQztZQUN0QyxTQUFTLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQyxDQUFDO0lBQzNDLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxJQUFJLENBQUMsQ0FBQyxPQUFPLElBQUksU0FBUyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzdHLENBQUM7OytHQXZDVSxrQkFBa0I7bUdBQWxCLGtCQUFrQixpS0NaL0IsOG1DQW1CTTsyRkRQTyxrQkFBa0I7a0JBTDlCLFNBQVM7K0JBQ0UsWUFBWTs4QkFNYixNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUVJLFFBQVE7c0JBQWpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQYWdlRXZlbnQgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wYWdpbmF0b3InO1xuaW1wb3J0IHsgVG90c0xpc3RSZXNwb25zZSB9IGZyb20gJ0B0b3RzL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCwgdGFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBUb3RzQWN0aW9uVGFibGUgfSBmcm9tICcuLi8uLi9lbnRpdGllcy90b3RzLWFjdGlvbi10YWJsZSc7XG5pbXBvcnQgeyBUb3RzVGFibGVDb25maWcgfSBmcm9tICcuLi8uLi9lbnRpdGllcy90b3RzLXRhYmxlLWNvbmZpZyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3RvdHMtdGFibGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vdG90cy10YWJsZS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3RvdHMtdGFibGUuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBUb3RzVGFibGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIEBJbnB1dCgpIGNvbmZpZyA9IG5ldyBUb3RzVGFibGVDb25maWcoKTtcbiAgQElucHV0KCkgcGFnZUluZGV4OiBudW1iZXIgPSAwO1xuICBASW5wdXQoKSBwYWdlU2l6ZTogbnVtYmVyID0gNTA7XG5cbiAgQE91dHB1dCgpIG9uQWN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjxUb3RzQWN0aW9uVGFibGU+KCk7XG5cbiAgaXNMb2FkaW5nID0gdHJ1ZTtcbiAgZGF0YUl0ZW1zPzogVG90c0xpc3RSZXNwb25zZTxhbnk+O1xuICBkaXNwbGF5Q29sdW1uczogQXJyYXk8U3RyaW5nPiA9IFtdO1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMubG9hZENvbmZpZygpO1xuICAgIHRoaXMubG9hZEl0ZW1zKCk7XG4gIH1cblxuICBvbkNsaWNrUm93KGl0ZW06IGFueSkge1xuICAgIHRoaXMub25BY3Rpb24uZW1pdCh7IGtleTogJ2NsaWNrLXJvdycsIGl0ZW06IGl0ZW0gfSk7XG4gIH1cblxuICBvblBhZ2VDaGFuZ2UoZXZlbnQ6IFBhZ2VFdmVudCkge1xuICAgIHRoaXMub25BY3Rpb24uZW1pdCh7IGtleTogJ3BhZ2UtY2hhbmdlJywgaXRlbTogZXZlbnQgfSk7XG4gICAgdGhpcy5sb2FkSXRlbXMoKTtcbiAgfVxuXG4gIGxvYWRJdGVtcygpIHtcbiAgICB0aGlzLmlzTG9hZGluZyA9IHRydWU7XG4gICAgdGhpcy5jb25maWcub2JzPy5cbiAgICBwaXBlKHRhcChyZXMgPT4gdGhpcy5kYXRhSXRlbXMgPSByZXMpKS5cbiAgICBzdWJzY3JpYmUocmVzID0+IHRoaXMuaXNMb2FkaW5nID0gZmFsc2UpO1xuICB9XG5cbiAgbG9hZENvbmZpZygpIHtcbiAgICB0aGlzLmxvYWRDb2x1bW5zKCk7XG4gIH1cblxuICBsb2FkQ29sdW1ucygpIHtcbiAgICB0aGlzLmRpc3BsYXlDb2x1bW5zID0gdGhpcy5jb25maWcuY29sdW1ucy5maWx0ZXIoYyA9PiBjLmlzX3Nob3cgfHwgYy5pc19zaG93ID09IHVuZGVmaW5lZCkubWFwKGMgPT4gYy5rZXkpO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwidG90cy10YWJsZS1jb250YWluZXJcIj5cbiAgICA8dGFibGUgKm5nSWY9XCJkYXRhSXRlbXNcIiBtYXQtdGFibGUgW2RhdGFTb3VyY2VdPVwiZGF0YUl0ZW1zIS5kYXRhXCI+XG4gICAgICAgIFxuICAgICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBjb2x1bW4gb2YgY29uZmlnLmNvbHVtbnNcIiBbbWF0Q29sdW1uRGVmXT1cImNvbHVtbi5rZXlcIj5cbiAgICAgICAgICAgIDwhLS0gVEgtLT5cbiAgICAgICAgICAgIDx0aCBtYXQtaGVhZGVyLWNlbGwgKm1hdEhlYWRlckNlbGxEZWY+e3sgY29sdW1uLnRpdGxlIH19PC90aD5cbiAgICAgICAgICAgIDwhLS0gVEQgLS0+XG4gICAgICAgICAgICA8dGQgbWF0LWNlbGwgKm1hdENlbGxEZWY9XCJsZXQgaXRlbVwiPjx0b3RzLWJhc2UtcHJpbnQtY29sdW1uIFtjb2x1bW5dPVwiY29sdW1uXCIgW2l0ZW1dPVwiaXRlbVwiPjwvdG90cy1iYXNlLXByaW50LWNvbHVtbj48L3RkPlxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cblxuICAgICAgICA8dHIgbWF0LWhlYWRlci1yb3cgKm1hdEhlYWRlclJvd0RlZj1cImRpc3BsYXlDb2x1bW5zXCI+PC90cj5cbiAgICAgICAgPHRyIG1hdC1yb3cgKm1hdFJvd0RlZj1cImxldCByb3c7IGNvbHVtbnM6IGRpc3BsYXlDb2x1bW5zO1wiIChjbGljayk9XCJvbkNsaWNrUm93KHJvdylcIj48L3RyPlxuICAgICAgICBcbiAgICAgICAgPCEtLSBSb3cgc2hvd24gd2hlbiB0aGVyZSBpcyBubyBtYXRjaGluZyBkYXRhLiAtLT5cbiAgICAgICAgPHRyIGNsYXNzPVwibWF0LXJvd1wiICptYXROb0RhdGFSb3c+PHRkIGNsYXNzPVwibWF0LWNlbGxcIiBjb2xzcGFuPVwiMTAwXCI+Tm8gZGF0YSBtYXRjaGluZzwvdGQ+PC90cj5cblxuICAgICAgICA8IS0tIFBhZ2luYXRvciAtLT5cbiAgICAgICAgPG1hdC1wYWdpbmF0b3IgKm5nSWY9XCJkYXRhSXRlbXNcIiBbcGFnZUluZGV4XT1cInBhZ2VJbmRleFwiIFtsZW5ndGhdPVwiZGF0YUl0ZW1zIS50b3RhbFwiIFtwYWdlU2l6ZV09XCJwYWdlU2l6ZVwiIFtwYWdlU2l6ZU9wdGlvbnNdPVwiWzUsIDEwLCAyNSwgNTAsIDEwMF1cIiAocGFnZSk9XCJvblBhZ2VDaGFuZ2UoJGV2ZW50KVwiPjwvbWF0LXBhZ2luYXRvcj5cbiAgICA8L3RhYmxlPlxuPC9kaXY+Il19
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy10YWJsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL3RhYmxlL3NyYy9saWIvY29tcG9uZW50cy90b3RzLXRhYmxlL3RvdHMtdGFibGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS90b3RzLXRhYmxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHL0UsT0FBTyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFcEMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtDQUFrQyxDQUFDOzs7Ozs7QUFPbkUsTUFBTSxPQUFPLGtCQUFrQjtJQUwvQjtRQU9XLFdBQU0sR0FBRyxJQUFJLGVBQWUsRUFBRSxDQUFDO1FBQy9CLGNBQVMsR0FBVyxDQUFDLENBQUM7UUFDdEIsYUFBUSxHQUFXLEVBQUUsQ0FBQztRQUN0QixrQkFBYSxHQUFZLElBQUksQ0FBQztRQUU3QixhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQW1CLENBQUM7UUFDekQsbUJBQWMsR0FBRyxJQUFJLE9BQU8sRUFBbUIsQ0FBQztRQUVoRCxjQUFTLEdBQUcsSUFBSSxDQUFDO1FBRWpCLG1CQUFjLEdBQWtCLEVBQUUsQ0FBQztLQWtDcEM7SUFoQ0MsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNsQixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVELFVBQVUsQ0FBQyxJQUFTO1FBQ2xCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQWdCO1FBQzNCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUN4RCxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztRQUN0QixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRTtZQUNqQixJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxHQUFHLENBQUMsQ0FBQztZQUN0QyxTQUFTLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQyxDQUFDO0lBQzNDLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRW5CLElBQUksQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQ3JDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzdCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksQ0FBQyxDQUFDLE9BQU8sSUFBSSxTQUFTLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDN0csQ0FBQzs7K0dBN0NVLGtCQUFrQjttR0FBbEIsa0JBQWtCLGlNQ1ovQiwrbkNBbUJNOzJGRFBPLGtCQUFrQjtrQkFMOUIsU0FBUzsrQkFDRSxZQUFZOzhCQU1iLE1BQU07c0JBQWQsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSztnQkFFSSxRQUFRO3NCQUFqQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUGFnZUV2ZW50IH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcGFnaW5hdG9yJztcbmltcG9ydCB7IFRvdHNMaXN0UmVzcG9uc2UgfSBmcm9tICdAdG90cy9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QsIHRhcCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgVG90c0FjdGlvblRhYmxlIH0gZnJvbSAnLi4vLi4vZW50aXRpZXMvdG90cy1hY3Rpb24tdGFibGUnO1xuaW1wb3J0IHsgVG90c1RhYmxlQ29uZmlnIH0gZnJvbSAnLi4vLi4vZW50aXRpZXMvdG90cy10YWJsZS1jb25maWcnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0b3RzLXRhYmxlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RvdHMtdGFibGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90b3RzLXRhYmxlLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgVG90c1RhYmxlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBASW5wdXQoKSBjb25maWcgPSBuZXcgVG90c1RhYmxlQ29uZmlnKCk7XG4gIEBJbnB1dCgpIHBhZ2VJbmRleDogbnVtYmVyID0gMDtcbiAgQElucHV0KCkgcGFnZVNpemU6IG51bWJlciA9IDUwO1xuICBASW5wdXQoKSBoYXNQYWdpbmF0aW9uOiBib29sZWFuID0gdHJ1ZTtcblxuICBAT3V0cHV0KCkgb25BY3Rpb24gPSBuZXcgRXZlbnRFbWl0dGVyPFRvdHNBY3Rpb25UYWJsZT4oKTtcbiAgcHJpdmF0ZUFjdGlvbnMgPSBuZXcgU3ViamVjdDxUb3RzQWN0aW9uVGFibGU+KCk7XG5cbiAgaXNMb2FkaW5nID0gdHJ1ZTtcbiAgZGF0YUl0ZW1zPzogVG90c0xpc3RSZXNwb25zZTxhbnk+O1xuICBkaXNwbGF5Q29sdW1uczogQXJyYXk8U3RyaW5nPiA9IFtdO1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMubG9hZENvbmZpZygpO1xuICAgIHRoaXMubG9hZEl0ZW1zKCk7XG4gIH1cblxuICBvbkNsaWNrUm93KGl0ZW06IGFueSkge1xuICAgIHRoaXMub25BY3Rpb24uZW1pdCh7IGtleTogJ2NsaWNrLXJvdycsIGl0ZW06IGl0ZW0gfSk7XG4gIH1cblxuICBvblBhZ2VDaGFuZ2UoZXZlbnQ6IFBhZ2VFdmVudCkge1xuICAgIHRoaXMub25BY3Rpb24uZW1pdCh7IGtleTogJ3BhZ2UtY2hhbmdlJywgaXRlbTogZXZlbnQgfSk7XG4gICAgdGhpcy5sb2FkSXRlbXMoKTtcbiAgfVxuXG4gIGxvYWRJdGVtcygpIHtcbiAgICB0aGlzLmlzTG9hZGluZyA9IHRydWU7XG4gICAgdGhpcy5jb25maWcub2JzPy5cbiAgICBwaXBlKHRhcChyZXMgPT4gdGhpcy5kYXRhSXRlbXMgPSByZXMpKS5cbiAgICBzdWJzY3JpYmUocmVzID0+IHRoaXMuaXNMb2FkaW5nID0gZmFsc2UpO1xuICB9XG5cbiAgbG9hZENvbmZpZygpIHtcbiAgICB0aGlzLmxvYWRDb2x1bW5zKCk7XG5cbiAgICB0aGlzLnByaXZhdGVBY3Rpb25zLnN1YnNjcmliZShhY3Rpb24gPT4ge1xuICAgICAgdGhpcy5vbkFjdGlvbi5lbWl0KGFjdGlvbik7XG4gICAgfSk7XG4gIH1cblxuICBsb2FkQ29sdW1ucygpIHtcbiAgICB0aGlzLmRpc3BsYXlDb2x1bW5zID0gdGhpcy5jb25maWcuY29sdW1ucy5maWx0ZXIoYyA9PiBjLmlzX3Nob3cgfHwgYy5pc19zaG93ID09IHVuZGVmaW5lZCkubWFwKGMgPT4gYy5rZXkpO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwidG90cy10YWJsZS1jb250YWluZXJcIj5cbiAgICA8dGFibGUgKm5nSWY9XCJkYXRhSXRlbXNcIiBtYXQtdGFibGUgW2RhdGFTb3VyY2VdPVwiZGF0YUl0ZW1zIS5kYXRhXCI+XG4gICAgICAgIFxuICAgICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBjb2x1bW4gb2YgY29uZmlnLmNvbHVtbnNcIiBbbWF0Q29sdW1uRGVmXT1cImNvbHVtbi5rZXlcIj5cbiAgICAgICAgICAgIDwhLS0gVEgtLT5cbiAgICAgICAgICAgIDx0aCBtYXQtaGVhZGVyLWNlbGwgKm1hdEhlYWRlckNlbGxEZWY+e3sgY29sdW1uLnRpdGxlIH19PC90aD5cbiAgICAgICAgICAgIDwhLS0gVEQgLS0+XG4gICAgICAgICAgICA8dGQgbWF0LWNlbGwgKm1hdENlbGxEZWY9XCJsZXQgaXRlbVwiPjx0b3RzLWJhc2UtcHJpbnQtY29sdW1uIFtjb2x1bW5dPVwiY29sdW1uXCIgW2l0ZW1dPVwiaXRlbVwiPjwvdG90cy1iYXNlLXByaW50LWNvbHVtbj48L3RkPlxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cblxuICAgICAgICA8dHIgbWF0LWhlYWRlci1yb3cgKm1hdEhlYWRlclJvd0RlZj1cImRpc3BsYXlDb2x1bW5zXCI+PC90cj5cbiAgICAgICAgPHRyIG1hdC1yb3cgKm1hdFJvd0RlZj1cImxldCByb3c7IGNvbHVtbnM6IGRpc3BsYXlDb2x1bW5zO1wiIChjbGljayk9XCJvbkNsaWNrUm93KHJvdylcIj48L3RyPlxuICAgICAgICBcbiAgICAgICAgPCEtLSBSb3cgc2hvd24gd2hlbiB0aGVyZSBpcyBubyBtYXRjaGluZyBkYXRhLiAtLT5cbiAgICAgICAgPHRyIGNsYXNzPVwibWF0LXJvd1wiICptYXROb0RhdGFSb3c+PHRkIGNsYXNzPVwibWF0LWNlbGxcIiBjb2xzcGFuPVwiMTAwXCI+Tm8gZGF0YSBtYXRjaGluZzwvdGQ+PC90cj5cblxuICAgICAgICA8IS0tIFBhZ2luYXRvciAtLT5cbiAgICAgICAgPG1hdC1wYWdpbmF0b3IgKm5nSWY9XCJkYXRhSXRlbXMgJiYgaGFzUGFnaW5hdGlvblwiIFtwYWdlSW5kZXhdPVwicGFnZUluZGV4XCIgW2xlbmd0aF09XCJkYXRhSXRlbXMhLnRvdGFsXCIgW3BhZ2VTaXplXT1cInBhZ2VTaXplXCIgW3BhZ2VTaXplT3B0aW9uc109XCJbNSwgMTAsIDI1LCA1MCwgMTAwXVwiIChwYWdlKT1cIm9uUGFnZUNoYW5nZSgkZXZlbnQpXCI+PC9tYXQtcGFnaW5hdG9yPlxuICAgIDwvdGFibGU+XG48L2Rpdj4iXX0=
@@ -6,6 +6,7 @@ import * as i1 from "../tots-table/tots-table.component";
6
6
  export class TotsTableApiComponent {
7
7
  constructor() {
8
8
  this.config = new TotsTableApiConfig();
9
+ this.hasPagination = true;
9
10
  this.onAction = new EventEmitter();
10
11
  this.configTable = new TotsTableConfig();
11
12
  }
@@ -17,6 +18,7 @@ export class TotsTableApiComponent {
17
18
  this.config.query.per_page = action.item.pageSize;
18
19
  this.config.query.page = action.item.pageIndex + 1;
19
20
  }
21
+ this.onAction.emit(action);
20
22
  }
21
23
  loadConfig() {
22
24
  this.configTable.id = this.config.id;
@@ -25,13 +27,15 @@ export class TotsTableApiComponent {
25
27
  }
26
28
  }
27
29
  TotsTableApiComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableApiComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
28
- TotsTableApiComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsTableApiComponent, selector: "tots-table-api", inputs: { config: "config" }, outputs: { onAction: "onAction" }, ngImport: i0, template: "<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"config.query.page\" [pageSize]=\"config.query.per_page\" (onAction)=\"onTableAction($event)\"></tots-table>\n", styles: [""], dependencies: [{ kind: "component", type: i1.TotsTableComponent, selector: "tots-table", inputs: ["config", "pageIndex", "pageSize"], outputs: ["onAction"] }] });
30
+ TotsTableApiComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsTableApiComponent, selector: "tots-table-api", inputs: { config: "config", hasPagination: "hasPagination" }, outputs: { onAction: "onAction" }, ngImport: i0, template: "<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"config.query.page\" [pageSize]=\"config.query.per_page\" (onAction)=\"onTableAction($event)\"></tots-table>\n", styles: [""], dependencies: [{ kind: "component", type: i1.TotsTableComponent, selector: "tots-table", inputs: ["config", "pageIndex", "pageSize", "hasPagination"], outputs: ["onAction"] }] });
29
31
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableApiComponent, decorators: [{
30
32
  type: Component,
31
33
  args: [{ selector: 'tots-table-api', template: "<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"config.query.page\" [pageSize]=\"config.query.per_page\" (onAction)=\"onTableAction($event)\"></tots-table>\n" }]
32
34
  }], propDecorators: { config: [{
33
35
  type: Input
36
+ }], hasPagination: [{
37
+ type: Input
34
38
  }], onAction: [{
35
39
  type: Output
36
40
  }] } });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy10YWJsZS1hcGkuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS1hcGkvdG90cy10YWJsZS1hcGkuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS1hcGkvdG90cy10YWJsZS1hcGkuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7OztBQU9uRSxNQUFNLE9BQU8scUJBQXFCO0lBTGxDO1FBTVcsV0FBTSxHQUFHLElBQUksa0JBQWtCLEVBQUUsQ0FBQztRQUVqQyxhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQW1CLENBQUM7UUFFekQsZ0JBQVcsR0FBRyxJQUFJLGVBQWUsRUFBRSxDQUFDO0tBa0JyQztJQWhCQyxRQUFRO1FBQ04sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ3BCLENBQUM7SUFFRCxhQUFhLENBQUMsTUFBdUI7UUFDbkMsSUFBRyxNQUFNLENBQUMsR0FBRyxJQUFJLGFBQWEsRUFBQztZQUM3QixJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7WUFDbEQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLENBQUMsQ0FBQztTQUNwRDtJQUNILENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDckMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7UUFDL0MsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckUsQ0FBQzs7a0hBdEJVLHFCQUFxQjtzR0FBckIscUJBQXFCLHVIQ1ZsQyw2S0FDQTsyRkRTYSxxQkFBcUI7a0JBTGpDLFNBQVM7K0JBQ0UsZ0JBQWdCOzhCQUtqQixNQUFNO3NCQUFkLEtBQUs7Z0JBRUksUUFBUTtzQkFBakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRvdHNBY3Rpb25UYWJsZSB9IGZyb20gJy4uLy4uL2VudGl0aWVzL3RvdHMtYWN0aW9uLXRhYmxlJztcbmltcG9ydCB7IFRvdHNUYWJsZUFwaUNvbmZpZyB9IGZyb20gJy4uLy4uL2VudGl0aWVzL3RvdHMtdGFibGUtYXBpLWNvbmZpZyc7XG5pbXBvcnQgeyBUb3RzVGFibGVDb25maWcgfSBmcm9tICcuLi8uLi9lbnRpdGllcy90b3RzLXRhYmxlLWNvbmZpZyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3RvdHMtdGFibGUtYXBpJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RvdHMtdGFibGUtYXBpLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vdG90cy10YWJsZS1hcGkuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBUb3RzVGFibGVBcGlDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBjb25maWcgPSBuZXcgVG90c1RhYmxlQXBpQ29uZmlnKCk7XG5cbiAgQE91dHB1dCgpIG9uQWN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjxUb3RzQWN0aW9uVGFibGU+KCk7XG5cbiAgY29uZmlnVGFibGUgPSBuZXcgVG90c1RhYmxlQ29uZmlnKCk7XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5sb2FkQ29uZmlnKCk7XG4gIH1cblxuICBvblRhYmxlQWN0aW9uKGFjdGlvbjogVG90c0FjdGlvblRhYmxlKSB7XG4gICAgaWYoYWN0aW9uLmtleSA9PSAncGFnZS1jaGFuZ2UnKXtcbiAgICAgIHRoaXMuY29uZmlnLnF1ZXJ5LnBlcl9wYWdlID0gYWN0aW9uLml0ZW0ucGFnZVNpemU7XG4gICAgICB0aGlzLmNvbmZpZy5xdWVyeS5wYWdlID0gYWN0aW9uLml0ZW0ucGFnZUluZGV4ICsgMTtcbiAgICB9XG4gIH1cblxuICBsb2FkQ29uZmlnKCkge1xuICAgIHRoaXMuY29uZmlnVGFibGUuaWQgPSB0aGlzLmNvbmZpZy5pZDtcbiAgICB0aGlzLmNvbmZpZ1RhYmxlLmNvbHVtbnMgPSB0aGlzLmNvbmZpZy5jb2x1bW5zO1xuICAgIHRoaXMuY29uZmlnVGFibGUub2JzID0gdGhpcy5jb25maWcuc2VydmljZS5saXN0KHRoaXMuY29uZmlnLnF1ZXJ5KTtcbiAgfVxufVxuIiwiPHRvdHMtdGFibGUgI3RhYmxlQ29tcCBbY29uZmlnXT1cImNvbmZpZ1RhYmxlXCIgW3BhZ2VJbmRleF09XCJjb25maWcucXVlcnkucGFnZVwiIFtwYWdlU2l6ZV09XCJjb25maWcucXVlcnkucGVyX3BhZ2VcIiAob25BY3Rpb24pPVwib25UYWJsZUFjdGlvbigkZXZlbnQpXCI+PC90b3RzLXRhYmxlPlxuIl19
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy10YWJsZS1hcGkuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS1hcGkvdG90cy10YWJsZS1hcGkuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS1hcGkvdG90cy10YWJsZS1hcGkuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7OztBQU9uRSxNQUFNLE9BQU8scUJBQXFCO0lBTGxDO1FBT1csV0FBTSxHQUFHLElBQUksa0JBQWtCLEVBQUUsQ0FBQztRQUNsQyxrQkFBYSxHQUFZLElBQUksQ0FBQztRQUU3QixhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQW1CLENBQUM7UUFFekQsZ0JBQVcsR0FBRyxJQUFJLGVBQWUsRUFBRSxDQUFDO0tBb0JyQztJQWxCQyxRQUFRO1FBQ04sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ3BCLENBQUM7SUFFRCxhQUFhLENBQUMsTUFBdUI7UUFDbkMsSUFBRyxNQUFNLENBQUMsR0FBRyxJQUFJLGFBQWEsRUFBQztZQUM3QixJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7WUFDbEQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLENBQUMsQ0FBQztTQUNwRDtRQUVELElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDckMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7UUFDL0MsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckUsQ0FBQzs7a0hBMUJVLHFCQUFxQjtzR0FBckIscUJBQXFCLHVKQ1ZsQyw2S0FDQTsyRkRTYSxxQkFBcUI7a0JBTGpDLFNBQVM7K0JBQ0UsZ0JBQWdCOzhCQU1qQixNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSztnQkFFSSxRQUFRO3NCQUFqQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVG90c0FjdGlvblRhYmxlIH0gZnJvbSAnLi4vLi4vZW50aXRpZXMvdG90cy1hY3Rpb24tdGFibGUnO1xuaW1wb3J0IHsgVG90c1RhYmxlQXBpQ29uZmlnIH0gZnJvbSAnLi4vLi4vZW50aXRpZXMvdG90cy10YWJsZS1hcGktY29uZmlnJztcbmltcG9ydCB7IFRvdHNUYWJsZUNvbmZpZyB9IGZyb20gJy4uLy4uL2VudGl0aWVzL3RvdHMtdGFibGUtY29uZmlnJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndG90cy10YWJsZS1hcGknLFxuICB0ZW1wbGF0ZVVybDogJy4vdG90cy10YWJsZS1hcGkuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90b3RzLXRhYmxlLWFwaS5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIFRvdHNUYWJsZUFwaUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIFxuICBASW5wdXQoKSBjb25maWcgPSBuZXcgVG90c1RhYmxlQXBpQ29uZmlnKCk7XG4gIEBJbnB1dCgpIGhhc1BhZ2luYXRpb246IGJvb2xlYW4gPSB0cnVlO1xuXG4gIEBPdXRwdXQoKSBvbkFjdGlvbiA9IG5ldyBFdmVudEVtaXR0ZXI8VG90c0FjdGlvblRhYmxlPigpO1xuXG4gIGNvbmZpZ1RhYmxlID0gbmV3IFRvdHNUYWJsZUNvbmZpZygpO1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMubG9hZENvbmZpZygpO1xuICB9XG5cbiAgb25UYWJsZUFjdGlvbihhY3Rpb246IFRvdHNBY3Rpb25UYWJsZSkge1xuICAgIGlmKGFjdGlvbi5rZXkgPT0gJ3BhZ2UtY2hhbmdlJyl7XG4gICAgICB0aGlzLmNvbmZpZy5xdWVyeS5wZXJfcGFnZSA9IGFjdGlvbi5pdGVtLnBhZ2VTaXplO1xuICAgICAgdGhpcy5jb25maWcucXVlcnkucGFnZSA9IGFjdGlvbi5pdGVtLnBhZ2VJbmRleCArIDE7XG4gICAgfVxuXG4gICAgdGhpcy5vbkFjdGlvbi5lbWl0KGFjdGlvbik7XG4gIH1cblxuICBsb2FkQ29uZmlnKCkge1xuICAgIHRoaXMuY29uZmlnVGFibGUuaWQgPSB0aGlzLmNvbmZpZy5pZDtcbiAgICB0aGlzLmNvbmZpZ1RhYmxlLmNvbHVtbnMgPSB0aGlzLmNvbmZpZy5jb2x1bW5zO1xuICAgIHRoaXMuY29uZmlnVGFibGUub2JzID0gdGhpcy5jb25maWcuc2VydmljZS5saXN0KHRoaXMuY29uZmlnLnF1ZXJ5KTtcbiAgfVxufVxuIiwiPHRvdHMtdGFibGUgI3RhYmxlQ29tcCBbY29uZmlnXT1cImNvbmZpZ1RhYmxlXCIgW3BhZ2VJbmRleF09XCJjb25maWcucXVlcnkucGFnZVwiIFtwYWdlU2l6ZV09XCJjb25maWcucXVlcnkucGVyX3BhZ2VcIiAob25BY3Rpb24pPVwib25UYWJsZUFjdGlvbigkZXZlbnQpXCI+PC90b3RzLXRhYmxlPlxuIl19
@@ -1,14 +1,18 @@
1
1
  import { NgModule } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  /** Angular Material */
4
+ import { MatIconModule } from '@angular/material/icon';
5
+ import { MatButtonModule } from '@angular/material/button';
4
6
  import { MatTableModule } from '@angular/material/table';
5
7
  import { MatPaginatorModule } from '@angular/material/paginator';
8
+ import { MatMenuModule } from '@angular/material/menu';
6
9
  /** Components */
7
10
  import { TotsTableComponent } from './components/tots-table/tots-table.component';
8
11
  import { TotsTableApiComponent } from './components/tots-table-api/tots-table-api.component';
9
12
  /** Columns */
10
13
  import { BasePrintColumnComponent } from './columns/base-print-column/base-print-column.component';
11
14
  import { StringColumnComponent } from './columns/string-column/string-column.component';
15
+ import { MoreMenuColumnComponent } from './columns/more-menu-column/more-menu-column.component';
12
16
  import * as i0 from "@angular/core";
13
17
  export class TotsTableModule {
14
18
  }
@@ -16,15 +20,22 @@ TotsTableModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version:
16
20
  TotsTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.0.3", ngImport: i0, type: TotsTableModule, declarations: [TotsTableComponent,
17
21
  BasePrintColumnComponent,
18
22
  StringColumnComponent,
19
- TotsTableApiComponent], imports: [CommonModule,
23
+ TotsTableApiComponent,
24
+ MoreMenuColumnComponent], imports: [CommonModule,
20
25
  // Angular Material
26
+ MatIconModule,
21
27
  MatTableModule,
22
- MatPaginatorModule], exports: [TotsTableComponent,
28
+ MatPaginatorModule,
29
+ MatButtonModule,
30
+ MatMenuModule], exports: [TotsTableComponent,
23
31
  TotsTableApiComponent] });
24
32
  TotsTableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableModule, imports: [CommonModule,
25
33
  // Angular Material
34
+ MatIconModule,
26
35
  MatTableModule,
27
- MatPaginatorModule] });
36
+ MatPaginatorModule,
37
+ MatButtonModule,
38
+ MatMenuModule] });
28
39
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableModule, decorators: [{
29
40
  type: NgModule,
30
41
  args: [{
@@ -32,13 +43,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
32
43
  TotsTableComponent,
33
44
  BasePrintColumnComponent,
34
45
  StringColumnComponent,
35
- TotsTableApiComponent
46
+ TotsTableApiComponent,
47
+ MoreMenuColumnComponent
36
48
  ],
37
49
  imports: [
38
50
  CommonModule,
39
51
  // Angular Material
52
+ MatIconModule,
40
53
  MatTableModule,
41
- MatPaginatorModule
54
+ MatPaginatorModule,
55
+ MatButtonModule,
56
+ MatMenuModule,
42
57
  ],
43
58
  exports: [
44
59
  TotsTableComponent,
@@ -46,4 +61,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
46
61
  ]
47
62
  }]
48
63
  }] });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL3RhYmxlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyx1QkFBdUI7QUFDdkIsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRWpFLGlCQUFpQjtBQUNqQixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUNsRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUU3RixjQUFjO0FBQ2QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDbkcsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0saURBQWlELENBQUM7O0FBc0J4RixNQUFNLE9BQU8sZUFBZTs7NEdBQWYsZUFBZTs2R0FBZixlQUFlLGlCQWhCeEIsa0JBQWtCO1FBQ2xCLHdCQUF3QjtRQUN4QixxQkFBcUI7UUFDckIscUJBQXFCLGFBR3JCLFlBQVk7UUFDWixtQkFBbUI7UUFDbkIsY0FBYztRQUNkLGtCQUFrQixhQUdsQixrQkFBa0I7UUFDbEIscUJBQXFCOzZHQUdaLGVBQWUsWUFWeEIsWUFBWTtRQUNaLG1CQUFtQjtRQUNuQixjQUFjO1FBQ2Qsa0JBQWtCOzJGQU9ULGVBQWU7a0JBbEIzQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixrQkFBa0I7d0JBQ2xCLHdCQUF3Qjt3QkFDeEIscUJBQXFCO3dCQUNyQixxQkFBcUI7cUJBQ3RCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLG1CQUFtQjt3QkFDbkIsY0FBYzt3QkFDZCxrQkFBa0I7cUJBQ25CO29CQUNELE9BQU8sRUFBRTt3QkFDUCxrQkFBa0I7d0JBQ2xCLHFCQUFxQjtxQkFDdEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuLyoqIEFuZ3VsYXIgTWF0ZXJpYWwgKi9cbmltcG9ydCB7IE1hdFRhYmxlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFibGUnO1xuaW1wb3J0IHsgTWF0UGFnaW5hdG9yTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcGFnaW5hdG9yJztcblxuLyoqIENvbXBvbmVudHMgKi9cbmltcG9ydCB7IFRvdHNUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90b3RzLXRhYmxlL3RvdHMtdGFibGUuY29tcG9uZW50JztcbmltcG9ydCB7IFRvdHNUYWJsZUFwaUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90b3RzLXRhYmxlLWFwaS90b3RzLXRhYmxlLWFwaS5jb21wb25lbnQnO1xuXG4vKiogQ29sdW1ucyAqL1xuaW1wb3J0IHsgQmFzZVByaW50Q29sdW1uQ29tcG9uZW50IH0gZnJvbSAnLi9jb2x1bW5zL2Jhc2UtcHJpbnQtY29sdW1uL2Jhc2UtcHJpbnQtY29sdW1uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTdHJpbmdDb2x1bW5Db21wb25lbnQgfSBmcm9tICcuL2NvbHVtbnMvc3RyaW5nLWNvbHVtbi9zdHJpbmctY29sdW1uLmNvbXBvbmVudCc7XG5cblxuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBUb3RzVGFibGVDb21wb25lbnQsXG4gICAgQmFzZVByaW50Q29sdW1uQ29tcG9uZW50LFxuICAgIFN0cmluZ0NvbHVtbkNvbXBvbmVudCxcbiAgICBUb3RzVGFibGVBcGlDb21wb25lbnRcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICAvLyBBbmd1bGFyIE1hdGVyaWFsXG4gICAgTWF0VGFibGVNb2R1bGUsXG4gICAgTWF0UGFnaW5hdG9yTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBUb3RzVGFibGVDb21wb25lbnQsXG4gICAgVG90c1RhYmxlQXBpQ29tcG9uZW50XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgVG90c1RhYmxlTW9kdWxlIHsgfVxuIl19
64
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy90YWJsZS9zcmMvbGliL3RhYmxlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyx1QkFBdUI7QUFDdkIsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDakUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRXZELGlCQUFpQjtBQUNqQixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUNsRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUU3RixjQUFjO0FBQ2QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDbkcsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0saURBQWlELENBQUM7QUFDeEYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sdURBQXVELENBQUM7O0FBMEJoRyxNQUFNLE9BQU8sZUFBZTs7NEdBQWYsZUFBZTs2R0FBZixlQUFlLGlCQXBCeEIsa0JBQWtCO1FBQ2xCLHdCQUF3QjtRQUN4QixxQkFBcUI7UUFDckIscUJBQXFCO1FBQ3JCLHVCQUF1QixhQUd2QixZQUFZO1FBQ1osbUJBQW1CO1FBQ25CLGFBQWE7UUFDYixjQUFjO1FBQ2Qsa0JBQWtCO1FBQ2xCLGVBQWU7UUFDZixhQUFhLGFBR2Isa0JBQWtCO1FBQ2xCLHFCQUFxQjs2R0FHWixlQUFlLFlBYnhCLFlBQVk7UUFDWixtQkFBbUI7UUFDbkIsYUFBYTtRQUNiLGNBQWM7UUFDZCxrQkFBa0I7UUFDbEIsZUFBZTtRQUNmLGFBQWE7MkZBT0osZUFBZTtrQkF0QjNCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGtCQUFrQjt3QkFDbEIsd0JBQXdCO3dCQUN4QixxQkFBcUI7d0JBQ3JCLHFCQUFxQjt3QkFDckIsdUJBQXVCO3FCQUN4QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IsY0FBYzt3QkFDZCxrQkFBa0I7d0JBQ2xCLGVBQWU7d0JBQ2YsYUFBYTtxQkFDZDtvQkFDRCxPQUFPLEVBQUU7d0JBQ1Asa0JBQWtCO3dCQUNsQixxQkFBcUI7cUJBQ3RCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbi8qKiBBbmd1bGFyIE1hdGVyaWFsICovXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0VGFibGVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90YWJsZSc7XG5pbXBvcnQgeyBNYXRQYWdpbmF0b3JNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wYWdpbmF0b3InO1xuaW1wb3J0IHsgTWF0TWVudU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL21lbnUnO1xuXG4vKiogQ29tcG9uZW50cyAqL1xuaW1wb3J0IHsgVG90c1RhYmxlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3RvdHMtdGFibGUvdG90cy10YWJsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgVG90c1RhYmxlQXBpQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3RvdHMtdGFibGUtYXBpL3RvdHMtdGFibGUtYXBpLmNvbXBvbmVudCc7XG5cbi8qKiBDb2x1bW5zICovXG5pbXBvcnQgeyBCYXNlUHJpbnRDb2x1bW5Db21wb25lbnQgfSBmcm9tICcuL2NvbHVtbnMvYmFzZS1wcmludC1jb2x1bW4vYmFzZS1wcmludC1jb2x1bW4uY29tcG9uZW50JztcbmltcG9ydCB7IFN0cmluZ0NvbHVtbkNvbXBvbmVudCB9IGZyb20gJy4vY29sdW1ucy9zdHJpbmctY29sdW1uL3N0cmluZy1jb2x1bW4uY29tcG9uZW50JztcbmltcG9ydCB7IE1vcmVNZW51Q29sdW1uQ29tcG9uZW50IH0gZnJvbSAnLi9jb2x1bW5zL21vcmUtbWVudS1jb2x1bW4vbW9yZS1tZW51LWNvbHVtbi5jb21wb25lbnQnO1xuXG5cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgVG90c1RhYmxlQ29tcG9uZW50LFxuICAgIEJhc2VQcmludENvbHVtbkNvbXBvbmVudCxcbiAgICBTdHJpbmdDb2x1bW5Db21wb25lbnQsXG4gICAgVG90c1RhYmxlQXBpQ29tcG9uZW50LFxuICAgIE1vcmVNZW51Q29sdW1uQ29tcG9uZW50XG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgLy8gQW5ndWxhciBNYXRlcmlhbFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0VGFibGVNb2R1bGUsXG4gICAgTWF0UGFnaW5hdG9yTW9kdWxlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBNYXRNZW51TW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgVG90c1RhYmxlQ29tcG9uZW50LFxuICAgIFRvdHNUYWJsZUFwaUNvbXBvbmVudFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFRvdHNUYWJsZU1vZHVsZSB7IH1cbiJdfQ==
@@ -7,6 +7,7 @@
7
7
  export * from './lib/entities/tots-column';
8
8
  export * from './lib/entities/tots-table-config';
9
9
  export * from './lib/entities/tots-action-table';
10
+ export * from './lib/entities/tots-table-api-config';
10
11
  /**
11
12
  * Helpers
12
13
  */
@@ -16,6 +17,7 @@ export * from './lib/helpers/tots-table-helper';
16
17
  */
17
18
  export * from './lib/columns/tots-base-column.component';
18
19
  export * from './lib/columns/string-column/string-column.component';
20
+ export * from './lib/columns/more-menu-column/more-menu-column.component';
19
21
  /**
20
22
  * Components
21
23
  */
@@ -25,4 +27,4 @@ export * from './lib/components/tots-table-api/tots-table-api.component';
25
27
  * Modules
26
28
  */
27
29
  export * from './lib/table.module';
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3RvdHMvdGFibGUvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSDs7R0FFRztBQUNILGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLGtDQUFrQyxDQUFDO0FBRWpEOztHQUVHO0FBQ0gsY0FBYyxpQ0FBaUMsQ0FBQztBQUVoRDs7R0FFRztBQUNILGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyxxREFBcUQsQ0FBQztBQUVwRTs7R0FFRztBQUNILGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYywwREFBMEQsQ0FBQztBQUV6RTs7R0FFRztBQUNILGNBQWMsb0JBQW9CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHRhYmxlXG4gKi9cblxuLyoqXG4gKiBFbnRpdGllc1xuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbnRpdGllcy90b3RzLWNvbHVtbic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbnRpdGllcy90b3RzLXRhYmxlLWNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbnRpdGllcy90b3RzLWFjdGlvbi10YWJsZSc7XG5cbi8qKlxuICogSGVscGVyc1xuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9oZWxwZXJzL3RvdHMtdGFibGUtaGVscGVyJztcblxuLyoqXG4gKiBDb2x1bW5zXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbnMvdG90cy1iYXNlLWNvbHVtbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1ucy9zdHJpbmctY29sdW1uL3N0cmluZy1jb2x1bW4uY29tcG9uZW50JztcblxuLyoqXG4gKiBDb21wb25lbnRzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS90b3RzLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RvdHMtdGFibGUtYXBpL3RvdHMtdGFibGUtYXBpLmNvbXBvbmVudCc7XG5cbi8qKlxuICogTW9kdWxlc1xuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS5tb2R1bGUnO1xuIl19
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3RvdHMvdGFibGUvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSDs7R0FFRztBQUNILGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsc0NBQXNDLENBQUM7QUFFckQ7O0dBRUc7QUFDSCxjQUFjLGlDQUFpQyxDQUFDO0FBRWhEOztHQUVHO0FBQ0gsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsMkRBQTJELENBQUM7QUFFMUU7O0dBRUc7QUFDSCxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsMERBQTBELENBQUM7QUFFekU7O0dBRUc7QUFDSCxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiB0YWJsZVxuICovXG5cbi8qKlxuICogRW50aXRpZXNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW50aXRpZXMvdG90cy1jb2x1bW4nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW50aXRpZXMvdG90cy10YWJsZS1jb25maWcnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW50aXRpZXMvdG90cy1hY3Rpb24tdGFibGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW50aXRpZXMvdG90cy10YWJsZS1hcGktY29uZmlnJztcblxuLyoqXG4gKiBIZWxwZXJzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2hlbHBlcnMvdG90cy10YWJsZS1oZWxwZXInO1xuXG4vKipcbiAqIENvbHVtbnNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1ucy90b3RzLWJhc2UtY29sdW1uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2x1bW5zL3N0cmluZy1jb2x1bW4vc3RyaW5nLWNvbHVtbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1ucy9tb3JlLW1lbnUtY29sdW1uL21vcmUtbWVudS1jb2x1bW4uY29tcG9uZW50JztcblxuLyoqXG4gKiBDb21wb25lbnRzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS90b3RzLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RvdHMtdGFibGUtYXBpL3RvdHMtdGFibGUtYXBpLmNvbXBvbmVudCc7XG5cbi8qKlxuICogTW9kdWxlc1xuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS5tb2R1bGUnO1xuIl19
@@ -1,13 +1,19 @@
1
+ import { TotsQuery } from '@tots/core';
1
2
  import * as i0 from '@angular/core';
2
3
  import { Component, Input, EventEmitter, Output, NgModule } from '@angular/core';
3
- import { tap } from 'rxjs';
4
4
  import * as i1 from '@angular/common';
5
5
  import { CommonModule } from '@angular/common';
6
- import * as i2 from '@angular/material/table';
6
+ import * as i2 from '@angular/material/icon';
7
+ import { MatIconModule } from '@angular/material/icon';
8
+ import * as i3 from '@angular/material/button';
9
+ import { MatButtonModule } from '@angular/material/button';
10
+ import * as i4 from '@angular/material/menu';
11
+ import { MatMenuModule } from '@angular/material/menu';
12
+ import { Subject, tap } from 'rxjs';
13
+ import * as i2$1 from '@angular/material/table';
7
14
  import { MatTableModule } from '@angular/material/table';
8
- import * as i3 from '@angular/material/paginator';
15
+ import * as i3$1 from '@angular/material/paginator';
9
16
  import { MatPaginatorModule } from '@angular/material/paginator';
10
- import { TotsQuery } from '@tots/core';
11
17
 
12
18
  class TotsColumn {
13
19
  constructor() {
@@ -30,6 +36,14 @@ class TotsActionTable {
30
36
  }
31
37
  }
32
38
 
39
+ class TotsTableApiConfig {
40
+ constructor() {
41
+ this.id = '';
42
+ this.columns = [];
43
+ this.query = new TotsQuery();
44
+ }
45
+ }
46
+
33
47
  class TotsTableHelper {
34
48
  /**
35
49
  * Obtiene el valor de un objeto a traves de la KEY
@@ -61,7 +75,7 @@ class TotsBaseColumnComponent {
61
75
  }
62
76
  }
63
77
  TotsBaseColumnComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsBaseColumnComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
64
- TotsBaseColumnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsBaseColumnComponent, selector: "tots-base-column", inputs: { column: "column", item: "item" }, ngImport: i0, template: '', isInline: true });
78
+ TotsBaseColumnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsBaseColumnComponent, selector: "tots-base-column", inputs: { column: "column", item: "item", onAction: "onAction" }, ngImport: i0, template: '', isInline: true });
65
79
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsBaseColumnComponent, decorators: [{
66
80
  type: Component,
67
81
  args: [{
@@ -72,6 +86,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
72
86
  type: Input
73
87
  }], item: [{
74
88
  type: Input
89
+ }], onAction: [{
90
+ type: Input
75
91
  }] } });
76
92
 
77
93
  class StringColumnComponent extends TotsBaseColumnComponent {
@@ -83,6 +99,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
83
99
  args: [{ selector: 'tots-string-column', template: "{{getItemValue()}}" }]
84
100
  }] });
85
101
 
102
+ class MoreMenuColumnComponent extends TotsBaseColumnComponent {
103
+ clickButton(itemAction, $event) {
104
+ this.onAction.next({ key: itemAction.key, item: this.item });
105
+ $event.preventDefault();
106
+ return false;
107
+ }
108
+ }
109
+ MoreMenuColumnComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: MoreMenuColumnComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
110
+ MoreMenuColumnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: MoreMenuColumnComponent, selector: "tots-more-menu-column", usesInheritance: true, ngImport: i0, template: "<button mat-icon-button [matMenuTriggerFor]=\"actions\" (click)=\"$event.stopPropagation()\"><mat-icon>more_vert</mat-icon></button>\n<mat-menu #actions=\"matMenu\">\n <button mat-menu-item *ngFor=\"let button of column.extra?.actions\" (click)=\"clickButton(button, $event)\">\n <mat-icon *ngIf=\"button.icon\">{{ button.icon }}</mat-icon> {{ button.title }}\n </button>\n</mat-menu>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i4.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }] });
111
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: MoreMenuColumnComponent, decorators: [{
112
+ type: Component,
113
+ args: [{ selector: 'tots-more-menu-column', template: "<button mat-icon-button [matMenuTriggerFor]=\"actions\" (click)=\"$event.stopPropagation()\"><mat-icon>more_vert</mat-icon></button>\n<mat-menu #actions=\"matMenu\">\n <button mat-menu-item *ngFor=\"let button of column.extra?.actions\" (click)=\"clickButton(button, $event)\">\n <mat-icon *ngIf=\"button.icon\">{{ button.icon }}</mat-icon> {{ button.title }}\n </button>\n</mat-menu>" }]
114
+ }] });
115
+
86
116
  class BasePrintColumnComponent {
87
117
  constructor(viewContainerRef) {
88
118
  this.viewContainerRef = viewContainerRef;
@@ -91,10 +121,11 @@ class BasePrintColumnComponent {
91
121
  const view = this.viewContainerRef.createComponent(this.column.component);
92
122
  view.instance.column = this.column;
93
123
  view.instance.item = this.item;
124
+ view.instance.onAction = this.onAction;
94
125
  }
95
126
  }
96
127
  BasePrintColumnComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: BasePrintColumnComponent, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
97
- BasePrintColumnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: BasePrintColumnComponent, selector: "tots-base-print-column", inputs: { column: "column", item: "item" }, ngImport: i0, template: "<div #contentColumn></div>", styles: [""] });
128
+ BasePrintColumnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: BasePrintColumnComponent, selector: "tots-base-print-column", inputs: { column: "column", item: "item", onAction: "onAction" }, ngImport: i0, template: "<div #contentColumn></div>", styles: [""] });
98
129
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: BasePrintColumnComponent, decorators: [{
99
130
  type: Component,
100
131
  args: [{ selector: 'tots-base-print-column', template: "<div #contentColumn></div>" }]
@@ -102,6 +133,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
102
133
  type: Input
103
134
  }], item: [{
104
135
  type: Input
136
+ }], onAction: [{
137
+ type: Input
105
138
  }] } });
106
139
 
107
140
  class TotsTableComponent {
@@ -109,7 +142,9 @@ class TotsTableComponent {
109
142
  this.config = new TotsTableConfig();
110
143
  this.pageIndex = 0;
111
144
  this.pageSize = 50;
145
+ this.hasPagination = true;
112
146
  this.onAction = new EventEmitter();
147
+ this.privateActions = new Subject();
113
148
  this.isLoading = true;
114
149
  this.displayColumns = [];
115
150
  }
@@ -131,37 +166,35 @@ class TotsTableComponent {
131
166
  }
132
167
  loadConfig() {
133
168
  this.loadColumns();
169
+ this.privateActions.subscribe(action => {
170
+ this.onAction.emit(action);
171
+ });
134
172
  }
135
173
  loadColumns() {
136
174
  this.displayColumns = this.config.columns.filter(c => c.is_show || c.is_show == undefined).map(c => c.key);
137
175
  }
138
176
  }
139
177
  TotsTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
140
- TotsTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsTableComponent, selector: "tots-table", inputs: { config: "config", pageIndex: "pageIndex", pageSize: "pageSize" }, outputs: { onAction: "onAction" }, ngImport: i0, template: "<div class=\"tots-table-container\">\n <table *ngIf=\"dataItems\" mat-table [dataSource]=\"dataItems!.data\">\n \n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.key\">\n <!-- TH-->\n <th mat-header-cell *matHeaderCellDef>{{ column.title }}</th>\n <!-- TD -->\n <td mat-cell *matCellDef=\"let item\"><tots-base-print-column [column]=\"column\" [item]=\"item\"></tots-base-print-column></td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayColumns;\" (click)=\"onClickRow(row)\"></tr>\n \n <!-- Row shown when there is no matching data. -->\n <tr class=\"mat-row\" *matNoDataRow><td class=\"mat-cell\" colspan=\"100\">No data matching</td></tr>\n\n <!-- Paginator -->\n <mat-paginator *ngIf=\"dataItems\" [pageIndex]=\"pageIndex\" [length]=\"dataItems!.total\" [pageSize]=\"pageSize\" [pageSizeOptions]=\"[5, 10, 25, 50, 100]\" (page)=\"onPageChange($event)\"></mat-paginator>\n </table>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i2.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i2.MatNoDataRow, selector: "ng-template[matNoDataRow]" }, { kind: "component", type: i3.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: BasePrintColumnComponent, selector: "tots-base-print-column", inputs: ["column", "item"] }] });
178
+ TotsTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsTableComponent, selector: "tots-table", inputs: { config: "config", pageIndex: "pageIndex", pageSize: "pageSize", hasPagination: "hasPagination" }, outputs: { onAction: "onAction" }, ngImport: i0, template: "<div class=\"tots-table-container\">\n <table *ngIf=\"dataItems\" mat-table [dataSource]=\"dataItems!.data\">\n \n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.key\">\n <!-- TH-->\n <th mat-header-cell *matHeaderCellDef>{{ column.title }}</th>\n <!-- TD -->\n <td mat-cell *matCellDef=\"let item\"><tots-base-print-column [column]=\"column\" [item]=\"item\"></tots-base-print-column></td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayColumns;\" (click)=\"onClickRow(row)\"></tr>\n \n <!-- Row shown when there is no matching data. -->\n <tr class=\"mat-row\" *matNoDataRow><td class=\"mat-cell\" colspan=\"100\">No data matching</td></tr>\n\n <!-- Paginator -->\n <mat-paginator *ngIf=\"dataItems && hasPagination\" [pageIndex]=\"pageIndex\" [length]=\"dataItems!.total\" [pageSize]=\"pageSize\" [pageSizeOptions]=\"[5, 10, 25, 50, 100]\" (page)=\"onPageChange($event)\"></mat-paginator>\n </table>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2$1.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i2$1.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i2$1.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i2$1.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i2$1.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i2$1.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i2$1.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i2$1.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i2$1.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i2$1.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i2$1.MatNoDataRow, selector: "ng-template[matNoDataRow]" }, { kind: "component", type: i3$1.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: BasePrintColumnComponent, selector: "tots-base-print-column", inputs: ["column", "item", "onAction"] }] });
141
179
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableComponent, decorators: [{
142
180
  type: Component,
143
- args: [{ selector: 'tots-table', template: "<div class=\"tots-table-container\">\n <table *ngIf=\"dataItems\" mat-table [dataSource]=\"dataItems!.data\">\n \n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.key\">\n <!-- TH-->\n <th mat-header-cell *matHeaderCellDef>{{ column.title }}</th>\n <!-- TD -->\n <td mat-cell *matCellDef=\"let item\"><tots-base-print-column [column]=\"column\" [item]=\"item\"></tots-base-print-column></td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayColumns;\" (click)=\"onClickRow(row)\"></tr>\n \n <!-- Row shown when there is no matching data. -->\n <tr class=\"mat-row\" *matNoDataRow><td class=\"mat-cell\" colspan=\"100\">No data matching</td></tr>\n\n <!-- Paginator -->\n <mat-paginator *ngIf=\"dataItems\" [pageIndex]=\"pageIndex\" [length]=\"dataItems!.total\" [pageSize]=\"pageSize\" [pageSizeOptions]=\"[5, 10, 25, 50, 100]\" (page)=\"onPageChange($event)\"></mat-paginator>\n </table>\n</div>" }]
181
+ args: [{ selector: 'tots-table', template: "<div class=\"tots-table-container\">\n <table *ngIf=\"dataItems\" mat-table [dataSource]=\"dataItems!.data\">\n \n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.key\">\n <!-- TH-->\n <th mat-header-cell *matHeaderCellDef>{{ column.title }}</th>\n <!-- TD -->\n <td mat-cell *matCellDef=\"let item\"><tots-base-print-column [column]=\"column\" [item]=\"item\"></tots-base-print-column></td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayColumns;\" (click)=\"onClickRow(row)\"></tr>\n \n <!-- Row shown when there is no matching data. -->\n <tr class=\"mat-row\" *matNoDataRow><td class=\"mat-cell\" colspan=\"100\">No data matching</td></tr>\n\n <!-- Paginator -->\n <mat-paginator *ngIf=\"dataItems && hasPagination\" [pageIndex]=\"pageIndex\" [length]=\"dataItems!.total\" [pageSize]=\"pageSize\" [pageSizeOptions]=\"[5, 10, 25, 50, 100]\" (page)=\"onPageChange($event)\"></mat-paginator>\n </table>\n</div>" }]
144
182
  }], propDecorators: { config: [{
145
183
  type: Input
146
184
  }], pageIndex: [{
147
185
  type: Input
148
186
  }], pageSize: [{
149
187
  type: Input
188
+ }], hasPagination: [{
189
+ type: Input
150
190
  }], onAction: [{
151
191
  type: Output
152
192
  }] } });
153
193
 
154
- class TotsTableApiConfig {
155
- constructor() {
156
- this.id = '';
157
- this.columns = [];
158
- this.query = new TotsQuery();
159
- }
160
- }
161
-
162
194
  class TotsTableApiComponent {
163
195
  constructor() {
164
196
  this.config = new TotsTableApiConfig();
197
+ this.hasPagination = true;
165
198
  this.onAction = new EventEmitter();
166
199
  this.configTable = new TotsTableConfig();
167
200
  }
@@ -173,6 +206,7 @@ class TotsTableApiComponent {
173
206
  this.config.query.per_page = action.item.pageSize;
174
207
  this.config.query.page = action.item.pageIndex + 1;
175
208
  }
209
+ this.onAction.emit(action);
176
210
  }
177
211
  loadConfig() {
178
212
  this.configTable.id = this.config.id;
@@ -181,12 +215,14 @@ class TotsTableApiComponent {
181
215
  }
182
216
  }
183
217
  TotsTableApiComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableApiComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
184
- TotsTableApiComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsTableApiComponent, selector: "tots-table-api", inputs: { config: "config" }, outputs: { onAction: "onAction" }, ngImport: i0, template: "<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"config.query.page\" [pageSize]=\"config.query.per_page\" (onAction)=\"onTableAction($event)\"></tots-table>\n", styles: [""], dependencies: [{ kind: "component", type: TotsTableComponent, selector: "tots-table", inputs: ["config", "pageIndex", "pageSize"], outputs: ["onAction"] }] });
218
+ TotsTableApiComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsTableApiComponent, selector: "tots-table-api", inputs: { config: "config", hasPagination: "hasPagination" }, outputs: { onAction: "onAction" }, ngImport: i0, template: "<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"config.query.page\" [pageSize]=\"config.query.per_page\" (onAction)=\"onTableAction($event)\"></tots-table>\n", styles: [""], dependencies: [{ kind: "component", type: TotsTableComponent, selector: "tots-table", inputs: ["config", "pageIndex", "pageSize", "hasPagination"], outputs: ["onAction"] }] });
185
219
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableApiComponent, decorators: [{
186
220
  type: Component,
187
221
  args: [{ selector: 'tots-table-api', template: "<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"config.query.page\" [pageSize]=\"config.query.per_page\" (onAction)=\"onTableAction($event)\"></tots-table>\n" }]
188
222
  }], propDecorators: { config: [{
189
223
  type: Input
224
+ }], hasPagination: [{
225
+ type: Input
190
226
  }], onAction: [{
191
227
  type: Output
192
228
  }] } });
@@ -197,15 +233,22 @@ TotsTableModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version:
197
233
  TotsTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.0.3", ngImport: i0, type: TotsTableModule, declarations: [TotsTableComponent,
198
234
  BasePrintColumnComponent,
199
235
  StringColumnComponent,
200
- TotsTableApiComponent], imports: [CommonModule,
236
+ TotsTableApiComponent,
237
+ MoreMenuColumnComponent], imports: [CommonModule,
201
238
  // Angular Material
239
+ MatIconModule,
202
240
  MatTableModule,
203
- MatPaginatorModule], exports: [TotsTableComponent,
241
+ MatPaginatorModule,
242
+ MatButtonModule,
243
+ MatMenuModule], exports: [TotsTableComponent,
204
244
  TotsTableApiComponent] });
205
245
  TotsTableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableModule, imports: [CommonModule,
206
246
  // Angular Material
247
+ MatIconModule,
207
248
  MatTableModule,
208
- MatPaginatorModule] });
249
+ MatPaginatorModule,
250
+ MatButtonModule,
251
+ MatMenuModule] });
209
252
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableModule, decorators: [{
210
253
  type: NgModule,
211
254
  args: [{
@@ -213,13 +256,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
213
256
  TotsTableComponent,
214
257
  BasePrintColumnComponent,
215
258
  StringColumnComponent,
216
- TotsTableApiComponent
259
+ TotsTableApiComponent,
260
+ MoreMenuColumnComponent
217
261
  ],
218
262
  imports: [
219
263
  CommonModule,
220
264
  // Angular Material
265
+ MatIconModule,
221
266
  MatTableModule,
222
- MatPaginatorModule
267
+ MatPaginatorModule,
268
+ MatButtonModule,
269
+ MatMenuModule,
223
270
  ],
224
271
  exports: [
225
272
  TotsTableComponent,
@@ -236,5 +283,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
236
283
  * Generated bundle index. Do not edit.
237
284
  */
238
285
 
239
- export { StringColumnComponent, TotsActionTable, TotsBaseColumnComponent, TotsColumn, TotsTableApiComponent, TotsTableComponent, TotsTableConfig, TotsTableHelper, TotsTableModule };
286
+ export { MoreMenuColumnComponent, StringColumnComponent, TotsActionTable, TotsBaseColumnComponent, TotsColumn, TotsTableApiComponent, TotsTableApiConfig, TotsTableComponent, TotsTableConfig, TotsTableHelper, TotsTableModule };
240
287
  //# sourceMappingURL=tots-table.mjs.map