@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.
Files changed (56) hide show
  1. package/README.md +2 -2
  2. package/agnos-ui-angular.module.d.ts +2 -1
  3. package/components/accordion/accordion.component.d.ts +40 -18
  4. package/components/accordion/accordion.gen.d.ts +37 -9
  5. package/components/alert/alert.component.d.ts +29 -17
  6. package/components/alert/alert.gen.d.ts +21 -2
  7. package/components/collapse/collapse.component.d.ts +79 -0
  8. package/components/collapse/collapse.gen.d.ts +146 -0
  9. package/components/collapse/index.d.ts +2 -0
  10. package/components/modal/modal.component.d.ts +13 -19
  11. package/components/modal/modal.gen.d.ts +35 -18
  12. package/components/modal/modal.service.d.ts +5 -1
  13. package/components/pagination/pagination.component.d.ts +20 -15
  14. package/components/pagination/pagination.gen.d.ts +49 -29
  15. package/components/progressbar/progressbar.component.d.ts +32 -16
  16. package/components/progressbar/progressbar.gen.d.ts +21 -4
  17. package/components/rating/rating.component.d.ts +11 -4
  18. package/components/rating/rating.gen.d.ts +25 -17
  19. package/components/select/select.component.d.ts +24 -4
  20. package/components/select/select.gen.d.ts +41 -25
  21. package/components/slider/slider.component.d.ts +32 -23
  22. package/components/slider/slider.gen.d.ts +54 -33
  23. package/components/toast/toast.component.d.ts +29 -17
  24. package/components/toast/toast.gen.d.ts +22 -2
  25. package/config.d.ts +16 -5
  26. package/config.gen.d.ts +5 -0
  27. package/esm2022/agnos-ui-angular.module.mjs +12 -5
  28. package/esm2022/components/accordion/accordion.component.mjs +165 -134
  29. package/esm2022/components/accordion/accordion.gen.mjs +1 -1
  30. package/esm2022/components/alert/alert.component.mjs +90 -65
  31. package/esm2022/components/alert/alert.gen.mjs +1 -1
  32. package/esm2022/components/collapse/collapse.component.mjs +89 -0
  33. package/esm2022/components/collapse/collapse.gen.mjs +15 -0
  34. package/esm2022/components/collapse/index.mjs +3 -0
  35. package/esm2022/components/modal/modal.component.mjs +111 -99
  36. package/esm2022/components/modal/modal.gen.mjs +1 -1
  37. package/esm2022/components/modal/modal.service.mjs +7 -5
  38. package/esm2022/components/pagination/pagination.component.mjs +138 -123
  39. package/esm2022/components/pagination/pagination.gen.mjs +1 -1
  40. package/esm2022/components/progressbar/progressbar.component.mjs +94 -55
  41. package/esm2022/components/progressbar/progressbar.gen.mjs +1 -1
  42. package/esm2022/components/rating/rating.component.mjs +41 -35
  43. package/esm2022/components/rating/rating.gen.mjs +1 -1
  44. package/esm2022/components/select/select.component.mjs +103 -118
  45. package/esm2022/components/select/select.gen.mjs +1 -1
  46. package/esm2022/components/slider/slider.component.mjs +126 -111
  47. package/esm2022/components/slider/slider.gen.mjs +1 -1
  48. package/esm2022/components/toast/toast.component.mjs +106 -81
  49. package/esm2022/components/toast/toast.gen.mjs +1 -1
  50. package/esm2022/config.gen.mjs +1 -1
  51. package/esm2022/config.mjs +17 -1
  52. package/esm2022/index.mjs +2 -1
  53. package/fesm2022/agnos-ui-angular-bootstrap.mjs +1085 -806
  54. package/fesm2022/agnos-ui-angular-bootstrap.mjs.map +1 -1
  55. package/index.d.ts +8 -7
  56. package/package.json +9 -8
@@ -1,8 +1,6 @@
1
1
  import { BaseWidgetDirective, ComponentTemplate, SlotDirective, UseDirective, auBooleanAttribute, auNumberAttribute, useDirectiveForHost, } from '@agnos-ui/angular-headless';
2
- import { writable } from '@amadeus-it-group/tansu';
3
- import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, NgZone, Output, TemplateRef, ViewChild, ViewEncapsulation, forwardRef, inject, } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewChild, ViewEncapsulation, forwardRef, inject, } from '@angular/core';
4
3
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
5
- import { take } from 'rxjs';
6
4
  import { callWidgetFactory } from '../../config';
7
5
  import { createSlider } from './slider.gen';
8
6
  import * as i0 from "@angular/core";
@@ -14,22 +12,22 @@ function SliderDefaultHandleSlotComponent_ng_template_0_Template(rf, ctx) { if (
14
12
  i0.ɵɵtext(1, "\u00A0");
15
13
  i0.ɵɵelementEnd();
16
14
  } if (rf & 2) {
17
- const widget_r1 = ctx.widget;
15
+ const directives_r1 = ctx.directives;
18
16
  const item_r2 = ctx.item;
19
- i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(3, _c2, widget_r1.directives.handleDirective, i0.ɵɵpureFunction1(1, _c1, item_r2)));
17
+ i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(3, _c2, directives_r1.handleDirective, i0.ɵɵpureFunction1(1, _c1, item_r2)));
20
18
  } }
21
19
  const _c3 = ["structure"];
22
20
  const _forTrack0 = ($index, $item) => $item.id;
23
21
  const _c4 = a0 => ({ option: a0 });
24
- const _c5 = (a0, a1, a2) => ({ state: a0, widget: a1, value: a2 });
25
- const _c6 = (a0, a1, a2) => ({ state: a0, widget: a1, item: a2 });
22
+ const _c5 = (a0, a1, a2, a3) => ({ state: a0, api: a1, directives: a2, value: a3 });
23
+ const _c6 = (a0, a1, a2, a3) => ({ state: a0, api: a1, directives: a2, item: a3 });
26
24
  const _c7 = a0 => ({ index: a0 });
27
25
  function SliderDefaultStructureSlotComponent_ng_template_0_For_1_Template(rf, ctx) { if (rf & 1) {
28
26
  i0.ɵɵelement(0, "div", 2);
29
27
  } if (rf & 2) {
30
28
  const option_r1 = ctx.$implicit;
31
- const widget_r2 = i0.ɵɵnextContext().widget;
32
- i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(3, _c2, widget_r2.directives.progressDisplayDirective, i0.ɵɵpureFunction1(1, _c4, option_r1)));
29
+ const directives_r2 = i0.ɵɵnextContext().directives;
30
+ i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(3, _c2, directives_r2.progressDisplayDirective, i0.ɵɵpureFunction1(1, _c4, option_r1)));
33
31
  } }
34
32
  function SliderDefaultStructureSlotComponent_ng_template_0_Conditional_3_ng_template_1_Template(rf, ctx) { }
35
33
  function SliderDefaultStructureSlotComponent_ng_template_0_Conditional_3_ng_template_3_Template(rf, ctx) { }
