@agnos-ui/angular-bootstrap 0.3.1 → 0.4.0-next.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 (65) hide show
  1. package/agnos-ui-angular.module.d.ts +1 -1
  2. package/components/accordion/accordion.component.d.ts +63 -97
  3. package/components/accordion/accordion.d.ts +5 -10
  4. package/components/accordion/accordion.gen.d.ts +342 -0
  5. package/components/alert/alert.component.d.ts +11 -5
  6. package/components/alert/alert.d.ts +4 -6
  7. package/components/alert/alert.gen.d.ts +118 -0
  8. package/components/modal/modal.component.d.ts +28 -12
  9. package/components/modal/modal.d.ts +5 -8
  10. package/components/modal/modal.gen.d.ts +238 -0
  11. package/components/pagination/pagination.component.d.ts +51 -9
  12. package/components/pagination/pagination.d.ts +4 -7
  13. package/components/pagination/pagination.gen.d.ts +394 -0
  14. package/components/progressbar/progressbar.component.d.ts +9 -3
  15. package/components/progressbar/progressbar.d.ts +4 -6
  16. package/components/progressbar/progressbar.gen.d.ts +126 -0
  17. package/components/rating/rating.component.d.ts +6 -3
  18. package/components/rating/rating.d.ts +4 -5
  19. package/components/rating/rating.gen.d.ts +179 -0
  20. package/components/select/select.component.d.ts +16 -8
  21. package/components/select/select.d.ts +4 -7
  22. package/components/select/select.gen.d.ts +291 -0
  23. package/components/slider/slider.component.d.ts +13 -4
  24. package/components/slider/slider.d.ts +4 -8
  25. package/components/slider/slider.gen.d.ts +293 -0
  26. package/components/toast/toast.component.d.ts +15 -6
  27. package/components/toast/toast.d.ts +4 -6
  28. package/components/toast/toast.gen.d.ts +145 -0
  29. package/config.d.ts +3 -5
  30. package/config.gen.d.ts +47 -0
  31. package/esm2022/agnos-ui-angular.module.mjs +5 -5
  32. package/esm2022/components/accordion/accordion.component.mjs +121 -155
  33. package/esm2022/components/accordion/accordion.gen.mjs +2 -0
  34. package/esm2022/components/accordion/accordion.mjs +4 -3
  35. package/esm2022/components/alert/alert.component.mjs +20 -20
  36. package/esm2022/components/alert/alert.gen.mjs +2 -0
  37. package/esm2022/components/alert/alert.mjs +3 -3
  38. package/esm2022/components/modal/modal.component.mjs +42 -42
  39. package/esm2022/components/modal/modal.gen.mjs +2 -0
  40. package/esm2022/components/modal/modal.mjs +4 -3
  41. package/esm2022/components/pagination/pagination.component.mjs +67 -67
  42. package/esm2022/components/pagination/pagination.gen.mjs +2 -0
  43. package/esm2022/components/pagination/pagination.mjs +3 -3
  44. package/esm2022/components/progressbar/progressbar.component.mjs +18 -18
  45. package/esm2022/components/progressbar/progressbar.gen.mjs +2 -0
  46. package/esm2022/components/progressbar/progressbar.mjs +3 -3
  47. package/esm2022/components/rating/rating.component.mjs +11 -12
  48. package/esm2022/components/rating/rating.gen.mjs +2 -0
  49. package/esm2022/components/rating/rating.mjs +3 -3
  50. package/esm2022/components/select/select.component.mjs +24 -24
  51. package/esm2022/components/select/select.gen.mjs +2 -0
  52. package/esm2022/components/select/select.mjs +3 -3
  53. package/esm2022/components/slider/slider.component.mjs +42 -42
  54. package/esm2022/components/slider/slider.gen.mjs +2 -0
  55. package/esm2022/components/slider/slider.mjs +3 -3
  56. package/esm2022/components/toast/toast.component.mjs +31 -31
  57. package/esm2022/components/toast/toast.gen.mjs +2 -0
  58. package/esm2022/components/toast/toast.mjs +3 -3
  59. package/esm2022/config.gen.mjs +2 -0
  60. package/esm2022/config.mjs +1 -1
  61. package/esm2022/index.mjs +1 -1
  62. package/fesm2022/agnos-ui-angular-bootstrap.mjs +391 -434
  63. package/fesm2022/agnos-ui-angular-bootstrap.mjs.map +1 -1
  64. package/index.d.ts +9 -9
  65. package/package.json +7 -7
@@ -0,0 +1,2 @@
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,4 +1,5 @@
1
- import { createAccordion as coreCreateAccordion } from '@agnos-ui/core-bootstrap/components/accordion';
2
- export * from '@agnos-ui/core-bootstrap/components/accordion';
1
+ import { createAccordion as coreCreateAccordion, getAccordionDefaultConfig as coreGetAccordionDefaultConfig, createAccordionItem as coreCreateAccordionItem, } from '@agnos-ui/core-bootstrap/components/accordion';
3
2
  export const createAccordion = coreCreateAccordion;
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYWNjb3JkaW9uL2FjY29yZGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsZUFBZSxJQUFJLG1CQUFtQixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFFckcsY0FBYywrQ0FBK0MsQ0FBQztBQVU5RCxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQW1DLG1CQUFxRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge0FkYXB0V2lkZ2V0U2xvdHMsIFdpZGdldFByb3BzLCBXaWRnZXRTdGF0ZSwgQWRhcHRTbG90Q29udGVudFByb3BzLCBXaWRnZXRGYWN0b3J5fSBmcm9tICdAYWdub3MtdWkvYW5ndWxhci1oZWFkbGVzcyc7XG5pbXBvcnQge2NyZWF0ZUFjY29yZGlvbiBhcyBjb3JlQ3JlYXRlQWNjb3JkaW9ufSBmcm9tICdAYWdub3MtdWkvY29yZS1ib290c3RyYXAvY29tcG9uZW50cy9hY2NvcmRpb24nO1xuXG5leHBvcnQgKiBmcm9tICdAYWdub3MtdWkvY29yZS1ib290c3RyYXAvY29tcG9uZW50cy9hY2NvcmRpb24nO1xuXG5leHBvcnQgdHlwZSBBY2NvcmRpb25XaWRnZXQgPSBBZGFwdFdpZGdldFNsb3RzPGltcG9ydCgnQGFnbm9zLXVpL2NvcmUtYm9vdHN0cmFwL2NvbXBvbmVudHMvYWNjb3JkaW9uJykuQWNjb3JkaW9uV2lkZ2V0PjtcbmV4cG9ydCB0eXBlIEFjY29yZGlvblByb3BzID0gV2lkZ2V0UHJvcHM8QWNjb3JkaW9uV2lkZ2V0PjtcbmV4cG9ydCB0eXBlIEFjY29yZGlvblN0YXRlID0gV2lkZ2V0U3RhdGU8QWNjb3JkaW9uV2lkZ2V0PjtcbmV4cG9ydCB0eXBlIEFjY29yZGlvbkFwaSA9IEFjY29yZGlvbldpZGdldFsnYXBpJ107XG5leHBvcnQgdHlwZSBBY2NvcmRpb25JdGVtV2lkZ2V0ID0gQWRhcHRXaWRnZXRTbG90czxpbXBvcnQoJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL2FjY29yZGlvbicpLkFjY29yZGlvbkl0ZW1XaWRnZXQ+O1xuZXhwb3J0IHR5cGUgQWNjb3JkaW9uSXRlbVByb3BzID0gV2lkZ2V0UHJvcHM8QWNjb3JkaW9uSXRlbVdpZGdldD47XG5leHBvcnQgdHlwZSBBY2NvcmRpb25JdGVtU3RhdGUgPSBXaWRnZXRTdGF0ZTxBY2NvcmRpb25JdGVtV2lkZ2V0PjtcbmV4cG9ydCB0eXBlIEFjY29yZGlvbkl0ZW1Db250ZXh0ID0gQWRhcHRTbG90Q29udGVudFByb3BzPGltcG9ydCgnQGFnbm9zLXVpL2NvcmUtYm9vdHN0cmFwL2NvbXBvbmVudHMvYWNjb3JkaW9uJykuQWNjb3JkaW9uSXRlbUNvbnRleHQ+O1xuZXhwb3J0IGNvbnN0IGNyZWF0ZUFjY29yZGlvbjogV2lkZ2V0RmFjdG9yeTxBY2NvcmRpb25XaWRnZXQ+ID0gY29yZUNyZWF0ZUFjY29yZGlvbiBhcyBXaWRnZXRGYWN0b3J5PEFjY29yZGlvbldpZGdldD47XG4iXX0=
3
+ export const getAccordionDefaultConfig = coreGetAccordionDefaultConfig;
4
+ export const createAccordionItem = coreCreateAccordionItem;
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYWNjb3JkaW9uL2FjY29yZGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQ04sZUFBZSxJQUFJLG1CQUFtQixFQUN0Qyx5QkFBeUIsSUFBSSw2QkFBNkIsRUFDMUQsbUJBQW1CLElBQUksdUJBQXVCLEdBQzlDLE1BQU0sK0NBQStDLENBQUM7QUFJdkQsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFtQyxtQkFBMEIsQ0FBQztBQUMxRixNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBeUIsNkJBQW9DLENBQUM7QUFDcEcsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQXVDLHVCQUE4QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1dpZGdldEZhY3Rvcnl9IGZyb20gJ0BhZ25vcy11aS9hbmd1bGFyLWhlYWRsZXNzJztcbmltcG9ydCB7XG5cdGNyZWF0ZUFjY29yZGlvbiBhcyBjb3JlQ3JlYXRlQWNjb3JkaW9uLFxuXHRnZXRBY2NvcmRpb25EZWZhdWx0Q29uZmlnIGFzIGNvcmVHZXRBY2NvcmRpb25EZWZhdWx0Q29uZmlnLFxuXHRjcmVhdGVBY2NvcmRpb25JdGVtIGFzIGNvcmVDcmVhdGVBY2NvcmRpb25JdGVtLFxufSBmcm9tICdAYWdub3MtdWkvY29yZS1ib290c3RyYXAvY29tcG9uZW50cy9hY2NvcmRpb24nO1xuaW1wb3J0IHR5cGUge0FjY29yZGlvbkl0ZW1XaWRnZXQsIEFjY29yZGlvblByb3BzLCBBY2NvcmRpb25XaWRnZXR9IGZyb20gJy4vYWNjb3JkaW9uLmdlbic7XG5cbmV4cG9ydCB0eXBlICogZnJvbSAnLi9hY2NvcmRpb24uZ2VuJztcbmV4cG9ydCBjb25zdCBjcmVhdGVBY2NvcmRpb246IFdpZGdldEZhY3Rvcnk8QWNjb3JkaW9uV2lkZ2V0PiA9IGNvcmVDcmVhdGVBY2NvcmRpb24gYXMgYW55O1xuZXhwb3J0IGNvbnN0IGdldEFjY29yZGlvbkRlZmF1bHRDb25maWc6ICgpID0+IEFjY29yZGlvblByb3BzID0gY29yZUdldEFjY29yZGlvbkRlZmF1bHRDb25maWcgYXMgYW55O1xuZXhwb3J0IGNvbnN0IGNyZWF0ZUFjY29yZGlvbkl0ZW06IFdpZGdldEZhY3Rvcnk8QWNjb3JkaW9uSXRlbVdpZGdldD4gPSBjb3JlQ3JlYXRlQWNjb3JkaW9uSXRlbSBhcyBhbnk7XG4iXX0=
@@ -1,4 +1,4 @@
1
- import { BaseWidgetDirective, ComponentTemplate, SlotDefaultDirective, SlotDirective, UseDirective, auBooleanAttribute, } from '@agnos-ui/angular-headless';
1
+ import { BaseWidgetDirective, ComponentTemplate, ContentAsSlotDirective, SlotDirective, UseDirective, auBooleanAttribute, } from '@agnos-ui/angular-headless';
2
2
  import { createAlert } from './alert';
