UNPKG

@taiga-ui/addon-table

Version:

A library to display tabled data with filters, search, group actions, etc.

133 lines 18.9 kB
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"; const EMPTY_COMPARATOR = () => 0; 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; this.sorter = EMPTY_COMPARATOR; /** * @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(); } set sizeSetter(size) { this.size.set(size); } updateSorterAndDirection(sorter) { if (this.sorter === sorter) { this.updateSorter(this.sorter, this.direction === TuiSortDirection.Asc ? TuiSortDirection.Desc : TuiSortDirection.Asc); } else { this.updateSorter(sorter); } } ngOnChanges() { this.change$.next(); } ngAfterViewInit() { this.cdr.detectChanges(); } updateSorter(sorter, direction = TuiSortDirection.Asc) { this.sorter = sorter || EMPTY_COMPARATOR.bind({}); this.direction = direction; this.sorterChange.emit(sorter); 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", sorter: "sorter", sizeSetter: ["size", "sizeSetter"] }, 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 }], sorter: [{ type: Input }], directionChange: [{ type: Output }], sorterChange: [{ type: Output }], sortChange: [{ type: Output }], sizeSetter: [{ type: Input, args: ['size'] }] } }); //# 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 {\n    type AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Directive,\n    EventEmitter,\n    inject,\n    Input,\n    type OnChanges,\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 {\n    TUI_TEXTFIELD_OPTIONS,\n    type TuiTextfieldOptions,\n} from '@taiga-ui/core/components/textfield';\nimport {type TuiSizeL, type 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 {combineLatest, debounceTime, map, type Observable, Subject} from 'rxjs';\n\nimport {\n    TUI_TABLE_OPTIONS,\n    TuiSortDirection,\n    type TuiTableSortChange,\n} from '../table.options';\nimport {TuiStuck} from './stuck.directive';\n\nconst EMPTY_COMPARATOR: TuiComparator<unknown> = () => 0;\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, unknown>>>\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    @Input()\n    public sorter: TuiComparator<T> = EMPTY_COMPARATOR;\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    public updateSorterAndDirection(sorter: TuiComparator<T> | null): void {\n        if (this.sorter === sorter) {\n            this.updateSorter(\n                this.sorter,\n                this.direction === TuiSortDirection.Asc\n                    ? TuiSortDirection.Desc\n                    : TuiSortDirection.Asc,\n            );\n        } else {\n            this.updateSorter(sorter);\n        }\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(\n        sorter: TuiComparator<T> | null,\n        direction: TuiSortDirection = TuiSortDirection.Asc,\n    ): void {\n        this.sorter = sorter || EMPTY_COMPARATOR.bind({});\n        this.direction = direction;\n        this.sorterChange.emit(sorter);\n        this.directionChange.emit(this.direction);\n        this.change$.next();\n    }\n}\n"]}