@agnos-ui/angular-bootstrap 0.4.4 → 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
@@ -19,12 +19,17 @@ function RatingComponent_For_1_Template(rf, ctx) { if (rf & 1) {
19
19
  const ɵ$index_1_r1 = ctx.$index;
20
20
  const ctx_r1 = i0.ɵɵnextContext();
21
21
  i0.ɵɵadvance();
22
- i0.ɵɵtextInterpolate1("(", ɵ$index_1_r1 < ctx_r1.state().visibleRating ? "*" : " ", ")");
22
+ i0.ɵɵtextInterpolate1("(", ɵ$index_1_r1 < ctx_r1.state.visibleRating() ? "*" : " ", ")");
23
23
  i0.ɵɵadvance();
24
- i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(6, _c2, ctx_r1._widget.directives.starDirective, i0.ɵɵpureFunction1(4, _c1, ɵ$index_1_r1)));
24
+ i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(6, _c2, ctx_r1.directives.starDirective, i0.ɵɵpureFunction1(4, _c1, ɵ$index_1_r1)));
25
25
  i0.ɵɵadvance();
26
- i0.ɵɵproperty("auSlot", ctx_r1.state().star)("auSlotProps", ctx_r1.state().stars[ɵ$index_1_r1]);
26
+ i0.ɵɵproperty("auSlot", ctx_r1.state.star())("auSlotProps", ctx_r1.state.stars()[ɵ$index_1_r1]);
27
27
  } }
28
+ /**
29
+ * Directive to represent a rating star.
30
+ *
31
+ * This directive uses a template reference to render the {@link StarContext}.
32
+ */
28
33
  export class RatingStarDirective {
29
34
  constructor() {
30
35
  this.templateRef = inject((TemplateRef));
@@ -32,17 +37,32 @@ export class RatingStarDirective {
32
37
  static ngTemplateContextGuard(_dir, context) {
33
38
  return true;
34
39
  }
35
- static { this.ɵfac = function RatingStarDirective_Factory(t) { return new (t || RatingStarDirective)(); }; }
40
+ static { this.ɵfac = function RatingStarDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || RatingStarDirective)(); }; }
36
41
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: RatingStarDirective, selectors: [["ng-template", "auRatingStar", ""]], standalone: true }); }
37
42
  }
38
43
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RatingStarDirective, [{
39
44
  type: Directive,
40
45
  args: [{ selector: 'ng-template[auRatingStar]', standalone: true }]
41
46
  }], null, null); })();
47
+ /**
48
+ * The `RatingComponent` is an Angular component that allows users to provide a rating.
49
+ * It extends `BaseWidgetDirective` and implements `ControlValueAccessor` to integrate with Angular forms.
50
+ */
42
51
  export class RatingComponent extends BaseWidgetDirective {
52
+ writeValue(value) {
53
+ this['_widget'].patch({ rating: value });
54
+ }
55
+ registerOnChange(fn) {
56
+ this.onChange = fn;
57
+ }
58
+ registerOnTouched(fn) {
59
+ this.onTouched = fn;
60
+ }
61
+ setDisabledState(disabled) {
62
+ this['_widget'].patch({ disabled });
63
+ }
43
64
  constructor() {
44
- super(...arguments);
45
- this._widget = callWidgetFactory({
65
+ super(callWidgetFactory({
46
66
  factory: createRating,
47
67
  widgetName: 'rating',
48
68
  events: {
@@ -53,10 +73,13 @@ export class RatingComponent extends BaseWidgetDirective {
53
73
  this.onChange(rating);
54
74
  },
55
75
  },
56
- afterInit: () => {
57
- useDirectiveForHost(this._widget.directives.containerDirective);
76
+ afterInit: (widget) => {
77
+ useDirectiveForHost(widget.directives.containerDirective);
58
78
  },
59
- });
79
+ slotTemplates: () => ({
80
+ star: this.slotStarFromContent?.templateRef,
81
+ }),
82
+ }));
60
83
  this.onChange = (_) => { };
61
84
  this.onTouched = () => { };
62
85
  /**
@@ -93,27 +116,10 @@ export class RatingComponent extends BaseWidgetDirective {
93
116
  */
94
117
  this.ratingChange = new EventEmitter();
95
118
  }
96
- writeValue(value) {
97
- this._widget.patch({ rating: value });
98
- }
99
- registerOnChange(fn) {
100
- this.onChange = fn;
101
- }
102
- registerOnTouched(fn) {
103
- this.onTouched = fn;
104
- }
105
- setDisabledState(disabled) {
106
- this._widget.patch({ disabled });
107
- }
108
- ngAfterContentChecked() {
109
- this._widget.patchSlots({
110
- star: this.slotStarFromContent?.templateRef,
111
- });
112
- }
113
119
  trackByIndex(index) {
114
120
  return index;
115
121
  }
116
- static { this.ɵfac = /*@__PURE__*/ (() => { let ɵRatingComponent_BaseFactory; return function RatingComponent_Factory(t) { return (ɵRatingComponent_BaseFactory || (ɵRatingComponent_BaseFactory = i0.ɵɵgetInheritedFactory(RatingComponent)))(t || RatingComponent); }; })(); }
122
+ static { this.ɵfac = function RatingComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || RatingComponent)(); }; }
117
123
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: RatingComponent, selectors: [["", "auRating", ""]], contentQueries: function RatingComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
118
124
  i0.ɵɵcontentQuery(dirIndex, RatingStarDirective, 5);
