@agnos-ui/angular-bootstrap 0.4.4 → 0.5.0-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/README.md +2 -2
  2. package/agnos-ui-angular.module.d.ts +2 -1
  3. package/components/accordion/accordion.component.d.ts +40 -18
  4. package/components/accordion/accordion.gen.d.ts +37 -9
  5. package/components/alert/alert.component.d.ts +29 -17
  6. package/components/alert/alert.gen.d.ts +21 -2
  7. package/components/collapse/collapse.component.d.ts +79 -0
  8. package/components/collapse/collapse.gen.d.ts +146 -0
  9. package/components/collapse/index.d.ts +2 -0
  10. package/components/modal/modal.component.d.ts +13 -19
  11. package/components/modal/modal.gen.d.ts +35 -18
  12. package/components/modal/modal.service.d.ts +5 -1
  13. package/components/pagination/pagination.component.d.ts +20 -15
  14. package/components/pagination/pagination.gen.d.ts +49 -29
  15. package/components/progressbar/progressbar.component.d.ts +32 -16
  16. package/components/progressbar/progressbar.gen.d.ts +21 -4
  17. package/components/rating/rating.component.d.ts +11 -4
  18. package/components/rating/rating.gen.d.ts +25 -17
  19. package/components/select/select.component.d.ts +24 -4
  20. package/components/select/select.gen.d.ts +41 -25
  21. package/components/slider/slider.component.d.ts +32 -23
  22. package/components/slider/slider.gen.d.ts +54 -33
  23. package/components/toast/toast.component.d.ts +29 -17
  24. package/components/toast/toast.gen.d.ts +22 -2
  25. package/config.d.ts +16 -5
  26. package/config.gen.d.ts +5 -0
  27. package/esm2022/agnos-ui-angular.module.mjs +12 -5
  28. package/esm2022/components/accordion/accordion.component.mjs +165 -134
  29. package/esm2022/components/accordion/accordion.gen.mjs +1 -1
  30. package/esm2022/components/alert/alert.component.mjs +90 -65
  31. package/esm2022/components/alert/alert.gen.mjs +1 -1
  32. package/esm2022/components/collapse/collapse.component.mjs +89 -0
  33. package/esm2022/components/collapse/collapse.gen.mjs +15 -0
  34. package/esm2022/components/collapse/index.mjs +3 -0
  35. package/esm2022/components/modal/modal.component.mjs +111 -99
  36. package/esm2022/components/modal/modal.gen.mjs +1 -1
  37. package/esm2022/components/modal/modal.service.mjs +7 -5
  38. package/esm2022/components/pagination/pagination.component.mjs +138 -123
  39. package/esm2022/components/pagination/pagination.gen.mjs +1 -1
  40. package/esm2022/components/progressbar/progressbar.component.mjs +94 -55
  41. package/esm2022/components/progressbar/progressbar.gen.mjs +1 -1
  42. package/esm2022/components/rating/rating.component.mjs +41 -35
  43. package/esm2022/components/rating/rating.gen.mjs +1 -1
  44. package/esm2022/components/select/select.component.mjs +103 -118
  45. package/esm2022/components/select/select.gen.mjs +1 -1
  46. package/esm2022/components/slider/slider.component.mjs +126 -111
  47. package/esm2022/components/slider/slider.gen.mjs +1 -1
  48. package/esm2022/components/toast/toast.component.mjs +106 -81
  49. package/esm2022/components/toast/toast.gen.mjs +1 -1
  50. package/esm2022/config.gen.mjs +1 -1
  51. package/esm2022/config.mjs +17 -1
  52. package/esm2022/index.mjs +2 -1
  53. package/fesm2022/agnos-ui-angular-bootstrap.mjs +1085 -806
  54. package/fesm2022/agnos-ui-angular-bootstrap.mjs.map +1 -1
  55. package/index.d.ts +8 -7
  56. package/package.json +9 -8
@@ -30,4 +30,4 @@ export { export_createAccordion as createAccordion };
30
30
  */
31
31
  const export_factoryCreateAccordion = factoryCreateAccordion;
32
32
  export { export_factoryCreateAccordion as factoryCreateAccordion };
