UNPKG

@agnos-ui/angular

Version:

Bootstrap-based widget library for Angular.

314 lines 35 kB
import { __decorate } from "tslib"; import { BaseWidgetDirective, CachedProperty, SlotDirective, UseDirective, auBooleanAttribute, callWidgetFactory, createSelect, mergeDirectives, useDirectiveForHost, } from '@agnos-ui/angular-headless'; import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, inject } from '@angular/core'; import * as i0 from "@angular/core"; const _c0 = ["auSelect", ""]; function SelectComponent_Conditional_0_Conditional_1_For_1_ng_template_1_Template(rf, ctx) { } const _c1 = (a0, a1, a2) => ({ state: a0, widget: a1, itemContext: a2 }); function SelectComponent_Conditional_0_Conditional_1_For_1_Template(rf, ctx) { if (rf & 1) { const _r13 = i0.ɵɵgetCurrentView(); i0.ɵɵelementStart(0, "div", 3); i0.ɵɵlistener("keydown", function SelectComponent_Conditional_0_Conditional_1_For_1_Template_div_keydown_0_listener($event) { const restoredCtx = i0.ɵɵrestoreView(_r13); const itemContext_r6 = restoredCtx.$implicit; const ctx_r12 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r12._widget.actions.onBadgeKeydown($event, itemContext_r6.item)); }); i0.ɵɵtemplate(1, SelectComponent_Conditional_0_Conditional_1_For_1_ng_template_1_Template, 0, 0, "ng-template", 4); i0.ɵɵelementEnd(); } if (rf & 2) { const itemContext_r6 = ctx.$implicit; const state_r1 = i0.ɵɵnextContext(2); const ctx_r5 = i0.ɵɵnextContext(); i0.ɵɵclassMap(state_r1.badgeClassName); i0.ɵɵadvance(); i0.ɵɵproperty("auSlot", state_r1.slotBadgeLabel)("auSlotProps", i0.ɵɵpureFunction3(4, _c1, state_r1, ctx_r5.widget, itemContext_r6)); } } function SelectComponent_Conditional_0_Conditional_1_Template(rf, ctx) { if (rf & 1) { i0.ɵɵrepeaterCreate(0, SelectComponent_Conditional_0_Conditional_1_For_1_Template, 2, 8, "div", 5, i0.ɵɵcomponentInstance().itemCtxTrackBy); } if (rf & 2) { i0.ɵɵrepeater(ctx); } } function SelectComponent_Conditional_0_Conditional_3_For_2_ng_template_1_Template(rf, ctx) { } function SelectComponent_Conditional_0_Conditional_3_For_2_Template(rf, ctx) { if (rf & 1) { const _r23 = i0.ɵɵgetCurrentView(); i0.ɵɵelementStart(0, "li", 7); i0.ɵɵlistener("click", function SelectComponent_Conditional_0_Conditional_3_For_2_Template_li_click_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r23); const itemContext_r16 = restoredCtx.$implicit; const ctx_r22 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r22.widget.api.toggleItem(itemContext_r16.item)); }); i0.ɵɵtemplate(1, SelectComponent_Conditional_0_Conditional_3_For_2_ng_template_1_Template, 0, 0, "ng-template", 4); i0.ɵɵelementEnd(); } if (rf & 2) { const itemContext_r16 = ctx.$implicit; const state_r1 = i0.ɵɵnextContext(2); const ctx_r15 = i0.ɵɵnextContext(); i0.ɵɵstyleProp("cursor", "pointer"); i0.ɵɵclassProp("text-bg-primary", itemContext_r16 === state_r1.highlighted)("selected", itemContext_r16.selected); i0.ɵɵattribute("aria-selected", itemContext_r16.selected); i0.ɵɵadvance(); i0.ɵɵproperty("auSlot", state_r1.slotItem)("auSlotProps", i0.ɵɵpureFunction3(9, _c1, state_r1, ctx_r15.widget, itemContext_r16)); } } function SelectComponent_Conditional_0_Conditional_3_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "ul", 6); i0.ɵɵlistener("mousedown", function SelectComponent_Conditional_0_Conditional_3_Template_ul_mousedown_0_listener($event) { return $event.preventDefault(); }); i0.ɵɵrepeaterCreate(1, SelectComponent_Conditional_0_Conditional_3_For_2_Template, 2, 13, "li", 8, i0.ɵɵcomponentInstance().itemCtxTrackBy); i0.ɵɵelementEnd(); } if (rf & 2) { const state_r1 = i0.ɵɵnextContext(); const ctx_r3 = i0.ɵɵnextContext(); i0.ɵɵclassMap("dropdown-menu show " + (ctx_r3.menuClassName || "")); i0.ɵɵproperty("id", state_r1.id + "-menu")("auUse", ctx_r3.menuDirective); i0.ɵɵattribute("data-popper-placement", state_r1.placement); i0.ɵɵadvance(); i0.ɵɵrepeater(state_r1.visibleItems); } } function SelectComponent_Conditional_0_Template(rf, ctx) { if (rf & 1) { const _r28 = i0.ɵɵgetCurrentView(); i0.ɵɵelementStart(0, "div", 0); i0.ɵɵtemplate(1, SelectComponent_Conditional_0_Conditional_1_Template, 2, 0); i0.ɵɵelementStart(2, "input", 1); i0.ɵɵlistener("input", function SelectComponent_Conditional_0_Template_input_input_2_listener($event) { i0.ɵɵrestoreView(_r28); const ctx_r27 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r27._widget.actions.onInput($event)); })("keydown", function SelectComponent_Conditional_0_Template_input_keydown_2_listener($event) { i0.ɵɵrestoreView(_r28); const ctx_r29 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r29._widget.actions.onInputKeydown($event)); }); i0.ɵɵelementEnd()(); i0.ɵɵtemplate(3, SelectComponent_Conditional_0_Conditional_3_Template, 3, 5, "ul", 2); } if (rf & 2) { const ctx_r0 = i0.ɵɵnextContext(); let SelectComponent_Conditional_0_contFlowTmp; i0.ɵɵproperty("auUse", ctx_r0.controlContainerDirective); i0.ɵɵattribute("aria-controls", ctx.id + "-menu")("aria-expanded", ctx.open); i0.ɵɵadvance(); i0.ɵɵconditional(1, (SelectComponent_Conditional_0_contFlowTmp = ctx.selectedContexts) ? 1 : -1, SelectComponent_Conditional_0_contFlowTmp); i0.ɵɵadvance(); i0.ɵɵproperty("value", ctx.filterText); i0.ɵɵattribute("id", ctx.id)("aria-label", ctx.ariaLabel); i0.ɵɵadvance(); i0.ɵɵconditional(3, ctx.open && ctx.visibleItems.length ? 3 : -1); } } export class SelectBadgeLabelDirective { constructor() { this.templateRef = inject((TemplateRef)); } static ngTemplateContextGuard(_dir, context) { return true; } static { this.ɵfac = function SelectBadgeLabelDirective_Factory(t) { return new (t || SelectBadgeLabelDirective)(); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SelectBadgeLabelDirective, selectors: [["ng-template", "auSelectBadgeLabel", ""]], standalone: true }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectBadgeLabelDirective, [{ type: Directive, args: [{ selector: 'ng-template[auSelectBadgeLabel]', standalone: true }] }], null, null); })(); export class SelectItemDirective { constructor() { this.templateRef = inject((TemplateRef)); } static ngTemplateContextGuard(_dir, context) { return true; } static { this.ɵfac = function SelectItemDirective_Factory(t) { return new (t || SelectItemDirective)(); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SelectItemDirective, selectors: [["ng-template", "auSelectItem", ""]], standalone: true }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectItemDirective, [{ type: Directive, args: [{ selector: 'ng-template[auSelectItem]', standalone: true }] }], null, null); })(); export class SelectComponent extends BaseWidgetDirective { constructor() { super(...arguments); /** * Callback called when the text filter change */ this.filterTextChange = new EventEmitter(); /** * Callback called when the selection change */ this.selectedChange = new EventEmitter(); /** * Callback called dropdown open state change */ this.openChange = new EventEmitter(); this._widget = callWidgetFactory({ factory: createSelect, widgetName: 'select', events: { onOpenChange: (event) => this.openChange.emit(event), onSelectedChange: (event) => this.selectedChange.emit(event), onFilterTextChange: (event) => this.filterTextChange.emit(event), }, afterInit: () => { useDirectiveForHost(this._widget.directives.referenceDirective); }, }); } get menuDirective() { return mergeDirectives(this._widget.directives.hasFocusDirective, this._widget.directives.floatingDirective); } get controlContainerDirective() { return mergeDirectives(this._widget.directives.hasFocusDirective, this._widget.directives.inputContainerDirective); } itemCtxTrackBy(_, itemContext) { return itemContext.id; } ngAfterContentChecked() { this._widget.patchSlots({ slotBadgeLabel: this.slotSelectBadgeLabelFromContent?.templateRef, slotItem: this.slotSelectItemFromContent?.templateRef, }); } static { this.ɵfac = /*@__PURE__*/ (() => { let ɵSelectComponent_BaseFactory; return function SelectComponent_Factory(t) { return (ɵSelectComponent_BaseFactory || (ɵSelectComponent_BaseFactory = i0.ɵɵgetInheritedFactory(SelectComponent)))(t || SelectComponent); }; })(); } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SelectComponent, selectors: [["", "auSelect", ""]], contentQueries: function SelectComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) { i0.ɵɵcontentQuery(dirIndex, SelectBadgeLabelDirective, 5); i0.ɵɵcontentQuery(dirIndex, SelectItemDirective, 5); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotSelectBadgeLabelFromContent = _t.first); i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotSelectItemFromContent = _t.first); } }, hostVars: 2, hostBindings: function SelectComponent_HostBindings(rf, ctx) { if (rf & 2) { i0.ɵɵclassMap("au-select dropdown border border-1 p-1 mb-3 d-block" + ctx.state().className); } }, inputs: { ariaLabel: [i0.ɵɵInputFlags.None, "auAriaLabel", "ariaLabel"], id: [i0.ɵɵInputFlags.None, "auId", "id"], items: [i0.ɵɵInputFlags.None, "auItems", "items"], allowedPlacements: [i0.ɵɵInputFlags.None, "auAllowedPlacements", "allowedPlacements"], open: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auOpen", "open", auBooleanAttribute], filterText: [i0.ɵɵInputFlags.None, "auFilterText", "filterText"], className: [i0.ɵɵInputFlags.None, "auClassName", "className"], disabled: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auDisabled", "disabled", auBooleanAttribute], selected: [i0.ɵɵInputFlags.None, "auSelected", "selected"], loading: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auLoading", "loading", auBooleanAttribute], itemIdFn: [i0.ɵɵInputFlags.None, "auItemIdFn", "itemIdFn"], menuClassName: [i0.ɵɵInputFlags.None, "auMenuClassName", "menuClassName"], slotBadgeLabel: [i0.ɵɵInputFlags.None, "auSlotBadgeLabel", "slotBadgeLabel"], slotItem: [i0.ɵɵInputFlags.None, "auSlotItem", "slotItem"], menuItemClassName: [i0.ɵɵInputFlags.None, "auMenuItemClassName", "menuItemClassName"], badgeClassName: [i0.ɵɵInputFlags.None, "auBadgeClassName", "badgeClassName"], navSelector: [i0.ɵɵInputFlags.None, "auNavSelector", "navSelector"] }, outputs: { filterTextChange: "auFilterTextChange", selectedChange: "auSelectedChange", openChange: "auOpenChange" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c0, decls: 1, vars: 1, consts: [["role", "combobox", "aria-haspopup", "listbox", 1, "d-flex", "align-items-center", "flex-wrap", 3, "auUse"], ["type", "text", "aria-autocomplete", "list", "autoCorrect", "off", "autoCapitalize", "none", "autoComplete", "off", 1, "au-select-input", "flex-grow-1", "border-0", 3, "value", "input", "keydown"], ["role", "listbox", 3, "id", "auUse", "class"], ["tabindex", "-1", 1, "au-select-badge", "me-1", 3, "keydown"], [3, "auSlot", "auSlotProps"], ["tabindex", "-1", "class", "au-select-badge me-1", 3, "class"], ["role", "listbox", 3, "id", "auUse", "mousedown"], ["role", "option", 1, "au-select-item", "dropdown-item", "position-relative", 3, "click"], ["role", "option", "class", "au-select-item dropdown-item position-relative ", 3, "text-bg-primary", "selected", "cursor"]], template: function SelectComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵtemplate(0, SelectComponent_Conditional_0_Template, 4, 8); } if (rf & 2) { let SelectComponent_contFlowTmp; i0.ɵɵconditional(0, (SelectComponent_contFlowTmp = ctx.state()) ? 0 : -1, SelectComponent_contFlowTmp); } }, dependencies: [UseDirective, SlotDirective], encapsulation: 2, changeDetection: 0 }); } } __decorate([ CachedProperty ], SelectComponent.prototype, "menuDirective", null); __decorate([ CachedProperty ], SelectComponent.prototype, "controlContainerDirective", null); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectComponent, [{ type: Component, args: [{ standalone: true, imports: [UseDirective, SlotDirective], changeDetection: ChangeDetectionStrategy.OnPush, selector: '[auSelect]', host: { '[class]': '"au-select dropdown border border-1 p-1 mb-3 d-block" + state().className', }, template: ` @if (state(); as state) { <div [auUse]="controlContainerDirective" role="combobox" class="d-flex align-items-center flex-wrap" [attr.aria-controls]="state.id + '-menu'" aria-haspopup="listbox" [attr.aria-expanded]="state.open" > @if (state.selectedContexts; as selectedContexts) { @for (itemContext of selectedContexts; track itemCtxTrackBy($index, itemContext)) { <div tabindex="-1" class="au-select-badge me-1" [class]="state.badgeClassName" (keydown)="_widget.actions.onBadgeKeydown($event, itemContext.item)" > <ng-template [auSlot]="state.slotBadgeLabel" [auSlotProps]="{state, widget, itemContext}"></ng-template> </div> } } <input attr.id="{{ state.id }}" attr.aria-label="{{ state.ariaLabel }}" type="text" class="au-select-input flex-grow-1 border-0" [value]="state.filterText" aria-autocomplete="list" autoCorrect="off" autoCapitalize="none" autoComplete="off" (input)="_widget.actions.onInput($event)" (keydown)="_widget.actions.onInputKeydown($event)" /> </div> @if (state.open && state.visibleItems.length) { <ul role="listbox" [id]="state.id + '-menu'" [auUse]="menuDirective" [class]="'dropdown-menu show ' + (menuClassName || '')" [attr.data-popper-placement]="state.placement" (mousedown)="$event.preventDefault()" > @for (itemContext of state.visibleItems; track itemCtxTrackBy($index, itemContext)) { <li role="option" [attr.aria-selected]="itemContext.selected" class="au-select-item dropdown-item position-relative " [class.text-bg-primary]="itemContext === state.highlighted" [class.selected]="itemContext.selected" (click)="widget.api.toggleItem(itemContext.item)" [style.cursor]="'pointer'" > <ng-template [auSlot]="state.slotItem" [auSlotProps]="{state, widget, itemContext}"></ng-template> </li> } </ul> } } `, }] }], null, { ariaLabel: [{ type: Input, args: ['auAriaLabel'] }], id: [{ type: Input, args: ['auId'] }], items: [{ type: Input, args: ['auItems'] }], allowedPlacements: [{ type: Input, args: ['auAllowedPlacements'] }], open: [{ type: Input, args: [{ alias: 'auOpen', transform: auBooleanAttribute }] }], filterText: [{ type: Input, args: ['auFilterText'] }], className: [{ type: Input, args: ['auClassName'] }], disabled: [{ type: Input, args: [{ alias: 'auDisabled', transform: auBooleanAttribute }] }], selected: [{ type: Input, args: ['auSelected'] }], loading: [{ type: Input, args: [{ alias: 'auLoading', transform: auBooleanAttribute }] }], itemIdFn: [{ type: Input, args: ['auItemIdFn'] }], menuClassName: [{ type: Input, args: ['auMenuClassName'] }], slotBadgeLabel: [{ type: Input, args: ['auSlotBadgeLabel'] }], slotSelectBadgeLabelFromContent: [{ type: ContentChild, args: [SelectBadgeLabelDirective, { static: false }] }], slotItem: [{ type: Input, args: ['auSlotItem'] }], slotSelectItemFromContent: [{ type: ContentChild, args: [SelectItemDirective, { static: false }] }], filterTextChange: [{ type: Output, args: ['auFilterTextChange'] }], selectedChange: [{ type: Output, args: ['auSelectedChange'] }], openChange: [{ type: Output, args: ['auOpenChange'] }], menuItemClassName: [{ type: Input, args: ['auMenuItemClassName'] }], badgeClassName: [{ type: Input, args: ['auBadgeClassName'] }], navSelector: [{ type: Input, args: ['auNavSelector'] }], menuDirective: [], controlContainerDirective: [] }); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectComponent, { className: "SelectComponent", filePath: "components/select/select.component.ts", lineNumber: 104 }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../src/components/select/select.component.ts"],"names":[],"mappings":";AACA,OAAO,EACN,mBAAmB,EACnB,cAAc,EACd,aAAa,EACb,YAAY,EACZ,kBAAkB,EAClB,iBAAiB,EACjB,YAAY,EACZ,eAAe,EACf,mBAAmB,GACnB,MAAM,4BAA4B,CAAC;AAEpC,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAC,MAAM,eAAe,CAAC;;;;;;;IAuCtI,8BAKC;IADA,oQAAW,eAAA,mEAAwD,CAAA,IAAC;IAEpE,kHAAwG;IACzG,iBAAM;;;;;IAJL,sCAA8B;IAGjB,cAA+B;IAA/B,gDAA+B,oFAAA;;;IAP9C,2IASC;;IATD,kBASC;;;;;IA0BA,6BAQC;IAFA,0PAAS,eAAA,mDAAuC,CAAA,IAAC;IAGjD,kHAAkG;IACnG,iBAAK;;;;;IAHJ,mCAA0B;IAH1B,2EAA2D,sCAAA;IAF3D,yDAA2C;IAO9B,cAAyB;IAAzB,0CAAyB,sFAAA;;;IAlBzC,6BAOC;IADA,kIAAa,uBAAuB,IAAC;IAErC,2IAYC;IACF,iBAAK;;;;IAjBJ,mEAAuD;IAFvD,0CAAyB,+BAAA;IAGzB,2DAA8C;IAG9C,cAYC;IAZD,oCAYC;;;;IAvDH,8BAOC;IACA,4EAWC;IACD,gCAYE;IAFD,2KAAS,eAAA,uCAA+B,CAAA,IAAC,kKAC9B,eAAA,8CAAsC,CAAA,IADR;IAV1C,iBAYE,EAAA;IAEH,qFAuBC;;;;IAxDA,wDAAmC;IAGnC,iDAAyC,2BAAA;IAIzC,cAWC;IAXD,2IAWC;IAMA,cAA0B;IAA1B,sCAA0B;IAJ1B,4BAAwB,6BAAA;IAa1B,cAuBC;IAvBD,iEAuBC;;AAlFJ,MAAM,OAAO,yBAAyB;IADtC;QAEQ,gBAAW,GAAG,MAAM,CAAC,CAAA,WAA2D,CAAA,CAAC,CAAC;KAIzF;IAHA,MAAM,CAAC,sBAAsB,CAAO,IAAqC,EAAE,OAAgB;QAC1F,OAAO,IAAI,CAAC;IACb,CAAC;0FAJW,yBAAyB;oEAAzB,yBAAyB;;iFAAzB,yBAAyB;cADrC,SAAS;eAAC,EAAC,QAAQ,EAAE,iCAAiC,EAAE,UAAU,EAAE,IAAI,EAAC;;AAS1E,MAAM,OAAO,mBAAmB;IADhC;QAEQ,gBAAW,GAAG,MAAM,CAAC,CAAA,WAA2D,CAAA,CAAC,CAAC;KAIzF;IAHA,MAAM,CAAC,sBAAsB,CAAO,IAA+B,EAAE,OAAgB;QACpF,OAAO,IAAI,CAAC;IACb,CAAC;oFAJW,mBAAmB;oEAAnB,mBAAmB;;iFAAnB,mBAAmB;cAD/B,SAAS;eAAC,EAAC,QAAQ,EAAE,2BAA2B,EAAE,UAAU,EAAE,IAAI,EAAC;;AA+EpE,MAAM,OAAO,eAAsB,SAAQ,mBAAuC;IAvElF;;QA4IC;;WAEG;QAC2B,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;QAE5E;;WAEG;QACyB,mBAAc,GAAG,IAAI,YAAY,EAAU,CAAC;QAExE;;WAEG;QACqB,eAAU,GAAG,IAAI,YAAY,EAAW,CAAC;QAiBxD,YAAO,GAAG,iBAAiB,CAAqB;YACxD,OAAO,EAAE,YAAY;YACrB,UAAU,EAAE,QAAQ;YACpB,MAAM,EAAE;gBACP,YAAY,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC;gBACpD,gBAAgB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC;gBAC5D,kBAAkB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC;aAChE;YACD,SAAS,EAAE,GAAG,EAAE;gBACf,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC;YACjE,CAAC;SACD,CAAC,CAAC;KAsBH;IAnBA,IAAI,aAAa;QAChB,OAAO,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,iBAAiB,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;IAC9G,CAAC;IAGD,IAAI,yBAAyB;QAC5B,OAAO,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,iBAAiB,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,uBAAuB,CAAC,CAAC;IACpH,CAAC;IAED,cAAc,CAAC,CAAS,EAAE,WAA8B;QACvD,OAAO,WAAW,CAAC,EAAE,CAAC;IACvB,CAAC;IAED,qBAAqB;QACpB,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC;YACvB,cAAc,EAAE,IAAI,CAAC,+BAA+B,EAAE,WAAW;YACjE,QAAQ,EAAE,IAAI,CAAC,yBAAyB,EAAE,WAAW;SACrD,CAAC,CAAC;IACJ,CAAC;gOAnIW,eAAe,SAAf,eAAe;oEAAf,eAAe;wCAgEb,yBAAyB;wCAGzB,mBAAmB;;;;;;;+UA1CG,kBAAkB,qNAed,kBAAkB,6IAUnB,kBAAkB;YAhHxD,8DA2DC;;;YA3DD,sGA2DC;4BAlEQ,YAAY,EAAE,aAAa;;AAsLrC;IADC,cAAc;oDAGd;AAGD;IADC,cAAc;gEAGd;iFAxHW,eAAe;cAvE3B,SAAS;eAAC;gBACV,UAAU,EAAE,IAAI;gBAChB,OAAO,EAAE,CAAC,YAAY,EAAE,aAAa,CAAC;gBACtC,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,QAAQ,EAAE,YAAY;gBACtB,IAAI,EAAE;oBACL,SAAS,EAAE,2EAA2E;iBACtF;gBACD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA6DT;aACD;gBAKsB,SAAS;kBAA9B,KAAK;mBAAC,aAAa;YAKL,EAAE;kBAAhB,KAAK;mBAAC,MAAM;YAKK,KAAK;kBAAtB,KAAK;mBAAC,SAAS;YAMc,iBAAiB;kBAA9C,KAAK;mBAAC,qBAAqB;YAK6B,IAAI;kBAA5D,KAAK;mBAAC,EAAC,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,kBAAkB,EAAC;YAKhC,UAAU;kBAAhC,KAAK;mBAAC,cAAc;YAKC,SAAS;kBAA9B,KAAK;mBAAC,aAAa;YAKyC,QAAQ;kBAApE,KAAK;mBAAC,EAAC,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,kBAAkB,EAAC;YAKtC,QAAQ;kBAA5B,KAAK;mBAAC,YAAY;YAKyC,OAAO;kBAAlE,KAAK;mBAAC,EAAC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,kBAAkB,EAAC;YAMrC,QAAQ;kBAA5B,KAAK;mBAAC,YAAY;YAKO,aAAa;kBAAtC,KAAK;mBAAC,iBAAiB;YAEG,cAAc;kBAAxC,KAAK;mBAAC,kBAAkB;YACiC,+BAA+B;kBAAxF,YAAY;mBAAC,yBAAyB,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;YAEnC,QAAQ;kBAA5B,KAAK;mBAAC,YAAY;YACiC,yBAAyB;kBAA5E,YAAY;mBAAC,mBAAmB,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;YAKpB,gBAAgB;kBAA7C,MAAM;mBAAC,oBAAoB;YAKA,cAAc;kBAAzC,MAAM;mBAAC,kBAAkB;YAKF,UAAU;kBAAjC,MAAM;mBAAC,cAAc;YAKQ,iBAAiB;kBAA9C,KAAK;mBAAC,qBAAqB;YAKD,cAAc;kBAAxC,KAAK;mBAAC,kBAAkB;YAKD,WAAW;kBAAlC,KAAK;mBAAC,eAAe;YAgBlB,aAAa,MAKb,yBAAyB;kFAtHjB,eAAe","sourcesContent":["import type {AdaptSlotContentProps, ItemContext, SelectItemContext, SelectWidget, SlotContent} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tCachedProperty,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tcallWidgetFactory,\n\tcreateSelect,\n\tmergeDirectives,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport type {AfterContentChecked} from '@angular/core';\nimport {ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, inject} from '@angular/core';\nimport type {Placement} from '@floating-ui/dom';\n\n@Directive({selector: 'ng-template[auSelectBadgeLabel]', standalone: true})\nexport class SelectBadgeLabelDirective<Item> {\n\tpublic templateRef = inject(TemplateRef<AdaptSlotContentProps<SelectItemContext<Item>>>);\n\tstatic ngTemplateContextGuard<Item>(_dir: SelectBadgeLabelDirective<Item>, context: unknown): context is SelectItemContext<Item> {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auSelectItem]', standalone: true})\nexport class SelectItemDirective<Item> {\n\tpublic templateRef = inject(TemplateRef<AdaptSlotContentProps<SelectItemContext<Item>>>);\n\tstatic ngTemplateContextGuard<Item>(_dir: SelectItemDirective<Item>, context: unknown): context is SelectItemContext<Item> {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\timports: [UseDirective, SlotDirective],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tselector: '[auSelect]',\n\thost: {\n\t\t'[class]': '\"au-select dropdown border border-1 p-1 mb-3 d-block\" + state().className',\n\t},\n\ttemplate: `\n\t\t@if (state(); as state) {\n\t\t\t<div\n\t\t\t\t[auUse]=\"controlContainerDirective\"\n\t\t\t\trole=\"combobox\"\n\t\t\t\tclass=\"d-flex align-items-center flex-wrap\"\n\t\t\t\t[attr.aria-controls]=\"state.id + '-menu'\"\n\t\t\t\taria-haspopup=\"listbox\"\n\t\t\t\t[attr.aria-expanded]=\"state.open\"\n\t\t\t>\n\t\t\t\t@if (state.selectedContexts; as selectedContexts) {\n\t\t\t\t\t@for (itemContext of selectedContexts; track itemCtxTrackBy($index, itemContext)) {\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t\t\tclass=\"au-select-badge me-1\"\n\t\t\t\t\t\t\t[class]=\"state.badgeClassName\"\n\t\t\t\t\t\t\t(keydown)=\"_widget.actions.onBadgeKeydown($event, itemContext.item)\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<ng-template [auSlot]=\"state.slotBadgeLabel\" [auSlotProps]=\"{state, widget, itemContext}\"></ng-template>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t<input\n\t\t\t\t\tattr.id=\"{{ state.id }}\"\n\t\t\t\t\tattr.aria-label=\"{{ state.ariaLabel }}\"\n\t\t\t\t\ttype=\"text\"\n\t\t\t\t\tclass=\"au-select-input flex-grow-1 border-0\"\n\t\t\t\t\t[value]=\"state.filterText\"\n\t\t\t\t\taria-autocomplete=\"list\"\n\t\t\t\t\tautoCorrect=\"off\"\n\t\t\t\t\tautoCapitalize=\"none\"\n\t\t\t\t\tautoComplete=\"off\"\n\t\t\t\t\t(input)=\"_widget.actions.onInput($event)\"\n\t\t\t\t\t(keydown)=\"_widget.actions.onInputKeydown($event)\"\n\t\t\t\t/>\n\t\t\t</div>\n\t\t\t@if (state.open && state.visibleItems.length) {\n\t\t\t\t<ul\n\t\t\t\t\trole=\"listbox\"\n\t\t\t\t\t[id]=\"state.id + '-menu'\"\n\t\t\t\t\t[auUse]=\"menuDirective\"\n\t\t\t\t\t[class]=\"'dropdown-menu show ' + (menuClassName || '')\"\n\t\t\t\t\t[attr.data-popper-placement]=\"state.placement\"\n\t\t\t\t\t(mousedown)=\"$event.preventDefault()\"\n\t\t\t\t>\n\t\t\t\t\t@for (itemContext of state.visibleItems; track itemCtxTrackBy($index, itemContext)) {\n\t\t\t\t\t\t<li\n\t\t\t\t\t\t\trole=\"option\"\n\t\t\t\t\t\t\t[attr.aria-selected]=\"itemContext.selected\"\n\t\t\t\t\t\t\tclass=\"au-select-item dropdown-item position-relative \"\n\t\t\t\t\t\t\t[class.text-bg-primary]=\"itemContext === state.highlighted\"\n\t\t\t\t\t\t\t[class.selected]=\"itemContext.selected\"\n\t\t\t\t\t\t\t(click)=\"widget.api.toggleItem(itemContext.item)\"\n\t\t\t\t\t\t\t[style.cursor]=\"'pointer'\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<ng-template [auSlot]=\"state.slotItem\" [auSlotProps]=\"{state, widget, itemContext}\"></ng-template>\n\t\t\t\t\t\t</li>\n\t\t\t\t\t}\n\t\t\t\t</ul>\n\t\t\t}\n\t\t}\n\t`,\n})\nexport class SelectComponent<Item> extends BaseWidgetDirective<SelectWidget<Item>> implements AfterContentChecked {\n\t/**\n\t * aria-label used for the input inside the select\n\t */\n\t@Input('auAriaLabel') ariaLabel: string | undefined;\n\n\t/**\n\t * id used for the input inside the select\n\t */\n\t@Input('auId') id: string | undefined;\n\n\t/**\n\t * List of available items for the dropdown\n\t */\n\t@Input('auItems') items: Item[] | undefined;\n\n\t/**\n\t * List of allowed placements for the dropdown.\n\t * This refers to the [allowedPlacements from floating UI](https://floating-ui.com/docs/autoPlacement#allowedplacements), given the different [Placement possibilities](https://floating-ui.com/docs/computePosition#placement).\n\t */\n\t@Input('auAllowedPlacements') allowedPlacements: Placement[] | undefined;\n\n\t/**\n\t * true if the select is open\n\t */\n\t@Input({alias: 'auOpen', transform: auBooleanAttribute}) open: boolean | undefined;\n\n\t/**\n\t * Filtered text to be display in the filter input\n\t */\n\t@Input('auFilterText') filterText: string | undefined;\n\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t/**\n\t * true if the select is disabled\n\t */\n\t@Input({alias: 'auDisabled', transform: auBooleanAttribute}) disabled: boolean | undefined;\n\n\t/**\n\t * List of selected item ids\n\t */\n\t@Input('auSelected') selected: Item[] | undefined;\n\n\t/**\n\t * true if a loading process is being done\n\t */\n\t@Input({alias: 'auLoading', transform: auBooleanAttribute}) loading: boolean | undefined;\n\n\t/**\n\t * Custom function to get the id of an item\n\t * By default, the item is returned\n\t */\n\t@Input('auItemIdFn') itemIdFn: ((item: Item) => string) | undefined;\n\n\t/**\n\t * Class to be added on the dropdown menu container\n\t */\n\t@Input('auMenuClassName') menuClassName: string | undefined;\n\n\t@Input('auSlotBadgeLabel') slotBadgeLabel: SlotContent<SelectItemContext<Item>>;\n\t@ContentChild(SelectBadgeLabelDirective, {static: false}) slotSelectBadgeLabelFromContent: SelectBadgeLabelDirective<Item> | undefined;\n\n\t@Input('auSlotItem') slotItem: SlotContent<SelectItemContext<Item>>;\n\t@ContentChild(SelectItemDirective, {static: false}) slotSelectItemFromContent: SelectItemDirective<Item> | undefined;\n\n\t/**\n\t * Callback called when the text filter change\n\t */\n\t@Output('auFilterTextChange') filterTextChange = new EventEmitter<string>();\n\n\t/**\n\t * Callback called when the selection change\n\t */\n\t@Output('auSelectedChange') selectedChange = new EventEmitter<Item[]>();\n\n\t/**\n\t * Callback called dropdown open state change\n\t */\n\t@Output('auOpenChange') openChange = new EventEmitter<boolean>();\n\n\t/**\n\t * Class to be added on menu items\n\t */\n\t@Input('auMenuItemClassName') menuItemClassName: string | undefined;\n\n\t/**\n\t * Class to be added on selected items (displayed in the input zone)\n\t */\n\t@Input('auBadgeClassName') badgeClassName: string | undefined;\n\n\t/**\n\t * Retrieves navigable elements within an HTML element containing badges and the input.\n\t */\n\t@Input('auNavSelector') navSelector: ((node: HTMLElement) => NodeListOf<HTMLSpanElement | HTMLInputElement>) | undefined;\n\n\treadonly _widget = callWidgetFactory<SelectWidget<Item>>({\n\t\tfactory: createSelect,\n\t\twidgetName: 'select',\n\t\tevents: {\n\t\t\tonOpenChange: (event) => this.openChange.emit(event),\n\t\t\tonSelectedChange: (event) => this.selectedChange.emit(event),\n\t\t\tonFilterTextChange: (event) => this.filterTextChange.emit(event),\n\t\t},\n\t\tafterInit: () => {\n\t\t\tuseDirectiveForHost(this._widget.directives.referenceDirective);\n\t\t},\n\t});\n\n\t@CachedProperty\n\tget menuDirective() {\n\t\treturn mergeDirectives(this._widget.directives.hasFocusDirective, this._widget.directives.floatingDirective);\n\t}\n\n\t@CachedProperty\n\tget controlContainerDirective() {\n\t\treturn mergeDirectives(this._widget.directives.hasFocusDirective, this._widget.directives.inputContainerDirective);\n\t}\n\n\titemCtxTrackBy(_: number, itemContext: ItemContext<Item>) {\n\t\treturn itemContext.id;\n\t}\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tslotBadgeLabel: this.slotSelectBadgeLabelFromContent?.templateRef,\n\t\t\tslotItem: this.slotSelectItemFromContent?.templateRef,\n\t\t});\n\t}\n}\n"]}