@agnos-ui/angular-bootstrap 0.4.0-next.1 → 0.4.1

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 (80) hide show
  1. package/README.md +1 -1
  2. package/components/accordion/accordion.component.d.ts +38 -1
  3. package/components/accordion/accordion.gen.d.ts +77 -5
  4. package/components/accordion/index.d.ts +1 -1
  5. package/components/alert/alert.component.d.ts +32 -1
  6. package/components/alert/alert.gen.d.ts +61 -7
  7. package/components/alert/index.d.ts +1 -1
  8. package/components/modal/index.d.ts +1 -1
  9. package/components/modal/modal.component.d.ts +56 -4
  10. package/components/modal/modal.gen.d.ts +123 -23
  11. package/components/modal/modal.service.d.ts +1 -1
  12. package/components/pagination/index.d.ts +1 -1
  13. package/components/pagination/pagination.component.d.ts +104 -18
  14. package/components/pagination/pagination.gen.d.ts +188 -18
  15. package/components/progressbar/index.d.ts +1 -1
  16. package/components/progressbar/progressbar.component.d.ts +25 -1
  17. package/components/progressbar/progressbar.gen.d.ts +54 -1
  18. package/components/rating/index.d.ts +1 -1
  19. package/components/rating/rating.component.d.ts +46 -1
  20. package/components/rating/rating.gen.d.ts +84 -1
  21. package/components/select/index.d.ts +1 -1
  22. package/components/select/select.component.d.ts +67 -1
  23. package/components/select/select.gen.d.ts +121 -1
  24. package/components/slider/index.d.ts +1 -1
  25. package/components/slider/slider.component.d.ts +49 -1
  26. package/components/slider/slider.gen.d.ts +98 -3
  27. package/components/toast/index.d.ts +1 -1
  28. package/components/toast/toast.component.d.ts +35 -1
  29. package/components/toast/toast.gen.d.ts +65 -7
  30. package/esm2022/components/accordion/accordion.component.mjs +12 -2
  31. package/esm2022/components/accordion/accordion.gen.mjs +33 -2
  32. package/esm2022/components/accordion/index.mjs +2 -2
  33. package/esm2022/components/alert/alert.component.mjs +17 -2
  34. package/esm2022/components/alert/alert.gen.mjs +15 -2
  35. package/esm2022/components/alert/index.mjs +2 -2
  36. package/esm2022/components/modal/index.mjs +2 -2
  37. package/esm2022/components/modal/modal.component.mjs +28 -3
  38. package/esm2022/components/modal/modal.gen.mjs +27 -2
  39. package/esm2022/components/modal/modal.service.mjs +1 -1
  40. package/esm2022/components/pagination/index.mjs +2 -2
  41. package/esm2022/components/pagination/pagination.component.mjs +6 -2
  42. package/esm2022/components/pagination/pagination.gen.mjs +15 -2
  43. package/esm2022/components/progressbar/index.mjs +2 -2
  44. package/esm2022/components/progressbar/progressbar.component.mjs +2 -2
  45. package/esm2022/components/progressbar/progressbar.gen.mjs +15 -2
  46. package/esm2022/components/rating/index.mjs +2 -2
  47. package/esm2022/components/rating/rating.component.mjs +17 -2
  48. package/esm2022/components/rating/rating.gen.mjs +15 -2
  49. package/esm2022/components/select/index.mjs +2 -2
  50. package/esm2022/components/select/select.component.mjs +19 -2
  51. package/esm2022/components/select/select.gen.mjs +15 -2
  52. package/esm2022/components/slider/index.mjs +2 -2
  53. package/esm2022/components/slider/slider.component.mjs +7 -2
  54. package/esm2022/components/slider/slider.gen.mjs +15 -2
  55. package/esm2022/components/toast/index.mjs +2 -2
  56. package/esm2022/components/toast/toast.component.mjs +17 -2
  57. package/esm2022/components/toast/toast.gen.mjs +15 -2
  58. package/esm2022/index.mjs +3 -3
  59. package/fesm2022/agnos-ui-angular-bootstrap.mjs +251 -40
  60. package/fesm2022/agnos-ui-angular-bootstrap.mjs.map +1 -1
  61. package/index.d.ts +2 -2
  62. package/package.json +6 -6
  63. package/components/accordion/accordion.d.ts +0 -6
  64. package/components/alert/alert.d.ts +0 -5
  65. package/components/modal/modal.d.ts +0 -6
  66. package/components/pagination/pagination.d.ts +0 -5
  67. package/components/progressbar/progressbar.d.ts +0 -5
  68. package/components/rating/rating.d.ts +0 -5
  69. package/components/select/select.d.ts +0 -5
  70. package/components/slider/slider.d.ts +0 -5
  71. package/components/toast/toast.d.ts +0 -5
  72. package/esm2022/components/accordion/accordion.mjs +0 -5
  73. package/esm2022/components/alert/alert.mjs +0 -4
  74. package/esm2022/components/modal/modal.mjs +0 -5
  75. package/esm2022/components/pagination/pagination.mjs +0 -4
  76. package/esm2022/components/progressbar/progressbar.mjs +0 -4
  77. package/esm2022/components/rating/rating.mjs +0 -4
  78. package/esm2022/components/select/select.mjs +0 -4
  79. package/esm2022/components/slider/slider.mjs +0 -4
  80. package/esm2022/components/toast/toast.mjs +0 -4
@@ -3,7 +3,7 @@ import { BaseWidgetDirective, ComponentTemplate } from '@agnos-ui/angular-headle
3
3
  import type { WritableSignal } from '@amadeus-it-group/tansu';
4
4
  import type { AfterContentChecked } from '@angular/core';
5
5
  import { EventEmitter, TemplateRef } from '@angular/core';