3
3
  import { writable } from '@amadeus-it-group/tansu';
4
4
  import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewChild, inject, } from '@angular/core';
@@ -25,9 +25,9 @@ function AlertDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1
25
25
  const state_r3 = ctx.state;
26
26
  const widget_r2 = ctx.widget;
27
27
  i0.ɵɵadvance();
28
- i0.ɵɵproperty("auSlot", state_r3.slotDefault)("auSlotProps", i0.ɵɵpureFunction2(3, _c1, state_r3, widget_r2));
28
+ i0.ɵɵproperty("auSlot", state_r3.children)("auSlotProps", i0.ɵɵpureFunction2(3, _c1, state_r3, widget_r2));
29
29
  i0.ɵɵadvance();
30
- i0.ɵɵconditional(2, state_r3.dismissible ? 2 : -1);
30
+ i0.ɵɵconditional(state_r3.dismissible ? 2 : -1);
31
31
  } }
32
32
  const _c2 = ["auAlert", ""];
33
33
  const _c3 = ["*"];
@@ -44,7 +44,7 @@ function AlertComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
44
44
  i0.ɵɵclassMapInterpolate3("au-alert alert alert-", ctx_r0.state().type, " ", ctx_r0.state().className, " ", ctx_r0.state().dismissible ? "alert-dismissible" : "", "");
45
45
  i0.ɵɵproperty("auUse", ctx_r0.widget.directives.transitionDirective);
46
46
  i0.ɵɵadvance();
47
- i0.ɵɵproperty("auSlot", ctx_r0.state().slotStructure)("auSlotProps", i0.ɵɵpureFunction2(8, _c1, ctx_r0.state(), ctx_r0.widget));
47
+ i0.ɵɵproperty("auSlot", ctx_r0.state().structure)("auSlotProps", i0.ɵɵpureFunction2(8, _c1, ctx_r0.state(), ctx_r0.widget));
48
48
  } }
49
49
  export class AlertBodyDirective {
50
50
  constructor() {
@@ -93,7 +93,7 @@ export class AlertDefaultSlotsComponent {
93
93
  imports: [SlotDirective, AlertStructureDirective],
94
94
  template: ` <ng-template auAlertStructure #structure let-state="state" let-widget="widget">
95
95
  <div class="alert-body">
96
- <ng-template [auSlot]="state.slotDefault" [auSlotProps]="{state, widget}"></ng-template>
96
+ <ng-template [auSlot]="state.children" [auSlotProps]="{state, widget}"></ng-template>
97
97
  </div>
98
98
  @if (state.dismissible) {
99
99
  <button type="button" class="btn-close" (click)="widget.api.close()" [attr.aria-label]="state.ariaCloseButtonLabel"></button>
@@ -107,7 +107,7 @@ export class AlertDefaultSlotsComponent {
107
107
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(AlertDefaultSlotsComponent, { className: "AlertDefaultSlotsComponent", filePath: "components/alert/alert.component.ts", lineNumber: 57 }); })();
108
108
  export const alertDefaultSlotStructure = new ComponentTemplate(AlertDefaultSlotsComponent, 'structure');
109
109
  const defaultConfig = {
110
- slotStructure: alertDefaultSlotStructure,
110
+ structure: alertDefaultSlotStructure,
111
111
  };
112
112
  export class AlertComponent extends BaseWidgetDirective {
113
113
  constructor() {
@@ -138,8 +138,8 @@ export class AlertComponent extends BaseWidgetDirective {
138
138
  }
139
139
  ngAfterContentChecked() {
140
140
  this._widget.patchSlots({
141
- slotDefault: this.slotDefaultFromContent?.templateRef,
142
- slotStructure: this.slotStructureFromContent?.templateRef,
141
+ children: this.slotDefaultFromContent?.templateRef,
142
+ structure: this.slotStructureFromContent?.templateRef,
143
143
  });
144
144
  }
145
145
  static { this.ɵfac = /*@__PURE__*/ (() => { let ɵAlertComponent_BaseFactory; return function AlertComponent_Factory(t) { return (ɵAlertComponent_BaseFactory || (ɵAlertComponent_BaseFactory = i0.ɵɵgetInheritedFactory(AlertComponent)))(t || AlertComponent); }; })(); }
@@ -150,14 +150,14 @@ export class AlertComponent extends BaseWidgetDirective {
150
150
  let _t;
151
151
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first);
152
152
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStructureFromContent = _t.first);
153
- } }, inputs: { type: [i0.ɵɵInputFlags.None, "auType", "type"], dismissible: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auDismissible", "dismissible", auBooleanAttribute], transition: [i0.ɵɵInputFlags.None, "auTransition", "transition"], visible: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auVisible", "visible", auBooleanAttribute], animatedOnInit: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auAnimatedOnInit", "animatedOnInit", auBooleanAttribute], animated: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auAnimated", "animated", auBooleanAttribute], ariaCloseButtonLabel: [i0.ɵɵInputFlags.None, "auAriaCloseButtonLabel", "ariaCloseButtonLabel"], slotDefault: [i0.ɵɵInputFlags.None, "auSlotDefault", "slotDefault"], slotStructure: [i0.ɵɵInputFlags.None, "auSlotStructure", "slotStructure"], className: [i0.ɵɵInputFlags.None, "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, "auSlotDefault"], ["role", "alert", 3, "auUse", "class"], ["role", "alert", 3, "auUse"], [3, "auSlot", "auSlotProps"]], template: function AlertComponent_Template(rf, ctx) { if (rf & 1) {
153
+ } }, inputs: { type: [0, "auType", "type"], dismissible: [2, "auDismissible", "dismissible", auBooleanAttribute], transition: [0, "auTransition", "transition"], visible: [2, "auVisible", "visible", auBooleanAttribute], animatedOnInit: [2, "auAnimatedOnInit", "animatedOnInit", auBooleanAttribute], animated: [2, "auAnimated", "animated", auBooleanAttribute], ariaCloseButtonLabel: [0, "auAriaCloseButtonLabel", "ariaCloseButtonLabel"], children: [0, "auChildren", "children"], structure: [0, "auStructure", "structure"], 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"], ["role", "alert", 3, "auUse", "class"], ["role", "alert", 3, "auUse"], [3, "auSlot", "auSlotProps"]], template: function AlertComponent_Template(rf, ctx) { if (rf & 1) {
154
154
  i0.ɵɵprojectionDef();
155
155
  i0.ɵɵtemplate(0, AlertComponent_ng_template_0_Template, 1, 0, "ng-template", 0)(1, AlertComponent_Conditional_1_Template, 2, 11, "div", 1);
156
156
  } if (rf & 2) {
157
- i0.ɵɵproperty("auSlotDefault", ctx.defaultSlots);
157
+ i0.ɵɵproperty("auContentAsSlot", ctx.defaultSlots);
158
158
  i0.ɵɵadvance();
159
- i0.ɵɵconditional(1, !ctx.state().hidden ? 1 : -1);
160
- } }, dependencies: [SlotDirective, UseDirective, SlotDefaultDirective], encapsulation: 2, changeDetection: 0 }); }
159
+ i0.ɵɵconditional(!ctx.state().hidden ? 1 : -1);
160
+ } }, dependencies: [SlotDirective, UseDirective, ContentAsSlotDirective], encapsulation: 2, changeDetection: 0 }); }
161
161
  }
162
162
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AlertComponent, [{
163
163
  type: Component,
@@ -165,8 +165,8 @@ export class AlertComponent extends BaseWidgetDirective {
165
165
  selector: '[auAlert]',
166
166
  standalone: true,
167
167
  changeDetection: ChangeDetectionStrategy.OnPush,
168
- imports: [SlotDirective, UseDirective, SlotDefaultDirective],
169
- template: ` <ng-template [auSlotDefault]="defaultSlots">
168
+ imports: [SlotDirective, UseDirective, ContentAsSlotDirective],
169
+ template: ` <ng-template [auContentAsSlot]="defaultSlots">
170
170
  <ng-content></ng-content>
171
171
  </ng-template>
172
172
 
@@ -176,7 +176,7 @@ export class AlertComponent extends BaseWidgetDirective {
176
176
  class="au-alert alert alert-{{ state().type }} {{ state().className }} {{ state().dismissible ? 'alert-dismissible' : '' }}"
177
177
  role="alert"
178
178
  >
179
- <ng-template [auSlot]="state().slotStructure" [auSlotProps]="{state: state(), widget}"></ng-template>
179
+ <ng-template [auSlot]="state().structure" [auSlotProps]="{state: state(), widget}"></ng-template>
180
180
  </div>
181
181
  }`,
182
182
  }]
@@ -201,15 +201,15 @@ export class AlertComponent extends BaseWidgetDirective {
201
201
  }], ariaCloseButtonLabel: [{
202
202
  type: Input,
203
203
  args: ['auAriaCloseButtonLabel']
204
- }], slotDefault: [{
204
+ }], children: [{
205
205
  type: Input,
206
- args: ['auSlotDefault']
206
+ args: ['auChildren']
207
207
  }], slotDefaultFromContent: [{
208
208
  type: ContentChild,
209
209
  args: [AlertBodyDirective, { static: false }]
210
- }], slotStructure: [{
210
+ }], structure: [{
211
211
  type: Input,
212
- args: ['auSlotStructure']
212
+ args: ['auStructure']
213
213
  }], slotStructureFromContent: [{
214
214
  type: ContentChild,
215
215
  args: [AlertStructureDirective, { static: false }]
@@ -227,4 +227,4 @@ export class AlertComponent extends BaseWidgetDirective {
227
227
  args: ['auClassName']
228
228
  }] }); })();
