@lumeer/pivot 0.0.3 → 0.0.6

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.
@@ -16,9 +16,11 @@ export class LmrPivotTableComponent {
16
16
  constraintData;
17
17
  config;
18
18
  transform;
19
- strings;
19
+ emptyTablesTemplateInput;
20
+ tableCellTemplateInput;
20
21
  cellClick = new EventEmitter();
21
22
  pivotDataChange = new EventEmitter();
23
+ pivotTablesChange = new EventEmitter();
22
24
  emptyTablesTemplate;
23
25
  tableCellTemplate;
24
26
  pivotTransformer = new PivotDataConverter();
@@ -29,7 +31,7 @@ export class LmrPivotTableComponent {
29
31
  ngOnInit() {
30
32
  const observable = this.dataSubject.pipe(filter(data => !!data));
31
33
  this.pivotData$ = observable.pipe(throttleTime(200, asyncScheduler, { trailing: true, leading: true }), map(data => this.handleData(data)), tap(data => this.pivotDataChange.emit(data)));
32
- this.pivotTables$ = this.pivotData$.pipe(map(data => this.pivotTableConverter.createTables(data, this.strings)));
34
+ this.pivotTables$ = this.pivotData$.pipe(map(data => this.pivotTableConverter.createTables(data, this.transform)), tap(tables => this.pivotTablesChange.emit(tables)));
33
35
  }
34
36
  handleData(data) {
35
37
  return this.pivotTransformer.createData(data.config, data.transform, data.collections, data.linkTypes, data.data, data.query, data.constraintData);
@@ -46,11 +48,11 @@ export class LmrPivotTableComponent {
46
48
  });
47
49
  }
48
50
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LmrPivotTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
49
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: LmrPivotTableComponent, selector: "lmr-pivot-table", inputs: { collections: "collections", data: "data", linkTypes: "linkTypes", query: "query", constraintData: "constraintData", config: "config", transform: "transform", strings: "strings" }, outputs: { cellClick: "cellClick", pivotDataChange: "pivotDataChange" }, queries: [{ propertyName: "emptyTablesTemplate", first: true, predicate: LmrEmptyTablesTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "tableCellTemplate", first: true, predicate: LmrTableCellTemplateDirective, descendants: true, read: TemplateRef }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"{pivotTables: pivotTables$ | async, pivotData: pivotData$ | async} as data\">\n <ng-container *ngIf=\"data.pivotTables?.length && !(data.pivotData | pivotDataEmpty)\">\n <table *ngFor=\"let pivotTable of data.pivotTables; let first\"\n class=\"table table-without-padding table-borderless table-md\"\n [class.mt-4]=\"!first\">\n <tr *ngFor=\"let rowCells of pivotTable.cells; let rowIndex = index\">\n\n <ng-container *ngFor=\"let cell of rowCells; let cellIndex = index\">\n <td *ngIf=\"cell && {hasValue: cell | pivotTableCellHasValue} as cellData\"\n class=\"cell {{cell.constraint ? (cell.constraint.type | lowercase) : ''}} text-truncate\"\n [style.max-width.px]=\"300\"\n [class.sticky-start]=\"cell.stickyStart\"\n [class.sticky-top]=\"cell.stickyTop\"\n [rowSpan]=\"cell.rowSpan\"\n [colSpan]=\"cell.colSpan\"\n [style.top.px]=\"cell.stickyTop ? (rowIndex * 40) : undefined\"\n [style.left.px]=\"cell.stickyStart ? (cellIndex * 150) : undefined\"\n [ngClass]=\"cell.cssClass\"\n [style.background]=\"cell.background\"\n [style.color]=\"cell.background && (cell.background | contrastColor)\">\n <ng-container *ngIf=\"cell.summary\">\n <div class=\"d-flex align-items-center h-100\">\n <span class=\"summary\" [class.me-2]=\"cellData.hasValue\">{{cell.summary}}</span>\n <ng-container *ngIf=\"cellData.hasValue\">\n <ng-template #defaultTableCellTemplate>\n <span class=\"flex-grow-1 h-100 text-truncate d-inline-block\">\n {{ cell.value }}\n </span>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"tableCellTemplate || defaultTableCellTemplate\"\n [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n </ng-template>\n </ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!cell.summary\">\n <ng-container *ngIf=\"cellData.hasValue\">\n <ng-template #defaultTableCellTemplate>\n <span class=\"d-inline-block\">\n {{ cell.value }}\n </span>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"tableCellTemplate || defaultTableCellTemplate\"\n [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"!cellData.hasValue\">&nbsp;</ng-container>\n </ng-container>\n </td>\n </ng-container>\n </tr>\n </table>\n </ng-container>\n\n <ng-container *ngIf=\"!data.pivotTables?.length || (data.pivotData | pivotDataEmpty)\">\n <ng-template #defaultEmptyTablesTemplate>\n <div>&nbsp;</div>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"emptyTablesTemplate || defaultEmptyTablesTemplate\"\n [ngTemplateOutletContext]=\"{ }\">\n </ng-template>\n </ng-container>\n</ng-container>\n", styles: [".table{border-spacing:0;border-collapse:separate}.pivot-data-cell,.pivot-data-group-cell{text-align:right}.pivot-column-header-cell,.pivot-row-header-cell,.pivot-data-group-cell,.pivot-row-group-header-cell,.pivot-column-group-header-cell{font-weight:700;border:1px #f8f9fa solid}.pivot-row-header-cell.sticky-start,.pivot-row-group-header-cell.sticky-start,.pivot-empty-cell.sticky-start{position:sticky;width:150px;min-width:150px;max-width:150px!important;z-index:9}.pivot-column-header-cell.sticky-top,.pivot-column-group-header-cell.sticky-top,.pivot-empty-cell.sticky-top{position:sticky;z-index:10}.pivot-empty-cell{background:white;border:1px white solid}.pivot-empty-cell.sticky-top{z-index:11}.cell.color{padding:0!important;height:30px}.cell.color .summary{padding-left:.5rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.LowerCasePipe, name: "lowercase" }, { kind: "pipe", type: i2.PivotDataEmptyPipe, name: "pivotDataEmpty" }, { kind: "pipe", type: i3.PivotTableCellHasValuePipe, name: "pivotTableCellHasValue" }, { kind: "pipe", type: i4.ContrastColorPipe, name: "contrastColor" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
51
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: LmrPivotTableComponent, selector: "lmr-pivot-table", inputs: { collections: "collections", data: "data", linkTypes: "linkTypes", query: "query", constraintData: "constraintData", config: "config", transform: "transform", emptyTablesTemplateInput: "emptyTablesTemplateInput", tableCellTemplateInput: "tableCellTemplateInput" }, outputs: { cellClick: "cellClick", pivotDataChange: "pivotDataChange", pivotTablesChange: "pivotTablesChange" }, queries: [{ propertyName: "emptyTablesTemplate", first: true, predicate: LmrEmptyTablesTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "tableCellTemplate", first: true, predicate: LmrTableCellTemplateDirective, descendants: true, read: TemplateRef }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"{pivotTables: pivotTables$ | async, pivotData: pivotData$ | async} as data\">\n <ng-container *ngIf=\"data.pivotTables?.length && !(data.pivotData | pivotDataEmpty)\">\n <table *ngFor=\"let pivotTable of data.pivotTables; let first\"\n class=\"table table-without-padding table-borderless table-md\"\n [class.mt-4]=\"!first\">\n <tr *ngFor=\"let rowCells of pivotTable.cells; let rowIndex = index\">\n\n <ng-container *ngFor=\"let cell of rowCells; let cellIndex = index\">\n <td *ngIf=\"cell && {hasValue: cell | pivotTableCellHasValue} as cellData\"\n class=\"cell {{cell.constraint ? (cell.constraint.type | lowercase) : ''}} text-truncate\"\n [style.max-width.px]=\"300\"\n [class.sticky-start]=\"cell.stickyStart\"\n [class.sticky-top]=\"cell.stickyTop\"\n [rowSpan]=\"cell.rowSpan\"\n [colSpan]=\"cell.colSpan\"\n [style.top.px]=\"cell.stickyTop ? (rowIndex * 40) : undefined\"\n [style.left.px]=\"cell.stickyStart ? (cellIndex * 150) : undefined\"\n [ngClass]=\"cell.cssClass\"\n [style.background]=\"cell.background\"\n [style.color]=\"cell.background && (cell.background | contrastColor)\">\n <ng-container *ngIf=\"cell.summary\">\n <ng-container *ngIf=\"cellData.hasValue\">\n <div class=\"d-flex align-items-center h-100\">\n <span class=\"summary me-2\">{{cell.summary}}</span>\n <ng-template #defaultTableCellTemplate>\n <span class=\"flex-grow-1 h-100 text-truncate d-inline-block\">\n {{ cell.value }}\n </span>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"tableCellTemplate || tableCellTemplateInput || defaultTableCellTemplate\"\n [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n </ng-template>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!cellData.hasValue\">\n <span class=\"d-inline-block summary\">{{cell.summary}}</span>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!cell.summary\">\n <ng-container *ngIf=\"cellData.hasValue\">\n <ng-template #defaultTableCellTemplate>\n <span class=\"d-inline-block\">\n {{ cell.value }}\n </span>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"tableCellTemplate || tableCellTemplateInput || defaultTableCellTemplate\"\n [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"!cellData.hasValue\">&nbsp;</ng-container>\n </ng-container>\n </td>\n </ng-container>\n </tr>\n </table>\n </ng-container>\n\n <ng-container *ngIf=\"!data.pivotTables?.length || (data.pivotData | pivotDataEmpty)\">\n <ng-template #defaultEmptyTablesTemplate>\n <div>&nbsp;</div>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"emptyTablesTemplate || emptyTablesTemplateInput || defaultEmptyTablesTemplate\"\n [ngTemplateOutletContext]=\"{ }\">\n </ng-template>\n </ng-container>\n</ng-container>\n", styles: [".table{border-spacing:0;border-collapse:separate}.pivot-data-cell,.pivot-data-group-cell,.pivot-column-header-cell,.pivot-column-group-header-cell{text-align:right}.pivot-column-header-cell,.pivot-row-attribute-header-cell,.pivot-row-header-cell,.pivot-data-group-cell,.pivot-row-group-header-cell,.pivot-column-group-header-cell{font-weight:700;border:1px #f8f9fa solid}.pivot-row-header-cell.sticky-start,.pivot-row-group-header-cell.sticky-start,.pivot-empty-cell.sticky-start{position:sticky;width:150px;min-width:150px;max-width:150px!important;z-index:9}.pivot-column-header-cell.sticky-top,.pivot-row-attribute-header-cell.sticky-top,.pivot-column-group-header-cell.sticky-top,.pivot-empty-cell.sticky-top{position:sticky;z-index:10}.pivot-row-attribute-header-cell.sticky-top,.pivot-row-attribute-header-cell.sticky-start{position:sticky;z-index:11}.pivot-empty-cell{background:white;border:1px white solid}.pivot-empty-cell.sticky-top{z-index:11}.cell.color{padding:0!important;height:30px}.cell.color .summary{padding-left:.5rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.LowerCasePipe, name: "lowercase" }, { kind: "pipe", type: i2.PivotDataEmptyPipe, name: "pivotDataEmpty" }, { kind: "pipe", type: i3.PivotTableCellHasValuePipe, name: "pivotTableCellHasValue" }, { kind: "pipe", type: i4.ContrastColorPipe, name: "contrastColor" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
50
52
  }
51
53
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LmrPivotTableComponent, decorators: [{
52
54
  type: Component,
53
- args: [{ selector: 'lmr-pivot-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"{pivotTables: pivotTables$ | async, pivotData: pivotData$ | async} as data\">\n <ng-container *ngIf=\"data.pivotTables?.length && !(data.pivotData | pivotDataEmpty)\">\n <table *ngFor=\"let pivotTable of data.pivotTables; let first\"\n class=\"table table-without-padding table-borderless table-md\"\n [class.mt-4]=\"!first\">\n <tr *ngFor=\"let rowCells of pivotTable.cells; let rowIndex = index\">\n\n <ng-container *ngFor=\"let cell of rowCells; let cellIndex = index\">\n <td *ngIf=\"cell && {hasValue: cell | pivotTableCellHasValue} as cellData\"\n class=\"cell {{cell.constraint ? (cell.constraint.type | lowercase) : ''}} text-truncate\"\n [style.max-width.px]=\"300\"\n [class.sticky-start]=\"cell.stickyStart\"\n [class.sticky-top]=\"cell.stickyTop\"\n [rowSpan]=\"cell.rowSpan\"\n [colSpan]=\"cell.colSpan\"\n [style.top.px]=\"cell.stickyTop ? (rowIndex * 40) : undefined\"\n [style.left.px]=\"cell.stickyStart ? (cellIndex * 150) : undefined\"\n [ngClass]=\"cell.cssClass\"\n [style.background]=\"cell.background\"\n [style.color]=\"cell.background && (cell.background | contrastColor)\">\n <ng-container *ngIf=\"cell.summary\">\n <div class=\"d-flex align-items-center h-100\">\n <span class=\"summary\" [class.me-2]=\"cellData.hasValue\">{{cell.summary}}</span>\n <ng-container *ngIf=\"cellData.hasValue\">\n <ng-template #defaultTableCellTemplate>\n <span class=\"flex-grow-1 h-100 text-truncate d-inline-block\">\n {{ cell.value }}\n </span>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"tableCellTemplate || defaultTableCellTemplate\"\n [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n </ng-template>\n </ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!cell.summary\">\n <ng-container *ngIf=\"cellData.hasValue\">\n <ng-template #defaultTableCellTemplate>\n <span class=\"d-inline-block\">\n {{ cell.value }}\n </span>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"tableCellTemplate || defaultTableCellTemplate\"\n [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"!cellData.hasValue\">&nbsp;</ng-container>\n </ng-container>\n </td>\n </ng-container>\n </tr>\n </table>\n </ng-container>\n\n <ng-container *ngIf=\"!data.pivotTables?.length || (data.pivotData | pivotDataEmpty)\">\n <ng-template #defaultEmptyTablesTemplate>\n <div>&nbsp;</div>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"emptyTablesTemplate || defaultEmptyTablesTemplate\"\n [ngTemplateOutletContext]=\"{ }\">\n </ng-template>\n </ng-container>\n</ng-container>\n", styles: [".table{border-spacing:0;border-collapse:separate}.pivot-data-cell,.pivot-data-group-cell{text-align:right}.pivot-column-header-cell,.pivot-row-header-cell,.pivot-data-group-cell,.pivot-row-group-header-cell,.pivot-column-group-header-cell{font-weight:700;border:1px #f8f9fa solid}.pivot-row-header-cell.sticky-start,.pivot-row-group-header-cell.sticky-start,.pivot-empty-cell.sticky-start{position:sticky;width:150px;min-width:150px;max-width:150px!important;z-index:9}.pivot-column-header-cell.sticky-top,.pivot-column-group-header-cell.sticky-top,.pivot-empty-cell.sticky-top{position:sticky;z-index:10}.pivot-empty-cell{background:white;border:1px white solid}.pivot-empty-cell.sticky-top{z-index:11}.cell.color{padding:0!important;height:30px}.cell.color .summary{padding-left:.5rem}\n"] }]
55
+ args: [{ selector: 'lmr-pivot-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"{pivotTables: pivotTables$ | async, pivotData: pivotData$ | async} as data\">\n <ng-container *ngIf=\"data.pivotTables?.length && !(data.pivotData | pivotDataEmpty)\">\n <table *ngFor=\"let pivotTable of data.pivotTables; let first\"\n class=\"table table-without-padding table-borderless table-md\"\n [class.mt-4]=\"!first\">\n <tr *ngFor=\"let rowCells of pivotTable.cells; let rowIndex = index\">\n\n <ng-container *ngFor=\"let cell of rowCells; let cellIndex = index\">\n <td *ngIf=\"cell && {hasValue: cell | pivotTableCellHasValue} as cellData\"\n class=\"cell {{cell.constraint ? (cell.constraint.type | lowercase) : ''}} text-truncate\"\n [style.max-width.px]=\"300\"\n [class.sticky-start]=\"cell.stickyStart\"\n [class.sticky-top]=\"cell.stickyTop\"\n [rowSpan]=\"cell.rowSpan\"\n [colSpan]=\"cell.colSpan\"\n [style.top.px]=\"cell.stickyTop ? (rowIndex * 40) : undefined\"\n [style.left.px]=\"cell.stickyStart ? (cellIndex * 150) : undefined\"\n [ngClass]=\"cell.cssClass\"\n [style.background]=\"cell.background\"\n [style.color]=\"cell.background && (cell.background | contrastColor)\">\n <ng-container *ngIf=\"cell.summary\">\n <ng-container *ngIf=\"cellData.hasValue\">\n <div class=\"d-flex align-items-center h-100\">\n <span class=\"summary me-2\">{{cell.summary}}</span>\n <ng-template #defaultTableCellTemplate>\n <span class=\"flex-grow-1 h-100 text-truncate d-inline-block\">\n {{ cell.value }}\n </span>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"tableCellTemplate || tableCellTemplateInput || defaultTableCellTemplate\"\n [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n </ng-template>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!cellData.hasValue\">\n <span class=\"d-inline-block summary\">{{cell.summary}}</span>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!cell.summary\">\n <ng-container *ngIf=\"cellData.hasValue\">\n <ng-template #defaultTableCellTemplate>\n <span class=\"d-inline-block\">\n {{ cell.value }}\n </span>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"tableCellTemplate || tableCellTemplateInput || defaultTableCellTemplate\"\n [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"!cellData.hasValue\">&nbsp;</ng-container>\n </ng-container>\n </td>\n </ng-container>\n </tr>\n </table>\n </ng-container>\n\n <ng-container *ngIf=\"!data.pivotTables?.length || (data.pivotData | pivotDataEmpty)\">\n <ng-template #defaultEmptyTablesTemplate>\n <div>&nbsp;</div>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"emptyTablesTemplate || emptyTablesTemplateInput || defaultEmptyTablesTemplate\"\n [ngTemplateOutletContext]=\"{ }\">\n </ng-template>\n </ng-container>\n</ng-container>\n", styles: [".table{border-spacing:0;border-collapse:separate}.pivot-data-cell,.pivot-data-group-cell,.pivot-column-header-cell,.pivot-column-group-header-cell{text-align:right}.pivot-column-header-cell,.pivot-row-attribute-header-cell,.pivot-row-header-cell,.pivot-data-group-cell,.pivot-row-group-header-cell,.pivot-column-group-header-cell{font-weight:700;border:1px #f8f9fa solid}.pivot-row-header-cell.sticky-start,.pivot-row-group-header-cell.sticky-start,.pivot-empty-cell.sticky-start{position:sticky;width:150px;min-width:150px;max-width:150px!important;z-index:9}.pivot-column-header-cell.sticky-top,.pivot-row-attribute-header-cell.sticky-top,.pivot-column-group-header-cell.sticky-top,.pivot-empty-cell.sticky-top{position:sticky;z-index:10}.pivot-row-attribute-header-cell.sticky-top,.pivot-row-attribute-header-cell.sticky-start{position:sticky;z-index:11}.pivot-empty-cell{background:white;border:1px white solid}.pivot-empty-cell.sticky-top{z-index:11}.cell.color{padding:0!important;height:30px}.cell.color .summary{padding-left:.5rem}\n"] }]
54
56
  }], propDecorators: { collections: [{
55
57
  type: Input
56
58
  }], data: [{
@@ -65,12 +67,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
65
67
  type: Input
66
68
  }], transform: [{
67
69
  type: Input
68
- }], strings: [{
70
+ }], emptyTablesTemplateInput: [{
71
+ type: Input
72
+ }], tableCellTemplateInput: [{
69
73
  type: Input
70
74
  }], cellClick: [{
71
75
  type: Output
72
76
  }], pivotDataChange: [{
73
77
  type: Output
78
+ }], pivotTablesChange: [{
79
+ type: Output
74
80
  }], emptyTablesTemplate: [{
75
81
  type: ContentChild,
76
82
  args: [LmrEmptyTablesTemplateDirective, { read: TemplateRef }]
@@ -78,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
78
84
  type: ContentChild,
79
85
  args: [LmrTableCellTemplateDirective, { read: TemplateRef }]
80
86
  }] } });
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lmr-pivot-table.component.js","sourceRoot":"","sources":["../../../../projects/lmr-pivot-table/src/lib/lmr-pivot-table.component.ts","../../../../projects/lmr-pivot-table/src/lib/lmr-pivot-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAiB,WAAW,EAAC,MAAM,eAAe,CAAC;AAG3J,OAAO,EAAC,kBAAkB,EAAC,MAAM,6BAA6B,CAAC;AAE/D,OAAO,EAAC,cAAc,EAAE,eAAe,EAAE,MAAM,EAAE,GAAG,EAAc,GAAG,EAAE,YAAY,EAAC,MAAM,MAAM,CAAC;AAEjG,OAAO,EAAC,mBAAmB,EAAC,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAC,+BAA+B,EAAE,6BAA6B,EAAC,MAAM,sCAAsC,CAAC;;;;;;AAkBpH,MAAM,OAAO,sBAAsB;IAG1B,WAAW,CAAe;IAG1B,IAAI,CAAwB;IAG5B,SAAS,CAAa;IAGtB,KAAK,CAAQ;IAGb,cAAc,CAAiB;IAG/B,MAAM,CAAiB;IAGvB,SAAS,CAAoB;IAG7B,OAAO,CAAkB;IAGzB,SAAS,GAAG,IAAI,YAAY,EAAqB,CAAC;IAGlD,eAAe,GAAG,IAAI,YAAY,EAAgB,CAAC;IAEY,mBAAmB,CAAmB;IACxC,iBAAiB,CAAmB;IAEvF,gBAAgB,GAAG,IAAI,kBAAkB,EAAE,CAAC;IAC5C,mBAAmB,GAAwB,IAAI,mBAAmB,EAAE,CAAC;IAE9E,WAAW,GAAG,IAAI,eAAe,CAAO,IAAI,CAAC,CAAC;IAE/C,UAAU,CAA2B;IACrC,YAAY,CAA8B;IAE1C,QAAQ;QACb,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAEjE,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,IAAI,CAC/B,YAAY,CAAC,GAAG,EAAE,cAAc,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAC,CAAC,EAClE,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,EAClC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAC7C,CAAC;QAEF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CACtC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CACvE,CAAC;IACJ,CAAC;IAEO,UAAU,CAAC,IAAU;QAC3B,OAAO,IAAI,CAAC,gBAAgB,CAAC,UAAU,CACrC,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,cAAc,CACpB,CAAC;IACJ,CAAC;IAEM,WAAW,CAAC,OAAsB;QACvC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YACpB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,cAAc,EAAE,IAAI,CAAC,cAAc;SACpC,CAAC,CAAC;IACL,CAAC;wGA/EU,sBAAsB;4FAAtB,sBAAsB,+WAgCnB,+BAA+B,2BAAU,WAAW,iEACpD,6BAA6B,2BAAU,WAAW,kDC3DlE,uvGAqEA;;4FD3Ca,sBAAsB;kBANlC,SAAS;+BACE,iBAAiB,mBAGV,uBAAuB,CAAC,MAAM;8BAKxC,WAAW;sBADjB,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,SAAS;sBADf,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,cAAc;sBADpB,KAAK;gBAIC,MAAM;sBADZ,KAAK;gBAIC,SAAS;sBADf,KAAK;gBAIC,OAAO;sBADb,KAAK;gBAIC,SAAS;sBADf,MAAM;gBAIA,eAAe;sBADrB,MAAM;gBAG+D,mBAAmB;sBAAxF,YAAY;uBAAC,+BAA+B,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;gBACA,iBAAiB;sBAApF,YAAY;uBAAC,6BAA6B,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, TemplateRef} from '@angular/core';\nimport {LmrPivotConfig, LmrPivotStrings, LmrPivotTransform} from './util/lmr-pivot-config';\nimport {Collection, ConstraintData, DocumentsAndLinksData, LinkType, Query} from '@lumeer/data-filters';\nimport {PivotDataConverter} from './util/pivot-data-converter';\nimport {LmrPivotData} from './util/lmr-pivot-data';\nimport {asyncScheduler, BehaviorSubject, filter, map, Observable, tap, throttleTime} from 'rxjs';\nimport {LmrPivotTable, LmrPivotTableCell} from './util/lmr-pivot-table';\nimport {PivotTableConverter} from './util/pivot-table-converter';\nimport {LmrEmptyTablesTemplateDirective, LmrTableCellTemplateDirective} from './directives/lmr-templates.directive';\n\ninterface Data {\n  collections: Collection[];\n  linkTypes: LinkType[];\n  data: DocumentsAndLinksData;\n  query: Query;\n  constraintData: ConstraintData;\n  config: LmrPivotConfig;\n  transform: LmrPivotTransform;\n}\n\n@Component({\n  selector: 'lmr-pivot-table',\n  templateUrl: 'lmr-pivot-table.component.html',\n  styleUrls: ['./lmr-pivot-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class LmrPivotTableComponent implements OnInit, OnChanges {\n\n  @Input()\n  public collections: Collection[];\n\n  @Input()\n  public data: DocumentsAndLinksData;\n\n  @Input()\n  public linkTypes: LinkType[];\n\n  @Input()\n  public query: Query;\n\n  @Input()\n  public constraintData: ConstraintData;\n\n  @Input()\n  public config: LmrPivotConfig;\n\n  @Input()\n  public transform: LmrPivotTransform;\n\n  @Input()\n  public strings: LmrPivotStrings;\n\n  @Output()\n  public cellClick = new EventEmitter<LmrPivotTableCell>();\n\n  @Output()\n  public pivotDataChange = new EventEmitter<LmrPivotData>();\n\n  @ContentChild(LmrEmptyTablesTemplateDirective, { read: TemplateRef }) emptyTablesTemplate: TemplateRef<any>;\n  @ContentChild(LmrTableCellTemplateDirective, { read: TemplateRef }) tableCellTemplate: TemplateRef<any>;\n\n  private readonly pivotTransformer = new PivotDataConverter();\n  private readonly pivotTableConverter: PivotTableConverter = new PivotTableConverter();\n\n  private dataSubject = new BehaviorSubject<Data>(null);\n\n  public pivotData$: Observable<LmrPivotData>;\n  public pivotTables$: Observable<LmrPivotTable[]>;\n\n  public ngOnInit() {\n    const observable = this.dataSubject.pipe(filter(data => !!data));\n\n    this.pivotData$ = observable.pipe(\n      throttleTime(200, asyncScheduler, {trailing: true, leading: true}),\n      map(data => this.handleData(data)),\n      tap(data => this.pivotDataChange.emit(data)),\n    );\n\n    this.pivotTables$ = this.pivotData$.pipe(\n      map(data => this.pivotTableConverter.createTables(data, this.strings))\n    );\n  }\n\n  private handleData(data: Data): LmrPivotData {\n    return this.pivotTransformer.createData(\n      data.config,\n      data.transform,\n      data.collections,\n      data.linkTypes,\n      data.data,\n      data.query,\n      data.constraintData\n    );\n  }\n\n  public ngOnChanges(changes: SimpleChanges) {\n    this.dataSubject.next({\n      config: this.config,\n      transform: this.transform,\n      collections: this.collections,\n      linkTypes: this.linkTypes,\n      data: this.data,\n      query: this.query,\n      constraintData: this.constraintData,\n    });\n  }\n\n}\n","<ng-container *ngIf=\"{pivotTables: pivotTables$ | async, pivotData: pivotData$ | async} as data\">\n  <ng-container *ngIf=\"data.pivotTables?.length && !(data.pivotData | pivotDataEmpty)\">\n    <table *ngFor=\"let pivotTable of data.pivotTables; let first\"\n           class=\"table table-without-padding table-borderless table-md\"\n           [class.mt-4]=\"!first\">\n      <tr *ngFor=\"let rowCells of pivotTable.cells; let rowIndex = index\">\n\n        <ng-container *ngFor=\"let cell of rowCells; let cellIndex = index\">\n          <td *ngIf=\"cell && {hasValue: cell | pivotTableCellHasValue} as cellData\"\n              class=\"cell {{cell.constraint ? (cell.constraint.type | lowercase) : ''}} text-truncate\"\n              [style.max-width.px]=\"300\"\n              [class.sticky-start]=\"cell.stickyStart\"\n              [class.sticky-top]=\"cell.stickyTop\"\n              [rowSpan]=\"cell.rowSpan\"\n              [colSpan]=\"cell.colSpan\"\n              [style.top.px]=\"cell.stickyTop ? (rowIndex * 40) : undefined\"\n              [style.left.px]=\"cell.stickyStart ? (cellIndex * 150) : undefined\"\n              [ngClass]=\"cell.cssClass\"\n              [style.background]=\"cell.background\"\n              [style.color]=\"cell.background && (cell.background | contrastColor)\">\n            <ng-container *ngIf=\"cell.summary\">\n              <div class=\"d-flex align-items-center h-100\">\n                <span class=\"summary\" [class.me-2]=\"cellData.hasValue\">{{cell.summary}}</span>\n                <ng-container *ngIf=\"cellData.hasValue\">\n                  <ng-template #defaultTableCellTemplate>\n                  <span class=\"flex-grow-1 h-100 text-truncate d-inline-block\">\n                    {{ cell.value }}\n                  </span>\n                  </ng-template>\n\n                  <ng-template\n                    [ngTemplateOutlet]=\"tableCellTemplate || defaultTableCellTemplate\"\n                    [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n                  </ng-template>\n                </ng-container>\n              </div>\n            </ng-container>\n            <ng-container *ngIf=\"!cell.summary\">\n              <ng-container *ngIf=\"cellData.hasValue\">\n                <ng-template #defaultTableCellTemplate>\n                  <span class=\"d-inline-block\">\n                    {{ cell.value }}\n                  </span>\n                </ng-template>\n\n                <ng-template\n                  [ngTemplateOutlet]=\"tableCellTemplate || defaultTableCellTemplate\"\n                  [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n                </ng-template>\n              </ng-container>\n              <ng-container *ngIf=\"!cellData.hasValue\">&nbsp;</ng-container>\n            </ng-container>\n          </td>\n        </ng-container>\n      </tr>\n    </table>\n  </ng-container>\n\n  <ng-container *ngIf=\"!data.pivotTables?.length || (data.pivotData | pivotDataEmpty)\">\n    <ng-template #defaultEmptyTablesTemplate>\n      <div>&nbsp;</div>\n    </ng-template>\n\n    <ng-template\n      [ngTemplateOutlet]=\"emptyTablesTemplate || defaultEmptyTablesTemplate\"\n      [ngTemplateOutletContext]=\"{  }\">\n    </ng-template>\n  </ng-container>\n</ng-container>\n"]}
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lmr-pivot-table.component.js","sourceRoot":"","sources":["../../../../projects/lmr-pivot-table/src/lib/lmr-pivot-table.component.ts","../../../../projects/lmr-pivot-table/src/lib/lmr-pivot-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, TemplateRef} from '@angular/core';\nimport {LmrPivotConfig, LmrPivotTransform} from './util/lmr-pivot-config';\nimport {Collection, ConstraintData, DocumentsAndLinksData, LinkType, Query} from '@lumeer/data-filters';\nimport {PivotDataConverter} from './util/pivot-data-converter';\nimport {LmrPivotData} from './util/lmr-pivot-data';\nimport {asyncScheduler, BehaviorSubject, filter, map, Observable, tap, throttleTime} from 'rxjs';\nimport {LmrPivotTable, LmrPivotTableCell} from './util/lmr-pivot-table';\nimport {PivotTableConverter} from './util/pivot-table-converter';\nimport {LmrEmptyTablesTemplateDirective, LmrTableCellTemplateDirective} from './directives/lmr-templates.directive';\n\ninterface Data {\n  collections: Collection[];\n  linkTypes: LinkType[];\n  data: DocumentsAndLinksData;\n  query: Query;\n  constraintData: ConstraintData;\n  config: LmrPivotConfig;\n  transform: LmrPivotTransform;\n}\n\n@Component({\n  selector: 'lmr-pivot-table',\n  templateUrl: 'lmr-pivot-table.component.html',\n  styleUrls: ['./lmr-pivot-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class LmrPivotTableComponent implements OnInit, OnChanges {\n\n  @Input()\n  public collections: Collection[];\n\n  @Input()\n  public data: DocumentsAndLinksData;\n\n  @Input()\n  public linkTypes: LinkType[];\n\n  @Input()\n  public query: Query;\n\n  @Input()\n  public constraintData: ConstraintData;\n\n  @Input()\n  public config: LmrPivotConfig;\n\n  @Input()\n  public transform: LmrPivotTransform;\n\n  @Input()\n  public emptyTablesTemplateInput: TemplateRef<any>;\n\n  @Input()\n  public tableCellTemplateInput: TemplateRef<any>;\n\n  @Output()\n  public cellClick = new EventEmitter<LmrPivotTableCell>();\n\n  @Output()\n  public pivotDataChange = new EventEmitter<LmrPivotData>();\n\n  @Output()\n  public pivotTablesChange = new EventEmitter<LmrPivotTable[]>();\n\n  @ContentChild(LmrEmptyTablesTemplateDirective, { read: TemplateRef }) emptyTablesTemplate: TemplateRef<any>;\n  @ContentChild(LmrTableCellTemplateDirective, { read: TemplateRef }) tableCellTemplate: TemplateRef<any>;\n\n  private readonly pivotTransformer = new PivotDataConverter();\n  private readonly pivotTableConverter: PivotTableConverter = new PivotTableConverter();\n\n  private dataSubject = new BehaviorSubject<Data>(null);\n\n  public pivotData$: Observable<LmrPivotData>;\n  public pivotTables$: Observable<LmrPivotTable[]>;\n\n  public ngOnInit() {\n    const observable = this.dataSubject.pipe(filter(data => !!data));\n\n    this.pivotData$ = observable.pipe(\n      throttleTime(200, asyncScheduler, {trailing: true, leading: true}),\n      map(data => this.handleData(data)),\n      tap(data => this.pivotDataChange.emit(data)),\n    );\n\n    this.pivotTables$ = this.pivotData$.pipe(\n      map(data => this.pivotTableConverter.createTables(data, this.transform)),\n      tap(tables => this.pivotTablesChange.emit(tables))\n    );\n  }\n\n  private handleData(data: Data): LmrPivotData {\n    return this.pivotTransformer.createData(\n      data.config,\n      data.transform,\n      data.collections,\n      data.linkTypes,\n      data.data,\n      data.query,\n      data.constraintData\n    );\n  }\n\n  public ngOnChanges(changes: SimpleChanges) {\n    this.dataSubject.next({\n      config: this.config,\n      transform: this.transform,\n      collections: this.collections,\n      linkTypes: this.linkTypes,\n      data: this.data,\n      query: this.query,\n      constraintData: this.constraintData,\n    });\n  }\n\n}\n","<ng-container *ngIf=\"{pivotTables: pivotTables$ | async, pivotData: pivotData$ | async} as data\">\n  <ng-container *ngIf=\"data.pivotTables?.length && !(data.pivotData | pivotDataEmpty)\">\n    <table *ngFor=\"let pivotTable of data.pivotTables; let first\"\n           class=\"table table-without-padding table-borderless table-md\"\n           [class.mt-4]=\"!first\">\n      <tr *ngFor=\"let rowCells of pivotTable.cells; let rowIndex = index\">\n\n        <ng-container *ngFor=\"let cell of rowCells; let cellIndex = index\">\n          <td *ngIf=\"cell && {hasValue: cell | pivotTableCellHasValue} as cellData\"\n              class=\"cell {{cell.constraint ? (cell.constraint.type | lowercase) : ''}} text-truncate\"\n              [style.max-width.px]=\"300\"\n              [class.sticky-start]=\"cell.stickyStart\"\n              [class.sticky-top]=\"cell.stickyTop\"\n              [rowSpan]=\"cell.rowSpan\"\n              [colSpan]=\"cell.colSpan\"\n              [style.top.px]=\"cell.stickyTop ? (rowIndex * 40) : undefined\"\n              [style.left.px]=\"cell.stickyStart ? (cellIndex * 150) : undefined\"\n              [ngClass]=\"cell.cssClass\"\n              [style.background]=\"cell.background\"\n              [style.color]=\"cell.background && (cell.background | contrastColor)\">\n            <ng-container *ngIf=\"cell.summary\">\n              <ng-container *ngIf=\"cellData.hasValue\">\n                <div class=\"d-flex align-items-center h-100\">\n                  <span class=\"summary me-2\">{{cell.summary}}</span>\n                  <ng-template #defaultTableCellTemplate>\n                    <span class=\"flex-grow-1 h-100 text-truncate d-inline-block\">\n                      {{ cell.value }}\n                    </span>\n                  </ng-template>\n\n                  <ng-template\n                    [ngTemplateOutlet]=\"tableCellTemplate || tableCellTemplateInput || defaultTableCellTemplate\"\n                    [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n                  </ng-template>\n                </div>\n              </ng-container>\n              <ng-container *ngIf=\"!cellData.hasValue\">\n                <span class=\"d-inline-block summary\">{{cell.summary}}</span>\n              </ng-container>\n            </ng-container>\n            <ng-container *ngIf=\"!cell.summary\">\n              <ng-container *ngIf=\"cellData.hasValue\">\n                <ng-template #defaultTableCellTemplate>\n                  <span class=\"d-inline-block\">\n                    {{ cell.value }}\n                  </span>\n                </ng-template>\n\n                <ng-template\n                  [ngTemplateOutlet]=\"tableCellTemplate || tableCellTemplateInput || defaultTableCellTemplate\"\n                  [ngTemplateOutletContext]=\"{ value: cell.value, cell: cell }\">\n                </ng-template>\n              </ng-container>\n              <ng-container *ngIf=\"!cellData.hasValue\">&nbsp;</ng-container>\n            </ng-container>\n          </td>\n        </ng-container>\n      </tr>\n    </table>\n  </ng-container>\n\n  <ng-container *ngIf=\"!data.pivotTables?.length || (data.pivotData | pivotDataEmpty)\">\n    <ng-template #defaultEmptyTablesTemplate>\n      <div>&nbsp;</div>\n    </ng-template>\n\n    <ng-template\n      [ngTemplateOutlet]=\"emptyTablesTemplate || emptyTablesTemplateInput || defaultEmptyTablesTemplate\"\n      [ngTemplateOutletContext]=\"{  }\">\n    </ng-template>\n  </ng-container>\n</ng-container>\n"]}
@@ -1,28 +1,35 @@
1
1
  import { NgModule } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
+ import { ScrollingModule } from '@angular/cdk/scrolling';
3
4
  import { LmrPivotTableComponent } from './lmr-pivot-table.component';
4
5
  import { PivotDataEmptyPipe } from './pipes/pivot-data-empty.pipe';
5
6
  import { PivotTableCellHasValuePipe } from './pipes/pivot-table-value.pipe';
6
7
  import { ContrastColorPipe } from './pipes/contrast-color.pipe';
7
8
  import { LmrEmptyTablesTemplateDirective, LmrTableCellTemplateDirective } from './directives/lmr-templates.directive';
9
+ import { LmrSimplePivotTableComponent } from './lmr-simple-pivot-table.component';
8
10
  import * as i0 from "@angular/core";
9
11
  export class LmrPivotTableModule {
10
12
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LmrPivotTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
11
13
  static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: LmrPivotTableModule, declarations: [LmrPivotTableComponent,
14
+ LmrSimplePivotTableComponent,
12
15
  PivotDataEmptyPipe,
13
16
  PivotTableCellHasValuePipe,
14
17
  ContrastColorPipe,
15
18
  LmrEmptyTablesTemplateDirective,
16
- LmrTableCellTemplateDirective], imports: [CommonModule], exports: [LmrPivotTableComponent,
19
+ LmrTableCellTemplateDirective], imports: [CommonModule,
20
+ ScrollingModule], exports: [LmrPivotTableComponent,
21
+ LmrSimplePivotTableComponent,
17
22
  LmrEmptyTablesTemplateDirective,
18
23
  LmrTableCellTemplateDirective] });
19
- static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LmrPivotTableModule, imports: [CommonModule] });
24
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LmrPivotTableModule, imports: [CommonModule,
25
+ ScrollingModule] });
20
26
  }
21
27
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LmrPivotTableModule, decorators: [{
22
28
  type: NgModule,
23
29
  args: [{
24
30
  declarations: [
25
31
  LmrPivotTableComponent,
32
+ LmrSimplePivotTableComponent,
26
33
  PivotDataEmptyPipe,
27
34
  PivotTableCellHasValuePipe,
28
35
  ContrastColorPipe,
@@ -31,12 +38,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
31
38
  ],
32
39
  imports: [
33
40
  CommonModule,
41
+ ScrollingModule,
34
42
  ],
35
43
  exports: [
36
44
  LmrPivotTableComponent,
45
+ LmrSimplePivotTableComponent,
37
46
  LmrEmptyTablesTemplateDirective,
38
47
  LmrTableCellTemplateDirective,
39
48
  ]
40
49
  }]
41
50
  }] });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG1yLXBpdm90LXRhYmxlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2xtci1waXZvdC10YWJsZS9zcmMvbGliL2xtci1waXZvdC10YWJsZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDbkUsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFDakUsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDMUUsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDOUQsT0FBTyxFQUFDLCtCQUErQixFQUFFLDZCQUE2QixFQUFDLE1BQU0sc0NBQXNDLENBQUM7O0FBb0JwSCxNQUFNLE9BQU8sbUJBQW1CO3dHQUFuQixtQkFBbUI7eUdBQW5CLG1CQUFtQixpQkFoQjVCLHNCQUFzQjtZQUN0QixrQkFBa0I7WUFDbEIsMEJBQTBCO1lBQzFCLGlCQUFpQjtZQUNqQiwrQkFBK0I7WUFDL0IsNkJBQTZCLGFBRzdCLFlBQVksYUFHWixzQkFBc0I7WUFDdEIsK0JBQStCO1lBQy9CLDZCQUE2Qjt5R0FHcEIsbUJBQW1CLFlBUjVCLFlBQVk7OzRGQVFILG1CQUFtQjtrQkFsQi9CLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHNCQUFzQjt3QkFDdEIsa0JBQWtCO3dCQUNsQiwwQkFBMEI7d0JBQzFCLGlCQUFpQjt3QkFDakIsK0JBQStCO3dCQUMvQiw2QkFBNkI7cUJBQzlCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3FCQUNiO29CQUNELE9BQU8sRUFBRTt3QkFDUCxzQkFBc0I7d0JBQ3RCLCtCQUErQjt3QkFDL0IsNkJBQTZCO3FCQUM5QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0xtclBpdm90VGFibGVDb21wb25lbnR9IGZyb20gJy4vbG1yLXBpdm90LXRhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQge1Bpdm90RGF0YUVtcHR5UGlwZX0gZnJvbSAnLi9waXBlcy9waXZvdC1kYXRhLWVtcHR5LnBpcGUnO1xuaW1wb3J0IHtQaXZvdFRhYmxlQ2VsbEhhc1ZhbHVlUGlwZX0gZnJvbSAnLi9waXBlcy9waXZvdC10YWJsZS12YWx1ZS5waXBlJztcbmltcG9ydCB7Q29udHJhc3RDb2xvclBpcGV9IGZyb20gJy4vcGlwZXMvY29udHJhc3QtY29sb3IucGlwZSc7XG5pbXBvcnQge0xtckVtcHR5VGFibGVzVGVtcGxhdGVEaXJlY3RpdmUsIExtclRhYmxlQ2VsbFRlbXBsYXRlRGlyZWN0aXZlfSBmcm9tICcuL2RpcmVjdGl2ZXMvbG1yLXRlbXBsYXRlcy5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBMbXJQaXZvdFRhYmxlQ29tcG9uZW50LFxuICAgIFBpdm90RGF0YUVtcHR5UGlwZSxcbiAgICBQaXZvdFRhYmxlQ2VsbEhhc1ZhbHVlUGlwZSxcbiAgICBDb250cmFzdENvbG9yUGlwZSxcbiAgICBMbXJFbXB0eVRhYmxlc1RlbXBsYXRlRGlyZWN0aXZlLFxuICAgIExtclRhYmxlQ2VsbFRlbXBsYXRlRGlyZWN0aXZlLFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgTG1yUGl2b3RUYWJsZUNvbXBvbmVudCxcbiAgICBMbXJFbXB0eVRhYmxlc1RlbXBsYXRlRGlyZWN0aXZlLFxuICAgIExtclRhYmxlQ2VsbFRlbXBsYXRlRGlyZWN0aXZlLFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIExtclBpdm90VGFibGVNb2R1bGUge1xufVxuIl19
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG1yLXBpdm90LXRhYmxlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2xtci1waXZvdC10YWJsZS9zcmMvbGliL2xtci1waXZvdC10YWJsZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQ25FLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQ2pFLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQzlELE9BQU8sRUFBQywrQkFBK0IsRUFBRSw2QkFBNkIsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQ3BILE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLG9DQUFvQyxDQUFDOztBQXVCaEYsTUFBTSxPQUFPLG1CQUFtQjt3R0FBbkIsbUJBQW1CO3lHQUFuQixtQkFBbUIsaUJBbkI1QixzQkFBc0I7WUFDdEIsNEJBQTRCO1lBQzVCLGtCQUFrQjtZQUNsQiwwQkFBMEI7WUFDMUIsaUJBQWlCO1lBQ2pCLCtCQUErQjtZQUMvQiw2QkFBNkIsYUFHN0IsWUFBWTtZQUNaLGVBQWUsYUFHZixzQkFBc0I7WUFDdEIsNEJBQTRCO1lBQzVCLCtCQUErQjtZQUMvQiw2QkFBNkI7eUdBR3BCLG1CQUFtQixZQVY1QixZQUFZO1lBQ1osZUFBZTs7NEZBU04sbUJBQW1CO2tCQXJCL0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osc0JBQXNCO3dCQUN0Qiw0QkFBNEI7d0JBQzVCLGtCQUFrQjt3QkFDbEIsMEJBQTBCO3dCQUMxQixpQkFBaUI7d0JBQ2pCLCtCQUErQjt3QkFDL0IsNkJBQTZCO3FCQUM5QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixlQUFlO3FCQUNoQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1Asc0JBQXNCO3dCQUN0Qiw0QkFBNEI7d0JBQzVCLCtCQUErQjt3QkFDL0IsNkJBQTZCO3FCQUM5QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1Njcm9sbGluZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY2RrL3Njcm9sbGluZyc7XG5pbXBvcnQge0xtclBpdm90VGFibGVDb21wb25lbnR9IGZyb20gJy4vbG1yLXBpdm90LXRhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQge1Bpdm90RGF0YUVtcHR5UGlwZX0gZnJvbSAnLi9waXBlcy9waXZvdC1kYXRhLWVtcHR5LnBpcGUnO1xuaW1wb3J0IHtQaXZvdFRhYmxlQ2VsbEhhc1ZhbHVlUGlwZX0gZnJvbSAnLi9waXBlcy9waXZvdC10YWJsZS12YWx1ZS5waXBlJztcbmltcG9ydCB7Q29udHJhc3RDb2xvclBpcGV9IGZyb20gJy4vcGlwZXMvY29udHJhc3QtY29sb3IucGlwZSc7XG5pbXBvcnQge0xtckVtcHR5VGFibGVzVGVtcGxhdGVEaXJlY3RpdmUsIExtclRhYmxlQ2VsbFRlbXBsYXRlRGlyZWN0aXZlfSBmcm9tICcuL2RpcmVjdGl2ZXMvbG1yLXRlbXBsYXRlcy5kaXJlY3RpdmUnO1xuaW1wb3J0IHtMbXJTaW1wbGVQaXZvdFRhYmxlQ29tcG9uZW50fSBmcm9tICcuL2xtci1zaW1wbGUtcGl2b3QtdGFibGUuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgTG1yUGl2b3RUYWJsZUNvbXBvbmVudCxcbiAgICBMbXJTaW1wbGVQaXZvdFRhYmxlQ29tcG9uZW50LFxuICAgIFBpdm90RGF0YUVtcHR5UGlwZSxcbiAgICBQaXZvdFRhYmxlQ2VsbEhhc1ZhbHVlUGlwZSxcbiAgICBDb250cmFzdENvbG9yUGlwZSxcbiAgICBMbXJFbXB0eVRhYmxlc1RlbXBsYXRlRGlyZWN0aXZlLFxuICAgIExtclRhYmxlQ2VsbFRlbXBsYXRlRGlyZWN0aXZlLFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIFNjcm9sbGluZ01vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIExtclBpdm90VGFibGVDb21wb25lbnQsXG4gICAgTG1yU2ltcGxlUGl2b3RUYWJsZUNvbXBvbmVudCxcbiAgICBMbXJFbXB0eVRhYmxlc1RlbXBsYXRlRGlyZWN0aXZlLFxuICAgIExtclRhYmxlQ2VsbFRlbXBsYXRlRGlyZWN0aXZlLFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIExtclBpdm90VGFibGVNb2R1bGUge1xufVxuIl19
@@ -0,0 +1,98 @@
1
+ import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from '@angular/core';
2
+ import { AttributesResourceType, generateId, LanguageTag } from '@lumeer/data-filters';
3
+ import { LmrEmptyTablesTemplateDirective, LmrTableCellTemplateDirective } from './directives/lmr-templates.directive';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "./lmr-pivot-table.component";
6
+ export class LmrSimplePivotTableComponent {
7
+ rows;
8
+ attributes;
9
+ color;
10
+ config;
11
+ transform;
12
+ locale;
13
+ cellClick = new EventEmitter();
14
+ pivotDataChange = new EventEmitter();
15
+ pivotTablesChange = new EventEmitter();
16
+ emptyTablesTemplate;
17
+ tableCellTemplate;
18
+ collectionId = generateId();
19
+ query = { stems: [{ collectionId: this.collectionId }] };
20
+ collection = this.createCollection();
21
+ pivotConfig = this.createConfig();
22
+ data = this.createRows();
23
+ constraintData;
24
+ ngOnChanges(changes) {
25
+ if (changes['rows']) {
26
+ this.data = this.createRows();
27
+ }
28
+ if (changes['attributes'] || changes['color']) {
29
+ this.collection = this.createCollection();
30
+ }
31
+ if (changes['config']) {
32
+ this.pivotConfig = this.createConfig();
33
+ }
34
+ this.constraintData = {
35
+ locale: this.locale || LanguageTag.USA,
36
+ };
37
+ }
38
+ createCollection() {
39
+ return {
40
+ id: this.collectionId,
41
+ attributes: (this.attributes || []),
42
+ color: this.color,
43
+ };
44
+ }
45
+ createConfig() {
46
+ return {
47
+ stemsConfigs: [{
48
+ stem: this.query.stems[0],
49
+ rowAttributes: (this.config?.rowAttributes || []).map(attribute => ({ ...attribute, resourceId: this.collectionId, resourceIndex: 0, resourceType: AttributesResourceType.Collection })),
50
+ columnAttributes: (this.config?.columnAttributes || []).map(attribute => ({ ...attribute, resourceId: this.collectionId, resourceIndex: 0, resourceType: AttributesResourceType.Collection })),
51
+ valueAttributes: (this.config?.valueAttributes || []).map(attribute => ({ ...attribute, resourceId: this.collectionId, resourceIndex: 0, resourceType: AttributesResourceType.Collection }))
52
+ }]
53
+ };
54
+ }
55
+ createRows() {
56
+ const documents = (this.rows || []).map((row, index) => ({ id: index.toString(), collectionId: this.collection.id, data: row }));
57
+ return ({
58
+ uniqueDocuments: documents,
59
+ uniqueLinkInstances: [],
60
+ dataByStems: [{
61
+ stem: this.query.stems[0],
62
+ linkInstances: [],
63
+ documents
64
+ }]
65
+ });
66
+ }
67
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LmrSimplePivotTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
68
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: LmrSimplePivotTableComponent, selector: "lmr-simple-pivot-table", inputs: { rows: "rows", attributes: "attributes", color: "color", config: "config", transform: "transform", locale: "locale" }, outputs: { cellClick: "cellClick", pivotDataChange: "pivotDataChange", pivotTablesChange: "pivotTablesChange" }, queries: [{ propertyName: "emptyTablesTemplate", first: true, predicate: LmrEmptyTablesTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "tableCellTemplate", first: true, predicate: LmrTableCellTemplateDirective, descendants: true, read: TemplateRef }], usesOnChanges: true, ngImport: i0, template: "<lmr-pivot-table [transform]=\"transform\"\n [data]=\"data\"\n [config]=\"pivotConfig\"\n [query]=\"query\"\n [constraintData]=\"constraintData\"\n [collections]=\"[collection]\"\n [emptyTablesTemplateInput]=\"emptyTablesTemplate\"\n [tableCellTemplateInput]=\"tableCellTemplate\"\n (pivotDataChange)=\"pivotDataChange.emit($event)\"\n (pivotTablesChange)=\"pivotTablesChange.emit($event)\">\n</lmr-pivot-table>\n", dependencies: [{ kind: "component", type: i1.LmrPivotTableComponent, selector: "lmr-pivot-table", inputs: ["collections", "data", "linkTypes", "query", "constraintData", "config", "transform", "emptyTablesTemplateInput", "tableCellTemplateInput"], outputs: ["cellClick", "pivotDataChange", "pivotTablesChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
69
+ }
70
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LmrSimplePivotTableComponent, decorators: [{
71
+ type: Component,
72
+ args: [{ selector: 'lmr-simple-pivot-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<lmr-pivot-table [transform]=\"transform\"\n [data]=\"data\"\n [config]=\"pivotConfig\"\n [query]=\"query\"\n [constraintData]=\"constraintData\"\n [collections]=\"[collection]\"\n [emptyTablesTemplateInput]=\"emptyTablesTemplate\"\n [tableCellTemplateInput]=\"tableCellTemplate\"\n (pivotDataChange)=\"pivotDataChange.emit($event)\"\n (pivotTablesChange)=\"pivotTablesChange.emit($event)\">\n</lmr-pivot-table>\n" }]
73
+ }], propDecorators: { rows: [{
74
+ type: Input
75
+ }], attributes: [{
76
+ type: Input
77
+ }], color: [{
78
+ type: Input
79
+ }], config: [{
80
+ type: Input
81
+ }], transform: [{
82
+ type: Input
83
+ }], locale: [{
84
+ type: Input
85
+ }], cellClick: [{
86
+ type: Output
87
+ }], pivotDataChange: [{
88
+ type: Output
89
+ }], pivotTablesChange: [{
90
+ type: Output
91
+ }], emptyTablesTemplate: [{
92
+ type: ContentChild,
93
+ args: [LmrEmptyTablesTemplateDirective, { read: TemplateRef }]
94
+ }], tableCellTemplate: [{
95
+ type: ContentChild,
96
+ args: [LmrTableCellTemplateDirective, { read: TemplateRef }]
97
+ }] } });
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lmr-simple-pivot-table.component.js","sourceRoot":"","sources":["../../../../projects/lmr-pivot-table/src/lib/lmr-simple-pivot-table.component.ts","../../../../projects/lmr-pivot-table/src/lib/lmr-simple-pivot-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, OnChanges, Output, SimpleChanges, TemplateRef} from '@angular/core';\nimport {LmrPivotConfig, LmrPivotTransform} from './util/lmr-pivot-config';\nimport {Attribute, AttributesResourceType, Collection, ConstraintData, DocumentModel, DocumentsAndLinksData, generateId, LanguageTag, Query} from '@lumeer/data-filters';\nimport {LmrPivotData} from './util/lmr-pivot-data';\nimport {LmrPivotTable, LmrPivotTableCell} from './util/lmr-pivot-table';\nimport {LmrSimplePivotConfig} from './util/lmr-simple-pivot-config';\nimport {LmrEmptyTablesTemplateDirective, LmrTableCellTemplateDirective} from './directives/lmr-templates.directive';\n\n@Component({\n  selector: 'lmr-simple-pivot-table',\n  templateUrl: 'lmr-simple-pivot-table.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class LmrSimplePivotTableComponent implements OnChanges {\n\n  @Input()\n  public rows: Record<string, any>[];\n\n  @Input()\n  public attributes: Attribute[];\n\n  @Input()\n  public color: string;\n\n  @Input()\n  public config: LmrSimplePivotConfig;\n\n  @Input()\n  public transform: LmrPivotTransform;\n\n  @Input()\n  public locale: LanguageTag;\n\n  @Output()\n  public cellClick = new EventEmitter<LmrPivotTableCell>();\n\n  @Output()\n  public pivotDataChange = new EventEmitter<LmrPivotData>();\n\n  @Output()\n  public pivotTablesChange = new EventEmitter<LmrPivotTable[]>();\n\n  @ContentChild(LmrEmptyTablesTemplateDirective, { read: TemplateRef }) emptyTablesTemplate: TemplateRef<any>;\n  @ContentChild(LmrTableCellTemplateDirective, { read: TemplateRef }) tableCellTemplate: TemplateRef<any>;\n\n  public readonly collectionId = generateId()\n  public readonly query: Query = {stems: [{collectionId: this.collectionId}]};\n\n  public collection: Collection = this.createCollection();\n  public pivotConfig: LmrPivotConfig = this.createConfig();\n  public data: DocumentsAndLinksData = this.createRows();\n  public constraintData: ConstraintData;\n\n  public ngOnChanges(changes: SimpleChanges) {\n    if (changes['rows']) {\n      this.data = this.createRows();\n    }\n    if (changes['attributes'] || changes['color']) {\n      this.collection = this.createCollection();\n    }\n    if (changes['config']) {\n      this.pivotConfig = this.createConfig();\n    }\n    this.constraintData = {\n      locale: this.locale || LanguageTag.USA,\n    }\n  }\n\n  private createCollection(): Collection {\n    return {\n      id: this.collectionId,\n      attributes: (this.attributes || []),\n      color: this.color,\n    }\n  }\n\n  private createConfig(): LmrPivotConfig {\n    return {\n      stemsConfigs: [{\n        stem: this.query.stems[0],\n        rowAttributes: (this.config?.rowAttributes || []).map(attribute => ({...attribute, resourceId: this.collectionId, resourceIndex: 0, resourceType: AttributesResourceType.Collection})),\n        columnAttributes: (this.config?.columnAttributes || []).map(attribute => ({...attribute, resourceId: this.collectionId, resourceIndex: 0, resourceType: AttributesResourceType.Collection})),\n        valueAttributes: (this.config?.valueAttributes || []).map(attribute => ({...attribute, resourceId: this.collectionId, resourceIndex: 0, resourceType: AttributesResourceType.Collection}))\n      }]\n    }\n  }\n\n  private createRows(): DocumentsAndLinksData {\n    const documents = (this.rows || []).map<DocumentModel>((row, index) => ({id: index.toString(), collectionId: this.collection.id, data: row}));\n    return ({\n      uniqueDocuments: documents,\n      uniqueLinkInstances: [],\n      dataByStems: [{\n        stem: this.query.stems[0],\n        linkInstances: [],\n        documents\n      }]\n    })\n  }\n\n}\n","<lmr-pivot-table [transform]=\"transform\"\n                 [data]=\"data\"\n                 [config]=\"pivotConfig\"\n                 [query]=\"query\"\n                 [constraintData]=\"constraintData\"\n                 [collections]=\"[collection]\"\n                 [emptyTablesTemplateInput]=\"emptyTablesTemplate\"\n                 [tableCellTemplateInput]=\"tableCellTemplate\"\n                 (pivotDataChange)=\"pivotDataChange.emit($event)\"\n                 (pivotTablesChange)=\"pivotTablesChange.emit($event)\">\n</lmr-pivot-table>\n"]}
@@ -9,4 +9,4 @@ export var LmrPivotValueType;
9
9
  LmrPivotValueType["RowPercentage"] = "row";
10
10
  LmrPivotValueType["AllPercentage"] = "all";
11
11
  })(LmrPivotValueType || (LmrPivotValueType = {}));
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG1yLXBpdm90LWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xtci1waXZvdC10YWJsZS9zcmMvbGliL3V0aWwvbG1yLXBpdm90LWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QkEsTUFBTSxDQUFOLElBQVkscUJBRVg7QUFGRCxXQUFZLHFCQUFxQjtJQUMvQixpQ0FBUSxDQUFBO0FBQ1YsQ0FBQyxFQUZXLHFCQUFxQixLQUFyQixxQkFBcUIsUUFFaEM7QUE4QkQsTUFBTSxDQUFOLElBQVksaUJBS1g7QUFMRCxXQUFZLGlCQUFpQjtJQUMzQix3Q0FBbUIsQ0FBQTtJQUNuQixnREFBMkIsQ0FBQTtJQUMzQiwwQ0FBcUIsQ0FBQTtJQUNyQiwwQ0FBcUIsQ0FBQTtBQUN2QixDQUFDLEVBTFcsaUJBQWlCLEtBQWpCLGlCQUFpQixRQUs1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29uc3RyYWludCwgRGF0YUFnZ3JlZ2F0aW9uVHlwZSwgUXVlcnlBdHRyaWJ1dGUsIFF1ZXJ5U3RlbX0gZnJvbSAnQGx1bWVlci9kYXRhLWZpbHRlcnMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90Q29uZmlnIHtcbiAgdmVyc2lvbj86IExtclBpdm90Q29uZmlnVmVyc2lvbjtcbiAgc3RlbXNDb25maWdzOiBMbXJQaXZvdFN0ZW1Db25maWdbXTtcbiAgbWVyZ2VUYWJsZXM/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90VHJhbnNmb3JtIHtcbiAgY2hlY2tWYWxpZENvbnN0cmFpbnRPdmVycmlkZT86IChjMTogQ29uc3RyYWludCwgYzI6IENvbnN0cmFpbnQpID0+IENvbnN0cmFpbnQ7XG4gIHRyYW5zbGF0ZUFnZ3JlZ2F0aW9uPzogKHR5cGU6IERhdGFBZ2dyZWdhdGlvblR5cGUpID0+IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdFN0cmluZ3Mge1xuICBzdW1tYXJ5U3RyaW5nOiBzdHJpbmc7XG4gIGhlYWRlclN1bW1hcnlTdHJpbmc6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdFN0ZW1Db25maWcge1xuICBzdGVtPzogUXVlcnlTdGVtO1xuICByb3dBdHRyaWJ1dGVzOiBMbXJQaXZvdFJvd0F0dHJpYnV0ZVtdO1xuICBjb2x1bW5BdHRyaWJ1dGVzOiBMbXJQaXZvdENvbHVtbkF0dHJpYnV0ZVtdO1xuICB2YWx1ZUF0dHJpYnV0ZXM6IExtclBpdm90VmFsdWVBdHRyaWJ1dGVbXTtcbn1cblxuZXhwb3J0IGVudW0gTG1yUGl2b3RDb25maWdWZXJzaW9uIHtcbiAgVjEgPSAnMScsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3RBdHRyaWJ1dGUgZXh0ZW5kcyBRdWVyeUF0dHJpYnV0ZSB7fVxuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90Um93Q29sdW1uQXR0cmlidXRlIGV4dGVuZHMgTG1yUGl2b3RBdHRyaWJ1dGUge1xuICBzaG93U3Vtcz86IGJvb2xlYW47XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIHNvcnQ/OiBMbXJQaXZvdFNvcnQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3RSb3dBdHRyaWJ1dGUgZXh0ZW5kcyBMbXJQaXZvdFJvd0NvbHVtbkF0dHJpYnV0ZSB7fVxuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90Q29sdW1uQXR0cmlidXRlIGV4dGVuZHMgTG1yUGl2b3RSb3dDb2x1bW5BdHRyaWJ1dGUge31cblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdFNvcnRWYWx1ZSB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIGlzU3VtbWFyeT86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3RTb3J0TGlzdCB7XG4gIHZhbHVlVGl0bGU6IHN0cmluZztcbiAgdmFsdWVzOiBMbXJQaXZvdFNvcnRWYWx1ZVtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90U29ydCB7XG4gIGF0dHJpYnV0ZT86IExtclBpdm90QXR0cmlidXRlO1xuICBsaXN0PzogTG1yUGl2b3RTb3J0TGlzdDtcbiAgYXNjOiBib29sZWFuO1xufVxuXG5leHBvcnQgZW51bSBMbXJQaXZvdFZhbHVlVHlwZSB7XG4gIERlZmF1bHQgPSAnZGVmYXVsdCcsXG4gIENvbHVtblBlcmNlbnRhZ2UgPSAnY29sdW1uJyxcbiAgUm93UGVyY2VudGFnZSA9ICdyb3cnLFxuICBBbGxQZXJjZW50YWdlID0gJ2FsbCcsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3RWYWx1ZUF0dHJpYnV0ZSBleHRlbmRzIExtclBpdm90QXR0cmlidXRlIHtcbiAgYWdncmVnYXRpb246IERhdGFBZ2dyZWdhdGlvblR5cGU7XG4gIHZhbHVlVHlwZT86IExtclBpdm90VmFsdWVUeXBlO1xufVxuIl19
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG1yLXBpdm90LWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xtci1waXZvdC10YWJsZS9zcmMvbGliL3V0aWwvbG1yLXBpdm90LWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QkEsTUFBTSxDQUFOLElBQVkscUJBRVg7QUFGRCxXQUFZLHFCQUFxQjtJQUMvQixpQ0FBUSxDQUFBO0FBQ1YsQ0FBQyxFQUZXLHFCQUFxQixLQUFyQixxQkFBcUIsUUFFaEM7QUFpQ0QsTUFBTSxDQUFOLElBQVksaUJBS1g7QUFMRCxXQUFZLGlCQUFpQjtJQUMzQix3Q0FBbUIsQ0FBQTtJQUNuQixnREFBMkIsQ0FBQTtJQUMzQiwwQ0FBcUIsQ0FBQTtJQUNyQiwwQ0FBcUIsQ0FBQTtBQUN2QixDQUFDLEVBTFcsaUJBQWlCLEtBQWpCLGlCQUFpQixRQUs1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29uc3RyYWludCwgRGF0YUFnZ3JlZ2F0aW9uVHlwZSwgUXVlcnlBdHRyaWJ1dGUsIFF1ZXJ5U3RlbX0gZnJvbSAnQGx1bWVlci9kYXRhLWZpbHRlcnMnO1xuaW1wb3J0IHtMbXJQaXZvdERhdGFIZWFkZXJ9IGZyb20gJy4vbG1yLXBpdm90LWRhdGEnO1xuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90Q29uZmlnIHtcbiAgdmVyc2lvbj86IExtclBpdm90Q29uZmlnVmVyc2lvbjtcbiAgc3RlbXNDb25maWdzOiBMbXJQaXZvdFN0ZW1Db25maWdbXTtcbiAgbWVyZ2VUYWJsZXM/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90VHJhbnNmb3JtIHtcbiAgY2hlY2tWYWxpZENvbnN0cmFpbnRPdmVycmlkZT86IChjMTogQ29uc3RyYWludCwgYzI6IENvbnN0cmFpbnQpID0+IENvbnN0cmFpbnQ7XG4gIGZvcm1hdEFnZ3JlZ2F0aW9uPzogKHR5cGU6IERhdGFBZ2dyZWdhdGlvblR5cGUpID0+IHN0cmluZztcbiAgZm9ybWF0U3VtbWFyeUhlYWRlcj86IChoZWFkZXI6IExtclBpdm90RGF0YUhlYWRlciwgbGV2ZWw6IG51bWJlcikgPT4ge3RpdGxlPzogc3RyaW5nOyBzdW1tYXJ5OiBzdHJpbmd9O1xuICBmb3JtYXRSb3dIZWFkZXI/OiAodGl0bGU6IHN0cmluZywgbGV2ZWw6IG51bWJlcikgPT4gc3RyaW5nO1xuICBmb3JtYXRDb2x1bW5IZWFkZXI/OiAodGl0bGU6IHN0cmluZywgbGV2ZWw6IG51bWJlcikgPT4gc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90U3RlbUNvbmZpZyB7XG4gIHN0ZW0/OiBRdWVyeVN0ZW07XG4gIHJvd0F0dHJpYnV0ZXM6IExtclBpdm90Um93QXR0cmlidXRlW107XG4gIGNvbHVtbkF0dHJpYnV0ZXM6IExtclBpdm90Q29sdW1uQXR0cmlidXRlW107XG4gIHZhbHVlQXR0cmlidXRlczogTG1yUGl2b3RWYWx1ZUF0dHJpYnV0ZVtdO1xufVxuXG5leHBvcnQgZW51bSBMbXJQaXZvdENvbmZpZ1ZlcnNpb24ge1xuICBWMSA9ICcxJyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdEF0dHJpYnV0ZSBleHRlbmRzIFF1ZXJ5QXR0cmlidXRlIHt9XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3RSb3dDb2x1bW5BdHRyaWJ1dGUgZXh0ZW5kcyBMbXJQaXZvdEF0dHJpYnV0ZSB7XG4gIHNob3dTdW1zPzogYm9vbGVhbjtcbiAgc3RpY2t5PzogYm9vbGVhbjtcbiAgc29ydD86IExtclBpdm90U29ydDtcbiAgZXhwcmVzc2lvbnM/OiBMbXJQaXZvdEV4cHJlc3Npb25bXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdFJvd0F0dHJpYnV0ZSBleHRlbmRzIExtclBpdm90Um93Q29sdW1uQXR0cmlidXRlIHtcbiAgc2hvd0hlYWRlcj86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3RDb2x1bW5BdHRyaWJ1dGUgZXh0ZW5kcyBMbXJQaXZvdFJvd0NvbHVtbkF0dHJpYnV0ZSB7fVxuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90U29ydFZhbHVlIHtcbiAgdGl0bGU6IHN0cmluZztcbiAgaXNTdW1tYXJ5PzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdFNvcnRMaXN0IHtcbiAgdmFsdWVUaXRsZTogc3RyaW5nO1xuICB2YWx1ZXM6IExtclBpdm90U29ydFZhbHVlW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3RTb3J0IHtcbiAgYXR0cmlidXRlPzogTG1yUGl2b3RBdHRyaWJ1dGU7XG4gIGxpc3Q/OiBMbXJQaXZvdFNvcnRMaXN0O1xuICBhc2M6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBlbnVtIExtclBpdm90VmFsdWVUeXBlIHtcbiAgRGVmYXVsdCA9ICdkZWZhdWx0JyxcbiAgQ29sdW1uUGVyY2VudGFnZSA9ICdjb2x1bW4nLFxuICBSb3dQZXJjZW50YWdlID0gJ3JvdycsXG4gIEFsbFBlcmNlbnRhZ2UgPSAnYWxsJyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdFZhbHVlQXR0cmlidXRlIGV4dGVuZHMgTG1yUGl2b3RBdHRyaWJ1dGUge1xuICBhZ2dyZWdhdGlvbjogRGF0YUFnZ3JlZ2F0aW9uVHlwZTtcbiAgdmFsdWVUeXBlPzogTG1yUGl2b3RWYWx1ZVR5cGU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3RFeHByZXNzaW9uIHtcbiAgb3BlcmF0aW9uOiBMbXJQaXZvdEV4cHJlc3Npb25PcGVyYXRpb247XG4gIG9wZXJhbmRzOiBMbXJQaXZvdE9wZXJhbmRbXTtcbiAgdGl0bGU6IHN0cmluZztcbiAgdHlwZTogJ2V4cHJlc3Npb24nXG59XG5cbmV4cG9ydCB0eXBlIExtclBpdm90RXhwcmVzc2lvbk9wZXJhdGlvbiA9ICdhZGQnIHwgJ3N1YnRyYWN0JyB8ICdtdWx0aXBseScgfCAnZGl2aWRlJztcblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdEhlYWRlck9wZXJhbmQge1xuICB0eXBlOiAnaGVhZGVyJztcbiAgdmFsdWU6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdFZhbHVlT3BlcmFuZCB7XG4gIHR5cGU6ICd2YWx1ZSc7XG4gIHZhbHVlOiBudW1iZXI7XG59XG5cbmV4cG9ydCB0eXBlIExtclBpdm90T3BlcmFuZCA9IExtclBpdm90SGVhZGVyT3BlcmFuZCB8IExtclBpdm90VmFsdWVPcGVyYW5kIHwgTG1yUGl2b3RFeHByZXNzaW9uO1xuIl19
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG1yLXBpdm90LWRhdGEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9sbXItcGl2b3QtdGFibGUvc3JjL2xpYi91dGlsL2xtci1waXZvdC1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogTHVtZWVyOiBNb2Rlcm4gRGF0YSBEZWZpbml0aW9uIGFuZCBQcm9jZXNzaW5nIFBsYXRmb3JtXG4gKlxuICogQ29weXJpZ2h0IChDKSBzaW5jZSAyMDE3IEx1bWVlci5pbywgcy5yLm8uIGFuZC9vciBpdHMgYWZmaWxpYXRlcy5cbiAqXG4gKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeVxuICogaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnlcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXG4gKiAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLlxuICpcbiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLFxuICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2ZcbiAqIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gIFNlZSB0aGVcbiAqIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGZvciBtb3JlIGRldGFpbHMuXG4gKlxuICogWW91IHNob3VsZCBoYXZlIHJlY2VpdmVkIGEgY29weSBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2VcbiAqIGFsb25nIHdpdGggdGhpcyBwcm9ncmFtLiAgSWYgbm90LCBzZWUgPGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy8+LlxuICovXG5pbXBvcnQge0NvbnN0cmFpbnQsIENvbnN0cmFpbnREYXRhLCBEYXRhQWdncmVnYXRpb25UeXBlLCBEYXRhUmVzb3VyY2V9IGZyb20gJ0BsdW1lZXIvZGF0YS1maWx0ZXJzJztcbmltcG9ydCB7TG1yUGl2b3RTb3J0LCBMbXJQaXZvdFZhbHVlVHlwZX0gZnJvbSAnLi9sbXItcGl2b3QtY29uZmlnJztcblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdERhdGEge1xuICBkYXRhOiBMbXJQaXZvdFN0ZW1EYXRhW107XG5cbiAgY29uc3RyYWludERhdGE/OiBDb25zdHJhaW50RGF0YTtcbiAgbWVyZ2VUYWJsZXM/OiBib29sZWFuO1xuICBhYmxlVG9NZXJnZT86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3RTdGVtRGF0YSB7XG4gIGNvbHVtbkhlYWRlcnM6IExtclBpdm90RGF0YUhlYWRlcltdO1xuICByb3dIZWFkZXJzOiBMbXJQaXZvdERhdGFIZWFkZXJbXTtcbiAgdmFsdWVUaXRsZXM6IHN0cmluZ1tdO1xuICB2YWx1ZXM6IGFueVtdW107XG4gIGRhdGFSZXNvdXJjZXM6IERhdGFSZXNvdXJjZVtdW11bXTtcbiAgdmFsdWVzQ29uc3RyYWludHM/OiBDb25zdHJhaW50W107XG4gIHZhbHVlVHlwZXM/OiBMbXJQaXZvdFZhbHVlVHlwZVtdO1xuICB2YWx1ZUFnZ3JlZ2F0aW9ucz86IERhdGFBZ2dyZWdhdGlvblR5cGVbXTtcblxuICByb3dTaG93U3VtczogYm9vbGVhbltdO1xuICByb3dTdGlja3k6IGJvb2xlYW5bXTtcbiAgcm93U29ydHM/OiBMbXJQaXZvdFNvcnRbXTtcbiAgY29sdW1uU2hvd1N1bXM6IGJvb2xlYW5bXTtcbiAgY29sdW1uU3RpY2t5OiBib29sZWFuW107XG4gIGNvbHVtblNvcnRzPzogTG1yUGl2b3RTb3J0W107XG4gIGhhc0FkZGl0aW9uYWxDb2x1bW5MZXZlbD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3REYXRhSGVhZGVyIHtcbiAgdGl0bGU6IHN0cmluZztcbiAgY2hpbGRyZW4/OiBMbXJQaXZvdERhdGFIZWFkZXJbXTtcbiAgdGFyZ2V0SW5kZXg/OiBudW1iZXI7XG4gIGNvbG9yOiBzdHJpbmc7XG4gIGlzVmFsdWVIZWFkZXI6IGJvb2xlYW47XG4gIGNvbnN0cmFpbnQ/OiBDb25zdHJhaW50O1xuICBhdHRyaWJ1dGVOYW1lPzogc3RyaW5nO1xufVxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG1yLXBpdm90LWRhdGEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9sbXItcGl2b3QtdGFibGUvc3JjL2xpYi91dGlsL2xtci1waXZvdC1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogTHVtZWVyOiBNb2Rlcm4gRGF0YSBEZWZpbml0aW9uIGFuZCBQcm9jZXNzaW5nIFBsYXRmb3JtXG4gKlxuICogQ29weXJpZ2h0IChDKSBzaW5jZSAyMDE3IEx1bWVlci5pbywgcy5yLm8uIGFuZC9vciBpdHMgYWZmaWxpYXRlcy5cbiAqXG4gKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeVxuICogaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnlcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXG4gKiAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLlxuICpcbiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLFxuICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2ZcbiAqIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gIFNlZSB0aGVcbiAqIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGZvciBtb3JlIGRldGFpbHMuXG4gKlxuICogWW91IHNob3VsZCBoYXZlIHJlY2VpdmVkIGEgY29weSBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2VcbiAqIGFsb25nIHdpdGggdGhpcyBwcm9ncmFtLiAgSWYgbm90LCBzZWUgPGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy8+LlxuICovXG5pbXBvcnQge0NvbnN0cmFpbnQsIENvbnN0cmFpbnREYXRhLCBEYXRhQWdncmVnYXRpb25UeXBlLCBEYXRhUmVzb3VyY2V9IGZyb20gJ0BsdW1lZXIvZGF0YS1maWx0ZXJzJztcbmltcG9ydCB7TG1yUGl2b3RFeHByZXNzaW9uLCBMbXJQaXZvdEhlYWRlck9wZXJhbmQsIExtclBpdm90U29ydCwgTG1yUGl2b3RWYWx1ZU9wZXJhbmQsIExtclBpdm90VmFsdWVUeXBlfSBmcm9tICcuL2xtci1waXZvdC1jb25maWcnO1xuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90RGF0YSB7XG4gIGRhdGE6IExtclBpdm90U3RlbURhdGFbXTtcblxuICBjb25zdHJhaW50RGF0YT86IENvbnN0cmFpbnREYXRhO1xuICBtZXJnZVRhYmxlcz86IGJvb2xlYW47XG4gIGFibGVUb01lcmdlPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMbXJQaXZvdFN0ZW1EYXRhIHtcbiAgY29sdW1uSGVhZGVyczogTG1yUGl2b3REYXRhSGVhZGVyW107XG4gIGNvbHVtbkhlYWRlckF0dHJpYnV0ZXM6IExtclBpdm90SGVhZGVyQXR0cmlidXRlW107XG4gIHJvd0hlYWRlcnM6IExtclBpdm90RGF0YUhlYWRlcltdO1xuICByb3dIZWFkZXJBdHRyaWJ1dGVzOiBMbXJQaXZvdEhlYWRlckF0dHJpYnV0ZVtdO1xuICB2YWx1ZVRpdGxlczogc3RyaW5nW107XG4gIHZhbHVlczogYW55W11bXTtcbiAgZGF0YVJlc291cmNlczogRGF0YVJlc291cmNlW11bXVtdO1xuICB2YWx1ZXNDb25zdHJhaW50cz86IENvbnN0cmFpbnRbXTtcbiAgdmFsdWVUeXBlcz86IExtclBpdm90VmFsdWVUeXBlW107XG4gIHZhbHVlQWdncmVnYXRpb25zPzogRGF0YUFnZ3JlZ2F0aW9uVHlwZVtdO1xuXG4gIHJvd3NDb25maWc6IExtclBpdm90RGltZW5zaW9uQ29uZmlnW107XG4gIGNvbHVtbnNDb25maWc6IExtclBpdm90RGltZW5zaW9uQ29uZmlnW107XG4gIGhhc0FkZGl0aW9uYWxDb2x1bW5MZXZlbD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3REaW1lbnNpb25Db25maWcge1xuICBzaG93U3Vtcz86IGJvb2xlYW47XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIHNvcnQ/OiBMbXJQaXZvdFNvcnQ7XG4gIGV4cHJlc3Npb25zPzogTG1yUGl2b3RFeHByZXNzaW9uW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3RIZWFkZXJBdHRyaWJ1dGUge1xuICB0aXRsZTogc3RyaW5nO1xuICBjb2xvcjogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExtclBpdm90RGF0YUhlYWRlciB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIGNoaWxkcmVuPzogTG1yUGl2b3REYXRhSGVhZGVyW107XG4gIHRhcmdldEluZGV4PzogbnVtYmVyO1xuICBjb2xvcjogc3RyaW5nO1xuICBpc1ZhbHVlSGVhZGVyOiBib29sZWFuO1xuICBjb25zdHJhaW50PzogQ29uc3RyYWludDtcbiAgYXR0cmlidXRlTmFtZT86IHN0cmluZztcbiAgZXhwcmVzc2lvbnM/OiBMbXJQaXZvdERhdGFIZWFkZXJFeHByZXNzaW9uW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTG1yUGl2b3REYXRhSGVhZGVyRXhwcmVzc2lvbiBleHRlbmRzIExtclBpdm90RXhwcmVzc2lvbiB7XG4gIGxhc3RIZWFkZXJJbmRleD86IG51bWJlcjtcbiAgb3BlcmFuZHM6IExtclBpdm90RGF0YUhlYWRlck9wZXJhbmRbXTtcbn1cblxuZXhwb3J0IHR5cGUgTG1yUGl2b3REYXRhSGVhZGVyT3BlcmFuZCA9IExtclBpdm90SGVhZGVyT3BlcmFuZCAmIHtoZWFkZXJzOiBMbXJQaXZvdERhdGFIZWFkZXJbXX0gfCBMbXJQaXZvdFZhbHVlT3BlcmFuZCB8IExtclBpdm90RGF0YUhlYWRlckV4cHJlc3Npb247XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG1yLXNpbXBsZS1waXZvdC1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9sbXItcGl2b3QtdGFibGUvc3JjL2xpYi91dGlsL2xtci1zaW1wbGUtcGl2b3QtY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0xtclBpdm90Q29sdW1uQXR0cmlidXRlLCBMbXJQaXZvdFJvd0F0dHJpYnV0ZSwgTG1yUGl2b3RWYWx1ZUF0dHJpYnV0ZX0gZnJvbSAnLi9sbXItcGl2b3QtY29uZmlnJztcblxuZXhwb3J0IGludGVyZmFjZSBMbXJTaW1wbGVQaXZvdENvbmZpZyB7XG4gIHJvd0F0dHJpYnV0ZXM6IExtclNpbXBsZVBpdm90Um93QXR0cmlidXRlW107XG4gIGNvbHVtbkF0dHJpYnV0ZXM6IExtclNpbXBsZVBpdm90Q29sdW1uQXR0cmlidXRlW107XG4gIHZhbHVlQXR0cmlidXRlczogTG1yU2ltcGxlUGl2b3RWYWx1ZUF0dHJpYnV0ZVtdO1xufVxuXG5leHBvcnQgdHlwZSBMbXJTaW1wbGVQaXZvdFJvd0F0dHJpYnV0ZSA9IE9taXQ8TG1yUGl2b3RSb3dBdHRyaWJ1dGUsICdyZXNvdXJjZVR5cGUnIHwgJ3Jlc291cmNlSWQnIHwgJ3Jlc291cmNlSW5kZXgnPlxuZXhwb3J0IHR5cGUgTG1yU2ltcGxlUGl2b3RDb2x1bW5BdHRyaWJ1dGUgPSBPbWl0PExtclBpdm90Q29sdW1uQXR0cmlidXRlLCAncmVzb3VyY2VUeXBlJyB8ICdyZXNvdXJjZUlkJyB8ICdyZXNvdXJjZUluZGV4Jz5cbmV4cG9ydCB0eXBlIExtclNpbXBsZVBpdm90VmFsdWVBdHRyaWJ1dGUgPSBPbWl0PExtclBpdm90VmFsdWVBdHRyaWJ1dGUsICdyZXNvdXJjZVR5cGUnIHwgJ3Jlc291cmNlSWQnIHwgJ3Jlc291cmNlSW5kZXgnPlxuIl19