6
- import type { ToastContext, ToastProps, ToastWidget } from './toast';
6
+ import type { ToastContext, ToastProps, ToastWidget } from './toast.gen';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class ToastBodyDirective {
9
9
  templateRef: TemplateRef<any>;
@@ -33,15 +33,22 @@ export declare class ToastComponent extends BaseWidgetDirective<ToastWidget> imp
33
33
  /**
34
34
  * If `true`, alert can be dismissed by the user.
35
35
  * The close button (×) will be displayed and you can be notified of the event with the (close) output.
36
+ *
37
+ * @defaultValue `true`
36
38
  */
37
39
  dismissible: boolean | undefined;
38
40
  /**
39
41
  * The transition function will be executed when the alert is displayed or hidden.
42
+ *
40
43
  * Depending on the value of `animatedOnInit`, the animation can be optionally skipped during the showing process.
44
+ *
45
+ * @defaultValue `fadeTransition`
41
46
  */
42
47
  transition: TransitionFn | undefined;
43
48
  /**
44
49
  * If `true` the alert is visible to the user
50
+ *
51
+ * @defaultValue `true`
45
52
  */
46
53
  visible: boolean | undefined;
47
54
  /**
@@ -49,6 +56,8 @@ export declare class ToastComponent extends BaseWidgetDirective<ToastWidget> imp
49
56
  *
50
57
  * Animation is triggered when the `.open()` function is called
51
58
  * or the visible prop is changed
59
+ *
60
+ * @defaultValue `false`
52
61
  */
53
62
  animatedOnInit: boolean | undefined;
54
63
  /**
@@ -56,18 +65,26 @@ export declare class ToastComponent extends BaseWidgetDirective<ToastWidget> imp
56
65
  *
57
66
  * Animation is triggered when clicked on the close button (×),
58
67
  * via the `.close()` function or the visible prop is changed
68
+ *
69
+ * @defaultValue `true`
59
70
  */
60
71
  animated: boolean | undefined;
61
72
  /**
62
73
  * If `true` automatically hides the toast after the delay.
74
+ *
75
+ * @defaultValue `true`
63
76
  */
64
77
  autoHide: boolean | undefined;
65
78
  /**
66
79
  * Delay in milliseconds before hiding the toast.
80
+ *
81
+ * @defaultValue `5000`
67
82
  */
68
83
  delay: number | undefined;
69
84
  /**
70
85
  * Accessibility close button label
86
+ *
87
+ * @defaultValue `'Close'`
71
88
  */
72
89
  ariaCloseButtonLabel: string | undefined;
73
90
  /**
@@ -87,19 +104,36 @@ export declare class ToastComponent extends BaseWidgetDirective<ToastWidget> imp
87
104
  slotHeaderFromContent: ToastHeaderDirective | undefined;
88
105
  /**
89
106
  * Callback called when the alert visibility changed.
107
+ *
108
+ * @defaultValue
109
+ * ```ts
110
+ * () => {}
111
+ * ```
90
112
  */
91
113
  visibleChange: EventEmitter<boolean>;
92
114
  /**
93
115
  * Callback called when the alert is hidden.
116
+ *
117
+ * @defaultValue
118
+ * ```ts
119
+ * () => {}
120
+ * ```
94
121
  */
95
122
  hidden: EventEmitter<void>;
96
123
  /**
97
124
  * Callback called when the alert is shown.
125
+ *
126
+ * @defaultValue
127
+ * ```ts
128
+ * () => {}
129
+ * ```
98
130
  */
99
131
  shown: EventEmitter<void>;
100
132
  readonly defaultSlots: WritableSignal<Partial<ToastProps>>;
101
133
  /**
102
134
  * CSS classes to be applied on the widget main container
135
+ *
136
+ * @defaultValue `''`
103
137
  */
104
138
  className: string | undefined;
105
139
  readonly _widget: import("@agnos-ui/angular-headless").AngularWidget<ToastWidget>;
@@ -1,4 +1,10 @@
1
- import type { WidgetSlotContext, SlotContent, TransitionFn, Widget, Directive } from '@agnos-ui/angular-headless';
1
+ import type { WidgetSlotContext, SlotContent, TransitionFn, Widget, WidgetFactory, Directive } from '@agnos-ui/angular-headless';
2
+ /**
3
+ * Retrieve a shallow copy of the default Toast config
4
+ * @returns the default Toast config
5
+ */
6
+ declare const export_getToastDefaultConfig: () => ToastProps;
7
+ export { export_getToastDefaultConfig as getToastDefaultConfig };
2
8
  export type ToastContext = WidgetSlotContext<ToastWidget>;
3
9
  export interface ToastState {
4
10
  /**
@@ -8,26 +14,38 @@ export interface ToastState {
8
14
  /**
9
15
  * If `true`, alert can be dismissed by the user.
10
16
  * The close button (×) will be displayed and you can be notified of the event with the (close) output.
17
+ *
18
+ * @defaultValue `true`
11
19
  */
12
20
  dismissible: boolean;
13
21
  /**
14
22
  * If `true` the alert is visible to the user
23
+ *
24
+ * @defaultValue `true`
15
25
  */
16
26
  visible: boolean;
17
27
  /**
18
28
  * Accessibility close button label
29
+ *
30
+ * @defaultValue `'Close'`
19
31
  */
20
32
  ariaCloseButtonLabel: string;
21
33
  /**
22
34
  * CSS classes to be applied on the widget main container
35
+ *
36
+ * @defaultValue `''`
23
37
  */
24
38
  className: string;
25
39
  /**
26
40
  * If `true` automatically hides the toast after the delay.
41
+ *
42
+ * @defaultValue `true`
27
43
  */
28
44
  autoHide: boolean;
29
45
  /**
30
46
  * Delay in milliseconds before hiding the toast.
47
+ *
48
+ * @defaultValue `5000`
31
49
  */
32
50
  delay: number;
33
51
  /**
@@ -44,29 +62,48 @@ export interface ToastState {
44
62
  header: SlotContent<ToastContext>;
45
63
  }
46
64
  export interface ToastProps {
65
+ /**
66
+ * The transition function will be executed when the alert is displayed or hidden.
67
+ *
68
+ * Depending on the value of `animatedOnInit`, the animation can be optionally skipped during the showing process.
69
+ *
70
+ * @defaultValue `fadeTransition`
71
+ */
72
+ transition: TransitionFn;
47
73
  /**
48
74
  * Callback called when the alert visibility changed.
75
+ *
76
+ * @defaultValue
77
+ * ```ts
78
+ * () => {}
79
+ * ```
49
80
  */
50
81
  onVisibleChange: (visible: boolean) => void;
51
82
  /**
52
83
  * Callback called when the alert is hidden.
84
+ *
85
+ * @defaultValue
86
+ * ```ts
87
+ * () => {}
88
+ * ```
53
89
  */
54
90
  onHidden: () => void;
55
91
  /**
56
92
  * Callback called when the alert is shown.
57
- */
58
- onShown: () => void;
59
- /**
60
- * The transition function will be executed when the alert is displayed or hidden.
61
93
  *
62
- * Depending on the value of `animatedOnInit`, the animation can be optionally skipped during the showing process.
94
+ * @defaultValue
95
+ * ```ts
96
+ * () => {}
97
+ * ```
63
98
  */
64
- transition: TransitionFn;
99
+ onShown: () => void;
65
100
  /**
66
101
  * If `true`, alert opening will be animated.
67
102
  *
68
103
  * Animation is triggered when the `.open()` function is called
69
104
  * or the visible prop is changed
105
+ *
106
+ * @defaultValue `false`
70
107
  */
71
108
  animatedOnInit: boolean;
72
109
  /**
@@ -74,31 +111,45 @@ export interface ToastProps {
74
111
  *
75
112
  * Animation is triggered when clicked on the close button (×),
76
113
  * via the `.close()` function or the visible prop is changed
114
+ *
115
+ * @defaultValue `true`
77
116
  */
78
117
  animated: boolean;
79
118
  /**
80
119
  * If `true`, alert can be dismissed by the user.
81
120
  * The close button (×) will be displayed and you can be notified of the event with the (close) output.
121
+ *
122
+ * @defaultValue `true`
82
123
  */
83
124
  dismissible: boolean;
84
125
  /**
85
126
  * If `true` the alert is visible to the user
127
+ *
128
+ * @defaultValue `true`
86
129
  */
87
130
  visible: boolean;
88
131
  /**
89
132
  * Accessibility close button label
133
+ *
134
+ * @defaultValue `'Close'`
90
135
  */
91
136
  ariaCloseButtonLabel: string;
92
137
  /**
93
138
  * CSS classes to be applied on the widget main container
139
+ *
140
+ * @defaultValue `''`
94
141
  */
95
142
  className: string;
96
143
  /**
97
144
  * If `true` automatically hides the toast after the delay.
145
+ *
146
+ * @defaultValue `true`
98
147
  */
99
148
  autoHide: boolean;
100
149
  /**
101
150
  * Delay in milliseconds before hiding the toast.
151
+ *
152
+ * @defaultValue `5000`
102
153
  */
103
154
  delay: number;
104
155
  /**
@@ -115,6 +166,13 @@ export interface ToastProps {
115
166
  header: SlotContent<ToastContext>;
116
167
  }
117
168
  export type ToastWidget = Widget<ToastProps, ToastState, ToastApi, object, ToastDirectives>;
169
+ /**
170
+ * Create an ToastWidget with given config props
171
+ * @param config - an optional alert config
172
+ * @returns an ToastWidget
173
+ */
174
+ declare const export_createToast: WidgetFactory<ToastWidget>;
175
+ export { export_createToast as createToast };
118
176
  export interface ToastApi {
119
177
  /**
120
178
  * Triggers alert closing programmatically (same as clicking on the close button (×)).
@@ -2,7 +2,7 @@ import { BaseWidgetDirective, ComponentTemplate, ContentAsSlotDirective, SlotDir
2
2
  import { NgTemplateOutlet } from '@angular/common';
3
3
  import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewChild, inject, } from '@angular/core';
4
4
  import { callWidgetFactory } from '../../config';
5
- import { createAccordion } from './accordion';
5
+ import { createAccordion } from './accordion.gen';
6
6
  import { writable } from '@amadeus-it-group/tansu';
7
7
  import * as i0 from "@angular/core";
8
8
  const _c0 = ["structure"];
@@ -466,12 +466,22 @@ export class AccordionDirective extends BaseWidgetDirective {
466
466
  * An event fired when an item is shown.
467
467
  *
468
468
  * Event payload is the id of the item.
469
+ *
470
+ * @defaultValue
471
+ * ```ts
472
+ * () => {}
473
+ * ```
469
474
  */
470
475
  this.itemShown = new EventEmitter();
471
476
  /**
472
477
  * An event fired when an item is hidden.
473
478
  *
474
479
  * Event payload is the id of the item.
480
+ *
481
+ * @defaultValue
482
+ * ```ts
483
+ * () => {}
484
+ * ```
475
485
  */
476
486
  this.itemHidden = new EventEmitter();
477
487
  this._widget = callWidgetFactory({
@@ -542,4 +552,4 @@ export class AccordionDirective extends BaseWidgetDirective {
542
552
  type: Input,
543
553
  args: ['auItemHeadingTag']
544
554
  }] }); })();
