@rivet-health/design-system 27.0.1 → 27.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/table/table/table-column-settings/table-column-settings-side-sheet.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
package/esm2020/lib/table/table/table-column-settings/table-column-settings-side-sheet.component.mjs
CHANGED
|
@@ -37,7 +37,7 @@ export class TableColumnSettingsSideSheetComponent {
|
|
|
37
37
|
});
|
|
38
38
|
const fuse = new Fuse(allColumns, {
|
|
39
39
|
keys: ['resolvedName'],
|
|
40
|
-
|
|
40
|
+
ignoreLocation: true,
|
|
41
41
|
threshold: 0,
|
|
42
42
|
});
|
|
43
43
|
return { fuse, allColumns };
|
|
@@ -160,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
160
160
|
type: ViewChild,
|
|
161
161
|
args: ['trigger', { read: ElementRef }]
|
|
162
162
|
}] } });
|
|
163
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column-settings-side-sheet.component.js","sourceRoot":"","sources":["../../../../../../../projects/riv/src/lib/table/table/table-column-settings/table-column-settings-side-sheet.component.ts","../../../../../../../projects/riv/src/lib/table/table/table-column-settings/table-column-settings-side-sheet.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  ViewChild,\n} from '@angular/core';\nimport Fuse from 'fuse.js';\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs';\nimport { HighlightComponent } from '../../../visualization/highlight/highlight.component';\nimport { RivTable } from '../state';\n\ntype ColumnList<C extends RivTable.Column> = (RivTable.ColumnSettings<C> & {\n  resolvedName: C | string;\n  highlightIndices: HighlightComponent.HighlightIndices[];\n  stateIndex: number;\n  isLastPinnedColumn: boolean;\n})[];\n\ntype ColumnGroups<C extends RivTable.Column> = {\n  enabledColumns: ColumnList<C>;\n  disabledColumns: ColumnList<C>;\n};\n\n@Component({\n  selector: 'riv-table-column-settings-side-sheet',\n  templateUrl: './table-column-settings-side-sheet.component.html',\n  styleUrls: ['./table-column-settings-side-sheet.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TableColumnSettingsSideSheetComponent<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n> implements OnInit\n{\n  @Input()\n  manager?: RivTable.Manager<R, C, F>;\n\n  @ViewChild('trigger', { read: ElementRef })\n  anchor?: ElementRef;\n\n  readonly open = new BehaviorSubject(false);\n\n  readonly filterQuery = new BehaviorSubject('');\n\n  readonly searching = this.filterQuery.pipe(map(query => !!query));\n\n  columnList?: Observable<ColumnGroups<C>>;\n\n  ngOnInit() {\n    this.columnList = combineLatest([\n      this.manager!.state.pipe(\n        map(s => {\n          const columnsLength = s.display.allColumns.length;\n          const allColumns = s.display.allColumns.map((column, i) => {\n            const nextColumnPinned =\n              i + 2 <= columnsLength\n                ? s.display.allColumns[i + 1].pinned\n                : false;\n\n            return {\n              ...column,\n              resolvedName:\n                s.display.columnNameMap.get(column.name) ?? column.name,\n              stateIndex: i,\n              isLastPinnedColumn: column.pinned && !nextColumnPinned,\n            };\n          });\n          const fuse = new Fuse(allColumns, {\n            keys: ['resolvedName'],\n            distance: 0,\n            threshold: 0,\n          });\n          return { fuse, allColumns };\n        }),\n      ),\n      this.filterQuery,\n    ]).pipe(\n      map(([{ fuse, allColumns }, filterQuery]) => {\n        if (filterQuery) {\n          const matches = fuse.search(filterQuery).map(match => ({\n            ...match.item,\n            highlightIndices: [\n              ...(match.matches?.find(result => result.key === 'resolvedName')\n                ?.indices || []),\n            ],\n          }));\n          const enabledColumns = matches.filter(column => column.enabled);\n          const disabledColumns = matches.filter(column => !column.enabled);\n\n          return {\n            enabledColumns,\n            disabledColumns,\n          };\n        }\n\n        const allVisableColumns = allColumns.map(column => ({\n          ...column,\n          highlightIndices: [],\n        }));\n\n        const enabledColumns = allVisableColumns.filter(\n          column => column.enabled,\n        );\n        const disabledColumns = allVisableColumns.filter(\n          column => !column.enabled,\n        );\n\n        return {\n          enabledColumns: enabledColumns,\n          disabledColumns: disabledColumns,\n        };\n      }),\n    );\n  }\n\n  columnEnabledChange(column: RivTable.ColumnSettings<C>, enabled: boolean) {\n    this.manager?.actions.next({\n      type: 'columnEnabledChange',\n      column: column.name,\n      enabled,\n    });\n  }\n\n  columnPinChange(column: RivTable.ColumnSettings<C>, pinned: boolean) {\n    this.manager?.actions.next({\n      type: 'columnPinChange',\n      column: column.name,\n      pinned,\n    });\n  }\n  resetToDefault() {\n    this.manager?.actions.next({\n      type: 'resetToDefaultColumns',\n    });\n  }\n\n  columnMoveTo(column: RivTable.ColumnSettings<C>, position: 'start' | 'end') {\n    this.manager?.actions.next({\n      type: 'columnMoveToChange',\n      position,\n      column: column.name,\n    });\n  }\n\n  columnFreezeUpTo(freeze: boolean, index: number) {\n    this.manager?.actions.next({\n      type: 'columnsFreezeUpToChange',\n      freeze,\n      index,\n    });\n  }\n\n  allColumnsDisabled(columns: ColumnGroups<C>): boolean {\n    return (\n      columns.disabledColumns.length == 0 && columns.enabledColumns.length > 0\n    );\n  }\n\n  allColumnsEnabled(columns: ColumnGroups<C>): boolean {\n    return (\n      columns.enabledColumns.length == 0 && columns.disabledColumns.length > 0\n    );\n  }\n\n  enableAllColumns(enabled: boolean) {\n    this.manager?.actions.next({\n      type: 'enableAllColumnsChange',\n      enabled,\n    });\n  }\n\n  draggedColumnIdx: number | null = null;\n  draggedColumnName: C | null = null;\n  draggedOverColumnIdx: number | null = null;\n\n  dragStart(idx: number, name: C) {\n    this.draggedColumnIdx = idx;\n    this.draggedColumnName = name;\n  }\n\n  dragOver(ontoIdx: number) {\n    this.draggedOverColumnIdx = ontoIdx;\n  }\n\n  drop(ontoIdx: number, stateIndex: number) {\n    if (this.draggedColumnIdx !== null) {\n      this.manager?.actions.next({\n        type: 'columnOrderChange',\n        previousIndex: this.draggedColumnIdx,\n        newIndex: stateIndex,\n      });\n      this.draggedOverColumnIdx = null;\n      this.draggedColumnName = null;\n    }\n  }\n\n  dropEnabledState(enabled: boolean) {\n    if (this.draggedColumnName !== null) {\n      this.manager?.actions.next({\n        type: 'columnEnabledChange',\n        column: this.draggedColumnName,\n        enabled: enabled,\n      });\n\n      this.draggedOverColumnIdx = null;\n      this.draggedColumnName = null;\n    }\n  }\n\n  disabledColumnsWithOffset(index: number) {\n    return index;\n  }\n}\n","<button #trigger rivButton (click)=\"open.next(true)\">Columns</button>\n\n<ng-container *ngIf=\"columnList | async; let columns\">\n  <ng-container *ngIf=\"open | async\">\n    <riv-side-sheet (close)=\"open.next(false); filterQuery.next('')\">\n      <div class=\"content\">\n        <div class=\"title\">\n          <span>Columns</span>\n          <button\n            rivButton\n            [variant]=\"'ghost'\"\n            [icon]=\"'X'\"\n            (click)=\"open.next(false); filterQuery.next('')\"\n          ></button>\n        </div>\n        <riv-search\n          [name]=\"'column-search'\"\n          [value]=\"(filterQuery | async) || ''\"\n          (valueChange)=\"filterQuery.next($event)\"\n        ></riv-search>\n        <div class=\"columns\">\n          <div *ngIf=\"columns.enabledColumns.length > 0\">\n            <div\n              class=\"column-header\"\n              (drop)=\"dropEnabledState(true)\"\n              (dragover)=\"$event.preventDefault(); dragOver(-1)\"\n            >\n              <span class=\"column-header-label\">Shown in table</span>\n              <button\n                *ngIf=\"!(searching | async)\"\n                rivButton\n                [variant]=\"'ghost'\"\n                [disabled]=\"allColumnsEnabled(columns)\"\n                (click)=\"enableAllColumns(false)\"\n              >\n                Hide all\n              </button>\n            </div>\n\n            <div class=\"options\">\n              <ng-container\n                *ngFor=\"let column of columns.enabledColumns; let i = index\"\n              >\n                <div\n                  class=\"option\"\n                  [attr.draggable]=\"!(searching | async)\"\n                  [attr.droppable]=\"!(searching | async)\"\n                  (dragstart)=\"dragStart(column.stateIndex, column.name)\"\n                  (dragenter)=\"$event.preventDefault()\"\n                  (dragover)=\"$event.preventDefault(); dragOver(i)\"\n                  (drop)=\"drop(i, column.stateIndex)\"\n                  [class.dragged-over-top]=\"\n                    draggedOverColumnIdx === i &&\n                    draggedColumnIdx !== null &&\n                    draggedColumnIdx > i\n                  \"\n                  [class.dragged-over-bottom]=\"\n                    draggedOverColumnIdx === i &&\n                    draggedColumnIdx !== null &&\n                    draggedColumnIdx < i\n                  \"\n                >\n                  <ng-container\n                    *ngTemplateOutlet=\"columnTemplate; context: { column }\"\n                  ></ng-container>\n                  <div\n                    *ngIf=\"column.isLastPinnedColumn && !(searching | async)\"\n                    class=\"column scroll-padding\"\n                  >\n                    <div class=\"frozen\">\n                      <span class=\"pinned\">\n                        <riv-icon [name]=\"'PinInactive'\" [size]=\"20\"></riv-icon>\n                      </span>\n                      <span>Frozen through here</span>\n                    </div>\n\n                    <button\n                      class=\"hidden\"\n                      rivButton\n                      [rivTooltip]=\"'Un-freeze columns'\"\n                      [class.disabled]=\"!column.enabled\"\n                      [variant]=\"'ghost'\"\n                      [size]=\"'small'\"\n                      [icon]=\"'X'\"\n                      (click)=\"columnFreezeUpTo(false, column.stateIndex)\"\n                    ></button>\n                  </div>\n                </div>\n              </ng-container>\n            </div>\n          </div>\n          <div\n            *ngIf=\"columns.enabledColumns.length == 0 && !(searching | async)\"\n            class=\"column-header\"\n            (drop)=\"dropEnabledState(true)\"\n            (dragover)=\"$event.preventDefault(); dragOver(-1)\"\n          >\n            <span>No columns shown</span>\n            <button rivButton [variant]=\"'ghost'\" (click)=\"resetToDefault()\">\n              Reset to default\n            </button>\n          </div>\n          <div\n            class=\"divider\"\n            *ngIf=\"\n              columns.disabledColumns.length > 0 &&\n              (!(searching | async) ||\n                ((searching | async) && columns.enabledColumns.length > 0))\n            \"\n          ></div>\n          <div\n            *ngIf=\"columns.disabledColumns.length > 0\"\n            (drop)=\"dropEnabledState(false)\"\n            (dragover)=\"$event.preventDefault(); dragOver(-1)\"\n          >\n            <div class=\"column-header\">\n              <span class=\"column-header-label\">Hidden from table</span>\n\n              <button\n                *ngIf=\"!(searching | async)\"\n                rivButton\n                [variant]=\"'ghost'\"\n                [disabled]=\"allColumnsDisabled(columns)\"\n                (click)=\"enableAllColumns(true)\"\n              >\n                Show all\n              </button>\n            </div>\n\n            <div class=\"options\">\n              <div\n                *ngFor=\"let column of columns.disabledColumns; let i = index\"\n                [attr.draggable]=\"!(searching | async)\"\n                [attr.droppable]=\"!(searching | async)\"\n                (dragstart)=\"dragStart(column.stateIndex, column.name)\"\n                (dragenter)=\"$event.preventDefault()\"\n                (dragover)=\"\n                  $event.preventDefault();\n                  dragOver(i + columns.enabledColumns.length)\n                \"\n                (drop)=\"\n                  drop(i + columns.enabledColumns.length, column.stateIndex)\n                \"\n              >\n                <ng-container\n                  *ngTemplateOutlet=\"columnTemplate; context: { column }\"\n                ></ng-container>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </riv-side-sheet>\n  </ng-container>\n</ng-container>\n\n<ng-template #columnTemplate let-column=\"column\">\n  <div class=\"column scroll-padding\">\n    <div class=\"column\">\n      <span class=\"reorder\" *ngIf=\"!(searching | async)\">\n        <riv-icon [name]=\"'Reorder'\" [size]=\"20\"></riv-icon>\n      </span>\n      <riv-highlight\n        [text]=\"column.resolvedName\"\n        [indices]=\"column.highlightIndices\"\n      ></riv-highlight>\n    </div>\n    <div>\n      <riv-menu class=\"hidden\">\n        <button\n          *ngIf=\"column.enabled && !column.isLastPinnedColumn\"\n          riv-menu-item\n          (click)=\"columnFreezeUpTo(true, column.stateIndex)\"\n        >\n          Freeze up to column\n        </button>\n        <button\n          *ngIf=\"column.enabled && column.isLastPinnedColumn\"\n          riv-menu-item\n          (click)=\"columnPinChange(column, false)\"\n        >\n          Unfreeze column\n        </button>\n        <button riv-menu-item (click)=\"columnMoveTo(column, 'start')\">\n          Move to start\n        </button>\n        <button riv-menu-item (click)=\"columnMoveTo(column, 'end')\">\n          Move to end\n        </button>\n        <button\n          riv-menu-item\n          (click)=\"columnEnabledChange(column, !column.enabled)\"\n        >\n          {{ column.enabled ? 'Hide column' : 'Show column' }}\n        </button>\n      </riv-menu>\n      <button\n        rivButton\n        [rivTooltip]=\"column.enabled ? 'Hide column' : 'Show column'\"\n        [class.disabled]=\"!column.enabled\"\n        [variant]=\"'ghost'\"\n        [size]=\"'small'\"\n        [icon]=\"column.enabled ? 'Eye' : 'EyeOff'\"\n        (click)=\"columnEnabledChange(column, !column.enabled)\"\n      ></button>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column-settings-side-sheet.component.js","sourceRoot":"","sources":["../../../../../../../projects/riv/src/lib/table/table/table-column-settings/table-column-settings-side-sheet.component.ts","../../../../../../../projects/riv/src/lib/table/table/table-column-settings/table-column-settings-side-sheet.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  ViewChild,\n} from '@angular/core';\nimport Fuse from 'fuse.js';\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs';\nimport { HighlightComponent } from '../../../visualization/highlight/highlight.component';\nimport { RivTable } from '../state';\n\ntype ColumnList<C extends RivTable.Column> = (RivTable.ColumnSettings<C> & {\n  resolvedName: C | string;\n  highlightIndices: HighlightComponent.HighlightIndices[];\n  stateIndex: number;\n  isLastPinnedColumn: boolean;\n})[];\n\ntype ColumnGroups<C extends RivTable.Column> = {\n  enabledColumns: ColumnList<C>;\n  disabledColumns: ColumnList<C>;\n};\n\n@Component({\n  selector: 'riv-table-column-settings-side-sheet',\n  templateUrl: './table-column-settings-side-sheet.component.html',\n  styleUrls: ['./table-column-settings-side-sheet.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TableColumnSettingsSideSheetComponent<\n  R extends RivTable.Row,\n  C extends RivTable.Column,\n  F extends RivTable.Filters,\n> implements OnInit\n{\n  @Input()\n  manager?: RivTable.Manager<R, C, F>;\n\n  @ViewChild('trigger', { read: ElementRef })\n  anchor?: ElementRef;\n\n  readonly open = new BehaviorSubject(false);\n\n  readonly filterQuery = new BehaviorSubject('');\n\n  readonly searching = this.filterQuery.pipe(map(query => !!query));\n\n  columnList?: Observable<ColumnGroups<C>>;\n\n  ngOnInit() {\n    this.columnList = combineLatest([\n      this.manager!.state.pipe(\n        map(s => {\n          const columnsLength = s.display.allColumns.length;\n          const allColumns = s.display.allColumns.map((column, i) => {\n            const nextColumnPinned =\n              i + 2 <= columnsLength\n                ? s.display.allColumns[i + 1].pinned\n                : false;\n\n            return {\n              ...column,\n              resolvedName:\n                s.display.columnNameMap.get(column.name) ?? column.name,\n              stateIndex: i,\n              isLastPinnedColumn: column.pinned && !nextColumnPinned,\n            };\n          });\n          const fuse = new Fuse(allColumns, {\n            keys: ['resolvedName'],\n            ignoreLocation: true,\n            threshold: 0,\n          });\n          return { fuse, allColumns };\n        }),\n      ),\n      this.filterQuery,\n    ]).pipe(\n      map(([{ fuse, allColumns }, filterQuery]) => {\n        if (filterQuery) {\n          const matches = fuse.search(filterQuery).map(match => ({\n            ...match.item,\n            highlightIndices: [\n              ...(match.matches?.find(result => result.key === 'resolvedName')\n                ?.indices || []),\n            ],\n          }));\n          const enabledColumns = matches.filter(column => column.enabled);\n          const disabledColumns = matches.filter(column => !column.enabled);\n\n          return {\n            enabledColumns,\n            disabledColumns,\n          };\n        }\n\n        const allVisableColumns = allColumns.map(column => ({\n          ...column,\n          highlightIndices: [],\n        }));\n\n        const enabledColumns = allVisableColumns.filter(\n          column => column.enabled,\n        );\n        const disabledColumns = allVisableColumns.filter(\n          column => !column.enabled,\n        );\n\n        return {\n          enabledColumns: enabledColumns,\n          disabledColumns: disabledColumns,\n        };\n      }),\n    );\n  }\n\n  columnEnabledChange(column: RivTable.ColumnSettings<C>, enabled: boolean) {\n    this.manager?.actions.next({\n      type: 'columnEnabledChange',\n      column: column.name,\n      enabled,\n    });\n  }\n\n  columnPinChange(column: RivTable.ColumnSettings<C>, pinned: boolean) {\n    this.manager?.actions.next({\n      type: 'columnPinChange',\n      column: column.name,\n      pinned,\n    });\n  }\n  resetToDefault() {\n    this.manager?.actions.next({\n      type: 'resetToDefaultColumns',\n    });\n  }\n\n  columnMoveTo(column: RivTable.ColumnSettings<C>, position: 'start' | 'end') {\n    this.manager?.actions.next({\n      type: 'columnMoveToChange',\n      position,\n      column: column.name,\n    });\n  }\n\n  columnFreezeUpTo(freeze: boolean, index: number) {\n    this.manager?.actions.next({\n      type: 'columnsFreezeUpToChange',\n      freeze,\n      index,\n    });\n  }\n\n  allColumnsDisabled(columns: ColumnGroups<C>): boolean {\n    return (\n      columns.disabledColumns.length == 0 && columns.enabledColumns.length > 0\n    );\n  }\n\n  allColumnsEnabled(columns: ColumnGroups<C>): boolean {\n    return (\n      columns.enabledColumns.length == 0 && columns.disabledColumns.length > 0\n    );\n  }\n\n  enableAllColumns(enabled: boolean) {\n    this.manager?.actions.next({\n      type: 'enableAllColumnsChange',\n      enabled,\n    });\n  }\n\n  draggedColumnIdx: number | null = null;\n  draggedColumnName: C | null = null;\n  draggedOverColumnIdx: number | null = null;\n\n  dragStart(idx: number, name: C) {\n    this.draggedColumnIdx = idx;\n    this.draggedColumnName = name;\n  }\n\n  dragOver(ontoIdx: number) {\n    this.draggedOverColumnIdx = ontoIdx;\n  }\n\n  drop(ontoIdx: number, stateIndex: number) {\n    if (this.draggedColumnIdx !== null) {\n      this.manager?.actions.next({\n        type: 'columnOrderChange',\n        previousIndex: this.draggedColumnIdx,\n        newIndex: stateIndex,\n      });\n      this.draggedOverColumnIdx = null;\n      this.draggedColumnName = null;\n    }\n  }\n\n  dropEnabledState(enabled: boolean) {\n    if (this.draggedColumnName !== null) {\n      this.manager?.actions.next({\n        type: 'columnEnabledChange',\n        column: this.draggedColumnName,\n        enabled: enabled,\n      });\n\n      this.draggedOverColumnIdx = null;\n      this.draggedColumnName = null;\n    }\n  }\n\n  disabledColumnsWithOffset(index: number) {\n    return index;\n  }\n}\n","<button #trigger rivButton (click)=\"open.next(true)\">Columns</button>\n\n<ng-container *ngIf=\"columnList | async; let columns\">\n  <ng-container *ngIf=\"open | async\">\n    <riv-side-sheet (close)=\"open.next(false); filterQuery.next('')\">\n      <div class=\"content\">\n        <div class=\"title\">\n          <span>Columns</span>\n          <button\n            rivButton\n            [variant]=\"'ghost'\"\n            [icon]=\"'X'\"\n            (click)=\"open.next(false); filterQuery.next('')\"\n          ></button>\n        </div>\n        <riv-search\n          [name]=\"'column-search'\"\n          [value]=\"(filterQuery | async) || ''\"\n          (valueChange)=\"filterQuery.next($event)\"\n        ></riv-search>\n        <div class=\"columns\">\n          <div *ngIf=\"columns.enabledColumns.length > 0\">\n            <div\n              class=\"column-header\"\n              (drop)=\"dropEnabledState(true)\"\n              (dragover)=\"$event.preventDefault(); dragOver(-1)\"\n            >\n              <span class=\"column-header-label\">Shown in table</span>\n              <button\n                *ngIf=\"!(searching | async)\"\n                rivButton\n                [variant]=\"'ghost'\"\n                [disabled]=\"allColumnsEnabled(columns)\"\n                (click)=\"enableAllColumns(false)\"\n              >\n                Hide all\n              </button>\n            </div>\n\n            <div class=\"options\">\n              <ng-container\n                *ngFor=\"let column of columns.enabledColumns; let i = index\"\n              >\n                <div\n                  class=\"option\"\n                  [attr.draggable]=\"!(searching | async)\"\n                  [attr.droppable]=\"!(searching | async)\"\n                  (dragstart)=\"dragStart(column.stateIndex, column.name)\"\n                  (dragenter)=\"$event.preventDefault()\"\n                  (dragover)=\"$event.preventDefault(); dragOver(i)\"\n                  (drop)=\"drop(i, column.stateIndex)\"\n                  [class.dragged-over-top]=\"\n                    draggedOverColumnIdx === i &&\n                    draggedColumnIdx !== null &&\n                    draggedColumnIdx > i\n                  \"\n                  [class.dragged-over-bottom]=\"\n                    draggedOverColumnIdx === i &&\n                    draggedColumnIdx !== null &&\n                    draggedColumnIdx < i\n                  \"\n                >\n                  <ng-container\n                    *ngTemplateOutlet=\"columnTemplate; context: { column }\"\n                  ></ng-container>\n                  <div\n                    *ngIf=\"column.isLastPinnedColumn && !(searching | async)\"\n                    class=\"column scroll-padding\"\n                  >\n                    <div class=\"frozen\">\n                      <span class=\"pinned\">\n                        <riv-icon [name]=\"'PinInactive'\" [size]=\"20\"></riv-icon>\n                      </span>\n                      <span>Frozen through here</span>\n                    </div>\n\n                    <button\n                      class=\"hidden\"\n                      rivButton\n                      [rivTooltip]=\"'Un-freeze columns'\"\n                      [class.disabled]=\"!column.enabled\"\n                      [variant]=\"'ghost'\"\n                      [size]=\"'small'\"\n                      [icon]=\"'X'\"\n                      (click)=\"columnFreezeUpTo(false, column.stateIndex)\"\n                    ></button>\n                  </div>\n                </div>\n              </ng-container>\n            </div>\n          </div>\n          <div\n            *ngIf=\"columns.enabledColumns.length == 0 && !(searching | async)\"\n            class=\"column-header\"\n            (drop)=\"dropEnabledState(true)\"\n            (dragover)=\"$event.preventDefault(); dragOver(-1)\"\n          >\n            <span>No columns shown</span>\n            <button rivButton [variant]=\"'ghost'\" (click)=\"resetToDefault()\">\n              Reset to default\n            </button>\n          </div>\n          <div\n            class=\"divider\"\n            *ngIf=\"\n              columns.disabledColumns.length > 0 &&\n              (!(searching | async) ||\n                ((searching | async) && columns.enabledColumns.length > 0))\n            \"\n          ></div>\n          <div\n            *ngIf=\"columns.disabledColumns.length > 0\"\n            (drop)=\"dropEnabledState(false)\"\n            (dragover)=\"$event.preventDefault(); dragOver(-1)\"\n          >\n            <div class=\"column-header\">\n              <span class=\"column-header-label\">Hidden from table</span>\n\n              <button\n                *ngIf=\"!(searching | async)\"\n                rivButton\n                [variant]=\"'ghost'\"\n                [disabled]=\"allColumnsDisabled(columns)\"\n                (click)=\"enableAllColumns(true)\"\n              >\n                Show all\n              </button>\n            </div>\n\n            <div class=\"options\">\n              <div\n                *ngFor=\"let column of columns.disabledColumns; let i = index\"\n                [attr.draggable]=\"!(searching | async)\"\n                [attr.droppable]=\"!(searching | async)\"\n                (dragstart)=\"dragStart(column.stateIndex, column.name)\"\n                (dragenter)=\"$event.preventDefault()\"\n                (dragover)=\"\n                  $event.preventDefault();\n                  dragOver(i + columns.enabledColumns.length)\n                \"\n                (drop)=\"\n                  drop(i + columns.enabledColumns.length, column.stateIndex)\n                \"\n              >\n                <ng-container\n                  *ngTemplateOutlet=\"columnTemplate; context: { column }\"\n                ></ng-container>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </riv-side-sheet>\n  </ng-container>\n</ng-container>\n\n<ng-template #columnTemplate let-column=\"column\">\n  <div class=\"column scroll-padding\">\n    <div class=\"column\">\n      <span class=\"reorder\" *ngIf=\"!(searching | async)\">\n        <riv-icon [name]=\"'Reorder'\" [size]=\"20\"></riv-icon>\n      </span>\n      <riv-highlight\n        [text]=\"column.resolvedName\"\n        [indices]=\"column.highlightIndices\"\n      ></riv-highlight>\n    </div>\n    <div>\n      <riv-menu class=\"hidden\">\n        <button\n          *ngIf=\"column.enabled && !column.isLastPinnedColumn\"\n          riv-menu-item\n          (click)=\"columnFreezeUpTo(true, column.stateIndex)\"\n        >\n          Freeze up to column\n        </button>\n        <button\n          *ngIf=\"column.enabled && column.isLastPinnedColumn\"\n          riv-menu-item\n          (click)=\"columnPinChange(column, false)\"\n        >\n          Unfreeze column\n        </button>\n        <button riv-menu-item (click)=\"columnMoveTo(column, 'start')\">\n          Move to start\n        </button>\n        <button riv-menu-item (click)=\"columnMoveTo(column, 'end')\">\n          Move to end\n        </button>\n        <button\n          riv-menu-item\n          (click)=\"columnEnabledChange(column, !column.enabled)\"\n        >\n          {{ column.enabled ? 'Hide column' : 'Show column' }}\n        </button>\n      </riv-menu>\n      <button\n        rivButton\n        [rivTooltip]=\"column.enabled ? 'Hide column' : 'Show column'\"\n        [class.disabled]=\"!column.enabled\"\n        [variant]=\"'ghost'\"\n        [size]=\"'small'\"\n        [icon]=\"column.enabled ? 'Eye' : 'EyeOff'\"\n        (click)=\"columnEnabledChange(column, !column.enabled)\"\n      ></button>\n    </div>\n  </div>\n</ng-template>\n"]}
|