@agnos-ui/angular-bootstrap 0.4.4 → 0.5.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
@@ -12,4 +12,4 @@ export { export_getSliderDefaultConfig as getSliderDefaultConfig };
12
12
  */
13
13
  const export_createSlider = createSlider;
14
14
  export { export_createSlider as createSlider };
15
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.gen.js","sourceRoot":"","sources":["../../../../src/components/slider/slider.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;AAmVjE;;;;GAIG;AAEH,MAAM,mBAAmB,GAAgC,YAAmB,CAAC;AAC7E,OAAO,EAAC,mBAAmB,IAAI,YAAY,EAAC,CAAC","sourcesContent":["import {getSliderDefaultConfig, createSlider} from '@agnos-ui/core-bootstrap/components/slider';\nimport type {WidgetSlotContext, SlotContent, Widget, WidgetFactory, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default Slider config\n * @returns the default Slider config\n */\nconst export_getSliderDefaultConfig: () => SliderProps = getSliderDefaultConfig as any;\nexport {export_getSliderDefaultConfig as getSliderDefaultConfig};\n\n\n\nexport type SliderContext = WidgetSlotContext<SliderWidget>;\n\n\nexport type SliderSlotLabelContext = SliderContext & {value: number};\n\n\nexport type SliderSlotHandleContext = SliderContext & {item: SliderHandle};\n\nexport interface SliderState {\n\t\n\t/**\n\t * Sorted slider values\n\t */\n\tsortedValues: number[];\n\t\n\n\t/**\n\t * Combined label left offset in %\n\t */\n\tcombinedLabelPositionLeft: number;\n\t\n\n\t/**\n\t * Combined label top offset in %\n\t */\n\tcombinedLabelPositionTop: number;\n\t\n\n\t/**\n\t * If true, the minimum label will be visible\n\t */\n\tminValueLabelDisplay: boolean;\n\t\n\n\t/**\n\t * If true, the maximum label will be visible\n\t */\n\tmaxValueLabelDisplay: boolean;\n\t\n\n\t/**\n\t * If true, the label when the handles are close is visible\n\t */\n\tcombinedLabelDisplay: boolean;\n\t\n\n\t/**\n\t * Array of the sorted handles to display\n\t */\n\tsortedHandles: SliderHandle[];\n\t\n\n\t/**\n\t * Array of objects representing progress display options\n\t */\n\tprogressDisplayOptions: ProgressDisplayOptions[];\n\t\n\n\t/**\n\t * Array of objects representing handle display options\n\t */\n\thandleDisplayOptions: HandleDisplayOptions[];\n\t\n\n\t/**\n\t * Check if the slider is interactive, meaning it is not disabled or readonly\n\t */\n\tinteractive: boolean;\n\t\n\t/**\n\t * Minimum value that can be assigned to the slider\n\t *\n\t * @defaultValue `0`\n\t */\n\tmin: number;\n\t\n\n\t/**\n\t * Maximum value that can be assigned to the slider\n\t *\n\t * @defaultValue `100`\n\t */\n\tmax: number;\n\t\n\n\t/**\n\t * Unit value between slider steps\n\t *\n\t * @defaultValue `1`\n\t */\n\tstepSize: number;\n\t\n\n\t/**\n\t * If `true` slider value cannot be changed but the slider is still focusable\n\t *\n\t * @defaultValue `false`\n\t */\n\treadonly: boolean;\n\t\n\n\t/**\n\t * If `true` slider value cannot be changed and the slider cannot be focused\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true` is vertically positioned otherwise it is horizontal\n\t *\n\t * @defaultValue `false`\n\t */\n\tvertical: boolean;\n\t\n\n\t/**\n\t * Current slider values\n\t *\n\t * @defaultValue `[0]`\n\t */\n\tvalues: number[];\n\t\n\n\t/**\n\t * If `true` the value labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\tshowValueLabels: boolean;\n\t\n\n\t/**\n\t * If `true` the min and max labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\tshowMinMaxLabels: boolean;\n\t\n\n\t/**\n\t * It `true` slider display is inversed\n\t *\n\t * @defaultValue `false`\n\t */\n\trtl: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Slot to change the default display of the slider\n\t */\n\tstructure: SlotContent<SliderContext>;\n\t\n\n\t/**\n\t * Slot to change the default labels of the slider\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({value}: SliderSlotLabelContext) => '' + value\n\t * ```\n\t */\n\tlabel: SlotContent<SliderSlotLabelContext>;\n\t\n\n\t/**\n\t *  Slot to change the handlers\n\t */\n\thandle: SlotContent<SliderSlotHandleContext>;\n}\n\nexport interface SliderProps {\n\t\n\t/**\n\t * Return the value for the 'aria-label' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\tariaLabelHandle: (value: number, sortedIndex: number, index: number) => string;\n\t\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\tariaValueText: (value: number, sortedIndex: number, index: number) => string;\n\t\n\n\t/**\n\t * An event emitted when slider values are changed\n\t *\n\t * Event payload equals to the updated slider values\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonValuesChange: (values: number[]) => void;\n\t\n\t/**\n\t * Minimum value that can be assigned to the slider\n\t *\n\t * @defaultValue `0`\n\t */\n\tmin: number;\n\t\n\n\t/**\n\t * Maximum value that can be assigned to the slider\n\t *\n\t * @defaultValue `100`\n\t */\n\tmax: number;\n\t\n\n\t/**\n\t * Unit value between slider steps\n\t *\n\t * @defaultValue `1`\n\t */\n\tstepSize: number;\n\t\n\n\t/**\n\t * If `true` slider value cannot be changed but the slider is still focusable\n\t *\n\t * @defaultValue `false`\n\t */\n\treadonly: boolean;\n\t\n\n\t/**\n\t * If `true` slider value cannot be changed and the slider cannot be focused\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true` is vertically positioned otherwise it is horizontal\n\t *\n\t * @defaultValue `false`\n\t */\n\tvertical: boolean;\n\t\n\n\t/**\n\t * Current slider values\n\t *\n\t * @defaultValue `[0]`\n\t */\n\tvalues: number[];\n\t\n\n\t/**\n\t * If `true` the value labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\tshowValueLabels: boolean;\n\t\n\n\t/**\n\t * If `true` the min and max labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\tshowMinMaxLabels: boolean;\n\t\n\n\t/**\n\t * It `true` slider display is inversed\n\t *\n\t * @defaultValue `false`\n\t */\n\trtl: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Slot to change the default display of the slider\n\t */\n\tstructure: SlotContent<SliderContext>;\n\t\n\n\t/**\n\t * Slot to change the default labels of the slider\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({value}: SliderSlotLabelContext) => '' + value\n\t * ```\n\t */\n\tlabel: SlotContent<SliderSlotLabelContext>;\n\t\n\n\t/**\n\t *  Slot to change the handlers\n\t */\n\thandle: SlotContent<SliderSlotHandleContext>;\n}\n\n\n\nexport type SliderWidget = Widget<SliderProps, SliderState, SliderApi, SliderActions, SliderDirectives>;\n\n\n\n/**\n * Create a Slider with given config props\n * @param config - an optional slider config\n * @returns a SliderWidget\n */\n\nconst export_createSlider: WidgetFactory<SliderWidget> = createSlider as any;\nexport {export_createSlider as createSlider};\n\nexport interface ProgressDisplayOptions {\n\t\n\t/**\n\t * Right offset of the progress in %\n\t */\n\tleft: number | null;\n\t\n\t/**\n\t * Left offset of the progress in %\n\t */\n\tright: number | null;\n\t\n\t/**\n\t * Top offset of the progress in %\n\t */\n\ttop: number | null;\n\t\n\t/**\n\t * Bottom offset of the progress in %\n\t */\n\tbottom: number | null;\n\t\n\t/**\n\t * Width of the progress in %\n\t */\n\twidth: number;\n\t\n\t/**\n\t * Height of hte progress in %\n\t */\n\theight: number;\n}\n\nexport interface HandleDisplayOptions {\n\t\n\t/**\n\t * Left offset of the handle in %\n\t */\n\tleft: number | null;\n\t\n\t/**\n\t * Top offset of the handle in %\n\t */\n\ttop: number | null;\n}\n\nexport interface SliderHandle {\n\t\n\t/**\n\t * Value of the handle\n\t */\n\tvalue: number;\n\t\n\t/**\n\t * Handle id\n\t */\n\tid: number;\n\t\n\t/**\n\t * ariaLabel of the handle\n\t */\n\tariaLabel: string;\n\t\n\t/**\n\t * ariaValueText of the handle\n\t */\n\tariaValueText: string;\n}\n\nexport interface SliderApi {\n}\n\nexport interface SliderDirectives {\n\t\n\t/**\n\t * Directive to get the slider component elementRef\n\t */\n\tsliderDirective: Directive;\n\t\n\n\t/**\n\t * Directive used to style the progress display for each handle\n\t */\n\tprogressDisplayDirective: Directive<{option: ProgressDisplayOptions}>;\n\t\n\n\t/**\n\t * Directive to apply to the slider clickable area, to directly move the handle to a given specific position\n\t */\n\tclickableAreaDirective: Directive;\n\t\n\n\t/**\n\t * Directive to apply to the slider handle if any\n\t */\n\thandleDirective: Directive<{item: SliderHandle}>;\n\t\n\n\t/**\n\t * Directive to get the minLabel elementRef\n\t */\n\tminLabelDirective: Directive;\n\t\n\n\t/**\n\t * Directive to get the maxLabel elementRef\n\t */\n\tmaxLabelDirective: Directive;\n\t\n\n\t/**\n\t * Directive to apply to the handle when combined label display is active\n\t */\n\tcombinedHandleLabelDisplayDirective: Directive;\n\t\n\n\t/**\n\t * Directive to apply to the handle when combined label display is not active\n\t */\n\thandleLabelDisplayDirective: Directive<{index: number}>;\n}\n\nexport interface SliderActions {\n\t\n\t/**\n\t * Method to handle click on the slider\n\t * @param event - mouse event\n\t */\n\tclick(event: MouseEvent): void;\n\t\n\t/**\n\t * Method to process the keyboard event\n\t * @param event - keyboard event object\n\t * @param handleNumber - id of the modified handle\n\t */\n\tkeydown(event: KeyboardEvent, handleNumber: number): void;\n\t\n\n\t/**\n\t * Method describing the behavior of the slider handle on mouse down event\n\t * @param event - mouse event\n\t * @param handleId - numeric id of the handle\n\t */\n\tmouseDown(event: MouseEvent, handleId: number): void;\n\t\n\n\t/**\n\t * Method describing the behavior of the slider handle on touch start event\n\t * @param event - touch event\n\t * @param handleId - number id of the handle\n\t */\n\ttouchStart(event: TouchEvent, handleId: number): void;\n}\n\n"]}
15
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.gen.js","sourceRoot":"","sources":["../../../../src/components/slider/slider.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;AAkXjE;;;;GAIG;AAEH,MAAM,mBAAmB,GAAgC,YAAmB,CAAC;AAC7E,OAAO,EAAC,mBAAmB,IAAI,YAAY,EAAC,CAAC","sourcesContent":["import {getSliderDefaultConfig, createSlider} from '@agnos-ui/core-bootstrap/components/slider';\nimport type {WidgetSlotContext, SlotContent, Widget, WidgetFactory, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default Slider config\n * @returns the default Slider config\n */\nconst export_getSliderDefaultConfig: () => SliderProps = getSliderDefaultConfig as any;\nexport {export_getSliderDefaultConfig as getSliderDefaultConfig};\n\n\n\n/**\n * Represents the context for a Slider component.\n * This type is an alias for `WidgetSlotContext<SliderWidget>`.\n */\nexport interface SliderContext extends WidgetSlotContext<SliderWidget> {}\n\n\n/**\n * Represents the context for a slider slot label, extending the base `SliderContext`\n * with an additional `value` property.\n */\nexport interface SliderSlotLabelContext extends SliderContext {\n\t/**\n\t * the value of the handle the label is attached to\n\t */\n\tvalue: number;\n}\n\n\n/**\n * Represents the context for a slider slot handle.\n * This type extends the `SliderContext` and includes an additional `item` property of type `SliderHandle`.\n */\nexport interface SliderSlotHandleContext extends SliderContext {\n\t/**\n\t * the handle context\n\t */\n\titem: SliderHandle;\n}\n\n/**\n * Represents the state of a slider component.\n */\nexport interface SliderState {\n\t\n\t/**\n\t * Sorted slider values\n\t */\n\tsortedValues: number[];\n\t\n\n\t/**\n\t * Combined label left offset in %\n\t */\n\tcombinedLabelPositionLeft: number;\n\t\n\n\t/**\n\t * Combined label top offset in %\n\t */\n\tcombinedLabelPositionTop: number;\n\t\n\n\t/**\n\t * If true, the minimum label will be visible\n\t */\n\tminValueLabelDisplay: boolean;\n\t\n\n\t/**\n\t * If true, the maximum label will be visible\n\t */\n\tmaxValueLabelDisplay: boolean;\n\t\n\n\t/**\n\t * If true, the label when the handles are close is visible\n\t */\n\tcombinedLabelDisplay: boolean;\n\t\n\n\t/**\n\t * Array of the sorted handles to display\n\t */\n\tsortedHandles: SliderHandle[];\n\t\n\n\t/**\n\t * Array of objects representing progress display options\n\t */\n\tprogressDisplayOptions: ProgressDisplayOptions[];\n\t\n\n\t/**\n\t * Array of objects representing handle display options\n\t */\n\thandleDisplayOptions: HandleDisplayOptions[];\n\t\n\n\t/**\n\t * Check if the slider is interactive, meaning it is not disabled or readonly\n\t */\n\tinteractive: boolean;\n\t\n\t/**\n\t * Minimum value that can be assigned to the slider\n\t *\n\t * @defaultValue `0`\n\t */\n\tmin: number;\n\t\n\n\t/**\n\t * Maximum value that can be assigned to the slider\n\t *\n\t * @defaultValue `100`\n\t */\n\tmax: number;\n\t\n\n\t/**\n\t * Unit value between slider steps\n\t *\n\t * @defaultValue `1`\n\t */\n\tstepSize: number;\n\t\n\n\t/**\n\t * If `true` slider value cannot be changed but the slider is still focusable\n\t *\n\t * @defaultValue `false`\n\t */\n\treadonly: boolean;\n\t\n\n\t/**\n\t * If `true` slider value cannot be changed and the slider cannot be focused\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true` is vertically positioned otherwise it is horizontal\n\t *\n\t * @defaultValue `false`\n\t */\n\tvertical: boolean;\n\t\n\n\t/**\n\t * Current slider values\n\t *\n\t * @defaultValue `[0]`\n\t */\n\tvalues: number[];\n\t\n\n\t/**\n\t * If `true` the value labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\tshowValueLabels: boolean;\n\t\n\n\t/**\n\t * If `true` the min and max labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\tshowMinMaxLabels: boolean;\n\t\n\n\t/**\n\t * It `true` slider display is inversed\n\t *\n\t * @defaultValue `false`\n\t */\n\trtl: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Slot to change the default display of the slider\n\t */\n\tstructure: SlotContent<SliderContext>;\n\t\n\n\t/**\n\t * Slot to change the default labels of the slider\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({value}: SliderSlotLabelContext) => '' + value\n\t * ```\n\t */\n\tlabel: SlotContent<SliderSlotLabelContext>;\n\t\n\n\t/**\n\t *  Slot to change the handlers\n\t */\n\thandle: SlotContent<SliderSlotHandleContext>;\n}\n\n/**\n * Represents the properties for the Slider component.\n */\nexport interface SliderProps {\n\t\n\t/**\n\t * Return the value for the 'aria-label' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\tariaLabelHandle: (value: number, sortedIndex: number, index: number) => string;\n\t\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute for the handle\n\t * @param value - value of the handle\n\t * @param sortedIndex - index of the handle in the sorted list\n\t * @param index - index of the handle in the original list\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (value: number) => '' + value\n\t * ```\n\t */\n\tariaValueText: (value: number, sortedIndex: number, index: number) => string;\n\t\n\n\t/**\n\t * An event emitted when slider values are changed\n\t *\n\t * Event payload equals to the updated slider values\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonValuesChange: (values: number[]) => void;\n\t\n\t/**\n\t * Minimum value that can be assigned to the slider\n\t *\n\t * @defaultValue `0`\n\t */\n\tmin: number;\n\t\n\n\t/**\n\t * Maximum value that can be assigned to the slider\n\t *\n\t * @defaultValue `100`\n\t */\n\tmax: number;\n\t\n\n\t/**\n\t * Unit value between slider steps\n\t *\n\t * @defaultValue `1`\n\t */\n\tstepSize: number;\n\t\n\n\t/**\n\t * If `true` slider value cannot be changed but the slider is still focusable\n\t *\n\t * @defaultValue `false`\n\t */\n\treadonly: boolean;\n\t\n\n\t/**\n\t * If `true` slider value cannot be changed and the slider cannot be focused\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true` is vertically positioned otherwise it is horizontal\n\t *\n\t * @defaultValue `false`\n\t */\n\tvertical: boolean;\n\t\n\n\t/**\n\t * Current slider values\n\t *\n\t * @defaultValue `[0]`\n\t */\n\tvalues: number[];\n\t\n\n\t/**\n\t * If `true` the value labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\tshowValueLabels: boolean;\n\t\n\n\t/**\n\t * If `true` the min and max labels are displayed on the slider\n\t *\n\t * @defaultValue `true`\n\t */\n\tshowMinMaxLabels: boolean;\n\t\n\n\t/**\n\t * It `true` slider display is inversed\n\t *\n\t * @defaultValue `false`\n\t */\n\trtl: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Slot to change the default display of the slider\n\t */\n\tstructure: SlotContent<SliderContext>;\n\t\n\n\t/**\n\t * Slot to change the default labels of the slider\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({value}: SliderSlotLabelContext) => '' + value\n\t * ```\n\t */\n\tlabel: SlotContent<SliderSlotLabelContext>;\n\t\n\n\t/**\n\t *  Slot to change the handlers\n\t */\n\thandle: SlotContent<SliderSlotHandleContext>;\n}\n\n\n\n/**\n * Represents a slider widget component.\n */\nexport type SliderWidget = Widget<SliderProps, SliderState, object, SliderDirectives>;\n\n\n\n/**\n * Create a Slider with given config props\n * @param config - an optional slider config\n * @returns a SliderWidget\n */\n\nconst export_createSlider: WidgetFactory<SliderWidget> = createSlider as any;\nexport {export_createSlider as createSlider};\n\n/**\n * Options for displaying progress in a slider component.\n */\nexport interface ProgressDisplayOptions {\n\t\n\t/**\n\t * Right offset of the progress in %\n\t */\n\tleft: number | null;\n\t\n\t/**\n\t * Left offset of the progress in %\n\t */\n\tright: number | null;\n\t\n\t/**\n\t * Top offset of the progress in %\n\t */\n\ttop: number | null;\n\t\n\t/**\n\t * Bottom offset of the progress in %\n\t */\n\tbottom: number | null;\n\t\n\t/**\n\t * Width of the progress in %\n\t */\n\twidth: number;\n\t\n\t/**\n\t * Height of hte progress in %\n\t */\n\theight: number;\n}\n\n/**\n * Options for displaying a handle in a slider component.\n */\nexport interface HandleDisplayOptions {\n\t\n\t/**\n\t * Left offset of the handle in %\n\t */\n\tleft: number | null;\n\t\n\t/**\n\t * Top offset of the handle in %\n\t */\n\ttop: number | null;\n}\n\n/**\n * Represents a handle in a slider component.\n */\nexport interface SliderHandle {\n\t\n\t/**\n\t * Value of the handle\n\t */\n\tvalue: number;\n\t\n\t/**\n\t * Handle id\n\t */\n\tid: number;\n\t\n\t/**\n\t * ariaLabel of the handle\n\t */\n\tariaLabel: string;\n\t\n\t/**\n\t * ariaValueText of the handle\n\t */\n\tariaValueText: string;\n}\n\n/**\n * Interface representing various directives used in the slider component.\n */\nexport interface SliderDirectives {\n\t\n\t/**\n\t * Directive to get the slider component elementRef\n\t */\n\tsliderDirective: Directive;\n\t\n\n\t/**\n\t * Directive used to style the progress display for each handle\n\t */\n\tprogressDisplayDirective: Directive<{option: ProgressDisplayOptions}>;\n\t\n\n\t/**\n\t * Directive to apply to the slider clickable area, to directly move the handle to a given specific position\n\t */\n\tclickableAreaDirective: Directive;\n\t\n\n\t/**\n\t * Directive to apply handle events handlers\n\t */\n\thandleEventsDirective: Directive<{item: {id: number}}>;\n\t\n\t/**\n\t * Directive to apply to the slider handle if any\n\t */\n\thandleDirective: Directive<{item: SliderHandle}>;\n\t\n\n\t/**\n\t * Directive to get the minLabel elementRef\n\t */\n\tminLabelDirective: Directive;\n\t\n\n\t/**\n\t * Directive to get the maxLabel elementRef\n\t */\n\tmaxLabelDirective: Directive;\n\t\n\n\t/**\n\t * Directive to apply to the handle when combined label display is active\n\t */\n\tcombinedHandleLabelDisplayDirective: Directive;\n\t\n\n\t/**\n\t * Directive to apply to the handle when combined label display is not active\n\t */\n\thandleLabelDisplayDirective: Directive<{index: number}>;\n}\n\n"]}
@@ -1,17 +1,16 @@
1
- import { BaseWidgetDirective, ComponentTemplate, ContentAsSlotDirective, SlotDirective, UseDirective, UseMultiDirective, auBooleanAttribute, auNumberAttribute, } from '@agnos-ui/angular-headless';
2
- import { writable } from '@amadeus-it-group/tansu';
1
+ import { BaseWidgetDirective, ComponentTemplate, SlotDirective, UseDirective, UseMultiDirective, auBooleanAttribute, auNumberAttribute, } from '@agnos-ui/angular-headless';
3
2
  import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewChild, inject, } from '@angular/core';
4
3
  import { callWidgetFactory } from '../../config';
5
4
  import { createToast } from './toast.gen';
6
5
  import * as i0 from "@angular/core";
7
6
  const _c0 = ["structure"];
8
- const _c1 = (a0, a1) => ({ state: a0, widget: a1 });
7
+ const _c1 = (a0, a1, a2) => ({ state: a0, api: a1, directives: a2 });
9
8
  function ToastDefaultSlotsComponent_ng_template_0_Conditional_0_ng_template_1_Template(rf, ctx) { }
10
9
  function ToastDefaultSlotsComponent_ng_template_0_Conditional_0_Conditional_2_Template(rf, ctx) { if (rf & 1) {
11
10
  i0.ɵɵelement(0, "button", 6);
12
11
  } if (rf & 2) {
13
- const widget_r1 = i0.ɵɵnextContext(2).widget;
14
- i0.ɵɵproperty("auUse", widget_r1.directives.closeButtonDirective);
12
+ const directives_r1 = i0.ɵɵnextContext(2).directives;
13
+ i0.ɵɵproperty("auUse", directives_r1.closeButtonDirective);
15
14
  } }
16
15
  function ToastDefaultSlotsComponent_ng_template_0_Conditional_0_Template(rf, ctx) { if (rf & 1) {
17
16
  i0.ɵɵelementStart(0, "div", 2);
@@ -20,103 +19,118 @@ function ToastDefaultSlotsComponent_ng_template_0_Conditional_0_Template(rf, ctx
20
19
  } if (rf & 2) {
21
20
  const ctx_r1 = i0.ɵɵnextContext();
22
21
  const state_r3 = ctx_r1.state;
23
- const widget_r1 = ctx_r1.widget;
22
+ const api_r4 = ctx_r1.api;
23
+ const directives_r1 = ctx_r1.directives;
24
24
  i0.ɵɵadvance();
25
- i0.ɵɵproperty("auSlot", state_r3.header)("auSlotProps", i0.ɵɵpureFunction2(3, _c1, state_r3, widget_r1));
25
+ i0.ɵɵproperty("auSlot", state_r3.header())("auSlotProps", i0.ɵɵpureFunction3(3, _c1, state_r3, api_r4, directives_r1));
26
26
  i0.ɵɵadvance();
27
- i0.ɵɵconditional(state_r3.dismissible ? 2 : -1);
27
+ i0.ɵɵconditional(state_r3.dismissible() ? 2 : -1);
28
28
  } }
29
29
  function ToastDefaultSlotsComponent_ng_template_0_ng_template_2_Template(rf, ctx) { }
30
30
  function ToastDefaultSlotsComponent_ng_template_0_Conditional_3_Template(rf, ctx) { if (rf & 1) {
31
31
  i0.ɵɵelement(0, "button", 5);
32
32
  } if (rf & 2) {
33
- const widget_r1 = i0.ɵɵnextContext().widget;
34
- i0.ɵɵproperty("auUse", widget_r1.directives.closeButtonDirective);
33
+ const directives_r1 = i0.ɵɵnextContext().directives;
34
+ i0.ɵɵproperty("auUse", directives_r1.closeButtonDirective);
35
35
  } }
36
36
  function ToastDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
37
- i0.ɵɵtemplate(0, ToastDefaultSlotsComponent_ng_template_0_Conditional_0_Template, 3, 6, "div", 2);
37
+ i0.ɵɵtemplate(0, ToastDefaultSlotsComponent_ng_template_0_Conditional_0_Template, 3, 7, "div", 2);
38
38
  i0.ɵɵelementStart(1, "div", 3);
39
39
  i0.ɵɵtemplate(2, ToastDefaultSlotsComponent_ng_template_0_ng_template_2_Template, 0, 0, "ng-template", 4);
40
40
  i0.ɵɵelementEnd();
41
41
  i0.ɵɵtemplate(3, ToastDefaultSlotsComponent_ng_template_0_Conditional_3_Template, 1, 1, "button", 5);
42
42
  } if (rf & 2) {
43
43
  const state_r3 = ctx.state;
44
- const widget_r1 = ctx.widget;
45
- i0.ɵɵconditional(state_r3.header ? 0 : -1);
44
+ const api_r4 = ctx.api;
45
+ const directives_r1 = ctx.directives;
46
+ i0.ɵɵconditional(state_r3.header() ? 0 : -1);
46
47
  i0.ɵɵadvance(2);
47
- i0.ɵɵproperty("auSlot", state_r3.children)("auSlotProps", i0.ɵɵpureFunction2(4, _c1, state_r3, widget_r1));
48
+ i0.ɵɵproperty("auSlot", state_r3.children())("auSlotProps", i0.ɵɵpureFunction3(4, _c1, state_r3, api_r4, directives_r1));
48
49
  i0.ɵɵadvance();
49
- i0.ɵɵconditional(state_r3.dismissible && !state_r3.header ? 3 : -1);
50
+ i0.ɵɵconditional(state_r3.dismissible() && !state_r3.header() ? 3 : -1);
50
51
  } }