229
229
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(AlertComponent, { className: "AlertComponent", filePath: "components/alert/alert.component.ts", lineNumber: 87 }); })();
230
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert.component.js","sourceRoot":"","sources":["../../../../src/components/alert/alert.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent, TransitionFn} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDefaultDirective,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n} from '@agnos-ui/angular-headless';\nimport type {AlertContext, AlertProps, AlertWidget} from './alert';\nimport {createAlert} from './alert';\nimport {type WritableSignal, writable} from '@amadeus-it-group/tansu';\nimport type {AfterContentChecked} from '@angular/core';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tinject,\n} from '@angular/core';\nimport {callWidgetFactory} from '../../config';\nimport type {BSContextualClass} from '@agnos-ui/core-bootstrap/types';\n\n@Directive({selector: 'ng-template[auAlertBody]', standalone: true})\nexport class AlertBodyDirective {\n\tpublic templateRef = inject(TemplateRef<AlertContext>);\n\tstatic ngTemplateContextGuard(dir: AlertBodyDirective, context: unknown): context is AlertContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auAlertStructure]', standalone: true})\nexport class AlertStructureDirective {\n\tpublic templateRef = inject(TemplateRef<AlertContext>);\n\tstatic ngTemplateContextGuard(dir: AlertStructureDirective, context: unknown): context is AlertContext {\n\t\treturn true;\n\t}\n}\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, AlertStructureDirective],\n\ttemplate: ` <ng-template auAlertStructure #structure let-state=\"state\" let-widget=\"widget\">\n\t\t<div class=\"alert-body\">\n\t\t\t<ng-template [auSlot]=\"state.slotDefault\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t</div>\n\t\t@if (state.dismissible) {\n\t\t\t<button type=\"button\" class=\"btn-close\" (click)=\"widget.api.close()\" [attr.aria-label]=\"state.ariaCloseButtonLabel\"></button>\n\t\t}\n\t</ng-template>`,\n})\nexport class AlertDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure: TemplateRef<AlertContext>;\n}\n\nexport const alertDefaultSlotStructure = new ComponentTemplate(AlertDefaultSlotsComponent, 'structure');\n\nexport type PartialAlertProps = Partial<AlertProps>;\nconst defaultConfig: PartialAlertProps = {\n\tslotStructure: alertDefaultSlotStructure,\n};\n\n@Component({\n\tselector: '[auAlert]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, UseDirective, SlotDefaultDirective],\n\ttemplate: ` <ng-template [auSlotDefault]=\"defaultSlots\">\n\t\t\t<ng-content></ng-content>\n\t\t</ng-template>\n\n\t\t@if (!state().hidden) {\n\t\t\t<div\n\t\t\t\t[auUse]=\"widget.directives.transitionDirective\"\n\t\t\t\tclass=\"au-alert alert alert-{{ state().type }} {{ state().className }} {{ state().dismissible ? 'alert-dismissible' : '' }}\"\n\t\t\t\trole=\"alert\"\n\t\t\t>\n\t\t\t\t<ng-template [auSlot]=\"state().slotStructure\" [auSlotProps]=\"{state: state(), widget}\"></ng-template>\n\t\t\t</div>\n\t\t}`,\n})\nexport class AlertComponent extends BaseWidgetDirective<AlertWidget> implements AfterContentChecked {\n\t/**\n\t * Type of the alert, following bootstrap types.\n\t */\n\t@Input('auType')\n\ttype: BSContextualClass | undefined;\n\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@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 CommonAlertProps.animatedOnInit, the animation can be optionally skipped during the showing process.\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@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@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@Input({alias: 'auAnimated', transform: auBooleanAttribute})\n\tanimated: boolean | undefined;\n\n\t/**\n\t * Accessibility close button label\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t@Input('auSlotDefault') slotDefault: SlotContent<AlertContext>;\n\t@ContentChild(AlertBodyDirective, {static: false})\n\tslotDefaultFromContent: AlertBodyDirective | null;\n\n\t@Input('auSlotStructure') slotStructure: SlotContent<AlertContext>;\n\t@ContentChild(AlertStructureDirective, {static: false}) slotStructureFromContent: AlertStructureDirective | undefined;\n\n\t/**\n\t * Callback called when the alert visibility changed.\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@Output('auHidden') hidden = new EventEmitter<void>();\n\n\t/**\n\t * Callback called when the alert is shown.\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\n\treadonly defaultSlots: WritableSignal<PartialAlertProps> = writable(defaultConfig);\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\treadonly _widget = callWidgetFactory({\n\t\tfactory: createAlert,\n\t\twidgetName: 'alert',\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\tslotDefault: this.slotDefaultFromContent?.templateRef,\n\t\t\tslotStructure: this.slotStructureFromContent?.templateRef,\n\t\t});\n\t}\n}\n"]}
230
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert.component.js","sourceRoot":"","sources":["../../../../src/components/alert/alert.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\tauBooleanAttribute,\n} from '@agnos-ui/angular-headless';\nimport type {AlertContext, AlertProps, AlertWidget} from './alert';\nimport {createAlert} from './alert';\nimport {type WritableSignal, writable} from '@amadeus-it-group/tansu';\nimport type {AfterContentChecked} from '@angular/core';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tinject,\n} from '@angular/core';\nimport {callWidgetFactory} from '../../config';\nimport type {BSContextualClass} from '@agnos-ui/core-bootstrap/types';\n\n@Directive({selector: 'ng-template[auAlertBody]', standalone: true})\nexport class AlertBodyDirective {\n\tpublic templateRef = inject(TemplateRef<AlertContext>);\n\tstatic ngTemplateContextGuard(dir: AlertBodyDirective, context: unknown): context is AlertContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auAlertStructure]', standalone: true})\nexport class AlertStructureDirective {\n\tpublic templateRef = inject(TemplateRef<AlertContext>);\n\tstatic ngTemplateContextGuard(dir: AlertStructureDirective, context: unknown): context is AlertContext {\n\t\treturn true;\n\t}\n}\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, AlertStructureDirective],\n\ttemplate: ` <ng-template auAlertStructure #structure let-state=\"state\" let-widget=\"widget\">\n\t\t<div class=\"alert-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) {\n\t\t\t<button type=\"button\" class=\"btn-close\" (click)=\"widget.api.close()\" [attr.aria-label]=\"state.ariaCloseButtonLabel\"></button>\n\t\t}\n\t</ng-template>`,\n})\nexport class AlertDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<AlertContext>;\n}\n\nexport const alertDefaultSlotStructure = new ComponentTemplate(AlertDefaultSlotsComponent, 'structure');\n\nexport type PartialAlertProps = Partial<AlertProps>;\nconst defaultConfig: PartialAlertProps = {\n\tstructure: alertDefaultSlotStructure,\n};\n\n@Component({\n\tselector: '[auAlert]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, UseDirective, ContentAsSlotDirective],\n\ttemplate: ` <ng-template [auContentAsSlot]=\"defaultSlots\">\n\t\t\t<ng-content></ng-content>\n\t\t</ng-template>\n\n\t\t@if (!state().hidden) {\n\t\t\t<div\n\t\t\t\t[auUse]=\"widget.directives.transitionDirective\"\n\t\t\t\tclass=\"au-alert alert alert-{{ state().type }} {{ state().className }} {{ state().dismissible ? 'alert-dismissible' : '' }}\"\n\t\t\t\trole=\"alert\"\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 AlertComponent extends BaseWidgetDirective<AlertWidget> implements AfterContentChecked {\n\t/**\n\t * Type of the alert, following bootstrap types.\n\t */\n\t@Input('auType')\n\ttype: BSContextualClass | undefined;\n\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@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@Input('auTransition')\n\ttransition: TransitionFn | undefined;\n\n\t/**\n\t * If `true` the alert is visible to the user\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@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@Input({alias: 'auAnimated', transform: auBooleanAttribute})\n\tanimated: boolean | undefined;\n\n\t/**\n\t * Accessibility close button label\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t/**\n\t * Template for the alert content\n\t */\n\t@Input('auChildren') children: SlotContent<AlertContext>;\n\t@ContentChild(AlertBodyDirective, {static: false})\n\tslotDefaultFromContent: AlertBodyDirective | undefined;\n\n\t/**\n\t * Global template for the alert component\n\t */\n\t@Input('auStructure') structure: SlotContent<AlertContext>;\n\t@ContentChild(AlertStructureDirective, {static: false}) slotStructureFromContent: AlertStructureDirective | undefined;\n\n\t/**\n\t * Callback called when the alert visibility changed.\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@Output('auHidden') hidden = new EventEmitter<void>();\n\n\t/**\n\t * Callback called when the alert is shown.\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\n\treadonly defaultSlots: WritableSignal<PartialAlertProps> = writable(defaultConfig);\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\treadonly _widget = callWidgetFactory({\n\t\tfactory: createAlert,\n\t\twidgetName: 'alert',\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});\n\t}\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuZ2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYWxlcnQvYWxlcnQuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7V2lkZ2V0U2xvdENvbnRleHQsIFNsb3RDb250ZW50LCBUcmFuc2l0aW9uRm4sIFdpZGdldCwgRGlyZWN0aXZlfSBmcm9tICdAYWdub3MtdWkvYW5ndWxhci1oZWFkbGVzcyc7XG5pbXBvcnQgdHlwZSB7QlNDb250ZXh0dWFsQ2xhc3N9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC90eXBlcyc7XG5cbmV4cG9ydCB0eXBlIEFsZXJ0Q29udGV4dCA9IFdpZGdldFNsb3RDb250ZXh0PEFsZXJ0V2lkZ2V0PjtcblxuZXhwb3J0IGludGVyZmFjZSBBbGVydFN0YXRlIHtcblx0LyoqXG5cdCAqIElzIGB0cnVlYCB3aGVuIHRoZSBhbGVydCBpcyBoaWRkZW4uIENvbXBhcmVkIHRvIGB2aXNpYmxlYCwgdGhpcyBpcyB1cGRhdGVkIGFmdGVyIHRoZSB0cmFuc2l0aW9uIGlzIGV4ZWN1dGVkLlxuXHQgKi9cblx0aGlkZGVuOiBib29sZWFuO1xuXHQvKipcblx0ICogSWYgYHRydWVgLCBhbGVydCBjYW4gYmUgZGlzbWlzc2VkIGJ5IHRoZSB1c2VyLlxuXHQgKiBUaGUgY2xvc2UgYnV0dG9uICjDlykgd2lsbCBiZSBkaXNwbGF5ZWQgYW5kIHlvdSBjYW4gYmUgbm90aWZpZWQgb2YgdGhlIGV2ZW50IHdpdGggdGhlIChjbG9zZSkgb3V0cHV0LlxuXHQgKi9cblx0ZGlzbWlzc2libGU6IGJvb2xlYW47XG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAgdGhlIGFsZXJ0IGlzIHZpc2libGUgdG8gdGhlIHVzZXJcblx0ICovXG5cdHZpc2libGU6IGJvb2xlYW47XG5cdC8qKlxuXHQgKiBBY2Nlc3NpYmlsaXR5IGNsb3NlIGJ1dHRvbiBsYWJlbFxuXHQgKi9cblx0YXJpYUNsb3NlQnV0dG9uTGFiZWw6IHN0cmluZztcblx0LyoqXG5cdCAqIENTUyBjbGFzc2VzIHRvIGJlIGFwcGxpZWQgb24gdGhlIHdpZGdldCBtYWluIGNvbnRhaW5lclxuXHQgKi9cblx0Y2xhc3NOYW1lOiBzdHJpbmc7XG5cdC8qKlxuXHQgKiBHbG9iYWwgdGVtcGxhdGUgZm9yIHRoZSBhbGVydCBjb21wb25lbnRcblx0ICovXG5cdHN0cnVjdHVyZTogU2xvdENvbnRlbnQ8QWxlcnRDb250ZXh0Pjtcblx0LyoqXG5cdCAqIFRlbXBsYXRlIGZvciB0aGUgYWxlcnQgY29udGVudFxuXHQgKi9cblx0Y2hpbGRyZW46IFNsb3RDb250ZW50PEFsZXJ0Q29udGV4dD47XG5cdC8qKlxuXHQgKiBUeXBlIG9mIHRoZSBhbGVydCwgZm9sbG93aW5nIGJvb3RzdHJhcCB0eXBlcy5cblx0ICovXG5cdHR5cGU6IEJTQ29udGV4dHVhbENsYXNzO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFsZXJ0UHJvcHMge1xuXHQvKipcblx0ICogQ2FsbGJhY2sgY2FsbGVkIHdoZW4gdGhlIGFsZXJ0IHZpc2liaWxpdHkgY2hhbmdlZC5cblx0ICovXG5cdG9uVmlzaWJsZUNoYW5nZTogKHZpc2libGU6IGJvb2xlYW4pID0+IHZvaWQ7XG5cdC8qKlxuXHQgKiBDYWxsYmFjayBjYWxsZWQgd2hlbiB0aGUgYWxlcnQgaXMgaGlkZGVuLlxuXHQgKi9cblx0b25IaWRkZW46ICgpID0+IHZvaWQ7XG5cdC8qKlxuXHQgKiBDYWxsYmFjayBjYWxsZWQgd2hlbiB0aGUgYWxlcnQgaXMgc2hvd24uXG5cdCAqL1xuXHRvblNob3duOiAoKSA9PiB2b2lkO1xuXHQvKipcblx0ICogVGhlIHRyYW5zaXRpb24gZnVuY3Rpb24gd2lsbCBiZSBleGVjdXRlZCB3aGVuIHRoZSBhbGVydCBpcyBkaXNwbGF5ZWQgb3IgaGlkZGVuLlxuXHQgKiBcblx0ICogRGVwZW5kaW5nIG9uIHRoZSB2YWx1ZSBvZiBgYW5pbWF0ZWRPbkluaXRgLCB0aGUgYW5pbWF0aW9uIGNhbiBiZSBvcHRpb25hbGx5IHNraXBwZWQgZHVyaW5nIHRoZSBzaG93aW5nIHByb2Nlc3MuXG5cdCAqL1xuXHR0cmFuc2l0aW9uOiBUcmFuc2l0aW9uRm47XG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAsIGFsZXJ0IG9wZW5pbmcgd2lsbCBiZSBhbmltYXRlZC5cblx0ICogXG5cdCAqIEFuaW1hdGlvbiBpcyB0cmlnZ2VyZWQgIHdoZW4gdGhlIGAub3BlbigpYCBmdW5jdGlvbiBpcyBjYWxsZWRcblx0ICogb3IgdGhlIHZpc2libGUgcHJvcCBpcyBjaGFuZ2VkXG5cdCAqL1xuXHRhbmltYXRlZE9uSW5pdDogYm9vbGVhbjtcblx0LyoqXG5cdCAqIElmIGB0cnVlYCwgYWxlcnQgY2xvc2luZyB3aWxsIGJlIGFuaW1hdGVkLlxuXHQgKiBcblx0ICogQW5pbWF0aW9uIGlzIHRyaWdnZXJlZCAgd2hlbiBjbGlja2VkIG9uIHRoZSBjbG9zZSBidXR0b24gKMOXKSxcblx0ICogdmlhIHRoZSBgLmNsb3NlKClgIGZ1bmN0aW9uIG9yIHRoZSB2aXNpYmxlIHByb3AgaXMgY2hhbmdlZFxuXHQgKi9cblx0YW5pbWF0ZWQ6IGJvb2xlYW47XG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAsIGFsZXJ0IGNhbiBiZSBkaXNtaXNzZWQgYnkgdGhlIHVzZXIuXG5cdCAqIFRoZSBjbG9zZSBidXR0b24gKMOXKSB3aWxsIGJlIGRpc3BsYXllZCBhbmQgeW91IGNhbiBiZSBub3RpZmllZCBvZiB0aGUgZXZlbnQgd2l0aCB0aGUgKGNsb3NlKSBvdXRwdXQuXG5cdCAqL1xuXHRkaXNtaXNzaWJsZTogYm9vbGVhbjtcblx0LyoqXG5cdCAqIElmIGB0cnVlYCB0aGUgYWxlcnQgaXMgdmlzaWJsZSB0byB0aGUgdXNlclxuXHQgKi9cblx0dmlzaWJsZTogYm9vbGVhbjtcblx0LyoqXG5cdCAqIEFjY2Vzc2liaWxpdHkgY2xvc2UgYnV0dG9uIGxhYmVsXG5cdCAqL1xuXHRhcmlhQ2xvc2VCdXR0b25MYWJlbDogc3RyaW5nO1xuXHQvKipcblx0ICogQ1NTIGNsYXNzZXMgdG8gYmUgYXBwbGllZCBvbiB0aGUgd2lkZ2V0IG1haW4gY29udGFpbmVyXG5cdCAqL1xuXHRjbGFzc05hbWU6IHN0cmluZztcblx0LyoqXG5cdCAqIEdsb2JhbCB0ZW1wbGF0ZSBmb3IgdGhlIGFsZXJ0IGNvbXBvbmVudFxuXHQgKi9cblx0c3RydWN0dXJlOiBTbG90Q29udGVudDxBbGVydENvbnRleHQ+O1xuXHQvKipcblx0ICogVGVtcGxhdGUgZm9yIHRoZSBhbGVydCBjb250ZW50XG5cdCAqL1xuXHRjaGlsZHJlbjogU2xvdENvbnRlbnQ8QWxlcnRDb250ZXh0Pjtcblx0LyoqXG5cdCAqIFR5cGUgb2YgdGhlIGFsZXJ0LCBmb2xsb3dpbmcgYm9vdHN0cmFwIHR5cGVzLlxuXHQgKi9cblx0dHlwZTogQlNDb250ZXh0dWFsQ2xhc3M7XG59XG5cbmV4cG9ydCB0eXBlIEFsZXJ0V2lkZ2V0ID0gV2lkZ2V0PEFsZXJ0UHJvcHMsIEFsZXJ0U3RhdGUsIEFsZXJ0QXBpLCBvYmplY3QsIEFsZXJ0RGlyZWN0aXZlcz47XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWxlcnRBcGkge1xuXHQvKipcblx0ICogVHJpZ2dlcnMgYWxlcnQgY2xvc2luZyBwcm9ncmFtbWF0aWNhbGx5IChzYW1lIGFzIGNsaWNraW5nIG9uIHRoZSBjbG9zZSBidXR0b24gKMOXKSkuXG5cdCAqL1xuXHRjbG9zZSgpOiB2b2lkO1xuXHQvKipcblx0ICogVHJpZ2dlcnMgdGhlIGFsZXJ0IHRvIGJlIGRpc3BsYXllZCBmb3IgdGhlIHVzZXIuXG5cdCAqL1xuXHRvcGVuKCk6IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWxlcnREaXJlY3RpdmVzIHtcblx0LyoqXG5cdCAqIHRoZSB0cmFuc2l0aW9uIGRpcmVjdGl2ZSwgcGlsb3Rpbmcgd2hhdCBpcyB0aGUgdmlzdWFsIGVmZmVjdCBvZiBnb2luZyBmcm9tIGhpZGRlbiB0byB2aXNpYmxlXG5cdCAqL1xuXHR0cmFuc2l0aW9uRGlyZWN0aXZlOiBEaXJlY3RpdmU7XG59XG5cbiJdfQ==
@@ -1,4 +1,4 @@
1
- import { createAlert as coreCreateAlert } from '@agnos-ui/core-bootstrap/components/alert';
2
- export * from '@agnos-ui/core-bootstrap/components/alert';
1
+ import { createAlert as coreCreateAlert, getAlertDefaultConfig as coreGetAlertDefaultConfig } from '@agnos-ui/core-bootstrap/components/alert';
3
2
  export const createAlert = coreCreateAlert;
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9hbGVydC9hbGVydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsV0FBVyxJQUFJLGVBQWUsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBRXpGLGNBQWMsMkNBQTJDLENBQUM7QUFNMUQsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUErQixlQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge0FkYXB0V2lkZ2V0U2xvdHMsIFdpZGdldFByb3BzLCBXaWRnZXRTdGF0ZSwgQWRhcHRTbG90Q29udGVudFByb3BzLCBXaWRnZXRGYWN0b3J5fSBmcm9tICdAYWdub3MtdWkvYW5ndWxhci1oZWFkbGVzcyc7XG5pbXBvcnQge2NyZWF0ZUFsZXJ0IGFzIGNvcmVDcmVhdGVBbGVydH0gZnJvbSAnQGFnbm9zLXVpL2NvcmUtYm9vdHN0cmFwL2NvbXBvbmVudHMvYWxlcnQnO1xuXG5leHBvcnQgKiBmcm9tICdAYWdub3MtdWkvY29yZS1ib290c3RyYXAvY29tcG9uZW50cy9hbGVydCc7XG5cbmV4cG9ydCB0eXBlIEFsZXJ0V2lkZ2V0ID0gQWRhcHRXaWRnZXRTbG90czxpbXBvcnQoJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL2FsZXJ0JykuQWxlcnRXaWRnZXQ+O1xuZXhwb3J0IHR5cGUgQWxlcnRQcm9wcyA9IFdpZGdldFByb3BzPEFsZXJ0V2lkZ2V0PjtcbmV4cG9ydCB0eXBlIEFsZXJ0U3RhdGUgPSBXaWRnZXRTdGF0ZTxBbGVydFdpZGdldD47XG5leHBvcnQgdHlwZSBBbGVydENvbnRleHQgPSBBZGFwdFNsb3RDb250ZW50UHJvcHM8aW1wb3J0KCdAYWdub3MtdWkvY29yZS1ib290c3RyYXAvY29tcG9uZW50cy9hbGVydCcpLkFsZXJ0Q29udGV4dD47XG5leHBvcnQgY29uc3QgY3JlYXRlQWxlcnQ6IFdpZGdldEZhY3Rvcnk8QWxlcnRXaWRnZXQ+ID0gY29yZUNyZWF0ZUFsZXJ0IGFzIGFueTtcbiJdfQ==
3
+ export const getAlertDefaultConfig = coreGetAlertDefaultConfig;
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9hbGVydC9hbGVydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsV0FBVyxJQUFJLGVBQWUsRUFBRSxxQkFBcUIsSUFBSSx5QkFBeUIsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBSTdJLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBK0IsZUFBc0IsQ0FBQztBQUM5RSxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBcUIseUJBQWdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7V2lkZ2V0RmFjdG9yeX0gZnJvbSAnQGFnbm9zLXVpL2FuZ3VsYXItaGVhZGxlc3MnO1xuaW1wb3J0IHtjcmVhdGVBbGVydCBhcyBjb3JlQ3JlYXRlQWxlcnQsIGdldEFsZXJ0RGVmYXVsdENvbmZpZyBhcyBjb3JlR2V0QWxlcnREZWZhdWx0Q29uZmlnfSBmcm9tICdAYWdub3MtdWkvY29yZS1ib290c3RyYXAvY29tcG9uZW50cy9hbGVydCc7XG5pbXBvcnQgdHlwZSB7QWxlcnRQcm9wcywgQWxlcnRXaWRnZXR9IGZyb20gJy4vYWxlcnQuZ2VuJztcblxuZXhwb3J0IHR5cGUgKiBmcm9tICcuL2FsZXJ0Lmdlbic7XG5leHBvcnQgY29uc3QgY3JlYXRlQWxlcnQ6IFdpZGdldEZhY3Rvcnk8QWxlcnRXaWRnZXQ+ID0gY29yZUNyZWF0ZUFsZXJ0IGFzIGFueTtcbmV4cG9ydCBjb25zdCBnZXRBbGVydERlZmF1bHRDb25maWc6ICgpID0+IEFsZXJ0UHJvcHMgPSBjb3JlR2V0QWxlcnREZWZhdWx0Q29uZmlnIGFzIGFueTtcbiJdfQ==
@@ -1,4 +1,4 @@
1
- import { BaseWidgetDirective, ComponentTemplate, SlotDefaultDirective, SlotDirective, UseDirective, UseMultiDirective, auBooleanAttribute, } from '@agnos-ui/angular-headless';
1
+ import { BaseWidgetDirective, ComponentTemplate, ContentAsSlotDirective, SlotDirective, UseDirective, UseMultiDirective, auBooleanAttribute, } from '@agnos-ui/angular-headless';
2
2
  import { createModal } from './modal';
3
3
  import { writable } from '@amadeus-it-group/tansu';
4
4
  import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewChild, inject, } from '@angular/core';
@@ -23,9 +23,9 @@ function ModalDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1
23
23
  const state_r2 = ctx.state;
24
24
  const widget_r1 = ctx.widget;
25
25
  i0.ɵɵadvance();
26
- i0.ɵɵproperty("auSlot", state_r2.slotTitle)("auSlotProps", i0.ɵɵpureFunction2(3, _c2, state_r2, widget_r1));
26
+ i0.ɵɵproperty("auSlot", state_r2.title)("auSlotProps", i0.ɵɵpureFunction2(3, _c2, state_r2, widget_r1));
27
27
  i0.ɵɵadvance();
28
- i0.ɵɵconditional(2, state_r2.closeButton ? 2 : -1);
28
+ i0.ɵɵconditional(state_r2.closeButton ? 2 : -1);
29
29
  } }
30
30
  function ModalDefaultSlotsComponent_ng_template_2_Conditional_0_ng_template_1_Template(rf, ctx) { }
31
31
  function ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template(rf, ctx) { if (rf & 1) {
@@ -37,7 +37,7 @@ function ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template(rf, ctx
37
37
  const state_r4 = ctx_r2.state;
38
38
  const widget_r5 = ctx_r2.widget;
39
39
  i0.ɵɵadvance();
40
- i0.ɵɵproperty("auSlot", state_r4.slotHeader)("auSlotProps", i0.ɵɵpureFunction2(2, _c2, state_r4, widget_r5));
40
+ i0.ɵɵproperty("auSlot", state_r4.header)("auSlotProps", i0.ɵɵpureFunction2(2, _c2, state_r4, widget_r5));
41
41
  } }
42
42
  function ModalDefaultSlotsComponent_ng_template_2_ng_template_2_Template(rf, ctx) { }
43
43
  function ModalDefaultSlotsComponent_ng_template_2_Conditional_3_ng_template_1_Template(rf, ctx) { }
@@ -50,7 +50,7 @@ function ModalDefaultSlotsComponent_ng_template_2_Conditional_3_Template(rf, ctx
50
50
  const state_r4 = ctx_r2.state;
51
51
  const widget_r5 = ctx_r2.widget;
52
52
  i0.ɵɵadvance();
53
- i0.ɵɵproperty("auSlot", state_r4.slotFooter)("auSlotProps", i0.ɵɵpureFunction2(2, _c2, state_r4, widget_r5));
53
+ i0.ɵɵproperty("auSlot", state_r4.footer)("auSlotProps", i0.ɵɵpureFunction2(2, _c2, state_r4, widget_r5));
54
54
  } }
55
55
  function ModalDefaultSlotsComponent_ng_template_2_Template(rf, ctx) { if (rf & 1) {
56
56
  i0.ɵɵtemplate(0, ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template, 2, 5, "div", 7);
@@ -61,11 +61,11 @@ function ModalDefaultSlotsComponent_ng_template_2_Template(rf, ctx) { if (rf & 1
61
61
  } if (rf & 2) {
62
62
  const state_r4 = ctx.state;
63
63
  const widget_r5 = ctx.widget;
64
- i0.ɵɵconditional(0, state_r4.slotTitle ? 0 : -1);
64
+ i0.ɵɵconditional(state_r4.title ? 0 : -1);
65
65
  i0.ɵɵadvance(2);
66
- i0.ɵɵproperty("auSlot", state_r4.slotDefault)("auSlotProps", i0.ɵɵpureFunction2(4, _c2, state_r4, widget_r5));
66
+ i0.ɵɵproperty("auSlot", state_r4.children)("auSlotProps", i0.ɵɵpureFunction2(4, _c2, state_r4, widget_r5));
67
67
  i0.ɵɵadvance();
68
- i0.ɵɵconditional(3, state_r4.slotFooter ? 3 : -1);
68
+ i0.ɵɵconditional(state_r4.footer ? 3 : -1);
69
69
  } }
70
70
  const _c3 = ["auModal", ""];
71
71
  const _c4 = ["*"];
@@ -90,7 +90,7 @@ function ModalComponent_Conditional_2_Template(rf, ctx) { if (rf & 1) {
90
90
  i0.ɵɵadvance();
91
91
  i0.ɵɵclassMapInterpolate1("modal-dialog ", ctx_r0.state().fullscreen ? "modal-fullscreen" : "", "");
92
92
  i0.ɵɵadvance(2);
93
- i0.ɵɵproperty("auSlot", ctx_r0.state().slotStructure)("auSlotProps", i0.ɵɵpureFunction2(9, _c2, ctx_r0.state(), ctx_r0.widget));
93
+ i0.ɵɵproperty("auSlot", ctx_r0.state().structure)("auSlotProps", i0.ɵɵpureFunction2(9, _c2, ctx_r0.state(), ctx_r0.widget));
94
94
  } }
95
95
  /**
96
96
  * Directive to provide the slot structure for the modal widget.
@@ -202,24 +202,24 @@ export class ModalDefaultSlotsComponent {
202
202
  template: `
203
203
  <ng-template auModalHeader #header let-state="state" let-widget="widget">
204
204
  <h5 class="modal-title">
205
- <ng-template [auSlot]="state.slotTitle" [auSlotProps]="{state, widget}"></ng-template>
205
+ <ng-template [auSlot]="state.title" [auSlotProps]="{state, widget}"></ng-template>
206
206
  </h5>
207
207
  @if (state.closeButton) {
208
208
  <button class="btn-close" [auUse]="widget.directives.closeButtonDirective"></button>
209
209
  }
210
210
  </ng-template>
211
211
  <ng-template auModalStructure #structure let-state="state" let-widget="widget">
212
- @if (state.slotTitle) {
212
+ @if (state.title) {
213
213
  <div class="modal-header">
214
- <ng-template [auSlot]="state.slotHeader" [auSlotProps]="{state, widget}"></ng-template>
214
+ <ng-template [auSlot]="state.header" [auSlotProps]="{state, widget}"></ng-template>
215
215
  </div>
216
216
  }
217
217
  <div class="modal-body">
218
- <ng-template [auSlot]="state.slotDefault" [auSlotProps]="{state, widget}"></ng-template>
218
+ <ng-template [auSlot]="state.children" [auSlotProps]="{state, widget}"></ng-template>
219
219
  </div>
220
- @if (state.slotFooter) {
220
+ @if (state.footer) {
221
221
  <div class="modal-footer">
222
- <ng-template [auSlot]="state.slotFooter" [auSlotProps]="{state, widget}"></ng-template>
222
+ <ng-template [auSlot]="state.footer" [auSlotProps]="{state, widget}"></ng-template>
223
223
  </div>
224
224
  }
225
225
  </ng-template>
@@ -242,8 +242,8 @@ export const modalDefaultSlotHeader = new ComponentTemplate(ModalDefaultSlotsCom
242
242
  */
243
243
  export const modalDefaultSlotStructure = new ComponentTemplate(ModalDefaultSlotsComponent, 'structure');
244
244
  const defaultConfig = {
245
- slotHeader: modalDefaultSlotHeader,
246
- slotStructure: modalDefaultSlotStructure,
245
+ header: modalDefaultSlotHeader,
246
+ structure: modalDefaultSlotStructure,
247
247
  };
248
248
  /**
249
249
  * Modal component.
@@ -256,7 +256,7 @@ export class ModalComponent extends BaseWidgetDirective {
256
256
  */
257
257
  this.visibleChange = new EventEmitter();
258
258
  /**
259
- * Event to be triggered when the modal is about to be closed (i.e. the close method was called).
259
+ * Event to be triggered when the modal is about to be closed (i.e. the ModalApi.closeclose method was called).
260
260
  */
261
261
  this.beforeClose = new EventEmitter();
262
262
  /**
@@ -282,11 +282,11 @@ export class ModalComponent extends BaseWidgetDirective {
282
282
  }
283
283
  ngAfterContentChecked() {
284
284
  this._widget.patchSlots({
285
- slotDefault: this.slotDefaultFromContent?.templateRef,
286
- slotFooter: this.slotFooterFromContent?.templateRef,
287
- slotHeader: this.slotHeaderFromContent?.templateRef,
288
- slotStructure: this.slotStructureFromContent?.templateRef,
289
- slotTitle: this.slotTitleFromContent?.templateRef,
285
+ children: this.slotDefaultFromContent?.templateRef,
286
+ footer: this.slotFooterFromContent?.templateRef,
287
+ header: this.slotHeaderFromContent?.templateRef,
288
+ structure: this.slotStructureFromContent?.templateRef,
289
+ title: this.slotTitleFromContent?.templateRef,
290
290
  });
291
291
  }
292
292
  static { this.ɵfac = /*@__PURE__*/ (() => { let ɵModalComponent_BaseFactory; return function ModalComponent_Factory(t) { return (ɵModalComponent_BaseFactory || (ɵModalComponent_BaseFactory = i0.ɵɵgetInheritedFactory(ModalComponent)))(t || ModalComponent); }; })(); }