545
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.component.js","sourceRoot":"","sources":["../../../../src/components/accordion/accordion.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent, TransitionFn, WidgetFactory} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tContentAsSlotDirective,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport {NgTemplateOutlet} from '@angular/common';\nimport type {AfterContentChecked, AfterViewInit} from '@angular/core';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tinject,\n} from '@angular/core';\nimport {callWidgetFactory} from '../../config';\nimport type {AccordionItemContext, AccordionItemProps, AccordionItemWidget, AccordionWidget} from './accordion';\nimport {createAccordion} from './accordion';\nimport {writable} from '@amadeus-it-group/tansu';\n\n@Directive({selector: 'ng-template[auAccordionItemBody]', standalone: true})\nexport class AccordionBodyDirective {\n\tpublic templateRef = inject(TemplateRef<AccordionItemContext>);\n\tstatic ngTemplateContextGuard(dir: AccordionBodyDirective, context: unknown): context is AccordionItemContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auAccordionItemHeader]', standalone: true})\nexport class AccordionHeaderDirective {\n\tpublic templateRef = inject(TemplateRef<AccordionItemContext>);\n\tstatic ngTemplateContextGuard(dir: AccordionHeaderDirective, context: unknown): context is AccordionItemContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auAccordionItemStructure]', standalone: true})\nexport class AccordionItemStructureDirective {\n\tpublic templateRef = inject(TemplateRef<AccordionItemContext>);\n\tstatic ngTemplateContextGuard(dir: AccordionItemStructureDirective, context: unknown): context is AccordionItemContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SlotDirective, AccordionHeaderDirective, AccordionBodyDirective, NgTemplateOutlet],\n\ttemplate: `\n\t\t<ng-template #structure let-state=\"state\" let-widget=\"widget\">\n\t\t\t@switch (state.itemHeadingTag) {\n\t\t\t\t@case ('h1') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h1\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@case ('h2') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h2\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@case ('h3') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h3\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@case ('h4') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h4\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@case ('h5') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h5\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@case ('h6') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h6\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@default {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h2\"></ng-container>\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t<ng-template #h1>\n\t\t\t\t<h1 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h1>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template #h2>\n\t\t\t\t<h2 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h2>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template #h3>\n\t\t\t\t<h3 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h3>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template #h4>\n\t\t\t\t<h4 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h4>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template #h5>\n\t\t\t\t<h5 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h5>\n\t\t\t</ng-template>\n\t\t\t<ng-template #h6>\n\t\t\t\t<h6 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h6>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template #button>\n\t\t\t\t<button class=\"accordion-button \" [auUse]=\"widget.directives.buttonDirective\">\n\t\t\t\t\t<ng-template [auSlotProps]=\"{state, widget}\" [auSlot]=\"state.header\"></ng-template>\n\t\t\t\t</button>\n\t\t\t</ng-template>\n\t\t\t@if (state.shouldBeInDOM) {\n\t\t\t\t<div [auUse]=\"widget.directives.bodyContainerDirective\" class=\"accordion-collapse\">\n\t\t\t\t\t<div class=\"accordion-body\" [auUse]=\"widget.directives.bodyDirective\">\n\t\t\t\t\t\t<ng-template [auSlotProps]=\"{state, widget}\" [auSlot]=\"state.children\"></ng-template>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nexport class AccordionItemDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<AccordionItemContext>;\n}\nexport const accordionItemDefaultSlotItemStructure = new ComponentTemplate(AccordionItemDefaultSlotsComponent, 'structure');\n\nconst defaultConfig: Partial<AccordionItemProps> = {\n\tstructure: accordionItemDefaultSlotItemStructure,\n};\n\n@Component({\n\tselector: '[auAccordionItem]',\n\texportAs: 'auAccordionItem',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\thost: {\n\t\tclass: 'accordion-item',\n\t},\n\timports: [SlotDirective, UseDirective, ContentAsSlotDirective],\n\ttemplate: `\n\t\t<ng-template [auContentAsSlot]=\"defaultSlots\">\n\t\t\t<ng-content></ng-content>\n\t\t</ng-template>\n\t\t<ng-template [auSlotProps]=\"{state: state(), widget}\" [auSlot]=\"state().structure\"></ng-template>\n\t`,\n})\nexport class AccordionItemComponent extends BaseWidgetDirective<AccordionItemWidget> implements AfterContentChecked, AfterViewInit {\n\t/**\n\t * Content present in the accordion button inside the accordion header.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\t@Input('auHeader') header: SlotContent<AccordionItemContext>;\n\t@ContentChild(AccordionHeaderDirective, {static: false})\n\tslotHeaderFromContent: AccordionHeaderDirective | undefined;\n\t/**\n\t * Content present in the accordion body.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\t@Input('auChildren') children: SlotContent<AccordionItemContext>;\n\t@ContentChild(AccordionBodyDirective, {static: false})\n\tslotBodyFromContent: AccordionBodyDirective | undefined;\n\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\t@Input('auStructure') structure: SlotContent<AccordionItemContext>;\n\t@ContentChild(AccordionItemStructureDirective, {static: false})\n\tslotStructureFromContent: AccordionItemStructureDirective | undefined;\n\n\t/**\n\t * The id of the accordion-item. It can be used for controlling the accordion-item via the accordion api.\n\t */\n\t@Input('auId') id: string | undefined;\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t */\n\t@Input('auTransition') transition: TransitionFn | undefined;\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t */\n\t@Input('auClassName') className: string | undefined;\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t */\n\t@Input({alias: 'auDestroyOnHide', transform: auBooleanAttribute}) destroyOnHide: boolean | undefined;\n\t/**\n\t * If `true`, the accordion-item will be disabled.\n\t * It will not react to user's clicks, but still will be possible to toggle programmatically.\n\t */\n\t@Input({alias: 'auDisabled', transform: auBooleanAttribute}) disabled: boolean | undefined;\n\n\t/**\n\t * If `true`, the accordion-item will be visible (expanded). Otherwise, it will be hidden (collapsed).\n\t */\n\t@Input({alias: 'auVisible', transform: auBooleanAttribute}) visible: boolean | undefined;\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t */\n\t@Input({alias: 'auAnimated', transform: auBooleanAttribute}) animated: boolean | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\t@Input('auHeaderClassName') headerClassName: string | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item collapse DOM element.\n\t */\n\t@Input('auButtonClassName') buttonClassName: string | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\t@Input('auBodyContainerClassName') bodyContainerClassName: string | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\t@Input('auBodyClassName') bodyClassName: string | undefined;\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\t@Input('auHeadingTag') headingTag: string | undefined;\n\t/**\n\t * An event fired when an item is shown.\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\t/**\n\t * An event fired when an item is hidden.\n\t */\n\t@Output('auHidden') hidden = new EventEmitter<void>();\n\t/**\n\t * An event fired when the `visible` value changes.\n\t *\n\t * Event payload is the new value of visible.\n\t */\n\t@Output('auVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n\treadonly ad = inject(AccordionDirective);\n\treadonly defaultSlots = writable(defaultConfig);\n\n\treadonly _widget = callWidgetFactory<AccordionItemWidget>({\n\t\tfactory: ((arg) => this.ad.api.registerItem(arg)) as WidgetFactory<AccordionItemWidget>,\n\t\tdefaultConfig: this.defaultSlots,\n\t\tevents: {\n\t\t\tonVisibleChange: (visible) => this.visibleChange.emit(visible),\n\t\t\tonHidden: () => this.hidden.emit(),\n\t\t\tonShown: () => this.shown.emit(),\n\t\t},\n\t\tafterInit: () => {\n\t\t\tuseDirectiveForHost(this._widget.directives.itemDirective);\n\t\t},\n\t});\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\theader: this.slotHeaderFromContent?.templateRef,\n\t\t\tchildren: this.slotBodyFromContent?.templateRef,\n\t\t});\n\t}\n\n\tngAfterViewInit() {\n\t\tqueueMicrotask(() => this.api.initDone());\n\t}\n}\n\n@Directive({\n\tselector: '[auAccordion]',\n\texportAs: 'auAccordion',\n\tstandalone: true,\n\thost: {\n\t\tclass: 'accordion',\n\t},\n})\nexport class AccordionDirective extends BaseWidgetDirective<AccordionWidget> {\n\t/**\n\t * If `true`, only one accordion-item at the time can stay open.\n\t */\n\t@Input({alias: 'auCloseOthers', transform: auBooleanAttribute}) closeOthers: boolean | undefined;\n\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t/**\n\t * An event fired when an item is shown.\n\t *\n\t * Event payload is the id of the item.\n\t */\n\t@Output('auItemShown') itemShown: EventEmitter<string> = new EventEmitter<string>();\n\t/**\n\t * An event fired when an item is hidden.\n\t *\n\t * Event payload is the id of the item.\n\t */\n\t@Output('auItemHidden') itemHidden: EventEmitter<string> = new EventEmitter<string>();\n\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t */\n\t@Input({alias: 'auItemDestroyOnHide', transform: auBooleanAttribute}) itemDestroyOnHide: boolean | undefined;\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t */\n\t@Input({alias: 'auItemAnimated', transform: auBooleanAttribute}) itemAnimated: boolean | undefined;\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t */\n\t@Input('auItemTransition') itemTransition: TransitionFn | undefined;\n\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\t@Input('auItemStructure') itemStructure: SlotContent<AccordionItemContext>;\n\t/**\n\t * CSS classes to add on the accordion-item DOM element.\n\t */\n\t@Input('auItemClassName') itemClassName: string | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\t@Input('auItemHeaderClassName') itemHeaderClassName: string | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item toggle button DOM element.\n\t */\n\t@Input('auItemButtonClassName') itemButtonClassName: string | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\t@Input('auItemBodyContainerClassName') itemBodyContainerClassName: string | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\t@Input('auItemBodyClassName') itemBodyClassName: string | undefined;\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\t@Input('auItemHeadingTag') itemHeadingTag: string | undefined;\n\n\treadonly _widget = callWidgetFactory({\n\t\tfactory: createAccordion,\n\t\twidgetName: 'accordion',\n\t\tevents: {\n\t\t\tonItemShown: (id) => this.itemShown.emit(id),\n\t\t\tonItemHidden: (id) => this.itemHidden.emit(id),\n\t\t},\n\t\tafterInit: () => {\n\t\t\tuseDirectiveForHost(this._widget.directives.accordionDirective);\n\t\t},\n\t});\n}\n"]}
555
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.component.js","sourceRoot":"","sources":["../../../../src/components/accordion/accordion.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent, TransitionFn, WidgetFactory} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tContentAsSlotDirective,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport {NgTemplateOutlet} from '@angular/common';\nimport type {AfterContentChecked, AfterViewInit} from '@angular/core';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tinject,\n} from '@angular/core';\nimport {callWidgetFactory} from '../../config';\nimport type {AccordionItemContext, AccordionItemProps, AccordionItemWidget, AccordionWidget} from './accordion.gen';\nimport {createAccordion} from './accordion.gen';\nimport {writable} from '@amadeus-it-group/tansu';\n\n@Directive({selector: 'ng-template[auAccordionItemBody]', standalone: true})\nexport class AccordionBodyDirective {\n\tpublic templateRef = inject(TemplateRef<AccordionItemContext>);\n\tstatic ngTemplateContextGuard(dir: AccordionBodyDirective, context: unknown): context is AccordionItemContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auAccordionItemHeader]', standalone: true})\nexport class AccordionHeaderDirective {\n\tpublic templateRef = inject(TemplateRef<AccordionItemContext>);\n\tstatic ngTemplateContextGuard(dir: AccordionHeaderDirective, context: unknown): context is AccordionItemContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auAccordionItemStructure]', standalone: true})\nexport class AccordionItemStructureDirective {\n\tpublic templateRef = inject(TemplateRef<AccordionItemContext>);\n\tstatic ngTemplateContextGuard(dir: AccordionItemStructureDirective, context: unknown): context is AccordionItemContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SlotDirective, AccordionHeaderDirective, AccordionBodyDirective, NgTemplateOutlet],\n\ttemplate: `\n\t\t<ng-template #structure let-state=\"state\" let-widget=\"widget\">\n\t\t\t@switch (state.itemHeadingTag) {\n\t\t\t\t@case ('h1') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h1\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@case ('h2') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h2\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@case ('h3') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h3\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@case ('h4') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h4\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@case ('h5') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h5\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@case ('h6') {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h6\"></ng-container>\n\t\t\t\t}\n\t\t\t\t@default {\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"h2\"></ng-container>\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t<ng-template #h1>\n\t\t\t\t<h1 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h1>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template #h2>\n\t\t\t\t<h2 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h2>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template #h3>\n\t\t\t\t<h3 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h3>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template #h4>\n\t\t\t\t<h4 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h4>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template #h5>\n\t\t\t\t<h5 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h5>\n\t\t\t</ng-template>\n\t\t\t<ng-template #h6>\n\t\t\t\t<h6 class=\"accordion-header\" [auUse]=\"widget.directives.headerDirective\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"button\"></ng-template>\n\t\t\t\t</h6>\n\t\t\t</ng-template>\n\n\t\t\t<ng-template #button>\n\t\t\t\t<button class=\"accordion-button \" [auUse]=\"widget.directives.buttonDirective\">\n\t\t\t\t\t<ng-template [auSlotProps]=\"{state, widget}\" [auSlot]=\"state.header\"></ng-template>\n\t\t\t\t</button>\n\t\t\t</ng-template>\n\t\t\t@if (state.shouldBeInDOM) {\n\t\t\t\t<div [auUse]=\"widget.directives.bodyContainerDirective\" class=\"accordion-collapse\">\n\t\t\t\t\t<div class=\"accordion-body\" [auUse]=\"widget.directives.bodyDirective\">\n\t\t\t\t\t\t<ng-template [auSlotProps]=\"{state, widget}\" [auSlot]=\"state.children\"></ng-template>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nexport class AccordionItemDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<AccordionItemContext>;\n}\nexport const accordionItemDefaultSlotItemStructure = new ComponentTemplate(AccordionItemDefaultSlotsComponent, 'structure');\n\nconst defaultConfig: Partial<AccordionItemProps> = {\n\tstructure: accordionItemDefaultSlotItemStructure,\n};\n\n@Component({\n\tselector: '[auAccordionItem]',\n\texportAs: 'auAccordionItem',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\thost: {\n\t\tclass: 'accordion-item',\n\t},\n\timports: [SlotDirective, UseDirective, ContentAsSlotDirective],\n\ttemplate: `\n\t\t<ng-template [auContentAsSlot]=\"defaultSlots\">\n\t\t\t<ng-content></ng-content>\n\t\t</ng-template>\n\t\t<ng-template [auSlotProps]=\"{state: state(), widget}\" [auSlot]=\"state().structure\"></ng-template>\n\t`,\n})\nexport class AccordionItemComponent extends BaseWidgetDirective<AccordionItemWidget> implements AfterContentChecked, AfterViewInit {\n\t/**\n\t * Content present in the accordion button inside the accordion header.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\t@Input('auHeader') header: SlotContent<AccordionItemContext>;\n\t@ContentChild(AccordionHeaderDirective, {static: false})\n\tslotHeaderFromContent: AccordionHeaderDirective | undefined;\n\t/**\n\t * Content present in the accordion body.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\t@Input('auChildren') children: SlotContent<AccordionItemContext>;\n\t@ContentChild(AccordionBodyDirective, {static: false})\n\tslotBodyFromContent: AccordionBodyDirective | undefined;\n\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\t@Input('auStructure') structure: SlotContent<AccordionItemContext>;\n\t@ContentChild(AccordionItemStructureDirective, {static: false})\n\tslotStructureFromContent: AccordionItemStructureDirective | undefined;\n\n\t/**\n\t * The id of the accordion-item. It can be used for controlling the accordion-item via the accordion api.\n\t */\n\t@Input('auId') id: string | undefined;\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t */\n\t@Input('auTransition') transition: TransitionFn | 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\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t */\n\t@Input({alias: 'auDestroyOnHide', transform: auBooleanAttribute}) destroyOnHide: boolean | undefined;\n\t/**\n\t * If `true`, the accordion-item will be disabled.\n\t * It will not react to user's clicks, but still will be possible to toggle programmatically.\n\t */\n\t@Input({alias: 'auDisabled', transform: auBooleanAttribute}) disabled: boolean | undefined;\n\n\t/**\n\t * If `true`, the accordion-item will be visible (expanded). Otherwise, it will be hidden (collapsed).\n\t */\n\t@Input({alias: 'auVisible', transform: auBooleanAttribute}) visible: boolean | undefined;\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t */\n\t@Input({alias: 'auAnimated', transform: auBooleanAttribute}) animated: boolean | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\t@Input('auHeaderClassName') headerClassName: string | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item collapse DOM element.\n\t */\n\t@Input('auButtonClassName') buttonClassName: string | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\t@Input('auBodyContainerClassName') bodyContainerClassName: string | undefined;\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\t@Input('auBodyClassName') bodyClassName: string | undefined;\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\t@Input('auHeadingTag') headingTag: string | undefined;\n\t/**\n\t * An event fired when an item is shown.\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\t/**\n\t * An event fired when an item is hidden.\n\t */\n\t@Output('auHidden') hidden = new EventEmitter<void>();\n\t/**\n\t * An event fired when the `visible` value changes.\n\t *\n\t * Event payload is the new value of visible.\n\t */\n\t@Output('auVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n\treadonly ad = inject(AccordionDirective);\n\treadonly defaultSlots = writable(defaultConfig);\n\n\treadonly _widget = callWidgetFactory<AccordionItemWidget>({\n\t\tfactory: ((arg) => this.ad.api.registerItem(arg)) as WidgetFactory<AccordionItemWidget>,\n\t\tdefaultConfig: this.defaultSlots,\n\t\tevents: {\n\t\t\tonVisibleChange: (visible) => this.visibleChange.emit(visible),\n\t\t\tonHidden: () => this.hidden.emit(),\n\t\t\tonShown: () => this.shown.emit(),\n\t\t},\n\t\tafterInit: () => {\n\t\t\tuseDirectiveForHost(this._widget.directives.itemDirective);\n\t\t},\n\t});\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\theader: this.slotHeaderFromContent?.templateRef,\n\t\t\tchildren: this.slotBodyFromContent?.templateRef,\n\t\t});\n\t}\n\n\tngAfterViewInit() {\n\t\tqueueMicrotask(() => this.api.initDone());\n\t}\n}\n\n@Directive({\n\tselector: '[auAccordion]',\n\texportAs: 'auAccordion',\n\tstandalone: true,\n\thost: {\n\t\tclass: 'accordion',\n\t},\n})\nexport class AccordionDirective extends BaseWidgetDirective<AccordionWidget> {\n\t/**\n\t * If `true`, only one accordion-item at the time can stay open.\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auCloseOthers', transform: auBooleanAttribute}) closeOthers: boolean | 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 * An event fired when an item is shown.\n\t *\n\t * Event payload is the id of the item.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auItemShown') itemShown: EventEmitter<string> = new EventEmitter<string>();\n\n\t/**\n\t * An event fired when an item is hidden.\n\t *\n\t * Event payload is the id of the item.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auItemHidden') itemHidden: EventEmitter<string> = new EventEmitter<string>();\n\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auItemDestroyOnHide', transform: auBooleanAttribute}) itemDestroyOnHide: boolean | undefined;\n\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auItemAnimated', transform: auBooleanAttribute}) itemAnimated: boolean | undefined;\n\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * collapseVerticalTransition\n\t * ```\n\t */\n\t@Input('auItemTransition') itemTransition: TransitionFn | undefined;\n\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\t@Input('auItemStructure') itemStructure: SlotContent<AccordionItemContext>;\n\n\t/**\n\t * CSS classes to add on the accordion-item DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auItemClassName') itemClassName: string | undefined;\n\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auItemHeaderClassName') itemHeaderClassName: string | undefined;\n\n\t/**\n\t * CSS classes to add on the accordion-item toggle button DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auItemButtonClassName') itemButtonClassName: string | undefined;\n\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auItemBodyContainerClassName') itemBodyContainerClassName: string | undefined;\n\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auItemBodyClassName') itemBodyClassName: string | undefined;\n\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auItemHeadingTag') itemHeadingTag: string | undefined;\n\n\treadonly _widget = callWidgetFactory({\n\t\tfactory: createAccordion,\n\t\twidgetName: 'accordion',\n\t\tevents: {\n\t\t\tonItemShown: (id) => this.itemShown.emit(id),\n\t\t\tonItemHidden: (id) => this.itemHidden.emit(id),\n\t\t},\n\t\tafterInit: () => {\n\t\t\tuseDirectiveForHost(this._widget.directives.accordionDirective);\n\t\t},\n\t});\n}\n"]}
@@ -1,2 +1,33 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.gen.js","sourceRoot":"","sources":["../../../../src/components/accordion/accordion.gen.ts"],"names":[],"mappings":"","sourcesContent":["import type {WidgetSlotContext, SlotContent, TransitionFn, Widget, PropsConfig, Directive} from '@agnos-ui/angular-headless';\n\nexport type AccordionItemContext = WidgetSlotContext<AccordionItemWidget>;\n\nexport interface AccordionState {\n\t/**\n\t * Array containing all the accordion-items contained in the accordion.\n\t */\n\titemWidgets: AccordionItemWidget[];\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t */\n\tclassName: string;\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t * \n\t * It is a prop of the accordion-item.\n\t */\n\titemStructure: SlotContent<AccordionItemContext>;\n}\n\nexport interface AccordionProps {\n\t/**\n\t * If `true`, only one accordion-item at the time can stay open.\n\t */\n\tcloseOthers: boolean;\n\t/**\n\t * An event fired when an item is shown.\n\t * \n\t * Event payload is the id of the item.\n\t */\n\tonItemShown: (itemId: string) => void;\n\t/**\n\t * An event fired when an item is hidden.\n\t * \n\t * Event payload is the id of the item.\n\t */\n\tonItemHidden: (itemId: string) => void;\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t */\n\titemDestroyOnHide: boolean;\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t */\n\titemAnimated: boolean;\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t */\n\titemTransition: TransitionFn;\n\t/**\n\t * CSS classes to add on the accordion-item DOM element.\n\t */\n\titemClassName: string;\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\titemHeaderClassName: string;\n\t/**\n\t * CSS classes to add on the accordion-item toggle button DOM element.\n\t */\n\titemButtonClassName: string;\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\titemBodyContainerClassName: string;\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\titemBodyClassName: string;\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\titemHeadingTag: string;\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t */\n\tclassName: string;\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t * \n\t * It is a prop of the accordion-item.\n\t */\n\titemStructure: SlotContent<AccordionItemContext>;\n}\n\nexport type AccordionWidget = Widget<AccordionProps, AccordionState, AccordionApi, object, AccordionDirectives>;\n\nexport interface AccordionItemState {\n\t/**\n\t * If `true` the content of the accordion-item collapse should be in DOM. Its value depends on the\n\t * value of the `visible` and `destroyOnHide`.\n\t */\n\tshouldBeInDOM: boolean;\n\t/**\n\t * If `true`, the accordion-item will be visible (expanded). Otherwise, it will be hidden (collapsed).\n\t */\n\tvisible: boolean;\n\t/**\n\t * If `true`, the accordion-item will be disabled.\n\t * It will not react to user's clicks, but still will be possible to toggle programmatically.\n\t */\n\tdisabled: boolean;\n\t/**\n\t * The id of the accordion-item. It can be used for controlling the accordion-item via the accordion api.\n\t */\n\tid: string;\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\theaderClassName: string;\n\t/**\n\t * CSS classes to add on the accordion-item collapse DOM element.\n\t */\n\tbuttonClassName: string;\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\tbodyContainerClassName: string;\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\tbodyClassName: string;\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\theadingTag: string;\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t */\n\tclassName: string;\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t * \n\t * It is a prop of the accordion-item.\n\t */\n\tstructure: SlotContent<AccordionItemContext>;\n\t/**\n\t * Content present in the accordion body.\n\t * \n\t * It is a prop of the accordion-item.\n\t */\n\tchildren: SlotContent<AccordionItemContext>;\n\t/**\n\t * Content present in the accordion button inside the accordion header.\n\t * \n\t * It is a prop of the accordion-item.\n\t */\n\theader: SlotContent<AccordionItemContext>;\n}\n\nexport interface AccordionItemProps {\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t */\n\tanimated: boolean;\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t */\n\ttransition: TransitionFn;\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t */\n\tdestroyOnHide: boolean;\n\t/**\n\t * An event fired when an item is shown.\n\t */\n\tonShown: () => void;\n\t/**\n\t * An event fired when an item is hidden.\n\t */\n\tonHidden: () => void;\n\t/**\n\t * An event fired when the `visible` value changes.\n\t * \n\t * Event payload is the new value of visible.\n\t */\n\tonVisibleChange: (visible: boolean) => void;\n\t/**\n\t * If `true`, the accordion-item will be visible (expanded). Otherwise, it will be hidden (collapsed).\n\t */\n\tvisible: boolean;\n\t/**\n\t * If `true`, the accordion-item will be disabled.\n\t * It will not react to user's clicks, but still will be possible to toggle programmatically.\n\t */\n\tdisabled: boolean;\n\t/**\n\t * The id of the accordion-item. It can be used for controlling the accordion-item via the accordion api.\n\t */\n\tid: string;\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\theaderClassName: string;\n\t/**\n\t * CSS classes to add on the accordion-item collapse DOM element.\n\t */\n\tbuttonClassName: string;\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\tbodyContainerClassName: string;\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\tbodyClassName: string;\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\theadingTag: string;\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t */\n\tclassName: string;\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t * \n\t * It is a prop of the accordion-item.\n\t */\n\tstructure: SlotContent<AccordionItemContext>;\n\t/**\n\t * Content present in the accordion body.\n\t * \n\t * It is a prop of the accordion-item.\n\t */\n\tchildren: SlotContent<AccordionItemContext>;\n\t/**\n\t * Content present in the accordion button inside the accordion header.\n\t * \n\t * It is a prop of the accordion-item.\n\t */\n\theader: SlotContent<AccordionItemContext>;\n}\n\nexport type AccordionItemWidget = Widget<AccordionItemProps, AccordionItemState, AccordionItemApi, AccordionItemActions, AccordionItemDirectives>;\n\nexport interface AccordionApi {\n\t/**\n\t * Given the itemId, will expand the corresponding accordion-item.\n\t * \n\t * If the itemId is not valid, nothing will happen.\n\t */\n\texpand(itemId: string): void;\n\t/**\n\t * Given the itemId, will collapse the corresponding accordion-item.\n\t * \n\t * If the itemId is not valid, nothing will happen.\n\t */\n\tcollapse(itemId: string): void;\n\t/**\n\t * Given the itemId, will toggle the corresponding accordion-item.\n\t * \n\t * If the itemId is not valid, nothing will happen.\n\t */\n\ttoggle(itemId: string): void;\n\t/**\n\t * It will expand all the items in the accordion.\n\t * \n\t * If `closeOthers` is `true` it will expand only the last accordion-item.\n\t */\n\texpandAll(): void;\n\t/**\n\t * It will collapse all the accordion-items in the accordion.\n\t */\n\tcollapseAll(): void;\n\t/**\n\t * Creates a new accordionItem.\n\t */\n\tregisterItem(itemConfig?: PropsConfig<AccordionItemProps>): AccordionItemWidget;\n}\n\nexport interface AccordionDirectives {\n\t/**\n\t * Directive to put on the accordion DOM element\n\t */\n\taccordionDirective: Directive;\n}\n\nexport interface AccordionItemActions {\n\t/**\n\t * Action to be called when the user clicks on the accordion-item button. If the accordion-item is disabled nothing will happen.\n\t */\n\tclick(): void;\n}\n\nexport interface AccordionItemApi {\n\t/**\n\t * It will collapse the accordion-item.\n\t */\n\tcollapse(): void;\n\t/**\n\t * It will expand the accordion-item.\n\t */\n\texpand(): void;\n\t/**\n\t * It will toggle the accordion-item.\n\t */\n\ttoggle(): void;\n\t/**\n\t * Method to be called after the initialization to allow animations.\n\t */\n\tinitDone(): void;\n}\n\nexport interface AccordionItemDirectives {\n\t/**\n\t * Directive to use in special cases, if the accordion header does not use a button element to control the collapsing.\n\t */\n\ttoggleDirective: Directive;\n\t/**\n\t * Directive to put on the button element that will control the collapsing of the accordion-item.\n\t */\n\tbuttonDirective: Directive;\n\t/**\n\t * Directive to put on the accordion-item header that will contain the button element.\n\t */\n\theaderDirective: Directive;\n\t/**\n\t * Directive to put on the accordion-item body.\n\t */\n\tbodyDirective: Directive;\n\t/**\n\t * Directive to apply the itemTransition\n\t */\n\ttransitionDirective: Directive;\n\t/**\n\t * Directive to apply aria attributes to the expanded body panel\n\t */\n\tbodyContainerAttrsDirective: Directive;\n\t/**\n\t * Directive to be put on the accordion-item body container. It will handle the animation.\n\t */\n\tbodyContainerDirective: Directive;\n\t/**\n\t * Directive to be put on the accordion-item. It will handle adding the accordion-item to the accordion.\n\t */\n\titemDirective: Directive;\n}\n\n"]}
1
+ import { getAccordionDefaultConfig, createAccordionItem, createAccordion, factoryCreateAccordion } from '@agnos-ui/core-bootstrap/components/accordion';
2
+ /**
3
+ * Retrieve a shallow copy of the default accordion config
4
+ * @returns the default accordion config
5
+ */
6
+ const export_getAccordionDefaultConfig = getAccordionDefaultConfig;
7
+ export { export_getAccordionDefaultConfig as getAccordionDefaultConfig };
8
+ /**
9
+ * Create an AccordionItemWidget with given config props
10
+ * @param config - an optional AccordionItem config
11
+ * @returns an AccordionItemWidget
12
+ */
13
+ const export_createAccordionItem = createAccordionItem;
14
+ export { export_createAccordionItem as createAccordionItem };
15
+ /**
16
+ * Create an AccordionWidget with given config props
17
+ * @param config - an optional accordion config
18
+ * @returns an AccordionWidget
19
+ */
20
+ const export_createAccordion = createAccordion;
21
+ export { export_createAccordion as createAccordion };
22
+ /**
23
+ * Create an accordion WidgetFactory based on a item factory and the list of item props that should inherit from the parent accordion
24
+ *
25
+ * @param itemFactory - the item factory
26
+ * @param accordionItemProps - the list of item props
27
+ * @param accordionConfig - the default accordion config
28
+ * @param accordionValidator - the validator of props
29
+ * @returns the accordion widget factory
30
+ */
31
+ const export_factoryCreateAccordion = factoryCreateAccordion;
32
+ export { export_factoryCreateAccordion as factoryCreateAccordion };
33
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.gen.js","sourceRoot":"","sources":["../../../../src/components/accordion/accordion.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,yBAAyB,EAAE,mBAAmB,EAAE,eAAe,EAAE,sBAAsB,EAAC,MAAM,+CAA+C,CAAC;AAKtJ;;;GAGG;AACH,MAAM,gCAAgC,GAAyB,yBAAgC,CAAC;AAChG,OAAO,EAAC,gCAAgC,IAAI,yBAAyB,EAAC,CAAC;AA6VvE;;;;GAIG;AACH,MAAM,0BAA0B,GAAuC,mBAA0B,CAAC;AAClG,OAAO,EAAC,0BAA0B,IAAI,mBAAmB,EAAC,CAAC;AAI3D;;;;GAIG;AACH,MAAM,sBAAsB,GAAmC,eAAsB,CAAC;AACtF,OAAO,EAAC,sBAAsB,IAAI,eAAe,EAAC,CAAC;AAInD;;;;;;;;GAQG;AACH,MAAM,6BAA6B,GAAgN,sBAA6B,CAAC;AACjR,OAAO,EAAC,6BAA6B,IAAI,sBAAsB,EAAC,CAAC","sourcesContent":["import {getAccordionDefaultConfig, createAccordionItem, createAccordion, factoryCreateAccordion} from '@agnos-ui/core-bootstrap/components/accordion';\nimport type {WidgetSlotContext, SlotContent, TransitionFn, Widget, WidgetFactory, ConfigValidator, PropsConfig, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default accordion config\n * @returns the default accordion config\n */\nconst export_getAccordionDefaultConfig: () => AccordionProps = getAccordionDefaultConfig as any;\nexport {export_getAccordionDefaultConfig as getAccordionDefaultConfig};\n\n\n\nexport type AccordionItemContext = WidgetSlotContext<AccordionItemWidget>;\n\nexport interface AccordionState {\n\t\n\t/**\n\t * Array containing all the accordion-items contained in the accordion.\n\t */\n\titemWidgets: AccordionItemWidget[];\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 * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\titemStructure: SlotContent<AccordionItemContext>;\n}\n\nexport interface AccordionProps {\n\t\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * collapseVerticalTransition\n\t * ```\n\t */\n\titemTransition: TransitionFn;\n\t\n\t/**\n\t * If `true`, only one accordion-item at the time can stay open.\n\t *\n\t * @defaultValue `false`\n\t */\n\tcloseOthers: boolean;\n\t\n\t/**\n\t * An event fired when an item is shown.\n\t *\n\t * Event payload is the id of the item.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonItemShown: (itemId: string) => void;\n\t\n\t/**\n\t * An event fired when an item is hidden.\n\t *\n\t * Event payload is the id of the item.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonItemHidden: (itemId: string) => void;\n\t\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t *\n\t * @defaultValue `true`\n\t */\n\titemDestroyOnHide: boolean;\n\t\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t *\n\t * @defaultValue `true`\n\t */\n\titemAnimated: boolean;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemHeaderClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item toggle button DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemButtonClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemBodyContainerClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemBodyClassName: string;\n\t\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemHeadingTag: 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 * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\titemStructure: SlotContent<AccordionItemContext>;\n}\n\n\n\nexport type AccordionWidget = Widget<AccordionProps, AccordionState, AccordionApi, object, AccordionDirectives>;\n\nexport interface AccordionItemState {\n\t\n\t/**\n\t * If `true` the content of the accordion-item collapse should be in DOM. Its value depends on the\n\t * value of the `visible` and `destroyOnHide`.\n\t */\n\tshouldBeInDOM: boolean;\n\t\n\t/**\n\t * If `true`, the accordion-item will be visible (expanded). Otherwise, it will be hidden (collapsed).\n\t */\n\tvisible: boolean;\n\t\n\t/**\n\t * If `true`, the accordion-item will be disabled.\n\t * It will not react to user's clicks, but still will be possible to toggle programmatically.\n\t */\n\tdisabled: boolean;\n\t\n\t/**\n\t * The id of the accordion-item. It can be used for controlling the accordion-item via the accordion api.\n\t */\n\tid: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\theaderClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item collapse DOM element.\n\t */\n\tbuttonClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\tbodyContainerClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\tbodyClassName: string;\n\t\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\theadingTag: 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 * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tstructure: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion body.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tchildren: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion button inside the accordion header.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\theader: SlotContent<AccordionItemContext>;\n}\n\nexport interface AccordionItemProps {\n\t\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t */\n\tanimated: boolean;\n\t\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t */\n\ttransition: TransitionFn;\n\t\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t */\n\tdestroyOnHide: boolean;\n\t\n\t/**\n\t * An event fired when an item is shown.\n\t */\n\tonShown: () => void;\n\t\n\t/**\n\t * An event fired when an item is hidden.\n\t */\n\tonHidden: () => void;\n\t\n\t/**\n\t * An event fired when the `visible` value changes.\n\t *\n\t * Event payload is the new value of visible.\n\t */\n\tonVisibleChange: (visible: boolean) => void;\n\t\n\t/**\n\t * If `true`, the accordion-item will be visible (expanded). Otherwise, it will be hidden (collapsed).\n\t */\n\tvisible: boolean;\n\t\n\t/**\n\t * If `true`, the accordion-item will be disabled.\n\t * It will not react to user's clicks, but still will be possible to toggle programmatically.\n\t */\n\tdisabled: boolean;\n\t\n\t/**\n\t * The id of the accordion-item. It can be used for controlling the accordion-item via the accordion api.\n\t */\n\tid: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\theaderClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item collapse DOM element.\n\t */\n\tbuttonClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\tbodyContainerClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\tbodyClassName: string;\n\t\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\theadingTag: 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 * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tstructure: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion body.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tchildren: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion button inside the accordion header.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\theader: SlotContent<AccordionItemContext>;\n}\n\n\n\nexport type AccordionItemWidget = Widget<AccordionItemProps, AccordionItemState, AccordionItemApi, AccordionItemActions, AccordionItemDirectives>;\n\n\n\n/**\n * Create an AccordionItemWidget with given config props\n * @param config - an optional AccordionItem config\n * @returns an AccordionItemWidget\n */\nconst export_createAccordionItem: WidgetFactory<AccordionItemWidget> = createAccordionItem as any;\nexport {export_createAccordionItem as createAccordionItem};\n\n\n\n/**\n * Create an AccordionWidget with given config props\n * @param config - an optional accordion config\n * @returns an AccordionWidget\n */\nconst export_createAccordion: WidgetFactory<AccordionWidget> = createAccordion as any;\nexport {export_createAccordion as createAccordion};\n\n\n\n/**\n * Create an accordion WidgetFactory based on a item factory and the list of item props that should inherit from the parent accordion\n *\n * @param itemFactory - the item factory\n * @param accordionItemProps - the list of item props\n * @param accordionConfig - the default accordion config\n * @param accordionValidator - the validator of props\n * @returns the accordion widget factory\n */\nconst export_factoryCreateAccordion: (itemFactory?: WidgetFactory<AccordionItemWidget>, accordionItemProps?: string[], accordionConfig?: AccordionProps, accordionValidator?: ConfigValidator<AccordionProps>) => WidgetFactory<AccordionWidget> = factoryCreateAccordion as any;\nexport {export_factoryCreateAccordion as factoryCreateAccordion};\n\nexport interface AccordionApi {\n\t\n\t/**\n\t * Given the itemId, will expand the corresponding accordion-item.\n\t *\n\t * If the itemId is not valid, nothing will happen.\n\t */\n\texpand(itemId: string): void;\n\t\n\t/**\n\t * Given the itemId, will collapse the corresponding accordion-item.\n\t *\n\t * If the itemId is not valid, nothing will happen.\n\t */\n\tcollapse(itemId: string): void;\n\t\n\t/**\n\t * Given the itemId, will toggle the corresponding accordion-item.\n\t *\n\t * If the itemId is not valid, nothing will happen.\n\t */\n\ttoggle(itemId: string): void;\n\t\n\t/**\n\t * It will expand all the items in the accordion.\n\t *\n\t * If `closeOthers` is `true` it will expand only the last accordion-item.\n\t */\n\texpandAll(): void;\n\t\n\t/**\n\t * It will collapse all the accordion-items in the accordion.\n\t */\n\tcollapseAll(): void;\n\t\n\t/**\n\t * Creates a new accordionItem.\n\t */\n\tregisterItem(itemConfig?: PropsConfig<AccordionItemProps>): AccordionItemWidget;\n}\n\nexport interface AccordionDirectives {\n\t\n\t/**\n\t * Directive to put on the accordion DOM element\n\t */\n\taccordionDirective: Directive;\n}\n\nexport interface AccordionItemActions {\n\t\n\t/**\n\t * Action to be called when the user clicks on the accordion-item button. If the accordion-item is disabled nothing will happen.\n\t */\n\tclick(): void;\n}\n\nexport interface AccordionItemApi {\n\t\n\t/**\n\t * It will collapse the accordion-item.\n\t */\n\tcollapse(): void;\n\t\n\n\t/**\n\t * It will expand the accordion-item.\n\t */\n\texpand(): void;\n\t\n\t/**\n\t * It will toggle the accordion-item.\n\t */\n\ttoggle(): void;\n\t\n\t/**\n\t * Method to be called after the initialization to allow animations.\n\t */\n\tinitDone(): void;\n}\n\nexport interface AccordionItemDirectives {\n\t\n\t/**\n\t * Directive to use in special cases, if the accordion header does not use a button element to control the collapsing.\n\t */\n\ttoggleDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the button element that will control the collapsing of the accordion-item.\n\t */\n\tbuttonDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the accordion-item header that will contain the button element.\n\t */\n\theaderDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the accordion-item body.\n\t */\n\tbodyDirective: Directive;\n\t\n\t/**\n\t * Directive to apply the itemTransition\n\t */\n\ttransitionDirective: Directive;\n\t\n\t/**\n\t * Directive to apply aria attributes to the expanded body panel\n\t */\n\tbodyContainerAttrsDirective: Directive;\n\t\n\t/**\n\t * Directive to be put on the accordion-item body container. It will handle the animation.\n\t */\n\tbodyContainerDirective: Directive;\n\t\n\t/**\n\t * Directive to be put on the accordion-item. It will handle adding the accordion-item to the accordion.\n\t */\n\titemDirective: Directive;\n}\n\n"]}
@@ -1,3 +1,3 @@
1
- export * from './accordion';
2
1
  export * from './accordion.component';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9hY2NvcmRpb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWNjb3JkaW9uJztcbmV4cG9ydCAqIGZyb20gJy4vYWNjb3JkaW9uLmNvbXBvbmVudCc7XG4iXX0=
2
+ export * from './accordion.gen';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9hY2NvcmRpb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY2NvcmRpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vYWNjb3JkaW9uLmdlbic7XG4iXX0=