UNPKG

@taiga-ui/kit

Version:
277 lines • 34.9 kB
import { __decorate, __extends, __param, __read, __spread } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, forwardRef, HostBinding, Inject, Input, Optional, Output, Self, TemplateRef, ViewChild, } from '@angular/core'; import { NgControl } from '@angular/forms'; import { AbstractTuiMultipleControl, ALWAYS_FALSE_HANDLER, EMPTY_ARRAY, isNativeFocused, setNativeFocused, TUI_DEFAULT_IDENTITY_MATCHER, TUI_DEFAULT_STRINGIFY, TUI_FOCUSABLE_ITEM_ACCESSOR, tuiDefaultProp, tuiPure, } from '@taiga-ui/cdk'; import { TUI_DATA_LIST_ACCESSOR, TUI_DATA_LIST_HOST, TUI_TEXTFIELD_LABEL_OUTSIDE, TuiDataListAccessor, TuiDataListDirective, TuiDataListHost, TuiHostedDropdownComponent, TuiSvgService, TuiTextfieldLabelOutsideDirective, } from '@taiga-ui/core'; import { TuiStringifiableItem } from '@taiga-ui/kit/classes'; import { TuiInputTagComponent } from '@taiga-ui/kit/components/input-tag'; import { iconBlank } from '@taiga-ui/kit/constants'; import { FIXED_DROPDOWN_CONTROLLER_PROVIDER } from '@taiga-ui/kit/providers'; var TuiMultiSelectComponent = /** @class */ (function (_super) { __extends(TuiMultiSelectComponent, _super); function TuiMultiSelectComponent(control, changeDetectorRef, svgService, textfieldLabelOutside) { var _this = _super.call(this, control, changeDetectorRef) || this; _this.textfieldLabelOutside = textfieldLabelOutside; _this.stringify = TUI_DEFAULT_STRINGIFY; _this.identityMatcher = TUI_DEFAULT_IDENTITY_MATCHER; _this.expandable = true; _this.search = ''; _this.editable = true; _this.disabledItemHandler = ALWAYS_FALSE_HANDLER; _this.valueContent = ''; _this.searchChange = new EventEmitter(); _this.open = false; _this.valueMapper = function (value, stringify, group) { return group ? EMPTY_ARRAY : value.map(function (item) { return new TuiStringifiableItem(item, stringify); }); }; _this.disabledItemHandlerWrapper = function (handler) { return function (stringifiable) { return typeof stringifiable === 'string' || handler(stringifiable.item); }; }; _this.datalist = ''; svgService.define({ iconBlank: iconBlank }); return _this; } TuiMultiSelectComponent_1 = TuiMultiSelectComponent; Object.defineProperty(TuiMultiSelectComponent.prototype, "nativeFocusableElement", { get: function () { return this.input ? this.input.nativeFocusableElement : null; }, enumerable: true, configurable: true }); Object.defineProperty(TuiMultiSelectComponent.prototype, "focused", { get: function () { return ((!!this.input && this.input.focused) || (!!this.hostedDropdown && this.hostedDropdown.focused)); }, enumerable: true, configurable: true }); Object.defineProperty(TuiMultiSelectComponent.prototype, "computedValue", { get: function () { return this.computedGroup ? EMPTY_ARRAY : this.value; }, enumerable: true, configurable: true }); Object.defineProperty(TuiMultiSelectComponent.prototype, "searchOrSpace", { // @bad TODO: think of a better way get: function () { return this.computedGroup ? ' ' : this.searchString; }, enumerable: true, configurable: true }); Object.defineProperty(TuiMultiSelectComponent.prototype, "searchString", { get: function () { return this.search === null ? '' : this.search; }, enumerable: true, configurable: true }); Object.defineProperty(TuiMultiSelectComponent.prototype, "tagIcon", { get: function () { return this.interactive ? 'iconBlank' : 'tuiIconChevronDownLarge'; }, enumerable: true, configurable: true }); Object.defineProperty(TuiMultiSelectComponent.prototype, "interactive", { get: function () { return !this.disabled && !this.readOnly; }, enumerable: true, configurable: true }); Object.defineProperty(TuiMultiSelectComponent.prototype, "inputHidden", { get: function () { return !this.editable && !this.computedGroup; }, enumerable: true, configurable: true }); Object.defineProperty(TuiMultiSelectComponent.prototype, "computedGroup", { get: function () { return (!!this.valueContent && this.value.length > 0 && (!this.focused || !this.editable)); }, enumerable: true, configurable: true }); Object.defineProperty(TuiMultiSelectComponent.prototype, "context", { get: function () { return this.getContext(this.value); }, enumerable: true, configurable: true }); TuiMultiSelectComponent.prototype.getStringifier = function (stringify) { return function (_a) { var $implicit = _a.$implicit; return stringify($implicit); }; }; TuiMultiSelectComponent.prototype.onHoveredChange = function (hovered) { this.updateHovered(hovered); }; TuiMultiSelectComponent.prototype.onSpace = function (event) { if (!this.editable) { event.preventDefault(); } if (!this.readOnly) { this.open = true; } }; TuiMultiSelectComponent.prototype.handleOption = function (option) { var _a = this, value = _a.value, identityMatcher = _a.identityMatcher; var index = value.findIndex(function (item) { return identityMatcher(item, option); }); this.updateValue(index === -1 ? __spread(value, [option]) : __spread(value.slice(0, index), value.slice(index + 1))); this.updateSearch(null); }; TuiMultiSelectComponent.prototype.onEnter = function (event) { var value = this.value; var options = this.accessor ? this.accessor.getOptions() : []; if (options.length !== 1) { return; } var index = value.indexOf(options[0]); event.preventDefault(); this.updateValue(index === -1 ? __spread(value, [options[0]]) : __spread(value.slice(0, index), value.slice(index + 1))); this.updateSearch(null); }; TuiMultiSelectComponent.prototype.onClick = function (_a) { var nativeFocusableElement = _a.nativeFocusableElement; if (this.interactive && nativeFocusableElement && isNativeFocused(nativeFocusableElement)) { this.open = !this.open; } }; TuiMultiSelectComponent.prototype.onArrowClick = function () { this.open = !this.open; this.focusInput(); }; TuiMultiSelectComponent.prototype.onInput = function (value) { this.updateValue(value.map(function (_a) { var item = _a.item; return item; })); }; TuiMultiSelectComponent.prototype.onSearch = function (search) { this.open = true; this.updateSearch(search); }; TuiMultiSelectComponent.prototype.onActiveZone = function (active) { this.updateFocused(active); }; TuiMultiSelectComponent.prototype.setDisabledState = function () { _super.prototype.setDisabledState.call(this); this.open = false; }; TuiMultiSelectComponent.prototype.updateSearch = function (search) { if (this.search === search) { return; } this.search = search; this.searchChange.emit(search); }; TuiMultiSelectComponent.prototype.focusInput = function (preventScroll) { if (preventScroll === void 0) { preventScroll = false; } if (this.nativeFocusableElement) { setNativeFocused(this.nativeFocusableElement, true, preventScroll); } }; TuiMultiSelectComponent.prototype.getContext = function ($implicit) { return { $implicit: $implicit }; }; var TuiMultiSelectComponent_1; TuiMultiSelectComponent.ctorParameters = function () { return [ { type: NgControl, decorators: [{ type: Optional }, { type: Self }, { type: Inject, args: [NgControl,] }] }, { type: ChangeDetectorRef, decorators: [{ type: Inject, args: [ChangeDetectorRef,] }] }, { type: TuiSvgService, decorators: [{ type: Inject, args: [TuiSvgService,] }] }, { type: TuiTextfieldLabelOutsideDirective, decorators: [{ type: Inject, args: [TUI_TEXTFIELD_LABEL_OUTSIDE,] }] } ]; }; __decorate([ Input(), tuiDefaultProp() ], TuiMultiSelectComponent.prototype, "stringify", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiMultiSelectComponent.prototype, "identityMatcher", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiMultiSelectComponent.prototype, "expandable", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiMultiSelectComponent.prototype, "search", void 0); __decorate([ Input(), HostBinding('class._editable'), tuiDefaultProp() ], TuiMultiSelectComponent.prototype, "editable", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiMultiSelectComponent.prototype, "disabledItemHandler", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiMultiSelectComponent.prototype, "valueContent", void 0); __decorate([ Output() ], TuiMultiSelectComponent.prototype, "searchChange", void 0); __decorate([ ContentChild(TuiDataListDirective, { read: TemplateRef }) ], TuiMultiSelectComponent.prototype, "datalist", void 0); __decorate([ ContentChild(TUI_DATA_LIST_ACCESSOR) ], TuiMultiSelectComponent.prototype, "accessor", void 0); __decorate([ ViewChild(TuiHostedDropdownComponent) ], TuiMultiSelectComponent.prototype, "hostedDropdown", void 0); __decorate([ ViewChild(TuiInputTagComponent) ], TuiMultiSelectComponent.prototype, "input", void 0); __decorate([ tuiPure ], TuiMultiSelectComponent.prototype, "getStringifier", null); __decorate([ tuiPure ], TuiMultiSelectComponent.prototype, "getContext", null); TuiMultiSelectComponent = TuiMultiSelectComponent_1 = __decorate([ Component({ selector: 'tui-multi-select', template: "<tui-hosted-dropdown\n class=\"wrapper\"\n [canOpen]=\"interactive\"\n [content]=\"datalist || ''\"\n [(open)]=\"open\"\n (tuiHoveredChange)=\"onHoveredChange($event)\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n <tui-input-tag\n tuiHostedDropdownHost\n #inputTag\n automation-id=\"tui-multi-select__input\"\n class=\"input\"\n [nativeId]=\"nativeId\"\n [icon]=\"tagIcon\"\n [disabled]=\"disabled\"\n [disabledItemHandler]=\"disabledItemHandler | tuiMapper : disabledItemHandlerWrapper\"\n [readOnly]=\"readOnly\"\n [inputHidden]=\"!editable\"\n [pseudoHovered]=\"hovered\"\n [pseudoFocused]=\"focused\"\n [pseudoInvalid]=\"computedInvalid\"\n [editable]=\"false\"\n [expandable]=\"expandable\"\n [search]=\"searchOrSpace\"\n [ngModel]=\"computedValue | tuiMapper: valueMapper: stringify\"\n (ngModelChange)=\"onInput($event)\"\n (searchChange)=\"onSearch($event)\"\n (keydown.space)=\"onSpace($event)\"\n (keydown.enter)=\"onEnter($event)\"\n (click.stop)=\"onClick(inputTag)\"\n >\n <ng-content></ng-content>\n </tui-input-tag>\n <div\n *ngIf=\"computedGroup\"\n polymorpheus-outlet\n class=\"group\"\n [class.group_fullsize]=\"textfieldLabelOutside.labelOutside\"\n [context]=\"context\"\n [content]=\"valueContent\"\n ></div>\n <tui-svg\n *ngIf=\"interactive\"\n automation-id=\"tui-multi-select__arrow\"\n class=\"arrow\"\n src=\"tuiIconChevronDownLarge\"\n tuiPreventDefault=\"mousedown\"\n [class.arrow_open]=\"open\"\n (click.prevent)=\"onArrowClick()\"\n ></tui-svg>\n</tui-hosted-dropdown>\n", changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: TUI_FOCUSABLE_ITEM_ACCESSOR, useExisting: forwardRef(function () { return TuiMultiSelectComponent_1; }), }, { provide: TUI_DATA_LIST_HOST, useExisting: forwardRef(function () { return TuiMultiSelectComponent_1; }), }, FIXED_DROPDOWN_CONTROLLER_PROVIDER, ], styles: [":host{position:relative;display:block}:host._disabled{pointer-events:none}.wrapper{display:block}:host:not(._editable):not(._readonly) .input{cursor:pointer}.arrow{transition-duration:.3s;transition-timing-function:ease-in-out;display:flex;width:24px;align-items:center;justify-content:center;color:var(--tui-text-03);box-sizing:border-box;transition-property:color,transform;position:absolute;top:50%;transform:translate(0,-50%);right:12px;height:24px;box-sizing:content-box;cursor:pointer}.arrow:hover{color:var(--tui-text-02)}:host._disabled .arrow,:host._readonly .arrow{pointer-events:none}:host[data-mode=onDark] .arrow{color:var(--tui-text-03-night)}:host[data-mode=onDark] .arrow:hover{color:var(--tui-text-01-night)}.arrow_open{transform:rotate(-180deg) translate(0,50%)}.group{position:absolute;top:0;left:0;bottom:0;display:flex;align-items:center;padding:27px 16px 9px;pointer-events:none}.group_fullsize{padding-top:1px;padding-bottom:0}:host[data-tui-host-size='m'] .group_fullsize.group_fullsize{padding-top:0}:host[data-tui-host-size='m'] .group{padding:19px 12px 0;font-size:13px}"] }), __param(0, Optional()), __param(0, Self()), __param(0, Inject(NgControl)), __param(1, Inject(ChangeDetectorRef)), __param(2, Inject(TuiSvgService)), __param(3, Inject(TUI_TEXTFIELD_LABEL_OUTSIDE)) ], TuiMultiSelectComponent); return TuiMultiSelectComponent; }(AbstractTuiMultipleControl)); export { TuiMultiSelectComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select.component.js","sourceRoot":"ng://@taiga-ui/kit/components/multi-select/","sources":["multi-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiMultipleControl,\n    ALWAYS_FALSE_HANDLER,\n    EMPTY_ARRAY,\n    isNativeFocused,\n    setNativeFocused,\n    TUI_DEFAULT_IDENTITY_MATCHER,\n    TUI_DEFAULT_STRINGIFY,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    TuiBooleanHandler,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiIdentityMatcher,\n    TuiMapper,\n    tuiPure,\n    TuiStringHandler,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_DATA_LIST_ACCESSOR,\n    TUI_DATA_LIST_HOST,\n    TUI_TEXTFIELD_LABEL_OUTSIDE,\n    TuiDataListAccessor,\n    TuiDataListDirective,\n    TuiDataListHost,\n    TuiHostedDropdownComponent,\n    TuiSvgService,\n    TuiTextfieldLabelOutsideDirective,\n} from '@taiga-ui/core';\nimport {TuiStringifiableItem} from '@taiga-ui/kit/classes';\nimport {TuiInputTagComponent} from '@taiga-ui/kit/components/input-tag';\nimport {iconBlank} from '@taiga-ui/kit/constants';\nimport {FIXED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n@Component({\n    selector: 'tui-multi-select',\n    templateUrl: './multi-select.template.html',\n    styleUrls: ['./multi-select.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiMultiSelectComponent),\n        },\n        {\n            provide: TUI_DATA_LIST_HOST,\n            useExisting: forwardRef(() => TuiMultiSelectComponent),\n        },\n        FIXED_DROPDOWN_CONTROLLER_PROVIDER,\n    ],\n})\nexport class TuiMultiSelectComponent<T>\n    extends AbstractTuiMultipleControl<T>\n    implements TuiFocusableElementAccessor, TuiDataListHost<T> {\n    @Input()\n    @tuiDefaultProp()\n    stringify: TuiStringHandler<T> = TUI_DEFAULT_STRINGIFY;\n\n    @Input()\n    @tuiDefaultProp()\n    identityMatcher: TuiIdentityMatcher<T> = TUI_DEFAULT_IDENTITY_MATCHER;\n\n    @Input()\n    @tuiDefaultProp()\n    expandable = true;\n\n    @Input()\n    @tuiDefaultProp()\n    search: string | null = '';\n\n    @Input()\n    @HostBinding('class._editable')\n    @tuiDefaultProp()\n    editable = true;\n\n    @Input()\n    @tuiDefaultProp()\n    disabledItemHandler: TuiBooleanHandler<T> = ALWAYS_FALSE_HANDLER;\n\n    @Input()\n    @tuiDefaultProp()\n    valueContent: PolymorpheusContent<TuiContextWithImplicit<ReadonlyArray<T>>> = '';\n\n    @Output()\n    readonly searchChange = new EventEmitter<string | null>();\n\n    open = false;\n\n    readonly valueMapper: TuiMapper<\n        ReadonlyArray<T>,\n        ReadonlyArray<TuiStringifiableItem<T>>\n    > = (value, stringify: TuiStringHandler<T>, group: boolean) =>\n        group\n            ? EMPTY_ARRAY\n            : value.map(item => new TuiStringifiableItem(item, stringify));\n\n    readonly disabledItemHandlerWrapper: TuiMapper<\n        TuiBooleanHandler<T>,\n        TuiBooleanHandler<TuiStringifiableItem<T>>\n    > = handler => stringifiable =>\n        typeof stringifiable === 'string' || handler(stringifiable.item);\n\n    @ContentChild(TuiDataListDirective, {read: TemplateRef})\n    readonly datalist: PolymorpheusContent = '';\n\n    @ContentChild(TUI_DATA_LIST_ACCESSOR as any)\n    private readonly accessor?: TuiDataListAccessor<T>;\n\n    @ViewChild(TuiHostedDropdownComponent)\n    private readonly hostedDropdown?: TuiHostedDropdownComponent;\n\n    @ViewChild(TuiInputTagComponent)\n    private readonly input?: TuiInputTagComponent;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(TuiSvgService) svgService: TuiSvgService,\n        @Inject(TUI_TEXTFIELD_LABEL_OUTSIDE)\n        readonly textfieldLabelOutside: TuiTextfieldLabelOutsideDirective,\n    ) {\n        super(control, changeDetectorRef);\n\n        svgService.define({iconBlank});\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.input ? this.input.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return (\n            (!!this.input && this.input.focused) ||\n            (!!this.hostedDropdown && this.hostedDropdown.focused)\n        );\n    }\n\n    get computedValue(): ReadonlyArray<T> {\n        return this.computedGroup ? EMPTY_ARRAY : this.value;\n    }\n\n    // @bad TODO: think of a better way\n    get searchOrSpace(): string {\n        return this.computedGroup ? ' ' : this.searchString;\n    }\n\n    get searchString(): string {\n        return this.search === null ? '' : this.search;\n    }\n\n    get tagIcon(): string {\n        return this.interactive ? 'iconBlank' : 'tuiIconChevronDownLarge';\n    }\n\n    get interactive(): boolean {\n        return !this.disabled && !this.readOnly;\n    }\n\n    get inputHidden(): boolean {\n        return !this.editable && !this.computedGroup;\n    }\n\n    get computedGroup(): boolean {\n        return (\n            !!this.valueContent &&\n            this.value.length > 0 &&\n            (!this.focused || !this.editable)\n        );\n    }\n\n    get context(): TuiContextWithImplicit<ReadonlyArray<T>> {\n        return this.getContext(this.value);\n    }\n\n    @tuiPure\n    getStringifier(\n        stringify: TuiStringHandler<T>,\n    ): TuiStringHandler<TuiContextWithImplicit<T>> {\n        return ({$implicit}) => stringify($implicit);\n    }\n\n    onHoveredChange(hovered: boolean) {\n        this.updateHovered(hovered);\n    }\n\n    onSpace(event: KeyboardEvent) {\n        if (!this.editable) {\n            event.preventDefault();\n        }\n\n        if (!this.readOnly) {\n            this.open = true;\n        }\n    }\n\n    handleOption(option: T) {\n        const {value, identityMatcher} = this;\n        const index = value.findIndex(item => identityMatcher(item, option));\n\n        this.updateValue(\n            index === -1\n                ? [...value, option]\n                : [...value.slice(0, index), ...value.slice(index + 1)],\n        );\n        this.updateSearch(null);\n    }\n\n    onEnter(event: KeyboardEvent) {\n        const {value} = this;\n        const options = this.accessor ? this.accessor.getOptions() : [];\n\n        if (options.length !== 1) {\n            return;\n        }\n\n        const index = value.indexOf(options[0]);\n\n        event.preventDefault();\n        this.updateValue(\n            index === -1\n                ? [...value, options[0]]\n                : [...value.slice(0, index), ...value.slice(index + 1)],\n        );\n        this.updateSearch(null);\n    }\n\n    onClick({nativeFocusableElement}: TuiInputTagComponent) {\n        if (\n            this.interactive &&\n            nativeFocusableElement &&\n            isNativeFocused(nativeFocusableElement)\n        ) {\n            this.open = !this.open;\n        }\n    }\n\n    onArrowClick() {\n        this.open = !this.open;\n        this.focusInput();\n    }\n\n    onInput(value: ReadonlyArray<TuiStringifiableItem<T>>) {\n        this.updateValue(value.map(({item}) => item));\n    }\n\n    onSearch(search: string | null) {\n        this.open = true;\n        this.updateSearch(search);\n    }\n\n    onActiveZone(active: boolean) {\n        this.updateFocused(active);\n    }\n\n    setDisabledState() {\n        super.setDisabledState();\n        this.open = false;\n    }\n\n    private updateSearch(search: string | null) {\n        if (this.search === search) {\n            return;\n        }\n\n        this.search = search;\n        this.searchChange.emit(search);\n    }\n\n    private focusInput(preventScroll: boolean = false) {\n        if (this.nativeFocusableElement) {\n            setNativeFocused(this.nativeFocusableElement, true, preventScroll);\n        }\n    }\n\n    @tuiPure\n    private getContext(\n        $implicit: ReadonlyArray<T>,\n    ): TuiContextWithImplicit<ReadonlyArray<T>> {\n        return {$implicit};\n    }\n}\n"]}