51
- const _c2 = ["auToast", ""];
52
- const _c3 = ["*"];
53
- const _c4 = (a0, a1, a2) => [a0, a1, a2];
52
+ const _c2 = ["content"];
53
+ const _c3 = ["auToast", ""];
54
+ const _c4 = ["*"];
55
+ const _c5 = (a0, a1, a2) => [a0, a1, a2];
54
56
  function ToastComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
55
57
  i0.ɵɵprojection(0);
56
58
  } }
57
- function ToastComponent_Conditional_1_ng_template_1_Template(rf, ctx) { }
58
- function ToastComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
59
+ function ToastComponent_Conditional_2_ng_template_1_Template(rf, ctx) { }
60
+ function ToastComponent_Conditional_2_Template(rf, ctx) { if (rf & 1) {
59
61
  i0.ɵɵelementStart(0, "div", 2);
60
- i0.ɵɵtemplate(1, ToastComponent_Conditional_1_ng_template_1_Template, 0, 0, "ng-template", 3);
62
+ i0.ɵɵtemplate(1, ToastComponent_Conditional_2_ng_template_1_Template, 0, 0, "ng-template", 3);
61
63
  i0.ɵɵelementEnd();
62
64
  } if (rf & 2) {
63
65
  const ctx_r0 = i0.ɵɵnextContext();
64
- i0.ɵɵclassProp("d-flex", !ctx_r0.state().header)("toast-dismissible", ctx_r0.state().dismissible);
65
- i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction3(7, _c4, ctx_r0.widget.directives.autoHideDirective, ctx_r0.widget.directives.transitionDirective, ctx_r0.widget.directives.bodyDirective));
66
+ i0.ɵɵclassProp("d-flex", !ctx_r0.state.header())("toast-dismissible", ctx_r0.state.dismissible());
67
+ i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction3(7, _c5, ctx_r0.directives.autoHideDirective, ctx_r0.directives.transitionDirective, ctx_r0.directives.bodyDirective));
66
68
  i0.ɵɵadvance();
