@lumeer/pivot 0.0.8 → 0.0.10

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.
@@ -33,7 +33,7 @@ export class LmrPivotTableComponent {
33
33
  pivotTransformer = new PivotDataConverter();
34
34
  pivotTableConverter = new PivotTableConverter();
35
35
  stickyColumnWidth = 150;
36
- stickyColumnHeight = 150;
36
+ stickyColumnHeight = 40;
37
37
  dataSubject$ = new BehaviorSubject(null);
38
38
  currentTables;
39
39
  pivotData$;
@@ -144,4 +144,4 @@ function tablesAreVeryDifferent(t1, t2) {
144
144
  // row numbers are different
145
145
  return (t1 || []).some((t, index) => t.cells?.length !== t2[index].cells?.length);
146
146
  }
147
- //# 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';\nimport {collapseAllCells, isCellExpandable, LmrPivotTableState, toggleExpanded} from './util/lmr-pivot-state';\nimport {isPivotConfigChanged} from './util/pivot-util';\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  @Input()\n  public initiallyCollapsed: boolean;\n\n  @Output()\n  public cellClick = new EventEmitter<{cell: LmrPivotTableCell; tableIndex: number; rowIndex: number; columnIndex: number }>();\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  public readonly stickyColumnWidth = 150;\n  public readonly stickyColumnHeight = 150;\n\n  private dataSubject$ = new BehaviorSubject<Data>(null);\n  private currentTables: LmrPivotTable[];\n\n  public pivotData$: Observable<LmrPivotData>;\n  public pivotTables$: Observable<LmrPivotTable[]>;\n  public pivotStates$ = new BehaviorSubject<LmrPivotTableState[]>([]);\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.onPivotDataChange(data)),\n    );\n\n    this.pivotTables$ = this.pivotData$.pipe(\n      map(data => this.pivotTableConverter.createTables(data, this.transform)),\n      tap(tables => this.onPivotTablesChange(tables))\n    );\n  }\n\n  private onPivotDataChange(data: LmrPivotData) {\n    this.pivotDataChange.emit(data);\n  }\n\n  private onPivotTablesChange(tables: LmrPivotTable[]) {\n    if (this.initiallyCollapsed && tablesAreVeryDifferent(this.currentTables, tables)) {\n      this.pivotStates$.next(tables.map(table => collapseAllCells(table)));\n    }\n\n    this.currentTables = tables;\n    this.pivotTablesChange.emit(tables);\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    if (shouldResetState(changes)) {\n      this.resetState();\n    }\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  private resetState() {\n    // this.pivotStates$.next([]);\n  }\n\n  public onCellClick(cell: LmrPivotTableCell, row: LmrPivotTableCell[], tableIndex: number, rowIndex: number, columnIndex: number) {\n    if (isCellExpandable(cell)) {\n      const oldState = this.pivotStates$.value[tableIndex]\n      const newState = toggleExpanded(cell, columnIndex, oldState)\n      this.setState(tableIndex, newState)\n    } else if (cell?.isHeader || cell?.isValue) {\n      const headerCell = cell.isHeader ? cell : row.find(c => c.isHeader)\n      this.cellClick.emit({cell, tableIndex, rowIndex: headerCell?.originalRowIndex || rowIndex, columnIndex})\n    }\n  }\n\n  private setState(index: number, state: LmrPivotTableState) {\n    const statesCopy = [...(this.pivotStates$.value || [])];\n    statesCopy.splice(index, 1, state)\n    this.pivotStates$.next(statesCopy)\n  }\n}\n\nfunction shouldResetState(changes: SimpleChanges): boolean {\n  if (changes['config']) {\n    const previousValue = changes['config'].previousValue as LmrPivotConfig\n    const currentValue = changes['config'].currentValue as LmrPivotConfig\n    return isPivotConfigChanged(previousValue, currentValue)\n  }\n  return false;\n}\n\nfunction tablesAreVeryDifferent(t1: LmrPivotTable[], t2: LmrPivotTable[]): boolean {\n  if ((t1 || []).length !== (t2 || []).length) {\n    return true\n  }\n  // row numbers are different\n  return (t1 || []).some((t, index) => t.cells?.length !== t2[index].cells?.length);\n}\n","<ng-container *ngIf=\"{pivotTables: pivotTables$ | async, pivotStates: pivotStates$ | 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; let tableIndex = index\"\n           class=\"table table-without-padding table-borderless table-md\"\n           [class.mt-4]=\"!first\">\n      <tr *ngFor=\"let rowCells of pivotTable | filterVisibleCells:data.pivotStates[tableIndex]; let rowIndex = index\">\n\n        <ng-container *ngFor=\"let cell of rowCells; let cellIndex = index\">\n          <td *ngIf=\"cell && {hasValue: cell | cellHasValue} as cellData\"\n              class=\"cell position-relative {{cell.constraint ? (cell.constraint.type | lowercase) : ''}} text-truncate\"\n              [class.expandable]=\"cell | isCellExpandable\"\n              [class.expandable-rows]=\"cell | isCellRowsExpandable\"\n              [class.expanded]=\"cell | isCellExpanded:cellIndex:data.pivotStates[tableIndex]\"\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 * stickyColumnHeight) : undefined\"\n              [style.left.px]=\"cell.stickyStart ? (cellIndex * stickyColumnWidth) : undefined\"\n              [style.width.px]=\"cell.stickyStart ? (cell.colSpan * stickyColumnWidth) : undefined\"\n              [style.max-width.px]=\"cell.stickyStart ? (cell.colSpan * stickyColumnWidth) : 300\"\n              [style.min-width.px]=\"cell.stickyStart ? (cell.colSpan * stickyColumnWidth) : undefined\"\n              [ngClass]=\"cell.cssClass\"\n              [style.background]=\"cell.background\"\n              [style.color]=\"cell.background && (cell.background | contrastColor)\"\n              (click)=\"onCellClick(cell, rowCells, tableIndex, rowIndex, cellIndex)\">\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-block\" style=\"overflow: hidden; white-space: normal\">{{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-block\" style=\"overflow: hidden; white-space: normal; cursor: pointer\">\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"]}
147
+ //# 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;AACpH,OAAO,EAAC,gBAAgB,EAAE,gBAAgB,EAAsB,cAAc,EAAC,MAAM,wBAAwB,CAAC;AAC9G,OAAO,EAAC,oBAAoB,EAAC,MAAM,mBAAmB,CAAC;;;;;;;;;;AAkBvD,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,wBAAwB,CAAmB;IAG3C,sBAAsB,CAAmB;IAGzC,kBAAkB,CAAU;IAG5B,SAAS,GAAG,IAAI,YAAY,EAAyF,CAAC;IAGtH,eAAe,GAAG,IAAI,YAAY,EAAgB,CAAC;IAGnD,iBAAiB,GAAG,IAAI,YAAY,EAAmB,CAAC;IAEK,mBAAmB,CAAmB;IACxC,iBAAiB,CAAmB;IAErF,gBAAgB,GAAG,IAAI,kBAAkB,EAAE,CAAC;IAC5C,mBAAmB,GAAwB,IAAI,mBAAmB,EAAE,CAAC;IACtE,iBAAiB,GAAG,GAAG,CAAC;IACxB,kBAAkB,GAAG,EAAE,CAAC;IAEhC,YAAY,GAAG,IAAI,eAAe,CAAO,IAAI,CAAC,CAAC;IAC/C,aAAa,CAAkB;IAEhC,UAAU,CAA2B;IACrC,YAAY,CAA8B;IAC1C,YAAY,GAAG,IAAI,eAAe,CAAuB,EAAE,CAAC,CAAC;IAE7D,QAAQ;QACb,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAElE,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,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAC1C,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,SAAS,CAAC,CAAC,EACxE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAChD,CAAC;IACJ,CAAC;IAEO,iBAAiB,CAAC,IAAkB;QAC1C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAEO,mBAAmB,CAAC,MAAuB;QACjD,IAAI,IAAI,CAAC,kBAAkB,IAAI,sBAAsB,CAAC,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,EAAE;YACjF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SACtE;QAED,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC;QAC5B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACtC,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,gBAAgB,CAAC,OAAO,CAAC,EAAE;YAC7B,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;QACD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;YACrB,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;IAEO,UAAU;QAChB,8BAA8B;IAChC,CAAC;IAEM,WAAW,CAAC,IAAuB,EAAE,GAAwB,EAAE,UAAkB,EAAE,QAAgB,EAAE,WAAmB;QAC7H,IAAI,gBAAgB,CAAC,IAAI,CAAC,EAAE;YAC1B,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;YACpD,MAAM,QAAQ,GAAG,cAAc,CAAC,IAAI,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAA;YAC5D,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;SACpC;aAAM,IAAI,IAAI,EAAE,QAAQ,IAAI,IAAI,EAAE,OAAO,EAAE;YAC1C,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAA;YACnE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,gBAAgB,IAAI,QAAQ,EAAE,WAAW,EAAC,CAAC,CAAA;SACzG;IACH,CAAC;IAEO,QAAQ,CAAC,KAAa,EAAE,KAAyB;QACvD,MAAM,UAAU,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,CAAC;QACxD,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,CAAC,CAAA;QAClC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;IACpC,CAAC;wGAlIU,sBAAsB;4FAAtB,sBAAsB,qhBAyCnB,+BAA+B,2BAAS,WAAW,iEACnD,6BAA6B,2BAAS,WAAW,kDCtEjE,ywIA8EA;;4FDlDa,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,wBAAwB;sBAD9B,KAAK;gBAIC,sBAAsB;sBAD5B,KAAK;gBAIC,kBAAkB;sBADxB,KAAK;gBAIC,SAAS;sBADf,MAAM;gBAIA,eAAe;sBADrB,MAAM;gBAIA,iBAAiB;sBADvB,MAAM;gBAG6D,mBAAmB;sBAAtF,YAAY;uBAAC,+BAA+B,EAAE,EAAC,IAAI,EAAE,WAAW,EAAC;gBACA,iBAAiB;sBAAlF,YAAY;uBAAC,6BAA6B,EAAE,EAAC,IAAI,EAAE,WAAW,EAAC;;AA2FlE,SAAS,gBAAgB,CAAC,OAAsB;IAC9C,IAAI,OAAO,CAAC,QAAQ,CAAC,EAAE;QACrB,MAAM,aAAa,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,aAA+B,CAAA;QACvE,MAAM,YAAY,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,YAA8B,CAAA;QACrE,OAAO,oBAAoB,CAAC,aAAa,EAAE,YAAY,CAAC,CAAA;KACzD;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,sBAAsB,CAAC,EAAmB,EAAE,EAAmB;IACtE,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;QAC3C,OAAO,IAAI,CAAA;KACZ;IACD,4BAA4B;IAC5B,OAAO,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE,MAAM,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;AACpF,CAAC","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';\nimport {collapseAllCells, isCellExpandable, LmrPivotTableState, toggleExpanded} from './util/lmr-pivot-state';\nimport {isPivotConfigChanged} from './util/pivot-util';\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  @Input()\n  public initiallyCollapsed: boolean;\n\n  @Output()\n  public cellClick = new EventEmitter<{cell: LmrPivotTableCell; tableIndex: number; rowIndex: number; columnIndex: number }>();\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  public readonly stickyColumnWidth = 150;\n  public readonly stickyColumnHeight = 40;\n\n  private dataSubject$ = new BehaviorSubject<Data>(null);\n  private currentTables: LmrPivotTable[];\n\n  public pivotData$: Observable<LmrPivotData>;\n  public pivotTables$: Observable<LmrPivotTable[]>;\n  public pivotStates$ = new BehaviorSubject<LmrPivotTableState[]>([]);\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.onPivotDataChange(data)),\n    );\n\n    this.pivotTables$ = this.pivotData$.pipe(\n      map(data => this.pivotTableConverter.createTables(data, this.transform)),\n      tap(tables => this.onPivotTablesChange(tables))\n    );\n  }\n\n  private onPivotDataChange(data: LmrPivotData) {\n    this.pivotDataChange.emit(data);\n  }\n\n  private onPivotTablesChange(tables: LmrPivotTable[]) {\n    if (this.initiallyCollapsed && tablesAreVeryDifferent(this.currentTables, tables)) {\n      this.pivotStates$.next(tables.map(table => collapseAllCells(table)));\n    }\n\n    this.currentTables = tables;\n    this.pivotTablesChange.emit(tables);\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    if (shouldResetState(changes)) {\n      this.resetState();\n    }\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  private resetState() {\n    // this.pivotStates$.next([]);\n  }\n\n  public onCellClick(cell: LmrPivotTableCell, row: LmrPivotTableCell[], tableIndex: number, rowIndex: number, columnIndex: number) {\n    if (isCellExpandable(cell)) {\n      const oldState = this.pivotStates$.value[tableIndex]\n      const newState = toggleExpanded(cell, columnIndex, oldState)\n      this.setState(tableIndex, newState)\n    } else if (cell?.isHeader || cell?.isValue) {\n      const headerCell = cell.isHeader ? cell : row.find(c => c.isHeader)\n      this.cellClick.emit({cell, tableIndex, rowIndex: headerCell?.originalRowIndex || rowIndex, columnIndex})\n    }\n  }\n\n  private setState(index: number, state: LmrPivotTableState) {\n    const statesCopy = [...(this.pivotStates$.value || [])];\n    statesCopy.splice(index, 1, state)\n    this.pivotStates$.next(statesCopy)\n  }\n}\n\nfunction shouldResetState(changes: SimpleChanges): boolean {\n  if (changes['config']) {\n    const previousValue = changes['config'].previousValue as LmrPivotConfig\n    const currentValue = changes['config'].currentValue as LmrPivotConfig\n    return isPivotConfigChanged(previousValue, currentValue)\n  }\n  return false;\n}\n\nfunction tablesAreVeryDifferent(t1: LmrPivotTable[], t2: LmrPivotTable[]): boolean {\n  if ((t1 || []).length !== (t2 || []).length) {\n    return true\n  }\n  // row numbers are different\n  return (t1 || []).some((t, index) => t.cells?.length !== t2[index].cells?.length);\n}\n","<ng-container *ngIf=\"{pivotTables: pivotTables$ | async, pivotStates: pivotStates$ | 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; let tableIndex = index\"\n           class=\"table table-without-padding table-borderless table-md\"\n           [class.mt-4]=\"!first\">\n      <tr *ngFor=\"let rowCells of pivotTable | filterVisibleCells:data.pivotStates[tableIndex]; let rowIndex = index\">\n\n        <ng-container *ngFor=\"let cell of rowCells; let cellIndex = index\">\n          <td *ngIf=\"cell && {hasValue: cell | cellHasValue} as cellData\"\n              class=\"cell position-relative {{cell.constraint ? (cell.constraint.type | lowercase) : ''}} text-truncate\"\n              [class.expandable]=\"cell | isCellExpandable\"\n              [class.expandable-rows]=\"cell | isCellRowsExpandable\"\n              [class.expanded]=\"cell | isCellExpanded:cellIndex:data.pivotStates[tableIndex]\"\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 * stickyColumnHeight) : undefined\"\n              [style.left.px]=\"cell.stickyStart ? (cellIndex * stickyColumnWidth) : undefined\"\n              [style.width.px]=\"cell.stickyStart ? (cell.colSpan * stickyColumnWidth) : undefined\"\n              [style.max-width.px]=\"cell.stickyStart ? (cell.colSpan * stickyColumnWidth) : 300\"\n              [style.min-width.px]=\"cell.stickyStart ? (cell.colSpan * stickyColumnWidth) : undefined\"\n              [ngClass]=\"cell.cssClass\"\n              [style.background]=\"cell.background\"\n              [style.color]=\"cell.background && (cell.background | contrastColor)\"\n              (click)=\"onCellClick(cell, rowCells, tableIndex, rowIndex, cellIndex)\">\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-block\" style=\"overflow: hidden; white-space: normal\">{{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-block\" style=\"overflow: hidden; white-space: normal; cursor: pointer\">\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"]}