UNPKG

@taiga-ui/kit

Version:
223 lines • 31.3 kB
var TuiMultiSelectComponent_1; import { __decorate, __param } 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'; let TuiMultiSelectComponent = TuiMultiSelectComponent_1 = class TuiMultiSelectComponent extends AbstractTuiMultipleControl { constructor(control, changeDetectorRef, svgService, textfieldLabelOutside) { super(control, changeDetectorRef); 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 = (value, stringify, group) => group ? EMPTY_ARRAY : value.map(item => new TuiStringifiableItem(item, stringify)); this.disabledItemHandlerWrapper = handler => stringifiable => typeof stringifiable === 'string' || handler(stringifiable.item); this.datalist = ''; svgService.define({ iconBlank }); } get nativeFocusableElement() { return this.input ? this.input.nativeFocusableElement : null; } get focused() { return ((!!this.input && this.input.focused) || (!!this.hostedDropdown && this.hostedDropdown.focused)); } get computedValue() { return this.computedGroup ? EMPTY_ARRAY : this.value; } // @bad TODO: think of a better way get searchOrSpace() { return this.computedGroup ? ' ' : this.searchString; } get searchString() { return this.search === null ? '' : this.search; } get tagIcon() { return this.interactive ? 'iconBlank' : 'tuiIconChevronDownLarge'; } get interactive() { return !this.disabled && !this.readOnly; } get inputHidden() { return !this.editable && !this.computedGroup; } get computedGroup() { return (!!this.valueContent && this.value.length > 0 && (!this.focused || !this.editable)); } get context() { return this.getContext(this.value); } getStringifier(stringify) { return ({ $implicit }) => stringify($implicit); } onHoveredChange(hovered) { this.updateHovered(hovered); } onSpace(event) { if (!this.editable) { event.preventDefault(); } if (!this.readOnly) { this.open = true; } } handleOption(option) { const { value, identityMatcher } = this; const index = value.findIndex(item => identityMatcher(item, option)); this.updateValue(index === -1 ? [...value, option] : [...value.slice(0, index), ...value.slice(index + 1)]); this.updateSearch(null); } onEnter(event) { const { value } = this; const options = this.accessor ? this.accessor.getOptions() : []; if (options.length !== 1) { return; } const index = value.indexOf(options[0]); event.preventDefault(); this.updateValue(index === -1 ? [...value, options[0]] : [...value.slice(0, index), ...value.slice(index + 1)]); this.updateSearch(null); } onClick({ nativeFocusableElement }) { if (this.interactive && nativeFocusableElement && isNativeFocused(nativeFocusableElement)) { this.open = !this.open; } } onArrowClick() { this.open = !this.open; this.focusInput(); } onInput(value) { this.updateValue(value.map(({ item }) => item)); } onSearch(search) { this.open = true; this.updateSearch(search); } onActiveZone(active) { this.updateFocused(active); } setDisabledState() { super.setDisabledState(); this.open = false; } updateSearch(search) { if (this.search === search) { return; } this.search = search; this.searchChange.emit(search); } focusInput(preventScroll = false) { if (this.nativeFocusableElement) { setNativeFocused(this.nativeFocusableElement, true, preventScroll); } } getContext($implicit) { return { $implicit }; } }; TuiMultiSelectComponent.ctorParameters = () => [ { 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(() => TuiMultiSelectComponent_1), }, { provide: TUI_DATA_LIST_HOST, useExisting: forwardRef(() => 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); 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":";;AAAA,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,YAAY,EACZ,UAAU,EACV,WAAW,EACX,MAAM,EACN,KAAK,EACL,QAAQ,EACR,MAAM,EACN,IAAI,EACJ,WAAW,EACX,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACzC,OAAO,EACH,0BAA0B,EAC1B,oBAAoB,EACpB,WAAW,EACX,eAAe,EACf,gBAAgB,EAChB,4BAA4B,EAC5B,qBAAqB,EACrB,2BAA2B,EAG3B,cAAc,EAId,OAAO,GAEV,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,sBAAsB,EACtB,kBAAkB,EAClB,2BAA2B,EAC3B,mBAAmB,EACnB,oBAAoB,EACpB,eAAe,EACf,0BAA0B,EAC1B,aAAa,EACb,iCAAiC,GACpC,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAC,oBAAoB,EAAC,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAC,oBAAoB,EAAC,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAC,SAAS,EAAC,MAAM,yBAAyB,CAAC;AAClD,OAAO,EAAC,kCAAkC,EAAC,MAAM,yBAAyB,CAAC;AAoB3E,IAAa,uBAAuB,+BAApC,MAAa,uBACT,SAAQ,0BAA6B;IA8DrC,YAII,OAAyB,EACE,iBAAoC,EACxC,UAAyB,EAEvC,qBAAwD;QAEjE,KAAK,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;QAFzB,0BAAqB,GAArB,qBAAqB,CAAmC;QAlErE,cAAS,GAAwB,qBAAqB,CAAC;QAIvD,oBAAe,GAA0B,4BAA4B,CAAC;QAItE,eAAU,GAAG,IAAI,CAAC;QAIlB,WAAM,GAAkB,EAAE,CAAC;QAK3B,aAAQ,GAAG,IAAI,CAAC;QAIhB,wBAAmB,GAAyB,oBAAoB,CAAC;QAIjE,iBAAY,GAAkE,EAAE,CAAC;QAGxE,iBAAY,GAAG,IAAI,YAAY,EAAiB,CAAC;QAE1D,SAAI,GAAG,KAAK,CAAC;QAEJ,gBAAW,GAGhB,CAAC,KAAK,EAAE,SAA8B,EAAE,KAAc,EAAE,EAAE,CAC1D,KAAK;YACD,CAAC,CAAC,WAAW;YACb,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,oBAAoB,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC;QAE9D,+BAA0B,GAG/B,OAAO,CAAC,EAAE,CAAC,aAAa,CAAC,EAAE,CAC3B,OAAO,aAAa,KAAK,QAAQ,IAAI,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAG5D,aAAQ,GAAwB,EAAE,CAAC;QAuBxC,UAAU,CAAC,MAAM,CAAC,EAAC,SAAS,EAAC,CAAC,CAAC;IACnC,CAAC;IAED,IAAI,sBAAsB;QACtB,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC,IAAI,CAAC;IACjE,CAAC;IAED,IAAI,OAAO;QACP,OAAO,CACH,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;YACpC,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CACzD,CAAC;IACN,CAAC;IAED,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;IACzD,CAAC;IAED,mCAAmC;IACnC,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;IACxD,CAAC;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;IACnD,CAAC;IAED,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,yBAAyB,CAAC;IACtE,CAAC;IAED,IAAI,WAAW;QACX,OAAO,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;IAC5C,CAAC;IAED,IAAI,WAAW;QACX,OAAO,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;IACjD,CAAC;IAED,IAAI,aAAa;QACb,OAAO,CACH,CAAC,CAAC,IAAI,CAAC,YAAY;YACnB,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;YACrB,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CACpC,CAAC;IACN,CAAC;IAED,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IAGD,cAAc,CACV,SAA8B;QAE9B,OAAO,CAAC,EAAC,SAAS,EAAC,EAAE,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;IACjD,CAAC;IAED,eAAe,CAAC,OAAgB;QAC5B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IAED,OAAO,CAAC,KAAoB;QACxB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAChB,KAAK,CAAC,cAAc,EAAE,CAAC;SAC1B;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAChB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;SACpB;IACL,CAAC;IAED,YAAY,CAAC,MAAS;QAClB,MAAM,EAAC,KAAK,EAAE,eAAe,EAAC,GAAG,IAAI,CAAC;QACtC,MAAM,KAAK,GAAG,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;QAErE,IAAI,CAAC,WAAW,CACZ,KAAK,KAAK,CAAC,CAAC;YACR,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE,MAAM,CAAC;YACpB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAC9D,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,OAAO,CAAC,KAAoB;QACxB,MAAM,EAAC,KAAK,EAAC,GAAG,IAAI,CAAC;QACrB,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAEhE,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;YACtB,OAAO;SACV;QAED,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAExC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,WAAW,CACZ,KAAK,KAAK,CAAC,CAAC;YACR,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;YACxB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAC9D,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,OAAO,CAAC,EAAC,sBAAsB,EAAuB;QAClD,IACI,IAAI,CAAC,WAAW;YAChB,sBAAsB;YACtB,eAAe,CAAC,sBAAsB,CAAC,EACzC;YACE,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;SAC1B;IACL,CAAC;IAED,YAAY;QACR,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;QACvB,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED,OAAO,CAAC,KAA6C;QACjD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAC,IAAI,EAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAClD,CAAC;IAED,QAAQ,CAAC,MAAqB;QAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IAC9B,CAAC;IAED,YAAY,CAAC,MAAe;QACxB,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;IAED,gBAAgB;QACZ,KAAK,CAAC,gBAAgB,EAAE,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;IACtB,CAAC;IAEO,YAAY,CAAC,MAAqB;QACtC,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE;YACxB,OAAO;SACV;QAED,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAEO,UAAU,CAAC,gBAAyB,KAAK;QAC7C,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC7B,gBAAgB,CAAC,IAAI,CAAC,sBAAsB,EAAE,IAAI,EAAE,aAAa,CAAC,CAAC;SACtE;IACL,CAAC;IAGO,UAAU,CACd,SAA2B;QAE3B,OAAO,EAAC,SAAS,EAAC,CAAC;IACvB,CAAC;CACJ,CAAA;;YArKgB,SAAS,uBAHjB,QAAQ,YACR,IAAI,YACJ,MAAM,SAAC,SAAS;YAE6B,iBAAiB,uBAA9D,MAAM,SAAC,iBAAiB;YACU,aAAa,uBAA/C,MAAM,SAAC,aAAa;YAEW,iCAAiC,uBADhE,MAAM,SAAC,2BAA2B;;AAjEvC;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;0DACsC;AAIvD;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;gEACqD;AAItE;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;2DACC;AAIlB;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;uDACU;AAK3B;IAHC,KAAK,EAAE;IACP,WAAW,CAAC,iBAAiB,CAAC;IAC9B,cAAc,EAAE;yDACD;AAIhB;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;oEACgD;AAIjE;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;6DACgE;AAGjF;IADC,MAAM,EAAE;6DACiD;AAmB1D;IADC,YAAY,CAAC,oBAAoB,EAAE,EAAC,IAAI,EAAE,WAAW,EAAC,CAAC;yDACZ;AAG5C;IADC,YAAY,CAAC,sBAA6B,CAAC;yDACO;AAGnD;IADC,SAAS,CAAC,0BAA0B,CAAC;+DACuB;AAG7D;IADC,SAAS,CAAC,oBAAoB,CAAC;sDACc;AAkE9C;IADC,OAAO;6DAKP;AAgGD;IADC,OAAO;yDAKP;AAvOQ,uBAAuB;IAjBnC,SAAS,CAAC;QACP,QAAQ,EAAE,kBAAkB;QAC5B,sxDAA2C;QAE3C,eAAe,EAAE,uBAAuB,CAAC,MAAM;QAC/C,SAAS,EAAE;YACP;gBACI,OAAO,EAAE,2BAA2B;gBACpC,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAuB,CAAC;aACzD;YACD;gBACI,OAAO,EAAE,kBAAkB;gBAC3B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAuB,CAAC;aACzD;YACD,kCAAkC;SACrC;;KACJ,CAAC;IAiEO,WAAA,QAAQ,EAAE,CAAA;IACV,WAAA,IAAI,EAAE,CAAA;IACN,WAAA,MAAM,CAAC,SAAS,CAAC,CAAA;IAEjB,WAAA,MAAM,CAAC,iBAAiB,CAAC,CAAA;IACzB,WAAA,MAAM,CAAC,aAAa,CAAC,CAAA;IACrB,WAAA,MAAM,CAAC,2BAA2B,CAAC,CAAA;GAtE/B,uBAAuB,CAwOnC;SAxOY,uBAAuB","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"]}