33
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.gen.js","sourceRoot":"","sources":["../../../../src/components/accordion/accordion.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,yBAAyB,EAAE,mBAAmB,EAAE,eAAe,EAAE,sBAAsB,EAAC,MAAM,+CAA+C,CAAC;AAKtJ;;;GAGG;AACH,MAAM,gCAAgC,GAAyB,yBAAgC,CAAC;AAChG,OAAO,EAAC,gCAAgC,IAAI,yBAAyB,EAAC,CAAC;AA6VvE;;;;GAIG;AACH,MAAM,0BAA0B,GAAuC,mBAA0B,CAAC;AAClG,OAAO,EAAC,0BAA0B,IAAI,mBAAmB,EAAC,CAAC;AAI3D;;;;GAIG;AACH,MAAM,sBAAsB,GAAmC,eAAsB,CAAC;AACtF,OAAO,EAAC,sBAAsB,IAAI,eAAe,EAAC,CAAC;AAInD;;;;;;;;GAQG;AACH,MAAM,6BAA6B,GAAgN,sBAA6B,CAAC;AACjR,OAAO,EAAC,6BAA6B,IAAI,sBAAsB,EAAC,CAAC","sourcesContent":["import {getAccordionDefaultConfig, createAccordionItem, createAccordion, factoryCreateAccordion} from '@agnos-ui/core-bootstrap/components/accordion';\nimport type {WidgetSlotContext, SlotContent, TransitionFn, Widget, WidgetFactory, ConfigValidator, PropsConfig, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default accordion config\n * @returns the default accordion config\n */\nconst export_getAccordionDefaultConfig: () => AccordionProps = getAccordionDefaultConfig as any;\nexport {export_getAccordionDefaultConfig as getAccordionDefaultConfig};\n\n\n\nexport type AccordionItemContext = WidgetSlotContext<AccordionItemWidget>;\n\nexport interface AccordionState {\n\t\n\t/**\n\t * Array containing all the accordion-items contained in the accordion.\n\t */\n\titemWidgets: AccordionItemWidget[];\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\titemStructure: SlotContent<AccordionItemContext>;\n}\n\nexport interface AccordionProps {\n\t\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * collapseVerticalTransition\n\t * ```\n\t */\n\titemTransition: TransitionFn;\n\t\n\t/**\n\t * If `true`, only one accordion-item at the time can stay open.\n\t *\n\t * @defaultValue `false`\n\t */\n\tcloseOthers: boolean;\n\t\n\t/**\n\t * An event fired when an item is shown.\n\t *\n\t * Event payload is the id of the item.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonItemShown: (itemId: string) => void;\n\t\n\t/**\n\t * An event fired when an item is hidden.\n\t *\n\t * Event payload is the id of the item.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonItemHidden: (itemId: string) => void;\n\t\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t *\n\t * @defaultValue `true`\n\t */\n\titemDestroyOnHide: boolean;\n\t\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t *\n\t * @defaultValue `true`\n\t */\n\titemAnimated: boolean;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemHeaderClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item toggle button DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemButtonClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemBodyContainerClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemBodyClassName: string;\n\t\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemHeadingTag: string;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\titemStructure: SlotContent<AccordionItemContext>;\n}\n\n\n\nexport type AccordionWidget = Widget<AccordionProps, AccordionState, AccordionApi, object, AccordionDirectives>;\n\nexport interface AccordionItemState {\n\t\n\t/**\n\t * If `true` the content of the accordion-item collapse should be in DOM. Its value depends on the\n\t * value of the `visible` and `destroyOnHide`.\n\t */\n\tshouldBeInDOM: boolean;\n\t\n\t/**\n\t * If `true`, the accordion-item will be visible (expanded). Otherwise, it will be hidden (collapsed).\n\t */\n\tvisible: boolean;\n\t\n\t/**\n\t * If `true`, the accordion-item will be disabled.\n\t * It will not react to user's clicks, but still will be possible to toggle programmatically.\n\t */\n\tdisabled: boolean;\n\t\n\t/**\n\t * The id of the accordion-item. It can be used for controlling the accordion-item via the accordion api.\n\t */\n\tid: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\theaderClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item collapse DOM element.\n\t */\n\tbuttonClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\tbodyContainerClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\tbodyClassName: string;\n\t\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\theadingTag: string;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tstructure: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion body.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tchildren: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion button inside the accordion header.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\theader: SlotContent<AccordionItemContext>;\n}\n\nexport interface AccordionItemProps {\n\t\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t */\n\tanimated: boolean;\n\t\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t */\n\ttransition: TransitionFn;\n\t\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t */\n\tdestroyOnHide: boolean;\n\t\n\t/**\n\t * An event fired when an item is shown.\n\t */\n\tonShown: () => void;\n\t\n\t/**\n\t * An event fired when an item is hidden.\n\t */\n\tonHidden: () => void;\n\t\n\t/**\n\t * An event fired when the `visible` value changes.\n\t *\n\t * Event payload is the new value of visible.\n\t */\n\tonVisibleChange: (visible: boolean) => void;\n\t\n\t/**\n\t * If `true`, the accordion-item will be visible (expanded). Otherwise, it will be hidden (collapsed).\n\t */\n\tvisible: boolean;\n\t\n\t/**\n\t * If `true`, the accordion-item will be disabled.\n\t * It will not react to user's clicks, but still will be possible to toggle programmatically.\n\t */\n\tdisabled: boolean;\n\t\n\t/**\n\t * The id of the accordion-item. It can be used for controlling the accordion-item via the accordion api.\n\t */\n\tid: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\theaderClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item collapse DOM element.\n\t */\n\tbuttonClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\tbodyContainerClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\tbodyClassName: string;\n\t\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\theadingTag: string;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tstructure: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion body.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tchildren: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion button inside the accordion header.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\theader: SlotContent<AccordionItemContext>;\n}\n\n\n\nexport type AccordionItemWidget = Widget<AccordionItemProps, AccordionItemState, AccordionItemApi, AccordionItemActions, AccordionItemDirectives>;\n\n\n\n/**\n * Create an AccordionItemWidget with given config props\n * @param config - an optional AccordionItem config\n * @returns an AccordionItemWidget\n */\nconst export_createAccordionItem: WidgetFactory<AccordionItemWidget> = createAccordionItem as any;\nexport {export_createAccordionItem as createAccordionItem};\n\n\n\n/**\n * Create an AccordionWidget with given config props\n * @param config - an optional accordion config\n * @returns an AccordionWidget\n */\nconst export_createAccordion: WidgetFactory<AccordionWidget> = createAccordion as any;\nexport {export_createAccordion as createAccordion};\n\n\n\n/**\n * Create an accordion WidgetFactory based on a item factory and the list of item props that should inherit from the parent accordion\n *\n * @param itemFactory - the item factory\n * @param accordionItemProps - the list of item props\n * @param accordionConfig - the default accordion config\n * @param accordionValidator - the validator of props\n * @returns the accordion widget factory\n */\nconst export_factoryCreateAccordion: (itemFactory?: WidgetFactory<AccordionItemWidget>, accordionItemProps?: string[], accordionConfig?: AccordionProps, accordionValidator?: ConfigValidator<AccordionProps>) => WidgetFactory<AccordionWidget> = factoryCreateAccordion as any;\nexport {export_factoryCreateAccordion as factoryCreateAccordion};\n\nexport interface AccordionApi {\n\t\n\t/**\n\t * Given the itemId, will expand the corresponding accordion-item.\n\t *\n\t * If the itemId is not valid, nothing will happen.\n\t */\n\texpand(itemId: string): void;\n\t\n\t/**\n\t * Given the itemId, will collapse the corresponding accordion-item.\n\t *\n\t * If the itemId is not valid, nothing will happen.\n\t */\n\tcollapse(itemId: string): void;\n\t\n\t/**\n\t * Given the itemId, will toggle the corresponding accordion-item.\n\t *\n\t * If the itemId is not valid, nothing will happen.\n\t */\n\ttoggle(itemId: string): void;\n\t\n\t/**\n\t * It will expand all the items in the accordion.\n\t *\n\t * If `closeOthers` is `true` it will expand only the last accordion-item.\n\t */\n\texpandAll(): void;\n\t\n\t/**\n\t * It will collapse all the accordion-items in the accordion.\n\t */\n\tcollapseAll(): void;\n\t\n\t/**\n\t * Creates a new accordionItem.\n\t */\n\tregisterItem(itemConfig?: PropsConfig<AccordionItemProps>): AccordionItemWidget;\n}\n\nexport interface AccordionDirectives {\n\t\n\t/**\n\t * Directive to put on the accordion DOM element\n\t */\n\taccordionDirective: Directive;\n}\n\nexport interface AccordionItemActions {\n\t\n\t/**\n\t * Action to be called when the user clicks on the accordion-item button. If the accordion-item is disabled nothing will happen.\n\t */\n\tclick(): void;\n}\n\nexport interface AccordionItemApi {\n\t\n\t/**\n\t * It will collapse the accordion-item.\n\t */\n\tcollapse(): void;\n\t\n\n\t/**\n\t * It will expand the accordion-item.\n\t */\n\texpand(): void;\n\t\n\t/**\n\t * It will toggle the accordion-item.\n\t */\n\ttoggle(): void;\n\t\n\t/**\n\t * Method to be called after the initialization to allow animations.\n\t */\n\tinitDone(): void;\n}\n\nexport interface AccordionItemDirectives {\n\t\n\t/**\n\t * Directive to use in special cases, if the accordion header does not use a button element to control the collapsing.\n\t */\n\ttoggleDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the button element that will control the collapsing of the accordion-item.\n\t */\n\tbuttonDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the accordion-item header that will contain the button element.\n\t */\n\theaderDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the accordion-item body.\n\t */\n\tbodyDirective: Directive;\n\t\n\t/**\n\t * Directive to apply the itemTransition\n\t */\n\ttransitionDirective: Directive;\n\t\n\t/**\n\t * Directive to apply aria attributes to the expanded body panel\n\t */\n\tbodyContainerAttrsDirective: Directive;\n\t\n\t/**\n\t * Directive to be put on the accordion-item body container. It will handle the animation.\n\t */\n\tbodyContainerDirective: Directive;\n\t\n\t/**\n\t * Directive to be put on the accordion-item. It will handle adding the accordion-item to the accordion.\n\t */\n\titemDirective: Directive;\n}\n\n"]}
33
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.gen.js","sourceRoot":"","sources":["../../../../src/components/accordion/accordion.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,yBAAyB,EAAE,mBAAmB,EAAE,eAAe,EAAE,sBAAsB,EAAC,MAAM,+CAA+C,CAAC;AAKtJ;;;GAGG;AACH,MAAM,gCAAgC,GAAyB,yBAAgC,CAAC;AAChG,OAAO,EAAC,gCAAgC,IAAI,yBAAyB,EAAC,CAAC;AAkXvE;;;;GAIG;AACH,MAAM,0BAA0B,GAAuC,mBAA0B,CAAC;AAClG,OAAO,EAAC,0BAA0B,IAAI,mBAAmB,EAAC,CAAC;AAI3D;;;;GAIG;AACH,MAAM,sBAAsB,GAAmC,eAAsB,CAAC;AACtF,OAAO,EAAC,sBAAsB,IAAI,eAAe,EAAC,CAAC;AAInD;;;;;;;;GAQG;AACH,MAAM,6BAA6B,GAAgN,sBAA6B,CAAC;AACjR,OAAO,EAAC,6BAA6B,IAAI,sBAAsB,EAAC,CAAC","sourcesContent":["import {getAccordionDefaultConfig, createAccordionItem, createAccordion, factoryCreateAccordion} from '@agnos-ui/core-bootstrap/components/accordion';\nimport type {WidgetSlotContext, SlotContent, TransitionFn, Widget, WidgetFactory, ConfigValidator, PropsConfig, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default accordion config\n * @returns the default accordion config\n */\nconst export_getAccordionDefaultConfig: () => AccordionProps = getAccordionDefaultConfig as any;\nexport {export_getAccordionDefaultConfig as getAccordionDefaultConfig};\n\n\n\n/**\n * Represents the context for an accordion item within the accordion component.\n */\nexport interface AccordionItemContext extends WidgetSlotContext<AccordionItemWidget> {}\n\n/**\n * Represents the state of an Accordion component.\n */\nexport interface AccordionState {\n\t\n\t/**\n\t * Array containing all the accordion-items contained in the accordion.\n\t */\n\titemWidgets: AccordionItemWidget[];\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\titemStructure: SlotContent<AccordionItemContext>;\n}\n\n/**\n * Represents the state of an AccordionItem component.\n */\nexport interface AccordionProps {\n\t\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * collapseVerticalTransition\n\t * ```\n\t */\n\titemTransition: TransitionFn;\n\t\n\t/**\n\t * If `true`, only one accordion-item at the time can stay open.\n\t *\n\t * @defaultValue `false`\n\t */\n\tcloseOthers: boolean;\n\t\n\t/**\n\t * An event fired when an item is shown.\n\t *\n\t * Event payload is the id of the item.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonItemShown: (itemId: string) => void;\n\t\n\t/**\n\t * An event fired when an item is hidden.\n\t *\n\t * Event payload is the id of the item.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonItemHidden: (itemId: string) => void;\n\t\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t *\n\t * @defaultValue `true`\n\t */\n\titemDestroyOnHide: boolean;\n\t\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t *\n\t * @defaultValue `true`\n\t */\n\titemAnimated: boolean;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemHeaderClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item toggle button DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemButtonClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemBodyContainerClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemBodyClassName: string;\n\t\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t *\n\t * @defaultValue `''`\n\t */\n\titemHeadingTag: string;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\titemStructure: SlotContent<AccordionItemContext>;\n}\n\n\n\n/**\n * Represents an Accordion widget type.\n */\nexport type AccordionWidget = Widget<AccordionProps, AccordionState, AccordionApi, AccordionDirectives>;\n\n/**\n * Represents the state of an accordion item, extending the core item state and additional properties specific to the accordion item.\n */\nexport interface AccordionItemState {\n\t\n\t/**\n\t * If `true` the content of the accordion-item collapse should be in DOM. Its value depends on the\n\t * value of the `visible` and `destroyOnHide`.\n\t */\n\tshouldBeInDOM: boolean;\n\t\n\t/**\n\t * If `true`, the accordion-item will be visible (expanded). Otherwise, it will be hidden (collapsed).\n\t */\n\tvisible: boolean;\n\t\n\t/**\n\t * If `true`, the accordion-item will be disabled.\n\t * It will not react to user's clicks, but still will be possible to toggle programmatically.\n\t */\n\tdisabled: boolean;\n\t\n\t/**\n\t * The id of the accordion-item. It can be used for controlling the accordion-item via the accordion api.\n\t */\n\tid: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\theaderClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item collapse DOM element.\n\t */\n\tbuttonClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\tbodyContainerClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\tbodyClassName: string;\n\t\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\theadingTag: string;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tstructure: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion body.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tchildren: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion button inside the accordion header.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\theader: SlotContent<AccordionItemContext>;\n}\n\n/**\n * Represents the properties for an Accordion item component.\n */\nexport interface AccordionItemProps {\n\t\n\t/**\n\t * If `true`, accordion-item will be animated.\n\t */\n\tanimated: boolean;\n\t\n\t/**\n\t * The transition to use for the accordion-item body-container when the accordion-item is toggled.\n\t */\n\ttransition: TransitionFn;\n\t\n\t/**\n\t * If `true`, the accordion-item body container will be removed from the DOM when the accordion-item is collapsed. It will be just hidden otherwise.\n\t */\n\tdestroyOnHide: boolean;\n\t\n\t/**\n\t * An event fired when an item is shown.\n\t */\n\tonShown: () => void;\n\t\n\t/**\n\t * An event fired when an item is hidden.\n\t */\n\tonHidden: () => void;\n\t\n\t/**\n\t * An event fired when the `visible` value changes.\n\t *\n\t * Event payload is the new value of visible.\n\t */\n\tonVisibleChange: (visible: boolean) => void;\n\t\n\t/**\n\t * If `true`, the accordion-item will be visible (expanded). Otherwise, it will be hidden (collapsed).\n\t */\n\tvisible: boolean;\n\t\n\t/**\n\t * If `true`, the accordion-item will be disabled.\n\t * It will not react to user's clicks, but still will be possible to toggle programmatically.\n\t */\n\tdisabled: boolean;\n\t\n\t/**\n\t * The id of the accordion-item. It can be used for controlling the accordion-item via the accordion api.\n\t */\n\tid: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item header DOM element.\n\t */\n\theaderClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item collapse DOM element.\n\t */\n\tbuttonClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body container DOM element.\n\t * The accordion-item body container is the DOM element on what the itemTransition is applied.\n\t */\n\tbodyContainerClassName: string;\n\t\n\t/**\n\t * CSS classes to add on the accordion-item body DOM element.\n\t */\n\tbodyClassName: string;\n\t\n\t/**\n\t * The html tag to use for the accordion-item-header.\n\t */\n\theadingTag: string;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Structure of the accordion-item. The default item structure is: accordion-item\n\t * contains accordion header and accordion-item body container; the accordion header contains the accordion button\n\t * (that contains `header`), while the accordion-item body container contains the accordion body (that contains `children`).\n\t * The itemTransition is applied on this element.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tstructure: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion body.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\tchildren: SlotContent<AccordionItemContext>;\n\t\n\t/**\n\t * Content present in the accordion button inside the accordion header.\n\t *\n\t * It is a prop of the accordion-item.\n\t */\n\theader: SlotContent<AccordionItemContext>;\n}\n\n\n\n/**\n * Represents a widget for an accordion item.\n */\nexport type AccordionItemWidget = Widget<AccordionItemProps, AccordionItemState, AccordionItemApi, AccordionItemDirectives>;\n\n\n\n/**\n * Create an AccordionItemWidget with given config props\n * @param config - an optional AccordionItem config\n * @returns an AccordionItemWidget\n */\nconst export_createAccordionItem: WidgetFactory<AccordionItemWidget> = createAccordionItem as any;\nexport {export_createAccordionItem as createAccordionItem};\n\n\n\n/**\n * Create an AccordionWidget with given config props\n * @param config - an optional accordion config\n * @returns an AccordionWidget\n */\nconst export_createAccordion: WidgetFactory<AccordionWidget> = createAccordion as any;\nexport {export_createAccordion as createAccordion};\n\n\n\n/**\n * Create an accordion WidgetFactory based on a item factory and the list of item props that should inherit from the parent accordion\n *\n * @param itemFactory - the item factory\n * @param accordionItemProps - the list of item props\n * @param accordionConfig - the default accordion config\n * @param accordionValidator - the validator of props\n * @returns the accordion widget factory\n */\nconst export_factoryCreateAccordion: (itemFactory?: WidgetFactory<AccordionItemWidget>, accordionItemProps?: string[], accordionConfig?: AccordionProps, accordionValidator?: ConfigValidator<AccordionProps>) => WidgetFactory<AccordionWidget> = factoryCreateAccordion as any;\nexport {export_factoryCreateAccordion as factoryCreateAccordion};\n\n/**\n * Interface representing the API for an accordion component.\n */\nexport interface AccordionApi {\n\t\n\t/**\n\t * Given the itemId, will expand the corresponding accordion-item.\n\t *\n\t * If the itemId is not valid, nothing will happen.\n\t */\n\texpand(itemId: string): void;\n\t\n\t/**\n\t * Given the itemId, will collapse the corresponding accordion-item.\n\t *\n\t * If the itemId is not valid, nothing will happen.\n\t */\n\tcollapse(itemId: string): void;\n\t\n\t/**\n\t * Given the itemId, will toggle the corresponding accordion-item.\n\t *\n\t * If the itemId is not valid, nothing will happen.\n\t */\n\ttoggle(itemId: string): void;\n\t\n\t/**\n\t * It will expand all the items in the accordion.\n\t *\n\t * If `closeOthers` is `true` it will expand only the last accordion-item.\n\t */\n\texpandAll(): void;\n\t\n\t/**\n\t * It will collapse all the accordion-items in the accordion.\n\t */\n\tcollapseAll(): void;\n\t\n\t/**\n\t * Creates a new accordionItem.\n\t */\n\tregisterItem(itemConfig?: PropsConfig<AccordionItemProps>): AccordionItemWidget;\n}\n\n/**\n * Interface representing the directives used in the Accordion component.\n */\nexport interface AccordionDirectives {\n\t\n\t/**\n\t * Directive to put on the accordion DOM element\n\t */\n\taccordionDirective: Directive;\n}\n\n/**\n * Interface representing the API for an accordion item.\n */\nexport interface AccordionItemApi {\n\t\n\t/**\n\t * It will collapse the accordion-item.\n\t */\n\tcollapse(): void;\n\t\n\n\t/**\n\t * It will expand the accordion-item.\n\t */\n\texpand(): void;\n\t\n\t/**\n\t * It will toggle the accordion-item.\n\t */\n\ttoggle(): void;\n\t\n\t/**\n\t * Method to be called after the initialization to allow animations.\n\t */\n\tinitDone(): void;\n}\n\n/**\n * Interface representing the directives used in an accordion item.\n */\nexport interface AccordionItemDirectives {\n\t\n\t/**\n\t * Directive to use in special cases, if the accordion header does not use a button element to control the collapsing.\n\t */\n\ttoggleDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the button element that will control the collapsing of the accordion-item.\n\t */\n\tbuttonDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the accordion-item header that will contain the button element.\n\t */\n\theaderDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the accordion-item body.\n\t */\n\tbodyDirective: Directive;\n\t\n\t/**\n\t * Directive to apply the itemTransition\n\t */\n\ttransitionDirective: Directive;\n\t\n\t/**\n\t * Directive to apply aria attributes to the expanded body panel\n\t */\n\tbodyContainerAttrsDirective: Directive;\n\t\n\t/**\n\t * Directive to be put on the accordion-item body container. It will handle the animation.\n\t */\n\tbodyContainerDirective: Directive;\n\t\n\t/**\n\t * Directive to be put on the accordion-item. It will handle adding the accordion-item to the accordion.\n\t */\n\titemDirective: Directive;\n}\n\n"]}
@@ -1,20 +1,19 @@
1
- import { BaseWidgetDirective, ComponentTemplate, ContentAsSlotDirective, SlotDirective, UseDirective, auBooleanAttribute, } from '@agnos-ui/angular-headless';
1
+ import { BaseWidgetDirective, ComponentTemplate, SlotDirective, UseDirective, auBooleanAttribute } from '@agnos-ui/angular-headless';
2
2
  import { createAlert } from './alert.gen';
3
- import { writable } from '@amadeus-it-group/tansu';
4
3
  import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewChild, inject, } from '@angular/core';
