@taiga-ui/kit
Version:
Taiga UI Angular main components kit
86 lines • 22.3 kB
JavaScript
import { NgForOf, NgIf } from '@angular/common';
import { ChangeDetectionStrategy, Component, computed, EventEmitter, forwardRef, inject, Input, isSignal, Output, signal, ViewChild, ViewChildren, } from '@angular/core';
import { EMPTY_QUERY } from '@taiga-ui/cdk/constants';
import { TuiElement } from '@taiga-ui/cdk/directives/element';
import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
import { tuiIsNativeFocused } from '@taiga-ui/cdk/utils/focus';
import { tuiIsPresent } from '@taiga-ui/cdk/utils/miscellaneous';
import { tuiAsDataListAccessor, TuiDataList, TuiDataListComponent, tuiInjectDataListSize, TuiOption, TuiOptionWithValue, } from '@taiga-ui/core/components/data-list';
import { TuiLoader } from '@taiga-ui/core/components/loader';
import { TUI_ITEMS_HANDLERS, } from '@taiga-ui/core/directives/items-handlers';
import { TUI_ITEMS_HANDLERS as TUI_ITEMS_HANDLERS_LEGACY, } from '@taiga-ui/kit/tokens';
import { PolymorpheusOutlet } from '@taiga-ui/polymorpheus';
import * as i0 from "@angular/core";
import * as i1 from "@taiga-ui/core/components/data-list";
class TuiDataListWrapperComponent {
constructor() {
this.datalist = signal(null);
this.itemsHandlers = inject(TUI_ITEMS_HANDLERS);
// TODO(v5): delete
this.itemsHandlersLegacy = inject(TUI_ITEMS_HANDLERS_LEGACY);
// TODO(v5): delete
this.legacyOptionsQuery = EMPTY_QUERY;
// TODO(v5): delete
this.optionsQuery = EMPTY_QUERY;
this.newOptionMode = tuiInjectElement().hasAttribute('new');
this.items = [];
this.disabledItemHandler = this.newOptionMode
? this.itemsHandlers?.disabledItemHandler()
: this.itemsHandlersLegacy.disabledItemHandler;
this.size = tuiInjectDataListSize();
this.itemClick = new EventEmitter();
this.options = computed(() => this.datalist()?.options() ?? []);
this.itemContent = ({ $implicit }) => this.newOptionMode
? this.itemsHandlers.stringify()($implicit)
: this.itemsHandlersLegacy.stringify($implicit);
}
getContext($implicit, { nativeElement }) {
return { $implicit, active: tuiIsNativeFocused(nativeElement) };
}
// TODO(v5): delete
getOptions(includeDisabled = false) {
return [
...this.legacyOptionsQuery,
...this.optionsQuery,
]
.filter(({ disabled }) => includeDisabled || !disabled)
.map(({ value }) => (isSignal(value) ? value() : value))
.filter(tuiIsPresent);
}
// TODO(v5): use signal `viewChild`
set datalistSetter(x) {
this.datalist.set(x);
}
$cast(items) {
return items;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDataListWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDataListWrapperComponent, isStandalone: true, selector: "tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]", inputs: { items: "items", disabledItemHandler: "disabledItemHandler", emptyContent: "emptyContent", size: "size", itemContent: "itemContent" }, outputs: { itemClick: "itemClick" }, providers: [tuiAsDataListAccessor(TuiDataListWrapperComponent)], viewQueries: [{ propertyName: "datalistSetter", first: true, predicate: TuiDataListComponent, descendants: true }, { propertyName: "legacyOptionsQuery", predicate: i0.forwardRef(function () { return TuiOption; }), descendants: true }, { propertyName: "optionsQuery", predicate: i0.forwardRef(function () { return TuiOptionWithValue; }), descendants: true }], ngImport: i0, template: "<tui-data-list\n *ngIf=\"items; else loading\"\n [emptyContent]=\"emptyContent\"\n [size]=\"size\"\n>\n <ng-container *ngIf=\"newOptionMode; else legacyOptionFallback\">\n <button\n *ngFor=\"let item of $cast(items)\"\n #elementRef=\"elementRef\"\n new\n tuiElement\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n (click.capture)=\"itemClick.emit(item)\"\n >\n <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n {{ text }}\n </ng-container>\n </button>\n </ng-container>\n\n <!-- TODO(v5): delete fallback -->\n <ng-template #legacyOptionFallback>\n <button\n *ngFor=\"let item of $cast(items)\"\n #elementRef=\"elementRef\"\n automation-id=\"tui-data-list-wrapper__option\"\n tuiElement\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n (click)=\"itemClick.emit(item)\"\n >\n <span class=\"t-content\">\n <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n {{ text }}\n </ng-container>\n </span>\n </button>\n </ng-template>\n</tui-data-list>\n<ng-template #loading>\n <tui-loader\n automation-id=\"tui-data-list-wrapper__loader\"\n class=\"t-loader\"\n />\n</ng-template>\n", styles: [":host{display:block}.t-content{flex:1;min-inline-size:0}.t-loader{margin:.75rem 0}\n"], dependencies: [{ kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: i1.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "component", type: i1.TuiOption, selector: "button[tuiOption]:not([new]), a[tuiOption]:not([new]), label[tuiOption]:not([new])", inputs: ["disabled", "value"] }, { kind: "directive", type: i1.TuiOptionNew, selector: "button[tuiOption][new], a[tuiOption][new], label[tuiOption][new]", inputs: ["disabled"] }, { kind: "directive", type: i1.TuiOptionWithValue, selector: "button[tuiOption][value][new], a[tuiOption][value][new], label[tuiOption][value][new]", inputs: ["disabled", "value"] }, { kind: "directive", type: TuiElement, selector: "[tuiElement]", exportAs: ["elementRef"] }, { kind: "component", type: TuiLoader, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
export { TuiDataListWrapperComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDataListWrapperComponent, decorators: [{
type: Component,
args: [{ standalone: true, selector: 'tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]', imports: [NgForOf, NgIf, PolymorpheusOutlet, TuiDataList, TuiElement, TuiLoader], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsDataListAccessor(TuiDataListWrapperComponent)], template: "<tui-data-list\n *ngIf=\"items; else loading\"\n [emptyContent]=\"emptyContent\"\n [size]=\"size\"\n>\n <ng-container *ngIf=\"newOptionMode; else legacyOptionFallback\">\n <button\n *ngFor=\"let item of $cast(items)\"\n #elementRef=\"elementRef\"\n new\n tuiElement\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n (click.capture)=\"itemClick.emit(item)\"\n >\n <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n {{ text }}\n </ng-container>\n </button>\n </ng-container>\n\n <!-- TODO(v5): delete fallback -->\n <ng-template #legacyOptionFallback>\n <button\n *ngFor=\"let item of $cast(items)\"\n #elementRef=\"elementRef\"\n automation-id=\"tui-data-list-wrapper__option\"\n tuiElement\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n (click)=\"itemClick.emit(item)\"\n >\n <span class=\"t-content\">\n <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n {{ text }}\n </ng-container>\n </span>\n </button>\n </ng-template>\n</tui-data-list>\n<ng-template #loading>\n <tui-loader\n automation-id=\"tui-data-list-wrapper__loader\"\n class=\"t-loader\"\n />\n</ng-template>\n", styles: [":host{display:block}.t-content{flex:1;min-inline-size:0}.t-loader{margin:.75rem 0}\n"] }]
}], propDecorators: { legacyOptionsQuery: [{
type: ViewChildren,
args: [forwardRef(() => TuiOption)]
}], optionsQuery: [{
type: ViewChildren,
args: [forwardRef(() => TuiOptionWithValue)]
}], items: [{
type: Input
}], disabledItemHandler: [{
type: Input
}], emptyContent: [{
type: Input
}], size: [{
type: Input
}], itemClick: [{
type: Output
}], itemContent: [{
type: Input
}], datalistSetter: [{
type: ViewChild,
args: [TuiDataListComponent]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list-wrapper.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/data-list-wrapper/data-list-wrapper.component.ts","../../../../../projects/kit/components/data-list-wrapper/data-list-wrapper.template.html"],"names":[],"mappings":"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","sourcesContent":["import {NgForOf, NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    type ElementRef,\n    EventEmitter,\n    forwardRef,\n    inject,\n    Input,\n    isSignal,\n    Output,\n    type QueryList,\n    signal,\n    ViewChild,\n    ViewChildren,\n} from '@angular/core';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiElement} from '@taiga-ui/cdk/directives/element';\nimport {type TuiBooleanHandler} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocused} from '@taiga-ui/cdk/utils/focus';\nimport {tuiIsPresent} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {\n    tuiAsDataListAccessor,\n    TuiDataList,\n    type TuiDataListAccessor,\n    TuiDataListComponent,\n    tuiInjectDataListSize,\n    TuiOption,\n    TuiOptionWithValue,\n} from '@taiga-ui/core/components/data-list';\nimport {TuiLoader} from '@taiga-ui/core/components/loader';\nimport {\n    TUI_ITEMS_HANDLERS,\n    type TuiItemsHandlers,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {type TuiValueContentContext} from '@taiga-ui/core/types';\nimport {\n    TUI_ITEMS_HANDLERS as TUI_ITEMS_HANDLERS_LEGACY,\n    type TuiItemsHandlers as TuiItemsHandlersLegacy,\n} from '@taiga-ui/kit/tokens';\nimport {type PolymorpheusContent, PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\n@Component({\n    standalone: true,\n    selector:\n        'tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]', // TODO(v5): remove [new]\n    imports: [NgForOf, NgIf, PolymorpheusOutlet, TuiDataList, TuiElement, TuiLoader],\n    templateUrl: './data-list-wrapper.template.html',\n    styleUrls: ['./data-list-wrapper.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsDataListAccessor(TuiDataListWrapperComponent)],\n})\nexport class TuiDataListWrapperComponent<T, K = T> implements TuiDataListAccessor<T> {\n    private readonly datalist = signal<TuiDataListComponent<T> | null>(null);\n    private readonly itemsHandlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n    // TODO(v5): delete\n    private readonly itemsHandlersLegacy: TuiItemsHandlersLegacy<T> = inject(\n        TUI_ITEMS_HANDLERS_LEGACY,\n    );\n\n    // TODO(v5): delete\n    @ViewChildren(forwardRef(() => TuiOption))\n    protected readonly legacyOptionsQuery: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    // TODO(v5): delete\n    @ViewChildren(forwardRef(() => TuiOptionWithValue))\n    protected readonly optionsQuery: QueryList<TuiOptionWithValue<T>> = EMPTY_QUERY;\n\n    protected readonly newOptionMode = tuiInjectElement().hasAttribute('new');\n\n    @Input()\n    public items: readonly K[] | null = [];\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<T> = this.newOptionMode\n        ? this.itemsHandlers?.disabledItemHandler()\n        : this.itemsHandlersLegacy.disabledItemHandler;\n\n    @Input()\n    public emptyContent: PolymorpheusContent;\n\n    @Input()\n    public size = tuiInjectDataListSize();\n\n    @Output()\n    public readonly itemClick = new EventEmitter<T>();\n\n    public readonly options = computed(() => this.datalist()?.options() ?? []);\n\n    @Input()\n    public itemContent: PolymorpheusContent<TuiValueContentContext<T>> = ({$implicit}) =>\n        this.newOptionMode\n            ? this.itemsHandlers.stringify()($implicit)\n            : this.itemsHandlersLegacy.stringify($implicit);\n\n    public getContext(\n        $implicit: T,\n        {nativeElement}: ElementRef<HTMLElement>,\n    ): TuiValueContentContext<T> {\n        return {$implicit, active: tuiIsNativeFocused(nativeElement)};\n    }\n\n    // TODO(v5): delete\n    public getOptions(includeDisabled = false): readonly T[] {\n        return [\n            ...this.legacyOptionsQuery, // TODO(v5): delete\n            ...this.optionsQuery,\n        ]\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => (isSignal(value) ? value() : value))\n            .filter(tuiIsPresent);\n    }\n\n    // TODO(v5): use signal `viewChild`\n    @ViewChild(TuiDataListComponent)\n    protected set datalistSetter(x: TuiDataListComponent<T>) {\n        this.datalist.set(x);\n    }\n\n    protected $cast(items: readonly K[]): readonly T[] {\n        return items as unknown as readonly T[];\n    }\n}\n","<tui-data-list\n    *ngIf=\"items; else loading\"\n    [emptyContent]=\"emptyContent\"\n    [size]=\"size\"\n>\n    <ng-container *ngIf=\"newOptionMode; else legacyOptionFallback\">\n        <button\n            *ngFor=\"let item of $cast(items)\"\n            #elementRef=\"elementRef\"\n            new\n            tuiElement\n            tuiOption\n            type=\"button\"\n            [disabled]=\"disabledItemHandler(item)\"\n            [value]=\"item\"\n            (click.capture)=\"itemClick.emit(item)\"\n        >\n            <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n                {{ text }}\n            </ng-container>\n        </button>\n    </ng-container>\n\n    <!-- TODO(v5): delete fallback -->\n    <ng-template #legacyOptionFallback>\n        <button\n            *ngFor=\"let item of $cast(items)\"\n            #elementRef=\"elementRef\"\n            automation-id=\"tui-data-list-wrapper__option\"\n            tuiElement\n            tuiOption\n            type=\"button\"\n            [disabled]=\"disabledItemHandler(item)\"\n            [value]=\"item\"\n            (click)=\"itemClick.emit(item)\"\n        >\n            <span class=\"t-content\">\n                <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n                    {{ text }}\n                </ng-container>\n            </span>\n        </button>\n    </ng-template>\n</tui-data-list>\n<ng-template #loading>\n    <tui-loader\n        automation-id=\"tui-data-list-wrapper__loader\"\n        class=\"t-loader\"\n    />\n</ng-template>\n"]}