@agnos-ui/angular-bootstrap 0.3.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.
Files changed (67) hide show
  1. package/README.md +15 -0
  2. package/agnos-ui-angular.module.d.ts +16 -0
  3. package/components/accordion/accordion.component.d.ts +239 -0
  4. package/components/accordion/accordion.d.ts +11 -0
  5. package/components/accordion/index.d.ts +2 -0
  6. package/components/alert/alert.component.d.ts +95 -0
  7. package/components/alert/alert.d.ts +7 -0
  8. package/components/alert/index.d.ts +2 -0
  9. package/components/modal/index.d.ts +3 -0
  10. package/components/modal/modal.component.d.ts +164 -0
  11. package/components/modal/modal.d.ts +9 -0
  12. package/components/modal/modal.service.d.ts +13 -0
  13. package/components/pagination/index.d.ts +2 -0
  14. package/components/pagination/pagination.component.d.ts +252 -0
  15. package/components/pagination/pagination.d.ts +8 -0
  16. package/components/progressbar/index.d.ts +2 -0
  17. package/components/progressbar/progressbar.component.d.ts +77 -0
  18. package/components/progressbar/progressbar.d.ts +7 -0
  19. package/components/rating/index.d.ts +2 -0
  20. package/components/rating/rating.component.d.ts +95 -0
  21. package/components/rating/rating.d.ts +6 -0
  22. package/components/select/index.d.ts +2 -0
  23. package/components/select/select.component.d.ts +107 -0
  24. package/components/select/select.d.ts +8 -0
  25. package/components/slider/index.d.ts +2 -0
  26. package/components/slider/slider.component.d.ts +130 -0
  27. package/components/slider/slider.d.ts +9 -0
  28. package/components/toast/index.d.ts +2 -0
  29. package/components/toast/toast.component.d.ts +106 -0
  30. package/components/toast/toast.d.ts +7 -0
  31. package/config.d.ts +18 -0
  32. package/esm2022/agnos-ui-angular-bootstrap.mjs +5 -0
  33. package/esm2022/agnos-ui-angular.module.mjs +151 -0
  34. package/esm2022/components/accordion/accordion.component.mjs +579 -0
  35. package/esm2022/components/accordion/accordion.mjs +4 -0
  36. package/esm2022/components/accordion/index.mjs +3 -0
  37. package/esm2022/components/alert/alert.component.mjs +230 -0
  38. package/esm2022/components/alert/alert.mjs +4 -0
  39. package/esm2022/components/alert/index.mjs +3 -0
  40. package/esm2022/components/modal/index.mjs +4 -0
  41. package/esm2022/components/modal/modal.component.mjs +423 -0
  42. package/esm2022/components/modal/modal.mjs +4 -0
  43. package/esm2022/components/modal/modal.service.mjs +47 -0
  44. package/esm2022/components/pagination/index.mjs +3 -0
  45. package/esm2022/components/pagination/pagination.component.mjs +581 -0
  46. package/esm2022/components/pagination/pagination.mjs +4 -0
  47. package/esm2022/components/progressbar/index.mjs +3 -0
  48. package/esm2022/components/progressbar/progressbar.component.mjs +180 -0
  49. package/esm2022/components/progressbar/progressbar.mjs +4 -0
  50. package/esm2022/components/rating/index.mjs +3 -0
  51. package/esm2022/components/rating/rating.component.mjs +185 -0
  52. package/esm2022/components/rating/rating.mjs +4 -0
  53. package/esm2022/components/select/index.mjs +3 -0
  54. package/esm2022/components/select/select.component.mjs +280 -0
  55. package/esm2022/components/select/select.mjs +4 -0
  56. package/esm2022/components/slider/index.mjs +3 -0
  57. package/esm2022/components/slider/slider.component.mjs +443 -0
  58. package/esm2022/components/slider/slider.mjs +4 -0
  59. package/esm2022/components/toast/index.mjs +3 -0
  60. package/esm2022/components/toast/toast.component.mjs +284 -0
  61. package/esm2022/components/toast/toast.mjs +4 -0
  62. package/esm2022/config.mjs +5 -0
  63. package/esm2022/index.mjs +27 -0
  64. package/fesm2022/agnos-ui-angular-bootstrap.mjs +3382 -0
  65. package/fesm2022/agnos-ui-angular-bootstrap.mjs.map +1 -0
  66. package/index.d.ts +33 -0
  67. package/package.json +48 -0
