@agnos-ui/angular
Version:
Bootstrap-based widget library for Angular.
314 lines • 35 kB
JavaScript
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
[]="controlContainerDirective"
role="combobox"
class="d-flex align-items-center flex-wrap"
[]="state.id + '-menu'"
aria-haspopup="listbox"
[]="state.open"
>
@if (state.selectedContexts; as selectedContexts) {
@for (itemContext of selectedContexts; track itemCtxTrackBy($index, itemContext)) {
<div
tabindex="-1"
class="au-select-badge me-1"
[]="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"
[]="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"
[]="state.id + '-menu'"
[]="menuDirective"
[]="'dropdown-menu show ' + (menuClassName || '')"
[]="state.placement"
(mousedown)="$event.preventDefault()"
>
@for (itemContext of state.visibleItems; track itemCtxTrackBy($index, itemContext)) {
<li
role="option"
[]="itemContext.selected"
class="au-select-item dropdown-item position-relative "
[]="itemContext === state.highlighted"
[]="itemContext.selected"
(click)="widget.api.toggleItem(itemContext.item)"
[]="'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":"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","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"]}