@@ -43,14 +41,15 @@ function SliderDefaultStructureSlotComponent_ng_template_0_Conditional_3_Templat
43
41
  } if (rf & 2) {
44
42
  const ctx_r2 = i0.ɵɵnextContext();
45
43
  const state_r4 = ctx_r2.state;
46
- const widget_r2 = ctx_r2.widget;
47
- i0.ɵɵproperty("auUse", widget_r2.directives.minLabelDirective);
44
+ const directives_r2 = ctx_r2.directives;
45
+ const api_r5 = ctx_r2.api;
46
+ i0.ɵɵproperty("auUse", directives_r2.minLabelDirective);
48
47
  i0.ɵɵadvance();
49
- i0.ɵɵproperty("auSlot", state_r4.label)("auSlotProps", i0.ɵɵpureFunction3(6, _c5, state_r4, widget_r2, state_r4.min));
48
+ i0.ɵɵproperty("auSlot", state_r4.label())("auSlotProps", i0.ɵɵpureFunction4(6, _c5, state_r4, api_r5, directives_r2, state_r4.min()));
50
49
  i0.ɵɵadvance();
51
- i0.ɵɵproperty("auUse", widget_r2.directives.maxLabelDirective);
50
+ i0.ɵɵproperty("auUse", directives_r2.maxLabelDirective);
52
51
  i0.ɵɵadvance();
53
- i0.ɵɵproperty("auSlot", state_r4.label)("auSlotProps", i0.ɵɵpureFunction3(10, _c5, state_r4, widget_r2, state_r4.max));
52
+ i0.ɵɵproperty("auSlot", state_r4.label())("auSlotProps", i0.ɵɵpureFunction4(11, _c5, state_r4, api_r5, directives_r2, state_r4.max()));
54
53
  } }
55
54
  function SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Conditional_1_ng_template_0_Template(rf, ctx) { }
56
55
  function SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Conditional_1_ng_template_2_Template(rf, ctx) { }
@@ -61,10 +60,11 @@ function SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Conditi
61
60
  } if (rf & 2) {
62
61
  const ctx_r2 = i0.ɵɵnextContext(2);
63
62
  const state_r4 = ctx_r2.state;
64
- const widget_r2 = ctx_r2.widget;
65
- i0.ɵɵproperty("auSlot", state_r4.label)("auSlotProps", i0.ɵɵpureFunction3(4, _c5, state_r4, widget_r2, state_r4.sortedValues[1]));
63
+ const directives_r2 = ctx_r2.directives;
64
+ const api_r5 = ctx_r2.api;
65
+ i0.ɵɵproperty("auSlot", state_r4.label())("auSlotProps", i0.ɵɵpureFunction4(4, _c5, state_r4, api_r5, directives_r2, state_r4.sortedValues()[1]));
66
66
  i0.ɵɵadvance(2);
67
- i0.ɵɵproperty("auSlot", state_r4.label)("auSlotProps", i0.ɵɵpureFunction3(8, _c5, state_r4, widget_r2, state_r4.sortedValues[0]));
67
+ i0.ɵɵproperty("auSlot", state_r4.label())("auSlotProps", i0.ɵɵpureFunction4(9, _c5, state_r4, api_r5, directives_r2, state_r4.sortedValues()[0]));
68
68
  } }
69
69
  function SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Conditional_2_ng_template_0_Template(rf, ctx) { }
70
70
  function SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Conditional_2_ng_template_2_Template(rf, ctx) { }
@@ -75,22 +75,23 @@ function SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Conditi
75
75
  } if (rf & 2) {
76
76
  const ctx_r2 = i0.ɵɵnextContext(2);
77
77
  const state_r4 = ctx_r2.state;
78
- const widget_r2 = ctx_r2.widget;
79
- i0.ɵɵproperty("auSlot", state_r4.label)("auSlotProps", i0.ɵɵpureFunction3(4, _c5, state_r4, widget_r2, state_r4.sortedValues[0]));
78
+ const directives_r2 = ctx_r2.directives;
79
+ const api_r5 = ctx_r2.api;
80
+ i0.ɵɵproperty("auSlot", state_r4.label())("auSlotProps", i0.ɵɵpureFunction4(4, _c5, state_r4, api_r5, directives_r2, state_r4.sortedValues()[0]));
80
81
  i0.ɵɵadvance(2);
81
- i0.ɵɵproperty("auSlot", state_r4.label)("auSlotProps", i0.ɵɵpureFunction3(8, _c5, state_r4, widget_r2, state_r4.sortedValues[1]));
82
+ i0.ɵɵproperty("auSlot", state_r4.label())("auSlotProps", i0.ɵɵpureFunction4(9, _c5, state_r4, api_r5, directives_r2, state_r4.sortedValues()[1]));
82
83
  } }
83
84
  function SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Template(rf, ctx) { if (rf & 1) {
84
85
  i0.ɵɵelementStart(0, "div", 2);
85
- i0.ɵɵtemplate(1, SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Conditional_1_Template, 3, 12)(2, SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Conditional_2_Template, 3, 12);
86
+ i0.ɵɵtemplate(1, SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Conditional_1_Template, 3, 14)(2, SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Conditional_2_Template, 3, 14);
86
87
  i0.ɵɵelementEnd();
87
88
  } if (rf & 2) {
88
89
  const ctx_r2 = i0.ɵɵnextContext();
89
90
  const state_r4 = ctx_r2.state;
90
- const widget_r2 = ctx_r2.widget;
91
- i0.ɵɵproperty("auUse", widget_r2.directives.combinedHandleLabelDisplayDirective);
91
+ const directives_r2 = ctx_r2.directives;
92
+ i0.ɵɵproperty("auUse", directives_r2.combinedHandleLabelDisplayDirective);
92
93
  i0.ɵɵadvance();
93
- i0.ɵɵconditional(state_r4.rtl ? 1 : 2);
94
+ i0.ɵɵconditional(state_r4.rtl() ? 1 : 2);
94
95
  } }
95
96
  function SliderDefaultStructureSlotComponent_ng_template_0_For_6_ng_template_0_Template(rf, ctx) { }
96
97
  function SliderDefaultStructureSlotComponent_ng_template_0_For_6_Conditional_1_ng_template_1_Template(rf, ctx) { }
@@ -99,46 +100,53 @@ function SliderDefaultStructureSlotComponent_ng_template_0_For_6_Conditional_1_T
99
100
  i0.ɵɵtemplate(1, SliderDefaultStructureSlotComponent_ng_template_0_For_6_Conditional_1_ng_template_1_Template, 0, 0, "ng-template", 3);
100
101
  i0.ɵɵelementEnd();
101
102
  } if (rf & 2) {
102
- const ɵ$index_32_r5 = i0.ɵɵnextContext().$index;
103
+ const ɵ$index_32_r6 = i0.ɵɵnextContext().$index;
103
104
  const ctx_r2 = i0.ɵɵnextContext();
104
105
  const state_r4 = ctx_r2.state;
105
- const widget_r2 = ctx_r2.widget;
106
- i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(5, _c2, widget_r2.directives.handleLabelDisplayDirective, i0.ɵɵpureFunction1(3, _c7, ɵ$index_32_r5)));
106
+ const directives_r2 = ctx_r2.directives;
107
+ const api_r5 = ctx_r2.api;
108
+ i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(5, _c2, directives_r2.handleLabelDisplayDirective, i0.ɵɵpureFunction1(3, _c7, ɵ$index_32_r6)));
107
109
  i0.ɵɵadvance();
108
- i0.ɵɵproperty("auSlot", state_r4.label)("auSlotProps", i0.ɵɵpureFunction3(8, _c5, state_r4, widget_r2, state_r4.values[ɵ$index_32_r5]));
110
+ i0.ɵɵproperty("auSlot", state_r4.label())("auSlotProps", i0.ɵɵpureFunction4(8, _c5, state_r4, api_r5, directives_r2, state_r4.values()[ɵ$index_32_r6]));
109
111
  } }