5
4
  import { callWidgetFactory } from '../../config';
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 AlertDefaultSlotsComponent_ng_template_0_ng_template_1_Template(rf, ctx) { }
10
9
  function AlertDefaultSlotsComponent_ng_template_0_Conditional_2_Template(rf, ctx) { if (rf & 1) {
11
10
  const _r1 = i0.ɵɵgetCurrentView();
12
11
  i0.ɵɵelementStart(0, "button", 5);
13
- i0.ɵɵlistener("click", function AlertDefaultSlotsComponent_ng_template_0_Conditional_2_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r1); const widget_r2 = i0.ɵɵnextContext().widget; return i0.ɵɵresetView(widget_r2.api.close()); });
12
+ i0.ɵɵlistener("click", function AlertDefaultSlotsComponent_ng_template_0_Conditional_2_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r1); const api_r2 = i0.ɵɵnextContext().api; return i0.ɵɵresetView(api_r2.close()); });
14
13
  i0.ɵɵelementEnd();
15
14
  } if (rf & 2) {
16
15
  const state_r3 = i0.ɵɵnextContext().state;
17
- i0.ɵɵattribute("aria-label", state_r3.ariaCloseButtonLabel);
16
+ i0.ɵɵattribute("aria-label", state_r3.ariaCloseButtonLabel());
18
17
  } }
19
18
  function AlertDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
20
19
  i0.ɵɵelementStart(0, "div", 2);
@@ -23,66 +22,78 @@ function AlertDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1
23
22
  i0.ɵɵtemplate(2, AlertDefaultSlotsComponent_ng_template_0_Conditional_2_Template, 1, 1, "button", 4);
24
23
  } if (rf & 2) {
25
24
  const state_r3 = ctx.state;
26
- const widget_r2 = ctx.widget;
25
+ const api_r2 = ctx.api;
26
+ const directives_r4 = ctx.directives;
27
27
  i0.ɵɵadvance();
28
- i0.ɵɵproperty("auSlot", state_r3.children)("auSlotProps", i0.ɵɵpureFunction2(3, _c1, state_r3, widget_r2));
28
+ i0.ɵɵproperty("auSlot", state_r3.children())("auSlotProps", i0.ɵɵpureFunction3(3, _c1, state_r3, api_r2, directives_r4));
29
29
  i0.ɵɵadvance();
30
- i0.ɵɵconditional(state_r3.dismissible ? 2 : -1);
30
+ i0.ɵɵconditional(state_r3.dismissible() ? 2 : -1);
31
31
  } }
32
- const _c2 = ["auAlert", ""];
33
- const _c3 = ["*"];
32
+ const _c2 = ["content"];
33
+ const _c3 = ["auAlert", ""];
34
+ const _c4 = ["*"];
34
35
  function AlertComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
35
36
  i0.ɵɵprojection(0);
36
37
  } }
37
- function AlertComponent_Conditional_1_ng_template_1_Template(rf, ctx) { }
38
- function AlertComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
38
+ function AlertComponent_Conditional_2_ng_template_1_Template(rf, ctx) { }
39
+ function AlertComponent_Conditional_2_Template(rf, ctx) { if (rf & 1) {
39
40
  i0.ɵɵelementStart(0, "div", 2);
40
- i0.ɵɵtemplate(1, AlertComponent_Conditional_1_ng_template_1_Template, 0, 0, "ng-template", 3);
41
+ i0.ɵɵtemplate(1, AlertComponent_Conditional_2_ng_template_1_Template, 0, 0, "ng-template", 3);
41
42
  i0.ɵɵelementEnd();
42
43
  } if (rf & 2) {
43
44
  const ctx_r0 = i0.ɵɵnextContext();
44
- i0.ɵɵclassMapInterpolate3("au-alert alert alert-", ctx_r0.state().type, " ", ctx_r0.state().className, " ", ctx_r0.state().dismissible ? "alert-dismissible" : "", "");
45
- i0.ɵɵproperty("auUse", ctx_r0.widget.directives.transitionDirective);
45
+ i0.ɵɵclassMapInterpolate3("au-alert alert alert-", ctx_r0.state.type(), " ", ctx_r0.state.className(), " ", ctx_r0.state.dismissible() ? "alert-dismissible" : "", "");
46
+ i0.ɵɵproperty("auUse", ctx_r0.directives.transitionDirective);
46
47
  i0.ɵɵadvance();
47
- i0.ɵɵproperty("auSlot", ctx_r0.state().structure)("auSlotProps", i0.ɵɵpureFunction2(8, _c1, ctx_r0.state(), ctx_r0.widget));
48
+ i0.ɵɵproperty("auSlot", ctx_r0.state.structure())("auSlotProps", i0.ɵɵpureFunction3(8, _c1, ctx_r0.state, ctx_r0.api, ctx_r0.directives));
48
49
  } }
50
+ /**
51
+ * Directive to be used as a structural directive for the body of an alert component.
52
+ *
53
+ * This directive allows the use of a template reference for the alert body content, with type {@link AlertContext}.
54
+ */
49
55
  export class AlertBodyDirective {
50
56
  constructor() {
51
57
  this.templateRef = inject((TemplateRef));
52
58
  }
53
- static ngTemplateContextGuard(dir, context) {
59
+ static ngTemplateContextGuard(_dir, context) {
54
60
  return true;
55
61
  }
56
- static { this.ɵfac = function AlertBodyDirective_Factory(t) { return new (t || AlertBodyDirective)(); }; }
62
+ static { this.ɵfac = function AlertBodyDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || AlertBodyDirective)(); }; }
57
63
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: AlertBodyDirective, selectors: [["ng-template", "auAlertBody", ""]], standalone: true }); }
58
64
  }
59
65
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AlertBodyDirective, [{
60
66
  type: Directive,
61
67
  args: [{ selector: 'ng-template[auAlertBody]', standalone: true }]
62
68
  }], null, null); })();
69
+ /**
70
+ * Directive to define the structure of an alert component.
71
+ *
72
+ * This directive uses a `TemplateRef` to inject the template reference of the {@link AlertContext}.
73
+ */
63
74
  export class AlertStructureDirective {
64
75
  constructor() {
65
76
  this.templateRef = inject((TemplateRef));
66
77
  }
67
- static ngTemplateContextGuard(dir, context) {
78
+ static ngTemplateContextGuard(_dir, context) {
68
79
  return true;
69
80
  }
70
- static { this.ɵfac = function AlertStructureDirective_Factory(t) { return new (t || AlertStructureDirective)(); }; }
81
+ static { this.ɵfac = function AlertStructureDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || AlertStructureDirective)(); }; }
71
82
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: AlertStructureDirective, selectors: [["ng-template", "auAlertStructure", ""]], standalone: true }); }
72
83
  }
73
84
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AlertStructureDirective, [{
74
85
  type: Directive,
75
86
  args: [{ selector: 'ng-template[auAlertStructure]', standalone: true }]
76
87
  }], null, null); })();
77
- export class AlertDefaultSlotsComponent {
78
- static { this.ɵfac = function AlertDefaultSlotsComponent_Factory(t) { return new (t || AlertDefaultSlotsComponent)(); }; }
88
+ class AlertDefaultSlotsComponent {
89
+ static { this.ɵfac = function AlertDefaultSlotsComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || AlertDefaultSlotsComponent)(); }; }
79
90
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: AlertDefaultSlotsComponent, selectors: [["ng-component"]], viewQuery: function AlertDefaultSlotsComponent_Query(rf, ctx) { if (rf & 1) {
80
91
  i0.ɵɵviewQuery(_c0, 7);
81
92
  } if (rf & 2) {
82
93
  let _t;
83
94
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.structure = _t.first);
84
95
  } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [["structure", ""], ["auAlertStructure", ""], [1, "alert-body"], [3, "auSlot", "auSlotProps"], ["type", "button", 1, "btn-close"], ["type", "button", 1, "btn-close", 3, "click"]], template: function AlertDefaultSlotsComponent_Template(rf, ctx) { if (rf & 1) {
85
- i0.ɵɵtemplate(0, AlertDefaultSlotsComponent_ng_template_0_Template, 3, 6, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
96
+ i0.ɵɵtemplate(0, AlertDefaultSlotsComponent_ng_template_0_Template, 3, 7, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
86
97
  } }, dependencies: [SlotDirective, AlertStructureDirective], encapsulation: 2, changeDetection: 0 }); }
87
98
  }
