@taiga-ui/addon-table
Version:
A library to display tabled data with filters, search, group actions, etc.
136 lines • 19 kB
JavaScript
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Directive, EventEmitter, inject, Input, Output, signal, ViewEncapsulation, } from '@angular/core';
import { WA_INTERSECTION_ROOT_MARGIN } from '@ng-web-apis/intersection-observer';
import { tuiProvide, tuiWithStyles } from '@taiga-ui/cdk/utils/miscellaneous';
import { tuiButtonOptionsProvider } from '@taiga-ui/core/components/button';
import { TUI_TEXTFIELD_OPTIONS } from '@taiga-ui/core/components/textfield';
import { tuiBadgeOptionsProvider } from '@taiga-ui/kit/components/badge';
import { tuiChipOptionsProvider } from '@taiga-ui/kit/components/chip';
import { tuiProgressOptionsProvider } from '@taiga-ui/kit/components/progress';
import { combineLatest, debounceTime, map, Subject } from 'rxjs';
import { TUI_TABLE_OPTIONS, TuiSortDirection } from '../table.options';
import { TuiStuck } from './stuck.directive';
import * as i0 from "@angular/core";
import * as i1 from "./stuck.directive";
class TuiTableStyles {
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTableStyles, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiTableStyles, isStandalone: true, selector: "ng-component", host: { classAttribute: "tui-table" }, ngImport: i0, template: '', isInline: true, styles: ["table[tuiTable]{border-collapse:separate;border-spacing:0}table[tuiTable] [tuiCell]{padding:0}table[tuiTable] [tuiTitle]{white-space:nowrap}table[tuiTable] [tuiTitle] tui-icon{font-size:1rem}table[tuiTable] [tuiSubtitle]{color:var(--tui-text-secondary)}table[tuiTable] [tuiTh] [tuiCell],table[tuiTable] [tuiTh] [tuiTitle]{font:inherit;color:inherit}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTableStyles, decorators: [{
type: Component,
args: [{ standalone: true, template: '', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
class: 'tui-table',
}, styles: ["table[tuiTable]{border-collapse:separate;border-spacing:0}table[tuiTable] [tuiCell]{padding:0}table[tuiTable] [tuiTitle]{white-space:nowrap}table[tuiTable] [tuiTitle] tui-icon{font-size:1rem}table[tuiTable] [tuiSubtitle]{color:var(--tui-text-secondary)}table[tuiTable] [tuiTh] [tuiCell],table[tuiTable] [tuiTh] [tuiTitle]{font:inherit;color:inherit}\n"] }]
}] });
class TuiTableDirective {
constructor() {
this.options = inject(TUI_TABLE_OPTIONS);
this.cdr = inject(ChangeDetectorRef);
this.nothing = tuiWithStyles(TuiTableStyles);
this.columns = [];
this.direction = this.options.direction;
/**
* @deprecated: use sortChange
*/
this.directionChange = new EventEmitter();
/**
* @deprecated: use sortChange
*/
this.sorterChange = new EventEmitter();
this.sortChange = combineLatest([
this.sorterChange,
this.directionChange,
]).pipe(debounceTime(0), map(([sortComparator, sortDirection]) => ({
sortBy: sortComparator,
orderBy: sortDirection,
sortComparator,
sortDirection,
})));
this.appearance = signal('table');
this.size = signal(this.options.size);
this.cleaner = signal(false);
// TODO: refactor to signal inputs after Angular update
this.change$ = new Subject();
this.sorter = () => 0;
}
set sizeSetter(size) {
this.size.set(size);
}
updateSorterAndDirection(sorter) {
if (this.sorter === sorter) {
this.updateDirection(this.direction === TuiSortDirection.Asc
? TuiSortDirection.Desc
: TuiSortDirection.Asc);
}
else {
this.updateDirection(1);
}
this.updateSorter(sorter);
}
ngOnChanges() {
this.change$.next();
}
ngAfterViewInit() {
this.cdr.detectChanges();
}
updateSorter(sorter) {
this.sorter = sorter || (() => 0);
this.sorterChange.emit(this.sorter);
this.change$.next();
}
updateDirection(direction) {
this.direction = direction;
this.directionChange.emit(this.direction);
this.change$.next();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiTableDirective, isStandalone: true, selector: "table[tuiTable]", inputs: { columns: "columns", direction: "direction", sizeSetter: ["size", "sizeSetter"], sorter: "sorter" }, outputs: { directionChange: "directionChange", sorterChange: "sorterChange", sortChange: "sortChange" }, host: { properties: { "attr.data-size": "size()" } }, providers: [
{
provide: WA_INTERSECTION_ROOT_MARGIN,
useValue: '10000px 10000px 10000px 0px',
},
tuiProvide(TUI_TEXTFIELD_OPTIONS, TuiTableDirective),
tuiButtonOptionsProvider({ size: 's' }),
tuiBadgeOptionsProvider({ size: 'm', appearance: 'neutral' }),
tuiChipOptionsProvider({ size: 'xxs', appearance: 'neutral' }),
tuiProgressOptionsProvider({ size: 's', color: 'var(--tui-text-action)' }),
], usesOnChanges: true, hostDirectives: [{ directive: i1.TuiStuck }], ngImport: i0 }); }
}
export { TuiTableDirective };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTableDirective, decorators: [{
type: Directive,
args: [{
standalone: true,
selector: 'table[tuiTable]',
providers: [
{
provide: WA_INTERSECTION_ROOT_MARGIN,
useValue: '10000px 10000px 10000px 0px',
},
tuiProvide(TUI_TEXTFIELD_OPTIONS, TuiTableDirective),
tuiButtonOptionsProvider({ size: 's' }),
tuiBadgeOptionsProvider({ size: 'm', appearance: 'neutral' }),
tuiChipOptionsProvider({ size: 'xxs', appearance: 'neutral' }),
tuiProgressOptionsProvider({ size: 's', color: 'var(--tui-text-action)' }),
],
hostDirectives: [TuiStuck],
host: {
'[attr.data-size]': 'size()',
},
}]
}], propDecorators: { columns: [{
type: Input
}], direction: [{
type: Input
}], directionChange: [{
type: Output
}], sorterChange: [{
type: Output
}], sortChange: [{
type: Output
}], sizeSetter: [{
type: Input,
args: ['size']
}], sorter: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.directive.js","sourceRoot":"","sources":["../../../../../../projects/addon-table/components/table/directives/table.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import type {AfterViewInit, OnChanges} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Directive,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {WA_INTERSECTION_ROOT_MARGIN} from '@ng-web-apis/intersection-observer';\nimport type {TuiComparator} from '@taiga-ui/addon-table/types';\nimport {tuiProvide, tuiWithStyles} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {tuiButtonOptionsProvider} from '@taiga-ui/core/components/button';\nimport type {TuiTextfieldOptions} from '@taiga-ui/core/components/textfield';\nimport {TUI_TEXTFIELD_OPTIONS} from '@taiga-ui/core/components/textfield';\nimport type {TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport {tuiBadgeOptionsProvider} from '@taiga-ui/kit/components/badge';\nimport {tuiChipOptionsProvider} from '@taiga-ui/kit/components/chip';\nimport {tuiProgressOptionsProvider} from '@taiga-ui/kit/components/progress';\nimport type {Observable} from 'rxjs';\nimport {combineLatest, debounceTime, map, Subject} from 'rxjs';\n\nimport type {TuiTableSortChange} from '../table.options';\nimport {TUI_TABLE_OPTIONS, TuiSortDirection} from '../table.options';\nimport {TuiStuck} from './stuck.directive';\n\n@Component({\n    standalone: true,\n    template: '',\n    styleUrls: ['./table.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'tui-table',\n    },\n})\nclass TuiTableStyles {}\n\n@Directive({\n    standalone: true,\n    selector: 'table[tuiTable]',\n    providers: [\n        {\n            provide: WA_INTERSECTION_ROOT_MARGIN,\n            useValue: '10000px 10000px 10000px 0px',\n        },\n        tuiProvide(TUI_TEXTFIELD_OPTIONS, TuiTableDirective),\n        tuiButtonOptionsProvider({size: 's'}),\n        tuiBadgeOptionsProvider({size: 'm', appearance: 'neutral'}),\n        tuiChipOptionsProvider({size: 'xxs', appearance: 'neutral'}),\n        tuiProgressOptionsProvider({size: 's', color: 'var(--tui-text-action)'}),\n    ],\n    hostDirectives: [TuiStuck],\n    host: {\n        '[attr.data-size]': 'size()',\n    },\n})\nexport class TuiTableDirective<T extends Partial<Record<keyof T, any>>>\n    implements AfterViewInit, TuiTextfieldOptions, OnChanges\n{\n    private readonly options = inject(TUI_TABLE_OPTIONS);\n    private readonly cdr = inject(ChangeDetectorRef);\n\n    protected readonly nothing = tuiWithStyles(TuiTableStyles);\n\n    @Input()\n    public columns: ReadonlyArray<string | keyof T> = [];\n\n    @Input()\n    public direction = this.options.direction;\n\n    /**\n     * @deprecated: use sortChange\n     */\n    @Output()\n    public readonly directionChange = new EventEmitter<TuiSortDirection>();\n\n    /**\n     * @deprecated: use sortChange\n     */\n    @Output()\n    public readonly sorterChange = new EventEmitter<TuiComparator<T> | null>();\n\n    @Output()\n    public readonly sortChange: Observable<TuiTableSortChange<T>> = combineLatest([\n        this.sorterChange,\n        this.directionChange,\n    ]).pipe(\n        debounceTime(0),\n        map(([sortComparator, sortDirection]) => ({\n            sortBy: sortComparator,\n            orderBy: sortDirection,\n            sortComparator,\n            sortDirection,\n        })),\n    );\n\n    public readonly appearance = signal('table');\n    public readonly size = signal(this.options.size);\n    public readonly cleaner = signal(false);\n\n    // TODO: refactor to signal inputs after Angular update\n    public readonly change$ = new Subject<void>();\n\n    @Input('size')\n    public set sizeSetter(size: TuiSizeL | TuiSizeS) {\n        this.size.set(size);\n    }\n\n    @Input()\n    public sorter: TuiComparator<T> = () => 0;\n\n    public updateSorterAndDirection(sorter: TuiComparator<T> | null): void {\n        if (this.sorter === sorter) {\n            this.updateDirection(\n                this.direction === TuiSortDirection.Asc\n                    ? TuiSortDirection.Desc\n                    : TuiSortDirection.Asc,\n            );\n        } else {\n            this.updateDirection(1);\n        }\n\n        this.updateSorter(sorter);\n    }\n\n    public ngOnChanges(): void {\n        this.change$.next();\n    }\n\n    public ngAfterViewInit(): void {\n        this.cdr.detectChanges();\n    }\n\n    public updateSorter(sorter: TuiComparator<T> | null): void {\n        this.sorter = sorter || (() => 0);\n        this.sorterChange.emit(this.sorter);\n        this.change$.next();\n    }\n\n    private updateDirection(direction: TuiSortDirection): void {\n        this.direction = direction;\n        this.directionChange.emit(this.direction);\n        this.change$.next();\n    }\n}\n"]}