@rivet-health/design-system 30.0.0 → 30.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/table/table/table/table.component.mjs +2 -2
- package/fesm2015/rivet-health-design-system.mjs +1 -1
- package/fesm2015/rivet-health-design-system.mjs.map +1 -1
- package/fesm2020/rivet-health-design-system.mjs +1 -1
- package/fesm2020/rivet-health-design-system.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -131,7 +131,7 @@ export class TableComponent {
|
|
|
131
131
|
}
|
|
132
132
|
}
|
|
133
133
|
getEnabledCount(columns) {
|
|
134
|
-
return columns.filter(c => c.
|
|
134
|
+
return columns.filter(c => c.enabled).length;
|
|
135
135
|
}
|
|
136
136
|
dropEnabledState(enabled, enabledColumnCount) {
|
|
137
137
|
if (this.draggedColumnKey !== null && this.draggedColumnIdx !== null) {
|
|
@@ -229,4 +229,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
229
229
|
type: HostListener,
|
|
230
230
|
args: ['document:keyup', ['$event']]
|
|
231
231
|
}] } });
|
|
232
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/riv/src/lib/table/table/table/table.component.ts","../../../../../../../projects/riv/src/lib/table/table/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  HostListener,\n  Input,\n  OnDestroy,\n  TemplateRef,\n  TrackByFunction,\n} from '@angular/core';\nimport { sum } from 'lodash';\nimport { combineLatest, map, Observable, Subject, takeUntil } from 'rxjs';\nimport { RivSelect } from '../../../input/select/state';\nimport { RivTable } from '../state';\n\ntype PageSizeOption = {\n  id: string;\n  title: string;\n  value: number;\n};\n\n@Component({\n  selector: 'riv-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TableComponent<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n  G extends RivTable.Group = { key: '' },\n> implements AfterViewInit, OnDestroy\n{\n  @Input()\n  manager?: RivTable.Manager<R, C, F, G>;\n\n  @ContentChild('cell')\n  cellTemplate?: TemplateRef<{\n    row: RivTable.FullRow<R>;\n    column: RivTable.FullColumn<C>;\n  }>;\n\n  @ContentChild('summary')\n  summaryTemplate?: TemplateRef<{\n    column: RivTable.FullColumn<C>;\n  }>;\n\n  @ContentChild('menu')\n  menuTemplate?: TemplateRef<{ row: RivTable.FullRow<R> }>;\n\n  @ContentChild('selection')\n  selectionTemplate?: TemplateRef<{ state: RivTable.FullState<R, C, F, G> }>;\n\n  @ContentChild('header')\n  headerTemplate?: TemplateRef<{ state: RivTable.FullState<R, C, F, G> }>;\n\n  @ContentChild('subheader')\n  subheaderTemplate?: TemplateRef<{\n    state: RivTable.FullState<R, C, F, G>;\n    group: RivTable.RowGroup<R, G>;\n  }>;\n\n  readonly destroy = new Subject();\n\n  readonly containerSize = new Subject<DOMRect>();\n  readonly selectionCalloutPosition: Observable<DOMRect> =\n    this.containerSize.pipe(\n      map(rect => new DOMRect(rect.x + 44, rect.y - 12, 0, 0)),\n    );\n\n  ngAfterViewInit() {\n    combineLatest([this.manager!.state, this.containerSize])\n      .pipe(takeUntil(this.destroy))\n      .subscribe(([state, containerSize]) => {\n        const containerWidth = containerSize.width;\n        const totalFrozenWidth = sum(\n          state.display.columns.filter(c => c.pinned).map(c => c.width),\n        );\n        if (totalFrozenWidth > containerWidth) {\n          // Check how many columns can be pinned without overflowing.\n          for (const [i] of state.display.columns\n            .filter(c => c.pinned)\n            .entries()) {\n            const slicedFrozenWidth = sum(\n              state.display.columns.slice(0, i + 1).map(c => c.width),\n            );\n            if (slicedFrozenWidth > containerWidth) {\n              this.manager?.actions.next({\n                type: 'columnsFreezeUpToChange',\n                index: i - 1,\n                freeze: i > 0,\n              });\n              break;\n            }\n          }\n        }\n      });\n\n    document.addEventListener('dragover', this.handleDragOver);\n  }\n\n  // We only care about when we have entered a drop zone for applying our visual\n  // treatment. However, in order to trigger the drop event, you must call preventDefault\n  // on the dragover. We are handling this natively on the document, outside of angular\n  // as a performance optimization. If we have a draggedOverColumnIdx and we drag over an\n  // element with class drop-zone, we will assume you want to the drop element enabled\n  // and we will preventDefault.\n  handleDragOver = (event: DragEvent) => {\n    const target = event.target as HTMLElement;\n    if (this.draggedOverColumnIdx != null && target.closest('.drop-zone')) {\n      event.preventDefault();\n    }\n  };\n\n  ngOnDestroy() {\n    document.removeEventListener('dragover', this.handleDragOver);\n    this.destroy.next(null);\n  }\n\n  readonly pageSizeOptions: RivSelect.OptionGroup<PageSizeOption>[] = [\n    {\n      options: RivTable.pageSizes.map(pageSize => ({\n        id: pageSize.toString(),\n        title: pageSize.toString(),\n        value: pageSize,\n      })),\n    },\n  ];\n\n  readonly trackByRow: TrackByFunction<RivTable.FullRow<R>> = (_, row) =>\n    row.id;\n  readonly trackByGroup: TrackByFunction<RivTable.RowGroup<R, G>> = (\n    _,\n    group,\n  ) => group.groupData.key;\n  readonly trackByColumn: TrackByFunction<RivTable.FullColumn<C>> = (\n    _,\n    column,\n  ) => column.key;\n\n  private readonly temporaryWidths: Map<C, number> = new Map();\n  setWidth(column: C, width: number | null): void {\n    if (width === null) {\n      const temporaryWidth = this.temporaryWidths.get(column);\n      if (temporaryWidth) {\n        this.manager?.actions.next({\n          type: 'columnWidthChange',\n          column,\n          preferredWidth: temporaryWidth,\n        });\n      }\n      this.temporaryWidths.delete(column);\n    } else {\n      this.temporaryWidths.set(column, width);\n    }\n  }\n  getWidth(column: RivTable.FullColumn<C>): number {\n    if (this.temporaryWidths.has(column.key)) {\n      return Math.max(this.temporaryWidths.get(column.key)!, column.minWidth);\n    } else {\n      return column.width;\n    }\n  }\n\n  draggedColumnIdx: number | null = null;\n  draggedColumnKey: C | null = null;\n  draggedOverColumnIdx: number | null = null;\n\n  dragStart(idx: number, key: C) {\n    this.draggedColumnIdx = idx;\n    this.draggedColumnKey = key;\n  }\n\n  dragOver(ontoIdx: number) {\n    this.draggedOverColumnIdx = ontoIdx;\n  }\n\n  drop(ontoIdx: number, enabledColumnCount: number) {\n    if (this.draggedColumnIdx !== null) {\n      this.manager?.actions.next({\n        type: 'columnOrderChange',\n        previousIndex: this.draggedColumnIdx,\n        newIndex: ontoIdx,\n        source: 'tableDrag',\n        column: this.draggedColumnKey || undefined,\n      });\n      const enabled = ontoIdx < enabledColumnCount;\n      this.dropEnabledState(enabled, enabledColumnCount);\n      this.draggedOverColumnIdx = null;\n      this.draggedColumnKey = null;\n    }\n  }\n\n  getEnabledCount(columns: RivTable.FullColumn<any>[]): number {\n    return columns.filter(c => c.pinned).length;\n  }\n\n  dropEnabledState(enabled: boolean, enabledColumnCount: number) {\n    if (this.draggedColumnKey !== null && this.draggedColumnIdx !== null) {\n      const isEnabled = enabledColumnCount > this.draggedColumnIdx;\n      const shouldFire = enabled ? !isEnabled : isEnabled;\n      if (shouldFire) {\n        this.manager?.actions.next({\n          type: 'columnEnabledChange',\n          column: this.draggedColumnKey,\n          enabled: enabled,\n          source: 'dragDrop',\n        });\n      }\n\n      this.draggedOverColumnIdx = null;\n      this.draggedColumnKey = null;\n    }\n  }\n\n  getErrorMessage(e: unknown): string {\n    if (e instanceof Error) return e.message;\n    if (typeof e === 'string') return e;\n    if (typeof e === 'object' && e !== null) return e.toString();\n    else return 'An error occurred.';\n  }\n\n  private shift: boolean = false;\n\n  @HostListener('document:keydown', ['$event'])\n  keyDown(event: KeyboardEvent) {\n    this.shift = event.shiftKey;\n  }\n\n  @HostListener('document:keyup', ['$event'])\n  keyUp(event: KeyboardEvent) {\n    this.shift = event.shiftKey;\n  }\n\n  selectionChange(rowId: R['id'], selected: boolean) {\n    this.manager?.actions.next({\n      type: 'rowSelectedChange',\n      id: rowId,\n      selected,\n      contiguous: this.shift,\n    });\n  }\n\n  handleClick(event: MouseEvent, column: RivTable.FullColumn<C>) {\n    if (column.clickPreventDefault) event.preventDefault();\n    if (column.clickStopPropagation) event.stopPropagation();\n  }\n\n  isExternalRowLink(\n    rowLink: RivTable.RowLink,\n  ): rowLink is RivTable.ExternalRowLink {\n    return rowLink.type === 'external';\n  }\n\n  isInternalRowLink(\n    rowLink: RivTable.RowLink,\n  ): rowLink is RivTable.InternalRowLink {\n    return rowLink.type === 'internal';\n  }\n\n  needsRightBorder<C extends RivTable.Column>(\n    s: RivTable.FullState<any, C, any, any>,\n    rowIndex: number,\n    column: RivTable.FullColumn<C>,\n  ): boolean {\n    // Need to check if the column to the right has a row span > 1 OR\n    // if the column to the right would have a row span of 0.\n    const cols = s.display.columns as RivTable.FullColumn<C>[];\n    const i = cols.findIndex(c => c.key === column.key);\n    if (i < 0 || i === cols.length - 1) return false;\n\n    const rightCol = cols[i + 1];\n    const spanOnRight = s.display.cellRowSpan(rowIndex, rightCol.key);\n    return spanOnRight > 1 || spanOnRight === 0;\n  }\n}\n","<ng-container *ngIf=\"manager?.state | async; let s\">\n  <ng-container *ngIf=\"selectionCalloutPosition | async; let position\">\n    <ng-container *ngIf=\"s.selection.selectedCount > 0 && selectionTemplate\">\n      <riv-callout\n        *riv-overlay\n        [anchor]=\"position\"\n        [isModal]=\"false\"\n        [theme]=\"'light'\"\n        [showCaret]=\"false\"\n        [preferredPosition]=\"'top-right'\"\n      >\n        <ng-container\n          *ngTemplateOutlet=\"selectionTemplate; context: { state: s }\"\n        ></ng-container>\n      </riv-callout>\n    </ng-container>\n  </ng-container>\n  <div class=\"loading-container\">\n    <header *ngIf=\"headerTemplate\">\n      <ng-container\n        *ngTemplateOutlet=\"headerTemplate; context: { state: s }\"\n      ></ng-container>\n    </header>\n    <riv-loading-cover\n      class=\"container-loader-wrapper\"\n      [loading]=\"s.load.loading\"\n      [errorMessage]=\"s.load.error ? getErrorMessage(s.load.error) : undefined\"\n    >\n      <div\n        class=\"container\"\n        [ngClass]=\"{\n          'container-ungrouped': !s.result.isGrouped,\n          'has-header': !s.result.isGrouped && headerTemplate,\n          'without-columns': s.display.columns.length === 0\n        }\"\n        (rivClientSize)=\"containerSize.next($event)\"\n      >\n        <riv-zero-state\n          *ngIf=\"s.display.columns.length === 0\"\n          class=\"no-columns-message\"\n          [message]=\"\n            'All columns disabled. Enable at least one column to view table data.'\n          \"\n        ></riv-zero-state>\n        <ng-container\n          *ngFor=\"\n            let group of s.result.isGrouped\n              ? s.result.rowGroups\n              : [s.result.rowsAsGroup];\n            trackBy: trackByGroup;\n            let last = last\n          \"\n        >\n          <ng-container\n            *ngTemplateOutlet=\"\n              subheaderTemplate || null;\n              context: { state: s, group }\n            \"\n          ></ng-container>\n          <div [ngClass]=\"{ 'subcontainer-grouped': s.result.isGrouped }\">\n            <table>\n              <thead>\n                <tr>\n                  <th\n                    *ngIf=\"!!s.selection.allowSelection\"\n                    class=\"selection-head\"\n                  >\n                    <div\n                      *ngIf=\"\n                        s.selection.allowSelection !== 'individual' &&\n                        s.selection.allowSelection === true\n                      \"\n                      class=\"checkbox-wrapper\"\n                    >\n                      <riv-checkbox\n                        *ngIf=\"!s.result.isGrouped\"\n                        [value]=\"s.selection.isAllSelected === true\"\n                        [indeterminate]=\"\n                          s.selection.isAllSelected === 'indeterminate'\n                        \"\n                        (valueChange)=\"\n                          manager?.actions?.next({ type: 'allSelectedChange' })\n                        \"\n                      ></riv-checkbox>\n                      <riv-checkbox\n                        *ngIf=\"s.result.isGrouped\"\n                        [value]=\"group.selected === true\"\n                        [indeterminate]=\"group.selected === 'indeterminate'\"\n                        (valueChange)=\"\n                          manager?.actions?.next({\n                            type: 'groupSelectionChange',\n                            payload: group\n                          })\n                        \"\n                      ></riv-checkbox>\n                    </div>\n                  </th>\n                  <th\n                    *ngFor=\"let column of s.display.columns; let i = index\"\n                    [class.pinned]=\"column.pinned\"\n                    [style.left.px]=\"column.left\"\n                    [style.width.px]=\"getWidth(column)\"\n                    draggable=\"true\"\n                    droppable=\"true\"\n                    class=\"drop-zone\"\n                    (dragstart)=\"dragStart(i, column.key)\"\n                    (dragenter)=\"$event.preventDefault(); dragOver(i)\"\n                    (drop)=\"drop(i, getEnabledCount(s.display.columns))\"\n                    [class.dragged-over-left]=\"\n                      draggedOverColumnIdx === i &&\n                      draggedColumnIdx !== null &&\n                      draggedColumnIdx > i\n                    \"\n                    [class.dragged-over-right]=\"\n                      draggedOverColumnIdx === i &&\n                      draggedColumnIdx !== null &&\n                      draggedColumnIdx < i\n                    \"\n                  >\n                    <div\n                      *ngIf=\"\n                        !column.orderable &&\n                        !column.filterable &&\n                        !s.display.columnsAreFreezable &&\n                        !s.display.columnsAreHideable\n                      \"\n                      class=\"header-wrapper\"\n                      [class.left]=\"column.alignment === 'left'\"\n                      [class.right]=\"column.alignment === 'right'\"\n                    >\n                      {{ s.display.columnNameMap.get(column.key) }}\n                    </div>\n                    <riv-menu\n                      *ngIf=\"\n                        column.orderable ||\n                        column.filterable ||\n                        s.display.columnsAreFreezable ||\n                        s.display.columnsAreHideable\n                      \"\n                    >\n                      <ng-template #trigger>\n                        <button\n                          type=\"button\"\n                          class=\"header-wrapper\"\n                          [class.left]=\"column.alignment === 'left'\"\n                          [class.right]=\"column.alignment === 'right'\"\n                          [class.active]=\"s.query.order?.column === column.key\"\n                        >\n                          {{ s.display.columnNameMap.get(column.key) }}\n                          <span class=\"icon-container\">\n                            <riv-icon\n                              [size]=\"12\"\n                              [name]=\"\n                                s.query.order?.direction === 'desc'\n                                  ? 'ArrowDown'\n                                  : 'ArrowUp'\n                              \"\n                            ></riv-icon>\n                          </span>\n                        </button>\n                        <riv-table-header-resize-handle\n                          (dragResize)=\"setWidth(column.key, $event)\"\n                        ></riv-table-header-resize-handle>\n                      </ng-template>\n                      <ng-container *ngIf=\"column.orderable\">\n                        <button\n                          *ngIf=\"\n                            !(\n                              s.query.order?.column === column.key &&\n                              s.query.order?.direction === 'asc'\n                            )\n                          \"\n                          riv-menu-item\n                          (click)=\"\n                            manager?.actions?.next({\n                              type: 'orderChange',\n                              source: 'headerMenu',\n                              payload: {\n                                direction: 'asc',\n                                column: column.key\n                              }\n                            })\n                          \"\n                        >\n                          Sort ascending\n                        </button>\n                        <button\n                          *ngIf=\"s.query.order?.column === column.key\"\n                          riv-menu-item\n                          (click)=\"\n                            manager?.actions?.next({\n                              type: 'orderChange',\n                              source: 'headerMenu',\n                              payload: null\n                            })\n                          \"\n                        >\n                          Remove sort\n                        </button>\n                        <button\n                          *ngIf=\"\n                            !(\n                              s.query.order?.column === column.key &&\n                              s.query.order?.direction === 'desc'\n                            )\n                          \"\n                          riv-menu-item\n                          (click)=\"\n                            manager?.actions?.next({\n                              type: 'orderChange',\n                              source: 'headerMenu',\n                              payload: {\n                                direction: 'desc',\n                                column: column.key\n                              }\n                            })\n                          \"\n                        >\n                          Sort descending\n                        </button>\n                      </ng-container>\n                      <riv-menu-divider\n                        *ngIf=\"column.orderable && column.filterable\"\n                      ></riv-menu-divider>\n                      <button\n                        *ngIf=\"column.filterable\"\n                        riv-menu-item\n                        (click)=\"\n                          this.manager?.actions?.next({\n                            type: 'filterAdd',\n                            columnKey: column.key\n                          })\n                        \"\n                      >\n                        Add a filter\n                      </button>\n                      <riv-menu-divider\n                        *ngIf=\"\n                          (column.orderable || column.filterable) &&\n                          (s.display.columnsAreFreezable ||\n                            s.display.columnsAreHideable)\n                        \"\n                      ></riv-menu-divider>\n                      <ng-container *ngIf=\"s.display.columnsAreFreezable\">\n                        <button\n                          *ngIf=\"!column.pinned\"\n                          riv-menu-item\n                          (click)=\"\n                            this.manager?.actions?.next({\n                              type: 'columnsFreezeUpToChange',\n                              freeze: true,\n                              index: i,\n                              source: 'headerMenu',\n                              column: column.key\n                            })\n                          \"\n                        >\n                          Freeze up to column\n                        </button>\n                        <button\n                          *ngIf=\"column.pinned\"\n                          riv-menu-item\n                          (click)=\"\n                            this.manager?.actions?.next({\n                              type: 'columnsFreezeUpToChange',\n                              freeze: false,\n                              index: 0,\n                              source: 'headerMenu',\n                              column: column.key\n                            })\n                          \"\n                        >\n                          Un-freeze columns\n                        </button>\n                      </ng-container>\n                      <button\n                        *ngIf=\"s.display.columnsAreHideable\"\n                        riv-menu-item\n                        (click)=\"\n                          this.manager?.actions?.next({\n                            type: 'columnEnabledChange',\n                            column: column.key,\n                            enabled: false,\n                            source: 'headerMenu'\n                          })\n                        \"\n                      >\n                        Hide column\n                      </button>\n                    </riv-menu>\n                  </th>\n                  <th *ngIf=\"menuTemplate\" class=\"menu-head\"></th>\n                </tr>\n              </thead>\n              <tbody>\n                <ng-container\n                  *ngIf=\"s.result.totalMatchingRowCount > 0; else empty\"\n                >\n                  <ng-container\n                    *ngFor=\"\n                      let row of group.rows;\n                      let rowIndex = index;\n                      trackBy: trackByRow\n                    \"\n                  >\n                    <ng-template #rowBody>\n                      <td\n                        *ngIf=\"\n                          s.selection.allowSelection === true ||\n                          s.selection.allowSelection === 'individual'\n                        \"\n                        class=\"selection-body\"\n                        (click)=\"$event.preventDefault()\"\n                      >\n                        <label\n                          class=\"checkbox-wrapper\"\n                          (click)=\"$event.stopPropagation()\"\n                        >\n                          <riv-checkbox\n                            [identifier]=\"'riv-table-selection-' + row.id\"\n                            [value]=\"row.selected\"\n                            (valueChange)=\"selectionChange(row.id, $event)\"\n                          ></riv-checkbox>\n                        </label>\n                      </td>\n                      <ng-container\n                        *ngFor=\"\n                          let column of s.display.columns;\n                          trackBy: trackByColumn\n                        \"\n                      >\n                        <ng-container\n                          *ngIf=\"\n                            s.display.cellRowSpan(rowIndex, column.key) as span\n                          \"\n                        >\n                          <td\n                            *ngIf=\"span > 0\"\n                            [attr.rowspan]=\"span\"\n                            [class.rs-right-border]=\"\n                              needsRightBorder(s, rowIndex, column)\n                            \"\n                            [class.pinned]=\"column.pinned\"\n                            [class.advanced]=\"column.dataType === 'advanced'\"\n                            [style.left.px]=\"column.left\"\n                            [style.text-align]=\"column.alignment\"\n                            (click)=\"handleClick($event, column)\"\n                          >\n                            <ng-container\n                              *ngTemplateOutlet=\"\n                                cellTemplate || null;\n                                context: { row: row, column: column }\n                              \"\n                            ></ng-container>\n                          </td>\n                        </ng-container>\n                      </ng-container>\n                      <td\n                        *ngIf=\"menuTemplate\"\n                        class=\"menu-body\"\n                        (click)=\"\n                          $event.stopPropagation(); $event.preventDefault()\n                        \"\n                      >\n                        <ng-container\n                          *ngTemplateOutlet=\"\n                            menuTemplate || null;\n                            context: { row: row }\n                          \"\n                        ></ng-container>\n                      </td>\n                    </ng-template>\n                    <ng-container *ngIf=\"row.rowLink; let rl\">\n                      <a\n                        *ngIf=\"isExternalRowLink(rl)\"\n                        [href]=\"rl.href\"\n                        class=\"row-link\"\n                        [class.grayed]=\"s.display.rowsAreGrayed\"\n                      >\n                        <ng-container\n                          *ngTemplateOutlet=\"rowBody\"\n                        ></ng-container>\n                      </a>\n                      <a\n                        *ngIf=\"isInternalRowLink(rl)\"\n                        [routerLink]=\"rl.routerLink\"\n                        [queryParams]=\"rl.queryParams\"\n                        [queryParamsHandling]=\"rl.queryParamsHandling\"\n                        class=\"row-link\"\n                        [class.grayed]=\"s.display.rowsAreGrayed\"\n                        [class.active]=\"rl.active\"\n                      >\n                        <ng-container\n                          *ngTemplateOutlet=\"rowBody\"\n                        ></ng-container>\n                      </a>\n                    </ng-container>\n                    <tr\n                      *ngIf=\"!row.rowLink\"\n                      [class.grayed]=\"s.display.rowsAreGrayed\"\n                    >\n                      <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n                    </tr>\n                  </ng-container>\n                  <tr *ngIf=\"s.display.customSummaryRow\">\n                    <td\n                      *ngFor=\"\n                        let column of s.display.columns;\n                        trackBy: trackByColumn\n                      \"\n                      [class.pinned]=\"column.pinned\"\n                      [class.advanced]=\"column.dataType === 'advanced'\"\n                      [style.left.px]=\"column.left\"\n                      [style.text-align]=\"column.alignment\"\n                    >\n                      <ng-container\n                        *ngTemplateOutlet=\"\n                          summaryTemplate || null;\n                          context: { column: column }\n                        \"\n                      ></ng-container>\n                    </td>\n                  </tr>\n                </ng-container>\n                <ng-template #empty>\n                  <tr>\n                    <td [attr.colspan]=\"s.display.columns.length\">\n                      <riv-zero-state\n                        *ngIf=\"s.display.zeroStateMessage; let message\"\n                        [message]=\"message\"\n                      ></riv-zero-state>\n                    </td>\n                  </tr>\n                </ng-template>\n              </tbody>\n            </table>\n          </div>\n          <div\n            class=\"footer\"\n            *ngIf=\"\n              s.result.isGrouped &&\n              group.totalMatchingRowCount > s.query.grouping.countPerGroup &&\n              group.rows.length === s.query.grouping.countPerGroup\n            \"\n          >\n            <span\n              rivLink\n              class=\"footer-link\"\n              (click)=\"\n                manager?.actions?.next({\n                  type: 'viewMoreKeyChange',\n                  viewMoreKey: group.groupData.key.toString()\n                })\n              \"\n              >View all {{ group.totalMatchingRowCount }}</span\n            >\n          </div>\n          <br *ngIf=\"!last\" />\n        </ng-container>\n      </div>\n      <div *ngIf=\"s.query.pagination.showControls\" class=\"pagination\">\n        <div class=\"page-size-controls\">\n          <ng-container *ngIf=\"!s.result.isGrouped\">\n            <span> Results per page: </span>\n            <riv-simple-select\n              [selectedOption]=\"{\n                id: s.query.pagination.pageSize.toString(),\n                title: s.query.pagination.pageSize.toString(),\n                value: s.query.pagination.pageSize\n              }\"\n              (selectedOptionChange)=\"\n                manager?.actions?.next({\n                  type: 'pageSizeChange',\n                  size: $event?.value || 25\n                })\n              \"\n              [optionGroups]=\"pageSizeOptions\"\n              [size]=\"'small'\"\n            ></riv-simple-select>\n          </ng-container>\n        </div>\n        <span\n          *ngIf=\"s.result.totalMatchingRowCount > 0 && !s.result.isGrouped\"\n          class=\"page-data-indicator\"\n        >\n          {{ s.query.pagination.pageRowStart | rivNumber }}-{{\n            s.query.pagination.pageRowEnd | rivNumber\n          }}\n          of\n          {{ s.result.totalMatchingRowCount | rivNumber }}\n        </span>\n        <div\n          *ngIf=\"s.query.pagination.showControls\"\n          class=\"pagination-controls\"\n        >\n          <button\n            rivButton\n            [variant]=\"'basic'\"\n            [size]=\"'small'\"\n            [icon]=\"'ArrowLeft'\"\n            type=\"button\"\n            [disabled]=\"s.query.pagination.previous === null\"\n            (click)=\"manager?.actions?.next({ type: 'previousPageNavigate' })\"\n          ></button>\n          <span\n            *ngIf=\"s.query.pagination.pages[0] > 0\"\n            class=\"truncated-pages left\"\n          >\n            &hellip;\n          </span>\n          <button\n            *ngFor=\"let page of s.query.pagination.pages\"\n            class=\"page\"\n            type=\"button\"\n            [disabled]=\"page === s.query.pagination.page\"\n            (click)=\"manager?.actions?.next({ type: 'pageChange', page })\"\n          >\n            {{ page + 1 }}\n          </button>\n          <span\n            *ngIf=\"\n              s.query.pagination.pages[s.query.pagination.pages.length - 1] <\n              s.query.pagination.pageCount - 1\n            \"\n            class=\"truncated-pages right\"\n          >\n            &hellip;\n          </span>\n          <button\n            rivButton\n            [variant]=\"'basic'\"\n            [size]=\"'small'\"\n            [icon]=\"'ArrowRight'\"\n            type=\"button\"\n            [disabled]=\"s.query.pagination.next === null\"\n            (click)=\"manager?.actions?.next({ type: 'nextPageNavigate' })\"\n          ></button>\n        </div>\n      </div>\n    </riv-loading-cover>\n  </div>\n</ng-container>\n"]}
|
|
232
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/riv/src/lib/table/table/table/table.component.ts","../../../../../../../projects/riv/src/lib/table/table/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  HostListener,\n  Input,\n  OnDestroy,\n  TemplateRef,\n  TrackByFunction,\n} from '@angular/core';\nimport { sum } from 'lodash';\nimport { combineLatest, map, Observable, Subject, takeUntil } from 'rxjs';\nimport { RivSelect } from '../../../input/select/state';\nimport { RivTable } from '../state';\n\ntype PageSizeOption = {\n  id: string;\n  title: string;\n  value: number;\n};\n\n@Component({\n  selector: 'riv-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TableComponent<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n  G extends RivTable.Group = { key: '' },\n> implements AfterViewInit, OnDestroy\n{\n  @Input()\n  manager?: RivTable.Manager<R, C, F, G>;\n\n  @ContentChild('cell')\n  cellTemplate?: TemplateRef<{\n    row: RivTable.FullRow<R>;\n    column: RivTable.FullColumn<C>;\n  }>;\n\n  @ContentChild('summary')\n  summaryTemplate?: TemplateRef<{\n    column: RivTable.FullColumn<C>;\n  }>;\n\n  @ContentChild('menu')\n  menuTemplate?: TemplateRef<{ row: RivTable.FullRow<R> }>;\n\n  @ContentChild('selection')\n  selectionTemplate?: TemplateRef<{ state: RivTable.FullState<R, C, F, G> }>;\n\n  @ContentChild('header')\n  headerTemplate?: TemplateRef<{ state: RivTable.FullState<R, C, F, G> }>;\n\n  @ContentChild('subheader')\n  subheaderTemplate?: TemplateRef<{\n    state: RivTable.FullState<R, C, F, G>;\n    group: RivTable.RowGroup<R, G>;\n  }>;\n\n  readonly destroy = new Subject();\n\n  readonly containerSize = new Subject<DOMRect>();\n  readonly selectionCalloutPosition: Observable<DOMRect> =\n    this.containerSize.pipe(\n      map(rect => new DOMRect(rect.x + 44, rect.y - 12, 0, 0)),\n    );\n\n  ngAfterViewInit() {\n    combineLatest([this.manager!.state, this.containerSize])\n      .pipe(takeUntil(this.destroy))\n      .subscribe(([state, containerSize]) => {\n        const containerWidth = containerSize.width;\n        const totalFrozenWidth = sum(\n          state.display.columns.filter(c => c.pinned).map(c => c.width),\n        );\n        if (totalFrozenWidth > containerWidth) {\n          // Check how many columns can be pinned without overflowing.\n          for (const [i] of state.display.columns\n            .filter(c => c.pinned)\n            .entries()) {\n            const slicedFrozenWidth = sum(\n              state.display.columns.slice(0, i + 1).map(c => c.width),\n            );\n            if (slicedFrozenWidth > containerWidth) {\n              this.manager?.actions.next({\n                type: 'columnsFreezeUpToChange',\n                index: i - 1,\n                freeze: i > 0,\n              });\n              break;\n            }\n          }\n        }\n      });\n\n    document.addEventListener('dragover', this.handleDragOver);\n  }\n\n  // We only care about when we have entered a drop zone for applying our visual\n  // treatment. However, in order to trigger the drop event, you must call preventDefault\n  // on the dragover. We are handling this natively on the document, outside of angular\n  // as a performance optimization. If we have a draggedOverColumnIdx and we drag over an\n  // element with class drop-zone, we will assume you want to the drop element enabled\n  // and we will preventDefault.\n  handleDragOver = (event: DragEvent) => {\n    const target = event.target as HTMLElement;\n    if (this.draggedOverColumnIdx != null && target.closest('.drop-zone')) {\n      event.preventDefault();\n    }\n  };\n\n  ngOnDestroy() {\n    document.removeEventListener('dragover', this.handleDragOver);\n    this.destroy.next(null);\n  }\n\n  readonly pageSizeOptions: RivSelect.OptionGroup<PageSizeOption>[] = [\n    {\n      options: RivTable.pageSizes.map(pageSize => ({\n        id: pageSize.toString(),\n        title: pageSize.toString(),\n        value: pageSize,\n      })),\n    },\n  ];\n\n  readonly trackByRow: TrackByFunction<RivTable.FullRow<R>> = (_, row) =>\n    row.id;\n  readonly trackByGroup: TrackByFunction<RivTable.RowGroup<R, G>> = (\n    _,\n    group,\n  ) => group.groupData.key;\n  readonly trackByColumn: TrackByFunction<RivTable.FullColumn<C>> = (\n    _,\n    column,\n  ) => column.key;\n\n  private readonly temporaryWidths: Map<C, number> = new Map();\n  setWidth(column: C, width: number | null): void {\n    if (width === null) {\n      const temporaryWidth = this.temporaryWidths.get(column);\n      if (temporaryWidth) {\n        this.manager?.actions.next({\n          type: 'columnWidthChange',\n          column,\n          preferredWidth: temporaryWidth,\n        });\n      }\n      this.temporaryWidths.delete(column);\n    } else {\n      this.temporaryWidths.set(column, width);\n    }\n  }\n  getWidth(column: RivTable.FullColumn<C>): number {\n    if (this.temporaryWidths.has(column.key)) {\n      return Math.max(this.temporaryWidths.get(column.key)!, column.minWidth);\n    } else {\n      return column.width;\n    }\n  }\n\n  draggedColumnIdx: number | null = null;\n  draggedColumnKey: C | null = null;\n  draggedOverColumnIdx: number | null = null;\n\n  dragStart(idx: number, key: C) {\n    this.draggedColumnIdx = idx;\n    this.draggedColumnKey = key;\n  }\n\n  dragOver(ontoIdx: number) {\n    this.draggedOverColumnIdx = ontoIdx;\n  }\n\n  drop(ontoIdx: number, enabledColumnCount: number) {\n    if (this.draggedColumnIdx !== null) {\n      this.manager?.actions.next({\n        type: 'columnOrderChange',\n        previousIndex: this.draggedColumnIdx,\n        newIndex: ontoIdx,\n        source: 'tableDrag',\n        column: this.draggedColumnKey || undefined,\n      });\n      const enabled = ontoIdx < enabledColumnCount;\n      this.dropEnabledState(enabled, enabledColumnCount);\n      this.draggedOverColumnIdx = null;\n      this.draggedColumnKey = null;\n    }\n  }\n\n  getEnabledCount(columns: RivTable.FullColumn<any>[]): number {\n    return columns.filter(c => c.enabled).length;\n  }\n\n  dropEnabledState(enabled: boolean, enabledColumnCount: number) {\n    if (this.draggedColumnKey !== null && this.draggedColumnIdx !== null) {\n      const isEnabled = enabledColumnCount > this.draggedColumnIdx;\n      const shouldFire = enabled ? !isEnabled : isEnabled;\n      if (shouldFire) {\n        this.manager?.actions.next({\n          type: 'columnEnabledChange',\n          column: this.draggedColumnKey,\n          enabled: enabled,\n          source: 'dragDrop',\n        });\n      }\n\n      this.draggedOverColumnIdx = null;\n      this.draggedColumnKey = null;\n    }\n  }\n\n  getErrorMessage(e: unknown): string {\n    if (e instanceof Error) return e.message;\n    if (typeof e === 'string') return e;\n    if (typeof e === 'object' && e !== null) return e.toString();\n    else return 'An error occurred.';\n  }\n\n  private shift: boolean = false;\n\n  @HostListener('document:keydown', ['$event'])\n  keyDown(event: KeyboardEvent) {\n    this.shift = event.shiftKey;\n  }\n\n  @HostListener('document:keyup', ['$event'])\n  keyUp(event: KeyboardEvent) {\n    this.shift = event.shiftKey;\n  }\n\n  selectionChange(rowId: R['id'], selected: boolean) {\n    this.manager?.actions.next({\n      type: 'rowSelectedChange',\n      id: rowId,\n      selected,\n      contiguous: this.shift,\n    });\n  }\n\n  handleClick(event: MouseEvent, column: RivTable.FullColumn<C>) {\n    if (column.clickPreventDefault) event.preventDefault();\n    if (column.clickStopPropagation) event.stopPropagation();\n  }\n\n  isExternalRowLink(\n    rowLink: RivTable.RowLink,\n  ): rowLink is RivTable.ExternalRowLink {\n    return rowLink.type === 'external';\n  }\n\n  isInternalRowLink(\n    rowLink: RivTable.RowLink,\n  ): rowLink is RivTable.InternalRowLink {\n    return rowLink.type === 'internal';\n  }\n\n  needsRightBorder<C extends RivTable.Column>(\n    s: RivTable.FullState<any, C, any, any>,\n    rowIndex: number,\n    column: RivTable.FullColumn<C>,\n  ): boolean {\n    // Need to check if the column to the right has a row span > 1 OR\n    // if the column to the right would have a row span of 0.\n    const cols = s.display.columns as RivTable.FullColumn<C>[];\n    const i = cols.findIndex(c => c.key === column.key);\n    if (i < 0 || i === cols.length - 1) return false;\n\n    const rightCol = cols[i + 1];\n    const spanOnRight = s.display.cellRowSpan(rowIndex, rightCol.key);\n    return spanOnRight > 1 || spanOnRight === 0;\n  }\n}\n","<ng-container *ngIf=\"manager?.state | async; let s\">\n  <ng-container *ngIf=\"selectionCalloutPosition | async; let position\">\n    <ng-container *ngIf=\"s.selection.selectedCount > 0 && selectionTemplate\">\n      <riv-callout\n        *riv-overlay\n        [anchor]=\"position\"\n        [isModal]=\"false\"\n        [theme]=\"'light'\"\n        [showCaret]=\"false\"\n        [preferredPosition]=\"'top-right'\"\n      >\n        <ng-container\n          *ngTemplateOutlet=\"selectionTemplate; context: { state: s }\"\n        ></ng-container>\n      </riv-callout>\n    </ng-container>\n  </ng-container>\n  <div class=\"loading-container\">\n    <header *ngIf=\"headerTemplate\">\n      <ng-container\n        *ngTemplateOutlet=\"headerTemplate; context: { state: s }\"\n      ></ng-container>\n    </header>\n    <riv-loading-cover\n      class=\"container-loader-wrapper\"\n      [loading]=\"s.load.loading\"\n      [errorMessage]=\"s.load.error ? getErrorMessage(s.load.error) : undefined\"\n    >\n      <div\n        class=\"container\"\n        [ngClass]=\"{\n          'container-ungrouped': !s.result.isGrouped,\n          'has-header': !s.result.isGrouped && headerTemplate,\n          'without-columns': s.display.columns.length === 0\n        }\"\n        (rivClientSize)=\"containerSize.next($event)\"\n      >\n        <riv-zero-state\n          *ngIf=\"s.display.columns.length === 0\"\n          class=\"no-columns-message\"\n          [message]=\"\n            'All columns disabled. Enable at least one column to view table data.'\n          \"\n        ></riv-zero-state>\n        <ng-container\n          *ngFor=\"\n            let group of s.result.isGrouped\n              ? s.result.rowGroups\n              : [s.result.rowsAsGroup];\n            trackBy: trackByGroup;\n            let last = last\n          \"\n        >\n          <ng-container\n            *ngTemplateOutlet=\"\n              subheaderTemplate || null;\n              context: { state: s, group }\n            \"\n          ></ng-container>\n          <div [ngClass]=\"{ 'subcontainer-grouped': s.result.isGrouped }\">\n            <table>\n              <thead>\n                <tr>\n                  <th\n                    *ngIf=\"!!s.selection.allowSelection\"\n                    class=\"selection-head\"\n                  >\n                    <div\n                      *ngIf=\"\n                        s.selection.allowSelection !== 'individual' &&\n                        s.selection.allowSelection === true\n                      \"\n                      class=\"checkbox-wrapper\"\n                    >\n                      <riv-checkbox\n                        *ngIf=\"!s.result.isGrouped\"\n                        [value]=\"s.selection.isAllSelected === true\"\n                        [indeterminate]=\"\n                          s.selection.isAllSelected === 'indeterminate'\n                        \"\n                        (valueChange)=\"\n                          manager?.actions?.next({ type: 'allSelectedChange' })\n                        \"\n                      ></riv-checkbox>\n                      <riv-checkbox\n                        *ngIf=\"s.result.isGrouped\"\n                        [value]=\"group.selected === true\"\n                        [indeterminate]=\"group.selected === 'indeterminate'\"\n                        (valueChange)=\"\n                          manager?.actions?.next({\n                            type: 'groupSelectionChange',\n                            payload: group\n                          })\n                        \"\n                      ></riv-checkbox>\n                    </div>\n                  </th>\n                  <th\n                    *ngFor=\"let column of s.display.columns; let i = index\"\n                    [class.pinned]=\"column.pinned\"\n                    [style.left.px]=\"column.left\"\n                    [style.width.px]=\"getWidth(column)\"\n                    draggable=\"true\"\n                    droppable=\"true\"\n                    class=\"drop-zone\"\n                    (dragstart)=\"dragStart(i, column.key)\"\n                    (dragenter)=\"$event.preventDefault(); dragOver(i)\"\n                    (drop)=\"drop(i, getEnabledCount(s.display.columns))\"\n                    [class.dragged-over-left]=\"\n                      draggedOverColumnIdx === i &&\n                      draggedColumnIdx !== null &&\n                      draggedColumnIdx > i\n                    \"\n                    [class.dragged-over-right]=\"\n                      draggedOverColumnIdx === i &&\n                      draggedColumnIdx !== null &&\n                      draggedColumnIdx < i\n                    \"\n                  >\n                    <div\n                      *ngIf=\"\n                        !column.orderable &&\n                        !column.filterable &&\n                        !s.display.columnsAreFreezable &&\n                        !s.display.columnsAreHideable\n                      \"\n                      class=\"header-wrapper\"\n                      [class.left]=\"column.alignment === 'left'\"\n                      [class.right]=\"column.alignment === 'right'\"\n                    >\n                      {{ s.display.columnNameMap.get(column.key) }}\n                    </div>\n                    <riv-menu\n                      *ngIf=\"\n                        column.orderable ||\n                        column.filterable ||\n                        s.display.columnsAreFreezable ||\n                        s.display.columnsAreHideable\n                      \"\n                    >\n                      <ng-template #trigger>\n                        <button\n                          type=\"button\"\n                          class=\"header-wrapper\"\n                          [class.left]=\"column.alignment === 'left'\"\n                          [class.right]=\"column.alignment === 'right'\"\n                          [class.active]=\"s.query.order?.column === column.key\"\n                        >\n                          {{ s.display.columnNameMap.get(column.key) }}\n                          <span class=\"icon-container\">\n                            <riv-icon\n                              [size]=\"12\"\n                              [name]=\"\n                                s.query.order?.direction === 'desc'\n                                  ? 'ArrowDown'\n                                  : 'ArrowUp'\n                              \"\n                            ></riv-icon>\n                          </span>\n                        </button>\n                        <riv-table-header-resize-handle\n                          (dragResize)=\"setWidth(column.key, $event)\"\n                        ></riv-table-header-resize-handle>\n                      </ng-template>\n                      <ng-container *ngIf=\"column.orderable\">\n                        <button\n                          *ngIf=\"\n                            !(\n                              s.query.order?.column === column.key &&\n                              s.query.order?.direction === 'asc'\n                            )\n                          \"\n                          riv-menu-item\n                          (click)=\"\n                            manager?.actions?.next({\n                              type: 'orderChange',\n                              source: 'headerMenu',\n                              payload: {\n                                direction: 'asc',\n                                column: column.key\n                              }\n                            })\n                          \"\n                        >\n                          Sort ascending\n                        </button>\n                        <button\n                          *ngIf=\"s.query.order?.column === column.key\"\n                          riv-menu-item\n                          (click)=\"\n                            manager?.actions?.next({\n                              type: 'orderChange',\n                              source: 'headerMenu',\n                              payload: null\n                            })\n                          \"\n                        >\n                          Remove sort\n                        </button>\n                        <button\n                          *ngIf=\"\n                            !(\n                              s.query.order?.column === column.key &&\n                              s.query.order?.direction === 'desc'\n                            )\n                          \"\n                          riv-menu-item\n                          (click)=\"\n                            manager?.actions?.next({\n                              type: 'orderChange',\n                              source: 'headerMenu',\n                              payload: {\n                                direction: 'desc',\n                                column: column.key\n                              }\n                            })\n                          \"\n                        >\n                          Sort descending\n                        </button>\n                      </ng-container>\n                      <riv-menu-divider\n                        *ngIf=\"column.orderable && column.filterable\"\n                      ></riv-menu-divider>\n                      <button\n                        *ngIf=\"column.filterable\"\n                        riv-menu-item\n                        (click)=\"\n                          this.manager?.actions?.next({\n                            type: 'filterAdd',\n                            columnKey: column.key\n                          })\n                        \"\n                      >\n                        Add a filter\n                      </button>\n                      <riv-menu-divider\n                        *ngIf=\"\n                          (column.orderable || column.filterable) &&\n                          (s.display.columnsAreFreezable ||\n                            s.display.columnsAreHideable)\n                        \"\n                      ></riv-menu-divider>\n                      <ng-container *ngIf=\"s.display.columnsAreFreezable\">\n                        <button\n                          *ngIf=\"!column.pinned\"\n                          riv-menu-item\n                          (click)=\"\n                            this.manager?.actions?.next({\n                              type: 'columnsFreezeUpToChange',\n                              freeze: true,\n                              index: i,\n                              source: 'headerMenu',\n                              column: column.key\n                            })\n                          \"\n                        >\n                          Freeze up to column\n                        </button>\n                        <button\n                          *ngIf=\"column.pinned\"\n                          riv-menu-item\n                          (click)=\"\n                            this.manager?.actions?.next({\n                              type: 'columnsFreezeUpToChange',\n                              freeze: false,\n                              index: 0,\n                              source: 'headerMenu',\n                              column: column.key\n                            })\n                          \"\n                        >\n                          Un-freeze columns\n                        </button>\n                      </ng-container>\n                      <button\n                        *ngIf=\"s.display.columnsAreHideable\"\n                        riv-menu-item\n                        (click)=\"\n                          this.manager?.actions?.next({\n                            type: 'columnEnabledChange',\n                            column: column.key,\n                            enabled: false,\n                            source: 'headerMenu'\n                          })\n                        \"\n                      >\n                        Hide column\n                      </button>\n                    </riv-menu>\n                  </th>\n                  <th *ngIf=\"menuTemplate\" class=\"menu-head\"></th>\n                </tr>\n              </thead>\n              <tbody>\n                <ng-container\n                  *ngIf=\"s.result.totalMatchingRowCount > 0; else empty\"\n                >\n                  <ng-container\n                    *ngFor=\"\n                      let row of group.rows;\n                      let rowIndex = index;\n                      trackBy: trackByRow\n                    \"\n                  >\n                    <ng-template #rowBody>\n                      <td\n                        *ngIf=\"\n                          s.selection.allowSelection === true ||\n                          s.selection.allowSelection === 'individual'\n                        \"\n                        class=\"selection-body\"\n                        (click)=\"$event.preventDefault()\"\n                      >\n                        <label\n                          class=\"checkbox-wrapper\"\n                          (click)=\"$event.stopPropagation()\"\n                        >\n                          <riv-checkbox\n                            [identifier]=\"'riv-table-selection-' + row.id\"\n                            [value]=\"row.selected\"\n                            (valueChange)=\"selectionChange(row.id, $event)\"\n                          ></riv-checkbox>\n                        </label>\n                      </td>\n                      <ng-container\n                        *ngFor=\"\n                          let column of s.display.columns;\n                          trackBy: trackByColumn\n                        \"\n                      >\n                        <ng-container\n                          *ngIf=\"\n                            s.display.cellRowSpan(rowIndex, column.key) as span\n                          \"\n                        >\n                          <td\n                            *ngIf=\"span > 0\"\n                            [attr.rowspan]=\"span\"\n                            [class.rs-right-border]=\"\n                              needsRightBorder(s, rowIndex, column)\n                            \"\n                            [class.pinned]=\"column.pinned\"\n                            [class.advanced]=\"column.dataType === 'advanced'\"\n                            [style.left.px]=\"column.left\"\n                            [style.text-align]=\"column.alignment\"\n                            (click)=\"handleClick($event, column)\"\n                          >\n                            <ng-container\n                              *ngTemplateOutlet=\"\n                                cellTemplate || null;\n                                context: { row: row, column: column }\n                              \"\n                            ></ng-container>\n                          </td>\n                        </ng-container>\n                      </ng-container>\n                      <td\n                        *ngIf=\"menuTemplate\"\n                        class=\"menu-body\"\n                        (click)=\"\n                          $event.stopPropagation(); $event.preventDefault()\n                        \"\n                      >\n                        <ng-container\n                          *ngTemplateOutlet=\"\n                            menuTemplate || null;\n                            context: { row: row }\n                          \"\n                        ></ng-container>\n                      </td>\n                    </ng-template>\n                    <ng-container *ngIf=\"row.rowLink; let rl\">\n                      <a\n                        *ngIf=\"isExternalRowLink(rl)\"\n                        [href]=\"rl.href\"\n                        class=\"row-link\"\n                        [class.grayed]=\"s.display.rowsAreGrayed\"\n                      >\n                        <ng-container\n                          *ngTemplateOutlet=\"rowBody\"\n                        ></ng-container>\n                      </a>\n                      <a\n                        *ngIf=\"isInternalRowLink(rl)\"\n                        [routerLink]=\"rl.routerLink\"\n                        [queryParams]=\"rl.queryParams\"\n                        [queryParamsHandling]=\"rl.queryParamsHandling\"\n                        class=\"row-link\"\n                        [class.grayed]=\"s.display.rowsAreGrayed\"\n                        [class.active]=\"rl.active\"\n                      >\n                        <ng-container\n                          *ngTemplateOutlet=\"rowBody\"\n                        ></ng-container>\n                      </a>\n                    </ng-container>\n                    <tr\n                      *ngIf=\"!row.rowLink\"\n                      [class.grayed]=\"s.display.rowsAreGrayed\"\n                    >\n                      <ng-container *ngTemplateOutlet=\"rowBody\"></ng-container>\n                    </tr>\n                  </ng-container>\n                  <tr *ngIf=\"s.display.customSummaryRow\">\n                    <td\n                      *ngFor=\"\n                        let column of s.display.columns;\n                        trackBy: trackByColumn\n                      \"\n                      [class.pinned]=\"column.pinned\"\n                      [class.advanced]=\"column.dataType === 'advanced'\"\n                      [style.left.px]=\"column.left\"\n                      [style.text-align]=\"column.alignment\"\n                    >\n                      <ng-container\n                        *ngTemplateOutlet=\"\n                          summaryTemplate || null;\n                          context: { column: column }\n                        \"\n                      ></ng-container>\n                    </td>\n                  </tr>\n                </ng-container>\n                <ng-template #empty>\n                  <tr>\n                    <td [attr.colspan]=\"s.display.columns.length\">\n                      <riv-zero-state\n                        *ngIf=\"s.display.zeroStateMessage; let message\"\n                        [message]=\"message\"\n                      ></riv-zero-state>\n                    </td>\n                  </tr>\n                </ng-template>\n              </tbody>\n            </table>\n          </div>\n          <div\n            class=\"footer\"\n            *ngIf=\"\n              s.result.isGrouped &&\n              group.totalMatchingRowCount > s.query.grouping.countPerGroup &&\n              group.rows.length === s.query.grouping.countPerGroup\n            \"\n          >\n            <span\n              rivLink\n              class=\"footer-link\"\n              (click)=\"\n                manager?.actions?.next({\n                  type: 'viewMoreKeyChange',\n                  viewMoreKey: group.groupData.key.toString()\n                })\n              \"\n              >View all {{ group.totalMatchingRowCount }}</span\n            >\n          </div>\n          <br *ngIf=\"!last\" />\n        </ng-container>\n      </div>\n      <div *ngIf=\"s.query.pagination.showControls\" class=\"pagination\">\n        <div class=\"page-size-controls\">\n          <ng-container *ngIf=\"!s.result.isGrouped\">\n            <span> Results per page: </span>\n            <riv-simple-select\n              [selectedOption]=\"{\n                id: s.query.pagination.pageSize.toString(),\n                title: s.query.pagination.pageSize.toString(),\n                value: s.query.pagination.pageSize\n              }\"\n              (selectedOptionChange)=\"\n                manager?.actions?.next({\n                  type: 'pageSizeChange',\n                  size: $event?.value || 25\n                })\n              \"\n              [optionGroups]=\"pageSizeOptions\"\n              [size]=\"'small'\"\n            ></riv-simple-select>\n          </ng-container>\n        </div>\n        <span\n          *ngIf=\"s.result.totalMatchingRowCount > 0 && !s.result.isGrouped\"\n          class=\"page-data-indicator\"\n        >\n          {{ s.query.pagination.pageRowStart | rivNumber }}-{{\n            s.query.pagination.pageRowEnd | rivNumber\n          }}\n          of\n          {{ s.result.totalMatchingRowCount | rivNumber }}\n        </span>\n        <div\n          *ngIf=\"s.query.pagination.showControls\"\n          class=\"pagination-controls\"\n        >\n          <button\n            rivButton\n            [variant]=\"'basic'\"\n            [size]=\"'small'\"\n            [icon]=\"'ArrowLeft'\"\n            type=\"button\"\n            [disabled]=\"s.query.pagination.previous === null\"\n            (click)=\"manager?.actions?.next({ type: 'previousPageNavigate' })\"\n          ></button>\n          <span\n            *ngIf=\"s.query.pagination.pages[0] > 0\"\n            class=\"truncated-pages left\"\n          >\n            &hellip;\n          </span>\n          <button\n            *ngFor=\"let page of s.query.pagination.pages\"\n            class=\"page\"\n            type=\"button\"\n            [disabled]=\"page === s.query.pagination.page\"\n            (click)=\"manager?.actions?.next({ type: 'pageChange', page })\"\n          >\n            {{ page + 1 }}\n          </button>\n          <span\n            *ngIf=\"\n              s.query.pagination.pages[s.query.pagination.pages.length - 1] <\n              s.query.pagination.pageCount - 1\n            \"\n            class=\"truncated-pages right\"\n          >\n            &hellip;\n          </span>\n          <button\n            rivButton\n            [variant]=\"'basic'\"\n            [size]=\"'small'\"\n            [icon]=\"'ArrowRight'\"\n            type=\"button\"\n            [disabled]=\"s.query.pagination.next === null\"\n            (click)=\"manager?.actions?.next({ type: 'nextPageNavigate' })\"\n          ></button>\n        </div>\n      </div>\n    </riv-loading-cover>\n  </div>\n</ng-container>\n"]}
|