88
99
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AlertDefaultSlotsComponent, [{
@@ -91,12 +102,12 @@ export class AlertDefaultSlotsComponent {
91
102
  standalone: true,
92
103
  changeDetection: ChangeDetectionStrategy.OnPush,
93
104
  imports: [SlotDirective, AlertStructureDirective],
94
- template: ` <ng-template auAlertStructure #structure let-state="state" let-widget="widget">
105
+ template: ` <ng-template auAlertStructure #structure let-state="state" let-api="api" let-directives="directives">
95
106
  <div class="alert-body">
96
- <ng-template [auSlot]="state.children" [auSlotProps]="{state, widget}"></ng-template>
107
+ <ng-template [auSlot]="state.children()" [auSlotProps]="{state, api, directives}"></ng-template>
97
108
  </div>
98
- @if (state.dismissible) {
99
- <button type="button" class="btn-close" (click)="widget.api.close()" [attr.aria-label]="state.ariaCloseButtonLabel"></button>
109
+ @if (state.dismissible()) {
110
+ <button type="button" class="btn-close" (click)="api.close()" [attr.aria-label]="state.ariaCloseButtonLabel()"></button>
100
111
  }
101
112
  </ng-template>`,
102
113
  }]
@@ -104,14 +115,38 @@ export class AlertDefaultSlotsComponent {
104
115
  type: ViewChild,
105
116
  args: ['structure', { static: true }]
106
117
  }] }); })();
107
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(AlertDefaultSlotsComponent, { className: "AlertDefaultSlotsComponent", filePath: "components/alert/alert.component.ts", lineNumber: 57 }); })();
118
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(AlertDefaultSlotsComponent, { className: "AlertDefaultSlotsComponent", filePath: "components/alert/alert.component.ts", lineNumber: 59 }); })();
119
+ /**
120
+ * Represents the default slot structure for the alert component.
121
+ */
108
122
  export const alertDefaultSlotStructure = new ComponentTemplate(AlertDefaultSlotsComponent, 'structure');
109
- const defaultConfig = {
110
- structure: alertDefaultSlotStructure,
111
- };
123
+ /**
124
+ * AlertComponent is a UI component that extends BaseWidgetDirective to provide
125
+ * an alert box with various customizable properties and behaviors.
126
+ *
127
+ * @remarks
128
+ * This component is designed to be used with Bootstrap styles and supports
129
+ * various Bootstrap contextual classes for different alert types.
130
+ */
112
131
  export class AlertComponent extends BaseWidgetDirective {
113
132
  constructor() {
114
- super(...arguments);
133
+ super(callWidgetFactory({
134
+ factory: createAlert,
135
+ widgetName: 'alert',
136
+ defaultConfig: {
137
+ structure: alertDefaultSlotStructure,
138
+ },
139
+ events: {
140
+ onVisibleChange: (event) => this.visibleChange.emit(event),
141
+ onShown: () => this.shown.emit(),
142
+ onHidden: () => this.hidden.emit(),
143
+ },
144
+ slotTemplates: () => ({
145
+ children: this.slotDefaultFromContent?.templateRef,
146
+ structure: this.slotStructureFromContent?.templateRef,
147
+ }),
148
+ slotChildren: () => this.slotChildren,
149
+ }));
115
150
  /**
116
151
  * Callback called when the alert visibility changed.
117
152
  *
@@ -139,25 +174,8 @@ export class AlertComponent extends BaseWidgetDirective {
139
174
  * ```
140
175
  */
141
176
  this.shown = new EventEmitter();
142
- this.defaultSlots = writable(defaultConfig);
143
- this._widget = callWidgetFactory({
144
- factory: createAlert,
145
- widgetName: 'alert',
146
- defaultConfig: this.defaultSlots,
147
- events: {
148
- onVisibleChange: (event) => this.visibleChange.emit(event),
149
- onShown: () => this.shown.emit(),
150
- onHidden: () => this.hidden.emit(),
151
- },
152
- });
153
177
  }
154
- ngAfterContentChecked() {
155
- this._widget.patchSlots({
156
- children: this.slotDefaultFromContent?.templateRef,
157
- structure: this.slotStructureFromContent?.templateRef,
158
- });
159
- }
160
- static { this.ɵfac = /*@__PURE__*/ (() => { let ɵAlertComponent_BaseFactory; return function AlertComponent_Factory(t) { return (ɵAlertComponent_BaseFactory || (ɵAlertComponent_BaseFactory = i0.ɵɵgetInheritedFactory(AlertComponent)))(t || AlertComponent); }; })(); }
178
+ static { this.ɵfac = function AlertComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || AlertComponent)(); }; }
161
179
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: AlertComponent, selectors: [["", "auAlert", ""]], contentQueries: function AlertComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
162
180
  i0.ɵɵcontentQuery(dirIndex, AlertBodyDirective, 5);
163
181
  i0.ɵɵcontentQuery(dirIndex, AlertStructureDirective, 5);
@@ -165,14 +183,18 @@ export class AlertComponent extends BaseWidgetDirective {
165
183
  let _t;
166
184
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first);
167
185
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStructureFromContent = _t.first);
168
- } }, 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) {
186
+ } }, viewQuery: function AlertComponent_Query(rf, ctx) { if (rf & 1) {
187
+ i0.ɵɵviewQuery(_c2, 7);
188
+ } if (rf & 2) {
189
+ let _t;
190
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotChildren = _t.first);
191
+ } }, 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: _c3, ngContentSelectors: _c4, decls: 3, vars: 1, consts: [["content", ""], ["role", "alert", 3, "auUse", "class"], ["role", "alert", 3, "auUse"], [3, "auSlot", "auSlotProps"]], template: function AlertComponent_Template(rf, ctx) { if (rf & 1) {
169
192
  i0.ɵɵprojectionDef();
170
- i0.ɵɵtemplate(0, AlertComponent_ng_template_0_Template, 1, 0, "ng-template", 0)(1, AlertComponent_Conditional_1_Template, 2, 11, "div", 1);
193
+ i0.ɵɵtemplate(0, AlertComponent_ng_template_0_Template, 1, 0, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor)(2, AlertComponent_Conditional_2_Template, 2, 12, "div", 1);
171
194
  } if (rf & 2) {
172
- i0.ɵɵproperty("auContentAsSlot", ctx.defaultSlots);
173
- i0.ɵɵadvance();
174
- i0.ɵɵconditional(!ctx.state().hidden ? 1 : -1);
175
- } }, dependencies: [SlotDirective, UseDirective, ContentAsSlotDirective], encapsulation: 2, changeDetection: 0 }); }
195
+ i0.ɵɵadvance(2);
196
+ i0.ɵɵconditional(!ctx.state.hidden() ? 2 : -1);
197
+ } }, dependencies: [SlotDirective, UseDirective], encapsulation: 2, changeDetection: 0 }); }
176
198
  }