67
- i0.ɵɵproperty("auSlot", ctx_r0.state().structure)("auSlotProps", i0.ɵɵpureFunction2(11, _c1, ctx_r0.state(), ctx_r0.widget));
69
+ i0.ɵɵproperty("auSlot", ctx_r0.state.structure())("auSlotProps", i0.ɵɵpureFunction3(11, _c1, ctx_r0.state, ctx_r0.api, ctx_r0.directives));
68
70
  } }
71
+ /**
72
+ * Directive to represent the body of a toast notification.
73
+ * This directive uses a template reference to render the {@link ToastContext}.
74
+ */
69
75
  export class ToastBodyDirective {
70
76
  constructor() {
71
77
  this.templateRef = inject((TemplateRef));
72
78
  }
73
- static ngTemplateContextGuard(dir, context) {
79
+ static ngTemplateContextGuard(_dir, context) {
74
80
  return true;
75
81
  }
76
- static { this.ɵfac = function ToastBodyDirective_Factory(t) { return new (t || ToastBodyDirective)(); }; }
82
+ static { this.ɵfac = function ToastBodyDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ToastBodyDirective)(); }; }
77
83
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ToastBodyDirective, selectors: [["ng-template", "auToastBody", ""]], standalone: true }); }
78
84
  }
79
85
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ToastBodyDirective, [{
80
86
  type: Directive,
81
87
  args: [{ selector: 'ng-template[auToastBody]', standalone: true }]
82
88
  }], null, null); })();
89
+ /**
90
+ * Directive to define the structure of a toast component.
91
+ * This directive uses a template reference to render the {@link ToastContext}.
92
+ */
83
93
  export class ToastStructureDirective {
84
94
  constructor() {
85
95
  this.templateRef = inject((TemplateRef));
86
96
  }
87
- static ngTemplateContextGuard(dir, context) {
97
+ static ngTemplateContextGuard(_dir, context) {
88
98
  return true;
89
99
  }
90
- static { this.ɵfac = function ToastStructureDirective_Factory(t) { return new (t || ToastStructureDirective)(); }; }
100
+ static { this.ɵfac = function ToastStructureDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ToastStructureDirective)(); }; }
91
101
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ToastStructureDirective, selectors: [["ng-template", "auToastStructure", ""]], standalone: true }); }
92
102
  }
93
103
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ToastStructureDirective, [{
94
104
  type: Directive,
95
105
  args: [{ selector: 'ng-template[auToastStructure]', standalone: true }]
96
106
  }], null, null); })();
107
+ /**
108
+ * Directive representing the header of a toast component.
109
+ * This directive uses a template reference to render the {@link ToastContext}.
110
+ */
97
111
  export class ToastHeaderDirective {
98
112
  constructor() {
99
113
  this.templateRef = inject((TemplateRef));
100
114
  }
101
- static ngTemplateContextGuard(dir, context) {
115
+ static ngTemplateContextGuard(_dir, context) {
102
116
  return true;
103
117
  }
104
- static { this.ɵfac = function ToastHeaderDirective_Factory(t) { return new (t || ToastHeaderDirective)(); }; }
118
+ static { this.ɵfac = function ToastHeaderDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ToastHeaderDirective)(); }; }
105
119
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ToastHeaderDirective, selectors: [["ng-template", "auToastHeader", ""]], standalone: true }); }
106
120
  }
107
121
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ToastHeaderDirective, [{
108
122
  type: Directive,
109
123
  args: [{ selector: 'ng-template[auToastHeader]', standalone: true }]
110
124
  }], null, null); })();
111
- export class ToastDefaultSlotsComponent {
112
- static { this.ɵfac = function ToastDefaultSlotsComponent_Factory(t) { return new (t || ToastDefaultSlotsComponent)(); }; }
125
+ class ToastDefaultSlotsComponent {
126
+ static { this.ɵfac = function ToastDefaultSlotsComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ToastDefaultSlotsComponent)(); }; }
113
127
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ToastDefaultSlotsComponent, selectors: [["ng-component"]], viewQuery: function ToastDefaultSlotsComponent_Query(rf, ctx) { if (rf & 1) {
114
128
  i0.ɵɵviewQuery(_c0, 7);
115
129
  } if (rf & 2) {
116
130
  let _t;
117
131
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.structure = _t.first);
118
132
  } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [["structure", ""], ["auToastStructure", ""], [1, "toast-header"], [1, "toast-body"], [3, "auSlot", "auSlotProps"], [1, "btn-close", "btn-close-white", "me-2", "m-auto", 3, "auUse"], [1, "btn-close", "me-0", "ms-auto", 3, "auUse"]], template: function ToastDefaultSlotsComponent_Template(rf, ctx) { if (rf & 1) {
119
- i0.ɵɵtemplate(0, ToastDefaultSlotsComponent_ng_template_0_Template, 4, 7, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
133
+ i0.ɵɵtemplate(0, ToastDefaultSlotsComponent_ng_template_0_Template, 4, 8, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
120
134
  } }, dependencies: [SlotDirective, ToastStructureDirective, UseDirective], encapsulation: 2, changeDetection: 0 }); }
121
135
  }