@@ -0,0 +1,280 @@
1
+ import { BaseWidgetDirective, SlotDirective, UseDirective, UseMultiDirective, auBooleanAttribute, useDirectiveForHost, } from '@agnos-ui/angular-headless';
2
+ import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, inject } from '@angular/core';
3
+ import { callWidgetFactory } from '../../config';
4
+ import { createSelect } from './select';
5
+ import * as i0 from "@angular/core";
6
+ const _c0 = ["auSelect", ""];
7
+ const _c1 = (a0, a1) => [a0, a1];
8
+ const _c2 = (a0, a1, a2) => ({ state: a0, widget: a1, itemContext: a2 });
9
+ const _c3 = (a0, a1, a2) => [a0, a1, a2];
10
+ function SelectComponent_Conditional_0_Conditional_1_For_1_ng_template_1_Template(rf, ctx) { }
11
+ function SelectComponent_Conditional_0_Conditional_1_For_1_Template(rf, ctx) { if (rf & 1) {
12
+ i0.ɵɵelementStart(0, "div", 3);
13
+ i0.ɵɵtemplate(1, SelectComponent_Conditional_0_Conditional_1_For_1_ng_template_1_Template, 0, 0, "ng-template", 4);
14
+ i0.ɵɵelementEnd();
15
+ } if (rf & 2) {
16
+ const itemContext_r2 = ctx.$implicit;
17
+ const state_r3 = i0.ɵɵnextContext(2);
18
+ const ctx_r3 = i0.ɵɵnextContext();
19
+ i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(3, _c1, ctx_r3._widget.directives.badgeAttributesDirective, itemContext_r2));
20
+ i0.ɵɵadvance();
21
+ i0.ɵɵproperty("auSlot", state_r3.slotBadgeLabel)("auSlotProps", i0.ɵɵpureFunction3(6, _c2, state_r3, ctx_r3.widget, itemContext_r2));
22
+ } }
23
+ function SelectComponent_Conditional_0_Conditional_1_Template(rf, ctx) { if (rf & 1) {
24
+ i0.ɵɵrepeaterCreate(0, SelectComponent_Conditional_0_Conditional_1_For_1_Template, 2, 10, "div", 3, i0.ɵɵcomponentInstance().itemCtxTrackBy, true);
25
+ } if (rf & 2) {
26
+ i0.ɵɵrepeater(ctx);
27
+ } }
28
+ function SelectComponent_Conditional_0_Conditional_3_For_2_ng_template_1_Template(rf, ctx) { }
29
+ function SelectComponent_Conditional_0_Conditional_3_For_2_Template(rf, ctx) { if (rf & 1) {
30
+ i0.ɵɵelementStart(0, "li", 6);
31
+ i0.ɵɵtemplate(1, SelectComponent_Conditional_0_Conditional_3_For_2_ng_template_1_Template, 0, 0, "ng-template", 4);
32
+ i0.ɵɵelementEnd();
33
+ } if (rf & 2) {
34
+ const itemContext_r5 = ctx.$implicit;
35
+ const state_r3 = i0.ɵɵnextContext(2);
36
+ const ctx_r3 = i0.ɵɵnextContext();
37
+ i0.ɵɵclassProp("text-bg-primary", itemContext_r5 === state_r3.highlighted);
38
+ i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(5, _c1, ctx_r3._widget.directives.itemAttributesDirective, itemContext_r5));
39
+ i0.ɵɵadvance();
40
+ i0.ɵɵproperty("auSlot", state_r3.slotItem)("auSlotProps", i0.ɵɵpureFunction3(8, _c2, state_r3, ctx_r3.widget, itemContext_r5));
41
+ } }
42
+ function SelectComponent_Conditional_0_Conditional_3_Template(rf, ctx) { if (rf & 1) {
43
+ i0.ɵɵelementStart(0, "ul", 2);
44
+ i0.ɵɵrepeaterCreate(1, SelectComponent_Conditional_0_Conditional_3_For_2_Template, 2, 12, "li", 5, i0.ɵɵcomponentInstance().itemCtxTrackBy, true);
45
+ i0.ɵɵelementEnd();
46
+ } if (rf & 2) {
47
+ const state_r3 = i0.ɵɵnextContext();
48
+ const ctx_r3 = i0.ɵɵnextContext();
49
+ i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction3(1, _c3, ctx_r3.widget.directives.hasFocusDirective, ctx_r3.widget.directives.floatingDirective, ctx_r3.widget.directives.menuAttributesDirective));
50
+ i0.ɵɵadvance();
51
+ i0.ɵɵrepeater(state_r3.visibleItems);
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(1, (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(3, state_r3.open && state_r3.visibleItems.length ? 3 : -1);
73
+ } }
74
+ export class SelectBadgeLabelDirective {
75
+ constructor() {
76
+ this.templateRef = inject((TemplateRef));
77
+ }
78
+ static ngTemplateContextGuard(_dir, context) {
79
+ return true;
80
+ }
81
+ static { this.ɵfac = function SelectBadgeLabelDirective_Factory(t) { return new (t || SelectBadgeLabelDirective)(); }; }
82
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SelectBadgeLabelDirective, selectors: [["ng-template", "auSelectBadgeLabel", ""]], standalone: true }); }
83
+ }
84
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectBadgeLabelDirective, [{
85
+ type: Directive,
86
+ args: [{ selector: 'ng-template[auSelectBadgeLabel]', standalone: true }]
87
+ }], null, null); })();
88
+ export class SelectItemDirective {
89
+ constructor() {
90
+ this.templateRef = inject((TemplateRef));
91
+ }
92
+ static ngTemplateContextGuard(_dir, context) {
93
+ return true;
94
+ }
95
+ static { this.ɵfac = function SelectItemDirective_Factory(t) { return new (t || SelectItemDirective)(); }; }
96
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SelectItemDirective, selectors: [["ng-template", "auSelectItem", ""]], standalone: true }); }
97
+ }
98
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectItemDirective, [{
99
+ type: Directive,
100
+ args: [{ selector: 'ng-template[auSelectItem]', standalone: true }]
101
+ }], null, null); })();
102
+ export class SelectComponent extends BaseWidgetDirective {
103
+ constructor() {
104
+ super(...arguments);
105
+ /**
106
+ * Callback called when the text filter change
107
+ */
108
+ this.filterTextChange = new EventEmitter();
109
+ /**
110
+ * Callback called when the selection change
111
+ */
112
+ this.selectedChange = new EventEmitter();
113
+ /**
114
+ * Callback called dropdown open state change
115
+ */
116
+ this.openChange = new EventEmitter();
117
+ this._widget = callWidgetFactory({
118
+ factory: createSelect,
119
+ widgetName: 'select',
120
+ events: {
121
+ onOpenChange: (event) => this.openChange.emit(event),
122
+ onSelectedChange: (event) => this.selectedChange.emit(event),
123
+ onFilterTextChange: (event) => this.filterTextChange.emit(event),
124
+ },
125
+ afterInit: () => {
126
+ useDirectiveForHost(this._widget.directives.referenceDirective);
127
+ },
128
+ });
129
+ }
130
+ itemCtxTrackBy(_, itemContext) {
131
+ return itemContext.id;
132
+ }
133
+ ngAfterContentChecked() {
134
+ this._widget.patchSlots({
135
+ slotBadgeLabel: this.slotSelectBadgeLabelFromContent?.templateRef,
136
+ slotItem: this.slotSelectItemFromContent?.templateRef,
137
+ });
138
+ }
139
+ static { this.ɵfac = /*@__PURE__*/ (() => { let ɵSelectComponent_BaseFactory; return function SelectComponent_Factory(t) { return (ɵSelectComponent_BaseFactory || (ɵSelectComponent_BaseFactory = i0.ɵɵgetInheritedFactory(SelectComponent)))(t || SelectComponent); }; })(); }
140
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SelectComponent, selectors: [["", "auSelect", ""]], contentQueries: function SelectComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
141
+ i0.ɵɵcontentQuery(dirIndex, SelectBadgeLabelDirective, 5);
142
+ i0.ɵɵcontentQuery(dirIndex, SelectItemDirective, 5);
143
+ } if (rf & 2) {
144
+ let _t;
145
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotSelectBadgeLabelFromContent = _t.first);
146
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotSelectItemFromContent = _t.first);
147
+ } }, hostVars: 2, hostBindings: function SelectComponent_HostBindings(rf, ctx) { if (rf & 2) {
148
+ i0.ɵɵclassMap("au-select dropdown border border-1 p-1 mb-3 d-block" + ctx.state().className);
149
+ } }, 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: [[1, "d-flex", "align-items-center", "flex-wrap", "gap-1", 3, "auUseMulti"], ["type", "text", "aria-autocomplete", "list", "autoCorrect", "off", "autoCapitalize", "none", "autoComplete", "off", 1, "au-select-input", "flex-grow-1", "border-0", 3, "input", "keydown", "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) {
150
+ i0.ɵɵtemplate(0, SelectComponent_Conditional_0_Template, 4, 9);
151
+ } if (rf & 2) {
152
+ let tmp_0_0;
153
+ i0.ɵɵconditional(0, (tmp_0_0 = ctx.state()) ? 0 : -1, tmp_0_0);
154
+ } }, dependencies: [UseMultiDirective, SlotDirective, UseDirective], encapsulation: 2, changeDetection: 0 }); }
155
+ }
156
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectComponent, [{
157
+ type: Component,
158
+ args: [{
159
+ standalone: true,
160
+ imports: [UseMultiDirective, SlotDirective, UseDirective],
161
+ changeDetection: ChangeDetectionStrategy.OnPush,
162
+ selector: '[auSelect]',
163
+ host: {
164
+ '[class]': '"au-select dropdown border border-1 p-1 mb-3 d-block" + state().className',
165
+ },
166
+ template: `
167
+ @if (state(); as state) {
168
+ <div
169
+ [auUseMulti]="[widget.directives.hasFocusDirective, widget.directives.inputContainerDirective]"
170
+ class="d-flex align-items-center flex-wrap gap-1"
171
+ >
172
+ @if (state.selectedContexts; as selectedContexts) {
173
+ @for (itemContext of selectedContexts; track itemCtxTrackBy($index, itemContext)) {
174
+ <div [auUse]="[_widget.directives.badgeAttributesDirective, itemContext]">
175
+ <ng-template [auSlot]="state.slotBadgeLabel" [auSlotProps]="{state, widget, itemContext}"></ng-template>
176
+ </div>
177
+ }
178
+ }
179
+ <input
180
+ attr.id="{{ state.id }}"
181
+ attr.aria-label="{{ state.ariaLabel }}"
182
+ type="text"
183
+ class="au-select-input flex-grow-1 border-0"
184
+ [value]="state.filterText"
185
+ aria-autocomplete="list"
186
+ autoCorrect="off"
187
+ autoCapitalize="none"
188
+ autoComplete="off"
189
+ (input)="_widget.actions.onInput($event)"
190
+ (keydown)="_widget.actions.onInputKeydown($event)"
191
+ />
192
+ </div>
193
+ @if (state.open && state.visibleItems.length) {
194
+ <ul
195
+ [auUseMulti]="[widget.directives.hasFocusDirective, widget.directives.floatingDirective, widget.directives.menuAttributesDirective]"
196
+ class="dropdown-menu show"
197
+ >
198
+ @for (itemContext of state.visibleItems; track itemCtxTrackBy($index, itemContext)) {
199
+ <li
200
+ class="dropdown-item position-relative"
201
+ [auUse]="[_widget.directives.itemAttributesDirective, itemContext]"
202
+ [class.text-bg-primary]="itemContext === state.highlighted"
203
+ >
204
+ <ng-template [auSlot]="state.slotItem" [auSlotProps]="{state, widget, itemContext}"></ng-template>
205
+ </li>
206
+ }
207
+ </ul>
208
+ }
209
+ }
210
+ `,
211
+ }]
212
+ }], null, { ariaLabel: [{
213
+ type: Input,
214
+ args: ['auAriaLabel']
215
+ }], id: [{
216
+ type: Input,
217
+ args: ['auId']
218
+ }], items: [{
219
+ type: Input,
220
+ args: ['auItems']
221
+ }], allowedPlacements: [{
222
+ type: Input,
223
+ args: ['auAllowedPlacements']
224
+ }], open: [{
225
+ type: Input,
226
+ args: [{ alias: 'auOpen', transform: auBooleanAttribute }]
227
+ }], filterText: [{
228
+ type: Input,
229
+ args: ['auFilterText']
230
+ }], className: [{
231
+ type: Input,
232
+ args: ['auClassName']
233
+ }], disabled: [{
234
+ type: Input,
235
+ args: [{ alias: 'auDisabled', transform: auBooleanAttribute }]
236
+ }], selected: [{
237
+ type: Input,
238
+ args: ['auSelected']
239
+ }], loading: [{
240
+ type: Input,
241
+ args: [{ alias: 'auLoading', transform: auBooleanAttribute }]
242
+ }], itemIdFn: [{
243
+ type: Input,
244
+ args: ['auItemIdFn']
245
+ }], menuClassName: [{
246
+ type: Input,
247
+ args: ['auMenuClassName']
248
+ }], slotBadgeLabel: [{
249
+ type: Input,
250
+ args: ['auSlotBadgeLabel']
251
+ }], slotSelectBadgeLabelFromContent: [{
252
+ type: ContentChild,
253
+ args: [SelectBadgeLabelDirective, { static: false }]
254
+ }], slotItem: [{
255
+ type: Input,
256
+ args: ['auSlotItem']
257
+ }], slotSelectItemFromContent: [{
258
+ type: ContentChild,
259
+ args: [SelectItemDirective, { static: false }]
260
+ }], filterTextChange: [{
261
+ type: Output,
262
+ args: ['auFilterTextChange']
263
+ }], selectedChange: [{
264
+ type: Output,
265
+ args: ['auSelectedChange']
266
+ }], openChange: [{
267
+ type: Output,
268
+ args: ['auOpenChange']
269
+ }], menuItemClassName: [{
270
+ type: Input,
271
+ args: ['auMenuItemClassName']
272
+ }], badgeClassName: [{
273
+ type: Input,
274
+ args: ['auBadgeClassName']
275
+ }], navSelector: [{
276
+ type: Input,
277
+ args: ['auNavSelector']
278
+ }] }); })();
279
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectComponent, { className: "SelectComponent", filePath: "components/select/select.component.ts", lineNumber: 87 }); })();
280
+ //# 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, 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';\nimport {createSelect} from './select';\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: [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.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\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.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\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"]}
@@ -0,0 +1,4 @@
1
+ import { createSelect as coreCreateSelect } from '@agnos-ui/core-bootstrap/components/select';
2
+ export * from '@agnos-ui/core-bootstrap/components/select';
3
+ export const createSelect = coreCreateSelect;
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvc2VsZWN0L3NlbGVjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsWUFBWSxJQUFJLGdCQUFnQixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFFNUYsY0FBYyw0Q0FBNEMsQ0FBQztBQU8zRCxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQStFLGdCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge0FkYXB0V2lkZ2V0U2xvdHMsIFdpZGdldFByb3BzLCBXaWRnZXRTdGF0ZSwgQWRhcHRTbG90Q29udGVudFByb3BzLCBQcm9wc0NvbmZpZ30gZnJvbSAnQGFnbm9zLXVpL2FuZ3VsYXItaGVhZGxlc3MnO1xuaW1wb3J0IHtjcmVhdGVTZWxlY3QgYXMgY29yZUNyZWF0ZVNlbGVjdH0gZnJvbSAnQGFnbm9zLXVpL2NvcmUtYm9vdHN0cmFwL2NvbXBvbmVudHMvc2VsZWN0JztcblxuZXhwb3J0ICogZnJvbSAnQGFnbm9zLXVpL2NvcmUtYm9vdHN0cmFwL2NvbXBvbmVudHMvc2VsZWN0JztcblxuZXhwb3J0IHR5cGUgU2VsZWN0V2lkZ2V0PEl0ZW0+ID0gQWRhcHRXaWRnZXRTbG90czxpbXBvcnQoJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL3NlbGVjdCcpLlNlbGVjdFdpZGdldDxJdGVtPj47XG5leHBvcnQgdHlwZSBTZWxlY3RQcm9wczxJdGVtPiA9IFdpZGdldFByb3BzPFNlbGVjdFdpZGdldDxJdGVtPj47XG5leHBvcnQgdHlwZSBTZWxlY3RTdGF0ZTxJdGVtPiA9IFdpZGdldFN0YXRlPFNlbGVjdFdpZGdldDxJdGVtPj47XG5leHBvcnQgdHlwZSBTZWxlY3RDb250ZXh0PEl0ZW0+ID0gQWRhcHRTbG90Q29udGVudFByb3BzPGltcG9ydCgnQGFnbm9zLXVpL2NvcmUtYm9vdHN0cmFwL2NvbXBvbmVudHMvc2VsZWN0JykuU2VsZWN0Q29udGV4dDxJdGVtPj47XG5leHBvcnQgdHlwZSBTZWxlY3RJdGVtQ29udGV4dDxJdGVtPiA9IEFkYXB0U2xvdENvbnRlbnRQcm9wczxpbXBvcnQoJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL3NlbGVjdCcpLlNlbGVjdEl0ZW1Db250ZXh0PEl0ZW0+PjtcbmV4cG9ydCBjb25zdCBjcmVhdGVTZWxlY3Q6IDxJdGVtPihwcm9wc0NvbmZpZz86IFByb3BzQ29uZmlnPFNlbGVjdFByb3BzPEl0ZW0+PikgPT4gU2VsZWN0V2lkZ2V0PEl0ZW0+ID0gY29yZUNyZWF0ZVNlbGVjdCBhcyBhbnk7XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from './slider.component';
2
+ export * from './slider';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9zbGlkZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2xpZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NsaWRlcic7XG4iXX0=