110
112
  function SliderDefaultStructureSlotComponent_ng_template_0_For_6_Template(rf, ctx) { if (rf & 1) {
111
- i0.ɵɵtemplate(0, SliderDefaultStructureSlotComponent_ng_template_0_For_6_ng_template_0_Template, 0, 0, "ng-template", 3)(1, SliderDefaultStructureSlotComponent_ng_template_0_For_6_Conditional_1_Template, 2, 12, "div", 2);
113
+ i0.ɵɵtemplate(0, SliderDefaultStructureSlotComponent_ng_template_0_For_6_ng_template_0_Template, 0, 0, "ng-template", 3)(1, SliderDefaultStructureSlotComponent_ng_template_0_For_6_Conditional_1_Template, 2, 13, "div", 2);
112
114
  } if (rf & 2) {
113
- const item_r6 = ctx.$implicit;
115
+ const item_r7 = ctx.$implicit;
114
116
  const ctx_r2 = i0.ɵɵnextContext();
115
117
  const state_r4 = ctx_r2.state;
116
- const widget_r2 = ctx_r2.widget;
117
- i0.ɵɵproperty("auSlot", state_r4.handle)("auSlotProps", i0.ɵɵpureFunction3(3, _c6, state_r4, widget_r2, item_r6));
118
+ const directives_r2 = ctx_r2.directives;
119
+ const api_r5 = ctx_r2.api;
120
+ i0.ɵɵproperty("auSlot", state_r4.handle())("auSlotProps", i0.ɵɵpureFunction4(3, _c6, state_r4, api_r5, directives_r2, item_r7));
118
121
  i0.ɵɵadvance();
119
- i0.ɵɵconditional(state_r4.showValueLabels && !state_r4.combinedLabelDisplay ? 1 : -1);
122
+ i0.ɵɵconditional(state_r4.showValueLabels() && !state_r4.combinedLabelDisplay() ? 1 : -1);
120
123
  } }
121
124
  function SliderDefaultStructureSlotComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
122
125
  i0.ɵɵrepeaterCreate(0, SliderDefaultStructureSlotComponent_ng_template_0_For_1_Template, 1, 6, "div", 2, i0.ɵɵrepeaterTrackByIdentity);
123
126
  i0.ɵɵelement(2, "div", 2);
124
- i0.ɵɵtemplate(3, SliderDefaultStructureSlotComponent_ng_template_0_Conditional_3_Template, 4, 14)(4, SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Template, 3, 2, "div", 2);
125
- i0.ɵɵrepeaterCreate(5, SliderDefaultStructureSlotComponent_ng_template_0_For_6_Template, 2, 7, null, null, _forTrack0);
127
+ i0.ɵɵtemplate(3, SliderDefaultStructureSlotComponent_ng_template_0_Conditional_3_Template, 4, 16)(4, SliderDefaultStructureSlotComponent_ng_template_0_Conditional_4_Template, 3, 2, "div", 2);
128
+ i0.ɵɵrepeaterCreate(5, SliderDefaultStructureSlotComponent_ng_template_0_For_6_Template, 2, 8, null, null, _forTrack0);
126
129
  } if (rf & 2) {
127
130
  const state_r4 = ctx.state;
128
- const widget_r2 = ctx.widget;
129
- i0.ɵɵrepeater(state_r4.progressDisplayOptions);
131
+ const directives_r2 = ctx.directives;
132
+ i0.ɵɵrepeater(state_r4.progressDisplayOptions());
130
133
  i0.ɵɵadvance(2);
131
- i0.ɵɵproperty("auUse", widget_r2.directives.clickableAreaDirective);
134
+ i0.ɵɵproperty("auUse", directives_r2.clickableAreaDirective);
132
135
  i0.ɵɵadvance();
133
- i0.ɵɵconditional(state_r4.showMinMaxLabels ? 3 : -1);
136
+ i0.ɵɵconditional(state_r4.showMinMaxLabels() ? 3 : -1);
134
137
  i0.ɵɵadvance();
135
- i0.ɵɵconditional(state_r4.showValueLabels && state_r4.combinedLabelDisplay ? 4 : -1);
138
+ i0.ɵɵconditional(state_r4.showValueLabels() && state_r4.combinedLabelDisplay() ? 4 : -1);
136
139
  i0.ɵɵadvance();
137
- i0.ɵɵrepeater(state_r4.sortedHandles);
140
+ i0.ɵɵrepeater(state_r4.sortedHandles());
138
141
  } }
139
142
  const _c8 = ["auSlider", ""];
140
- const _c9 = (a0, a1) => ({ state: a0, widget: a1 });
143
+ const _c9 = (a0, a1, a2) => ({ state: a0, api: a1, directives: a2 });
141
144
  function SliderComponent_ng_template_0_Template(rf, ctx) { }
145
+ /**
146
+ * Directive to provide a template reference for slider labels.
147
+ *
148
+ * This directive uses a template reference to render the {@link SliderSlotLabelContext}.
149
+ */
142
150
  export class SliderLabelDirective {
143
151
  constructor() {
144
152
  this.templateRef = inject((TemplateRef));
@@ -146,13 +154,18 @@ export class SliderLabelDirective {
146
154
  static ngTemplateContextGuard(_dir, context) {
147
155
  return true;
148
156
  }
149
- static { this.ɵfac = function SliderLabelDirective_Factory(t) { return new (t || SliderLabelDirective)(); }; }
157
+ static { this.ɵfac = function SliderLabelDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SliderLabelDirective)(); }; }
150
158
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SliderLabelDirective, selectors: [["ng-template", "auSliderLabel", ""]], standalone: true }); }
151
159
  }
152
160
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SliderLabelDirective, [{
153
161
  type: Directive,
154
162
  args: [{ selector: 'ng-template[auSliderLabel]', standalone: true }]
155
163
  }], null, null); })();
164
+ /**
165
+ * Directive representing a handle for a slider component.
166
+ *
167
+ * This directive uses a template reference to render the {@link SliderSlotLabelContext}.
168
+ */
156
169
  export class SliderHandleDirective {
157
170
  constructor() {
158
171
  this.templateRef = inject((TemplateRef));
@@ -160,24 +173,15 @@ export class SliderHandleDirective {
160
173
  static ngTemplateContextGuard(_dir, context) {
161
174
  return true;
162
175
  }
163
- static { this.ɵfac = function SliderHandleDirective_Factory(t) { return new (t || SliderHandleDirective)(); }; }
176
+ static { this.ɵfac = function SliderHandleDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SliderHandleDirective)(); }; }
164
177
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SliderHandleDirective, selectors: [["ng-template", "auSliderHandle", ""]], standalone: true }); }
165
178
  }
166
179
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SliderHandleDirective, [{
167
180
  type: Directive,
168
181
  args: [{ selector: 'ng-template[auSliderHandle]', standalone: true }]
169
182
  }], null, null); })();
