@taiga-ui/kit
Version:
Taiga UI Angular main components kit
68 lines • 12.1 kB
JavaScript
import { __decorate } from "tslib";
import { inject, Pipe } from '@angular/core';
import { TUI_DEFAULT_MATCHER } from '@taiga-ui/cdk/constants';
import { tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
import { TUI_DATA_LIST_HOST } from '@taiga-ui/core/components/data-list';
import { TuiTextfieldComponent } from '@taiga-ui/core/components/textfield';
import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives/items-handlers';
import { tuiIsFlat } from '@taiga-ui/kit/utils';
import * as i0 from "@angular/core";
// TODO: Consider replacing TuiTextfieldComponent with proper token once we refactor textfields
class TuiFilterByInputPipe {
constructor() {
// TODO: Remove optional after legacy controls are dropped
this.textfield = inject(TuiTextfieldComponent, { optional: true });
this.host = inject(TUI_DATA_LIST_HOST);
this.itemsHandlers = inject(TUI_ITEMS_HANDLERS);
}
transform(items, matcher = TUI_DEFAULT_MATCHER) {
return this.filter(items, matcher, (this.textfield
? this.itemsHandlers.stringify()
: // TODO(v5): delete backward compatibility
this.host.stringify) || String, this.textfield?.value() ||
this.host.nativeFocusableElement?.value ||
'');
}
filter(items, matcher, stringify, query) {
if (!items) {
return null;
}
return tuiIsFlat(items)
? this.filterFlat(items, matcher, stringify, query)
: this.filter2d(items, matcher, stringify, query);
}
filterFlat(items, matcher, stringify, query) {
const match = this.getMatch(items, stringify, query);
return match != null
? items
: items.filter((item) => matcher(item, query, stringify));
}
filter2d(items, matcher, stringify, query) {
const match = items.find((item) => this.getMatch(item, stringify, query) != null);
return match != null
? items
: items.map((inner) => this.filterFlat(inner, matcher, stringify, query));
}
getMatch(items, stringify, query) {
// TODO: Refactor when tui-textfield[multi] is ready
if (this.host.tagValidator) {
return undefined;
}
return items.find((item) => stringify(item).toLocaleLowerCase() === query.toLocaleLowerCase());
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiFilterByInputPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: TuiFilterByInputPipe, isStandalone: true, name: "tuiFilterByInput", pure: false }); }
}
__decorate([
tuiPure
], TuiFilterByInputPipe.prototype, "filter", null);
export { TuiFilterByInputPipe };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiFilterByInputPipe, decorators: [{
type: Pipe,
args: [{
standalone: true,
name: 'tuiFilterByInput',
pure: false,
}]
}], propDecorators: { filter: [] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-by-input.pipe.js","sourceRoot":"","sources":["../../../../../projects/kit/pipes/filter-by-input/filter-by-input.pipe.ts"],"names":[],"mappings":";AACA,OAAO,EAAC,MAAM,EAAE,IAAI,EAAC,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAC,mBAAmB,EAAC,MAAM,yBAAyB,CAAC;AAE5D,OAAO,EAAC,OAAO,EAAC,MAAM,mCAAmC,CAAC;AAC1D,OAAO,EAAC,kBAAkB,EAAC,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAC,qBAAqB,EAAC,MAAM,qCAAqC,CAAC;AAE1E,OAAO,EAAC,kBAAkB,EAAC,MAAM,0CAA0C,CAAC;AAC5E,OAAO,EAAC,SAAS,EAAC,MAAM,qBAAqB,CAAC;;AAE9C,+FAA+F;AAC/F,MAKa,oBAAoB;IALjC;QAMI,0DAA0D;QACzC,cAAS,GAAG,MAAM,CAAC,qBAAqB,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;QAC5D,SAAI,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAClC,kBAAa,GAC1B,MAAM,CAAC,kBAAkB,CAAC,CAAC;KAwFlC;IAzEU,SAAS,CACZ,KAAwD,EACxD,UAA+B,mBAAmB;QAElD,OAAO,IAAI,CAAC,MAAM,CACd,KAAK,EACL,OAAO,EACP,CAAC,IAAI,CAAC,SAAS;YACX,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE;YAChC,CAAC,CAAC,0CAA0C;gBAC1C,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,MAAM,EACpC,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE;YAClB,IAAI,CAAC,IAAY,CAAC,sBAAsB,EAAE,KAAK;YAChD,EAAE,CACT,CAAC;IACN,CAAC;IAGO,MAAM,CACV,KAAwD,EACxD,OAA4B,EAC5B,SAA8B,EAC9B,KAAa;QAEb,IAAI,CAAC,KAAK,EAAE;YACR,OAAO,IAAI,CAAC;SACf;QAED,OAAO,SAAS,CAAC,KAAK,CAAC;YACnB,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,CAAC;YACnD,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;IAC1D,CAAC;IAEO,UAAU,CACd,KAAmB,EACnB,OAA4B,EAC5B,SAA8B,EAC9B,KAAa;QAEb,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;QAErD,OAAO,KAAK,IAAI,IAAI;YAChB,CAAC,CAAC,KAAK;YACP,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC;IAClE,CAAC;IAEO,QAAQ,CACZ,KAAkC,EAClC,OAA4B,EAC5B,SAA8B,EAC9B,KAAa;QAEb,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC;QAElF,OAAO,KAAK,IAAI,IAAI;YAChB,CAAC,CAAC,KAAK;YACP,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC;IAClF,CAAC;IAEO,QAAQ,CACZ,KAAmB,EACnB,SAA8B,EAC9B,KAAa;QAEb,oDAAoD;QACpD,IAAK,IAAI,CAAC,IAAY,CAAC,YAAY,EAAE;YACjC,OAAO,SAAS,CAAC;SACpB;QAED,OAAO,KAAK,CAAC,IAAI,CACb,CAAC,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,iBAAiB,EAAE,KAAK,KAAK,CAAC,iBAAiB,EAAE,CAC9E,CAAC;IACN,CAAC;+GA5FQ,oBAAoB;6GAApB,oBAAoB;;AAsCrB;IADP,OAAO;kDAcP;SAnDQ,oBAAoB;4FAApB,oBAAoB;kBALhC,IAAI;mBAAC;oBACF,UAAU,EAAE,IAAI;oBAChB,IAAI,EAAE,kBAAkB;oBACxB,IAAI,EAAE,KAAK;iBACd;8BAuCW,MAAM","sourcesContent":["import type {PipeTransform} from '@angular/core';\nimport {inject, Pipe} from '@angular/core';\nimport {TUI_DEFAULT_MATCHER} from '@taiga-ui/cdk/constants';\nimport type {TuiStringHandler, TuiStringMatcher} from '@taiga-ui/cdk/types';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TUI_DATA_LIST_HOST} from '@taiga-ui/core/components/data-list';\nimport {TuiTextfieldComponent} from '@taiga-ui/core/components/textfield';\nimport type {TuiItemsHandlers} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_ITEMS_HANDLERS} from '@taiga-ui/core/directives/items-handlers';\nimport {tuiIsFlat} from '@taiga-ui/kit/utils';\n\n// TODO: Consider replacing TuiTextfieldComponent with proper token once we refactor textfields\n@Pipe({\n    standalone: true,\n    name: 'tuiFilterByInput',\n    pure: false,\n})\nexport class TuiFilterByInputPipe implements PipeTransform {\n    // TODO: Remove optional after legacy controls are dropped\n    private readonly textfield = inject(TuiTextfieldComponent, {optional: true});\n    private readonly host = inject(TUI_DATA_LIST_HOST);\n    private readonly itemsHandlers: TuiItemsHandlers<unknown> =\n        inject(TUI_ITEMS_HANDLERS);\n\n    public transform<T>(\n        items: ReadonlyArray<readonly T[]>,\n        matcher?: TuiStringMatcher<T>,\n    ): ReadonlyArray<readonly T[]>;\n    public transform<T>(items: readonly T[], matcher?: TuiStringMatcher<T>): readonly T[];\n    public transform<T>(\n        items: ReadonlyArray<readonly T[]> | null,\n        matcher?: TuiStringMatcher<T>,\n    ): ReadonlyArray<readonly T[]> | null;\n    public transform<T>(\n        items: readonly T[] | null,\n        matcher?: TuiStringMatcher<T>,\n    ): readonly T[] | null;\n    public transform<T>(\n        items: ReadonlyArray<readonly T[]> | readonly T[] | null,\n        matcher: TuiStringMatcher<T> = TUI_DEFAULT_MATCHER,\n    ): ReadonlyArray<readonly T[]> | readonly T[] | null {\n        return this.filter<T>(\n            items,\n            matcher,\n            (this.textfield\n                ? this.itemsHandlers.stringify()\n                : // TODO(v5): delete backward compatibility\n                  this.host.stringify) || String,\n            this.textfield?.value() ||\n                (this.host as any).nativeFocusableElement?.value ||\n                '',\n        );\n    }\n\n    @tuiPure\n    private filter<T>(\n        items: ReadonlyArray<readonly T[]> | readonly T[] | null,\n        matcher: TuiStringMatcher<T>,\n        stringify: TuiStringHandler<T>,\n        query: string,\n    ): ReadonlyArray<readonly T[]> | readonly T[] | null {\n        if (!items) {\n            return null;\n        }\n\n        return tuiIsFlat(items)\n            ? this.filterFlat(items, matcher, stringify, query)\n            : this.filter2d(items, matcher, stringify, query);\n    }\n\n    private filterFlat<T>(\n        items: readonly T[],\n        matcher: TuiStringMatcher<T>,\n        stringify: TuiStringHandler<T>,\n        query: string,\n    ): readonly T[] {\n        const match = this.getMatch(items, stringify, query);\n\n        return match != null\n            ? items\n            : items.filter((item) => matcher(item, query, stringify));\n    }\n\n    private filter2d<T>(\n        items: ReadonlyArray<readonly T[]>,\n        matcher: TuiStringMatcher<T>,\n        stringify: TuiStringHandler<T>,\n        query: string,\n    ): ReadonlyArray<readonly T[]> {\n        const match = items.find((item) => this.getMatch(item, stringify, query) != null);\n\n        return match != null\n            ? items\n            : items.map((inner) => this.filterFlat(inner, matcher, stringify, query));\n    }\n\n    private getMatch<T>(\n        items: readonly T[],\n        stringify: TuiStringHandler<T>,\n        query: string,\n    ): T | undefined {\n        // TODO: Refactor when tui-textfield[multi] is ready\n        if ((this.host as any).tagValidator) {\n            return undefined;\n        }\n\n        return items.find(\n            (item) => stringify(item).toLocaleLowerCase() === query.toLocaleLowerCase(),\n        );\n    }\n}\n"]}