122
136
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ToastDefaultSlotsComponent, [{
@@ -125,20 +139,20 @@ export class ToastDefaultSlotsComponent {
125
139
  standalone: true,
126
140
  changeDetection: ChangeDetectionStrategy.OnPush,
127
141
  imports: [SlotDirective, ToastStructureDirective, UseDirective],
128
- template: ` <ng-template auToastStructure #structure let-state="state" let-widget="widget">
129
- @if (state.header) {
142
+ template: ` <ng-template auToastStructure #structure let-state="state" let-api="api" let-directives="directives">
143
+ @if (state.header()) {
130
144
  <div class="toast-header">
131
- <ng-template [auSlot]="state.header" [auSlotProps]="{state, widget}"></ng-template>
132
- @if (state.dismissible) {
133
- <button class="btn-close me-0 ms-auto" [auUse]="widget.directives.closeButtonDirective"></button>
145
+ <ng-template [auSlot]="state.header()" [auSlotProps]="{state, api, directives}"></ng-template>
146
+ @if (state.dismissible()) {
147
+ <button class="btn-close me-0 ms-auto" [auUse]="directives.closeButtonDirective"></button>
134
148
  }
135
149
  </div>
136
150
  }
137
151
  <div class="toast-body">
138
- <ng-template [auSlot]="state.children" [auSlotProps]="{state, widget}"></ng-template>
152
+ <ng-template [auSlot]="state.children()" [auSlotProps]="{state, api, directives}"></ng-template>
139
153
  </div>
140
- @if (state.dismissible && !state.header) {
141
- <button class="btn-close btn-close-white me-2 m-auto" [auUse]="widget.directives.closeButtonDirective"></button>
154
+ @if (state.dismissible() && !state.header()) {
155
+ <button class="btn-close btn-close-white me-2 m-auto" [auUse]="directives.closeButtonDirective"></button>
142
156
  }
143
157
  </ng-template>`,
144
158
  }]
@@ -146,14 +160,36 @@ export class ToastDefaultSlotsComponent {
146
160
  type: ViewChild,
147
161
  args: ['structure', { static: true }]
148
162
  }] }); })();
149
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ToastDefaultSlotsComponent, { className: "ToastDefaultSlotsComponent", filePath: "components/toast/toast.component.ts", lineNumber: 76 }); })();
163
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ToastDefaultSlotsComponent, { className: "ToastDefaultSlotsComponent", filePath: "components/toast/toast.component.ts", lineNumber: 84 }); })();
164
+ /**
165
+ * Represents the default slot structure for the toast component.
166
+ */
150
167
  export const toastDefaultSlotStructure = new ComponentTemplate(ToastDefaultSlotsComponent, 'structure');
151
- const defaultConfig = {
152
- structure: toastDefaultSlotStructure,
153
- };
168
+ /**
169
+ * The `ToastComponent` is a UI component that displays a toast notification.
170
+ * It extends the `BaseWidgetDirective` and provides various configurable properties
171
+ * and events to control the behavior and appearance of the toast.
172
+ */
154
173
  export class ToastComponent extends BaseWidgetDirective {
155
174
  constructor() {
156
- super(...arguments);
175
+ super(callWidgetFactory({
176
+ factory: createToast,
177
+ widgetName: 'toast',
178
+ defaultConfig: {
179
+ structure: toastDefaultSlotStructure,
180
+ },
181
+ events: {
182
+ onVisibleChange: (event) => this.visibleChange.emit(event),
183
+ onShown: () => this.shown.emit(),
184
+ onHidden: () => this.hidden.emit(),
185
+ },
186
+ slotTemplates: () => ({
187
+ children: this.slotDefaultFromContent?.templateRef,
188
+ structure: this.slotStructureFromContent?.templateRef,
189
+ header: this.slotHeaderFromContent?.templateRef,
190
+ }),
191
+ slotChildren: () => this.slotChildren,
192
+ }));
157
193
  /**
158
194
  * Callback called when the alert visibility changed.
159
195
  *
@@ -181,26 +217,8 @@ export class ToastComponent extends BaseWidgetDirective {
181
217
  * ```
182
218
  */
183
219
  this.shown = new EventEmitter();
184
- this.defaultSlots = writable(defaultConfig);
185
- this._widget = callWidgetFactory({
186
- factory: createToast,
187
- widgetName: 'toast',
188
- defaultConfig: this.defaultSlots,
189
- events: {
190
- onVisibleChange: (event) => this.visibleChange.emit(event),
191
- onShown: () => this.shown.emit(),
192
- onHidden: () => this.hidden.emit(),
193
- },
194
- });
195
220
  }
196
- ngAfterContentChecked() {
197
- this._widget.patchSlots({
198
- children: this.slotDefaultFromContent?.templateRef,
199
- structure: this.slotStructureFromContent?.templateRef,
200
- header: this.slotHeaderFromContent?.templateRef,
201
- });
202
- }
203
- static { this.ɵfac = /*@__PURE__*/ (() => { let ɵToastComponent_BaseFactory; return function ToastComponent_Factory(t) { return (ɵToastComponent_BaseFactory || (ɵToastComponent_BaseFactory = i0.ɵɵgetInheritedFactory(ToastComponent)))(t || ToastComponent); }; })(); }
221
+ static { this.ɵfac = function ToastComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ToastComponent)(); }; }
204
222
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ToastComponent, selectors: [["", "auToast", ""]], contentQueries: function ToastComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
205
223
  i0.ɵɵcontentQuery(dirIndex, ToastBodyDirective, 5);
206
224
  i0.ɵɵcontentQuery(dirIndex, ToastStructureDirective, 5);
@@ -210,14 +228,18 @@ export class ToastComponent extends BaseWidgetDirective {
210
228
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first);
211
229
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStructureFromContent = _t.first);
212
230
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotHeaderFromContent = _t.first);
213
- } }, inputs: { dismissible: [2, "auDismissible", "dismissible", auBooleanAttribute], transition: [0, "auTransition", "transition"], visible: [2, "auVisible", "visible", auBooleanAttribute], animatedOnInit: [2, "auAnimatedOnInit", "animatedOnInit", auBooleanAttribute], animated: [2, "auAnimated", "animated", auBooleanAttribute], autoHide: [2, "auAutoHide", "autoHide", auBooleanAttribute], delay: [2, "auDelay", "delay", auNumberAttribute], ariaCloseButtonLabel: [0, "auAriaCloseButtonLabel", "ariaCloseButtonLabel"], children: [0, "auChildren", "children"], structure: [0, "auStructure", "structure"], header: [0, "auHeader", "header"], className: [0, "auClassName", "className"] }, outputs: { visibleChange: "auVisibleChange", hidden: "auHidden", shown: "auShown" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c2, ngContentSelectors: _c3, decls: 2, vars: 2, consts: [[3, "auContentAsSlot"], [1, "toast", 3, "d-flex", "toast-dismissible", "auUseMulti"], [1, "toast", 3, "auUseMulti"], [3, "auSlot", "auSlotProps"]], template: function ToastComponent_Template(rf, ctx) { if (rf & 1) {
231
+ } }, viewQuery: function ToastComponent_Query(rf, ctx) { if (rf & 1) {
232
+ i0.ɵɵviewQuery(_c2, 7);
233
+ } if (rf & 2) {
234
+ let _t;
235
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotChildren = _t.first);
236
+ } }, inputs: { dismissible: [2, "auDismissible", "dismissible", auBooleanAttribute], transition: [0, "auTransition", "transition"], visible: [2, "auVisible", "visible", auBooleanAttribute], animatedOnInit: [2, "auAnimatedOnInit", "animatedOnInit", auBooleanAttribute], animated: [2, "auAnimated", "animated", auBooleanAttribute], autoHide: [2, "auAutoHide", "autoHide", auBooleanAttribute], delay: [2, "auDelay", "delay", auNumberAttribute], ariaCloseButtonLabel: [0, "auAriaCloseButtonLabel", "ariaCloseButtonLabel"], children: [0, "auChildren", "children"], structure: [0, "auStructure", "structure"], header: [0, "auHeader", "header"], className: [0, "auClassName", "className"] }, outputs: { visibleChange: "auVisibleChange", hidden: "auHidden", shown: "auShown" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c3, ngContentSelectors: _c4, decls: 3, vars: 1, consts: [["content", ""], [1, "toast", 3, "d-flex", "toast-dismissible", "auUseMulti"], [1, "toast", 3, "auUseMulti"], [3, "auSlot", "auSlotProps"]], template: function ToastComponent_Template(rf, ctx) { if (rf & 1) {
214
237
  i0.ɵɵprojectionDef();
215
- i0.ɵɵtemplate(0, ToastComponent_ng_template_0_Template, 1, 0, "ng-template", 0)(1, ToastComponent_Conditional_1_Template, 2, 14, "div", 1);
238
+ i0.ɵɵtemplate(0, ToastComponent_ng_template_0_Template, 1, 0, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor)(2, ToastComponent_Conditional_2_Template, 2, 15, "div", 1);
216
239
  } if (rf & 2) {
217
- i0.ɵɵproperty("auContentAsSlot", ctx.defaultSlots);
218
- i0.ɵɵadvance();
219
- i0.ɵɵconditional(!ctx.state().hidden ? 1 : -1);
220
- } }, dependencies: [SlotDirective, UseMultiDirective, ContentAsSlotDirective], encapsulation: 2, changeDetection: 0 }); }
240
+ i0.ɵɵadvance(2);
241
+ i0.ɵɵconditional(!ctx.state.hidden() ? 2 : -1);
242
+ } }, dependencies: [SlotDirective, UseMultiDirective], encapsulation: 2, changeDetection: 0 }); }
221
243
  }