119
125
  } if (rf & 2) {
@@ -124,7 +130,7 @@ export class RatingComponent extends BaseWidgetDirective {
124
130
  } }, inputs: { ariaValueTextFn: [0, "auAriaValueTextFn", "ariaValueTextFn"], disabled: [2, "auDisabled", "disabled", auBooleanAttribute], maxRating: [2, "auMaxRating", "maxRating", auNumberAttribute], rating: [2, "auRating", "rating", auNumberAttribute], readonly: [2, "auReadonly", "readonly", auBooleanAttribute], resettable: [2, "auResettable", "resettable", auBooleanAttribute], star: [0, "auStar", "star"], tabindex: [2, "auTabindex", "tabindex", auNumberAttribute], className: [0, "auClassName", "className"], ariaLabel: [0, "auAriaLabel", "ariaLabel"], ariaLabelledBy: [0, "auAriaLabelledBy", "ariaLabelledBy"] }, outputs: { hover: "auHover", leave: "auLeave", ratingChange: "auRatingChange" }, standalone: true, features: [i0.ɵɵProvidersFeature([{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RatingComponent), multi: true }]), i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c0, decls: 2, vars: 0, consts: [[1, "visually-hidden"], [3, "auUse"], [3, "auSlot", "auSlotProps"]], template: function RatingComponent_Template(rf, ctx) { if (rf & 1) {
125
131
  i0.ɵɵrepeaterCreate(0, RatingComponent_For_1_Template, 4, 9, null, null, ctx.trackByIndex, true);
126
132
  } if (rf & 2) {
127
- i0.ɵɵrepeater(ctx.state().stars);
133
+ i0.ɵɵrepeater(ctx.state.stars());
128
134
  } }, dependencies: [UseDirective, SlotDirective], encapsulation: 2, changeDetection: 0 }); }
129
135
  }
130
136
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RatingComponent, [{
@@ -140,16 +146,16 @@ export class RatingComponent extends BaseWidgetDirective {
140
146
  '(blur)': 'onTouched()',
141
147
  },
142
148
  template: `
143
- @for (item of state().stars; track trackByIndex(index); let index = $index) {
144
- <span class="visually-hidden">({{ index < state().visibleRating ? '*' : ' ' }})</span>
145
- <span [auUse]="[_widget.directives.starDirective, {index}]">
146
- <ng-template [auSlot]="state().star" [auSlotProps]="state().stars[index]"></ng-template>
149
+ @for (item of state.stars(); track trackByIndex(index); let index = $index) {
150
+ <span class="visually-hidden">({{ index < state.visibleRating() ? '*' : ' ' }})</span>
151
+ <span [auUse]="[directives.starDirective, {index}]">
152
+ <ng-template [auSlot]="state.star()" [auSlotProps]="state.stars()[index]"></ng-template>
147
153
  </span>
148
154
  }
149
155
  `,
150
156
  providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RatingComponent), multi: true }],
151
157
  }]
152
- }], null, { ariaValueTextFn: [{
158
+ }], () => [], { ariaValueTextFn: [{
153
159
  type: Input,
154
160
  args: ['auAriaValueTextFn']
155
161
  }], disabled: [{
@@ -195,5 +201,5 @@ export class RatingComponent extends BaseWidgetDirective {
195
201
  type: Output,
196
202
  args: ['auRatingChange']
197
203
  }] }); })();
