@agnos-ui/angular-bootstrap 0.4.3 → 0.5.0-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/agnos-ui-angular.module.d.ts +2 -1
- package/components/accordion/accordion.component.d.ts +40 -18
- package/components/accordion/accordion.gen.d.ts +37 -9
- package/components/alert/alert.component.d.ts +29 -17
- package/components/alert/alert.gen.d.ts +21 -2
- package/components/collapse/collapse.component.d.ts +79 -0
- package/components/collapse/collapse.gen.d.ts +146 -0
- package/components/collapse/index.d.ts +2 -0
- package/components/modal/modal.component.d.ts +13 -19
- package/components/modal/modal.gen.d.ts +35 -18
- package/components/modal/modal.service.d.ts +5 -1
- package/components/pagination/pagination.component.d.ts +20 -15
- package/components/pagination/pagination.gen.d.ts +49 -29
- package/components/progressbar/progressbar.component.d.ts +32 -16
- package/components/progressbar/progressbar.gen.d.ts +21 -4
- package/components/rating/rating.component.d.ts +11 -4
- package/components/rating/rating.gen.d.ts +25 -17
- package/components/select/select.component.d.ts +24 -4
- package/components/select/select.gen.d.ts +41 -25
- package/components/slider/slider.component.d.ts +32 -23
- package/components/slider/slider.gen.d.ts +54 -33
- package/components/toast/toast.component.d.ts +29 -17
- package/components/toast/toast.gen.d.ts +22 -2
- package/config.d.ts +16 -5
- package/config.gen.d.ts +5 -0
- package/esm2022/agnos-ui-angular.module.mjs +12 -5
- package/esm2022/components/accordion/accordion.component.mjs +165 -134
- package/esm2022/components/accordion/accordion.gen.mjs +1 -1
- package/esm2022/components/alert/alert.component.mjs +90 -65
- package/esm2022/components/alert/alert.gen.mjs +1 -1
- package/esm2022/components/collapse/collapse.component.mjs +89 -0
- package/esm2022/components/collapse/collapse.gen.mjs +15 -0
- package/esm2022/components/collapse/index.mjs +3 -0
- package/esm2022/components/modal/modal.component.mjs +111 -99
- package/esm2022/components/modal/modal.gen.mjs +1 -1
- package/esm2022/components/modal/modal.service.mjs +7 -5
- package/esm2022/components/pagination/pagination.component.mjs +138 -123
- package/esm2022/components/pagination/pagination.gen.mjs +1 -1
- package/esm2022/components/progressbar/progressbar.component.mjs +94 -55
- package/esm2022/components/progressbar/progressbar.gen.mjs +1 -1
- package/esm2022/components/rating/rating.component.mjs +41 -35
- package/esm2022/components/rating/rating.gen.mjs +1 -1
- package/esm2022/components/select/select.component.mjs +103 -118
- package/esm2022/components/select/select.gen.mjs +1 -1
- package/esm2022/components/slider/slider.component.mjs +126 -111
- package/esm2022/components/slider/slider.gen.mjs +1 -1
- package/esm2022/components/toast/toast.component.mjs +106 -81
- package/esm2022/components/toast/toast.gen.mjs +1 -1
- package/esm2022/config.gen.mjs +1 -1
- package/esm2022/config.mjs +17 -1
- package/esm2022/index.mjs +2 -1
- package/fesm2022/agnos-ui-angular-bootstrap.mjs +1085 -806
- package/fesm2022/agnos-ui-angular-bootstrap.mjs.map +1 -1
- package/index.d.ts +8 -7
- package/package.json +9 -8
|
@@ -5,72 +5,55 @@ import { createSelect } from './select.gen';
|
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
const _c0 = ["auSelect", ""];
|
|
7
7
|
const _c1 = (a0, a1) => [a0, a1];
|
|
8
|
-
const _c2 = (a0, a1, a2) => ({ state: a0,
|
|
8
|
+
const _c2 = (a0, a1, a2, a3) => ({ state: a0, api: a1, directives: a2, itemContext: a3 });
|
|
9
9
|
const _c3 = (a0, a1, a2) => [a0, a1, a2];
|
|
10
|
-
function
|
|
11
|
-
function
|
|
10
|
+
function SelectComponent_Conditional_1_For_1_ng_template_1_Template(rf, ctx) { }
|
|
11
|
+
function SelectComponent_Conditional_1_For_1_Template(rf, ctx) { if (rf & 1) {
|
|
12
12
|
i0.ɵɵelementStart(0, "div", 3);
|
|
13
|
-
i0.ɵɵtemplate(1,
|
|
13
|
+
i0.ɵɵtemplate(1, SelectComponent_Conditional_1_For_1_ng_template_1_Template, 0, 0, "ng-template", 4);
|
|
14
14
|
i0.ɵɵelementEnd();
|
|
15
15
|
} if (rf & 2) {
|
|
16
|
-
const
|
|
17
|
-
const
|
|
18
|
-
|
|
19
|
-
i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(3, _c1, ctx_r3._widget.directives.badgeAttributesDirective, itemContext_r2));
|
|
16
|
+
const itemContext_r1 = ctx.$implicit;
|
|
17
|
+
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
18
|
+
i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(3, _c1, ctx_r1.directives.badgeAttributesDirective, itemContext_r1));
|
|
20
19
|
i0.ɵɵadvance();
|
|
21
|
-
i0.ɵɵproperty("auSlot",
|
|
20
|
+
i0.ɵɵproperty("auSlot", ctx_r1.state.badgeLabel())("auSlotProps", i0.ɵɵpureFunction4(6, _c2, ctx_r1.state, ctx_r1.api, ctx_r1.directives, itemContext_r1));
|
|
22
21
|
} }
|
|
23
|
-
function
|
|
24
|
-
i0.ɵɵrepeaterCreate(0,
|
|
22
|
+
function SelectComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
|
|
23
|
+
i0.ɵɵrepeaterCreate(0, SelectComponent_Conditional_1_For_1_Template, 2, 11, "div", 3, i0.ɵɵcomponentInstance().itemCtxTrackBy, true);
|
|
25
24
|
} if (rf & 2) {
|
|
26
25
|
i0.ɵɵrepeater(ctx);
|
|
27
26
|
} }
|
|
28
|
-
function
|
|
29
|
-
function
|
|
27
|
+
function SelectComponent_Conditional_3_For_2_ng_template_1_Template(rf, ctx) { }
|
|
28
|
+
function SelectComponent_Conditional_3_For_2_Template(rf, ctx) { if (rf & 1) {
|
|
30
29
|
i0.ɵɵelementStart(0, "li", 6);
|
|
31
|
-
i0.ɵɵtemplate(1,
|
|
30
|
+
i0.ɵɵtemplate(1, SelectComponent_Conditional_3_For_2_ng_template_1_Template, 0, 0, "ng-template", 4);
|
|
32
31
|
i0.ɵɵelementEnd();
|
|
33
32
|
} if (rf & 2) {
|
|
34
|
-
const
|
|
35
|
-
const
|
|
36
|
-
|
|
37
|
-
i0.ɵɵ
|
|
38
|
-
i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(5, _c1, ctx_r3._widget.directives.itemAttributesDirective, itemContext_r5));
|
|
33
|
+
const itemContext_r3 = ctx.$implicit;
|
|
34
|
+
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
35
|
+
i0.ɵɵclassProp("text-bg-primary", itemContext_r3 === ctx_r1.state.highlighted());
|
|
36
|
+
i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(5, _c1, ctx_r1.directives.itemAttributesDirective, itemContext_r3));
|
|
39
37
|
i0.ɵɵadvance();
|
|
40
|
-
i0.ɵɵproperty("auSlot",
|
|
38
|
+
i0.ɵɵproperty("auSlot", ctx_r1.state.itemLabel())("auSlotProps", i0.ɵɵpureFunction4(8, _c2, ctx_r1.state, ctx_r1.api, ctx_r1.directives, itemContext_r3));
|
|
41
39
|
} }
|
|
42
|
-
function
|
|
40
|
+
function SelectComponent_Conditional_3_Template(rf, ctx) { if (rf & 1) {
|
|
43
41
|
i0.ɵɵelementStart(0, "ul", 2);
|
|
44
|
-
i0.ɵɵrepeaterCreate(1,
|
|
42
|
+
i0.ɵɵrepeaterCreate(1, SelectComponent_Conditional_3_For_2_Template, 2, 13, "li", 5, i0.ɵɵcomponentInstance().itemCtxTrackBy, true);
|
|
45
43
|
i0.ɵɵelementEnd();
|
|
46
44
|
} if (rf & 2) {
|
|
47
|
-
const
|
|
48
|
-
|
|
49
|
-
i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction3(1, _c3, ctx_r3.widget.directives.hasFocusDirective, ctx_r3.widget.directives.floatingDirective, ctx_r3.widget.directives.menuAttributesDirective));
|
|
45
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
46
|
+
i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction3(1, _c3, ctx_r1.directives.hasFocusDirective, ctx_r1.directives.floatingDirective, ctx_r1.directives.menuAttributesDirective));
|
|
50
47
|
i0.ɵɵadvance();
|
|
51
|
-
i0.ɵɵrepeater(
|
|
52
|
-
} }
|
|
53
|
-
function SelectComponent_Conditional_0_Template(rf, ctx) { if (rf & 1) {
|
|
54
|
-
const _r1 = i0.ɵɵgetCurrentView();
|
|
55
|
-
i0.ɵɵelementStart(0, "div", 0);
|
|
56
|
-
i0.ɵɵtemplate(1, SelectComponent_Conditional_0_Conditional_1_Template, 2, 0);
|
|
57
|
-
i0.ɵɵelementStart(2, "input", 1);
|
|
58
|
-
i0.ɵɵlistener("input", function SelectComponent_Conditional_0_Template_input_input_2_listener($event) { i0.ɵɵrestoreView(_r1); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3._widget.actions.onInput($event)); })("keydown", function SelectComponent_Conditional_0_Template_input_keydown_2_listener($event) { i0.ɵɵrestoreView(_r1); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3._widget.actions.onInputKeydown($event)); });
|
|
59
|
-
i0.ɵɵelementEnd()();
|
|
60
|
-
i0.ɵɵtemplate(3, SelectComponent_Conditional_0_Conditional_3_Template, 3, 5, "ul", 2);
|
|
61
|
-
} if (rf & 2) {
|
|
62
|
-
let tmp_3_0;
|
|
63
|
-
const state_r3 = ctx;
|
|
64
|
-
const ctx_r3 = i0.ɵɵnextContext();
|
|
65
|
-
i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction2(6, _c1, ctx_r3.widget.directives.hasFocusDirective, ctx_r3.widget.directives.inputContainerDirective));
|
|
66
|
-
i0.ɵɵadvance();
|
|
67
|
-
i0.ɵɵconditional((tmp_3_0 = state_r3.selectedContexts) ? 1 : -1, tmp_3_0);
|
|
68
|
-
i0.ɵɵadvance();
|
|
69
|
-
i0.ɵɵproperty("value", state_r3.filterText);
|
|
70
|
-
i0.ɵɵattribute("id", state_r3.id)("aria-label", state_r3.ariaLabel);
|
|
71
|
-
i0.ɵɵadvance();
|
|
72
|
-
i0.ɵɵconditional(state_r3.open && state_r3.visibleItems.length ? 3 : -1);
|
|
48
|
+
i0.ɵɵrepeater(ctx_r1.state.visibleItems());
|
|
73
49
|
} }
|
|
50
|
+
/**
|
|
51
|
+
* Directive to provide a custom template for the badge label in a select component.
|
|
52
|
+
*
|
|
53
|
+
* @template Item - The type of the item in the select component.
|
|
54
|
+
*
|
|
55
|
+
* This directive uses a template reference to render the {@link SelectItemContext<Item>}.
|
|
56
|
+
*/
|
|
74
57
|
export class SelectBadgeLabelDirective {
|
|
75
58
|
constructor() {
|
|
76
59
|
this.templateRef = inject((TemplateRef));
|
|
@@ -78,13 +61,23 @@ export class SelectBadgeLabelDirective {
|
|
|
78
61
|
static ngTemplateContextGuard(_dir, context) {
|
|
79
62
|
return true;
|
|
80
63
|
}
|
|
81
|
-
static { this.ɵfac = function SelectBadgeLabelDirective_Factory(
|
|
64
|
+
static { this.ɵfac = function SelectBadgeLabelDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SelectBadgeLabelDirective)(); }; }
|
|
82
65
|
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SelectBadgeLabelDirective, selectors: [["ng-template", "auSelectBadgeLabel", ""]], standalone: true }); }
|
|
83
66
|
}
|
|
84
67
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectBadgeLabelDirective, [{
|
|
85
68
|
type: Directive,
|
|
86
69
|
args: [{ selector: 'ng-template[auSelectBadgeLabel]', standalone: true }]
|
|
87
70
|
}], null, null); })();
|
|
71
|
+
/**
|
|
72
|
+
* Directive to provide a custom label template for select items.
|
|
73
|
+
*
|
|
74
|
+
* This directive allows you to define a custom template for the labels of items
|
|
75
|
+
* in a select component. The template can be specified using an Angular `TemplateRef`.
|
|
76
|
+
*
|
|
77
|
+
* @template Item - The type of the items in the select component.
|
|
78
|
+
*
|
|
79
|
+
* This directive uses a template reference to render the {@link SelectItemContext<Item>}.
|
|
80
|
+
*/
|
|
88
81
|
export class SelectItemLabelDirective {
|
|
89
82
|
constructor() {
|
|
90
83
|
this.templateRef = inject((TemplateRef));
|
|
@@ -92,16 +85,36 @@ export class SelectItemLabelDirective {
|
|
|
92
85
|
static ngTemplateContextGuard(_dir, context) {
|
|
93
86
|
return true;
|
|
94
87
|
}
|
|
95
|
-
static { this.ɵfac = function SelectItemLabelDirective_Factory(
|
|
88
|
+
static { this.ɵfac = function SelectItemLabelDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SelectItemLabelDirective)(); }; }
|
|
96
89
|
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SelectItemLabelDirective, selectors: [["ng-template", "auSelectItemLabel", ""]], standalone: true }); }
|
|
97
90
|
}
|
|
98
91
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectItemLabelDirective, [{
|
|
99
92
|
type: Directive,
|
|
100
93
|
args: [{ selector: 'ng-template[auSelectItemLabel]', standalone: true }]
|
|
101
94
|
}], null, null); })();
|
|
95
|
+
/**
|
|
96
|
+
* A component that represents a customizable select dropdown widget.
|
|
97
|
+
*
|
|
98
|
+
* @template Item - The type of items in the select dropdown.
|
|
99
|
+
*/
|
|
102
100
|
export class SelectComponent extends BaseWidgetDirective {
|
|
103
101
|
constructor() {
|
|
104
|
-
super(
|
|
102
|
+
super(callWidgetFactory({
|
|
103
|
+
factory: createSelect,
|
|
104
|
+
widgetName: 'select',
|
|
105
|
+
events: {
|
|
106
|
+
onOpenChange: (event) => this.openChange.emit(event),
|
|
107
|
+
onSelectedChange: (event) => this.selectedChange.emit(event),
|
|
108
|
+
onFilterTextChange: (event) => this.filterTextChange.emit(event),
|
|
109
|
+
},
|
|
110
|
+
afterInit: (widget) => {
|
|
111
|
+
useDirectiveForHost(widget.directives.referenceDirective);
|
|
112
|
+
},
|
|
113
|
+
slotTemplates: () => ({
|
|
114
|
+
badgeLabel: this.slotSelectBadgeLabelFromContent?.templateRef,
|
|
115
|
+
itemLabel: this.slotSelectItemLabelFromContent?.templateRef,
|
|
116
|
+
}),
|
|
117
|
+
}));
|
|
105
118
|
/**
|
|
106
119
|
* Callback called when the text filter change
|
|
107
120
|
* @param text - Filtered text
|
|
@@ -131,29 +144,11 @@ export class SelectComponent extends BaseWidgetDirective {
|
|
|
131
144
|
* ```
|
|
132
145
|
*/
|
|
133
146
|
this.openChange = new EventEmitter();
|
|
134
|
-
this._widget = callWidgetFactory({
|
|
135
|
-
factory: createSelect,
|
|
136
|
-
widgetName: 'select',
|
|
137
|
-
events: {
|
|
138
|
-
onOpenChange: (event) => this.openChange.emit(event),
|
|
139
|
-
onSelectedChange: (event) => this.selectedChange.emit(event),
|
|
140
|
-
onFilterTextChange: (event) => this.filterTextChange.emit(event),
|
|
141
|
-
},
|
|
142
|
-
afterInit: () => {
|
|
143
|
-
useDirectiveForHost(this._widget.directives.referenceDirective);
|
|
144
|
-
},
|
|
145
|
-
});
|
|
146
147
|
}
|
|
147
148
|
itemCtxTrackBy(_, itemContext) {
|
|
148
149
|
return itemContext.id;
|
|
149
150
|
}
|
|
150
|
-
|
|
151
|
-
this._widget.patchSlots({
|
|
152
|
-
badgeLabel: this.slotSelectBadgeLabelFromContent?.templateRef,
|
|
153
|
-
itemLabel: this.slotSelectItemLabelFromContent?.templateRef,
|
|
154
|
-
});
|
|
155
|
-
}
|
|
156
|
-
static { this.ɵfac = /*@__PURE__*/ (() => { let ɵSelectComponent_BaseFactory; return function SelectComponent_Factory(t) { return (ɵSelectComponent_BaseFactory || (ɵSelectComponent_BaseFactory = i0.ɵɵgetInheritedFactory(SelectComponent)))(t || SelectComponent); }; })(); }
|
|
151
|
+
static { this.ɵfac = function SelectComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SelectComponent)(); }; }
|
|
157
152
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SelectComponent, selectors: [["", "auSelect", ""]], contentQueries: function SelectComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
|
158
153
|
i0.ɵɵcontentQuery(dirIndex, SelectBadgeLabelDirective, 5);
|
|
159
154
|
i0.ɵɵcontentQuery(dirIndex, SelectItemLabelDirective, 5);
|
|
@@ -162,12 +157,22 @@ export class SelectComponent extends BaseWidgetDirective {
|
|
|
162
157
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotSelectBadgeLabelFromContent = _t.first);
|
|
163
158
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotSelectItemLabelFromContent = _t.first);
|
|
164
159
|
} }, hostVars: 2, hostBindings: function SelectComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
165
|
-
i0.ɵɵclassMap("au-select dropdown border border-1 p-1 mb-3 d-block" + ctx.state
|
|
166
|
-
} }, inputs: { ariaLabel: [0, "auAriaLabel", "ariaLabel"], id: [0, "auId", "id"], items: [0, "auItems", "items"], allowedPlacements: [0, "auAllowedPlacements", "allowedPlacements"], open: [2, "auOpen", "open", auBooleanAttribute], filterText: [0, "auFilterText", "filterText"], className: [0, "auClassName", "className"], disabled: [2, "auDisabled", "disabled", auBooleanAttribute], selected: [0, "auSelected", "selected"], loading: [2, "auLoading", "loading", auBooleanAttribute], itemIdFn: [0, "auItemIdFn", "itemIdFn"], menuClassName: [0, "auMenuClassName", "menuClassName"], badgeLabel: [0, "auBadgeLabel", "badgeLabel"], itemLabel: [0, "auItemLabel", "itemLabel"], menuItemClassName: [0, "auMenuItemClassName", "menuItemClassName"], badgeClassName: [0, "auBadgeClassName", "badgeClassName"], navSelector: [0, "auNavSelector", "navSelector"] }, outputs: { filterTextChange: "auFilterTextChange", selectedChange: "auSelectedChange", openChange: "auOpenChange" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c0, decls:
|
|
167
|
-
i0.ɵɵ
|
|
160
|
+
i0.ɵɵclassMap("au-select dropdown border border-1 p-1 mb-3 d-block" + ctx.state.className());
|
|
161
|
+
} }, inputs: { ariaLabel: [0, "auAriaLabel", "ariaLabel"], id: [0, "auId", "id"], items: [0, "auItems", "items"], allowedPlacements: [0, "auAllowedPlacements", "allowedPlacements"], open: [2, "auOpen", "open", auBooleanAttribute], filterText: [0, "auFilterText", "filterText"], className: [0, "auClassName", "className"], disabled: [2, "auDisabled", "disabled", auBooleanAttribute], selected: [0, "auSelected", "selected"], loading: [2, "auLoading", "loading", auBooleanAttribute], itemIdFn: [0, "auItemIdFn", "itemIdFn"], menuClassName: [0, "auMenuClassName", "menuClassName"], badgeLabel: [0, "auBadgeLabel", "badgeLabel"], itemLabel: [0, "auItemLabel", "itemLabel"], menuItemClassName: [0, "auMenuItemClassName", "menuItemClassName"], badgeClassName: [0, "auBadgeClassName", "badgeClassName"], navSelector: [0, "auNavSelector", "navSelector"] }, outputs: { filterTextChange: "auFilterTextChange", selectedChange: "auSelectedChange", openChange: "auOpenChange" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c0, decls: 4, vars: 8, consts: [[1, "d-flex", "align-items-center", "flex-wrap", "gap-1", 3, "auUseMulti"], [3, "auUse", "value"], [1, "dropdown-menu", "show", 3, "auUseMulti"], [3, "auUse"], [3, "auSlot", "auSlotProps"], [1, "dropdown-item", "position-relative", 3, "auUse", "text-bg-primary"], [1, "dropdown-item", "position-relative", 3, "auUse"]], template: function SelectComponent_Template(rf, ctx) { if (rf & 1) {
|
|
162
|
+
i0.ɵɵelementStart(0, "div", 0);
|
|
163
|
+
i0.ɵɵtemplate(1, SelectComponent_Conditional_1_Template, 2, 0);
|
|
164
|
+
i0.ɵɵelement(2, "input", 1);
|
|
165
|
+
i0.ɵɵelementEnd();
|
|
166
|
+
i0.ɵɵtemplate(3, SelectComponent_Conditional_3_Template, 3, 5, "ul", 2);
|
|
168
167
|
} if (rf & 2) {
|
|
169
|
-
let
|
|
170
|
-
i0.ɵɵ
|
|
168
|
+
let tmp_1_0;
|
|
169
|
+
i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction2(5, _c1, ctx.directives.hasFocusDirective, ctx.directives.inputContainerDirective));
|
|
170
|
+
i0.ɵɵadvance();
|
|
171
|
+
i0.ɵɵconditional((tmp_1_0 = ctx.state.selectedContexts()) ? 1 : -1, tmp_1_0);
|
|
172
|
+
i0.ɵɵadvance();
|
|
173
|
+
i0.ɵɵproperty("auUse", ctx.directives.inputDirective)("value", ctx.state.filterText());
|
|
174
|
+
i0.ɵɵadvance();
|
|
175
|
+
i0.ɵɵconditional(ctx.state.open() && ctx.state.visibleItems().length ? 3 : -1);
|
|
171
176
|
} }, dependencies: [UseMultiDirective, SlotDirective, UseDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
172
177
|
}
|
|
173
178
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectComponent, [{
|
|
@@ -178,55 +183,35 @@ export class SelectComponent extends BaseWidgetDirective {
|
|
|
178
183
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
179
184
|
selector: '[auSelect]',
|
|
180
185
|
host: {
|
|
181
|
-
'[class]': '"au-select dropdown border border-1 p-1 mb-3 d-block" + state()
|
|
186
|
+
'[class]': '"au-select dropdown border border-1 p-1 mb-3 d-block" + state.className()',
|
|
182
187
|
},
|
|
183
188
|
template: `
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
@for (itemContext of selectedContexts; track itemCtxTrackBy($index, itemContext)) {
|
|
191
|
-
<div [auUse]="[_widget.directives.badgeAttributesDirective, itemContext]">
|
|
192
|
-
<ng-template [auSlot]="state.badgeLabel" [auSlotProps]="{state, widget, itemContext}"></ng-template>
|
|
193
|
-
</div>
|
|
194
|
-
}
|
|
189
|
+
<div [auUseMulti]="[directives.hasFocusDirective, directives.inputContainerDirective]" class="d-flex align-items-center flex-wrap gap-1">
|
|
190
|
+
@if (state.selectedContexts(); as selectedContexts) {
|
|
191
|
+
@for (itemContext of selectedContexts; track itemCtxTrackBy($index, itemContext)) {
|
|
192
|
+
<div [auUse]="[directives.badgeAttributesDirective, itemContext]">
|
|
193
|
+
<ng-template [auSlot]="state.badgeLabel()" [auSlotProps]="{state, api, directives, itemContext}"></ng-template>
|
|
194
|
+
</div>
|
|
195
195
|
}
|
|
196
|
-
<input
|
|
197
|
-
attr.id="{{ state.id }}"
|
|
198
|
-
attr.aria-label="{{ state.ariaLabel }}"
|
|
199
|
-
type="text"
|
|
200
|
-
class="au-select-input flex-grow-1 border-0"
|
|
201
|
-
[value]="state.filterText"
|
|
202
|
-
aria-autocomplete="list"
|
|
203
|
-
autoCorrect="off"
|
|
204
|
-
autoCapitalize="none"
|
|
205
|
-
autoComplete="off"
|
|
206
|
-
(input)="_widget.actions.onInput($event)"
|
|
207
|
-
(keydown)="_widget.actions.onInputKeydown($event)"
|
|
208
|
-
/>
|
|
209
|
-
</div>
|
|
210
|
-
@if (state.open && state.visibleItems.length) {
|
|
211
|
-
<ul
|
|
212
|
-
[auUseMulti]="[widget.directives.hasFocusDirective, widget.directives.floatingDirective, widget.directives.menuAttributesDirective]"
|
|
213
|
-
class="dropdown-menu show"
|
|
214
|
-
>
|
|
215
|
-
@for (itemContext of state.visibleItems; track itemCtxTrackBy($index, itemContext)) {
|
|
216
|
-
<li
|
|
217
|
-
class="dropdown-item position-relative"
|
|
218
|
-
[auUse]="[_widget.directives.itemAttributesDirective, itemContext]"
|
|
219
|
-
[class.text-bg-primary]="itemContext === state.highlighted"
|
|
220
|
-
>
|
|
221
|
-
<ng-template [auSlot]="state.itemLabel" [auSlotProps]="{state, widget, itemContext}"></ng-template>
|
|
222
|
-
</li>
|
|
223
|
-
}
|
|
224
|
-
</ul>
|
|
225
196
|
}
|
|
197
|
+
<input [auUse]="directives.inputDirective" [value]="state.filterText()" />
|
|
198
|
+
</div>
|
|
199
|
+
@if (state.open() && state.visibleItems().length) {
|
|
200
|
+
<ul [auUseMulti]="[directives.hasFocusDirective, directives.floatingDirective, directives.menuAttributesDirective]" class="dropdown-menu show">
|
|
201
|
+
@for (itemContext of state.visibleItems(); track itemCtxTrackBy($index, itemContext)) {
|
|
202
|
+
<li
|
|
203
|
+
class="dropdown-item position-relative"
|
|
204
|
+
[auUse]="[directives.itemAttributesDirective, itemContext]"
|
|
205
|
+
[class.text-bg-primary]="itemContext === state.highlighted()"
|
|
206
|
+
>
|
|
207
|
+
<ng-template [auSlot]="state.itemLabel()" [auSlotProps]="{state, api, directives, itemContext}"></ng-template>
|
|
208
|
+
</li>
|
|
209
|
+
}
|
|
210
|
+
</ul>
|
|
226
211
|
}
|
|
227
212
|
`,
|
|
228
213
|
}]
|
|
229
|
-
}],
|
|
214
|
+
}], () => [], { ariaLabel: [{
|
|
230
215
|
type: Input,
|
|
231
216
|
args: ['auAriaLabel']
|
|
232
217
|
}], id: [{
|
|
@@ -293,5 +278,5 @@ export class SelectComponent extends BaseWidgetDirective {
|
|
|
293
278
|
type: Input,
|
|
294
279
|
args: ['auNavSelector']
|
|
295
280
|
}] }); })();
|
|
296
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectComponent, { className: "SelectComponent", filePath: "components/select/select.component.ts", lineNumber:
|
|
297
|
-
//# 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 {SlotContent} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tSlotDirective,\n\tUseDirective,\n\tUseMultiDirective,\n\tauBooleanAttribute,\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';\nimport {callWidgetFactory} from '../../config';\nimport type {ItemContext, SelectItemContext, SelectWidget} from './select.gen';\nimport {createSelect} from './select.gen';\n\n@Directive({selector: 'ng-template[auSelectBadgeLabel]', standalone: true})\nexport class SelectBadgeLabelDirective<Item> {\n\tpublic templateRef = inject(TemplateRef<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[auSelectItemLabel]', standalone: true})\nexport class SelectItemLabelDirective<Item> {\n\tpublic templateRef = inject(TemplateRef<SelectItemContext<Item>>);\n\tstatic ngTemplateContextGuard<Item>(_dir: SelectItemLabelDirective<Item>, context: unknown): context is SelectItemContext<Item> {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\timports: [UseMultiDirective, SlotDirective, UseDirective],\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[auUseMulti]=\"[widget.directives.hasFocusDirective, widget.directives.inputContainerDirective]\"\n\t\t\t\tclass=\"d-flex align-items-center flex-wrap gap-1\"\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 [auUse]=\"[_widget.directives.badgeAttributesDirective, itemContext]\">\n\t\t\t\t\t\t\t<ng-template [auSlot]=\"state.badgeLabel\" [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\t[auUseMulti]=\"[widget.directives.hasFocusDirective, widget.directives.floatingDirective, widget.directives.menuAttributesDirective]\"\n\t\t\t\t\tclass=\"dropdown-menu show\"\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\tclass=\"dropdown-item position-relative\"\n\t\t\t\t\t\t\t[auUse]=\"[_widget.directives.itemAttributesDirective, itemContext]\"\n\t\t\t\t\t\t\t[class.text-bg-primary]=\"itemContext === state.highlighted\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<ng-template [auSlot]=\"state.itemLabel\" [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 * @defaultValue `'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 * @defaultValue `[]`\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 * @defaultValue\n\t * ```ts\n\t * ['bottom-start', 'top-start', 'bottom-end', 'top-end']\n\t * ```\n\t */\n\t@Input('auAllowedPlacements') allowedPlacements: Placement[] | undefined;\n\n\t/**\n\t * true if the select is open\n\t *\n\t * @defaultValue `false`\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 * @defaultValue `''`\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 * @defaultValue `''`\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t/**\n\t * true if the select is disabled\n\t *\n\t * @defaultValue `false`\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 * @defaultValue `[]`\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 * @defaultValue `false`\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 * @defaultValue\n\t * ```ts\n\t * (item: any) => '' + item\n\t * ```\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 * @defaultValue `''`\n\t */\n\t@Input('auMenuClassName') menuClassName: string | undefined;\n\n\t/**\n\t * The template to override the way each badge on the left of the input is displayed.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\t@Input('auBadgeLabel') badgeLabel: SlotContent<SelectItemContext<Item>>;\n\t@ContentChild(SelectBadgeLabelDirective, {static: false}) slotSelectBadgeLabelFromContent: SelectBadgeLabelDirective<Item> | undefined;\n\n\t/**\n\t * The template to override the way each item is displayed in the list.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\t@Input('auItemLabel') itemLabel: SlotContent<SelectItemContext<Item>>;\n\t@ContentChild(SelectItemLabelDirective, {static: false}) slotSelectItemLabelFromContent: SelectItemLabelDirective<Item> | undefined;\n\n\t/**\n\t * Callback called when the text filter change\n\t * @param text - Filtered text\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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 * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auSelectedChange') selectedChange = new EventEmitter<Item[]>();\n\n\t/**\n\t * Callback called dropdown open state change\n\t * @param isOpen - updated open state\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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 * @defaultValue `''`\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 * @defaultValue `''`\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 * @param node - HTMLElement that contains the badges and the input\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (node: HTMLElement) => node.querySelectorAll('.au-select-badge,input')\n\t * ```\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\titemCtxTrackBy(_: number, itemContext: ItemContext<Item>) {\n\t\treturn itemContext.id;\n\t}\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tbadgeLabel: this.slotSelectBadgeLabelFromContent?.templateRef,\n\t\t\titemLabel: this.slotSelectItemLabelFromContent?.templateRef,\n\t\t});\n\t}\n}\n"]}
|
|
281
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectComponent, { className: "SelectComponent", filePath: "components/select/select.component.ts", lineNumber: 88 }); })();
|
|
282
|
+
//# 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 {SlotContent} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tSlotDirective,\n\tUseDirective,\n\tUseMultiDirective,\n\tauBooleanAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport {ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, inject} from '@angular/core';\nimport type {Placement} from '@floating-ui/dom';\nimport {callWidgetFactory} from '../../config';\nimport type {ItemContext, SelectItemContext, SelectWidget} from './select.gen';\nimport {createSelect} from './select.gen';\n\n/**\n * Directive to provide a custom template for the badge label in a select component.\n *\n * @template Item - The type of the item in the select component.\n *\n * This directive uses a template reference to render the {@link SelectItemContext<Item>}.\n */\n@Directive({selector: 'ng-template[auSelectBadgeLabel]', standalone: true})\nexport class SelectBadgeLabelDirective<Item> {\n\tpublic templateRef = inject(TemplateRef<SelectItemContext<Item>>);\n\tstatic ngTemplateContextGuard<Item>(_dir: SelectBadgeLabelDirective<Item>, context: unknown): context is SelectItemContext<Item> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide a custom label template for select items.\n *\n * This directive allows you to define a custom template for the labels of items\n * in a select component. The template can be specified using an Angular `TemplateRef`.\n *\n * @template Item - The type of the items in the select component.\n *\n * This directive uses a template reference to render the {@link SelectItemContext<Item>}.\n */\n@Directive({selector: 'ng-template[auSelectItemLabel]', standalone: true})\nexport class SelectItemLabelDirective<Item> {\n\tpublic templateRef = inject(TemplateRef<SelectItemContext<Item>>);\n\tstatic ngTemplateContextGuard<Item>(_dir: SelectItemLabelDirective<Item>, context: unknown): context is SelectItemContext<Item> {\n\t\treturn true;\n\t}\n}\n\n/**\n * A component that represents a customizable select dropdown widget.\n *\n * @template Item - The type of items in the select dropdown.\n */\n@Component({\n\tstandalone: true,\n\timports: [UseMultiDirective, SlotDirective, UseDirective],\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<div [auUseMulti]=\"[directives.hasFocusDirective, directives.inputContainerDirective]\" class=\"d-flex align-items-center flex-wrap gap-1\">\n\t\t\t@if (state.selectedContexts(); as selectedContexts) {\n\t\t\t\t@for (itemContext of selectedContexts; track itemCtxTrackBy($index, itemContext)) {\n\t\t\t\t\t<div [auUse]=\"[directives.badgeAttributesDirective, itemContext]\">\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.badgeLabel()\" [auSlotProps]=\"{state, api, directives, itemContext}\"></ng-template>\n\t\t\t\t\t</div>\n\t\t\t\t}\n\t\t\t}\n\t\t\t<input [auUse]=\"directives.inputDirective\" [value]=\"state.filterText()\" />\n\t\t</div>\n\t\t@if (state.open() && state.visibleItems().length) {\n\t\t\t<ul [auUseMulti]=\"[directives.hasFocusDirective, directives.floatingDirective, directives.menuAttributesDirective]\" class=\"dropdown-menu show\">\n\t\t\t\t@for (itemContext of state.visibleItems(); track itemCtxTrackBy($index, itemContext)) {\n\t\t\t\t\t<li\n\t\t\t\t\t\tclass=\"dropdown-item position-relative\"\n\t\t\t\t\t\t[auUse]=\"[directives.itemAttributesDirective, itemContext]\"\n\t\t\t\t\t\t[class.text-bg-primary]=\"itemContext === state.highlighted()\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.itemLabel()\" [auSlotProps]=\"{state, api, directives, itemContext}\"></ng-template>\n\t\t\t\t\t</li>\n\t\t\t\t}\n\t\t\t</ul>\n\t\t}\n\t`,\n})\nexport class SelectComponent<Item> extends BaseWidgetDirective<SelectWidget<Item>> {\n\t/**\n\t * aria-label used for the input inside the select\n\t *\n\t * @defaultValue `'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 * @defaultValue `[]`\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 * @defaultValue\n\t * ```ts\n\t * ['bottom-start', 'top-start', 'bottom-end', 'top-end']\n\t * ```\n\t */\n\t@Input('auAllowedPlacements') allowedPlacements: Placement[] | undefined;\n\n\t/**\n\t * true if the select is open\n\t *\n\t * @defaultValue `false`\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 * @defaultValue `''`\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 * @defaultValue `''`\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t/**\n\t * true if the select is disabled\n\t *\n\t * @defaultValue `false`\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 * @defaultValue `[]`\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 * @defaultValue `false`\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 * @defaultValue\n\t * ```ts\n\t * (item: any) => '' + item\n\t * ```\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 * @defaultValue `''`\n\t */\n\t@Input('auMenuClassName') menuClassName: string | undefined;\n\n\t/**\n\t * The template to override the way each badge on the left of the input is displayed.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\t@Input('auBadgeLabel') badgeLabel: SlotContent<SelectItemContext<Item>>;\n\t@ContentChild(SelectBadgeLabelDirective, {static: false}) slotSelectBadgeLabelFromContent: SelectBadgeLabelDirective<Item> | undefined;\n\n\t/**\n\t * The template to override the way each item is displayed in the list.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\t@Input('auItemLabel') itemLabel: SlotContent<SelectItemContext<Item>>;\n\t@ContentChild(SelectItemLabelDirective, {static: false}) slotSelectItemLabelFromContent: SelectItemLabelDirective<Item> | undefined;\n\n\t/**\n\t * Callback called when the text filter change\n\t * @param text - Filtered text\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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 * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auSelectedChange') selectedChange = new EventEmitter<Item[]>();\n\n\t/**\n\t * Callback called dropdown open state change\n\t * @param isOpen - updated open state\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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 * @defaultValue `''`\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 * @defaultValue `''`\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 * @param node - HTMLElement that contains the badges and the input\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (node: HTMLElement) => node.querySelectorAll('.au-select-badge,input')\n\t * ```\n\t */\n\t@Input('auNavSelector') navSelector: ((node: HTMLElement) => NodeListOf<HTMLSpanElement | HTMLInputElement>) | undefined;\n\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory<SelectWidget<Item>>({\n\t\t\t\tfactory: createSelect,\n\t\t\t\twidgetName: 'select',\n\t\t\t\tevents: {\n\t\t\t\t\tonOpenChange: (event) => this.openChange.emit(event),\n\t\t\t\t\tonSelectedChange: (event) => this.selectedChange.emit(event),\n\t\t\t\t\tonFilterTextChange: (event) => this.filterTextChange.emit(event),\n\t\t\t\t},\n\t\t\t\tafterInit: (widget) => {\n\t\t\t\t\tuseDirectiveForHost(widget.directives.referenceDirective);\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tbadgeLabel: this.slotSelectBadgeLabelFromContent?.templateRef,\n\t\t\t\t\titemLabel: this.slotSelectItemLabelFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t}),\n\t\t);\n\t}\n\n\titemCtxTrackBy(_: number, itemContext: ItemContext<Item>) {\n\t\treturn itemContext.id;\n\t}\n}\n"]}
|
|
@@ -12,4 +12,4 @@ export { export_getSelectDefaultConfig as getSelectDefaultConfig };
|
|
|
12
12
|
*/
|
|
13
13
|
const export_createSelect = createSelect;
|
|
14
14
|
export { export_createSelect as createSelect };
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.gen.js","sourceRoot":"","sources":["../../../../src/components/select/select.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAE,YAAY,EAAC,MAAM,4CAA4C,CAAC;AAMhG;;;GAGG;AACH,MAAM,6BAA6B,GAA2B,sBAA6B,CAAC;AAC5F,OAAO,EAAC,6BAA6B,IAAI,sBAAsB,EAAC,CAAC;AA6VjE;;;;GAIG;AACH,MAAM,mBAAmB,GAA0E,YAAmB,CAAC;AACvH,OAAO,EAAC,mBAAmB,IAAI,YAAY,EAAC,CAAC","sourcesContent":["import {getSelectDefaultConfig, createSelect} from '@agnos-ui/core-bootstrap/components/select';\nimport type {WidgetSlotContext, SlotContent, Widget, PropsConfig, HasFocus, FloatingUI, Directive} from '@agnos-ui/angular-headless';\nimport type {Placement} from '@floating-ui/dom';\n\n\n\n/**\n * Retrieve a shallow copy of the default Select config\n * @returns the default Select config\n */\nconst export_getSelectDefaultConfig: () => SelectProps<any> = getSelectDefaultConfig as any;\nexport {export_getSelectDefaultConfig as getSelectDefaultConfig};\n\n\n\n/**\n * A type for the slot context of the pagination widget\n */\nexport type SelectContext<Item> = WidgetSlotContext<SelectWidget<Item>>;\n\n\n\nexport type SelectItemContext<Item> = SelectContext<Item> & {\n\t/**\n\t * Contextual data related to an item\n\t */\n\titemContext: ItemContext<Item>;\n};\n\nexport interface SelectState<Item> {\n\t\n\t/**\n\t * List of item contexts, to be displayed in the menu\n\t */\n\tvisibleItems: ItemContext<Item>[];\n\t\n\n\t/**\n\t * List of selected items to be display\n\t */\n\tselectedContexts: ItemContext<Item>[];\n\t\n\n\t/**\n\t * Highlighted item context.\n\t * It is designed to define the highlighted item in the dropdown menu\n\t */\n\thighlighted: ItemContext<Item> | undefined;\n\t\n\n\t/**\n\t * Current placement of the dropdown\n\t */\n\tplacement: Placement | undefined;\n\t\n\t/**\n\t * id used for the input inside the select\n\t */\n\tid: string | undefined;\n\t\n\n\t/**\n\t * aria-label used for the input inside the select\n\t *\n\t * @defaultValue `'Select'`\n\t */\n\tariaLabel: string | undefined;\n\t\n\n\t/**\n\t * List of selected item ids\n\t *\n\t * @defaultValue `[]`\n\t */\n\tselected: Item[];\n\t\n\n\t/**\n\t * Filtered text to be display in the filter input\n\t *\n\t * @defaultValue `''`\n\t */\n\tfilterText: string;\n\t\n\n\t/**\n\t * true if the select is disabled\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * true if the select is open\n\t *\n\t * @defaultValue `false`\n\t */\n\topen: boolean;\n\t\n\n\t/**\n\t * Class to be added on the dropdown menu container\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuClassName: string;\n\t\n\n\t/**\n\t * Class to be added on menu items\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuItemClassName: string;\n\t\n\n\t/**\n\t * Class to be added on selected items (displayed in the input zone)\n\t *\n\t * @defaultValue `''`\n\t */\n\tbadgeClassName: string;\n\t\n\n\t/**\n\t * true if a loading process is being done\n\t *\n\t * @defaultValue `false`\n\t */\n\tloading: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to override the way each badge on the left of the input is displayed.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\tbadgeLabel: SlotContent<SelectItemContext<Item>>;\n\t\n\n\t/**\n\t * The template to override the way each item is displayed in the list.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\titemLabel: SlotContent<SelectItemContext<Item>>;\n}\n\nexport interface SelectProps<Item> {\n\t\n\t/**\n\t * List of available items for the dropdown\n\t *\n\t * @defaultValue `[]`\n\t */\n\titems: Item[];\n\t\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 * @defaultValue\n\t * ```ts\n\t * ['bottom-start', 'top-start', 'bottom-end', 'top-end']\n\t * ```\n\t */\n\tallowedPlacements: Placement[];\n\t\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 * @defaultValue\n\t * ```ts\n\t * (item: any) => '' + item\n\t * ```\n\t */\n\titemIdFn(item: Item): string;\n\t\n\n\t/**\n\t * Retrieves navigable elements within an HTML element containing badges and the input.\n\t *\n\t * @param node - HTMLElement that contains the badges and the input\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (node: HTMLElement) => node.querySelectorAll('.au-select-badge,input')\n\t * ```\n\t */\n\tnavSelector(node: HTMLElement): NodeListOf<HTMLSpanElement | HTMLInputElement>;\n\t\n\n\t// Event callbacks\n\n\t/**\n\t * Callback called dropdown open state change\n\t * @param isOpen - updated open state\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonOpenChange(isOpen: boolean): void;\n\t\n\n\t/**\n\t * Callback called when the text filter change\n\t * @param text - Filtered text\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonFilterTextChange(text: string): void;\n\t\n\n\t/**\n\t * Callback called when the selection change\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonSelectedChange(selected: Item[]): void;\n\t\n\t/**\n\t * id used for the input inside the select\n\t */\n\tid: string | undefined;\n\t\n\n\t/**\n\t * aria-label used for the input inside the select\n\t *\n\t * @defaultValue `'Select'`\n\t */\n\tariaLabel: string | undefined;\n\t\n\n\t/**\n\t * List of selected item ids\n\t *\n\t * @defaultValue `[]`\n\t */\n\tselected: Item[];\n\t\n\n\t/**\n\t * Filtered text to be display in the filter input\n\t *\n\t * @defaultValue `''`\n\t */\n\tfilterText: string;\n\t\n\n\t/**\n\t * true if the select is disabled\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * true if the select is open\n\t *\n\t * @defaultValue `false`\n\t */\n\topen: boolean;\n\t\n\n\t/**\n\t * Class to be added on the dropdown menu container\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuClassName: string;\n\t\n\n\t/**\n\t * Class to be added on menu items\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuItemClassName: string;\n\t\n\n\t/**\n\t * Class to be added on selected items (displayed in the input zone)\n\t *\n\t * @defaultValue `''`\n\t */\n\tbadgeClassName: string;\n\t\n\n\t/**\n\t * true if a loading process is being done\n\t *\n\t * @defaultValue `false`\n\t */\n\tloading: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to override the way each badge on the left of the input is displayed.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\tbadgeLabel: SlotContent<SelectItemContext<Item>>;\n\t\n\n\t/**\n\t * The template to override the way each item is displayed in the list.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\titemLabel: SlotContent<SelectItemContext<Item>>;\n}\n\n\n\nexport type SelectWidget<Item> = Widget<SelectProps<Item>, SelectState<Item>, SelectApi<Item>, SelectActions<Item>, SelectDirectives<Item>>;\n\n\n\n/**\n * Creates a new select widget instance.\n * @param config - config of the modal, either as a store or as an object containing values or stores.\n * @returns a new select widget instance\n */\nconst export_createSelect: <Item>(config?: PropsConfig<SelectProps<Item>>) => SelectWidget<Item> = createSelect as any;\nexport {export_createSelect as createSelect};\n\nexport interface ItemContext<T> {\n\t\n\t/**\n\t * Original item given in the parameters\n\t */\n\titem: T;\n\t\n\n\t/**\n\t * Unique id to identify the item\n\t */\n\tid: string;\n\t\n\n\t/**\n\t * Specify if the item is checked\n\t */\n\tselected: boolean;\n}\n\nexport interface SelectApi<Item> {\n\t\n\t/**\n\t * Clear all the selected items\n\t */\n\tclear(): void;\n\t\n\n\t/**\n\t * Clear the filter text\n\t */\n\tclearText(): void;\n\t\n\n\t/**\n\t * Highlight the given item, if there is a corresponding match among the visible list\n\t */\n\thighlight(item: Item): void;\n\t\n\n\t/**\n\t * Highlight the first item among the visible list\n\t */\n\thighlightFirst(): void;\n\t\n\n\t/**\n\t * Highlight the previous item among the visible list\n\t * Loop to the last item if needed\n\t */\n\thighlightPrevious(): void;\n\t\n\n\t/**\n\t * Highlight the next item among the visible list.\n\t * Loop to the first item if needed\n\t */\n\thighlightNext(): void;\n\t\n\n\t/**\n\t * Highlight the last item among the visible list\n\t */\n\thighlightLast(): void;\n\t\n\n\t/**\n\t * Select the provided item.\n\t * The selected list is used to\n\t * @param item - the item to select\n\t */\n\tselect(item: Item): void;\n\t\n\t/**\n\t * Unselect the provided item.\n\t * @param item - the item to unselect\n\t */\n\tunselect(item: Item): void;\n\t\n\t/**\n\t * Toggle the selection of an item\n\t * @param item - the item to toggle\n\t * @param selected - an optional boolean to enforce the selected/unselected state instead of toggling\n\t */\n\ttoggleItem(item: Item, selected?: boolean): void;\n\t\n\n\t/**\n\t * open the select\n\t */\n\topen(): void;\n\t\n\t/**\n\t * close the select\n\t */\n\tclose(): void;\n\t\n\t/**\n\t * Toggle the dropdown menu\n\t * @param isOpen - If specified, set the menu in the defined state.\n\t */\n\ttoggle(isOpen?: boolean): void;\n}\n\nexport interface SelectDirectives<Item> {\n\t\n\t/**\n\t * Directive to be used in the input group and the menu containers\n\t */\n\thasFocusDirective: HasFocus['directive'];\n\t\n\n\t/**\n\t * Directive that enables dynamic positioning of menu element\n\t */\n\tfloatingDirective: FloatingUI['directives']['floatingDirective'];\n\t\n\n\t/**\n\t * A directive to be applied to the input group element serves as the base for menu positioning\n\t */\n\treferenceDirective: FloatingUI['directives']['referenceDirective'];\n\t\n\n\t/**\n\t * A directive to be applied to the element that contains the badges and the input\n\t */\n\tinputContainerDirective: Directive;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the container badges\n\t */\n\tbadgeAttributesDirective: Directive<ItemContext<Item>>;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the dropdown menu\n\t */\n\tmenuAttributesDirective: Directive;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the dropdown item\n\t */\n\titemAttributesDirective: Directive<ItemContext<Item>>;\n}\n\nexport interface SelectActions<Item> {\n\t\n\t// Dom methods\n\n\t/**\n\t * Method to be plugged to on the 'input' event. The input text will be used as the filter text.\n\t */\n\tonInput: (e: {target: any}) => void;\n\t\n\n\t/**\n\t * Method to be attached to the node element to close a badge on click.\n\t */\n\tonRemoveBadgeClick: (event: MouseEvent, item: Item) => void;\n\t\n\n\t/**\n\t * Method to be plugged to on an keydown event of the main input, in order to control the keyboard interactions with the highlighted item.\n\t * It manages arrow keys to move the highlighted item, or enter to toggle the item.\n\t */\n\tonInputKeydown: (event: KeyboardEvent) => void;\n\t\n\n\t/**\n\t * Method to be plugged to on an keydown event of a badge container, in order to manage main actions on badges.\n\t *\n\t * @param event - keyboard event\n\t * @param item - corresponding item\n\t */\n\tonBadgeKeydown: (event: KeyboardEvent, item: Item) => void;\n}\n\n"]}
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.gen.js","sourceRoot":"","sources":["../../../../src/components/select/select.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAE,YAAY,EAAC,MAAM,4CAA4C,CAAC;AAMhG;;;GAGG;AACH,MAAM,6BAA6B,GAA2B,sBAA6B,CAAC;AAC5F,OAAO,EAAC,6BAA6B,IAAI,sBAAsB,EAAC,CAAC;AAmXjE;;;;GAIG;AACH,MAAM,mBAAmB,GAA0E,YAAmB,CAAC;AACvH,OAAO,EAAC,mBAAmB,IAAI,YAAY,EAAC,CAAC","sourcesContent":["import {getSelectDefaultConfig, createSelect} from '@agnos-ui/core-bootstrap/components/select';\nimport type {WidgetSlotContext, SlotContent, Widget, PropsConfig, HasFocus, FloatingUI, Directive} from '@agnos-ui/angular-headless';\nimport type {Placement} from '@floating-ui/dom';\n\n\n\n/**\n * Retrieve a shallow copy of the default Select config\n * @returns the default Select config\n */\nconst export_getSelectDefaultConfig: () => SelectProps<any> = getSelectDefaultConfig as any;\nexport {export_getSelectDefaultConfig as getSelectDefaultConfig};\n\n\n\n/**\n * Interface for the slot context of the pagination widget\n * @template Item - The type of the items in the Select component.\n */\nexport interface SelectContext<Item> extends WidgetSlotContext<SelectWidget<Item>> {}\n\n\n\n/**\n * Represents the context for a select item, extending the base `SelectContext` with additional\n * contextual data specific to an item.\n *\n * @template Item - The type of the item within the select context.\n */\nexport interface SelectItemContext<Item> extends SelectContext<Item> {\n\t/**\n\t * Contextual data related to an item\n\t */\n\titemContext: ItemContext<Item>;\n}\n\n/**\n * Represents the state of a Select component.\n *\n * @template Item - The type of the items in the select component.\n */\nexport interface SelectState<Item> {\n\t\n\t/**\n\t * List of item contexts, to be displayed in the menu\n\t */\n\tvisibleItems: ItemContext<Item>[];\n\t\n\n\t/**\n\t * List of selected items to be display\n\t */\n\tselectedContexts: ItemContext<Item>[];\n\t\n\n\t/**\n\t * Highlighted item context.\n\t * It is designed to define the highlighted item in the dropdown menu\n\t */\n\thighlighted: ItemContext<Item> | undefined;\n\t\n\n\t/**\n\t * Current placement of the dropdown\n\t */\n\tplacement: Placement | undefined;\n\t\n\t/**\n\t * id used for the input inside the select\n\t */\n\tid: string | undefined;\n\t\n\n\t/**\n\t * aria-label used for the input inside the select\n\t *\n\t * @defaultValue `'Select'`\n\t */\n\tariaLabel: string | undefined;\n\t\n\n\t/**\n\t * List of selected item ids\n\t *\n\t * @defaultValue `[]`\n\t */\n\tselected: Item[];\n\t\n\n\t/**\n\t * Filtered text to be display in the filter input\n\t *\n\t * @defaultValue `''`\n\t */\n\tfilterText: string;\n\t\n\n\t/**\n\t * true if the select is disabled\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * true if the select is open\n\t *\n\t * @defaultValue `false`\n\t */\n\topen: boolean;\n\t\n\n\t/**\n\t * Class to be added on the dropdown menu container\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuClassName: string;\n\t\n\n\t/**\n\t * Class to be added on menu items\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuItemClassName: string;\n\t\n\n\t/**\n\t * Class to be added on selected items (displayed in the input zone)\n\t *\n\t * @defaultValue `''`\n\t */\n\tbadgeClassName: string;\n\t\n\n\t/**\n\t * true if a loading process is being done\n\t *\n\t * @defaultValue `false`\n\t */\n\tloading: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to override the way each badge on the left of the input is displayed.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\tbadgeLabel: SlotContent<SelectItemContext<Item>>;\n\t\n\n\t/**\n\t * The template to override the way each item is displayed in the list.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\titemLabel: SlotContent<SelectItemContext<Item>>;\n}\n\n/**\n * Represents the properties for the Select component.\n *\n * @template Item - The type of the items in the select component.\n */\nexport interface SelectProps<Item> {\n\t\n\t/**\n\t * List of available items for the dropdown\n\t *\n\t * @defaultValue `[]`\n\t */\n\titems: Item[];\n\t\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 * @defaultValue\n\t * ```ts\n\t * ['bottom-start', 'top-start', 'bottom-end', 'top-end']\n\t * ```\n\t */\n\tallowedPlacements: Placement[];\n\t\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 * @defaultValue\n\t * ```ts\n\t * (item: any) => '' + item\n\t * ```\n\t */\n\titemIdFn(item: Item): string;\n\t\n\n\t/**\n\t * Retrieves navigable elements within an HTML element containing badges and the input.\n\t *\n\t * @param node - HTMLElement that contains the badges and the input\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (node: HTMLElement) => node.querySelectorAll('.au-select-badge,input')\n\t * ```\n\t */\n\tnavSelector(node: HTMLElement): NodeListOf<HTMLSpanElement | HTMLInputElement>;\n\t\n\n\t// Event callbacks\n\n\t/**\n\t * Callback called dropdown open state change\n\t * @param isOpen - updated open state\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonOpenChange(isOpen: boolean): void;\n\t\n\n\t/**\n\t * Callback called when the text filter change\n\t * @param text - Filtered text\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonFilterTextChange(text: string): void;\n\t\n\n\t/**\n\t * Callback called when the selection change\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonSelectedChange(selected: Item[]): void;\n\t\n\t/**\n\t * id used for the input inside the select\n\t */\n\tid: string | undefined;\n\t\n\n\t/**\n\t * aria-label used for the input inside the select\n\t *\n\t * @defaultValue `'Select'`\n\t */\n\tariaLabel: string | undefined;\n\t\n\n\t/**\n\t * List of selected item ids\n\t *\n\t * @defaultValue `[]`\n\t */\n\tselected: Item[];\n\t\n\n\t/**\n\t * Filtered text to be display in the filter input\n\t *\n\t * @defaultValue `''`\n\t */\n\tfilterText: string;\n\t\n\n\t/**\n\t * true if the select is disabled\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * true if the select is open\n\t *\n\t * @defaultValue `false`\n\t */\n\topen: boolean;\n\t\n\n\t/**\n\t * Class to be added on the dropdown menu container\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuClassName: string;\n\t\n\n\t/**\n\t * Class to be added on menu items\n\t *\n\t * @defaultValue `''`\n\t */\n\tmenuItemClassName: string;\n\t\n\n\t/**\n\t * Class to be added on selected items (displayed in the input zone)\n\t *\n\t * @defaultValue `''`\n\t */\n\tbadgeClassName: string;\n\t\n\n\t/**\n\t * true if a loading process is being done\n\t *\n\t * @defaultValue `false`\n\t */\n\tloading: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to override the way each badge on the left of the input is displayed.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\tbadgeLabel: SlotContent<SelectItemContext<Item>>;\n\t\n\n\t/**\n\t * The template to override the way each item is displayed in the list.\n\t * This define the content of the badge inside the badge container.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({itemContext}: SelectItemContext<any>) => itemContext.item\n\t * ```\n\t */\n\titemLabel: SlotContent<SelectItemContext<Item>>;\n}\n\n\n\n/**\n * Represents a Select widget component.\n *\n * @template Item - The type of the items that the select widget will handle.\n */\nexport type SelectWidget<Item> = Widget<SelectProps<Item>, SelectState<Item>, SelectApi<Item>, SelectDirectives<Item>>;\n\n\n\n/**\n * Creates a new select widget instance.\n * @param config - config of the modal, either as a store or as an object containing values or stores.\n * @returns a new select widget instance\n */\nconst export_createSelect: <Item>(config?: PropsConfig<SelectProps<Item>>) => SelectWidget<Item> = createSelect as any;\nexport {export_createSelect as createSelect};\n\n\n\n/**\n * Item representation built from the items provided in parameters\n */\nexport interface ItemContext<T> {\n\t/**\n\t * Original item given in the parameters\n\t */\n\titem: T;\n\n\t/**\n\t * Unique id to identify the item\n\t */\n\tid: string;\n\n\t/**\n\t * Specify if the item is checked\n\t */\n\tselected: boolean;\n}\n\n/**\n * Interface representing the API for a Select component.\n */\nexport interface SelectApi<Item> {\n\t\n\t/**\n\t * Clear all the selected items\n\t */\n\tclear(): void;\n\t\n\n\t/**\n\t * Clear the filter text\n\t */\n\tclearText(): void;\n\t\n\n\t/**\n\t * Highlight the given item, if there is a corresponding match among the visible list\n\t */\n\thighlight(item: Item): void;\n\t\n\n\t/**\n\t * Highlight the first item among the visible list\n\t */\n\thighlightFirst(): void;\n\t\n\n\t/**\n\t * Highlight the previous item among the visible list\n\t * Loop to the last item if needed\n\t */\n\thighlightPrevious(): void;\n\t\n\n\t/**\n\t * Highlight the next item among the visible list.\n\t * Loop to the first item if needed\n\t */\n\thighlightNext(): void;\n\t\n\n\t/**\n\t * Highlight the last item among the visible list\n\t */\n\thighlightLast(): void;\n\t\n\n\t/**\n\t * Select the provided item.\n\t * The selected list is used to\n\t * @param item - the item to select\n\t */\n\tselect(item: Item): void;\n\t\n\t/**\n\t * Unselect the provided item.\n\t * @param item - the item to unselect\n\t */\n\tunselect(item: Item): void;\n\t\n\t/**\n\t * Toggle the selection of an item\n\t * @param item - the item to toggle\n\t * @param selected - an optional boolean to enforce the selected/unselected state instead of toggling\n\t */\n\ttoggleItem(item: Item, selected?: boolean): void;\n\t\n\n\t/**\n\t * open the select\n\t */\n\topen(): void;\n\t\n\t/**\n\t * close the select\n\t */\n\tclose(): void;\n\t\n\t/**\n\t * Toggle the dropdown menu\n\t * @param isOpen - If specified, set the menu in the defined state.\n\t */\n\ttoggle(isOpen?: boolean): void;\n}\n\n/**\n * Interface representing the directives used in the Select component.\n */\nexport interface SelectDirectives<Item> {\n\t\n\t/**\n\t * Directive to be used in the input group and the menu containers\n\t */\n\thasFocusDirective: HasFocus['directive'];\n\t\n\n\t/**\n\t * Directive that enables dynamic positioning of menu element\n\t */\n\tfloatingDirective: FloatingUI['directives']['floatingDirective'];\n\t\n\n\t/**\n\t * A directive to be applied to the input group element serves as the base for menu positioning\n\t */\n\treferenceDirective: FloatingUI['directives']['referenceDirective'];\n\t\n\n\t/**\n\t * A directive to be applied to the element that contains the badges and the input\n\t */\n\tinputContainerDirective: Directive;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the container badges\n\t */\n\tbadgeAttributesDirective: Directive<ItemContext<Item>>;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the dropdown menu\n\t */\n\tmenuAttributesDirective: Directive;\n\t\n\n\t/**\n\t * A directive that applies all the necessary attributes to the dropdown item\n\t */\n\titemAttributesDirective: Directive<ItemContext<Item>>;\n\t\n\n\t/**\n\t * A directive to be applied to the input\n\t */\n\tinputDirective: Directive;\n\t\n\t/**\n\t * A directive to be applied to a button that closes a badge\n\t */\n\tbadgeCloseButtonDirective: Directive<ItemContext<Item>>;\n}\n\n"]}
|