@@ -303,16 +303,16 @@ export class ModalComponent extends BaseWidgetDirective {
303
303
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotTitleFromContent = _t.first);
304
304
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first);
305
305
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotFooterFromContent = _t.first);
306
- } }, inputs: { animated: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auAnimated", "animated", auBooleanAttribute], backdropTransition: [i0.ɵɵInputFlags.None, "auBackdropTransition", "backdropTransition"], modalTransition: [i0.ɵɵInputFlags.None, "auModalTransition", "modalTransition"], visible: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auVisible", "visible", auBooleanAttribute], backdrop: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auBackdrop", "backdrop", auBooleanAttribute], closeOnOutsideClick: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auCloseOnOutsideClick", "closeOnOutsideClick", auBooleanAttribute], container: [i0.ɵɵInputFlags.None, "auContainer", "container"], ariaCloseButtonLabel: [i0.ɵɵInputFlags.None, "auAriaCloseButtonLabel", "ariaCloseButtonLabel"], backdropClass: [i0.ɵɵInputFlags.None, "auBackdropClass", "backdropClass"], closeButton: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auCloseButton", "closeButton", auBooleanAttribute], className: [i0.ɵɵInputFlags.None, "auClassName", "className"], fullscreen: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auFullscreen", "fullscreen", auBooleanAttribute], slotStructure: [i0.ɵɵInputFlags.None, "auSlotStructure", "slotStructure"], slotHeader: [i0.ɵɵInputFlags.None, "auSlotHeader", "slotHeader"], slotTitle: [i0.ɵɵInputFlags.None, "auSlotTitle", "slotTitle"], slotDefault: [i0.ɵɵInputFlags.None, "auSlotDefault", "slotDefault"], slotFooter: [i0.ɵɵInputFlags.None, "auSlotFooter", "slotFooter"], contentData: [i0.ɵɵInputFlags.None, "auContentData", "contentData"] }, outputs: { visibleChange: "auVisibleChange", beforeClose: "auBeforeClose", hidden: "auHidden", shown: "auShown" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c3, ngContentSelectors: _c4, decls: 3, vars: 3, consts: [[3, "auSlotDefault"], [1, "modal-backdrop", 3, "auUseMulti"], [1, "modal", "d-block", 3, "auUseMulti"], [1, "modal-content"], [3, "auSlot", "auSlotProps"]], template: function ModalComponent_Template(rf, ctx) { if (rf & 1) {
306
+ } }, inputs: { animated: [2, "auAnimated", "animated", auBooleanAttribute], backdropTransition: [0, "auBackdropTransition", "backdropTransition"], modalTransition: [0, "auModalTransition", "modalTransition"], visible: [2, "auVisible", "visible", auBooleanAttribute], backdrop: [2, "auBackdrop", "backdrop", auBooleanAttribute], closeOnOutsideClick: [2, "auCloseOnOutsideClick", "closeOnOutsideClick", auBooleanAttribute], container: [0, "auContainer", "container"], ariaCloseButtonLabel: [0, "auAriaCloseButtonLabel", "ariaCloseButtonLabel"], backdropClass: [0, "auBackdropClass", "backdropClass"], closeButton: [2, "auCloseButton", "closeButton", auBooleanAttribute], className: [0, "auClassName", "className"], fullscreen: [2, "auFullscreen", "fullscreen", auBooleanAttribute], structure: [0, "auStructure", "structure"], header: [0, "auHeader", "header"], title: [0, "auTitle", "title"], children: [0, "auChildren", "children"], footer: [0, "auFooter", "footer"], contentData: [0, "auContentData", "contentData"] }, outputs: { visibleChange: "auVisibleChange", beforeClose: "auBeforeClose", hidden: "auHidden", shown: "auShown" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c3, ngContentSelectors: _c4, decls: 3, vars: 3, consts: [[3, "auContentAsSlot"], [1, "modal-backdrop", 3, "auUseMulti"], [1, "modal", "d-block", 3, "auUseMulti"], [1, "modal-content"], [3, "auSlot", "auSlotProps"]], template: function ModalComponent_Template(rf, ctx) { if (rf & 1) {
307
307
  i0.ɵɵprojectionDef();
308
308
  i0.ɵɵtemplate(0, ModalComponent_ng_template_0_Template, 1, 0, "ng-template", 0)(1, ModalComponent_Conditional_1_Template, 1, 4, "div", 1)(2, ModalComponent_Conditional_2_Template, 4, 12, "div", 2);
309
309
  } if (rf & 2) {
310
- i0.ɵɵproperty("auSlotDefault", ctx.defaultSlots);
310
+ i0.ɵɵproperty("auContentAsSlot", ctx.defaultSlots);
311
311
  i0.ɵɵadvance();
312
- i0.ɵɵconditional(1, !ctx.state().backdropHidden ? 1 : -1);
312
+ i0.ɵɵconditional(!ctx.state().backdropHidden ? 1 : -1);
313
313
  i0.ɵɵadvance();
314
- i0.ɵɵconditional(2, !ctx.state().hidden ? 2 : -1);
315
- } }, dependencies: [UseMultiDirective, SlotDirective, SlotDefaultDirective], encapsulation: 2, changeDetection: 0 }); }
314
+ i0.ɵɵconditional(!ctx.state().hidden ? 2 : -1);
315
+ } }, dependencies: [UseMultiDirective, SlotDirective, ContentAsSlotDirective], encapsulation: 2, changeDetection: 0 }); }
316
316
  }