198
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RatingComponent, { className: "RatingComponent", filePath: "components/rating/rating.component.ts", lineNumber: 58 }); })();
199
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rating.component.js","sourceRoot":"","sources":["../../../../src/components/rating/rating.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\tauBooleanAttribute,\n\tauNumberAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport type {AfterContentChecked} from '@angular/core';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewEncapsulation,\n\tforwardRef,\n\tinject,\n} from '@angular/core';\nimport type {ControlValueAccessor} from '@angular/forms';\nimport {NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {callWidgetFactory} from '../../config';\nimport type {RatingWidget, StarContext} from './rating.gen';\nimport {createRating} from './rating.gen';\n\n@Directive({selector: 'ng-template[auRatingStar]', standalone: true})\nexport class RatingStarDirective {\n\tpublic templateRef = inject(TemplateRef<StarContext>);\n\tstatic ngTemplateContextGuard(_dir: RatingStarDirective, context: unknown): context is StarContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tselector: '[auRating]',\n\tstandalone: true,\n\timports: [UseDirective, SlotDirective],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tencapsulation: ViewEncapsulation.None,\n\thost: {\n\t\tclass: 'd-inline-flex',\n\t\t'(blur)': 'onTouched()',\n\t},\n\ttemplate: `\n\t\t@for (item of state().stars; track trackByIndex(index); let index = $index) {\n\t\t\t<span class=\"visually-hidden\">({{ index < state().visibleRating ? '*' : ' ' }})</span>\n\t\t\t<span [auUse]=\"[_widget.directives.starDirective, {index}]\">\n\t\t\t\t<ng-template [auSlot]=\"state().star\" [auSlotProps]=\"state().stars[index]\"></ng-template>\n\t\t\t</span>\n\t\t}\n\t`,\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RatingComponent), multi: true}],\n})\nexport class RatingComponent extends BaseWidgetDirective<RatingWidget> implements ControlValueAccessor, AfterContentChecked {\n\treadonly _widget = callWidgetFactory({\n\t\tfactory: createRating,\n\t\twidgetName: 'rating',\n\t\tevents: {\n\t\t\tonHover: (event) => this.hover.emit(event),\n\t\t\tonLeave: (event) => this.leave.emit(event),\n\t\t\tonRatingChange: (rating: number) => {\n\t\t\t\tthis.ratingChange.emit(rating);\n\t\t\t\tthis.onChange(rating);\n\t\t\t},\n\t\t},\n\t\tafterInit: () => {\n\t\t\tuseDirectiveForHost(this._widget.directives.containerDirective);\n\t\t},\n\t});\n\n\tonChange = (_: any) => {};\n\tonTouched = () => {};\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute.\n\t * @param rating - Current rating value.\n\t * @param maxRating - maxRating value.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (rating: number, maxRating: number) => `${rating} out of ${maxRating}`\n\t * ```\n\t */\n\t@Input('auAriaValueTextFn') ariaValueTextFn: ((rating: number, maxRating: number) => string) | undefined;\n\n\t/**\n\t * If `true`, the rating 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 * The maximum rating that can be given.\n\t *\n\t * @defaultValue `10`\n\t */\n\t@Input({alias: 'auMaxRating', transform: auNumberAttribute}) maxRating: number | undefined;\n\n\t/**\n\t * The current rating. Could be a decimal value like `3.75`.\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auRating', transform: auNumberAttribute}) rating: number | undefined;\n\n\t/**\n\t * If `true`, the rating can't be changed.\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auReadonly', transform: auBooleanAttribute}) readonly: boolean | undefined;\n\n\t/**\n\t * Define if the rating can be reset.\n\t *\n\t * If set to true, the user can 'unset' the rating value by cliking on the current rating value.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auResettable', transform: auBooleanAttribute}) resettable: boolean | undefined;\n\n\t/**\n\t * The template to override the way each star is displayed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({fill}: StarContext) => String.fromCharCode(fill === 100 ? 9733 : 9734)\n\t * ```\n\t */\n\t@Input('auStar') star: SlotContent<StarContext>;\n\t@ContentChild(RatingStarDirective, {static: false}) slotStarFromContent: RatingStarDirective | undefined;\n\n\t/**\n\t * Allows setting a custom rating tabindex.\n\t * If the component is disabled, `tabindex` will still be set to `-1`.\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auTabindex', transform: auNumberAttribute}) tabindex: number | 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 * The aria label\n\t *\n\t * @defaultValue `'Rating'`\n\t */\n\t@Input('auAriaLabel') ariaLabel: string | undefined;\n\n\t/**\n\t * The aria labelled by\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auAriaLabelledBy') ariaLabelledBy: string | undefined;\n\n\t/**\n\t * An event emitted when the user is hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auHover') hover = new EventEmitter<number>();\n\n\t/**\n\t * An event emitted when the user stops hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating of the last item being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auLeave') leave = new EventEmitter<number>();\n\n\t/**\n\t * An event emitted when the rating is changed.\n\t *\n\t * Event payload is equal to the newly selected rating.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auRatingChange') ratingChange = new EventEmitter<number>();\n\n\twriteValue(value: any): void {\n\t\tthis._widget.patch({rating: value});\n\t}\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\tsetDisabledState(disabled: boolean): void {\n\t\tthis._widget.patch({disabled});\n\t}\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tstar: this.slotStarFromContent?.templateRef,\n\t\t});\n\t}\n\n\ttrackByIndex(index: number) {\n\t\treturn index;\n\t}\n}\n"]}
204
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RatingComponent, { className: "RatingComponent", filePath: "components/rating/rating.component.ts", lineNumber: 66 }); })();
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rating.component.js","sourceRoot":"","sources":["../../../../src/components/rating/rating.component.ts"],"names":[],"mappings":"AACA,OAAO,EACN,mBAAmB,EACnB,aAAa,EACb,YAAY,EACZ,kBAAkB,EAClB,iBAAiB,EACjB,mBAAmB,GACnB,MAAM,4BAA4B,CAAC;AACpC,OAAO,EACN,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,WAAW,EACX,iBAAiB,EACjB,UAAU,EACV,MAAM,GACN,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAC,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAC,iBAAiB,EAAC,MAAM,cAAc,CAAC;AAE/C,OAAO,EAAC,YAAY,EAAC,MAAM,cAAc,CAAC;;;;;;;IA+BvC,+BAA8B;IAAA,YAAiD;IAAA,iBAAO;IACtF,+BAAoD;IACnD,sFAA0E;IAC3E,iBAAO;;;;IAHuB,cAAiD;IAAjD,wFAAiD;IACzE,cAA6C;IAA7C,6HAA6C;IACrC,cAAuB;IAAC,AAAxB,4CAAuB,mDAAqC;;AA/B7E;;;;GAIG;AAEH,MAAM,OAAO,mBAAmB;IADhC;QAEQ,gBAAW,GAAG,MAAM,CAAC,CAAA,WAAwB,CAAA,CAAC,CAAC;KAItD;IAHA,MAAM,CAAC,sBAAsB,CAAC,IAAyB,EAAE,OAAgB;QACxE,OAAO,IAAI,CAAC;IACb,CAAC;oHAJW,mBAAmB;oEAAnB,mBAAmB;;iFAAnB,mBAAmB;cAD/B,SAAS;eAAC,EAAC,QAAQ,EAAE,2BAA2B,EAAE,UAAU,EAAE,IAAI,EAAC;;AAQpE;;;GAGG;AAqBH,MAAM,OAAO,eAAgB,SAAQ,mBAAiC;IAiIrE,UAAU,CAAC,KAAU;QACpB,IAAI,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,EAAC,MAAM,EAAE,KAAK,EAAC,CAAC,CAAC;IACxC,CAAC;IAED,gBAAgB,CAAC,EAAuB;QACvC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,iBAAiB,CAAC,EAAa;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,gBAAgB,CAAC,QAAiB;QACjC,IAAI,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,EAAC,QAAQ,EAAC,CAAC,CAAC;IACnC,CAAC;IAED;QACC,KAAK,CACJ,iBAAiB,CAAC;YACjB,OAAO,EAAE,YAAY;YACrB,UAAU,EAAE,QAAQ;YACpB,MAAM,EAAE;gBACP,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;gBAC1C,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;gBAC1C,cAAc,EAAE,CAAC,MAAc,EAAE,EAAE;oBAClC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBAC/B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;gBACvB,CAAC;aACD;YACD,SAAS,EAAE,CAAC,MAAM,EAAE,EAAE;gBACrB,mBAAmB,CAAC,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC;YAC3D,CAAC;YACD,aAAa,EAAE,GAAG,EAAE,CAAC,CAAC;gBACrB,IAAI,EAAE,IAAI,CAAC,mBAAmB,EAAE,WAAW;aAC3C,CAAC;SACF,CAAC,CACF,CAAC;QApKH,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAC1B,cAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QA2FrB;;;;;;;;;WASG;QACgB,UAAK,GAAG,IAAI,YAAY,EAAU,CAAC;QAEtD;;;;;;;;;WASG;QACgB,UAAK,GAAG,IAAI,YAAY,EAAU,CAAC;QAEtD;;;;;;;;;WASG;QACuB,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC;IAuCpE,CAAC;IAED,YAAY,CAAC,KAAa;QACzB,OAAO,KAAK,CAAC;IACd,CAAC;gHA1KW,eAAe;oEAAf,eAAe;wCA8Db,mBAAmB;;;;;YA9DrB,kFAAA,eAAW,IAAI;6HAqBa,kBAAkB,8CAOjB,iBAAiB,qCAOpB,iBAAiB,2CAOf,kBAAkB,iDAShB,kBAAkB,wEAmBpB,iBAAiB,4RAxE9C,CAAC,EAAC,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC;YAPrG,gGAKC;;YALD,cAAA,iBAAa,CAKZ;4BAbQ,YAAY,EAAE,aAAa;;iFAiBzB,eAAe;cApB3B,SAAS;eAAC;gBACV,QAAQ,EAAE,YAAY;gBACtB,UAAU,EAAE,IAAI;gBAChB,OAAO,EAAE,CAAC,YAAY,EAAE,aAAa,CAAC;gBACtC,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,IAAI,EAAE;oBACL,KAAK,EAAE,eAAe;oBACtB,QAAQ,EAAE,aAAa;iBACvB;gBACD,QAAQ,EAAE;;;;;;;EAOT;gBACD,SAAS,EAAE,CAAC,EAAC,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,gBAAgB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC;aACtG;oBAe4B,eAAe;kBAA1C,KAAK;mBAAC,mBAAmB;YAOmC,QAAQ;kBAApE,KAAK;mBAAC,EAAC,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,kBAAkB,EAAC;YAOE,SAAS;kBAArE,KAAK;mBAAC,EAAC,KAAK,EAAE,aAAa,EAAE,SAAS,EAAE,iBAAiB,EAAC;YAOD,MAAM;kBAA/D,KAAK;mBAAC,EAAC,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,iBAAiB,EAAC;YAOK,QAAQ;kBAApE,KAAK;mBAAC,EAAC,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,kBAAkB,EAAC;YASI,UAAU;kBAAxE,KAAK;mBAAC,EAAC,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,kBAAkB,EAAC;YAU5C,IAAI;kBAApB,KAAK;mBAAC,QAAQ;YACqC,mBAAmB;kBAAtE,YAAY;mBAAC,mBAAmB,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;YAQU,QAAQ;kBAAnE,KAAK;mBAAC,EAAC,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,iBAAiB,EAAC;YAOpC,SAAS;kBAA9B,KAAK;mBAAC,aAAa;YAOE,SAAS;kBAA9B,KAAK;mBAAC,aAAa;YAOO,cAAc;kBAAxC,KAAK;mBAAC,kBAAkB;YAYN,KAAK;kBAAvB,MAAM;mBAAC,SAAS;YAYE,KAAK;kBAAvB,MAAM;mBAAC,SAAS;YAYS,YAAY;kBAArC,MAAM;mBAAC,gBAAgB;;kFA/HZ,eAAe","sourcesContent":["import type {SlotContent} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\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\tViewEncapsulation,\n\tforwardRef,\n\tinject,\n} from '@angular/core';\nimport type {ControlValueAccessor} from '@angular/forms';\nimport {NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {callWidgetFactory} from '../../config';\nimport type {RatingWidget, StarContext} from './rating.gen';\nimport {createRating} from './rating.gen';\n\n/**\n * Directive to represent a rating star.\n *\n * This directive uses a template reference to render the {@link StarContext}.\n */\n@Directive({selector: 'ng-template[auRatingStar]', standalone: true})\nexport class RatingStarDirective {\n\tpublic templateRef = inject(TemplateRef<StarContext>);\n\tstatic ngTemplateContextGuard(_dir: RatingStarDirective, context: unknown): context is StarContext {\n\t\treturn true;\n\t}\n}\n\n/**\n * The `RatingComponent` is an Angular component that allows users to provide a rating.\n * It extends `BaseWidgetDirective` and implements `ControlValueAccessor` to integrate with Angular forms.\n */\n@Component({\n\tselector: '[auRating]',\n\tstandalone: true,\n\timports: [UseDirective, SlotDirective],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tencapsulation: ViewEncapsulation.None,\n\thost: {\n\t\tclass: 'd-inline-flex',\n\t\t'(blur)': 'onTouched()',\n\t},\n\ttemplate: `\n\t\t@for (item of state.stars(); track trackByIndex(index); let index = $index) {\n\t\t\t<span class=\"visually-hidden\">({{ index < state.visibleRating() ? '*' : ' ' }})</span>\n\t\t\t<span [auUse]=\"[directives.starDirective, {index}]\">\n\t\t\t\t<ng-template [auSlot]=\"state.star()\" [auSlotProps]=\"state.stars()[index]\"></ng-template>\n\t\t\t</span>\n\t\t}\n\t`,\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RatingComponent), multi: true}],\n})\nexport class RatingComponent extends BaseWidgetDirective<RatingWidget> implements ControlValueAccessor {\n\tonChange = (_: any) => {};\n\tonTouched = () => {};\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute.\n\t * @param rating - Current rating value.\n\t * @param maxRating - maxRating value.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (rating: number, maxRating: number) => `${rating} out of ${maxRating}`\n\t * ```\n\t */\n\t@Input('auAriaValueTextFn') ariaValueTextFn: ((rating: number, maxRating: number) => string) | undefined;\n\n\t/**\n\t * If `true`, the rating 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 * The maximum rating that can be given.\n\t *\n\t * @defaultValue `10`\n\t */\n\t@Input({alias: 'auMaxRating', transform: auNumberAttribute}) maxRating: number | undefined;\n\n\t/**\n\t * The current rating. Could be a decimal value like `3.75`.\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auRating', transform: auNumberAttribute}) rating: number | undefined;\n\n\t/**\n\t * If `true`, the rating can't be changed.\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auReadonly', transform: auBooleanAttribute}) readonly: boolean | undefined;\n\n\t/**\n\t * Define if the rating can be reset.\n\t *\n\t * If set to true, the user can 'unset' the rating value by cliking on the current rating value.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auResettable', transform: auBooleanAttribute}) resettable: boolean | undefined;\n\n\t/**\n\t * The template to override the way each star is displayed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({fill}: StarContext) => String.fromCharCode(fill === 100 ? 9733 : 9734)\n\t * ```\n\t */\n\t@Input('auStar') star: SlotContent<StarContext>;\n\t@ContentChild(RatingStarDirective, {static: false}) slotStarFromContent: RatingStarDirective | undefined;\n\n\t/**\n\t * Allows setting a custom rating tabindex.\n\t * If the component is disabled, `tabindex` will still be set to `-1`.\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auTabindex', transform: auNumberAttribute}) tabindex: number | 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 * The aria label\n\t *\n\t * @defaultValue `'Rating'`\n\t */\n\t@Input('auAriaLabel') ariaLabel: string | undefined;\n\n\t/**\n\t * The aria labelled by\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auAriaLabelledBy') ariaLabelledBy: string | undefined;\n\n\t/**\n\t * An event emitted when the user is hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auHover') hover = new EventEmitter<number>();\n\n\t/**\n\t * An event emitted when the user stops hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating of the last item being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auLeave') leave = new EventEmitter<number>();\n\n\t/**\n\t * An event emitted when the rating is changed.\n\t *\n\t * Event payload is equal to the newly selected rating.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auRatingChange') ratingChange = new EventEmitter<number>();\n\n\twriteValue(value: any): void {\n\t\tthis['_widget'].patch({rating: value});\n\t}\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\tsetDisabledState(disabled: boolean): void {\n\t\tthis['_widget'].patch({disabled});\n\t}\n\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory({\n\t\t\t\tfactory: createRating,\n\t\t\t\twidgetName: 'rating',\n\t\t\t\tevents: {\n\t\t\t\t\tonHover: (event) => this.hover.emit(event),\n\t\t\t\t\tonLeave: (event) => this.leave.emit(event),\n\t\t\t\t\tonRatingChange: (rating: number) => {\n\t\t\t\t\t\tthis.ratingChange.emit(rating);\n\t\t\t\t\t\tthis.onChange(rating);\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.containerDirective);\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tstar: this.slotStarFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t}),\n\t\t);\n\t}\n\n\ttrackByIndex(index: number) {\n\t\treturn index;\n\t}\n}\n"]}
@@ -12,4 +12,4 @@ export { export_getRatingDefaultConfig as getRatingDefaultConfig };
12
12
  */
13
13
  const export_createRating = createRating;
14
14
  export { export_createRating as createRating };
15
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rating.gen.js","sourceRoot":"","sources":["../../../../src/components/rating/rating.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAE,YAAY,EAAC,MAAM,4CAA4C,CAAC;AAKhG;;;GAGG;AACH,MAAM,6BAA6B,GAAsB,sBAA6B,CAAC;AACvF,OAAO,EAAC,6BAA6B,IAAI,sBAAsB,EAAC,CAAC;AA2PjE;;;;GAIG;AAEH,MAAM,mBAAmB,GAAgC,YAAmB,CAAC;AAC7E,OAAO,EAAC,mBAAmB,IAAI,YAAY,EAAC,CAAC","sourcesContent":["import {getRatingDefaultConfig, createRating} from '@agnos-ui/core-bootstrap/components/rating';\nimport type {SlotContent, Widget, WidgetFactory, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default Rating config\n * @returns the default Rating config\n */\nconst export_getRatingDefaultConfig: () => RatingProps = getRatingDefaultConfig as any;\nexport {export_getRatingDefaultConfig as getRatingDefaultConfig};\n\nexport interface RatingState {\n\t\n\t/**\n\t * the aria value of the rating\n\t */\n\tariaValueText: string;\n\t\n\t/**\n\t * the visible value of the rating (it changes when hovering over the rating even though the real value did not change)\n\t */\n\tvisibleRating: number;\n\t\n\t/**\n\t * is the rating interactive i.e. listening to hover, click and keyboard events\n\t */\n\tinteractive: boolean;\n\t\n\t/**\n\t * the list of stars\n\t */\n\tstars: StarContext[];\n\t\n\t/**\n\t * The current rating. Could be a decimal value like `3.75`.\n\t *\n\t * @defaultValue `0`\n\t */\n\trating: number;\n\t\n\n\t/**\n\t * The maximum rating that can be given.\n\t *\n\t * @defaultValue `10`\n\t */\n\tmaxRating: number;\n\t\n\n\t/**\n\t * If `true`, the rating is disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true`, the rating can't be changed.\n\t *\n\t * @defaultValue `false`\n\t */\n\treadonly: boolean;\n\t\n\n\t/**\n\t * Define if the rating can be reset.\n\t *\n\t * If set to true, the user can 'unset' the rating value by cliking on the current rating value.\n\t *\n\t * @defaultValue `true`\n\t */\n\tresettable: boolean;\n\t\n\n\t/**\n\t * Allows setting a custom rating tabindex.\n\t * If the component is disabled, `tabindex` will still be set to `-1`.\n\t *\n\t * @defaultValue `0`\n\t */\n\ttabindex: number;\n\t\n\n\t/**\n\t * The aria label\n\t *\n\t * @defaultValue `'Rating'`\n\t */\n\tariaLabel: string;\n\t\n\n\t/**\n\t * The aria labelled by\n\t *\n\t * @defaultValue `''`\n\t */\n\tariaLabelledBy: string;\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 star is displayed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({fill}: StarContext) => String.fromCharCode(fill === 100 ? 9733 : 9734)\n\t * ```\n\t */\n\tstar: SlotContent<StarContext>;\n}\n\nexport interface RatingProps {\n\t\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute.\n\t * @param rating - Current rating value.\n\t * @param maxRating - maxRating value.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (rating: number, maxRating: number) => `${rating} out of ${maxRating}`\n\t * ```\n\t */\n\tariaValueTextFn: (rating: number, maxRating: number) => string;\n\t\n\n\t/**\n\t * An event emitted when the rating is changed.\n\t *\n\t * Event payload is equal to the newly selected rating.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonRatingChange: (rating: number) => void;\n\t\n\n\t/**\n\t * An event emitted when the user is hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonHover: (rating: number) => void;\n\t\n\n\t/**\n\t * An event emitted when the user stops hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating of the last item being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonLeave: (rating: number) => void;\n\t\n\t/**\n\t * The current rating. Could be a decimal value like `3.75`.\n\t *\n\t * @defaultValue `0`\n\t */\n\trating: number;\n\t\n\n\t/**\n\t * The maximum rating that can be given.\n\t *\n\t * @defaultValue `10`\n\t */\n\tmaxRating: number;\n\t\n\n\t/**\n\t * If `true`, the rating is disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true`, the rating can't be changed.\n\t *\n\t * @defaultValue `false`\n\t */\n\treadonly: boolean;\n\t\n\n\t/**\n\t * Define if the rating can be reset.\n\t *\n\t * If set to true, the user can 'unset' the rating value by cliking on the current rating value.\n\t *\n\t * @defaultValue `true`\n\t */\n\tresettable: boolean;\n\t\n\n\t/**\n\t * Allows setting a custom rating tabindex.\n\t * If the component is disabled, `tabindex` will still be set to `-1`.\n\t *\n\t * @defaultValue `0`\n\t */\n\ttabindex: number;\n\t\n\n\t/**\n\t * The aria label\n\t *\n\t * @defaultValue `'Rating'`\n\t */\n\tariaLabel: string;\n\t\n\n\t/**\n\t * The aria labelled by\n\t *\n\t * @defaultValue `''`\n\t */\n\tariaLabelledBy: string;\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 star is displayed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({fill}: StarContext) => String.fromCharCode(fill === 100 ? 9733 : 9734)\n\t * ```\n\t */\n\tstar: SlotContent<StarContext>;\n}\n\n\n\nexport type RatingWidget = Widget<RatingProps, RatingState, object, RatingActions, RatingDirectives>;\n\n\n\n/**\n * Create a RatingWidget with given config props\n * @param config - an optional rating config\n * @returns a RatingWidget\n */\n\nconst export_createRating: WidgetFactory<RatingWidget> = createRating as any;\nexport {export_createRating as createRating};\n\nexport interface StarContext {\n\t\n\t/**\n\t * indicates how much the current star is filled, from 0 to 100\n\t */\n\tfill: number;\n\t\n\t/**\n\t * the position of the star in the rating\n\t */\n\tindex: number;\n}\n\nexport interface RatingDirectives {\n\t\n\t/**\n\t * A directive to be applied to the main container\n\t * This will handle the keydown, mouseleave, tabindex and aria attributes\n\t */\n\tcontainerDirective: Directive;\n\t\n\n\t/**\n\t * A directive to be applied on each star element\n\t */\n\tstarDirective: Directive<{index: number}>;\n}\n\nexport interface RatingActions {\n\t\n\t/**\n\t * Method to be used when a star is clicked.\n\t *\n\t * To be used in the onclick event of a star\n\t * @param index - Star index, starting from 1\n\t */\n\tclick(index: number): void;\n\t\n\n\t/**\n\t * Method to be used when the mouse enter in a star.\n\t *\n\t * To be used in the onmouseenter of a star\n\t * @param index - Star index, starting from 1\n\t */\n\thover(index: number): void;\n\t\n\n\t/**\n\t * Method to be used when the mouse leave the widget.\n\t *\n\t * To be used in the onmouseleave of the rating container\n\t */\n\tleave(): void;\n\t\n\n\t/**\n\t * Method to be used to handle the keyboard.\n\t *\n\t * To be used in the onkeydown of the rating container\n\t */\n\thandleKey(event: KeyboardEvent): void;\n}\n\n"]}
15
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rating.gen.js","sourceRoot":"","sources":["../../../../src/components/rating/rating.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAE,YAAY,EAAC,MAAM,4CAA4C,CAAC;AAKhG;;;GAGG;AACH,MAAM,6BAA6B,GAAsB,sBAA6B,CAAC;AACvF,OAAO,EAAC,6BAA6B,IAAI,sBAAsB,EAAC,CAAC;AAoQjE;;;;GAIG;AAEH,MAAM,mBAAmB,GAAgC,YAAmB,CAAC;AAC7E,OAAO,EAAC,mBAAmB,IAAI,YAAY,EAAC,CAAC","sourcesContent":["import {getRatingDefaultConfig, createRating} from '@agnos-ui/core-bootstrap/components/rating';\nimport type {SlotContent, Widget, WidgetFactory, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default Rating config\n * @returns the default Rating config\n */\nconst export_getRatingDefaultConfig: () => RatingProps = getRatingDefaultConfig as any;\nexport {export_getRatingDefaultConfig as getRatingDefaultConfig};\n\n/**\n * Represents the state of a rating component.\n */\nexport interface RatingState {\n\t\n\t/**\n\t * the aria value of the rating\n\t */\n\tariaValueText: string;\n\t\n\t/**\n\t * the visible value of the rating (it changes when hovering over the rating even though the real value did not change)\n\t */\n\tvisibleRating: number;\n\t\n\t/**\n\t * is the rating interactive i.e. listening to hover, click and keyboard events\n\t */\n\tinteractive: boolean;\n\t\n\t/**\n\t * the list of stars\n\t */\n\tstars: StarContext[];\n\t\n\t/**\n\t * The current rating. Could be a decimal value like `3.75`.\n\t *\n\t * @defaultValue `0`\n\t */\n\trating: number;\n\t\n\n\t/**\n\t * The maximum rating that can be given.\n\t *\n\t * @defaultValue `10`\n\t */\n\tmaxRating: number;\n\t\n\n\t/**\n\t * If `true`, the rating is disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true`, the rating can't be changed.\n\t *\n\t * @defaultValue `false`\n\t */\n\treadonly: boolean;\n\t\n\n\t/**\n\t * Define if the rating can be reset.\n\t *\n\t * If set to true, the user can 'unset' the rating value by cliking on the current rating value.\n\t *\n\t * @defaultValue `true`\n\t */\n\tresettable: boolean;\n\t\n\n\t/**\n\t * Allows setting a custom rating tabindex.\n\t * If the component is disabled, `tabindex` will still be set to `-1`.\n\t *\n\t * @defaultValue `0`\n\t */\n\ttabindex: number;\n\t\n\n\t/**\n\t * The aria label\n\t *\n\t * @defaultValue `'Rating'`\n\t */\n\tariaLabel: string;\n\t\n\n\t/**\n\t * The aria labelled by\n\t *\n\t * @defaultValue `''`\n\t */\n\tariaLabelledBy: string;\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 star is displayed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({fill}: StarContext) => String.fromCharCode(fill === 100 ? 9733 : 9734)\n\t * ```\n\t */\n\tstar: SlotContent<StarContext>;\n}\n\n/**\n * Represents the properties for the Rating component.\n */\nexport interface RatingProps {\n\t\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute.\n\t * @param rating - Current rating value.\n\t * @param maxRating - maxRating value.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (rating: number, maxRating: number) => `${rating} out of ${maxRating}`\n\t * ```\n\t */\n\tariaValueTextFn: (rating: number, maxRating: number) => string;\n\t\n\n\t/**\n\t * An event emitted when the rating is changed.\n\t *\n\t * Event payload is equal to the newly selected rating.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonRatingChange: (rating: number) => void;\n\t\n\n\t/**\n\t * An event emitted when the user is hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonHover: (rating: number) => void;\n\t\n\n\t/**\n\t * An event emitted when the user stops hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating of the last item being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonLeave: (rating: number) => void;\n\t\n\t/**\n\t * The current rating. Could be a decimal value like `3.75`.\n\t *\n\t * @defaultValue `0`\n\t */\n\trating: number;\n\t\n\n\t/**\n\t * The maximum rating that can be given.\n\t *\n\t * @defaultValue `10`\n\t */\n\tmaxRating: number;\n\t\n\n\t/**\n\t * If `true`, the rating is disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true`, the rating can't be changed.\n\t *\n\t * @defaultValue `false`\n\t */\n\treadonly: boolean;\n\t\n\n\t/**\n\t * Define if the rating can be reset.\n\t *\n\t * If set to true, the user can 'unset' the rating value by cliking on the current rating value.\n\t *\n\t * @defaultValue `true`\n\t */\n\tresettable: boolean;\n\t\n\n\t/**\n\t * Allows setting a custom rating tabindex.\n\t * If the component is disabled, `tabindex` will still be set to `-1`.\n\t *\n\t * @defaultValue `0`\n\t */\n\ttabindex: number;\n\t\n\n\t/**\n\t * The aria label\n\t *\n\t * @defaultValue `'Rating'`\n\t */\n\tariaLabel: string;\n\t\n\n\t/**\n\t * The aria labelled by\n\t *\n\t * @defaultValue `''`\n\t */\n\tariaLabelledBy: string;\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 star is displayed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({fill}: StarContext) => String.fromCharCode(fill === 100 ? 9733 : 9734)\n\t * ```\n\t */\n\tstar: SlotContent<StarContext>;\n}\n\n\n\n/**\n * Represents a Rating Widget component.\n */\nexport type RatingWidget = Widget<RatingProps, RatingState, RatingApi, RatingDirectives>;\n\n\n\n/**\n * Create a RatingWidget with given config props\n * @param config - an optional rating config\n * @returns a RatingWidget\n */\n\nconst export_createRating: WidgetFactory<RatingWidget> = createRating as any;\nexport {export_createRating as createRating};\n\n\n\n/**\n * Represents the context for a star in a rating component.\n */\nexport interface StarContext {\n\t/**\n\t * indicates how much the current star is filled, from 0 to 100\n\t */\n\tfill: number;\n\t/**\n\t * the position of the star in the rating\n\t */\n\tindex: number;\n}\n\n/**\n * Interface representing directives for a rating component.\n */\nexport interface RatingDirectives {\n\t\n\t/**\n\t * A directive to be applied to the main container\n\t * This will handle the keydown, mouseleave, tabindex and aria attributes\n\t */\n\tcontainerDirective: Directive;\n\t\n\n\t/**\n\t * A directive to be applied on each star element\n\t */\n\tstarDirective: Directive<{index: number}>;\n}\n\n/**\n * Interface representing the API that can be performed on a rating component.\n */\nexport interface RatingApi {\n\t\n\t/**\n\t * Sets the rating value.\n\t *\n\t * @param index - Star index, starting from 1\n\t */\n\tsetRating(index: number): void;\n\t\n\n\t/**\n\t * Sets the hovered rating value.\n\t *\n\t * @param index - Star index, starting from 1\n\t */\n\tsetHoveredRating(index: number): void;\n\t\n\n\t/**\n\t * Leave the rating, resetting the visible rating to the rating value and triggering the onLeave callback\n\t */\n\tleave(): void;\n}\n\n"]}