170
- export class SliderDefaultHandleSlotComponent {
171
- constructor() {
172
- this._zone = inject(NgZone);
173
- }
174
- onKeyDown(event, handleId, widgetOnKeyDownFn) {
175
- widgetOnKeyDownFn(event, handleId);
176
- this._zone.onStable.pipe(take(1)).subscribe(() => {
177
- event.target.focus();
178
- });
179
- }
180
- static { this.ɵfac = function SliderDefaultHandleSlotComponent_Factory(t) { return new (t || SliderDefaultHandleSlotComponent)(); }; }
183
+ class SliderDefaultHandleSlotComponent {
184
+ static { this.ɵfac = function SliderDefaultHandleSlotComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SliderDefaultHandleSlotComponent)(); }; }
181
185
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SliderDefaultHandleSlotComponent, selectors: [["ng-component"]], viewQuery: function SliderDefaultHandleSlotComponent_Query(rf, ctx) { if (rf & 1) {
182
186
  i0.ɵɵviewQuery(_c0, 7);
183
187
  } if (rf & 2) {
@@ -194,8 +198,8 @@ export class SliderDefaultHandleSlotComponent {
194
198
  changeDetection: ChangeDetectionStrategy.OnPush,
195
199
  imports: [UseDirective, SliderHandleDirective],
196
200
  template: `
197
- <ng-template auSliderHandle #handle let-state="state" let-widget="widget" let-item="item">
198
- <button [auUse]="[widget.directives.handleDirective, {item}]">&nbsp;</button>
201
+ <ng-template auSliderHandle #handle let-state="state" let-directives="directives" let-item="item">
202
+ <button [auUse]="[directives.handleDirective, {item}]">&nbsp;</button>
199
203
  </ng-template>
200
204
  `,
201
205
  }]
@@ -203,8 +207,16 @@ export class SliderDefaultHandleSlotComponent {
203
207
  type: ViewChild,
204
208
  args: ['handle', { static: true }]
205
209
  }] }); })();
206
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SliderDefaultHandleSlotComponent, { className: "SliderDefaultHandleSlotComponent", filePath: "components/slider/slider.component.ts", lineNumber: 60 }); })();
210
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SliderDefaultHandleSlotComponent, { className: "SliderDefaultHandleSlotComponent", filePath: "components/slider/slider.component.ts", lineNumber: 65 }); })();
211
+ /**
212
+ * A constant representing the default slot handle for the slider component.
213
+ */
207
214
  export const sliderDefaultSlotHandle = new ComponentTemplate(SliderDefaultHandleSlotComponent, 'handle');
215
+ /**
216
+ * Directive that provides structure for the slider component.
217
+ *
218
+ * This directive uses a `TemplateRef` to handle the context of the slider slot.
219
+ */
208
220
  export class SliderStructureDirective {
209
221
  constructor() {
210
222
  this.templateRef = inject((TemplateRef));
@@ -212,15 +224,15 @@ export class SliderStructureDirective {
212
224
  static ngTemplateContextGuard(_dir, context) {
213
225
  return true;
214
226
  }
215
- static { this.ɵfac = function SliderStructureDirective_Factory(t) { return new (t || SliderStructureDirective)(); }; }
227
+ static { this.ɵfac = function SliderStructureDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SliderStructureDirective)(); }; }
216
228
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SliderStructureDirective, selectors: [["ng-template", "auSliderStructure", ""]], standalone: true }); }
217
229
  }
218
230
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SliderStructureDirective, [{
219
231
  type: Directive,
220
232
  args: [{ selector: 'ng-template[auSliderStructure]', standalone: true }]
221
233
  }], null, null); })();