177
199
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AlertComponent, [{
178
200
  type: Component,
@@ -180,22 +202,22 @@ export class AlertComponent extends BaseWidgetDirective {
180
202
  selector: '[auAlert]',
181
203
  standalone: true,
182
204
  changeDetection: ChangeDetectionStrategy.OnPush,
183
- imports: [SlotDirective, UseDirective, ContentAsSlotDirective],
184
- template: ` <ng-template [auContentAsSlot]="defaultSlots">
205
+ imports: [SlotDirective, UseDirective],
206
+ template: ` <ng-template #content>
185
207
  <ng-content></ng-content>
186
208
  </ng-template>
187
209
 
188
- @if (!state().hidden) {
210
+ @if (!state.hidden()) {
189
211
  <div
190
- [auUse]="widget.directives.transitionDirective"
191
- class="au-alert alert alert-{{ state().type }} {{ state().className }} {{ state().dismissible ? 'alert-dismissible' : '' }}"
212
+ [auUse]="directives.transitionDirective"
213
+ class="au-alert alert alert-{{ state.type() }} {{ state.className() }} {{ state.dismissible() ? 'alert-dismissible' : '' }}"
192
214
  role="alert"
193
215
  >
194
- <ng-template [auSlot]="state().structure" [auSlotProps]="{state: state(), widget}"></ng-template>
216
+ <ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}"></ng-template>
195
217
  </div>
196
218
  }`,
197
219
  }]
198
- }], null, { type: [{
220
+ }], () => [], { type: [{
199
221
  type: Input,
200
222
  args: ['auType']
201
223
  }], dismissible: [{
@@ -240,6 +262,9 @@ export class AlertComponent extends BaseWidgetDirective {
240
262
  }], className: [{
241
263
  type: Input,
242
264
  args: ['auClassName']
265
+ }], slotChildren: [{
266
+ type: ViewChild,
267
+ args: ['content', { static: true }]
243
268
  }] }); })();
244
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(AlertComponent, { className: "AlertComponent", filePath: "components/alert/alert.component.ts", lineNumber: 87 }); })();
245
- //# 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.gen';\nimport {createAlert} from './alert.gen';\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 * @defaultValue `'primary'`\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 * @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 * 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 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 * @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<PartialAlertProps> = 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: 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"]}
269
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(AlertComponent, { className: "AlertComponent", filePath: "components/alert/alert.component.ts", lineNumber: 95 }); })();
270
+ //# 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 {BaseWidgetDirective, ComponentTemplate, SlotDirective, UseDirective, auBooleanAttribute} from '@agnos-ui/angular-headless';\nimport type {AlertContext, AlertWidget} from './alert.gen';\nimport {createAlert} from './alert.gen';\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/**\n * Directive to be used as a structural directive for the body of an alert component.\n *\n * This directive allows the use of a template reference for the alert body content, with type {@link AlertContext}.\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/**\n * Directive to define the structure of an alert component.\n *\n * This directive uses a `TemplateRef` to inject the template reference of the {@link AlertContext}.\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\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, AlertStructureDirective],\n\ttemplate: ` <ng-template auAlertStructure #structure let-state=\"state\" let-api=\"api\" let-directives=\"directives\">\n\t\t<div class=\"alert-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()) {\n\t\t\t<button type=\"button\" class=\"btn-close\" (click)=\"api.close()\" [attr.aria-label]=\"state.ariaCloseButtonLabel()\"></button>\n\t\t}\n\t</ng-template>`,\n})\nclass AlertDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<AlertContext>;\n}\n\n/**\n * Represents the default slot structure for the alert component.\n */\nexport const alertDefaultSlotStructure: SlotContent<AlertContext> = new ComponentTemplate(AlertDefaultSlotsComponent, 'structure');\n\n/**\n * AlertComponent is a UI component that extends BaseWidgetDirective to provide\n * an alert box with various customizable properties and behaviors.\n *\n * @remarks\n * This component is designed to be used with Bootstrap styles and supports\n * various Bootstrap contextual classes for different alert types.\n */\n@Component({\n\tselector: '[auAlert]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, UseDirective],\n\ttemplate: ` <ng-template #content>\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]=\"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, api, directives}\"></ng-template>\n\t\t\t</div>\n\t\t}`,\n})\nexport class AlertComponent extends BaseWidgetDirective<AlertWidget> {\n\t/**\n\t * Type of the alert, following bootstrap types.\n\t *\n\t * @defaultValue `'primary'`\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 * @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 * 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 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 * @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: createAlert,\n\t\t\t\twidgetName: 'alert',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\tstructure: alertDefaultSlotStructure,\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}),\n\t\t\t\tslotChildren: () => this.slotChildren,\n\t\t\t}),\n\t\t);\n\t}\n}\n"]}
@@ -12,4 +12,4 @@ export { export_getAlertDefaultConfig as getAlertDefaultConfig };
12
12
  */
13
13
  const export_createAlert = createAlert;
14
14
  export { export_createAlert as createAlert };
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuZ2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYWxlcnQvYWxlcnQuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxxQkFBcUIsRUFBRSxXQUFXLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQU03Rjs7O0dBR0c7QUFDSCxNQUFNLDRCQUE0QixHQUFxQixxQkFBNEIsQ0FBQztBQUNwRixPQUFPLEVBQUMsNEJBQTRCLElBQUkscUJBQXFCLEVBQUMsQ0FBQztBQW1ML0Q7Ozs7R0FJRztBQUNILE1BQU0sa0JBQWtCLEdBQStCLFdBQWtCLENBQUM7QUFDMUUsT0FBTyxFQUFDLGtCQUFrQixJQUFJLFdBQVcsRUFBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtnZXRBbGVydERlZmF1bHRDb25maWcsIGNyZWF0ZUFsZXJ0fSBmcm9tICdAYWdub3MtdWkvY29yZS1ib290c3RyYXAvY29tcG9uZW50cy9hbGVydCc7XG5pbXBvcnQgdHlwZSB7V2lkZ2V0U2xvdENvbnRleHQsIFNsb3RDb250ZW50LCBUcmFuc2l0aW9uRm4sIFdpZGdldCwgV2lkZ2V0RmFjdG9yeSwgRGlyZWN0aXZlfSBmcm9tICdAYWdub3MtdWkvYW5ndWxhci1oZWFkbGVzcyc7XG5pbXBvcnQgdHlwZSB7QlNDb250ZXh0dWFsQ2xhc3N9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC90eXBlcyc7XG5cblxuXG4vKipcbiAqIFJldHJpZXZlIGEgc2hhbGxvdyBjb3B5IG9mIHRoZSBkZWZhdWx0IEFsZXJ0IGNvbmZpZ1xuICogQHJldHVybnMgdGhlIGRlZmF1bHQgQWxlcnQgY29uZmlnXG4gKi9cbmNvbnN0IGV4cG9ydF9nZXRBbGVydERlZmF1bHRDb25maWc6ICgpID0+IEFsZXJ0UHJvcHMgPSBnZXRBbGVydERlZmF1bHRDb25maWcgYXMgYW55O1xuZXhwb3J0IHtleHBvcnRfZ2V0QWxlcnREZWZhdWx0Q29uZmlnIGFzIGdldEFsZXJ0RGVmYXVsdENvbmZpZ307XG5cblxuXG5leHBvcnQgdHlwZSBBbGVydENvbnRleHQgPSBXaWRnZXRTbG90Q29udGV4dDxBbGVydFdpZGdldD47XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWxlcnRTdGF0ZSB7XG5cdFxuXHQvKipcblx0ICogSXMgYHRydWVgIHdoZW4gdGhlIGFsZXJ0IGlzIGhpZGRlbi4gQ29tcGFyZWQgdG8gYHZpc2libGVgLCB0aGlzIGlzIHVwZGF0ZWQgYWZ0ZXIgdGhlIHRyYW5zaXRpb24gaXMgZXhlY3V0ZWQuXG5cdCAqL1xuXHRoaWRkZW46IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogSWYgYHRydWVgLCBhbGVydCBjYW4gYmUgZGlzbWlzc2VkIGJ5IHRoZSB1c2VyLlxuXHQgKiBUaGUgY2xvc2UgYnV0dG9uICjDlykgd2lsbCBiZSBkaXNwbGF5ZWQgYW5kIHlvdSBjYW4gYmUgbm90aWZpZWQgb2YgdGhlIGV2ZW50IHdpdGggdGhlIChjbG9zZSkgb3V0cHV0LlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGB0cnVlYFxuXHQgKi9cblx0ZGlzbWlzc2libGU6IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogSWYgYHRydWVgIHRoZSBhbGVydCBpcyB2aXNpYmxlIHRvIHRoZSB1c2VyXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYHRydWVgXG5cdCAqL1xuXHR2aXNpYmxlOiBib29sZWFuO1xuXHRcblxuXHQvKipcblx0ICogQWNjZXNzaWJpbGl0eSBjbG9zZSBidXR0b24gbGFiZWxcblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJ0Nsb3NlJ2Bcblx0ICovXG5cdGFyaWFDbG9zZUJ1dHRvbkxhYmVsOiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogQ1NTIGNsYXNzZXMgdG8gYmUgYXBwbGllZCBvbiB0aGUgd2lkZ2V0IG1haW4gY29udGFpbmVyXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYCcnYFxuXHQgKi9cblx0Y2xhc3NOYW1lOiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogR2xvYmFsIHRlbXBsYXRlIGZvciB0aGUgYWxlcnQgY29tcG9uZW50XG5cdCAqL1xuXHRzdHJ1Y3R1cmU6IFNsb3RDb250ZW50PEFsZXJ0Q29udGV4dD47XG5cdFxuXHQvKipcblx0ICogVGVtcGxhdGUgZm9yIHRoZSBhbGVydCBjb250ZW50XG5cdCAqL1xuXHRjaGlsZHJlbjogU2xvdENvbnRlbnQ8QWxlcnRDb250ZXh0Pjtcblx0XG5cdC8qKlxuXHQgKiBUeXBlIG9mIHRoZSBhbGVydCwgZm9sbG93aW5nIGJvb3RzdHJhcCB0eXBlcy5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJ3ByaW1hcnknYFxuXHQgKi9cblx0dHlwZTogQlNDb250ZXh0dWFsQ2xhc3M7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWxlcnRQcm9wcyB7XG5cdFxuXHQvKipcblx0ICogVGhlIHRyYW5zaXRpb24gZnVuY3Rpb24gd2lsbCBiZSBleGVjdXRlZCB3aGVuIHRoZSBhbGVydCBpcyBkaXNwbGF5ZWQgb3IgaGlkZGVuLlxuXHQgKlxuXHQgKiBEZXBlbmRpbmcgb24gdGhlIHZhbHVlIG9mIGBhbmltYXRlZE9uSW5pdGAsIHRoZSBhbmltYXRpb24gY2FuIGJlIG9wdGlvbmFsbHkgc2tpcHBlZCBkdXJpbmcgdGhlIHNob3dpbmcgcHJvY2Vzcy5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgZmFkZVRyYW5zaXRpb25gXG5cdCAqL1xuXHR0cmFuc2l0aW9uOiBUcmFuc2l0aW9uRm47XG5cdFxuXHQvKipcblx0ICogQ2FsbGJhY2sgY2FsbGVkIHdoZW4gdGhlIGFsZXJ0IHZpc2liaWxpdHkgY2hhbmdlZC5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZVxuXHQgKiBgYGB0c1xuXHQgKiAoKSA9PiB7fVxuXHQgKiBgYGBcblx0ICovXG5cdG9uVmlzaWJsZUNoYW5nZTogKHZpc2libGU6IGJvb2xlYW4pID0+IHZvaWQ7XG5cdFxuXG5cdC8qKlxuXHQgKiBDYWxsYmFjayBjYWxsZWQgd2hlbiB0aGUgYWxlcnQgaXMgaGlkZGVuLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlXG5cdCAqIGBgYHRzXG5cdCAqICgpID0+IHt9XG5cdCAqIGBgYFxuXHQgKi9cblx0b25IaWRkZW46ICgpID0+IHZvaWQ7XG5cdFxuXG5cdC8qKlxuXHQgKiBDYWxsYmFjayBjYWxsZWQgd2hlbiB0aGUgYWxlcnQgaXMgc2hvd24uXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWVcblx0ICogYGBgdHNcblx0ICogKCkgPT4ge31cblx0ICogYGBgXG5cdCAqL1xuXHRvblNob3duOiAoKSA9PiB2b2lkO1xuXHRcblxuXHQvKipcblx0ICogSWYgYHRydWVgLCBhbGVydCBvcGVuaW5nIHdpbGwgYmUgYW5pbWF0ZWQuXG5cdCAqXG5cdCAqIEFuaW1hdGlvbiBpcyB0cmlnZ2VyZWQgIHdoZW4gdGhlIGAub3BlbigpYCBmdW5jdGlvbiBpcyBjYWxsZWRcblx0ICogb3IgdGhlIHZpc2libGUgcHJvcCBpcyBjaGFuZ2VkXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYGZhbHNlYFxuXHQgKi9cblx0YW5pbWF0ZWRPbkluaXQ6IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogSWYgYHRydWVgLCBhbGVydCBjbG9zaW5nIHdpbGwgYmUgYW5pbWF0ZWQuXG5cdCAqXG5cdCAqIEFuaW1hdGlvbiBpcyB0cmlnZ2VyZWQgIHdoZW4gY2xpY2tlZCBvbiB0aGUgY2xvc2UgYnV0dG9uICjDlyksXG5cdCAqIHZpYSB0aGUgYC5jbG9zZSgpYCBmdW5jdGlvbiBvciB0aGUgdmlzaWJsZSBwcm9wIGlzIGNoYW5nZWRcblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgdHJ1ZWBcblx0ICovXG5cdGFuaW1hdGVkOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCwgYWxlcnQgY2FuIGJlIGRpc21pc3NlZCBieSB0aGUgdXNlci5cblx0ICogVGhlIGNsb3NlIGJ1dHRvbiAow5cpIHdpbGwgYmUgZGlzcGxheWVkIGFuZCB5b3UgY2FuIGJlIG5vdGlmaWVkIG9mIHRoZSBldmVudCB3aXRoIHRoZSAoY2xvc2UpIG91dHB1dC5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgdHJ1ZWBcblx0ICovXG5cdGRpc21pc3NpYmxlOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCB0aGUgYWxlcnQgaXMgdmlzaWJsZSB0byB0aGUgdXNlclxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGB0cnVlYFxuXHQgKi9cblx0dmlzaWJsZTogYm9vbGVhbjtcblx0XG5cblx0LyoqXG5cdCAqIEFjY2Vzc2liaWxpdHkgY2xvc2UgYnV0dG9uIGxhYmVsXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYCdDbG9zZSdgXG5cdCAqL1xuXHRhcmlhQ2xvc2VCdXR0b25MYWJlbDogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIENTUyBjbGFzc2VzIHRvIGJlIGFwcGxpZWQgb24gdGhlIHdpZGdldCBtYWluIGNvbnRhaW5lclxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnJ2Bcblx0ICovXG5cdGNsYXNzTmFtZTogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIEdsb2JhbCB0ZW1wbGF0ZSBmb3IgdGhlIGFsZXJ0IGNvbXBvbmVudFxuXHQgKi9cblx0c3RydWN0dXJlOiBTbG90Q29udGVudDxBbGVydENvbnRleHQ+O1xuXHRcblx0LyoqXG5cdCAqIFRlbXBsYXRlIGZvciB0aGUgYWxlcnQgY29udGVudFxuXHQgKi9cblx0Y2hpbGRyZW46IFNsb3RDb250ZW50PEFsZXJ0Q29udGV4dD47XG5cdFxuXHQvKipcblx0ICogVHlwZSBvZiB0aGUgYWxlcnQsIGZvbGxvd2luZyBib290c3RyYXAgdHlwZXMuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYCdwcmltYXJ5J2Bcblx0ICovXG5cdHR5cGU6IEJTQ29udGV4dHVhbENsYXNzO1xufVxuXG5cblxuZXhwb3J0IHR5cGUgQWxlcnRXaWRnZXQgPSBXaWRnZXQ8QWxlcnRQcm9wcywgQWxlcnRTdGF0ZSwgQWxlcnRBcGksIG9iamVjdCwgQWxlcnREaXJlY3RpdmVzPjtcblxuXG5cbi8qKlxuICogQ3JlYXRlIGFuIEFsZXJ0V2lkZ2V0IHdpdGggZ2l2ZW4gY29uZmlnIHByb3BzXG4gKiBAcGFyYW0gY29uZmlnIC0gYW4gb3B0aW9uYWwgYWxlcnQgY29uZmlnXG4gKiBAcmV0dXJucyBhbiBBbGVydFdpZGdldFxuICovXG5jb25zdCBleHBvcnRfY3JlYXRlQWxlcnQ6IFdpZGdldEZhY3Rvcnk8QWxlcnRXaWRnZXQ+ID0gY3JlYXRlQWxlcnQgYXMgYW55O1xuZXhwb3J0IHtleHBvcnRfY3JlYXRlQWxlcnQgYXMgY3JlYXRlQWxlcnR9O1xuXG5leHBvcnQgaW50ZXJmYWNlIEFsZXJ0QXBpIHtcblx0XG5cdC8qKlxuXHQgKiBUcmlnZ2VycyBhbGVydCBjbG9zaW5nIHByb2dyYW1tYXRpY2FsbHkgKHNhbWUgYXMgY2xpY2tpbmcgb24gdGhlIGNsb3NlIGJ1dHRvbiAow5cpKS5cblx0ICovXG5cdGNsb3NlKCk6IHZvaWQ7XG5cdFxuXG5cdC8qKlxuXHQgKiBUcmlnZ2VycyB0aGUgYWxlcnQgdG8gYmUgZGlzcGxheWVkIGZvciB0aGUgdXNlci5cblx0ICovXG5cdG9wZW4oKTogdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBbGVydERpcmVjdGl2ZXMge1xuXHRcblx0LyoqXG5cdCAqIHRoZSB0cmFuc2l0aW9uIGRpcmVjdGl2ZSwgcGlsb3Rpbmcgd2hhdCBpcyB0aGUgdmlzdWFsIGVmZmVjdCBvZiBnb2luZyBmcm9tIGhpZGRlbiB0byB2aXNpYmxlXG5cdCAqL1xuXHR0cmFuc2l0aW9uRGlyZWN0aXZlOiBEaXJlY3RpdmU7XG59XG5cbiJdfQ==
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuZ2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYWxlcnQvYWxlcnQuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxxQkFBcUIsRUFBRSxXQUFXLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQU03Rjs7O0dBR0c7QUFDSCxNQUFNLDRCQUE0QixHQUFxQixxQkFBNEIsQ0FBQztBQUNwRixPQUFPLEVBQUMsNEJBQTRCLElBQUkscUJBQXFCLEVBQUMsQ0FBQztBQStML0Q7Ozs7R0FJRztBQUNILE1BQU0sa0JBQWtCLEdBQStCLFdBQWtCLENBQUM7QUFDMUUsT0FBTyxFQUFDLGtCQUFrQixJQUFJLFdBQVcsRUFBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtnZXRBbGVydERlZmF1bHRDb25maWcsIGNyZWF0ZUFsZXJ0fSBmcm9tICdAYWdub3MtdWkvY29yZS1ib290c3RyYXAvY29tcG9uZW50cy9hbGVydCc7XG5pbXBvcnQgdHlwZSB7V2lkZ2V0U2xvdENvbnRleHQsIFNsb3RDb250ZW50LCBUcmFuc2l0aW9uRm4sIFdpZGdldCwgV2lkZ2V0RmFjdG9yeSwgRGlyZWN0aXZlfSBmcm9tICdAYWdub3MtdWkvYW5ndWxhci1oZWFkbGVzcyc7XG5pbXBvcnQgdHlwZSB7QlNDb250ZXh0dWFsQ2xhc3N9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC90eXBlcyc7XG5cblxuXG4vKipcbiAqIFJldHJpZXZlIGEgc2hhbGxvdyBjb3B5IG9mIHRoZSBkZWZhdWx0IEFsZXJ0IGNvbmZpZ1xuICogQHJldHVybnMgdGhlIGRlZmF1bHQgQWxlcnQgY29uZmlnXG4gKi9cbmNvbnN0IGV4cG9ydF9nZXRBbGVydERlZmF1bHRDb25maWc6ICgpID0+IEFsZXJ0UHJvcHMgPSBnZXRBbGVydERlZmF1bHRDb25maWcgYXMgYW55O1xuZXhwb3J0IHtleHBvcnRfZ2V0QWxlcnREZWZhdWx0Q29uZmlnIGFzIGdldEFsZXJ0RGVmYXVsdENvbmZpZ307XG5cblxuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIGNvbnRleHQgZm9yIGFuIEFsZXJ0IGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBbGVydENvbnRleHQgZXh0ZW5kcyBXaWRnZXRTbG90Q29udGV4dDxBbGVydFdpZGdldD4ge31cblxuLyoqXG4gKiBSZXByZXNlbnRzIHRoZSBzdGF0ZSBvZiBhbiBhbGVydCBjb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQWxlcnRTdGF0ZSB7XG5cdFxuXHQvKipcblx0ICogSXMgYHRydWVgIHdoZW4gdGhlIGFsZXJ0IGlzIGhpZGRlbi4gQ29tcGFyZWQgdG8gYHZpc2libGVgLCB0aGlzIGlzIHVwZGF0ZWQgYWZ0ZXIgdGhlIHRyYW5zaXRpb24gaXMgZXhlY3V0ZWQuXG5cdCAqL1xuXHRoaWRkZW46IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogSWYgYHRydWVgLCBhbGVydCBjYW4gYmUgZGlzbWlzc2VkIGJ5IHRoZSB1c2VyLlxuXHQgKiBUaGUgY2xvc2UgYnV0dG9uICjDlykgd2lsbCBiZSBkaXNwbGF5ZWQgYW5kIHlvdSBjYW4gYmUgbm90aWZpZWQgb2YgdGhlIGV2ZW50IHdpdGggdGhlIChjbG9zZSkgb3V0cHV0LlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGB0cnVlYFxuXHQgKi9cblx0ZGlzbWlzc2libGU6IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogSWYgYHRydWVgIHRoZSBhbGVydCBpcyB2aXNpYmxlIHRvIHRoZSB1c2VyXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYHRydWVgXG5cdCAqL1xuXHR2aXNpYmxlOiBib29sZWFuO1xuXHRcblxuXHQvKipcblx0ICogQWNjZXNzaWJpbGl0eSBjbG9zZSBidXR0b24gbGFiZWxcblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJ0Nsb3NlJ2Bcblx0ICovXG5cdGFyaWFDbG9zZUJ1dHRvbkxhYmVsOiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogQ1NTIGNsYXNzZXMgdG8gYmUgYXBwbGllZCBvbiB0aGUgd2lkZ2V0IG1haW4gY29udGFpbmVyXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYCcnYFxuXHQgKi9cblx0Y2xhc3NOYW1lOiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogR2xvYmFsIHRlbXBsYXRlIGZvciB0aGUgYWxlcnQgY29tcG9uZW50XG5cdCAqL1xuXHRzdHJ1Y3R1cmU6IFNsb3RDb250ZW50PEFsZXJ0Q29udGV4dD47XG5cdFxuXHQvKipcblx0ICogVGVtcGxhdGUgZm9yIHRoZSBhbGVydCBjb250ZW50XG5cdCAqL1xuXHRjaGlsZHJlbjogU2xvdENvbnRlbnQ8QWxlcnRDb250ZXh0Pjtcblx0XG5cdC8qKlxuXHQgKiBUeXBlIG9mIHRoZSBhbGVydCwgZm9sbG93aW5nIGJvb3RzdHJhcCB0eXBlcy5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJ3ByaW1hcnknYFxuXHQgKi9cblx0dHlwZTogQlNDb250ZXh0dWFsQ2xhc3M7XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgcHJvcGVydGllcyBmb3IgdGhlIEFsZXJ0IGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBbGVydFByb3BzIHtcblx0XG5cdC8qKlxuXHQgKiBUaGUgdHJhbnNpdGlvbiBmdW5jdGlvbiB3aWxsIGJlIGV4ZWN1dGVkIHdoZW4gdGhlIGFsZXJ0IGlzIGRpc3BsYXllZCBvciBoaWRkZW4uXG5cdCAqXG5cdCAqIERlcGVuZGluZyBvbiB0aGUgdmFsdWUgb2YgYGFuaW1hdGVkT25Jbml0YCwgdGhlIGFuaW1hdGlvbiBjYW4gYmUgb3B0aW9uYWxseSBza2lwcGVkIGR1cmluZyB0aGUgc2hvd2luZyBwcm9jZXNzLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGBmYWRlVHJhbnNpdGlvbmBcblx0ICovXG5cdHRyYW5zaXRpb246IFRyYW5zaXRpb25Gbjtcblx0XG5cdC8qKlxuXHQgKiBDYWxsYmFjayBjYWxsZWQgd2hlbiB0aGUgYWxlcnQgdmlzaWJpbGl0eSBjaGFuZ2VkLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlXG5cdCAqIGBgYHRzXG5cdCAqICgpID0+IHt9XG5cdCAqIGBgYFxuXHQgKi9cblx0b25WaXNpYmxlQ2hhbmdlOiAodmlzaWJsZTogYm9vbGVhbikgPT4gdm9pZDtcblx0XG5cblx0LyoqXG5cdCAqIENhbGxiYWNrIGNhbGxlZCB3aGVuIHRoZSBhbGVydCBpcyBoaWRkZW4uXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWVcblx0ICogYGBgdHNcblx0ICogKCkgPT4ge31cblx0ICogYGBgXG5cdCAqL1xuXHRvbkhpZGRlbjogKCkgPT4gdm9pZDtcblx0XG5cblx0LyoqXG5cdCAqIENhbGxiYWNrIGNhbGxlZCB3aGVuIHRoZSBhbGVydCBpcyBzaG93bi5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZVxuXHQgKiBgYGB0c1xuXHQgKiAoKSA9PiB7fVxuXHQgKiBgYGBcblx0ICovXG5cdG9uU2hvd246ICgpID0+IHZvaWQ7XG5cdFxuXG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAsIGFsZXJ0IG9wZW5pbmcgd2lsbCBiZSBhbmltYXRlZC5cblx0ICpcblx0ICogQW5pbWF0aW9uIGlzIHRyaWdnZXJlZCAgd2hlbiB0aGUgYC5vcGVuKClgIGZ1bmN0aW9uIGlzIGNhbGxlZFxuXHQgKiBvciB0aGUgdmlzaWJsZSBwcm9wIGlzIGNoYW5nZWRcblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgZmFsc2VgXG5cdCAqL1xuXHRhbmltYXRlZE9uSW5pdDogYm9vbGVhbjtcblx0XG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAsIGFsZXJ0IGNsb3Npbmcgd2lsbCBiZSBhbmltYXRlZC5cblx0ICpcblx0ICogQW5pbWF0aW9uIGlzIHRyaWdnZXJlZCAgd2hlbiBjbGlja2VkIG9uIHRoZSBjbG9zZSBidXR0b24gKMOXKSxcblx0ICogdmlhIHRoZSBgLmNsb3NlKClgIGZ1bmN0aW9uIG9yIHRoZSB2aXNpYmxlIHByb3AgaXMgY2hhbmdlZFxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGB0cnVlYFxuXHQgKi9cblx0YW5pbWF0ZWQ6IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogSWYgYHRydWVgLCBhbGVydCBjYW4gYmUgZGlzbWlzc2VkIGJ5IHRoZSB1c2VyLlxuXHQgKiBUaGUgY2xvc2UgYnV0dG9uICjDlykgd2lsbCBiZSBkaXNwbGF5ZWQgYW5kIHlvdSBjYW4gYmUgbm90aWZpZWQgb2YgdGhlIGV2ZW50IHdpdGggdGhlIChjbG9zZSkgb3V0cHV0LlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGB0cnVlYFxuXHQgKi9cblx0ZGlzbWlzc2libGU6IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogSWYgYHRydWVgIHRoZSBhbGVydCBpcyB2aXNpYmxlIHRvIHRoZSB1c2VyXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYHRydWVgXG5cdCAqL1xuXHR2aXNpYmxlOiBib29sZWFuO1xuXHRcblxuXHQvKipcblx0ICogQWNjZXNzaWJpbGl0eSBjbG9zZSBidXR0b24gbGFiZWxcblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJ0Nsb3NlJ2Bcblx0ICovXG5cdGFyaWFDbG9zZUJ1dHRvbkxhYmVsOiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogQ1NTIGNsYXNzZXMgdG8gYmUgYXBwbGllZCBvbiB0aGUgd2lkZ2V0IG1haW4gY29udGFpbmVyXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYCcnYFxuXHQgKi9cblx0Y2xhc3NOYW1lOiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogR2xvYmFsIHRlbXBsYXRlIGZvciB0aGUgYWxlcnQgY29tcG9uZW50XG5cdCAqL1xuXHRzdHJ1Y3R1cmU6IFNsb3RDb250ZW50PEFsZXJ0Q29udGV4dD47XG5cdFxuXHQvKipcblx0ICogVGVtcGxhdGUgZm9yIHRoZSBhbGVydCBjb250ZW50XG5cdCAqL1xuXHRjaGlsZHJlbjogU2xvdENvbnRlbnQ8QWxlcnRDb250ZXh0Pjtcblx0XG5cdC8qKlxuXHQgKiBUeXBlIG9mIHRoZSBhbGVydCwgZm9sbG93aW5nIGJvb3RzdHJhcCB0eXBlcy5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJ3ByaW1hcnknYFxuXHQgKi9cblx0dHlwZTogQlNDb250ZXh0dWFsQ2xhc3M7XG59XG5cblxuXG4vKipcbiAqIFJlcHJlc2VudHMgYW4gYWxlcnQgd2lkZ2V0IGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IHR5cGUgQWxlcnRXaWRnZXQgPSBXaWRnZXQ8QWxlcnRQcm9wcywgQWxlcnRTdGF0ZSwgQWxlcnRBcGksIEFsZXJ0RGlyZWN0aXZlcz47XG5cblxuXG4vKipcbiAqIENyZWF0ZSBhbiBBbGVydFdpZGdldCB3aXRoIGdpdmVuIGNvbmZpZyBwcm9wc1xuICogQHBhcmFtIGNvbmZpZyAtIGFuIG9wdGlvbmFsIGFsZXJ0IGNvbmZpZ1xuICogQHJldHVybnMgYW4gQWxlcnRXaWRnZXRcbiAqL1xuY29uc3QgZXhwb3J0X2NyZWF0ZUFsZXJ0OiBXaWRnZXRGYWN0b3J5PEFsZXJ0V2lkZ2V0PiA9IGNyZWF0ZUFsZXJ0IGFzIGFueTtcbmV4cG9ydCB7ZXhwb3J0X2NyZWF0ZUFsZXJ0IGFzIGNyZWF0ZUFsZXJ0fTtcblxuLyoqXG4gKiBSZXByZXNlbnRzIHRoZSBBUEkgZm9yIGFuIGFsZXJ0IGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBbGVydEFwaSB7XG5cdFxuXHQvKipcblx0ICogVHJpZ2dlcnMgYWxlcnQgY2xvc2luZyBwcm9ncmFtbWF0aWNhbGx5IChzYW1lIGFzIGNsaWNraW5nIG9uIHRoZSBjbG9zZSBidXR0b24gKMOXKSkuXG5cdCAqL1xuXHRjbG9zZSgpOiB2b2lkO1xuXHRcblxuXHQvKipcblx0ICogVHJpZ2dlcnMgdGhlIGFsZXJ0IHRvIGJlIGRpc3BsYXllZCBmb3IgdGhlIHVzZXIuXG5cdCAqL1xuXHRvcGVuKCk6IHZvaWQ7XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgZGlyZWN0aXZlcyBmb3IgYW4gYWxlcnQgY29tcG9uZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEFsZXJ0RGlyZWN0aXZlcyB7XG5cdFxuXHQvKipcblx0ICogdGhlIHRyYW5zaXRpb24gZGlyZWN0aXZlLCBwaWxvdGluZyB3aGF0IGlzIHRoZSB2aXN1YWwgZWZmZWN0IG9mIGdvaW5nIGZyb20gaGlkZGVuIHRvIHZpc2libGVcblx0ICovXG5cdHRyYW5zaXRpb25EaXJlY3RpdmU6IERpcmVjdGl2ZTtcbn1cblxuIl19
@@ -0,0 +1,89 @@
1
+ import { auBooleanAttribute, BaseWidgetDirective, useDirectiveForHost } from '@agnos-ui/angular-headless';
2
+ import { createCollapse } from '@agnos-ui/core-bootstrap/components/collapse';
3
+ import { Directive, EventEmitter, Input, Output } from '@angular/core';
4
+ import { callWidgetFactory } from '../../config';
5
+ import * as i0 from "@angular/core";
6
+ /**
7
+ * Directive to control the collapse behavior of an element.
8
+ */
9
+ export class CollapseDirective extends BaseWidgetDirective {
10
+ constructor() {
11
+ super(callWidgetFactory({
12
+ factory: createCollapse,
13
+ widgetName: 'collapse',
14
+ events: {
15
+ onVisibleChange: (event) => this.visibleChange.emit(event),
16
+ onShown: () => this.shown.emit(),
17
+ onHidden: () => this.hidden.emit(),
18
+ },
19
+ afterInit: (widget) => {
20
+ useDirectiveForHost(widget.directives.collapseDirective);
21
+ },
22
+ }));
23
+ /**
24
+ * Callback called when the collapse visibility changed.
25
+ *
26
+ * @defaultValue
27
+ * ```ts
28
+ * () => {}
29
+ * ```
30
+ */
31
+ this.visibleChange = new EventEmitter();
32
+ /**
33
+ * Callback called when the collapse is hidden.
34
+ *
35
+ * @defaultValue
36
+ * ```ts
37
+ * () => {}
38
+ * ```
39
+ */
40
+ this.hidden = new EventEmitter();
41
+ /**
42
+ * Callback called when the collapse is shown.
43
+ *
44
+ * @defaultValue
45
+ * ```ts
46
+ * () => {}
47
+ * ```
48
+ */
49
+ this.shown = new EventEmitter();
50
+ }
51
+ static { this.ɵfac = function CollapseDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || CollapseDirective)(); }; }
52
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: CollapseDirective, selectors: [["", "auCollapse", ""]], inputs: { animatedOnInit: [2, "auAnimatedOnInit", "animatedOnInit", auBooleanAttribute], animated: [2, "auAnimated", "animated", auBooleanAttribute], className: [0, "auClassName", "className"], horizontal: [2, "auHorizontal", "horizontal", auBooleanAttribute], visible: [2, "auVisible", "visible", auBooleanAttribute], id: [0, "auId", "id"] }, outputs: { visibleChange: "auVisibleChange", hidden: "auHidden", shown: "auShown" }, exportAs: ["auCollapse"], standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature] }); }
53
+ }
54
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CollapseDirective, [{
55
+ type: Directive,
56
+ args: [{
57
+ selector: '[auCollapse]',
58
+ standalone: true,
59
+ exportAs: 'auCollapse',
60
+ }]
61
+ }], () => [], { animatedOnInit: [{
62
+ type: Input,
63
+ args: [{ alias: 'auAnimatedOnInit', transform: auBooleanAttribute }]
64
+ }], animated: [{
65
+ type: Input,
66
+ args: [{ alias: 'auAnimated', transform: auBooleanAttribute }]
67
+ }], className: [{
68
+ type: Input,
69
+ args: ['auClassName']
70
+ }], horizontal: [{
71
+ type: Input,
72
+ args: [{ alias: 'auHorizontal', transform: auBooleanAttribute }]
73
+ }], visible: [{
74
+ type: Input,
75
+ args: [{ alias: 'auVisible', transform: auBooleanAttribute }]
76
+ }], id: [{
77
+ type: Input,
78
+ args: ['auId']
79
+ }], visibleChange: [{
80
+ type: Output,
81
+ args: ['auVisibleChange']
82
+ }], hidden: [{
83
+ type: Output,
84
+ args: ['auHidden']
85
+ }], shown: [{
86
+ type: Output,
87
+ args: ['auShown']
88
+ }] }); })();
89
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGFwc2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvY29sbGFwc2UvY29sbGFwc2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxtQkFBbUIsRUFBQyxNQUFNLDRCQUE0QixDQUFDO0FBRXhHLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUM1RSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3JFLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLGNBQWMsQ0FBQzs7QUFFL0M7O0dBRUc7QUFNSCxNQUFNLE9BQU8saUJBQWtCLFNBQVEsbUJBQW1DO0lBeUV6RTtRQUNDLEtBQUssQ0FDSixpQkFBaUIsQ0FBQztZQUNqQixPQUFPLEVBQUUsY0FBYztZQUN2QixVQUFVLEVBQUUsVUFBVTtZQUN0QixNQUFNLEVBQUU7Z0JBQ1AsZUFBZSxFQUFFLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7Z0JBQzFELE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRTtnQkFDaEMsUUFBUSxFQUFFLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFO2FBQ2xDO1lBQ0QsU0FBUyxFQUFFLENBQUMsTUFBTSxFQUFFLEVBQUU7Z0JBQ3JCLG1CQUFtQixDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsQ0FBQztZQUMxRCxDQUFDO1NBQ0QsQ0FBQyxDQUNGLENBQUM7UUE1Q0g7Ozs7Ozs7V0FPRztRQUN3QixrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFFdkU7Ozs7Ozs7V0FPRztRQUNpQixXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUV0RDs7Ozs7OztXQU9HO1FBQ2dCLFVBQUssR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO0lBaUJwRCxDQUFDO2tIQXhGVyxpQkFBaUI7b0VBQWpCLGlCQUFpQiwyR0FNaUIsa0JBQWtCLDJDQU94QixrQkFBa0IsNkZBY2hCLGtCQUFrQix3Q0FPckIsa0JBQWtCOztpRkFsQzdDLGlCQUFpQjtjQUw3QixTQUFTO2VBQUM7Z0JBQ1YsUUFBUSxFQUFFLGNBQWM7Z0JBQ3hCLFVBQVUsRUFBRSxJQUFJO2dCQUNoQixRQUFRLEVBQUUsWUFBWTthQUN0QjtvQkFPbUUsY0FBYztrQkFBaEYsS0FBSzttQkFBQyxFQUFDLEtBQUssRUFBRSxrQkFBa0IsRUFBRSxTQUFTLEVBQUUsa0JBQWtCLEVBQUM7WUFPSixRQUFRO2tCQUFwRSxLQUFLO21CQUFDLEVBQUMsS0FBSyxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsa0JBQWtCLEVBQUM7WUFPckMsU0FBUztrQkFBOUIsS0FBSzttQkFBQyxhQUFhO1lBTzJDLFVBQVU7a0JBQXhFLEtBQUs7bUJBQUMsRUFBQyxLQUFLLEVBQUUsY0FBYyxFQUFFLFNBQVMsRUFBRSxrQkFBa0IsRUFBQztZQU9ELE9BQU87a0JBQWxFLEtBQUs7bUJBQUMsRUFBQyxLQUFLLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxrQkFBa0IsRUFBQztZQU8zQyxFQUFFO2tCQUFoQixLQUFLO21CQUFDLE1BQU07WUFVYyxhQUFhO2tCQUF2QyxNQUFNO21CQUFDLGlCQUFpQjtZQVVMLE1BQU07a0JBQXpCLE1BQU07bUJBQUMsVUFBVTtZQVVDLEtBQUs7a0JBQXZCLE1BQU07bUJBQUMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7YXVCb29sZWFuQXR0cmlidXRlLCBCYXNlV2lkZ2V0RGlyZWN0aXZlLCB1c2VEaXJlY3RpdmVGb3JIb3N0fSBmcm9tICdAYWdub3MtdWkvYW5ndWxhci1oZWFkbGVzcyc7XG5pbXBvcnQgdHlwZSB7Q29sbGFwc2VXaWRnZXR9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL2NvbGxhcHNlJztcbmltcG9ydCB7Y3JlYXRlQ29sbGFwc2V9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL2NvbGxhcHNlJztcbmltcG9ydCB7RGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtjYWxsV2lkZ2V0RmFjdG9yeX0gZnJvbSAnLi4vLi4vY29uZmlnJztcblxuLyoqXG4gKiBEaXJlY3RpdmUgdG8gY29udHJvbCB0aGUgY29sbGFwc2UgYmVoYXZpb3Igb2YgYW4gZWxlbWVudC5cbiAqL1xuQERpcmVjdGl2ZSh7XG5cdHNlbGVjdG9yOiAnW2F1Q29sbGFwc2VdJyxcblx0c3RhbmRhbG9uZTogdHJ1ZSxcblx0ZXhwb3J0QXM6ICdhdUNvbGxhcHNlJyxcbn0pXG5leHBvcnQgY2xhc3MgQ29sbGFwc2VEaXJlY3RpdmUgZXh0ZW5kcyBCYXNlV2lkZ2V0RGlyZWN0aXZlPENvbGxhcHNlV2lkZ2V0PiB7XG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAsIGNvbGxhcHNlIG9wZW5pbmcgd2lsbCBiZSBhbmltYXRlZCBhdCBpbml0IHRpbWUuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYGZhbHNlYFxuXHQgKi9cblx0QElucHV0KHthbGlhczogJ2F1QW5pbWF0ZWRPbkluaXQnLCB0cmFuc2Zvcm06IGF1Qm9vbGVhbkF0dHJpYnV0ZX0pIGFuaW1hdGVkT25Jbml0OiBib29sZWFuIHwgdW5kZWZpbmVkO1xuXG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAsIGNvbGxhcHNlIGNsb3NpbmcgYW5kIG9wZW5pbmcgd2lsbCBiZSBhbmltYXRlZC5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgdHJ1ZWBcblx0ICovXG5cdEBJbnB1dCh7YWxpYXM6ICdhdUFuaW1hdGVkJywgdHJhbnNmb3JtOiBhdUJvb2xlYW5BdHRyaWJ1dGV9KSBhbmltYXRlZDogYm9vbGVhbiB8IHVuZGVmaW5lZDtcblxuXHQvKipcblx0ICogQ1NTIGNsYXNzZXMgdG8gYmUgYXBwbGllZCBvbiB0aGUgd2lkZ2V0IG1haW4gY29udGFpbmVyXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYCcnYFxuXHQgKi9cblx0QElucHV0KCdhdUNsYXNzTmFtZScpIGNsYXNzTmFtZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAsIGNvbGxhcHNlIHdpbGwgYmUgZG9uZSBob3Jpem9udGFsbHkuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYGZhbHNlYFxuXHQgKi9cblx0QElucHV0KHthbGlhczogJ2F1SG9yaXpvbnRhbCcsIHRyYW5zZm9ybTogYXVCb29sZWFuQXR0cmlidXRlfSkgaG9yaXpvbnRhbDogYm9vbGVhbiB8IHVuZGVmaW5lZDtcblxuXHQvKipcblx0ICogSWYgYHRydWVgIHRoZSBjb2xsYXBzZSBpcyB2aXNpYmxlIHRvIHRoZSB1c2VyXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYHRydWVgXG5cdCAqL1xuXHRASW5wdXQoe2FsaWFzOiAnYXVWaXNpYmxlJywgdHJhbnNmb3JtOiBhdUJvb2xlYW5BdHRyaWJ1dGV9KSB2aXNpYmxlOiBib29sZWFuIHwgdW5kZWZpbmVkO1xuXG5cdC8qKlxuXHQgKiBpZCBvZiB0aGUgY29sbGFwc2Vcblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJydgXG5cdCAqL1xuXHRASW5wdXQoJ2F1SWQnKSBpZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXG5cdC8qKlxuXHQgKiBDYWxsYmFjayBjYWxsZWQgd2hlbiB0aGUgY29sbGFwc2UgdmlzaWJpbGl0eSBjaGFuZ2VkLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlXG5cdCAqIGBgYHRzXG5cdCAqICgpID0+IHt9XG5cdCAqIGBgYFxuXHQgKi9cblx0QE91dHB1dCgnYXVWaXNpYmxlQ2hhbmdlJykgdmlzaWJsZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcblxuXHQvKipcblx0ICogQ2FsbGJhY2sgY2FsbGVkIHdoZW4gdGhlIGNvbGxhcHNlIGlzIGhpZGRlbi5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZVxuXHQgKiBgYGB0c1xuXHQgKiAoKSA9PiB7fVxuXHQgKiBgYGBcblx0ICovXG5cdEBPdXRwdXQoJ2F1SGlkZGVuJykgaGlkZGVuID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG5cdC8qKlxuXHQgKiBDYWxsYmFjayBjYWxsZWQgd2hlbiB0aGUgY29sbGFwc2UgaXMgc2hvd24uXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWVcblx0ICogYGBgdHNcblx0ICogKCkgPT4ge31cblx0ICogYGBgXG5cdCAqL1xuXHRAT3V0cHV0KCdhdVNob3duJykgc2hvd24gPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG5cblx0Y29uc3RydWN0b3IoKSB7XG5cdFx0c3VwZXIoXG5cdFx0XHRjYWxsV2lkZ2V0RmFjdG9yeSh7XG5cdFx0XHRcdGZhY3Rvcnk6IGNyZWF0ZUNvbGxhcHNlLFxuXHRcdFx0XHR3aWRnZXROYW1lOiAnY29sbGFwc2UnLFxuXHRcdFx0XHRldmVudHM6IHtcblx0XHRcdFx0XHRvblZpc2libGVDaGFuZ2U6IChldmVudCkgPT4gdGhpcy52aXNpYmxlQ2hhbmdlLmVtaXQoZXZlbnQpLFxuXHRcdFx0XHRcdG9uU2hvd246ICgpID0+IHRoaXMuc2hvd24uZW1pdCgpLFxuXHRcdFx0XHRcdG9uSGlkZGVuOiAoKSA9PiB0aGlzLmhpZGRlbi5lbWl0KCksXG5cdFx0XHRcdH0sXG5cdFx0XHRcdGFmdGVySW5pdDogKHdpZGdldCkgPT4ge1xuXHRcdFx0XHRcdHVzZURpcmVjdGl2ZUZvckhvc3Qod2lkZ2V0LmRpcmVjdGl2ZXMuY29sbGFwc2VEaXJlY3RpdmUpO1xuXHRcdFx0XHR9LFxuXHRcdFx0fSksXG5cdFx0KTtcblx0fVxufVxuIl19
@@ -0,0 +1,15 @@
1
+ import { getCollapseDefaultConfig, createCollapse } from '@agnos-ui/core-bootstrap/components/collapse';
2
+ /**
3
+ * Retrieve a shallow copy of the default collapse config
4
+ * @returns the default collapse config
5
+ */
6
+ const export_getCollapseDefaultConfig = getCollapseDefaultConfig;
7
+ export { export_getCollapseDefaultConfig as getCollapseDefaultConfig };
8
+ /**
9
+ * Create an CollapseWidget with given config props
10
+ * @param config - an optional collapse config
11
+ * @returns an CollapseWidget
12
+ */
13
+ const export_createCollapse = createCollapse;
14
+ export { export_createCollapse as createCollapse };
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGFwc2UuZ2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvY29sbGFwc2UvY29sbGFwc2UuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx3QkFBd0IsRUFBRSxjQUFjLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUt0Rzs7O0dBR0c7QUFDSCxNQUFNLCtCQUErQixHQUF3Qix3QkFBK0IsQ0FBQztBQUM3RixPQUFPLEVBQUMsK0JBQStCLElBQUksd0JBQXdCLEVBQUMsQ0FBQztBQUlyRTs7OztHQUlHO0FBQ0gsTUFBTSxxQkFBcUIsR0FBNEQsY0FBcUIsQ0FBQztBQUM3RyxPQUFPLEVBQUMscUJBQXFCLElBQUksY0FBYyxFQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge2dldENvbGxhcHNlRGVmYXVsdENvbmZpZywgY3JlYXRlQ29sbGFwc2V9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL2NvbGxhcHNlJztcbmltcG9ydCB0eXBlIHtQcm9wc0NvbmZpZywgRGlyZWN0aXZlLCBXaWRnZXR9IGZyb20gJ0BhZ25vcy11aS9hbmd1bGFyLWhlYWRsZXNzJztcblxuXG5cbi8qKlxuICogUmV0cmlldmUgYSBzaGFsbG93IGNvcHkgb2YgdGhlIGRlZmF1bHQgY29sbGFwc2UgY29uZmlnXG4gKiBAcmV0dXJucyB0aGUgZGVmYXVsdCBjb2xsYXBzZSBjb25maWdcbiAqL1xuY29uc3QgZXhwb3J0X2dldENvbGxhcHNlRGVmYXVsdENvbmZpZzogKCkgPT4gQ29sbGFwc2VQcm9wcyA9IGdldENvbGxhcHNlRGVmYXVsdENvbmZpZyBhcyBhbnk7XG5leHBvcnQge2V4cG9ydF9nZXRDb2xsYXBzZURlZmF1bHRDb25maWcgYXMgZ2V0Q29sbGFwc2VEZWZhdWx0Q29uZmlnfTtcblxuXG5cbi8qKlxuICogQ3JlYXRlIGFuIENvbGxhcHNlV2lkZ2V0IHdpdGggZ2l2ZW4gY29uZmlnIHByb3BzXG4gKiBAcGFyYW0gY29uZmlnIC0gYW4gb3B0aW9uYWwgY29sbGFwc2UgY29uZmlnXG4gKiBAcmV0dXJucyBhbiBDb2xsYXBzZVdpZGdldFxuICovXG5jb25zdCBleHBvcnRfY3JlYXRlQ29sbGFwc2U6IChjb25maWc/OiBQcm9wc0NvbmZpZzxDb2xsYXBzZVByb3BzPikgPT4gQ29sbGFwc2VXaWRnZXQgPSBjcmVhdGVDb2xsYXBzZSBhcyBhbnk7XG5leHBvcnQge2V4cG9ydF9jcmVhdGVDb2xsYXBzZSBhcyBjcmVhdGVDb2xsYXBzZX07XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgc3RhdGUgb2YgYSBjb2xsYXBzZSBjb21wb25lbnQuXG4gKiBFeHRlbmRzIHRoZSBwcm9wZXJ0aWVzIGFuZCBzdGF0ZSBmcm9tIGBDb2xsYXBzZUNvbW1vblByb3BzQW5kU3RhdGVgLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbGxhcHNlU3RhdGUge1xuXHRcblx0LyoqXG5cdCAqIElzIGB0cnVlYCB3aGVuIHRoZSBjb2xsYXBzZSBpcyBoaWRkZW4uIENvbXBhcmVkIHRvIGB2aXNpYmxlYCwgdGhpcyBpcyB1cGRhdGVkIGFmdGVyIHRoZSB0cmFuc2l0aW9uIGlzIGV4ZWN1dGVkLlxuXHQgKi9cblx0aGlkZGVuOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIENTUyBjbGFzc2VzIHRvIGJlIGFwcGxpZWQgb24gdGhlIHdpZGdldCBtYWluIGNvbnRhaW5lclxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnJ2Bcblx0ICovXG5cdGNsYXNzTmFtZTogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCwgY29sbGFwc2Ugd2lsbCBiZSBkb25lIGhvcml6b250YWxseS5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgZmFsc2VgXG5cdCAqL1xuXHRob3Jpem9udGFsOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCB0aGUgY29sbGFwc2UgaXMgdmlzaWJsZSB0byB0aGUgdXNlclxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGB0cnVlYFxuXHQgKi9cblx0dmlzaWJsZTogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciB0aGUgQ29sbGFwc2UgY29tcG9uZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbGxhcHNlUHJvcHMge1xuXHRcblx0LyoqXG5cdCAqIENhbGxiYWNrIGNhbGxlZCB3aGVuIHRoZSBjb2xsYXBzZSB2aXNpYmlsaXR5IGNoYW5nZWQuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWVcblx0ICogYGBgdHNcblx0ICogKCkgPT4ge31cblx0ICogYGBgXG5cdCAqIEBwYXJhbSB2aXNpYmxlIC0gVGhlIG5ldyB2aXNpYmlsaXR5IHN0YXRlIG9mIHRoZSBjb2xsYXBzZS5cblx0ICovXG5cdG9uVmlzaWJsZUNoYW5nZTogKHZpc2libGU6IGJvb2xlYW4pID0+IHZvaWQ7XG5cdFxuXG5cdC8qKlxuXHQgKiBDYWxsYmFjayBjYWxsZWQgd2hlbiB0aGUgY29sbGFwc2UgaXMgaGlkZGVuLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlXG5cdCAqIGBgYHRzXG5cdCAqICgpID0+IHt9XG5cdCAqIGBgYFxuXHQgKi9cblx0b25IaWRkZW46ICgpID0+IHZvaWQ7XG5cdFxuXG5cdC8qKlxuXHQgKiBDYWxsYmFjayBjYWxsZWQgd2hlbiB0aGUgY29sbGFwc2UgaXMgc2hvd24uXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWVcblx0ICogYGBgdHNcblx0ICogKCkgPT4ge31cblx0ICogYGBgXG5cdCAqL1xuXHRvblNob3duOiAoKSA9PiB2b2lkO1xuXHRcblxuXHQvKipcblx0ICogSWYgYHRydWVgLCBjb2xsYXBzZSBvcGVuaW5nIHdpbGwgYmUgYW5pbWF0ZWQgYXQgaW5pdCB0aW1lLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGBmYWxzZWBcblx0ICovXG5cdGFuaW1hdGVkT25Jbml0OiBib29sZWFuO1xuXHRcblxuXHQvKipcblx0ICogSWYgYHRydWVgLCBjb2xsYXBzZSBjbG9zaW5nIGFuZCBvcGVuaW5nIHdpbGwgYmUgYW5pbWF0ZWQuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYHRydWVgXG5cdCAqL1xuXHRhbmltYXRlZDogYm9vbGVhbjtcblx0XG5cdC8qKlxuXHQgKiBpZCBvZiB0aGUgY29sbGFwc2Vcblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJydgXG5cdCAqL1xuXHRpZDogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIENTUyBjbGFzc2VzIHRvIGJlIGFwcGxpZWQgb24gdGhlIHdpZGdldCBtYWluIGNvbnRhaW5lclxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnJ2Bcblx0ICovXG5cdGNsYXNzTmFtZTogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCwgY29sbGFwc2Ugd2lsbCBiZSBkb25lIGhvcml6b250YWxseS5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgZmFsc2VgXG5cdCAqL1xuXHRob3Jpem9udGFsOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCB0aGUgY29sbGFwc2UgaXMgdmlzaWJsZSB0byB0aGUgdXNlclxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGB0cnVlYFxuXHQgKi9cblx0dmlzaWJsZTogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBJbnRlcmZhY2UgcmVwcmVzZW50aW5nIHRoZSBBUEkgZm9yIGEgY29sbGFwc2libGUgY29tcG9uZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbGxhcHNlQXBpIHtcblx0XG5cdC8qKlxuXHQgKiBUcmlnZ2VycyBjb2xsYXBzZSBjbG9zaW5nIHByb2dyYW1tYXRpY2FsbHkuXG5cdCAqL1xuXHRjbG9zZSgpOiB2b2lkO1xuXHRcblxuXHQvKipcblx0ICogVHJpZ2dlcnMgdGhlIGNvbGxhcHNlIGNvbnRlbnQgdG8gYmUgZGlzcGxheWVkIGZvciB0aGUgdXNlci5cblx0ICovXG5cdG9wZW4oKTogdm9pZDtcblx0XG5cblx0LyoqXG5cdCAqIFRvZ2dsZXMgdGhlIGNvbGxhcHNlIGNvbnRlbnQgdmlzaWJpbGl0eS5cblx0ICovXG5cdHRvZ2dsZSgpOiB2b2lkO1xufVxuXG4vKipcbiAqIEludGVyZmFjZSByZXByZXNlbnRpbmcgdGhlIGRpcmVjdGl2ZXMgdXNlZCBpbiBhIGNvbGxhcHNlIGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDb2xsYXBzZURpcmVjdGl2ZXMge1xuXHRcblx0LyoqXG5cdCAqIERpcmVjdGl2ZSB0byBhcHBseSB0aGUgY29sbGFwc2UuXG5cdCAqL1xuXHRjb2xsYXBzZURpcmVjdGl2ZTogRGlyZWN0aXZlO1xufVxuXG5cblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgd2lkZ2V0IGZvciBoYW5kbGluZyBjb2xsYXBzZSBmdW5jdGlvbmFsaXR5LlxuICpcbiAqIFRoaXMgdHlwZSBkZWZpbmVzIHRoZSBzdHJ1Y3R1cmUgb2YgYSBDb2xsYXBzZVdpZGdldCwgd2hpY2ggaW5jbHVkZXMgcHJvcGVydGllcywgc3RhdGUsIEFQSSwgYW5kIGRpcmVjdGl2ZXNcbiAqIG5lY2Vzc2FyeSBmb3IgbWFuYWdpbmcgdGhlIGNvbGxhcHNlIGJlaGF2aW9yIGluIHRoZSBVSS5cbiAqXG4gKiBAdHlwZSB7V2lkZ2V0PENvbGxhcHNlUHJvcHMsIENvbGxhcHNlU3RhdGUsIENvbGxhcHNlQXBpLCBDb2xsYXBzZURpcmVjdGl2ZXM+fVxuICovXG5leHBvcnQgdHlwZSBDb2xsYXBzZVdpZGdldCA9IFdpZGdldDxDb2xsYXBzZVByb3BzLCBDb2xsYXBzZVN0YXRlLCBDb2xsYXBzZUFwaSwgQ29sbGFwc2VEaXJlY3RpdmVzPjtcblxuIl19
@@ -0,0 +1,3 @@
1
+ export * from './collapse.component';
2
+ export * from './collapse.gen';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9jb2xsYXBzZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsZ0JBQWdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbGxhcHNlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbGxhcHNlLmdlbic7XG4iXX0=