@taiga-ui/kit
Version:
Taiga UI Angular main components kit
77 lines • 15.2 kB
JavaScript
import { AsyncPipe, NgForOf, NgIf, NgTemplateOutlet } from '@angular/common';
import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, inject, Output, TemplateRef, } from '@angular/core';
import { toSignal } from '@angular/core/rxjs-interop';
import { MutationObserverService, WA_MUTATION_OBSERVER_INIT, } from '@ng-web-apis/mutation-observer';
import { ResizeObserverService } from '@ng-web-apis/resize-observer';
import { EMPTY_QUERY } from '@taiga-ui/cdk/constants';
import { TuiItem } from '@taiga-ui/cdk/directives/item';
import { TuiItemsWithMoreDirective } from './items-with-more.directive';
import { TuiItemsWithMoreService } from './items-with-more.service';
import { TuiMore } from './more.directive';
import * as i0 from "@angular/core";
import * as i1 from "./items-with-more.directive";
class TuiItemsWithMoreComponent {
constructor() {
this.items = EMPTY_QUERY;
this.directive = inject(TuiItemsWithMoreDirective);
this.lastIndexChange = inject(TuiItemsWithMoreService);
this.lastIndex = toSignal(this.lastIndexChange, {
initialValue: 0,
});
}
get isMoreHidden() {
const { computedSide } = this.directive;
return ((this.lastIndex() >= this.items.length - 1 && computedSide === 'end') ||
(!this.lastIndex() && computedSide === 'start'));
}
isHidden(index) {
const { computedSide, required } = this.directive;
return ((index > this.lastIndex() && index !== required && computedSide === 'end') ||
(index < this.lastIndex() && index !== required && computedSide === 'start'));
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiItemsWithMoreComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiItemsWithMoreComponent, isStandalone: true, selector: "tui-items-with-more", outputs: { lastIndexChange: "lastIndexChange" }, providers: [
MutationObserverService,
ResizeObserverService,
TuiItemsWithMoreService,
{
provide: WA_MUTATION_OBSERVER_INIT,
useValue: {
childList: true,
characterData: true,
subtree: true,
},
},
], queries: [{ propertyName: "more", first: true, predicate: TuiMore, descendants: true, read: TemplateRef }, { propertyName: "items", predicate: TuiItem, descendants: true, read: TemplateRef }], hostDirectives: [{ directive: i1.TuiItemsWithMoreDirective, inputs: ["itemsLimit", "itemsLimit", "required", "required", "side", "side", "linesLimit", "linesLimit"] }], ngImport: i0, template: "<ng-container *ngIf=\"items.changes | async\" />\n<ng-container\n *ngIf=\"directive.side === 'start'\"\n [ngTemplateOutlet]=\"template\"\n/>\n<div\n *ngFor=\"let item of items; let index = index\"\n class=\"t-item\"\n [class.t-item_hidden]=\"isHidden(index)\"\n>\n <ng-container *ngTemplateOutlet=\"item\" />\n</div>\n<ng-container\n *ngIf=\"directive.side === 'end'\"\n [ngTemplateOutlet]=\"template\"\n/>\n<ng-template #template>\n <span\n *ngIf=\"!isMoreHidden\"\n class=\"t-item t-item_more\"\n >\n <ng-container\n [ngTemplateOutlet]=\"more || null\"\n [ngTemplateOutletContext]=\"{$implicit: lastIndex()}\"\n />\n </span>\n</ng-template>\n", styles: [":host{position:relative;display:flex;min-inline-size:0;flex:1;align-items:center;white-space:nowrap}:host._multiline{flex-wrap:wrap}.t-item{flex:0 0 auto}.t-item_hidden{position:absolute;bottom:0;visibility:hidden}:host._multiline .t-item_more:not(:empty){min-inline-size:var(--t-min-width, 0)}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
export { TuiItemsWithMoreComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiItemsWithMoreComponent, decorators: [{
type: Component,
args: [{ standalone: true, selector: 'tui-items-with-more', imports: [AsyncPipe, NgForOf, NgIf, NgTemplateOutlet], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
MutationObserverService,
ResizeObserverService,
TuiItemsWithMoreService,
{
provide: WA_MUTATION_OBSERVER_INIT,
useValue: {
childList: true,
characterData: true,
subtree: true,
},
},
], hostDirectives: [
{
directive: TuiItemsWithMoreDirective,
inputs: ['itemsLimit', 'required', 'side', 'linesLimit'],
},
], template: "<ng-container *ngIf=\"items.changes | async\" />\n<ng-container\n *ngIf=\"directive.side === 'start'\"\n [ngTemplateOutlet]=\"template\"\n/>\n<div\n *ngFor=\"let item of items; let index = index\"\n class=\"t-item\"\n [class.t-item_hidden]=\"isHidden(index)\"\n>\n <ng-container *ngTemplateOutlet=\"item\" />\n</div>\n<ng-container\n *ngIf=\"directive.side === 'end'\"\n [ngTemplateOutlet]=\"template\"\n/>\n<ng-template #template>\n <span\n *ngIf=\"!isMoreHidden\"\n class=\"t-item t-item_more\"\n >\n <ng-container\n [ngTemplateOutlet]=\"more || null\"\n [ngTemplateOutletContext]=\"{$implicit: lastIndex()}\"\n />\n </span>\n</ng-template>\n", styles: [":host{position:relative;display:flex;min-inline-size:0;flex:1;align-items:center;white-space:nowrap}:host._multiline{flex-wrap:wrap}.t-item{flex:0 0 auto}.t-item_hidden{position:absolute;bottom:0;visibility:hidden}:host._multiline .t-item_more:not(:empty){min-inline-size:var(--t-min-width, 0)}\n"] }]
}], propDecorators: { items: [{
type: ContentChildren,
args: [TuiItem, { read: TemplateRef, descendants: true }]
}], more: [{
type: ContentChild,
args: [TuiMore, { read: TemplateRef }]
}], lastIndexChange: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"items-with-more.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/items-with-more/items-with-more.component.ts","../../../../../projects/kit/components/items-with-more/items-with-more.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgForOf, NgIf, NgTemplateOutlet} from '@angular/common';\nimport type {QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ContentChildren,\n    inject,\n    Output,\n    TemplateRef,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {\n    MutationObserverService,\n    WA_MUTATION_OBSERVER_INIT,\n} from '@ng-web-apis/mutation-observer';\nimport {ResizeObserverService} from '@ng-web-apis/resize-observer';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiItem} from '@taiga-ui/cdk/directives/item';\nimport type {TuiContext} from '@taiga-ui/cdk/types';\n\nimport {TuiItemsWithMoreDirective} from './items-with-more.directive';\nimport {TuiItemsWithMoreService} from './items-with-more.service';\nimport {TuiMore} from './more.directive';\n\n@Component({\n    standalone: true,\n    selector: 'tui-items-with-more',\n    imports: [AsyncPipe, NgForOf, NgIf, NgTemplateOutlet],\n    templateUrl: './items-with-more.template.html',\n    styleUrls: ['./items-with-more.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        MutationObserverService,\n        ResizeObserverService,\n        TuiItemsWithMoreService,\n        {\n            provide: WA_MUTATION_OBSERVER_INIT,\n            useValue: {\n                childList: true,\n                characterData: true,\n                subtree: true,\n            },\n        },\n    ],\n    hostDirectives: [\n        {\n            directive: TuiItemsWithMoreDirective,\n            inputs: ['itemsLimit', 'required', 'side', 'linesLimit'],\n        },\n    ],\n})\nexport class TuiItemsWithMoreComponent {\n    @ContentChildren(TuiItem, {read: TemplateRef, descendants: true})\n    protected readonly items: QueryList<TemplateRef<unknown>> = EMPTY_QUERY;\n\n    @ContentChild(TuiMore, {read: TemplateRef})\n    protected readonly more?: TemplateRef<TuiContext<number>>;\n\n    protected readonly directive = inject(TuiItemsWithMoreDirective);\n\n    @Output()\n    public readonly lastIndexChange = inject(TuiItemsWithMoreService);\n\n    public readonly lastIndex = toSignal(this.lastIndexChange, {\n        initialValue: 0,\n    });\n\n    protected get isMoreHidden(): boolean {\n        const {computedSide} = this.directive;\n\n        return (\n            (this.lastIndex() >= this.items.length - 1 && computedSide === 'end') ||\n            (!this.lastIndex() && computedSide === 'start')\n        );\n    }\n\n    protected isHidden(index: number): boolean {\n        const {computedSide, required} = this.directive;\n\n        return (\n            (index > this.lastIndex() && index !== required && computedSide === 'end') ||\n            (index < this.lastIndex() && index !== required && computedSide === 'start')\n        );\n    }\n}\n","<ng-container *ngIf=\"items.changes | async\" />\n<ng-container\n    *ngIf=\"directive.side === 'start'\"\n    [ngTemplateOutlet]=\"template\"\n/>\n<div\n    *ngFor=\"let item of items; let index = index\"\n    class=\"t-item\"\n    [class.t-item_hidden]=\"isHidden(index)\"\n>\n    <ng-container *ngTemplateOutlet=\"item\" />\n</div>\n<ng-container\n    *ngIf=\"directive.side === 'end'\"\n    [ngTemplateOutlet]=\"template\"\n/>\n<ng-template #template>\n    <span\n        *ngIf=\"!isMoreHidden\"\n        class=\"t-item t-item_more\"\n    >\n        <ng-container\n            [ngTemplateOutlet]=\"more || null\"\n            [ngTemplateOutletContext]=\"{$implicit: lastIndex()}\"\n        />\n    </span>\n</ng-template>\n"]}