222
- export class SliderDefaultStructureSlotComponent {
223
- static { this.ɵfac = function SliderDefaultStructureSlotComponent_Factory(t) { return new (t || SliderDefaultStructureSlotComponent)(); }; }
234
+ class SliderDefaultStructureSlotComponent {
235
+ static { this.ɵfac = function SliderDefaultStructureSlotComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SliderDefaultStructureSlotComponent)(); }; }
224
236
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SliderDefaultStructureSlotComponent, selectors: [["ng-component"]], viewQuery: function SliderDefaultStructureSlotComponent_Query(rf, ctx) { if (rf & 1) {
225
237
  i0.ɵɵviewQuery(_c3, 7);
226
238
  } if (rf & 2) {
@@ -237,35 +249,35 @@ export class SliderDefaultStructureSlotComponent {
237
249
  changeDetection: ChangeDetectionStrategy.OnPush,
238
250
  imports: [SlotDirective, SliderStructureDirective, UseDirective],
239
251
  template: `
240
- <ng-template auSliderStructure #structure let-state="state" let-widget="widget">
241
- @for (option of state.progressDisplayOptions; track option) {
242
- <div [auUse]="[widget.directives.progressDisplayDirective, {option}]"></div>
252
+ <ng-template auSliderStructure #structure let-state="state" let-directives="directives" let-api="api">
253
+ @for (option of state.progressDisplayOptions(); track option) {
254
+ <div [auUse]="[directives.progressDisplayDirective, {option}]"></div>
243
255
  }
244
- <div [auUse]="widget.directives.clickableAreaDirective"></div>
245
- @if (state.showMinMaxLabels) {
246
- <div [auUse]="widget.directives.minLabelDirective">
247
- <ng-template [auSlot]="state.label" [auSlotProps]="{state, widget, value: state.min}"></ng-template>
256
+ <div [auUse]="directives.clickableAreaDirective"></div>
257
+ @if (state.showMinMaxLabels()) {
258
+ <div [auUse]="directives.minLabelDirective">
259
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.min()}"></ng-template>
248
260
  </div>
249
- <div [auUse]="widget.directives.maxLabelDirective">
250
- <ng-template [auSlot]="state.label" [auSlotProps]="{state, widget, value: state.max}"></ng-template>
261
+ <div [auUse]="directives.maxLabelDirective">
262
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.max()}"></ng-template>
251
263
  </div>
252
264
  }
253
- @if (state.showValueLabels && state.combinedLabelDisplay) {
254
- <div [auUse]="widget.directives.combinedHandleLabelDisplayDirective">
255
- @if (state.rtl) {
256
- <ng-template [auSlot]="state.label" [auSlotProps]="{state, widget, value: state.sortedValues[1]}"></ng-template> -
257
- <ng-template [auSlot]="state.label" [auSlotProps]="{state, widget, value: state.sortedValues[0]}"></ng-template>
265
+ @if (state.showValueLabels() && state.combinedLabelDisplay()) {
266
+ <div [auUse]="directives.combinedHandleLabelDisplayDirective">
267
+ @if (state.rtl()) {
268
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[1]}"></ng-template> -
269
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[0]}"></ng-template>
258
270
  } @else {
259
- <ng-template [auSlot]="state.label" [auSlotProps]="{state, widget, value: state.sortedValues[0]}"></ng-template> -
260
- <ng-template [auSlot]="state.label" [auSlotProps]="{state, widget, value: state.sortedValues[1]}"></ng-template>
271
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[0]}"></ng-template> -
272
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.sortedValues()[1]}"></ng-template>
261
273
  }
262
274
  </div>
263
275
  }
264
- @for (item of state.sortedHandles; track item.id; let i = $index) {
265
- <ng-template [auSlot]="state.handle" [auSlotProps]="{state, widget, item}"></ng-template>
266
- @if (state.showValueLabels && !state.combinedLabelDisplay) {
267
- <div [auUse]="[widget.directives.handleLabelDisplayDirective, {index: i}]">
268
- <ng-template [auSlot]="state.label" [auSlotProps]="{state, widget, value: state.values[i]}"></ng-template>
276
+ @for (item of state.sortedHandles(); track item.id; let i = $index) {
277
+ <ng-template [auSlot]="state.handle()" [auSlotProps]="{state, api, directives, item}"></ng-template>
278
+ @if (state.showValueLabels() && !state.combinedLabelDisplay()) {
279
+ <div [auUse]="[directives.handleLabelDisplayDirective, {index: i}]">
280
+ <ng-template [auSlot]="state.label()" [auSlotProps]="{state, api, directives, value: state.values()[i]}"></ng-template>
269
281
  </div>
270
282
  }
271
283
  }
@@ -276,20 +288,25 @@ export class SliderDefaultStructureSlotComponent {
276
288
  type: ViewChild,
277
289
  args: ['structure', { static: true }]
278
290
  }] }); })();
279
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SliderDefaultStructureSlotComponent, { className: "SliderDefaultStructureSlotComponent", filePath: "components/slider/slider.component.ts", lineNumber: 123 }); })();
291
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SliderDefaultStructureSlotComponent, { className: "SliderDefaultStructureSlotComponent", filePath: "components/slider/slider.component.ts", lineNumber: 127 }); })();
292
+ /**
293
+ * Represents the default slot structure for the slider component.
294
+ */
280
295
  export const sliderDefaultSlotStructure = new ComponentTemplate(SliderDefaultStructureSlotComponent, 'structure');
281
- const defaultConfig = {
282
- structure: sliderDefaultSlotStructure,
283
- handle: sliderDefaultSlotHandle,
284
- };
296
+ /**
297
+ * SliderComponent is an Angular component that extends the BaseWidgetDirective
298
+ * to provide a customizable slider widget. This component allows for various
299
+ * configurations and customizations through its inputs and outputs.
300
+ */
285
301
  export class SliderComponent extends BaseWidgetDirective {
286
302
  constructor() {
287
- super(...arguments);
288
- this.defaultSlots = writable(defaultConfig);
289
- this._widget = callWidgetFactory({
303
+ super(callWidgetFactory({
290
304
  factory: createSlider,
291
305
  widgetName: 'slider',
292
- defaultConfig: this.defaultSlots,
306
+ defaultConfig: {
307
+ structure: sliderDefaultSlotStructure,
308
+ handle: sliderDefaultSlotHandle,
309
+ },
293
310
  events: {
294
311
  onValuesChange: (event) => {
295
312
  this.onChange(event);
@@ -297,10 +314,15 @@ export class SliderComponent extends BaseWidgetDirective {
297
314
  this.valuesChange.emit(event);
298
315
  },
299
316
  },
300
- afterInit: () => {
301
- useDirectiveForHost(this._widget.directives.sliderDirective);
317
+ afterInit: (widget) => {
318
+ useDirectiveForHost(widget.directives.sliderDirective);
302
319
  },
303
- });
320
+ slotTemplates: () => ({
321
+ structure: this.slotStructureFromContent?.templateRef,
322
+ handle: this.slotHandleFromContent?.templateRef,
323
+ label: this.slotLabelFromContent?.templateRef,
324
+ }),
325
+ }));
304
326
  /**
305
327
  * An event emitted when slider values are changed
306
328
  *
@@ -326,32 +348,25 @@ export class SliderComponent extends BaseWidgetDirective {
326
348
  }
327
349
  writeValue(value) {
328
350
  if (Array.isArray(value)) {
329
- this._widget.patch({
351
+ this['_widget'].patch({
330
352
  values: value,
331
353
  });
332
354
  }
333
355
  else {
334
- this._widget.patch({
356
+ this['_widget'].patch({
335
357
  values: [value],
336
358
  });
337
359
  }
338
360
  }
339
361
  setDisabledState(isDisabled) {
340
- this._widget.patch({
362
+ this['_widget'].patch({
341
363
  disabled: isDisabled,
342
364
  });
343
365
  }
344
366
  handleBlur() {
345
367
  this.onTouched();
346
368
  }
347
- ngAfterContentChecked() {
348
- this._widget.patchSlots({
349
- structure: this.slotStructureFromContent?.templateRef,
350
- handle: this.slotHandleFromContent?.templateRef,
351
- label: this.slotLabelFromContent?.templateRef,
352
- });
353
- }
354
- static { this.ɵfac = /*@__PURE__*/ (() => { let ɵSliderComponent_BaseFactory; return function SliderComponent_Factory(t) { return (ɵSliderComponent_BaseFactory || (ɵSliderComponent_BaseFactory = i0.ɵɵgetInheritedFactory(SliderComponent)))(t || SliderComponent); }; })(); }
369
+ static { this.ɵfac = function SliderComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SliderComponent)(); }; }
355
370
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SliderComponent, selectors: [["", "auSlider", ""]], contentQueries: function SliderComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
356
371
  i0.ɵɵcontentQuery(dirIndex, SliderLabelDirective, 5);
357
372
  i0.ɵɵcontentQuery(dirIndex, SliderStructureDirective, 5);
@@ -363,10 +378,10 @@ export class SliderComponent extends BaseWidgetDirective {
363
378
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotHandleFromContent = _t.first);
364
379
  } }, hostBindings: function SliderComponent_HostBindings(rf, ctx) { if (rf & 1) {
365
380
  i0.ɵɵlistener("blur", function SliderComponent_blur_HostBindingHandler() { return ctx.handleBlur(); });
366
- } }, inputs: { className: [0, "auClassName", "className"], min: [2, "auMin", "min", auNumberAttribute], max: [2, "auMax", "max", auNumberAttribute], stepSize: [2, "auStepSize", "stepSize", auNumberAttribute], values: [0, "auValues", "values"], rtl: [2, "auRtl", "rtl", auBooleanAttribute], showValueLabels: [2, "auShowValueLabels", "showValueLabels", auBooleanAttribute], showMinMaxLabels: [2, "auShowMinMaxLabels", "showMinMaxLabels", auBooleanAttribute], ariaLabelHandle: [0, "auAriaLabelHandle", "ariaLabelHandle"], ariaValueText: [0, "auAriaValueText", "ariaValueText"], readonly: [2, "auReadonly", "readonly", auBooleanAttribute], disabled: [2, "auDisabled", "disabled", auBooleanAttribute], vertical: [2, "auVertical", "vertical", auBooleanAttribute], label: [0, "auLabel", "label"], structure: [0, "auStructure", "structure"], handle: [0, "auHandle", "handle"] }, outputs: { valuesChange: "auValuesChange" }, standalone: true, features: [i0.ɵɵProvidersFeature([{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SliderComponent), multi: true }]), i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c8, decls: 1, vars: 5, consts: [[3, "auSlot", "auSlotProps"]], template: function SliderComponent_Template(rf, ctx) { if (rf & 1) {
381
+ } }, inputs: { className: [0, "auClassName", "className"], min: [2, "auMin", "min", auNumberAttribute], max: [2, "auMax", "max", auNumberAttribute], stepSize: [2, "auStepSize", "stepSize", auNumberAttribute], values: [0, "auValues", "values"], rtl: [2, "auRtl", "rtl", auBooleanAttribute], showValueLabels: [2, "auShowValueLabels", "showValueLabels", auBooleanAttribute], showMinMaxLabels: [2, "auShowMinMaxLabels", "showMinMaxLabels", auBooleanAttribute], ariaLabelHandle: [0, "auAriaLabelHandle", "ariaLabelHandle"], ariaValueText: [0, "auAriaValueText", "ariaValueText"], readonly: [2, "auReadonly", "readonly", auBooleanAttribute], disabled: [2, "auDisabled", "disabled", auBooleanAttribute], vertical: [2, "auVertical", "vertical", auBooleanAttribute], label: [0, "auLabel", "label"], structure: [0, "auStructure", "structure"], handle: [0, "auHandle", "handle"] }, outputs: { valuesChange: "auValuesChange" }, standalone: true, features: [i0.ɵɵProvidersFeature([{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SliderComponent), multi: true }]), i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c8, decls: 1, vars: 6, consts: [[3, "auSlot", "auSlotProps"]], template: function SliderComponent_Template(rf, ctx) { if (rf & 1) {
367
382
  i0.ɵɵtemplate(0, SliderComponent_ng_template_0_Template, 0, 0, "ng-template", 0);
368
383
  } if (rf & 2) {
369
- i0.ɵɵproperty("auSlot", ctx.state().structure)("auSlotProps", i0.ɵɵpureFunction2(2, _c9, ctx.state(), ctx.widget));
384
+ i0.ɵɵproperty("auSlot", ctx.state.structure())("auSlotProps", i0.ɵɵpureFunction3(2, _c9, ctx.state, ctx.api, ctx.directives));
370
385
  } }, dependencies: [SlotDirective], encapsulation: 2, changeDetection: 0 }); }
371
386
  }
372
387
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SliderComponent, [{
@@ -381,9 +396,9 @@ export class SliderComponent extends BaseWidgetDirective {
381
396
  host: {
382
397
  '(blur)': 'handleBlur()',
383
398
  },
384
- template: ` <ng-template [auSlot]="state().structure" [auSlotProps]="{state: state(), widget}"></ng-template> `,
399
+ template: ` <ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}"></ng-template> `,
385
400
  }]