222
244
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ToastComponent, [{
223
245
  type: Component,
@@ -225,22 +247,22 @@ export class ToastComponent extends BaseWidgetDirective {
225
247
  selector: '[auToast]',
226
248
  standalone: true,
227
249
  changeDetection: ChangeDetectionStrategy.OnPush,
228
- imports: [SlotDirective, UseMultiDirective, ContentAsSlotDirective],
229
- template: ` <ng-template [auContentAsSlot]="defaultSlots">
250
+ imports: [SlotDirective, UseMultiDirective],
251
+ template: ` <ng-template #content>
230
252
  <ng-content></ng-content>
231
253
  </ng-template>
232
- @if (!state().hidden) {
254
+ @if (!state.hidden()) {
233
255
  <div
234
256
  class="toast"
235
- [class.d-flex]="!state().header"
236
- [class.toast-dismissible]="state().dismissible"
237
- [auUseMulti]="[widget.directives.autoHideDirective, widget.directives.transitionDirective, widget.directives.bodyDirective]"
257
+ [class.d-flex]="!state.header()"
258
+ [class.toast-dismissible]="state.dismissible()"
259
+ [auUseMulti]="[directives.autoHideDirective, directives.transitionDirective, directives.bodyDirective]"
238
260
  >
239
- <ng-template [auSlot]="state().structure" [auSlotProps]="{state: state(), widget}"></ng-template>
261
+ <ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}"></ng-template>
240
262
  </div>
241
263
  }`,
242
264
  }]
243
- }], null, { dismissible: [{
265
+ }], () => [], { dismissible: [{
244
266
  type: Input,
245
267
  args: [{ alias: 'auDismissible', transform: auBooleanAttribute }]
246
268
  }], transition: [{
@@ -294,6 +316,9 @@ export class ToastComponent extends BaseWidgetDirective {
294
316
  }], className: [{
295
317
  type: Input,
296
318
  args: ['auClassName']
319
+ }], slotChildren: [{
320
+ type: ViewChild,
321
+ args: ['content', { static: true }]
297
322
  }] }); })();
298
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ToastComponent, { className: "ToastComponent", filePath: "components/toast/toast.component.ts", lineNumber: 105 }); })();
299
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../src/components/toast/toast.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent, TransitionFn} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tContentAsSlotDirective,\n\tSlotDirective,\n\tUseDirective,\n\tUseMultiDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n} from '@agnos-ui/angular-headless';\nimport type {WritableSignal} from '@amadeus-it-group/tansu';\nimport {writable} from '@amadeus-it-group/tansu';\nimport type {AfterContentChecked} from '@angular/core';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tinject,\n} from '@angular/core';\nimport {callWidgetFactory} from '../../config';\n\nimport type {ToastContext, ToastProps, ToastWidget} from './toast.gen';\nimport {createToast} from './toast.gen';\n\n@Directive({selector: 'ng-template[auToastBody]', standalone: true})\nexport class ToastBodyDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(dir: ToastBodyDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auToastStructure]', standalone: true})\nexport class ToastStructureDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(dir: ToastStructureDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auToastHeader]', standalone: true})\nexport class ToastHeaderDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(dir: ToastHeaderDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, ToastStructureDirective, UseDirective],\n\ttemplate: ` <ng-template auToastStructure #structure let-state=\"state\" let-widget=\"widget\">\n\t\t@if (state.header) {\n\t\t\t<div class=\"toast-header\">\n\t\t\t\t<ng-template [auSlot]=\"state.header\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t\t@if (state.dismissible) {\n\t\t\t\t\t<button class=\"btn-close me-0 ms-auto\" [auUse]=\"widget.directives.closeButtonDirective\"></button>\n\t\t\t\t}\n\t\t\t</div>\n\t\t}\n\t\t<div class=\"toast-body\">\n\t\t\t<ng-template [auSlot]=\"state.children\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t</div>\n\t\t@if (state.dismissible && !state.header) {\n\t\t\t<button class=\"btn-close btn-close-white me-2 m-auto\" [auUse]=\"widget.directives.closeButtonDirective\"></button>\n\t\t}\n\t</ng-template>`,\n})\nexport class ToastDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<ToastContext>;\n}\n\nexport const toastDefaultSlotStructure = new ComponentTemplate(ToastDefaultSlotsComponent, 'structure');\n\nconst defaultConfig: Partial<ToastProps> = {\n\tstructure: toastDefaultSlotStructure,\n};\n\n@Component({\n\tselector: '[auToast]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, UseMultiDirective, ContentAsSlotDirective],\n\ttemplate: ` <ng-template [auContentAsSlot]=\"defaultSlots\">\n\t\t\t<ng-content></ng-content>\n\t\t</ng-template>\n\t\t@if (!state().hidden) {\n\t\t\t<div\n\t\t\t\tclass=\"toast\"\n\t\t\t\t[class.d-flex]=\"!state().header\"\n\t\t\t\t[class.toast-dismissible]=\"state().dismissible\"\n\t\t\t\t[auUseMulti]=\"[widget.directives.autoHideDirective, widget.directives.transitionDirective, widget.directives.bodyDirective]\"\n\t\t\t>\n\t\t\t\t<ng-template [auSlot]=\"state().structure\" [auSlotProps]=\"{state: state(), widget}\"></ng-template>\n\t\t\t</div>\n\t\t}`,\n})\nexport class ToastComponent extends BaseWidgetDirective<ToastWidget> implements AfterContentChecked {\n\t/**\n\t * If `true`, alert can be dismissed by the user.\n\t * The close button (×) will be displayed and you can be notified of the event with the (close) output.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auDismissible', transform: auBooleanAttribute})\n\tdismissible: boolean | undefined;\n\n\t/**\n\t * The transition function will be executed when the alert is displayed or hidden.\n\t *\n\t * Depending on the value of `animatedOnInit`, the animation can be optionally skipped during the showing process.\n\t *\n\t * @defaultValue `fadeTransition`\n\t */\n\t@Input('auTransition')\n\ttransition: TransitionFn | undefined;\n\n\t/**\n\t * If `true` the alert is visible to the user\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auVisible', transform: auBooleanAttribute})\n\tvisible: boolean | undefined;\n\n\t/**\n\t * If `true`, alert opening will be animated.\n\t *\n\t * Animation is triggered  when the `.open()` function is called\n\t * or the visible prop is changed\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auAnimatedOnInit', transform: auBooleanAttribute})\n\tanimatedOnInit: boolean | undefined;\n\n\t/**\n\t * If `true`, alert closing will be animated.\n\t *\n\t * Animation is triggered  when clicked on the close button (×),\n\t * via the `.close()` function or the visible prop is changed\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auAnimated', transform: auBooleanAttribute})\n\tanimated: boolean | undefined;\n\n\t/**\n\t * If `true` automatically hides the toast after the delay.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auAutoHide', transform: auBooleanAttribute})\n\tautoHide: boolean | undefined;\n\n\t/**\n\t * Delay in milliseconds before hiding the toast.\n\t *\n\t * @defaultValue `5000`\n\t */\n\t@Input({alias: 'auDelay', transform: auNumberAttribute})\n\tdelay: number | undefined;\n\n\t/**\n\t * Accessibility close button label\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t/**\n\t * Template for the toast content\n\t */\n\t@Input('auChildren') children: SlotContent<ToastContext>;\n\t@ContentChild(ToastBodyDirective, {static: false})\n\tslotDefaultFromContent: ToastBodyDirective | undefined;\n\n\t/**\n\t * Global template for the toast component\n\t */\n\t@Input('auStructure') structure: SlotContent<ToastContext>;\n\t@ContentChild(ToastStructureDirective, {static: false}) slotStructureFromContent: ToastStructureDirective | undefined;\n\n\t/**\n\t * Header template for the toast component\n\t */\n\t@Input('auHeader') header: SlotContent<ToastContext>;\n\t@ContentChild(ToastHeaderDirective, {static: false}) slotHeaderFromContent: ToastHeaderDirective | undefined;\n\n\t/**\n\t * Callback called when the alert visibility changed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n\t/**\n\t * Callback called when the alert is hidden.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auHidden') hidden = new EventEmitter<void>();\n\n\t/**\n\t * Callback called when the alert is shown.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\n\treadonly defaultSlots: WritableSignal<Partial<ToastProps>> = writable(defaultConfig);\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\treadonly _widget = callWidgetFactory({\n\t\tfactory: createToast,\n\t\twidgetName: 'toast',\n\t\tdefaultConfig: this.defaultSlots,\n\t\tevents: {\n\t\t\tonVisibleChange: (event) => this.visibleChange.emit(event),\n\t\t\tonShown: () => this.shown.emit(),\n\t\t\tonHidden: () => this.hidden.emit(),\n\t\t},\n\t});\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tchildren: this.slotDefaultFromContent?.templateRef,\n\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\theader: this.slotHeaderFromContent?.templateRef,\n\t\t});\n\t}\n}\n"]}
323
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ToastComponent, { className: "ToastComponent", filePath: "components/toast/toast.component.ts", lineNumber: 117 }); })();
324
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../src/components/toast/toast.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent, TransitionFn} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDirective,\n\tUseDirective,\n\tUseMultiDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n} from '@agnos-ui/angular-headless';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tinject,\n} from '@angular/core';\nimport {callWidgetFactory} from '../../config';\n\nimport type {ToastContext, ToastWidget} from './toast.gen';\nimport {createToast} from './toast.gen';\n\n/**\n * Directive to represent the body of a toast notification.\n * This directive uses a template reference to render the {@link ToastContext}.\n */\n@Directive({selector: 'ng-template[auToastBody]', standalone: true})\nexport class ToastBodyDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(_dir: ToastBodyDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to define the structure of a toast component.\n * This directive uses a template reference to render the {@link ToastContext}.\n */\n@Directive({selector: 'ng-template[auToastStructure]', standalone: true})\nexport class ToastStructureDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(_dir: ToastStructureDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive representing the header of a toast component.\n * This directive uses a template reference to render the {@link ToastContext}.\n */\n@Directive({selector: 'ng-template[auToastHeader]', standalone: true})\nexport class ToastHeaderDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(_dir: ToastHeaderDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, ToastStructureDirective, UseDirective],\n\ttemplate: ` <ng-template auToastStructure #structure let-state=\"state\" let-api=\"api\" let-directives=\"directives\">\n\t\t@if (state.header()) {\n\t\t\t<div class=\"toast-header\">\n\t\t\t\t<ng-template [auSlot]=\"state.header()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t\t\t\t@if (state.dismissible()) {\n\t\t\t\t\t<button class=\"btn-close me-0 ms-auto\" [auUse]=\"directives.closeButtonDirective\"></button>\n\t\t\t\t}\n\t\t\t</div>\n\t\t}\n\t\t<div class=\"toast-body\">\n\t\t\t<ng-template [auSlot]=\"state.children()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t\t</div>\n\t\t@if (state.dismissible() && !state.header()) {\n\t\t\t<button class=\"btn-close btn-close-white me-2 m-auto\" [auUse]=\"directives.closeButtonDirective\"></button>\n\t\t}\n\t</ng-template>`,\n})\nclass ToastDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<ToastContext>;\n}\n\n/**\n * Represents the default slot structure for the toast component.\n */\nexport const toastDefaultSlotStructure: SlotContent<ToastContext> = new ComponentTemplate(ToastDefaultSlotsComponent, 'structure');\n\n/**\n * The `ToastComponent` is a UI component that displays a toast notification.\n * It extends the `BaseWidgetDirective` and provides various configurable properties\n * and events to control the behavior and appearance of the toast.\n */\n@Component({\n\tselector: '[auToast]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, UseMultiDirective],\n\ttemplate: ` <ng-template #content>\n\t\t\t<ng-content></ng-content>\n\t\t</ng-template>\n\t\t@if (!state.hidden()) {\n\t\t\t<div\n\t\t\t\tclass=\"toast\"\n\t\t\t\t[class.d-flex]=\"!state.header()\"\n\t\t\t\t[class.toast-dismissible]=\"state.dismissible()\"\n\t\t\t\t[auUseMulti]=\"[directives.autoHideDirective, directives.transitionDirective, directives.bodyDirective]\"\n\t\t\t>\n\t\t\t\t<ng-template [auSlot]=\"state.structure()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t\t\t</div>\n\t\t}`,\n})\nexport class ToastComponent extends BaseWidgetDirective<ToastWidget> {\n\t/**\n\t * If `true`, alert can be dismissed by the user.\n\t * The close button (×) will be displayed and you can be notified of the event with the (close) output.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auDismissible', transform: auBooleanAttribute})\n\tdismissible: boolean | undefined;\n\n\t/**\n\t * The transition function will be executed when the alert is displayed or hidden.\n\t *\n\t * Depending on the value of `animatedOnInit`, the animation can be optionally skipped during the showing process.\n\t *\n\t * @defaultValue `fadeTransition`\n\t */\n\t@Input('auTransition')\n\ttransition: TransitionFn | undefined;\n\n\t/**\n\t * If `true` the alert is visible to the user\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auVisible', transform: auBooleanAttribute})\n\tvisible: boolean | undefined;\n\n\t/**\n\t * If `true`, alert opening will be animated.\n\t *\n\t * Animation is triggered  when the `.open()` function is called\n\t * or the visible prop is changed\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auAnimatedOnInit', transform: auBooleanAttribute})\n\tanimatedOnInit: boolean | undefined;\n\n\t/**\n\t * If `true`, alert closing will be animated.\n\t *\n\t * Animation is triggered  when clicked on the close button (×),\n\t * via the `.close()` function or the visible prop is changed\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auAnimated', transform: auBooleanAttribute})\n\tanimated: boolean | undefined;\n\n\t/**\n\t * If `true` automatically hides the toast after the delay.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auAutoHide', transform: auBooleanAttribute})\n\tautoHide: boolean | undefined;\n\n\t/**\n\t * Delay in milliseconds before hiding the toast.\n\t *\n\t * @defaultValue `5000`\n\t */\n\t@Input({alias: 'auDelay', transform: auNumberAttribute})\n\tdelay: number | undefined;\n\n\t/**\n\t * Accessibility close button label\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t/**\n\t * Template for the toast content\n\t */\n\t@Input('auChildren') children: SlotContent<ToastContext>;\n\t@ContentChild(ToastBodyDirective, {static: false})\n\tslotDefaultFromContent: ToastBodyDirective | undefined;\n\n\t/**\n\t * Global template for the toast component\n\t */\n\t@Input('auStructure') structure: SlotContent<ToastContext>;\n\t@ContentChild(ToastStructureDirective, {static: false}) slotStructureFromContent: ToastStructureDirective | undefined;\n\n\t/**\n\t * Header template for the toast component\n\t */\n\t@Input('auHeader') header: SlotContent<ToastContext>;\n\t@ContentChild(ToastHeaderDirective, {static: false}) slotHeaderFromContent: ToastHeaderDirective | undefined;\n\n\t/**\n\t * Callback called when the alert visibility changed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n\t/**\n\t * Callback called when the alert is hidden.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auHidden') hidden = new EventEmitter<void>();\n\n\t/**\n\t * Callback called when the alert is shown.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\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@ViewChild('content', {static: true})\n\tslotChildren?: TemplateRef<void>;\n\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory({\n\t\t\t\tfactory: createToast,\n\t\t\t\twidgetName: 'toast',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\tstructure: toastDefaultSlotStructure,\n\t\t\t\t},\n\t\t\t\tevents: {\n\t\t\t\t\tonVisibleChange: (event) => this.visibleChange.emit(event),\n\t\t\t\t\tonShown: () => this.shown.emit(),\n\t\t\t\t\tonHidden: () => this.hidden.emit(),\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tchildren: this.slotDefaultFromContent?.templateRef,\n\t\t\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\t\t\theader: this.slotHeaderFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t\tslotChildren: () => this.slotChildren,\n\t\t\t}),\n\t\t);\n\t}\n}\n"]}
@@ -12,4 +12,4 @@ export { export_getToastDefaultConfig as getToastDefaultConfig };
12
12
  */
13
13
  const export_createToast = createToast;
14
14
  export { export_createToast as createToast };
