UNPKG

@taiga-ui/kit

Version:
105 lines 15.1 kB
import { __decorate, __param } from "tslib"; import { ChangeDetectionStrategy, Component, ContentChildren, Inject, Input, } from '@angular/core'; import { NgControl } from '@angular/forms'; import { EMPTY_QUERY, getOriginalArrayFromQueryList, isPresent, itemsQueryListObservable, TUI_DEFAULT_IDENTITY_MATCHER, tuiDefaultProp, tuiPure, tuiReplayedValueChangesFrom, } from '@taiga-ui/cdk'; import { sizeBigger, TUI_DATA_LIST_HOST, TuiOptionComponent, } from '@taiga-ui/core'; import { combineLatest } from 'rxjs'; import { map } from 'rxjs/operators'; let TuiMultiSelectGroupComponent = class TuiMultiSelectGroupComponent { constructor(host, control) { this.host = host; this.control = control; this.label = ''; this.options = EMPTY_QUERY; } get size() { return (this.options.first && this.options.first.size) || 'm'; } get checkboxSize() { return this.options.first && sizeBigger(this.options.first.size) ? 'l' : 'm'; } get empty$() { return itemsQueryListObservable(this.options).pipe(map(({ length }) => !length)); } get disabled$() { return itemsQueryListObservable(this.options).pipe(map(items => items.every(({ disabled }) => disabled))); } get value$() { return combineLatest(this.items$, this.valueChanges$).pipe(map(([items, current]) => { let result = false; for (let i = 0; i < items.length; i++) { const selected = current.some(selected => this.matcher(selected, items[i])); if ((!selected && result) || (selected && !result && i)) { return null; } result = selected; } return result; })); } onClick(checked) { if (!this.control.control) { return; } const controlValue = this.control.value || []; const { values } = this; const filtered = controlValue.filter(current => values.every(item => !this.matcher(current, item))); this.control.control.setValue(checked ? filtered : [...filtered, ...values]); } get values() { return this.filter(getOriginalArrayFromQueryList(this.options)); } get matcher() { return this.host.identityMatcher || TUI_DEFAULT_IDENTITY_MATCHER; } get items$() { return itemsQueryListObservable(this.options).pipe(map(options => options.map(({ value }) => value).filter(isPresent))); } get valueChanges$() { return tuiReplayedValueChangesFrom(this.control).pipe(map(value => value || [])); } filter(items) { return items.map(({ value }) => value).filter(isPresent); } }; TuiMultiSelectGroupComponent.ctorParameters = () => [ { type: undefined, decorators: [{ type: Inject, args: [TUI_DATA_LIST_HOST,] }] }, { type: NgControl, decorators: [{ type: Inject, args: [NgControl,] }] } ]; __decorate([ Input(), tuiDefaultProp() ], TuiMultiSelectGroupComponent.prototype, "label", void 0); __decorate([ ContentChildren(TuiOptionComponent) ], TuiMultiSelectGroupComponent.prototype, "options", void 0); __decorate([ tuiPure ], TuiMultiSelectGroupComponent.prototype, "empty$", null); __decorate([ tuiPure ], TuiMultiSelectGroupComponent.prototype, "disabled$", null); __decorate([ tuiPure ], TuiMultiSelectGroupComponent.prototype, "value$", null); __decorate([ tuiPure ], TuiMultiSelectGroupComponent.prototype, "items$", null); __decorate([ tuiPure ], TuiMultiSelectGroupComponent.prototype, "valueChanges$", null); __decorate([ tuiPure ], TuiMultiSelectGroupComponent.prototype, "filter", null); TuiMultiSelectGroupComponent = __decorate([ Component({ selector: 'tui-opt-group[tuiMultiSelectGroup]', template: "<ng-container *tuiLet=\"value$ | async as value\">\n <button\n *ngIf=\"label && !(empty$ | async)\"\n tuiMultiSelectGroupReset\n tuiOption\n [size]=\"size\"\n [disabled]=\"disabled$ | async\"\n (click)=\"onClick(value)\"\n >\n <tui-primitive-checkbox\n class=\"tui-space_right-3\"\n [size]=\"checkboxSize\"\n [value]=\"value\"\n ></tui-primitive-checkbox>\n <span class=\"label\">{{label}}</span>\n </button>\n</ng-container>\n<ng-content></ng-content>\n", changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:flex;flex-direction:column}:host:before{content:''}.label{font:var(--tui-font-text-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;color:var(--tui-text-02)}"] }), __param(0, Inject(TUI_DATA_LIST_HOST)), __param(1, Inject(NgControl)) ], TuiMultiSelectGroupComponent); export { TuiMultiSelectGroupComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-group.component.js","sourceRoot":"ng://@taiga-ui/kit/components/multi-select/","sources":["multi-select-group/multi-select-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    Inject,\n    Input,\n    QueryList,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    EMPTY_QUERY,\n    getOriginalArrayFromQueryList,\n    isPresent,\n    itemsQueryListObservable,\n    TUI_DEFAULT_IDENTITY_MATCHER,\n    tuiDefaultProp,\n    TuiIdentityMatcher,\n    tuiPure,\n    tuiReplayedValueChangesFrom,\n} from '@taiga-ui/cdk';\nimport {\n    sizeBigger,\n    TUI_DATA_LIST_HOST,\n    TuiDataListHost,\n    TuiOptionComponent,\n    TuiSizeL,\n    TuiSizeXS,\n} from '@taiga-ui/core';\nimport {combineLatest, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n@Component({\n    selector: 'tui-opt-group[tuiMultiSelectGroup]',\n    templateUrl: './multi-select-group.template.html',\n    styleUrls: ['./multi-select-group.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiMultiSelectGroupComponent<T> {\n    @Input()\n    @tuiDefaultProp()\n    label = '';\n\n    @ContentChildren(TuiOptionComponent)\n    private readonly options: QueryList<TuiOptionComponent<T>> = EMPTY_QUERY;\n\n    constructor(\n        @Inject(TUI_DATA_LIST_HOST) private readonly host: TuiDataListHost<T>,\n        @Inject(NgControl) private readonly control: NgControl,\n    ) {}\n\n    get size(): TuiSizeXS | TuiSizeL {\n        return (this.options.first && this.options.first.size) || 'm';\n    }\n\n    get checkboxSize(): TuiSizeL {\n        return this.options.first && sizeBigger(this.options.first.size) ? 'l' : 'm';\n    }\n\n    @tuiPure\n    get empty$(): Observable<boolean> {\n        return itemsQueryListObservable(this.options).pipe(map(({length}) => !length));\n    }\n\n    @tuiPure\n    get disabled$(): Observable<boolean> {\n        return itemsQueryListObservable(this.options).pipe(\n            map(items => items.every(({disabled}) => disabled)),\n        );\n    }\n\n    @tuiPure\n    get value$(): Observable<boolean | null> {\n        return combineLatest(this.items$, this.valueChanges$).pipe(\n            map(([items, current]) => {\n                let result = false;\n\n                for (let i = 0; i < items.length; i++) {\n                    const selected = current.some(selected =>\n                        this.matcher(selected, items[i]),\n                    );\n\n                    if ((!selected && result) || (selected && !result && i)) {\n                        return null;\n                    }\n\n                    result = selected;\n                }\n\n                return result;\n            }),\n        );\n    }\n\n    onClick(checked: boolean | null) {\n        if (!this.control.control) {\n            return;\n        }\n\n        const controlValue: ReadonlyArray<T> = this.control.value || [];\n        const {values} = this;\n        const filtered = controlValue.filter(current =>\n            values.every(item => !this.matcher(current, item)),\n        );\n\n        this.control.control.setValue(checked ? filtered : [...filtered, ...values]);\n    }\n\n    private get values(): ReadonlyArray<T> {\n        return this.filter(getOriginalArrayFromQueryList(this.options));\n    }\n\n    private get matcher(): TuiIdentityMatcher<T> {\n        return this.host.identityMatcher || TUI_DEFAULT_IDENTITY_MATCHER;\n    }\n\n    @tuiPure\n    private get items$(): Observable<ReadonlyArray<T>> {\n        return itemsQueryListObservable(this.options).pipe(\n            map(options => options.map(({value}) => value).filter(isPresent)),\n        );\n    }\n\n    @tuiPure\n    private get valueChanges$(): Observable<ReadonlyArray<T>> {\n        return tuiReplayedValueChangesFrom<ReadonlyArray<T>>(this.control).pipe(\n            map(value => value || []),\n        );\n    }\n\n    @tuiPure\n    private filter(items: ReadonlyArray<TuiOptionComponent<T>>): ReadonlyArray<T> {\n        return items.map(({value}) => value).filter(isPresent);\n    }\n}\n"]}