317
317
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalComponent, [{
318
318
  type: Component,
@@ -320,9 +320,9 @@ export class ModalComponent extends BaseWidgetDirective {
320
320
  selector: '[auModal]',
321
321
  standalone: true,
322
322
  changeDetection: ChangeDetectionStrategy.OnPush,
323
- imports: [UseMultiDirective, SlotDirective, SlotDefaultDirective],
323
+ imports: [UseMultiDirective, SlotDirective, ContentAsSlotDirective],
324
324
  template: `
325
- <ng-template [auSlotDefault]="defaultSlots"><ng-content></ng-content></ng-template>
325
+ <ng-template [auContentAsSlot]="defaultSlots"><ng-content></ng-content></ng-template>
326
326
  @if (!state().backdropHidden) {
327
327
  <div class="modal-backdrop" [auUseMulti]="[widget.directives.backdropPortalDirective, widget.directives.backdropDirective]"></div>
328
328
  }
@@ -330,7 +330,7 @@ export class ModalComponent extends BaseWidgetDirective {
330
330
  <div class="modal d-block" [auUseMulti]="[widget.directives.modalPortalDirective, widget.directives.modalDirective]">
331
331
  <div class="modal-dialog {{ state().fullscreen ? 'modal-fullscreen' : '' }}">
332
332
  <div class="modal-content">
333
- <ng-template [auSlot]="state().slotStructure" [auSlotProps]="{state: state(), widget}"></ng-template>
333
+ <ng-template [auSlot]="state().structure" [auSlotProps]="{state: state(), widget}"></ng-template>
334
334
  </div>
335
335
  </div>
336
336
  </div>
@@ -373,33 +373,33 @@ export class ModalComponent extends BaseWidgetDirective {
373
373
  }], fullscreen: [{
374
374
  type: Input,
375
375
  args: [{ alias: 'auFullscreen', transform: auBooleanAttribute }]
376
- }], slotStructure: [{
376
+ }], structure: [{
377
377
  type: Input,
378
- args: ['auSlotStructure']
378
+ args: ['auStructure']
379
379
  }], slotStructureFromContent: [{
380
380
  type: ContentChild,
381
381
  args: [ModalStructureDirective, { static: false }]
382
- }], slotHeader: [{
382
+ }], header: [{
383
383
  type: Input,
384
- args: ['auSlotHeader']
384
+ args: ['auHeader']
385
385
  }], slotHeaderFromContent: [{
386
386
  type: ContentChild,
387
387
  args: [ModalHeaderDirective, { static: false }]
388
- }], slotTitle: [{
388
+ }], title: [{
389
389
  type: Input,
390
- args: ['auSlotTitle']
390
+ args: ['auTitle']
391
391
  }], slotTitleFromContent: [{
392
392
  type: ContentChild,
393
393
  args: [ModalTitleDirective, { static: false }]
394
- }], slotDefault: [{
394
+ }], children: [{
395
395
  type: Input,
396
- args: ['auSlotDefault']
396
+ args: ['auChildren']
397
397
  }], slotDefaultFromContent: [{
398
398
  type: ContentChild,
399
399
  args: [ModalBodyDirective, { static: false }]
400
- }], slotFooter: [{
400
+ }], footer: [{
401
401
  type: Input,
402
- args: ['auSlotFooter']
402
+ args: ['auFooter']
403
403
  }], slotFooterFromContent: [{
404
404
  type: ContentChild,
405
405
  args: [ModalFooterDirective, { static: false }]
@@ -420,4 +420,4 @@ export class ModalComponent extends BaseWidgetDirective {
420
420
  args: ['auShown']
421
421
  }] }); })();
422
422
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ModalComponent, { className: "ModalComponent", filePath: "components/modal/modal.component.ts", lineNumber: 161 }); })();
423
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../src/components/modal/modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent, TransitionFn} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDefaultDirective,\n\tSlotDirective,\n\tUseDirective,\n\tUseMultiDirective,\n\tauBooleanAttribute,\n} from '@agnos-ui/angular-headless';\nimport type {ModalContext, ModalProps, ModalWidget, ModalBeforeCloseEvent} from './modal';\nimport {createModal} from './modal';\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\n/**\n * Directive to provide the slot structure for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalStructure]', standalone: true})\nexport class ModalStructureDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(dir: ModalStructureDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the slot header for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalHeader]', standalone: true})\nexport class ModalHeaderDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalHeaderDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the slot title for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalTitle]', standalone: true})\nexport class ModalTitleDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalTitleDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the default slot for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalBody]', standalone: true})\nexport class ModalBodyDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalBodyDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the slot footer for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalFooter]', standalone: true})\nexport class ModalFooterDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalFooterDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Component containing the default slots for the modal.\n */\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, ModalHeaderDirective, ModalStructureDirective, UseDirective],\n\ttemplate: `\n\t\t<ng-template auModalHeader #header let-state=\"state\" let-widget=\"widget\">\n\t\t\t<h5 class=\"modal-title\">\n\t\t\t\t<ng-template [auSlot]=\"state.slotTitle\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t</h5>\n\t\t\t@if (state.closeButton) {\n\t\t\t\t<button class=\"btn-close\" [auUse]=\"widget.directives.closeButtonDirective\"></button>\n\t\t\t}\n\t\t</ng-template>\n\t\t<ng-template auModalStructure #structure let-state=\"state\" let-widget=\"widget\">\n\t\t\t@if (state.slotTitle) {\n\t\t\t\t<div class=\"modal-header\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.slotHeader\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t<div class=\"modal-body\">\n\t\t\t\t<ng-template [auSlot]=\"state.slotDefault\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t</div>\n\t\t\t@if (state.slotFooter) {\n\t\t\t\t<div class=\"modal-footer\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.slotFooter\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nexport class ModalDefaultSlotsComponent<Data> {\n\t@ViewChild('header', {static: true}) header: TemplateRef<ModalContext<Data>>;\n\t@ViewChild('structure', {static: true}) structure: TemplateRef<ModalContext<Data>>;\n}\n\n/**\n * Default slot for modal header.\n */\nexport const modalDefaultSlotHeader = new ComponentTemplate(ModalDefaultSlotsComponent, 'header');\n\n/**\n * Default slot for modal structure.\n */\nexport const modalDefaultSlotStructure = new ComponentTemplate(ModalDefaultSlotsComponent, 'structure');\n\nconst defaultConfig: Partial<ModalProps<any>> = {\n\tslotHeader: modalDefaultSlotHeader,\n\tslotStructure: modalDefaultSlotStructure,\n};\n\n/**\n * Modal component.\n */\n@Component({\n\tselector: '[auModal]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseMultiDirective, SlotDirective, SlotDefaultDirective],\n\ttemplate: `\n\t\t<ng-template [auSlotDefault]=\"defaultSlots\"><ng-content></ng-content></ng-template>\n\t\t@if (!state().backdropHidden) {\n\t\t\t<div class=\"modal-backdrop\" [auUseMulti]=\"[widget.directives.backdropPortalDirective, widget.directives.backdropDirective]\"></div>\n\t\t}\n\t\t@if (!state().hidden) {\n\t\t\t<div class=\"modal d-block\" [auUseMulti]=\"[widget.directives.modalPortalDirective, widget.directives.modalDirective]\">\n\t\t\t\t<div class=\"modal-dialog {{ state().fullscreen ? 'modal-fullscreen' : '' }}\">\n\t\t\t\t\t<div class=\"modal-content\">\n\t\t\t\t\t\t<ng-template [auSlot]=\"state().slotStructure\" [auSlotProps]=\"{state: state(), widget}\"></ng-template>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t}\n\t`,\n})\nexport class ModalComponent<Data> extends BaseWidgetDirective<ModalWidget<Data>> implements AfterContentChecked {\n\t/**\n\t * Whether the modal and its backdrop (if present) should be animated when shown or hidden.\n\t */\n\t@Input({alias: 'auAnimated', transform: auBooleanAttribute}) animated: boolean | undefined;\n\n\t/**\n\t * The transition to use for the backdrop behind the modal (if present).\n\t */\n\t@Input('auBackdropTransition') backdropTransition: TransitionFn | undefined;\n\n\t/**\n\t * The transition to use for the modal.\n\t */\n\t@Input('auModalTransition') modalTransition: TransitionFn | undefined;\n\n\t/**\n\t * Whether the modal should be visible when the transition is completed.\n\t */\n\t@Input({alias: 'auVisible', transform: auBooleanAttribute}) visible: boolean | undefined;\n\n\t/**\n\t * Whether a backdrop should be created behind the modal.\n\t */\n\t@Input({alias: 'auBackdrop', transform: auBooleanAttribute}) backdrop: boolean | undefined;\n\n\t/**\n\t * Whether the modal should be closed when clicking on the viewport outside the modal.\n\t */\n\t@Input({alias: 'auCloseOnOutsideClick', transform: auBooleanAttribute}) closeOnOutsideClick: boolean | undefined;\n\n\t/**\n\t * Which element should contain the modal and backdrop DOM elements.\n\t * If it is not null, the modal and backdrop DOM elements are moved to the specified container.\n\t * Otherwise, they stay where the widget is located.\n\t */\n\t@Input('auContainer') container: HTMLElement | null | undefined;\n\n\t/**\n\t * Value of the aria-label attribute to put on the close button.\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t/**\n\t * Classes to add on the backdrop DOM element.\n\t */\n\t@Input('auBackdropClass') backdropClass: string | undefined;\n\n\t/**\n\t * Whether to display the close button.\n\t */\n\t@Input({alias: 'auCloseButton', transform: auBooleanAttribute}) closeButton: 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 * Option to create a fullscreen modal, according to the bootstrap documentation.\n\t */\n\t@Input({alias: 'auFullscreen', transform: auBooleanAttribute}) fullscreen: boolean | undefined;\n\n\t@Input('auSlotStructure') slotStructure: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalStructureDirective, {static: false})\n\tslotStructureFromContent: ModalStructureDirective<Data> | null;\n\n\t@Input('auSlotHeader') slotHeader: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalHeaderDirective, {static: false})\n\tslotHeaderFromContent: ModalHeaderDirective<Data> | null;\n\n\t@Input('auSlotTitle') slotTitle: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalTitleDirective, {static: false})\n\tslotTitleFromContent: ModalTitleDirective<Data> | null;\n\n\t@Input('auSlotDefault') slotDefault: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalBodyDirective, {static: false})\n\tslotDefaultFromContent: ModalBodyDirective<Data> | null;\n\n\t@Input('auSlotFooter') slotFooter: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalFooterDirective, {static: false})\n\tslotFooterFromContent: ModalFooterDirective<Data> | null;\n\n\t/**\n\t * Data to use in content slots\n\t */\n\t@Input('auContentData') contentData: Data | undefined;\n\n\t/**\n\t * Event to be triggered when the visible property changes.\n\t */\n\t@Output('auVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n\t/**\n\t * Event to be triggered when the modal is about to be closed (i.e. the close method was called).\n\t */\n\t@Output('auBeforeClose') beforeClose = new EventEmitter<ModalBeforeCloseEvent>();\n\n\t/**\n\t * Event to be triggered when the transition is completed and the modal is not visible.\n\t */\n\t@Output('auHidden') hidden = new EventEmitter<void>();\n\n\t/**\n\t * Event to be triggered when the transition is completed and the modal is visible.\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\n\treadonly defaultSlots = writable(defaultConfig);\n\n\treadonly _widget = callWidgetFactory<ModalWidget<Data>>({\n\t\tfactory: createModal,\n\t\twidgetName: 'modal',\n\t\tdefaultConfig: this.defaultSlots,\n\t\tevents: {\n\t\t\tonShown: () => this.shown.emit(),\n\t\t\tonHidden: () => this.hidden.emit(),\n\t\t\tonBeforeClose: (event) => this.beforeClose.emit(event),\n\t\t\tonVisibleChange: (event) => this.visibleChange.emit(event),\n\t\t},\n\t});\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tslotDefault: this.slotDefaultFromContent?.templateRef,\n\t\t\tslotFooter: this.slotFooterFromContent?.templateRef,\n\t\t\tslotHeader: this.slotHeaderFromContent?.templateRef,\n\t\t\tslotStructure: this.slotStructureFromContent?.templateRef,\n\t\t\tslotTitle: this.slotTitleFromContent?.templateRef,\n\t\t});\n\t}\n}\n"]}
423
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../src/components/modal/modal.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} from '@agnos-ui/angular-headless';\nimport type {ModalContext, ModalProps, ModalWidget, ModalBeforeCloseEvent} from './modal';\nimport {createModal} from './modal';\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\n/**\n * Directive to provide the slot structure for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalStructure]', standalone: true})\nexport class ModalStructureDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(dir: ModalStructureDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the slot header for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalHeader]', standalone: true})\nexport class ModalHeaderDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalHeaderDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the slot title for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalTitle]', standalone: true})\nexport class ModalTitleDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalTitleDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the default slot for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalBody]', standalone: true})\nexport class ModalBodyDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalBodyDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the slot footer for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalFooter]', standalone: true})\nexport class ModalFooterDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalFooterDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Component containing the default slots for the modal.\n */\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, ModalHeaderDirective, ModalStructureDirective, UseDirective],\n\ttemplate: `\n\t\t<ng-template auModalHeader #header let-state=\"state\" let-widget=\"widget\">\n\t\t\t<h5 class=\"modal-title\">\n\t\t\t\t<ng-template [auSlot]=\"state.title\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t</h5>\n\t\t\t@if (state.closeButton) {\n\t\t\t\t<button class=\"btn-close\" [auUse]=\"widget.directives.closeButtonDirective\"></button>\n\t\t\t}\n\t\t</ng-template>\n\t\t<ng-template auModalStructure #structure let-state=\"state\" let-widget=\"widget\">\n\t\t\t@if (state.title) {\n\t\t\t\t<div class=\"modal-header\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.header\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t<div class=\"modal-body\">\n\t\t\t\t<ng-template [auSlot]=\"state.children\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t</div>\n\t\t\t@if (state.footer) {\n\t\t\t\t<div class=\"modal-footer\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.footer\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nexport class ModalDefaultSlotsComponent<Data> {\n\t@ViewChild('header', {static: true}) header!: TemplateRef<ModalContext<Data>>;\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<ModalContext<Data>>;\n}\n\n/**\n * Default slot for modal header.\n */\nexport const modalDefaultSlotHeader = new ComponentTemplate(ModalDefaultSlotsComponent, 'header');\n\n/**\n * Default slot for modal structure.\n */\nexport const modalDefaultSlotStructure = new ComponentTemplate(ModalDefaultSlotsComponent, 'structure');\n\nconst defaultConfig: Partial<ModalProps<any>> = {\n\theader: modalDefaultSlotHeader,\n\tstructure: modalDefaultSlotStructure,\n};\n\n/**\n * Modal component.\n */\n@Component({\n\tselector: '[auModal]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseMultiDirective, SlotDirective, ContentAsSlotDirective],\n\ttemplate: `\n\t\t<ng-template [auContentAsSlot]=\"defaultSlots\"><ng-content></ng-content></ng-template>\n\t\t@if (!state().backdropHidden) {\n\t\t\t<div class=\"modal-backdrop\" [auUseMulti]=\"[widget.directives.backdropPortalDirective, widget.directives.backdropDirective]\"></div>\n\t\t}\n\t\t@if (!state().hidden) {\n\t\t\t<div class=\"modal d-block\" [auUseMulti]=\"[widget.directives.modalPortalDirective, widget.directives.modalDirective]\">\n\t\t\t\t<div class=\"modal-dialog {{ state().fullscreen ? 'modal-fullscreen' : '' }}\">\n\t\t\t\t\t<div class=\"modal-content\">\n\t\t\t\t\t\t<ng-template [auSlot]=\"state().structure\" [auSlotProps]=\"{state: state(), widget}\"></ng-template>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t}\n\t`,\n})\nexport class ModalComponent<Data> extends BaseWidgetDirective<ModalWidget<Data>> implements AfterContentChecked {\n\t/**\n\t * Whether the modal and its backdrop (if present) should be animated when shown or hidden.\n\t */\n\t@Input({alias: 'auAnimated', transform: auBooleanAttribute}) animated: boolean | undefined;\n\n\t/**\n\t * The transition to use for the backdrop behind the modal (if present).\n\t */\n\t@Input('auBackdropTransition') backdropTransition: TransitionFn | undefined;\n\n\t/**\n\t * The transition to use for the modal.\n\t */\n\t@Input('auModalTransition') modalTransition: TransitionFn | undefined;\n\n\t/**\n\t * Whether the modal should be visible when the transition is completed.\n\t */\n\t@Input({alias: 'auVisible', transform: auBooleanAttribute}) visible: boolean | undefined;\n\n\t/**\n\t * Whether a backdrop should be created behind the modal.\n\t */\n\t@Input({alias: 'auBackdrop', transform: auBooleanAttribute}) backdrop: boolean | undefined;\n\n\t/**\n\t * Whether the modal should be closed when clicking on the viewport outside the modal.\n\t */\n\t@Input({alias: 'auCloseOnOutsideClick', transform: auBooleanAttribute}) closeOnOutsideClick: boolean | undefined;\n\n\t/**\n\t * Which element should contain the modal and backdrop DOM elements.\n\t * If it is not null, the modal and backdrop DOM elements are moved to the specified container.\n\t * Otherwise, they stay where the widget is located.\n\t */\n\t@Input('auContainer') container: HTMLElement | null | undefined;\n\n\t/**\n\t * Value of the aria-label attribute to put on the close button.\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t/**\n\t * Classes to add on the backdrop DOM element.\n\t */\n\t@Input('auBackdropClass') backdropClass: string | undefined;\n\n\t/**\n\t * Whether to display the close button.\n\t */\n\t@Input({alias: 'auCloseButton', transform: auBooleanAttribute}) closeButton: 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 * Option to create a fullscreen modal, according to the bootstrap documentation.\n\t */\n\t@Input({alias: 'auFullscreen', transform: auBooleanAttribute}) fullscreen: boolean | undefined;\n\n\t/**\n\t * Structure of the modal.\n\t * The default structure uses ModalCommonPropsAndState.header header, ModalCommonPropsAndState.children children and ModalCommonPropsAndState.footer footer.\n\t */\n\t@Input('auStructure') structure: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalStructureDirective, {static: false})\n\tslotStructureFromContent: ModalStructureDirective<Data> | undefined;\n\n\t/**\n\t * Header of the modal. The default header includes ModalCommonPropsAndState.title title.\n\t */\n\t@Input('auHeader') header: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalHeaderDirective, {static: false})\n\tslotHeaderFromContent: ModalHeaderDirective<Data> | undefined;\n\n\t/**\n\t * Title of the modal.\n\t */\n\t@Input('auTitle') title: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalTitleDirective, {static: false})\n\tslotTitleFromContent: ModalTitleDirective<Data> | undefined;\n\n\t/**\n\t * Body of the modal.\n\t */\n\t@Input('auChildren') children: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalBodyDirective, {static: false})\n\tslotDefaultFromContent: ModalBodyDirective<Data> | undefined;\n\n\t/**\n\t * Footer of the modal.\n\t */\n\t@Input('auFooter') footer: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalFooterDirective, {static: false})\n\tslotFooterFromContent: ModalFooterDirective<Data> | undefined;\n\n\t/**\n\t * Data to use in content slots\n\t */\n\t@Input('auContentData') contentData: Data | undefined;\n\n\t/**\n\t * Event to be triggered when the visible property changes.\n\t */\n\t@Output('auVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n\t/**\n\t * Event to be triggered when the modal is about to be closed (i.e. the ModalApi.closeclose  method was called).\n\t */\n\t@Output('auBeforeClose') beforeClose = new EventEmitter<ModalBeforeCloseEvent>();\n\n\t/**\n\t * Event to be triggered when the transition is completed and the modal is not visible.\n\t */\n\t@Output('auHidden') hidden = new EventEmitter<void>();\n\n\t/**\n\t * Event to be triggered when the transition is completed and the modal is visible.\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\n\treadonly defaultSlots = writable(defaultConfig);\n\n\treadonly _widget = callWidgetFactory<ModalWidget<Data>>({\n\t\tfactory: createModal,\n\t\twidgetName: 'modal',\n\t\tdefaultConfig: this.defaultSlots,\n\t\tevents: {\n\t\t\tonShown: () => this.shown.emit(),\n\t\t\tonHidden: () => this.hidden.emit(),\n\t\t\tonBeforeClose: (event) => this.beforeClose.emit(event),\n\t\t\tonVisibleChange: (event) => this.visibleChange.emit(event),\n\t\t},\n\t});\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tchildren: this.slotDefaultFromContent?.templateRef,\n\t\t\tfooter: this.slotFooterFromContent?.templateRef,\n\t\t\theader: this.slotHeaderFromContent?.templateRef,\n\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\ttitle: this.slotTitleFromContent?.templateRef,\n\t\t} as any);\n\t}\n}\n"]}