15
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.gen.js","sourceRoot":"","sources":["../../../../src/components/toast/toast.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,qBAAqB,EAAE,WAAW,EAAC,MAAM,2CAA2C,CAAC;AAK7F;;;GAGG;AACH,MAAM,4BAA4B,GAAqB,qBAA4B,CAAC;AACpF,OAAO,EAAC,4BAA4B,IAAI,qBAAqB,EAAC,CAAC;AA2M/D;;;;GAIG;AACH,MAAM,kBAAkB,GAA+B,WAAkB,CAAC;AAC1E,OAAO,EAAC,kBAAkB,IAAI,WAAW,EAAC,CAAC","sourcesContent":["import {getToastDefaultConfig, createToast} from '@agnos-ui/core-bootstrap/components/toast';\nimport type {WidgetSlotContext, SlotContent, TransitionFn, Widget, WidgetFactory, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default Toast config\n * @returns the default Toast config\n */\nconst export_getToastDefaultConfig: () => ToastProps = getToastDefaultConfig as any;\nexport {export_getToastDefaultConfig as getToastDefaultConfig};\n\n\n\nexport type ToastContext = WidgetSlotContext<ToastWidget>;\n\nexport interface ToastState {\n\t\n\t/**\n\t * Is `true` when the alert is hidden. Compared to `visible`, this is updated after the transition is executed.\n\t */\n\thidden: boolean;\n\t\n\t/**\n\t * If `true`, alert can be dismissed by the user.\n\t * The close button (×) will be displayed and you can be notified of the event with the (close) output.\n\t *\n\t * @defaultValue `true`\n\t */\n\tdismissible: boolean;\n\t\n\t/**\n\t * If `true` the alert is visible to the user\n\t *\n\t * @defaultValue `true`\n\t */\n\tvisible: boolean;\n\t\n\n\t/**\n\t * Accessibility close button label\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\tariaCloseButtonLabel: 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 * If `true` automatically hides the toast after the delay.\n\t *\n\t * @defaultValue `true`\n\t */\n\tautoHide: boolean;\n\t\n\t/**\n\t * Delay in milliseconds before hiding the toast.\n\t *\n\t * @defaultValue `5000`\n\t */\n\tdelay: number;\n\t\n\t/**\n\t * Global template for the toast component\n\t */\n\tstructure: SlotContent<ToastContext>;\n\t\n\t/**\n\t * Template for the toast content\n\t */\n\tchildren: SlotContent<ToastContext>;\n\t\n\t/**\n\t * Header template for the toast component\n\t */\n\theader: SlotContent<ToastContext>;\n}\n\nexport interface ToastProps {\n\t\n\t/**\n\t * The transition function will be executed when the alert is displayed or hidden.\n\t *\n\t * Depending on the value of `animatedOnInit`, the animation can be optionally skipped during the showing process.\n\t *\n\t * @defaultValue `fadeTransition`\n\t */\n\ttransition: TransitionFn;\n\t\n\t/**\n\t * Callback called when the alert visibility changed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonVisibleChange: (visible: boolean) => void;\n\t\n\n\t/**\n\t * Callback called when the alert is hidden.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonHidden: () => void;\n\t\n\n\t/**\n\t * Callback called when the alert is shown.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonShown: () => void;\n\t\n\n\t/**\n\t * If `true`, alert opening will be animated.\n\t *\n\t * Animation is triggered  when the `.open()` function is called\n\t * or the visible prop is changed\n\t *\n\t * @defaultValue `false`\n\t */\n\tanimatedOnInit: boolean;\n\t\n\t/**\n\t * If `true`, alert closing will be animated.\n\t *\n\t * Animation is triggered  when clicked on the close button (×),\n\t * via the `.close()` function or the visible prop is changed\n\t *\n\t * @defaultValue `true`\n\t */\n\tanimated: boolean;\n\t\n\t/**\n\t * If `true`, alert can be dismissed by the user.\n\t * The close button (×) will be displayed and you can be notified of the event with the (close) output.\n\t *\n\t * @defaultValue `true`\n\t */\n\tdismissible: boolean;\n\t\n\t/**\n\t * If `true` the alert is visible to the user\n\t *\n\t * @defaultValue `true`\n\t */\n\tvisible: boolean;\n\t\n\n\t/**\n\t * Accessibility close button label\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\tariaCloseButtonLabel: 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 * If `true` automatically hides the toast after the delay.\n\t *\n\t * @defaultValue `true`\n\t */\n\tautoHide: boolean;\n\t\n\t/**\n\t * Delay in milliseconds before hiding the toast.\n\t *\n\t * @defaultValue `5000`\n\t */\n\tdelay: number;\n\t\n\t/**\n\t * Global template for the toast component\n\t */\n\tstructure: SlotContent<ToastContext>;\n\t\n\t/**\n\t * Template for the toast content\n\t */\n\tchildren: SlotContent<ToastContext>;\n\t\n\t/**\n\t * Header template for the toast component\n\t */\n\theader: SlotContent<ToastContext>;\n}\n\n\n\nexport type ToastWidget = Widget<ToastProps, ToastState, ToastApi, object, ToastDirectives>;\n\n\n\n/**\n * Create an ToastWidget with given config props\n * @param config - an optional alert config\n * @returns an ToastWidget\n */\nconst export_createToast: WidgetFactory<ToastWidget> = createToast as any;\nexport {export_createToast as createToast};\n\nexport interface ToastApi {\n\t\n\t/**\n\t * Triggers alert closing programmatically (same as clicking on the close button (×)).\n\t */\n\tclose(): void;\n\t\n\n\t/**\n\t * Triggers the alert to be displayed for the user.\n\t */\n\topen(): void;\n}\n\nexport interface ToastDirectives {\n\t\n\t/**\n\t * the transition directive, piloting what is the visual effect of going from hidden to visible\n\t */\n\ttransitionDirective: Directive;\n\t\n\t/**\n\t * Directive that handles the autohide of the toast component\n\t */\n\tautoHideDirective: Directive;\n\t\n\t/**\n\t * Directive that adds all the necessary attributes to the body\n\t */\n\tbodyDirective: Directive;\n\t\n\t/**\n\t * Directive that adds all the necessary attributes to the close button depending on the presence of the header\n\t */\n\tcloseButtonDirective: Directive;\n}\n\n"]}
15
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.gen.js","sourceRoot":"","sources":["../../../../src/components/toast/toast.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,qBAAqB,EAAE,WAAW,EAAC,MAAM,2CAA2C,CAAC;AAK7F;;;GAGG;AACH,MAAM,4BAA4B,GAAqB,qBAA4B,CAAC;AACpF,OAAO,EAAC,4BAA4B,IAAI,qBAAqB,EAAC,CAAC;AAwN/D;;;;GAIG;AACH,MAAM,kBAAkB,GAA+B,WAAkB,CAAC;AAC1E,OAAO,EAAC,kBAAkB,IAAI,WAAW,EAAC,CAAC","sourcesContent":["import {getToastDefaultConfig, createToast} from '@agnos-ui/core-bootstrap/components/toast';\nimport type {WidgetSlotContext, SlotContent, TransitionFn, Widget, WidgetFactory, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default Toast config\n * @returns the default Toast config\n */\nconst export_getToastDefaultConfig: () => ToastProps = getToastDefaultConfig as any;\nexport {export_getToastDefaultConfig as getToastDefaultConfig};\n\n\n\n/**\n * Represents the context for a Toast widget.\n * This interface is an alias for `WidgetSlotContext<ToastWidget>`.\n */\nexport interface ToastContext extends WidgetSlotContext<ToastWidget> {}\n\n/**\n * Represents the state of a Toast component.\n */\nexport interface ToastState {\n\t\n\t/**\n\t * Is `true` when the alert is hidden. Compared to `visible`, this is updated after the transition is executed.\n\t */\n\thidden: boolean;\n\t\n\t/**\n\t * If `true`, alert can be dismissed by the user.\n\t * The close button (×) will be displayed and you can be notified of the event with the (close) output.\n\t *\n\t * @defaultValue `true`\n\t */\n\tdismissible: boolean;\n\t\n\t/**\n\t * If `true` the alert is visible to the user\n\t *\n\t * @defaultValue `true`\n\t */\n\tvisible: boolean;\n\t\n\n\t/**\n\t * Accessibility close button label\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\tariaCloseButtonLabel: 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 * If `true` automatically hides the toast after the delay.\n\t *\n\t * @defaultValue `true`\n\t */\n\tautoHide: boolean;\n\t\n\t/**\n\t * Delay in milliseconds before hiding the toast.\n\t *\n\t * @defaultValue `5000`\n\t */\n\tdelay: number;\n\t\n\t/**\n\t * Global template for the toast component\n\t */\n\tstructure: SlotContent<ToastContext>;\n\t\n\t/**\n\t * Template for the toast content\n\t */\n\tchildren: SlotContent<ToastContext>;\n\t\n\t/**\n\t * Header template for the toast component\n\t */\n\theader: SlotContent<ToastContext>;\n}\n\n/**\n * Interface representing the properties for the Toast component.\n */\nexport interface ToastProps {\n\t\n\t/**\n\t * The transition function will be executed when the alert is displayed or hidden.\n\t *\n\t * Depending on the value of `animatedOnInit`, the animation can be optionally skipped during the showing process.\n\t *\n\t * @defaultValue `fadeTransition`\n\t */\n\ttransition: TransitionFn;\n\t\n\t/**\n\t * Callback called when the alert visibility changed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonVisibleChange: (visible: boolean) => void;\n\t\n\n\t/**\n\t * Callback called when the alert is hidden.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonHidden: () => void;\n\t\n\n\t/**\n\t * Callback called when the alert is shown.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonShown: () => void;\n\t\n\n\t/**\n\t * If `true`, alert opening will be animated.\n\t *\n\t * Animation is triggered  when the `.open()` function is called\n\t * or the visible prop is changed\n\t *\n\t * @defaultValue `false`\n\t */\n\tanimatedOnInit: boolean;\n\t\n\t/**\n\t * If `true`, alert closing will be animated.\n\t *\n\t * Animation is triggered  when clicked on the close button (×),\n\t * via the `.close()` function or the visible prop is changed\n\t *\n\t * @defaultValue `true`\n\t */\n\tanimated: boolean;\n\t\n\t/**\n\t * If `true`, alert can be dismissed by the user.\n\t * The close button (×) will be displayed and you can be notified of the event with the (close) output.\n\t *\n\t * @defaultValue `true`\n\t */\n\tdismissible: boolean;\n\t\n\t/**\n\t * If `true` the alert is visible to the user\n\t *\n\t * @defaultValue `true`\n\t */\n\tvisible: boolean;\n\t\n\n\t/**\n\t * Accessibility close button label\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\tariaCloseButtonLabel: 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 * If `true` automatically hides the toast after the delay.\n\t *\n\t * @defaultValue `true`\n\t */\n\tautoHide: boolean;\n\t\n\t/**\n\t * Delay in milliseconds before hiding the toast.\n\t *\n\t * @defaultValue `5000`\n\t */\n\tdelay: number;\n\t\n\t/**\n\t * Global template for the toast component\n\t */\n\tstructure: SlotContent<ToastContext>;\n\t\n\t/**\n\t * Template for the toast content\n\t */\n\tchildren: SlotContent<ToastContext>;\n\t\n\t/**\n\t * Header template for the toast component\n\t */\n\theader: SlotContent<ToastContext>;\n}\n\n\n\n/**\n * Represents a Toast widget component.\n */\nexport type ToastWidget = Widget<ToastProps, ToastState, ToastApi, ToastDirectives>;\n\n\n\n/**\n * Create an ToastWidget with given config props\n * @param config - an optional alert config\n * @returns an ToastWidget\n */\nconst export_createToast: WidgetFactory<ToastWidget> = createToast as any;\nexport {export_createToast as createToast};\n\n/**\n * Represents the API for the toast component.\n */\nexport interface ToastApi {\n\t\n\t/**\n\t * Triggers alert closing programmatically (same as clicking on the close button (×)).\n\t */\n\tclose(): void;\n\t\n\n\t/**\n\t * Triggers the alert to be displayed for the user.\n\t */\n\topen(): void;\n}\n\n/**\n * Interface representing the directives for a toast component.\n */\nexport interface ToastDirectives {\n\t\n\t/**\n\t * the transition directive, piloting what is the visual effect of going from hidden to visible\n\t */\n\ttransitionDirective: Directive;\n\t\n\t/**\n\t * Directive that handles the autohide of the toast component\n\t */\n\tautoHideDirective: Directive;\n\t\n\t/**\n\t * Directive that adds all the necessary attributes to the body\n\t */\n\tbodyDirective: Directive;\n\t\n\t/**\n\t * Directive that adds all the necessary attributes to the close button depending on the presence of the header\n\t */\n\tcloseButtonDirective: Directive;\n}\n\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmdlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7QWNjb3JkaW9uUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9hY2NvcmRpb24nO1xuaW1wb3J0IHR5cGUge0FsZXJ0UHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9hbGVydCc7XG5pbXBvcnQgdHlwZSB7TW9kYWxQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL21vZGFsJztcbmltcG9ydCB0eXBlIHtQYWdpbmF0aW9uUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9wYWdpbmF0aW9uJztcbmltcG9ydCB0eXBlIHtQcm9ncmVzc2JhclByb3BzfSBmcm9tICcuL2NvbXBvbmVudHMvcHJvZ3Jlc3NiYXInO1xuaW1wb3J0IHR5cGUge1JhdGluZ1Byb3BzfSBmcm9tICcuL2NvbXBvbmVudHMvcmF0aW5nJztcbmltcG9ydCB0eXBlIHtTZWxlY3RQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL3NlbGVjdCc7XG5pbXBvcnQgdHlwZSB7U2xpZGVyUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9zbGlkZXInO1xuaW1wb3J0IHR5cGUge1RvYXN0UHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy90b2FzdCc7XG5cbmV4cG9ydCB0eXBlIFdpZGdldHNDb25maWcgPSB7XG5cdC8qKlxuXHQgKiB0aGUgYWNjb3JkaW9uIHdpZGdldCBjb25maWdcblx0ICovXG5cdGFjY29yZGlvbjogQWNjb3JkaW9uUHJvcHM7XG5cdC8qKlxuXHQgKiB0aGUgYWxlcnQgd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0YWxlcnQ6IEFsZXJ0UHJvcHM7XG5cdC8qKlxuXHQgKiB0aGUgbW9kYWwgd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0bW9kYWw6IE1vZGFsUHJvcHM8YW55Pjtcblx0LyoqXG5cdCAqIHRoZSBwYWdpbmF0aW9uIHdpZGdldCBjb25maWdcblx0ICovXG5cdHBhZ2luYXRpb246IFBhZ2luYXRpb25Qcm9wcztcblx0LyoqXG5cdCAqIHRoZSBwcm9ncmVzc2JhciB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRwcm9ncmVzc2JhcjogUHJvZ3Jlc3NiYXJQcm9wcztcblx0LyoqXG5cdCAqIHRoZSByYXRpbmcgd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0cmF0aW5nOiBSYXRpbmdQcm9wcztcblx0LyoqXG5cdCAqIHRoZSBzZWxlY3Qgd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0c2VsZWN0OiBTZWxlY3RQcm9wczxhbnk+O1xuXHQvKipcblx0ICogdGhlIHNsaWRlciB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRzbGlkZXI6IFNsaWRlclByb3BzO1xuXHQvKipcblx0ICogdGhlIHRvYXN0IHdpZGdldCBjb25maWdcblx0ICovXG5cdHRvYXN0OiBUb2FzdFByb3BzO1xufVxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmdlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7QWNjb3JkaW9uUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9hY2NvcmRpb24nO1xuaW1wb3J0IHR5cGUge0FsZXJ0UHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9hbGVydCc7XG5pbXBvcnQgdHlwZSB7Q29sbGFwc2VQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL2NvbGxhcHNlJztcbmltcG9ydCB0eXBlIHtNb2RhbFByb3BzfSBmcm9tICcuL2NvbXBvbmVudHMvbW9kYWwnO1xuaW1wb3J0IHR5cGUge1BhZ2luYXRpb25Qcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL3BhZ2luYXRpb24nO1xuaW1wb3J0IHR5cGUge1Byb2dyZXNzYmFyUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9wcm9ncmVzc2Jhcic7XG5pbXBvcnQgdHlwZSB7UmF0aW5nUHJvcHN9IGZyb20gJy4vY29tcG9uZW50cy9yYXRpbmcnO1xuaW1wb3J0IHR5cGUge1NlbGVjdFByb3BzfSBmcm9tICcuL2NvbXBvbmVudHMvc2VsZWN0JztcbmltcG9ydCB0eXBlIHtTbGlkZXJQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL3NsaWRlcic7XG5pbXBvcnQgdHlwZSB7VG9hc3RQcm9wc30gZnJvbSAnLi9jb21wb25lbnRzL3RvYXN0JztcblxuZXhwb3J0IHR5cGUgV2lkZ2V0c0NvbmZpZyA9IHtcblx0LyoqXG5cdCAqIHRoZSBhY2NvcmRpb24gd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0YWNjb3JkaW9uOiBBY2NvcmRpb25Qcm9wcztcblx0LyoqXG5cdCAqIHRoZSBhbGVydCB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRhbGVydDogQWxlcnRQcm9wcztcblx0LyoqXG5cdCAqIHRoZSBjb2xsYXBzZSB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRjb2xsYXBzZTogQ29sbGFwc2VQcm9wcztcblx0LyoqXG5cdCAqIHRoZSBtb2RhbCB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRtb2RhbDogTW9kYWxQcm9wczxhbnk+O1xuXHQvKipcblx0ICogdGhlIHBhZ2luYXRpb24gd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0cGFnaW5hdGlvbjogUGFnaW5hdGlvblByb3BzO1xuXHQvKipcblx0ICogdGhlIHByb2dyZXNzYmFyIHdpZGdldCBjb25maWdcblx0ICovXG5cdHByb2dyZXNzYmFyOiBQcm9ncmVzc2JhclByb3BzO1xuXHQvKipcblx0ICogdGhlIHJhdGluZyB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRyYXRpbmc6IFJhdGluZ1Byb3BzO1xuXHQvKipcblx0ICogdGhlIHNlbGVjdCB3aWRnZXQgY29uZmlnXG5cdCAqL1xuXHRzZWxlY3Q6IFNlbGVjdFByb3BzPGFueT47XG5cdC8qKlxuXHQgKiB0aGUgc2xpZGVyIHdpZGdldCBjb25maWdcblx0ICovXG5cdHNsaWRlcjogU2xpZGVyUHJvcHM7XG5cdC8qKlxuXHQgKiB0aGUgdG9hc3Qgd2lkZ2V0IGNvbmZpZ1xuXHQgKi9cblx0dG9hc3Q6IFRvYXN0UHJvcHM7XG59XG4iXX0=
@@ -1,5 +1,21 @@
1
1
  import { widgetsConfigFactory } from '@agnos-ui/angular-headless';
2
2
  import { InjectionToken } from '@angular/core';
3
+ /**
4
+ * @param factory - The widget factory.
5
+ * @param widgetName - The name of the widget.
6
+ * @param defaultConfig - The default configuration for the widget.
7
+ * @param events - The events for the widget.
8
+ * @param afterInit - The function to call after initialization.
9
+ */
3
10
  const widgetFactories = widgetsConfigFactory(new InjectionToken('bootstrapWidgetsConfig'));
11
+ /**
12
+ * Destructures and exports several functions and constants from the `widgetFactories` object.
13
+ *
14
+ * @constant {InjectionToken} widgetsConfigInjectionToken - Token used for injecting widget configuration.
15
+ * @function provideWidgetsConfig - Provides the widget configuration.
16
+ * @function injectWidgetConfig - Injects a single widget configuration.
17
+ * @function injectWidgetsConfig - Injects multiple widget configurations.
18
+ * @function callWidgetFactory - Calls the widget factory function.
19
+ */
4
20
  export const { widgetsConfigInjectionToken, provideWidgetsConfig, injectWidgetConfig, injectWidgetsConfig, callWidgetFactory } = widgetFactories;
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUloRSxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBUTdDLE1BQU0sZUFBZSxHQWtCakIsb0JBQW9CLENBQWdCLElBQUksY0FBYyxDQUFvQyx3QkFBd0IsQ0FBQyxDQUFDLENBQUM7QUFDekgsTUFBTSxDQUFDLE1BQU0sRUFBQywyQkFBMkIsRUFBRSxvQkFBb0IsRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxpQkFBaUIsRUFBQyxHQUFHLGVBQWUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtBbmd1bGFyV2lkZ2V0LCBQYXJ0aWFsMkxldmVscywgV2lkZ2V0LCBXaWRnZXRGYWN0b3J5LCBXaWRnZXRQcm9wcywgV2lkZ2V0c0NvbmZpZ1N0b3JlfSBmcm9tICdAYWdub3MtdWkvYW5ndWxhci1oZWFkbGVzcyc7XG5pbXBvcnQge3dpZGdldHNDb25maWdGYWN0b3J5fSBmcm9tICdAYWdub3MtdWkvYW5ndWxhci1oZWFkbGVzcyc7XG5pbXBvcnQgdHlwZSB7Qm9vdHN0cmFwV2lkZ2V0c0NvbmZpZ30gZnJvbSAnQGFnbm9zLXVpL2NvcmUtYm9vdHN0cmFwL2NvbmZpZyc7XG5pbXBvcnQgdHlwZSB7UmVhZGFibGVTaWduYWx9IGZyb20gJ0BhbWFkZXVzLWl0LWdyb3VwL3RhbnN1JztcbmltcG9ydCB0eXBlIHtGYWN0b3J5UHJvdmlkZXJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtJbmplY3Rpb25Ub2tlbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB0eXBlIHtXaWRnZXRzQ29uZmlnfSBmcm9tICcuL2NvbmZpZy5nZW4nO1xuZXhwb3J0IHR5cGUge1dpZGdldHNDb25maWd9O1xuXG50eXBlIEFkYXB0UGFyZW50Q29uZmlnID0gKGNvbmZpZzogUGFydGlhbDJMZXZlbHM8V2lkZ2V0c0NvbmZpZz4pID0+IFBhcnRpYWwyTGV2ZWxzPFdpZGdldHNDb25maWc+O1xudHlwZSBJbmplY3RXaWRnZXRzQ29uZmlnID0gKGNvbmZpZz86IFBhcnRpYWwyTGV2ZWxzPFdpZGdldHNDb25maWc+KSA9PiBXaWRnZXRzQ29uZmlnU3RvcmU8V2lkZ2V0c0NvbmZpZz47XG5cbmNvbnN0IHdpZGdldEZhY3Rvcmllczoge1xuXHR3aWRnZXRzQ29uZmlnSW5qZWN0aW9uVG9rZW46IEluamVjdGlvblRva2VuPFdpZGdldHNDb25maWdTdG9yZTxXaWRnZXRzQ29uZmlnPj47XG5cdHByb3ZpZGVXaWRnZXRzQ29uZmlnOiAoYWRhcHRQYXJlbnRDb25maWc/OiBBZGFwdFBhcmVudENvbmZpZyB8IHVuZGVmaW5lZCkgPT4gRmFjdG9yeVByb3ZpZGVyO1xuXHRpbmplY3RXaWRnZXRDb25maWc6IDxOIGV4dGVuZHMga2V5b2YgQm9vdHN0cmFwV2lkZ2V0c0NvbmZpZz4od2lkZ2V0TmFtZTogTikgPT4gUmVhZGFibGVTaWduYWw8UGFydGlhbDxXaWRnZXRzQ29uZmlnW05dPiB8IHVuZGVmaW5lZD47XG5cdGluamVjdFdpZGdldHNDb25maWc6IEluamVjdFdpZGdldHNDb25maWc7XG5cdGNhbGxXaWRnZXRGYWN0b3J5OiA8VyBleHRlbmRzIFdpZGdldDxvYmplY3QsIG9iamVjdCwgb2JqZWN0LCBvYmplY3QsIG9iamVjdD4+KHtcblx0XHRmYWN0b3J5LFxuXHRcdHdpZGdldE5hbWUsXG5cdFx0ZGVmYXVsdENvbmZpZyxcblx0XHRldmVudHMsXG5cdFx0YWZ0ZXJJbml0LFxuXHR9OiB7XG5cdFx0ZmFjdG9yeTogV2lkZ2V0RmFjdG9yeTxXPjtcblx0XHR3aWRnZXROYW1lPzoga2V5b2YgQm9vdHN0cmFwV2lkZ2V0c0NvbmZpZyB8IG51bGwgfCB1bmRlZmluZWQ7XG5cdFx0ZGVmYXVsdENvbmZpZz86IFBhcnRpYWw8V2lkZ2V0UHJvcHM8Vz4+IHwgUmVhZGFibGVTaWduYWw8UGFydGlhbDxXaWRnZXRQcm9wczxXPj4gfCB1bmRlZmluZWQ+IHwgdW5kZWZpbmVkO1xuXHRcdGV2ZW50cz86IFBpY2s8V2lkZ2V0UHJvcHM8Vz4sIGtleW9mIFdpZGdldFByb3BzPFc+ICYgYG9uJHtzdHJpbmd9YD47XG5cdFx0YWZ0ZXJJbml0PzogKCgpID0+IHZvaWQpIHwgdW5kZWZpbmVkO1xuXHR9KSA9PiBBbmd1bGFyV2lkZ2V0PFc+O1xufSA9IHdpZGdldHNDb25maWdGYWN0b3J5PFdpZGdldHNDb25maWc+KG5ldyBJbmplY3Rpb25Ub2tlbjxXaWRnZXRzQ29uZmlnU3RvcmU8V2lkZ2V0c0NvbmZpZz4+KCdib290c3RyYXBXaWRnZXRzQ29uZmlnJykpO1xuZXhwb3J0IGNvbnN0IHt3aWRnZXRzQ29uZmlnSW5qZWN0aW9uVG9rZW4sIHByb3ZpZGVXaWRnZXRzQ29uZmlnLCBpbmplY3RXaWRnZXRDb25maWcsIGluamVjdFdpZGdldHNDb25maWcsIGNhbGxXaWRnZXRGYWN0b3J5fSA9IHdpZGdldEZhY3RvcmllcztcbiJdfQ==
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVQSxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUloRSxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBUTdDOzs7Ozs7R0FNRztBQUNILE1BQU0sZUFBZSxHQTBCakIsb0JBQW9CLENBQWdCLElBQUksY0FBYyxDQUFvQyx3QkFBd0IsQ0FBQyxDQUFRLENBQUM7QUFFaEk7Ozs7Ozs7O0dBUUc7QUFDSCxNQUFNLENBQUMsTUFBTSxFQUFDLDJCQUEyQixFQUFFLG9CQUFvQixFQUFFLGtCQUFrQixFQUFFLG1CQUFtQixFQUFFLGlCQUFpQixFQUFDLEdBQUcsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuXHRBbmd1bGFyV2lkZ2V0LFxuXHRJc1Nsb3RDb250ZW50LFxuXHRQYXJ0aWFsMkxldmVscyxcblx0U2xvdENvbnRlbnQsXG5cdFdpZGdldCxcblx0V2lkZ2V0RmFjdG9yeSxcblx0V2lkZ2V0UHJvcHMsXG5cdFdpZGdldHNDb25maWdTdG9yZSxcbn0gZnJvbSAnQGFnbm9zLXVpL2FuZ3VsYXItaGVhZGxlc3MnO1xuaW1wb3J0IHt3aWRnZXRzQ29uZmlnRmFjdG9yeX0gZnJvbSAnQGFnbm9zLXVpL2FuZ3VsYXItaGVhZGxlc3MnO1xuaW1wb3J0IHR5cGUge0Jvb3RzdHJhcFdpZGdldHNDb25maWd9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb25maWcnO1xuaW1wb3J0IHR5cGUge1JlYWRhYmxlU2lnbmFsfSBmcm9tICdAYW1hZGV1cy1pdC1ncm91cC90YW5zdSc7XG5pbXBvcnQgdHlwZSB7RmFjdG9yeVByb3ZpZGVyLCBUZW1wbGF0ZVJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0luamVjdGlvblRva2VufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHR5cGUge1dpZGdldHNDb25maWd9IGZyb20gJy4vY29uZmlnLmdlbic7XG5leHBvcnQgdHlwZSB7V2lkZ2V0c0NvbmZpZ307XG5cbnR5cGUgQWRhcHRQYXJlbnRDb25maWcgPSAoY29uZmlnOiBQYXJ0aWFsMkxldmVsczxXaWRnZXRzQ29uZmlnPikgPT4gUGFydGlhbDJMZXZlbHM8V2lkZ2V0c0NvbmZpZz47XG50eXBlIEluamVjdFdpZGdldHNDb25maWcgPSAoY29uZmlnPzogUGFydGlhbDJMZXZlbHM8V2lkZ2V0c0NvbmZpZz4pID0+IFdpZGdldHNDb25maWdTdG9yZTxXaWRnZXRzQ29uZmlnPjtcblxuLyoqXG4gKiBAcGFyYW0gZmFjdG9yeSAtIFRoZSB3aWRnZXQgZmFjdG9yeS5cbiAqIEBwYXJhbSB3aWRnZXROYW1lIC0gVGhlIG5hbWUgb2YgdGhlIHdpZGdldC5cbiAqIEBwYXJhbSBkZWZhdWx0Q29uZmlnIC0gVGhlIGRlZmF1bHQgY29uZmlndXJhdGlvbiBmb3IgdGhlIHdpZGdldC5cbiAqIEBwYXJhbSBldmVudHMgLSBUaGUgZXZlbnRzIGZvciB0aGUgd2lkZ2V0LlxuICogQHBhcmFtIGFmdGVySW5pdCAtIFRoZSBmdW5jdGlvbiB0byBjYWxsIGFmdGVyIGluaXRpYWxpemF0aW9uLlxuICovXG5jb25zdCB3aWRnZXRGYWN0b3JpZXM6IHtcblx0d2lkZ2V0c0NvbmZpZ0luamVjdGlvblRva2VuOiBJbmplY3Rpb25Ub2tlbjxXaWRnZXRzQ29uZmlnU3RvcmU8V2lkZ2V0c0NvbmZpZz4+O1xuXHRwcm92aWRlV2lkZ2V0c0NvbmZpZzogKGFkYXB0UGFyZW50Q29uZmlnPzogQWRhcHRQYXJlbnRDb25maWcpID0+IEZhY3RvcnlQcm92aWRlcjtcblx0aW5qZWN0V2lkZ2V0Q29uZmlnOiA8TiBleHRlbmRzIGtleW9mIEJvb3RzdHJhcFdpZGdldHNDb25maWc+KHdpZGdldE5hbWU6IE4pID0+IFJlYWRhYmxlU2lnbmFsPFBhcnRpYWw8V2lkZ2V0c0NvbmZpZ1tOXT4gfCB1bmRlZmluZWQ+O1xuXHRpbmplY3RXaWRnZXRzQ29uZmlnOiBJbmplY3RXaWRnZXRzQ29uZmlnO1xuXHRjYWxsV2lkZ2V0RmFjdG9yeTogPFcgZXh0ZW5kcyBXaWRnZXQ8b2JqZWN0LCBvYmplY3QsIG9iamVjdCwgb2JqZWN0Pj4oe1xuXHRcdGZhY3RvcnksXG5cdFx0d2lkZ2V0TmFtZSxcblx0XHRkZWZhdWx0Q29uZmlnLFxuXHRcdGV2ZW50cyxcblx0XHRhZnRlckluaXQsXG5cdFx0c2xvdFRlbXBsYXRlcyxcblx0XHRzbG90Q2hpbGRyZW4sXG5cdH06IHtcblx0XHRmYWN0b3J5OiBXaWRnZXRGYWN0b3J5PFc+O1xuXHRcdHdpZGdldE5hbWU/OiBrZXlvZiBCb290c3RyYXBXaWRnZXRzQ29uZmlnIHwgbnVsbCB8IHVuZGVmaW5lZDtcblx0XHRkZWZhdWx0Q29uZmlnPzogUGFydGlhbDxXaWRnZXRQcm9wczxXPj4gfCBSZWFkYWJsZVNpZ25hbDxQYXJ0aWFsPFdpZGdldFByb3BzPFc+PiB8IHVuZGVmaW5lZD4gfCB1bmRlZmluZWQ7XG5cdFx0ZXZlbnRzPzogUGFydGlhbDxQaWNrPFdpZGdldFByb3BzPFc+LCBrZXlvZiBXaWRnZXRQcm9wczxXPiAmIGBvbiR7c3RyaW5nfWA+Pjtcblx0XHRhZnRlckluaXQ/OiAod2lkZ2V0OiBBbmd1bGFyV2lkZ2V0PFc+KSA9PiB2b2lkO1xuXHRcdHNsb3RUZW1wbGF0ZXM/OiAoKSA9PiB7XG5cdFx0XHRbSyBpbiBrZXlvZiBXaWRnZXRQcm9wczxXPiBhcyBJc1Nsb3RDb250ZW50PFdpZGdldFByb3BzPFc+W0tdPiBleHRlbmRzIDAgPyBuZXZlciA6IEtdOiBXaWRnZXRQcm9wczxXPltLXSBleHRlbmRzIFNsb3RDb250ZW50PGluZmVyIFU+XG5cdFx0XHRcdD8gVGVtcGxhdGVSZWY8VT4gfCB1bmRlZmluZWRcblx0XHRcdFx0OiBuZXZlcjtcblx0XHR9O1xuXHRcdHNsb3RDaGlsZHJlbj86ICgpID0+IFRlbXBsYXRlUmVmPHZvaWQ+IHwgdW5kZWZpbmVkO1xuXHR9KSA9PiBBbmd1bGFyV2lkZ2V0PFc+O1xufSA9IHdpZGdldHNDb25maWdGYWN0b3J5PFdpZGdldHNDb25maWc+KG5ldyBJbmplY3Rpb25Ub2tlbjxXaWRnZXRzQ29uZmlnU3RvcmU8V2lkZ2V0c0NvbmZpZz4+KCdib290c3RyYXBXaWRnZXRzQ29uZmlnJykpIGFzIGFueTtcblxuLyoqXG4gKiBEZXN0cnVjdHVyZXMgYW5kIGV4cG9ydHMgc2V2ZXJhbCBmdW5jdGlvbnMgYW5kIGNvbnN0YW50cyBmcm9tIHRoZSBgd2lkZ2V0RmFjdG9yaWVzYCBvYmplY3QuXG4gKlxuICogQGNvbnN0YW50IHtJbmplY3Rpb25Ub2tlbn0gd2lkZ2V0c0NvbmZpZ0luamVjdGlvblRva2VuIC0gVG9rZW4gdXNlZCBmb3IgaW5qZWN0aW5nIHdpZGdldCBjb25maWd1cmF0aW9uLlxuICogQGZ1bmN0aW9uIHByb3ZpZGVXaWRnZXRzQ29uZmlnIC0gUHJvdmlkZXMgdGhlIHdpZGdldCBjb25maWd1cmF0aW9uLlxuICogQGZ1bmN0aW9uIGluamVjdFdpZGdldENvbmZpZyAtIEluamVjdHMgYSBzaW5nbGUgd2lkZ2V0IGNvbmZpZ3VyYXRpb24uXG4gKiBAZnVuY3Rpb24gaW5qZWN0V2lkZ2V0c0NvbmZpZyAtIEluamVjdHMgbXVsdGlwbGUgd2lkZ2V0IGNvbmZpZ3VyYXRpb25zLlxuICogQGZ1bmN0aW9uIGNhbGxXaWRnZXRGYWN0b3J5IC0gQ2FsbHMgdGhlIHdpZGdldCBmYWN0b3J5IGZ1bmN0aW9uLlxuICovXG5leHBvcnQgY29uc3Qge3dpZGdldHNDb25maWdJbmplY3Rpb25Ub2tlbiwgcHJvdmlkZVdpZGdldHNDb25maWcsIGluamVjdFdpZGdldENvbmZpZywgaW5qZWN0V2lkZ2V0c0NvbmZpZywgY2FsbFdpZGdldEZhY3Rvcnl9ID0gd2lkZ2V0RmFjdG9yaWVzO1xuIl19