386
- }], null, { className: [{
401
+ }], () => [], { className: [{
387
402
  type: Input,
388
403
  args: ['auClassName']
389
404
  }], min: [{
@@ -444,5 +459,5 @@ export class SliderComponent extends BaseWidgetDirective {
444
459
  type: ContentChild,
445
460
  args: [SliderHandleDirective, { static: false }]
446
461
  }] }); })();
447
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SliderComponent, { className: "SliderComponent", filePath: "components/slider/slider.component.ts", lineNumber: 147 }); })();
448
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../src/components/slider/slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport {type WritableSignal, writable} from '@amadeus-it-group/tansu';\nimport type {AfterContentChecked} from '@angular/core';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tNgZone,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tViewEncapsulation,\n\tforwardRef,\n\tinject,\n} from '@angular/core';\nimport {NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {take} from 'rxjs';\nimport {callWidgetFactory} from '../../config';\nimport type {SliderContext, SliderProps, SliderSlotHandleContext, SliderSlotLabelContext, SliderWidget} from './slider.gen';\nimport {createSlider} from './slider.gen';\n\n@Directive({selector: 'ng-template[auSliderLabel]', standalone: true})\nexport class SliderLabelDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotLabelContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderLabelDirective, context: unknown): context is SliderSlotLabelContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auSliderHandle]', standalone: true})\nexport class SliderHandleDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotLabelContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderHandleDirective, context: unknown): context is SliderSlotHandleContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SliderHandleDirective],\n\ttemplate: `\n\t\t<ng-template auSliderHandle #handle let-state=\"state\" let-widget=\"widget\" let-item=\"item\">\n\t\t\t<button [auUse]=\"[widget.directives.handleDirective, {item}]\">&nbsp;</button>\n\t\t</ng-template>\n\t`,\n})\nexport class SliderDefaultHandleSlotComponent {\n\tprivate readonly _zone = inject(NgZone);\n\n\t@ViewChild('handle', {static: true}) readonly handle!: TemplateRef<SliderSlotHandleContext>;\n\n\tonKeyDown(event: KeyboardEvent, handleId: number, widgetOnKeyDownFn: (event: KeyboardEvent, handleId: number) => void) {\n\t\twidgetOnKeyDownFn(event, handleId);\n\t\tthis._zone.onStable.pipe(take(1)).subscribe(() => {\n\t\t\t(event.target as HTMLElement).focus();\n\t\t});\n\t}\n}\n\nexport const sliderDefaultSlotHandle = new ComponentTemplate(SliderDefaultHandleSlotComponent, 'handle');\n\n@Directive({selector: 'ng-template[auSliderStructure]', standalone: true})\nexport class SliderStructureDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotHandleContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderStructureDirective, context: unknown): context is SliderSlotHandleContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, SliderStructureDirective, UseDirective],\n\ttemplate: `\n\t\t<ng-template auSliderStructure #structure let-state=\"state\" let-widget=\"widget\">\n\t\t\t@for (option of state.progressDisplayOptions; track option) {\n\t\t\t\t<div [auUse]=\"[widget.directives.progressDisplayDirective, {option}]\"></div>\n\t\t\t}\n\t\t\t<div [auUse]=\"widget.directives.clickableAreaDirective\"></div>\n\t\t\t@if (state.showMinMaxLabels) {\n\t\t\t\t<div [auUse]=\"widget.directives.minLabelDirective\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.label\" [auSlotProps]=\"{state, widget, value: state.min}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t\t<div [auUse]=\"widget.directives.maxLabelDirective\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.label\" [auSlotProps]=\"{state, widget, value: state.max}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t@if (state.showValueLabels && state.combinedLabelDisplay) {\n\t\t\t\t<div [auUse]=\"widget.directives.combinedHandleLabelDisplayDirective\">\n\t\t\t\t\t@if (state.rtl) {\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label\" [auSlotProps]=\"{state, widget, value: state.sortedValues[1]}\"></ng-template> -\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label\" [auSlotProps]=\"{state, widget, value: state.sortedValues[0]}\"></ng-template>\n\t\t\t\t\t} @else {\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label\" [auSlotProps]=\"{state, widget, value: state.sortedValues[0]}\"></ng-template> -\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label\" [auSlotProps]=\"{state, widget, value: state.sortedValues[1]}\"></ng-template>\n\t\t\t\t\t}\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t@for (item of state.sortedHandles; track item.id; let i = $index) {\n\t\t\t\t<ng-template [auSlot]=\"state.handle\" [auSlotProps]=\"{state, widget, item}\"></ng-template>\n\t\t\t\t@if (state.showValueLabels && !state.combinedLabelDisplay) {\n\t\t\t\t\t<div [auUse]=\"[widget.directives.handleLabelDisplayDirective, {index: i}]\">\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label\" [auSlotProps]=\"{state, widget, value: state.values[i]}\"></ng-template>\n\t\t\t\t\t</div>\n\t\t\t\t}\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nexport class SliderDefaultStructureSlotComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<SliderContext>;\n}\n\nexport const sliderDefaultSlotStructure = new ComponentTemplate(SliderDefaultStructureSlotComponent, 'structure');\n\nexport type PartialSliderProps = Partial<SliderProps>;\nconst defaultConfig: PartialSliderProps = {\n\tstructure: sliderDefaultSlotStructure,\n\thandle: sliderDefaultSlotHandle,\n};\n\n@Component({\n\tselector: '[auSlider]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tencapsulation: ViewEncapsulation.None,\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SliderComponent), multi: true}],\n\timports: [SlotDirective],\n\thost: {\n\t\t'(blur)': 'handleBlur()',\n\t},\n\ttemplate: ` <ng-template [auSlot]=\"state().structure\" [auSlotProps]=\"{state: state(), widget}\"></ng-template> `,\n})\nexport class SliderComponent extends BaseWidgetDirective<SliderWidget> implements AfterContentChecked {\n\treadonly defaultSlots: WritableSignal<PartialSliderProps> = writable(defaultConfig);\n\n\treadonly _widget = callWidgetFactory({\n\t\tfactory: createSlider,\n\t\twidgetName: 'slider',\n\t\tdefaultConfig: this.defaultSlots,\n\t\tevents: {\n\t\t\tonValuesChange: (event) => {\n\t\t\t\tthis.onChange(event);\n\t\t\t\tthis.onTouched();\n\t\t\t\tthis.valuesChange.emit(event);\n\t\t\t},\n\t\t},\n\t\tafterInit: () => {\n\t\t\tuseDirectiveForHost(this._widget.directives.sliderDirective);\n\t\t},\n\t});\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 * Minimum value that can be assigned to the slider\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auMin', transform: auNumberAttribute})\n\tmin: number | undefined;\n\n\t/**\n\t * Maximum value that can be assigned to the slider\n\t *\n\t * @defaultValue `100`\n\t */\n\t@Input({alias: 'auMax', transform: auNumberAttribute})\n\tmax: number | undefined;\n\n\t/**\n\t * Unit value between slider steps\n\t *\n\t * @defaultValue `1`\n\t */\n\t@Input({alias: 'auStepSize', transform: auNumberAttribute})\n\tstepSize: number | undefined;\n\n\t/**\n\t * Current slider values\n\t *\n\t * @defaultValue `[0]`\n\t */\n\t@Input('auValues')\n\tvalues: number[] | undefined;\n\n\t/**\n\t * It `true` slider display is inversed\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auRtl', transform: auBooleanAttribute})\n\trtl: boolean | undefined;\n\n\t/**\n\t * If `true` the value labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auShowValueLabels', transform: auBooleanAttribute}) showValueLabels: boolean | undefined;\n\n\t/**\n\t * If `true` the min and max labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auShowMinMaxLabels', transform: auBooleanAttribute}) showMinMaxLabels: boolean | undefined;\n\n\t/**\n\t * Return the value for the 'aria-label' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\t@Input('auAriaLabelHandle') ariaLabelHandle: ((value: number, sortedIndex: number, index: number) => string) | undefined;\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\t@Input('auAriaValueText') ariaValueText: ((value: number, sortedIndex: number, index: number) => string) | undefined;\n\n\t/**\n\t * If `true` slider value cannot be changed but the slider is still focusable\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auReadonly', transform: auBooleanAttribute})\n\treadonly: boolean | undefined;\n\n\t/**\n\t * If `true` slider value cannot be changed and the slider cannot be focused\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auDisabled', transform: auBooleanAttribute})\n\tdisabled: boolean | undefined;\n\n\t/**\n\t * If `true` is vertically positioned otherwise it is horizontal\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auVertical', transform: auBooleanAttribute})\n\tvertical: boolean | undefined;\n\n\t/**\n\t * An event emitted when slider values are changed\n\t *\n\t * Event payload equals to the updated slider values\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auValuesChange')\n\tvaluesChange = new EventEmitter<number[]>();\n\n\t/**\n\t * Slot to change the default labels of the slider\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({value}: SliderSlotLabelContext) => '' + value\n\t * ```\n\t */\n\t@Input('auLabel') label: SlotContent<SliderSlotLabelContext>;\n\t@ContentChild(SliderLabelDirective, {static: false}) slotLabelFromContent: SliderLabelDirective | undefined;\n\n\t/**\n\t * Slot to change the default display of the slider\n\t */\n\t@Input('auStructure') structure: SlotContent<SliderContext>;\n\t@ContentChild(SliderStructureDirective, {static: false}) slotStructureFromContent: SliderStructureDirective | undefined;\n\n\t/**\n\t * Slot to change the handlers\n\t */\n\t@Input('auHandle') handle: SlotContent<SliderSlotHandleContext>;\n\t@ContentChild(SliderHandleDirective, {static: false}) slotHandleFromContent: SliderHandleDirective | undefined;\n\n\t/**\n\t * Control value accessor methods\n\t */\n\tonChange = (_: any) => {};\n\n\tonTouched = () => {};\n\n\tregisterOnChange(fn: (value: any) => any): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => any): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\twriteValue(value: any): void {\n\t\tif (Array.isArray(value)) {\n\t\t\tthis._widget.patch({\n\t\t\t\tvalues: value,\n\t\t\t});\n\t\t} else {\n\t\t\tthis._widget.patch({\n\t\t\t\tvalues: [value],\n\t\t\t});\n\t\t}\n\t}\n\n\tsetDisabledState(isDisabled: boolean) {\n\t\tthis._widget.patch({\n\t\t\tdisabled: isDisabled,\n\t\t});\n\t}\n\n\thandleBlur() {\n\t\tthis.onTouched();\n\t}\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\thandle: this.slotHandleFromContent?.templateRef,\n\t\t\tlabel: this.slotLabelFromContent?.templateRef,\n\t\t});\n\t}\n}\n"]}
462
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SliderComponent, { className: "SliderComponent", filePath: "components/slider/slider.component.ts", lineNumber: 153 }); })();
463
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../src/components/slider/slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tViewEncapsulation,\n\tforwardRef,\n\tinject,\n} from '@angular/core';\nimport {NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {callWidgetFactory} from '../../config';\nimport type {SliderContext, SliderSlotHandleContext, SliderSlotLabelContext, SliderWidget} from './slider.gen';\nimport {createSlider} from './slider.gen';\n\n/**\n * Directive to provide a template reference for slider labels.\n *\n * This directive uses a template reference to render the {@link SliderSlotLabelContext}.\n */\n@Directive({selector: 'ng-template[auSliderLabel]', standalone: true})\nexport class SliderLabelDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotLabelContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderLabelDirective, context: unknown): context is SliderSlotLabelContext {\n\t\treturn true;\n\t}\n}\n/**\n * Directive representing a handle for a slider component.\n *\n * This directive uses a template reference to render the {@link SliderSlotLabelContext}.\n */\n@Directive({selector: 'ng-template[auSliderHandle]', standalone: true})\nexport class SliderHandleDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotLabelContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderHandleDirective, context: unknown): context is SliderSlotHandleContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SliderHandleDirective],\n\ttemplate: `\n\t\t<ng-template auSliderHandle #handle let-state=\"state\" let-directives=\"directives\" let-item=\"item\">\n\t\t\t<button [auUse]=\"[directives.handleDirective, {item}]\">&nbsp;</button>\n\t\t</ng-template>\n\t`,\n})\nclass SliderDefaultHandleSlotComponent {\n\t@ViewChild('handle', {static: true}) readonly handle!: TemplateRef<SliderSlotHandleContext>;\n}\n\n/**\n * A constant representing the default slot handle for the slider component.\n */\nexport const sliderDefaultSlotHandle: SlotContent<SliderSlotHandleContext> = new ComponentTemplate(SliderDefaultHandleSlotComponent, 'handle');\n\n/**\n * Directive that provides structure for the slider component.\n *\n * This directive uses a `TemplateRef` to handle the context of the slider slot.\n */\n@Directive({selector: 'ng-template[auSliderStructure]', standalone: true})\nexport class SliderStructureDirective {\n\tpublic templateRef = inject(TemplateRef<SliderSlotHandleContext>);\n\tstatic ngTemplateContextGuard(_dir: SliderStructureDirective, context: unknown): context is SliderSlotHandleContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, SliderStructureDirective, UseDirective],\n\ttemplate: `\n\t\t<ng-template auSliderStructure #structure let-state=\"state\" let-directives=\"directives\" let-api=\"api\">\n\t\t\t@for (option of state.progressDisplayOptions(); track option) {\n\t\t\t\t<div [auUse]=\"[directives.progressDisplayDirective, {option}]\"></div>\n\t\t\t}\n\t\t\t<div [auUse]=\"directives.clickableAreaDirective\"></div>\n\t\t\t@if (state.showMinMaxLabels()) {\n\t\t\t\t<div [auUse]=\"directives.minLabelDirective\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.min()}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t\t<div [auUse]=\"directives.maxLabelDirective\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.max()}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t@if (state.showValueLabels() && state.combinedLabelDisplay()) {\n\t\t\t\t<div [auUse]=\"directives.combinedHandleLabelDisplayDirective\">\n\t\t\t\t\t@if (state.rtl()) {\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[1]}\"></ng-template> -\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[0]}\"></ng-template>\n\t\t\t\t\t} @else {\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[0]}\"></ng-template> -\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.sortedValues()[1]}\"></ng-template>\n\t\t\t\t\t}\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t@for (item of state.sortedHandles(); track item.id; let i = $index) {\n\t\t\t\t<ng-template [auSlot]=\"state.handle()\" [auSlotProps]=\"{state, api, directives, item}\"></ng-template>\n\t\t\t\t@if (state.showValueLabels() && !state.combinedLabelDisplay()) {\n\t\t\t\t\t<div [auUse]=\"[directives.handleLabelDisplayDirective, {index: i}]\">\n\t\t\t\t\t\t<ng-template [auSlot]=\"state.label()\" [auSlotProps]=\"{state, api, directives, value: state.values()[i]}\"></ng-template>\n\t\t\t\t\t</div>\n\t\t\t\t}\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nclass SliderDefaultStructureSlotComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<SliderContext>;\n}\n\n/**\n * Represents the default slot structure for the slider component.\n */\nexport const sliderDefaultSlotStructure: SlotContent<SliderContext> = new ComponentTemplate(SliderDefaultStructureSlotComponent, 'structure');\n\n/**\n * SliderComponent is an Angular component that extends the BaseWidgetDirective\n * to provide a customizable slider widget. This component allows for various\n * configurations and customizations through its inputs and outputs.\n */\n@Component({\n\tselector: '[auSlider]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tencapsulation: ViewEncapsulation.None,\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SliderComponent), multi: true}],\n\timports: [SlotDirective],\n\thost: {\n\t\t'(blur)': 'handleBlur()',\n\t},\n\ttemplate: ` <ng-template [auSlot]=\"state.structure()\" [auSlotProps]=\"{state, api, directives}\"></ng-template> `,\n})\nexport class SliderComponent extends BaseWidgetDirective<SliderWidget> {\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 * Minimum value that can be assigned to the slider\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auMin', transform: auNumberAttribute})\n\tmin: number | undefined;\n\n\t/**\n\t * Maximum value that can be assigned to the slider\n\t *\n\t * @defaultValue `100`\n\t */\n\t@Input({alias: 'auMax', transform: auNumberAttribute})\n\tmax: number | undefined;\n\n\t/**\n\t * Unit value between slider steps\n\t *\n\t * @defaultValue `1`\n\t */\n\t@Input({alias: 'auStepSize', transform: auNumberAttribute})\n\tstepSize: number | undefined;\n\n\t/**\n\t * Current slider values\n\t *\n\t * @defaultValue `[0]`\n\t */\n\t@Input('auValues')\n\tvalues: number[] | undefined;\n\n\t/**\n\t * It `true` slider display is inversed\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auRtl', transform: auBooleanAttribute})\n\trtl: boolean | undefined;\n\n\t/**\n\t * If `true` the value labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auShowValueLabels', transform: auBooleanAttribute}) showValueLabels: boolean | undefined;\n\n\t/**\n\t * If `true` the min and max labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auShowMinMaxLabels', transform: auBooleanAttribute}) showMinMaxLabels: boolean | undefined;\n\n\t/**\n\t * Return the value for the 'aria-label' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\t@Input('auAriaLabelHandle') ariaLabelHandle: ((value: number, sortedIndex: number, index: number) => string) | undefined;\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\t@Input('auAriaValueText') ariaValueText: ((value: number, sortedIndex: number, index: number) => string) | undefined;\n\n\t/**\n\t * If `true` slider value cannot be changed but the slider is still focusable\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auReadonly', transform: auBooleanAttribute})\n\treadonly: boolean | undefined;\n\n\t/**\n\t * If `true` slider value cannot be changed and the slider cannot be focused\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auDisabled', transform: auBooleanAttribute})\n\tdisabled: boolean | undefined;\n\n\t/**\n\t * If `true` is vertically positioned otherwise it is horizontal\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auVertical', transform: auBooleanAttribute})\n\tvertical: boolean | undefined;\n\n\t/**\n\t * An event emitted when slider values are changed\n\t *\n\t * Event payload equals to the updated slider values\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auValuesChange')\n\tvaluesChange = new EventEmitter<number[]>();\n\n\t/**\n\t * Slot to change the default labels of the slider\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({value}: SliderSlotLabelContext) => '' + value\n\t * ```\n\t */\n\t@Input('auLabel') label: SlotContent<SliderSlotLabelContext>;\n\t@ContentChild(SliderLabelDirective, {static: false}) slotLabelFromContent: SliderLabelDirective | undefined;\n\n\t/**\n\t * Slot to change the default display of the slider\n\t */\n\t@Input('auStructure') structure: SlotContent<SliderContext>;\n\t@ContentChild(SliderStructureDirective, {static: false}) slotStructureFromContent: SliderStructureDirective | undefined;\n\n\t/**\n\t * Slot to change the handlers\n\t */\n\t@Input('auHandle') handle: SlotContent<SliderSlotHandleContext>;\n\t@ContentChild(SliderHandleDirective, {static: false}) slotHandleFromContent: SliderHandleDirective | undefined;\n\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory({\n\t\t\t\tfactory: createSlider,\n\t\t\t\twidgetName: 'slider',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\tstructure: sliderDefaultSlotStructure,\n\t\t\t\t\thandle: sliderDefaultSlotHandle,\n\t\t\t\t},\n\t\t\t\tevents: {\n\t\t\t\t\tonValuesChange: (event) => {\n\t\t\t\t\t\tthis.onChange(event);\n\t\t\t\t\t\tthis.onTouched();\n\t\t\t\t\t\tthis.valuesChange.emit(event);\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t\tafterInit: (widget) => {\n\t\t\t\t\tuseDirectiveForHost(widget.directives.sliderDirective);\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\t\t\thandle: this.slotHandleFromContent?.templateRef,\n\t\t\t\t\tlabel: this.slotLabelFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t}),\n\t\t);\n\t}\n\n\t/**\n\t * Control value accessor methods\n\t */\n\tonChange = (_: any) => {};\n\n\tonTouched = () => {};\n\n\tregisterOnChange(fn: (value: any) => any): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => any): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\twriteValue(value: any): void {\n\t\tif (Array.isArray(value)) {\n\t\t\tthis['_widget'].patch({\n\t\t\t\tvalues: value,\n\t\t\t});\n\t\t} else {\n\t\t\tthis['_widget'].patch({\n\t\t\t\tvalues: [value],\n\t\t\t});\n\t\t}\n\t}\n\n\tsetDisabledState(isDisabled: boolean) {\n\t\tthis['_widget'].patch({\n\t\t\tdisabled: isDisabled,\n\t\t});\n\t}\n\n\thandleBlur() {\n\t\tthis.onTouched();\n\t}\n}\n"]}