@agnos-ui/angular-bootstrap 0.4.4 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/agnos-ui-angular.module.d.ts +2 -1
- package/components/accordion/accordion.component.d.ts +40 -18
- package/components/accordion/accordion.gen.d.ts +37 -9
- package/components/alert/alert.component.d.ts +29 -17
- package/components/alert/alert.gen.d.ts +21 -2
- package/components/collapse/collapse.component.d.ts +79 -0
- package/components/collapse/collapse.gen.d.ts +146 -0
- package/components/collapse/index.d.ts +2 -0
- package/components/modal/modal.component.d.ts +13 -19
- package/components/modal/modal.gen.d.ts +35 -18
- package/components/modal/modal.service.d.ts +5 -1
- package/components/pagination/pagination.component.d.ts +20 -15
- package/components/pagination/pagination.gen.d.ts +49 -29
- package/components/progressbar/progressbar.component.d.ts +32 -16
- package/components/progressbar/progressbar.gen.d.ts +21 -4
- package/components/rating/rating.component.d.ts +11 -4
- package/components/rating/rating.gen.d.ts +25 -17
- package/components/select/select.component.d.ts +24 -4
- package/components/select/select.gen.d.ts +41 -25
- package/components/slider/slider.component.d.ts +32 -23
- package/components/slider/slider.gen.d.ts +54 -33
- package/components/toast/toast.component.d.ts +29 -17
- package/components/toast/toast.gen.d.ts +22 -2
- package/config.d.ts +16 -5
- package/config.gen.d.ts +5 -0
- package/esm2022/agnos-ui-angular.module.mjs +12 -5
- package/esm2022/components/accordion/accordion.component.mjs +165 -134
- package/esm2022/components/accordion/accordion.gen.mjs +1 -1
- package/esm2022/components/alert/alert.component.mjs +90 -65
- package/esm2022/components/alert/alert.gen.mjs +1 -1
- package/esm2022/components/collapse/collapse.component.mjs +89 -0
- package/esm2022/components/collapse/collapse.gen.mjs +15 -0
- package/esm2022/components/collapse/index.mjs +3 -0
- package/esm2022/components/modal/modal.component.mjs +111 -99
- package/esm2022/components/modal/modal.gen.mjs +1 -1
- package/esm2022/components/modal/modal.service.mjs +7 -5
- package/esm2022/components/pagination/pagination.component.mjs +138 -123
- package/esm2022/components/pagination/pagination.gen.mjs +1 -1
- package/esm2022/components/progressbar/progressbar.component.mjs +94 -55
- package/esm2022/components/progressbar/progressbar.gen.mjs +1 -1
- package/esm2022/components/rating/rating.component.mjs +41 -35
- package/esm2022/components/rating/rating.gen.mjs +1 -1
- package/esm2022/components/select/select.component.mjs +103 -118
- package/esm2022/components/select/select.gen.mjs +1 -1
- package/esm2022/components/slider/slider.component.mjs +126 -111
- package/esm2022/components/slider/slider.gen.mjs +1 -1
- package/esm2022/components/toast/toast.component.mjs +106 -81
- package/esm2022/components/toast/toast.gen.mjs +1 -1
- package/esm2022/config.gen.mjs +1 -1
- package/esm2022/config.mjs +17 -1
- package/esm2022/index.mjs +2 -1
- package/fesm2022/agnos-ui-angular-bootstrap.mjs +1085 -806
- package/fesm2022/agnos-ui-angular-bootstrap.mjs.map +1 -1
- package/index.d.ts +8 -7
- package/package.json +9 -8
|
@@ -12,4 +12,4 @@ export { export_getPaginationDefaultConfig as getPaginationDefaultConfig };
|
|
|
12
12
|
*/
|
|
13
13
|
const export_createPagination = createPagination;
|
|
14
14
|
export { export_createPagination as createPagination };
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.gen.js","sourceRoot":"","sources":["../../../../src/components/pagination/pagination.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,0BAA0B,EAAE,gBAAgB,EAAC,MAAM,gDAAgD,CAAC;AAI5G;;;GAGG;AACH,MAAM,iCAAiC,GAA0B,0BAAiC,CAAC;AACnG,OAAO,EAAC,iCAAiC,IAAI,0BAA0B,EAAC,CAAC;AA+lBzE;;;;GAIG;AACH,MAAM,uBAAuB,GAAoC,gBAAuB,CAAC;AACzF,OAAO,EAAC,uBAAuB,IAAI,gBAAgB,EAAC,CAAC","sourcesContent":["import {getPaginationDefaultConfig, createPagination} from '@agnos-ui/core-bootstrap/components/pagination';\nimport type {WidgetSlotContext, SlotContent, Widget, WidgetFactory, Directive} from '@agnos-ui/angular-headless';\n\n\n/**\n * Retrieve a shallow copy of the default Pagination config\n * @returns the default Pagination config\n */\nconst export_getPaginationDefaultConfig: () => PaginationProps = getPaginationDefaultConfig as any;\nexport {export_getPaginationDefaultConfig as getPaginationDefaultConfig};\n\n\n\n/**\n * A type for the slot context of the pagination widget\n */\nexport type PaginationContext = WidgetSlotContext<PaginationWidget>;\n\n\n\n/**\n * A type for the slot context of the pagination widget when the slot is the number label\n */\nexport type PaginationNumberContext = PaginationContext & {\n\t/**\n\t * Displayed page\n\t */\n\tdisplayedPage: number;\n};\n\nexport interface PaginationState {\n\t\n\t/**\n\t * The number of pages.\n\t */\n\tpageCount: number;\n\t\n\t/**\n\t * The current pages, the number in the Array is the number of the page.\n\t */\n\tpages: number[];\n\t\n\t/**\n\t * true if the previous link need to be disabled\n\t */\n\tpreviousDisabled: boolean;\n\t\n\t/**\n\t * true if the next link need to be disabled\n\t */\n\tnextDisabled: boolean;\n\t\n\t/**\n\t * The label for each \"Page\" page link.\n\t */\n\tpagesLabel: string[];\n\t\n\n\t/** The hrefs for each \"Page\" page link */\n\tpagesHrefs: string[];\n\t\n\n\t/** The hrefs for the direction links  */\n\tdirectionsHrefs: DirectionsHrefs;\n\t\n\n\t/** The aria-live text */\n\tariaLiveLabelText: string;\n\t\n\t/**\n\t * The current page.\n\t *\n\t * Page numbers start with `1`.\n\t *\n\t * @defaultValue `1`\n\t */\n\tpage: number;\n\t // value of the current/init page to display\n\n\t/**\n\t * The pagination display size.\n\t *\n\t * Bootstrap currently supports small and large sizes.\n\t *\n\t * @defaultValue `null`\n\t */\n\tsize: 'sm' | 'lg' | null;\n\t\n\n\t/**\n\t * The label for the nav element.\n\t *\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'Page navigation'`\n\t */\n\tariaLabel: string;\n\t\n\n\t/**\n\t * The label for the \"active\" page.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * '(current)'\n\t * ```\n\t */\n\tactiveLabel: string;\n\t\n\n\t/**\n\t * The label for the \"First\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for first page'\n\t * ```\n\t */\n\tariaFirstLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Previous\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for previous page'\n\t * ```\n\t */\n\tariaPreviousLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Next\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for next page'\n\t * ```\n\t */\n\tariaNextLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Last\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for last page'\n\t * ```\n\t */\n\tariaLastLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Ellipsis\" page.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'Ellipsis page element'`\n\t */\n\tariaEllipsisLabel: string;\n\t\n\n\t/**\n\t * If `true`, pagination links will be disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true`, the \"Next\" and \"Previous\" page links are shown.\n\t *\n\t * @defaultValue `true`\n\t */\n\tdirectionLinks: boolean;\n\t\n\n\t/**\n\t * If `true`, the \"First\" and \"Last\" page links are shown.\n\t *\n\t * @defaultValue `false`\n\t */\n\tboundaryLinks: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to use for the structure of the pagination component\n\t * The default structure uses {@link PaginationProps.ellipsisLabel|ellipsisLabel}, {@link PaginationProps.firstPageLabel|firstPageLabel},\n\t * {@link PaginationProps.previousPageLabel|previousPageLabel}, {@link PaginationProps.nextPageLabel|nextPageLabel},\n\t * {@link PaginationProps.lastPageLabel|lastPageLabel}, {@link PaginationProps.pagesDisplay|pagesDisplay},\n\t * {@link PaginationProps.numberLabel|numberLabel},\n\t */\n\tstructure: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the ellipsis slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'…'`\n\t */\n\tellipsisLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the first slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'«'`\n\t */\n\tfirstPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the previous slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'‹'`\n\t */\n\tpreviousPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the next slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'›'`\n\t */\n\tnextPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the last slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'»'`\n\t */\n\tlastPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the pages slot\n\t * To use to customize the pages view\n\t * override any configuration parameters provided for this\n\t */\n\tpagesDisplay: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the number slot\n\t * override any configuration parameters provided for this\n\t * for I18n, we suggest to use the global configuration\n\t * @param displayedPage - The current page number\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({displayedPage}: PaginationNumberContext) => `${displayedPage}`\n\t * ```\n\t */\n\tnumberLabel: SlotContent<PaginationNumberContext>;\n}\n\nexport interface PaginationProps {\n\t\n\t/**\n\t * The number of items in your paginated collection.\n\t *\n\t * Note, that this is not the number of pages. Page numbers are calculated dynamically based on\n\t * `collectionSize` and `pageSize`.\n\t *\n\t * Ex. if you have 100 items in your collection and displaying 20 items per page, you'll end up with 5 pages.\n\t *\n\t * Whatever the collectionSize the page number is of minimum 1.\n\t *\n\t * @defaultValue `0`\n\t */\n\tcollectionSize: number;\n\t\n\n\t/**\n\t * The number of items per page.\n\t * @remarks min value is 1\n\t *\n\t * @defaultValue `10`\n\t */\n\tpageSize: number;\n\t\n\n\t/**\n\t * An event fired when the page is changed.\n\t *\n\t * Event payload is the number of the newly selected page.\n\t *\n\t * Page numbers start with `1`.\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonPageChange: (page: number) => void;\n\t\n\n\t/**\n\t * pagesFactory returns a function computing the array of pages to be displayed\n\t * as number (-1 are treated as ellipsis).\n\t * Use Page slot to customize the pages view and not this\n\t * @param page - The current page number\n\t * @param pageCount - The total number of pages\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (_page: number, pageCount: number) => {\n\t * \t\tconst pages: number[] = [];\n\t * \t\tfor (let i = 1; i <= pageCount; i++) {\n\t * \t\t\tpages.push(i);\n\t * \t\t}\n\t * \t\treturn pages;\n\t * \t}\n\t * ```\n\t */\n\tpagesFactory: (page: number, pageCount: number) => number[];\n\t\n\n\t/**\n\t * Provide the label for each \"Page\" page button.\n\t * This is used for accessibility purposes.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t * @param processPage - The current page number\n\t * @param pageCount - The total number of pages\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (processPage: number, pageCount: number) => `Page ${processPage} of ${pageCount}`\n\t * ```\n\t */\n\tariaPageLabel: (processPage: number, pageCount: number) => string;\n\t\n\n\t/**\n\t * Provide the label for the aria-live element\n\t * This is used for accessibility purposes.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t * @param currentPage - The current page number\n\t * @param pageCount - The total number of pages\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (currentPage: number, pageCount: number) => `Current page is ${currentPage}`\n\t * ```\n\t */\n\tariaLiveLabel: (currentPage: number, pageCount: number) => string;\n\t\n\n\t/**\n\t * Factory function providing the href for a \"Page\" page anchor,\n\t * based on the current page number\n\t * @param pageNumber - The index to use in the link\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (_page: number) => PAGE_LINK_DEFAULT\n\t * ```\n\t */\n\tpageLink: (pageNumber: number) => string;\n\t\n\t/**\n\t * The current page.\n\t *\n\t * Page numbers start with `1`.\n\t *\n\t * @defaultValue `1`\n\t */\n\tpage: number;\n\t // value of the current/init page to display\n\n\t/**\n\t * The pagination display size.\n\t *\n\t * Bootstrap currently supports small and large sizes.\n\t *\n\t * @defaultValue `null`\n\t */\n\tsize: 'sm' | 'lg' | null;\n\t\n\n\t/**\n\t * The label for the nav element.\n\t *\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'Page navigation'`\n\t */\n\tariaLabel: string;\n\t\n\n\t/**\n\t * The label for the \"active\" page.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * '(current)'\n\t * ```\n\t */\n\tactiveLabel: string;\n\t\n\n\t/**\n\t * The label for the \"First\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for first page'\n\t * ```\n\t */\n\tariaFirstLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Previous\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for previous page'\n\t * ```\n\t */\n\tariaPreviousLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Next\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for next page'\n\t * ```\n\t */\n\tariaNextLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Last\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for last page'\n\t * ```\n\t */\n\tariaLastLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Ellipsis\" page.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'Ellipsis page element'`\n\t */\n\tariaEllipsisLabel: string;\n\t\n\n\t/**\n\t * If `true`, pagination links will be disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true`, the \"Next\" and \"Previous\" page links are shown.\n\t *\n\t * @defaultValue `true`\n\t */\n\tdirectionLinks: boolean;\n\t\n\n\t/**\n\t * If `true`, the \"First\" and \"Last\" page links are shown.\n\t *\n\t * @defaultValue `false`\n\t */\n\tboundaryLinks: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to use for the structure of the pagination component\n\t * The default structure uses {@link PaginationProps.ellipsisLabel|ellipsisLabel}, {@link PaginationProps.firstPageLabel|firstPageLabel},\n\t * {@link PaginationProps.previousPageLabel|previousPageLabel}, {@link PaginationProps.nextPageLabel|nextPageLabel},\n\t * {@link PaginationProps.lastPageLabel|lastPageLabel}, {@link PaginationProps.pagesDisplay|pagesDisplay},\n\t * {@link PaginationProps.numberLabel|numberLabel},\n\t */\n\tstructure: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the ellipsis slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'…'`\n\t */\n\tellipsisLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the first slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'«'`\n\t */\n\tfirstPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the previous slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'‹'`\n\t */\n\tpreviousPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the next slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'›'`\n\t */\n\tnextPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the last slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'»'`\n\t */\n\tlastPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the pages slot\n\t * To use to customize the pages view\n\t * override any configuration parameters provided for this\n\t */\n\tpagesDisplay: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the number slot\n\t * override any configuration parameters provided for this\n\t * for I18n, we suggest to use the global configuration\n\t * @param displayedPage - The current page number\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({displayedPage}: PaginationNumberContext) => `${displayedPage}`\n\t * ```\n\t */\n\tnumberLabel: SlotContent<PaginationNumberContext>;\n}\n\n\n\nexport type PaginationWidget = Widget<PaginationProps, PaginationState, PaginationApi, PaginationActions, PaginationDirectives>;\n\n\n\n/**\n * Create a PaginationWidget with given config props\n * @param config - an optional alert config\n * @returns a PaginationWidget\n */\nconst export_createPagination: WidgetFactory<PaginationWidget> = createPagination as any;\nexport {export_createPagination as createPagination};\n\nexport interface DirectionsHrefs {\n\t\n\t/**\n\t * The href for the 'Previous' navigation link\n\t */\n\tprevious: string;\n\t\n\t/**\n\t * The href for the 'Next' direction link\n\t */\n\tnext: string;\n}\n\nexport interface PaginationActions {\n\t\n\t/**\n\t * To \"go\" to a specific page\n\t * @param page - The page number to select\n\t */\n\tselect(page: number, event?: MouseEvent): void;\n\t\n\t/**\n\t * To \"go\" to the first page\n\t */\n\tfirst(event?: MouseEvent): void;\n\t\n\t/**\n\t * To \"go\" to the previous page\n\t */\n\tprevious(event?: MouseEvent): void;\n\t\n\t/**\n\t * To \"go\" to the next page\n\t */\n\tnext(event?: MouseEvent): void;\n\t\n\t/**\n\t * To \"go\" to the last page\n\t */\n\tlast(event?: MouseEvent): void;\n}\n\nexport interface PaginationDirectives {\n\t\n\t/**\n\t * A directive to be applied to each page link\n\t * This will handle the click, tabindex and aria attributes\n\t */\n\tpageLink: Directive<{\n\t\tpage: number;\n\t}>;\n\t\n\n\t/**\n\t * A directive to be applied on the previous link\n\t */\n\tpagePrev: Directive;\n\t\n\n\t/**\n\t * A directive to be applied on the first link\n\t */\n\tpageFirst: Directive;\n\t\n\n\t/**\n\t * A directive to be applied on the next link\n\t */\n\tpageNext: Directive;\n\t\n\n\t/**\n\t * A directive to be applied on the Last link\n\t */\n\tpageLast: Directive;\n}\n\nexport interface PaginationApi {\n}\n\n"]}
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.gen.js","sourceRoot":"","sources":["../../../../src/components/pagination/pagination.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,0BAA0B,EAAE,gBAAgB,EAAC,MAAM,gDAAgD,CAAC;AAK5G;;;GAGG;AACH,MAAM,iCAAiC,GAA0B,0BAAiC,CAAC;AACnG,OAAO,EAAC,iCAAiC,IAAI,0BAA0B,EAAC,CAAC;AA2mBzE;;;;GAIG;AACH,MAAM,uBAAuB,GAAoC,gBAAuB,CAAC;AACzF,OAAO,EAAC,uBAAuB,IAAI,gBAAgB,EAAC,CAAC","sourcesContent":["import {getPaginationDefaultConfig, createPagination} from '@agnos-ui/core-bootstrap/components/pagination';\nimport type {WidgetSlotContext, SlotContent, Widget, WidgetFactory, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default Pagination config\n * @returns the default Pagination config\n */\nconst export_getPaginationDefaultConfig: () => PaginationProps = getPaginationDefaultConfig as any;\nexport {export_getPaginationDefaultConfig as getPaginationDefaultConfig};\n\n\n\n/**\n * A type for the slot context of the pagination widget\n */\nexport interface PaginationContext extends WidgetSlotContext<PaginationWidget> {}\n\n\n\n/**\n * A type for the slot context of the pagination widget when the slot is the number label\n */\nexport interface PaginationNumberContext extends PaginationContext {\n\t/**\n\t * Displayed page\n\t */\n\tdisplayedPage: number;\n}\n\n/**\n * Represents the state of a pagination component.\n */\nexport interface PaginationState {\n\t\n\t/**\n\t * The number of pages.\n\t */\n\tpageCount: number;\n\t\n\t/**\n\t * The current pages, the number in the Array is the number of the page.\n\t */\n\tpages: number[];\n\t\n\t/**\n\t * true if the previous link need to be disabled\n\t */\n\tpreviousDisabled: boolean;\n\t\n\t/**\n\t * true if the next link need to be disabled\n\t */\n\tnextDisabled: boolean;\n\t\n\t/**\n\t * The label for each \"Page\" page link.\n\t */\n\tpagesLabel: string[];\n\t\n\n\t/** The hrefs for each \"Page\" page link */\n\tpagesHrefs: string[];\n\t\n\n\t/** The hrefs for the direction links  */\n\tdirectionsHrefs: DirectionsHrefs;\n\t\n\n\t/** The aria-live text */\n\tariaLiveLabelText: string;\n\t\n\t/**\n\t * The current page.\n\t *\n\t * Page numbers start with `1`.\n\t *\n\t * @defaultValue `1`\n\t */\n\tpage: number;\n\t // value of the current/init page to display\n\n\t/**\n\t * The label for the nav element.\n\t *\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'Page navigation'`\n\t */\n\tariaLabel: string;\n\t\n\n\t/**\n\t * The label for the \"active\" page.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * '(current)'\n\t * ```\n\t */\n\tactiveLabel: string;\n\t\n\n\t/**\n\t * The label for the \"First\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for first page'\n\t * ```\n\t */\n\tariaFirstLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Previous\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for previous page'\n\t * ```\n\t */\n\tariaPreviousLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Next\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for next page'\n\t * ```\n\t */\n\tariaNextLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Last\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for last page'\n\t * ```\n\t */\n\tariaLastLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Ellipsis\" page.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'Ellipsis page element'`\n\t */\n\tariaEllipsisLabel: string;\n\t\n\n\t/**\n\t * If `true`, pagination links will be disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true`, the \"Next\" and \"Previous\" page links are shown.\n\t *\n\t * @defaultValue `true`\n\t */\n\tdirectionLinks: boolean;\n\t\n\n\t/**\n\t * If `true`, the \"First\" and \"Last\" page links are shown.\n\t *\n\t * @defaultValue `false`\n\t */\n\tboundaryLinks: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to use for the structure of the pagination component\n\t * The default structure uses {@link PaginationProps.ellipsisLabel|ellipsisLabel}, {@link PaginationProps.firstPageLabel|firstPageLabel},\n\t * {@link PaginationProps.previousPageLabel|previousPageLabel}, {@link PaginationProps.nextPageLabel|nextPageLabel},\n\t * {@link PaginationProps.lastPageLabel|lastPageLabel}, {@link PaginationProps.pagesDisplay|pagesDisplay},\n\t * {@link PaginationProps.numberLabel|numberLabel},\n\t */\n\tstructure: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the ellipsis slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'…'`\n\t */\n\tellipsisLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the first slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'«'`\n\t */\n\tfirstPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the previous slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'‹'`\n\t */\n\tpreviousPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the next slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'›'`\n\t */\n\tnextPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the last slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'»'`\n\t */\n\tlastPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the pages slot\n\t * To use to customize the pages view\n\t * override any configuration parameters provided for this\n\t */\n\tpagesDisplay: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the number slot\n\t * override any configuration parameters provided for this\n\t * for I18n, we suggest to use the global configuration\n\t * @param displayedPage - The current page number\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({displayedPage}: PaginationNumberContext) => `${displayedPage}`\n\t * ```\n\t */\n\tnumberLabel: SlotContent<PaginationNumberContext>;\n\t\n\n\t/**\n\t * The pagination display size.\n\t *\n\t * Bootstrap currently supports small and large sizes.\n\t *\n\t * @defaultValue `null`\n\t */\n\tsize: 'sm' | 'lg' | null;\n}\n\n/**\n * Represents the properties for the Pagination component.\n */\nexport interface PaginationProps {\n\t\n\t/**\n\t * The number of items in your paginated collection.\n\t *\n\t * Note, that this is not the number of pages. Page numbers are calculated dynamically based on\n\t * `collectionSize` and `pageSize`.\n\t *\n\t * Ex. if you have 100 items in your collection and displaying 20 items per page, you'll end up with 5 pages.\n\t *\n\t * Whatever the collectionSize the page number is of minimum 1.\n\t *\n\t * @defaultValue `0`\n\t */\n\tcollectionSize: number;\n\t\n\n\t/**\n\t * The number of items per page.\n\t * @remarks min value is 1\n\t *\n\t * @defaultValue `10`\n\t */\n\tpageSize: number;\n\t\n\n\t/**\n\t * An event fired when the page is changed.\n\t *\n\t * Event payload is the number of the newly selected page.\n\t *\n\t * Page numbers start with `1`.\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonPageChange: (page: number) => void;\n\t\n\n\t/**\n\t * pagesFactory returns a function computing the array of pages to be displayed\n\t * as number (-1 are treated as ellipsis).\n\t * Use Page slot to customize the pages view and not this\n\t * @param page - The current page number\n\t * @param pageCount - The total number of pages\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (_page: number, pageCount: number) => {\n\t * \t\tconst pages: number[] = [];\n\t * \t\tfor (let i = 1; i <= pageCount; i++) {\n\t * \t\t\tpages.push(i);\n\t * \t\t}\n\t * \t\treturn pages;\n\t * \t}\n\t * ```\n\t */\n\tpagesFactory: (page: number, pageCount: number) => number[];\n\t\n\n\t/**\n\t * Provide the label for each \"Page\" page button.\n\t * This is used for accessibility purposes.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t * @param processPage - The current page number\n\t * @param pageCount - The total number of pages\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (processPage: number, pageCount: number) => `Page ${processPage} of ${pageCount}`\n\t * ```\n\t */\n\tariaPageLabel: (processPage: number, pageCount: number) => string;\n\t\n\n\t/**\n\t * Provide the label for the aria-live element\n\t * This is used for accessibility purposes.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t * @param currentPage - The current page number\n\t * @param pageCount - The total number of pages\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (currentPage: number) => `Current page is ${currentPage}`\n\t * ```\n\t */\n\tariaLiveLabel: (currentPage: number, pageCount: number) => string;\n\t\n\n\t/**\n\t * Factory function providing the href for a \"Page\" page anchor,\n\t * based on the current page number\n\t * @param pageNumber - The index to use in the link\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (_page: number) => PAGE_LINK_DEFAULT\n\t * ```\n\t */\n\tpageLink: (pageNumber: number) => string;\n\t\n\t/**\n\t * The current page.\n\t *\n\t * Page numbers start with `1`.\n\t *\n\t * @defaultValue `1`\n\t */\n\tpage: number;\n\t // value of the current/init page to display\n\n\t/**\n\t * The label for the nav element.\n\t *\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'Page navigation'`\n\t */\n\tariaLabel: string;\n\t\n\n\t/**\n\t * The label for the \"active\" page.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * '(current)'\n\t * ```\n\t */\n\tactiveLabel: string;\n\t\n\n\t/**\n\t * The label for the \"First\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for first page'\n\t * ```\n\t */\n\tariaFirstLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Previous\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for previous page'\n\t * ```\n\t */\n\tariaPreviousLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Next\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for next page'\n\t * ```\n\t */\n\tariaNextLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Last\" page button.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * 'Action link for last page'\n\t * ```\n\t */\n\tariaLastLabel: string;\n\t\n\n\t/**\n\t * The label for the \"Ellipsis\" page.\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'Ellipsis page element'`\n\t */\n\tariaEllipsisLabel: string;\n\t\n\n\t/**\n\t * If `true`, pagination links will be disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true`, the \"Next\" and \"Previous\" page links are shown.\n\t *\n\t * @defaultValue `true`\n\t */\n\tdirectionLinks: boolean;\n\t\n\n\t/**\n\t * If `true`, the \"First\" and \"Last\" page links are shown.\n\t *\n\t * @defaultValue `false`\n\t */\n\tboundaryLinks: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * The template to use for the structure of the pagination component\n\t * The default structure uses {@link PaginationProps.ellipsisLabel|ellipsisLabel}, {@link PaginationProps.firstPageLabel|firstPageLabel},\n\t * {@link PaginationProps.previousPageLabel|previousPageLabel}, {@link PaginationProps.nextPageLabel|nextPageLabel},\n\t * {@link PaginationProps.lastPageLabel|lastPageLabel}, {@link PaginationProps.pagesDisplay|pagesDisplay},\n\t * {@link PaginationProps.numberLabel|numberLabel},\n\t */\n\tstructure: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the ellipsis slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'…'`\n\t */\n\tellipsisLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the first slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'«'`\n\t */\n\tfirstPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the previous slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'‹'`\n\t */\n\tpreviousPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the next slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'›'`\n\t */\n\tnextPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the last slot\n\t * for I18n, we suggest to use the global configuration\n\t * override any configuration parameters provided for this\n\t *\n\t * @defaultValue `'»'`\n\t */\n\tlastPageLabel: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the pages slot\n\t * To use to customize the pages view\n\t * override any configuration parameters provided for this\n\t */\n\tpagesDisplay: SlotContent<PaginationContext>;\n\t\n\n\t/**\n\t * The template to use for the number slot\n\t * override any configuration parameters provided for this\n\t * for I18n, we suggest to use the global configuration\n\t * @param displayedPage - The current page number\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({displayedPage}: PaginationNumberContext) => `${displayedPage}`\n\t * ```\n\t */\n\tnumberLabel: SlotContent<PaginationNumberContext>;\n\t\n\n\t/**\n\t * The pagination display size.\n\t *\n\t * Bootstrap currently supports small and large sizes.\n\t *\n\t * @defaultValue `null`\n\t */\n\tsize: 'sm' | 'lg' | null;\n}\n\n\n\n/**\n * Represents a pagination widget component.\n *\n * This type defines a widget that handles pagination functionality,\n * including properties, state, api and directives specific to pagination.\n */\nexport type PaginationWidget = Widget<PaginationProps, PaginationState, PaginationApi, PaginationDirectives>;\n\n\n\n/**\n * Create a PaginationWidget with given config props\n * @param config - an optional alert config\n * @returns a PaginationWidget\n */\nconst export_createPagination: WidgetFactory<PaginationWidget> = createPagination as any;\nexport {export_createPagination as createPagination};\n\n/**\n * Interface representing the hrefs for pagination navigation links.\n */\nexport interface DirectionsHrefs {\n\t\n\t/**\n\t * The href for the 'Previous' navigation link\n\t */\n\tprevious: string;\n\t\n\t/**\n\t * The href for the 'Next' direction link\n\t */\n\tnext: string;\n}\n\n/**\n * Interface representing pagination API for navigating through pages.\n */\nexport interface PaginationApi {\n\t\n\t/**\n\t * To \"go\" to a specific page\n\t * @param page - The page number to select\n\t */\n\tselect(page: number): void;\n\t\n\t/**\n\t * To \"go\" to the first page\n\t */\n\tfirst(): void;\n\t\n\t/**\n\t * To \"go\" to the previous page\n\t */\n\tprevious(): void;\n\t\n\t/**\n\t * To \"go\" to the next page\n\t */\n\tnext(): void;\n\t\n\t/**\n\t * To \"go\" to the last page\n\t */\n\tlast(): void;\n}\n\n/**\n * Interface representing the directives for pagination components.\n */\nexport interface PaginationDirectives {\n\t\n\t/**\n\t * A directive to be applied to each page link\n\t * This will handle the click, tabindex and aria attributes\n\t */\n\tpageLink: Directive<{\n\t\tpage: number;\n\t}>;\n\t\n\n\t/**\n\t * A directive to be applied on the previous link\n\t */\n\tpagePrev: Directive;\n\t\n\n\t/**\n\t * A directive to be applied on the first link\n\t */\n\tpageFirst: Directive;\n\t\n\n\t/**\n\t * A directive to be applied on the next link\n\t */\n\tpageNext: Directive;\n\t\n\n\t/**\n\t * A directive to be applied on the Last link\n\t */\n\tpageLast: Directive;\n}\n\n"]}
|
|
@@ -1,12 +1,11 @@
|
|
|
1
|
-
import { BaseWidgetDirective, ComponentTemplate,
|
|
2
|
-
import { writable } from '@amadeus-it-group/tansu';
|
|
1
|
+
import { BaseWidgetDirective, ComponentTemplate, SlotDirective, auBooleanAttribute, auNumberAttribute, useDirectiveForHost, } from '@agnos-ui/angular-headless';
|
|
3
2
|
import { NgClass } from '@angular/common';
|
|
4
3
|
import { ChangeDetectionStrategy, Component, ContentChild, Directive, Input, TemplateRef, ViewChild, inject } from '@angular/core';
|
|
5
4
|
import { createProgressbar } from './progressbar.gen';
|
|
6
5
|
import { callWidgetFactory } from '../../config';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
8
7
|
const _c0 = ["structure"];
|
|
9
|
-
const _c1 = (a0, a1) => ({ state: a0,
|
|
8
|
+
const _c1 = (a0, a1, a2) => ({ state: a0, api: a1, directives: a2 });
|
|
10
9
|
function ProgressbarDefaultSlotsComponent_ng_template_0_ng_template_2_Template(rf, ctx) { }
|
|
11
10
|
function ProgressbarDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
|
|
12
11
|
i0.ɵɵelementStart(0, "div", 2)(1, "div", 3);
|
|
@@ -14,21 +13,46 @@ function ProgressbarDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (
|
|
|
14
13
|
i0.ɵɵelementEnd()();
|
|
15
14
|
} if (rf & 2) {
|
|
16
15
|
const state_r1 = ctx.state;
|
|
17
|
-
const
|
|
18
|
-
|
|
16
|
+
const api_r2 = ctx.api;
|
|
17
|
+
const directives_r3 = ctx.directives;
|
|
18
|
+
i0.ɵɵstyleProp("height", state_r1.height());
|
|
19
19
|
i0.ɵɵadvance();
|
|
20
|
-
i0.ɵɵstyleProp("width", state_r1.percentage, "%");
|
|
21
|
-
i0.ɵɵclassProp("progress-bar-striped", state_r1.striped)("progress-bar-animated", state_r1.animated);
|
|
22
|
-
i0.ɵɵproperty("ngClass", state_r1.type ? "text-bg-" + state_r1.type : undefined);
|
|
20
|
+
i0.ɵɵstyleProp("width", state_r1.percentage(), "%");
|
|
21
|
+
i0.ɵɵclassProp("progress-bar-striped", state_r1.striped())("progress-bar-animated", state_r1.animated());
|
|
22
|
+
i0.ɵɵproperty("ngClass", state_r1.type() ? "text-bg-" + state_r1.type() : undefined);
|
|
23
23
|
i0.ɵɵadvance();
|
|
24
|
-
i0.ɵɵproperty("auSlot", state_r1.children)("auSlotProps", i0.ɵɵ
|
|
24
|
+
i0.ɵɵproperty("auSlot", state_r1.children())("auSlotProps", i0.ɵɵpureFunction3(11, _c1, state_r1, api_r2, directives_r3));
|
|
25
25
|
} }
|
|
26
|
-
const _c2 = ["
|
|
27
|
-
const _c3 = ["
|
|
26
|
+
const _c2 = ["content"];
|
|
27
|
+
const _c3 = ["auProgressbar", ""];
|
|
28
|
+
const _c4 = ["*"];
|
|
28
29
|
function ProgressbarComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
|
|
29
30
|
i0.ɵɵprojection(0);
|
|
30
31
|
} }
|
|
31
|
-
function
|
|
32
|
+
function ProgressbarComponent_ng_template_2_Template(rf, ctx) { }
|
|
33
|
+
/**
|
|
34
|
+
* Directive that provides a template reference for the progress bar context.
|
|
35
|
+
* This directive provides a template reference for the {@link ProgressbarContext}.
|
|
36
|
+
*/
|
|
37
|
+
export class ProgressbarBodyDirective {
|
|
38
|
+
constructor() {
|
|
39
|
+
this.templateRef = inject((TemplateRef));
|
|
40
|
+
}
|
|
41
|
+
static ngTemplateContextGuard(_dir, context) {
|
|
42
|
+
return true;
|
|
43
|
+
}
|
|
44
|
+
static { this.ɵfac = function ProgressbarBodyDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ProgressbarBodyDirective)(); }; }
|
|
45
|
+
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ProgressbarBodyDirective, selectors: [["ng-template", "auProgressbarBody", ""]], standalone: true }); }
|
|
46
|
+
}
|
|
47
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ProgressbarBodyDirective, [{
|
|
48
|
+
type: Directive,
|
|
49
|
+
args: [{ selector: 'ng-template[auProgressbarBody]', standalone: true }]
|
|
50
|
+
}], null, null); })();
|
|
51
|
+
/**
|
|
52
|
+
* Directive to define the structure of a progress bar.
|
|
53
|
+
*
|
|
54
|
+
* This directive provides a template reference for the {@link ProgressbarContext}.
|
|
55
|
+
*/
|
|
32
56
|
export class ProgressbarStructureDirective {
|
|
33
57
|
constructor() {
|
|
34
58
|
this.templateRef = inject((TemplateRef));
|
|
@@ -36,22 +60,22 @@ export class ProgressbarStructureDirective {
|
|
|
36
60
|
static ngTemplateContextGuard(_dir, context) {
|
|
37
61
|
return true;
|
|
38
62
|
}
|
|
39
|
-
static { this.ɵfac = function ProgressbarStructureDirective_Factory(
|
|
63
|
+
static { this.ɵfac = function ProgressbarStructureDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ProgressbarStructureDirective)(); }; }
|
|
40
64
|
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ProgressbarStructureDirective, selectors: [["ng-template", "auProgressbarStructure", ""]], standalone: true }); }
|
|
41
65
|
}
|
|
42
66
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ProgressbarStructureDirective, [{
|
|
43
67
|
type: Directive,
|
|
44
68
|
args: [{ selector: 'ng-template[auProgressbarStructure]', standalone: true }]
|
|
45
69
|
}], null, null); })();
|
|
46
|
-
|
|
47
|
-
static { this.ɵfac = function ProgressbarDefaultSlotsComponent_Factory(
|
|
70
|
+
class ProgressbarDefaultSlotsComponent {
|
|
71
|
+
static { this.ɵfac = function ProgressbarDefaultSlotsComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ProgressbarDefaultSlotsComponent)(); }; }
|
|
48
72
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ProgressbarDefaultSlotsComponent, selectors: [["ng-component"]], viewQuery: function ProgressbarDefaultSlotsComponent_Query(rf, ctx) { if (rf & 1) {
|
|
49
73
|
i0.ɵɵviewQuery(_c0, 7);
|
|
50
74
|
} if (rf & 2) {
|
|
51
75
|
let _t;
|
|
52
76
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.structure = _t.first);
|
|
53
77
|
} }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [["structure", ""], ["auProgressbarStructure", ""], [1, "progress"], [1, "progress-bar", 3, "ngClass"], [3, "auSlot", "auSlotProps"]], template: function ProgressbarDefaultSlotsComponent_Template(rf, ctx) { if (rf & 1) {
|
|
54
|
-
i0.ɵɵtemplate(0, ProgressbarDefaultSlotsComponent_ng_template_0_Template, 3,
|
|
78
|
+
i0.ɵɵtemplate(0, ProgressbarDefaultSlotsComponent_ng_template_0_Template, 3, 15, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
|
|
55
79
|
} }, dependencies: [NgClass, SlotDirective, ProgressbarStructureDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
56
80
|
}
|
|
57
81
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ProgressbarDefaultSlotsComponent, [{
|
|
@@ -61,16 +85,16 @@ export class ProgressbarDefaultSlotsComponent {
|
|
|
61
85
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
62
86
|
imports: [NgClass, SlotDirective, ProgressbarStructureDirective],
|
|
63
87
|
template: `
|
|
64
|
-
<ng-template auProgressbarStructure #structure let-state="state" let-
|
|
65
|
-
<div class="progress" [style.height]="state.height">
|
|
88
|
+
<ng-template auProgressbarStructure #structure let-state="state" let-api="api" let-directives="directives">
|
|
89
|
+
<div class="progress" [style.height]="state.height()">
|
|
66
90
|
<div
|
|
67
91
|
class="progress-bar"
|
|
68
|
-
[class.progress-bar-striped]="state.striped"
|
|
69
|
-
[class.progress-bar-animated]="state.animated"
|
|
70
|
-
[ngClass]="state.type ? 'text-bg-' + state.type : undefined"
|
|
71
|
-
[style.width.%]="state.percentage"
|
|
92
|
+
[class.progress-bar-striped]="state.striped()"
|
|
93
|
+
[class.progress-bar-animated]="state.animated()"
|
|
94
|
+
[ngClass]="state.type() ? 'text-bg-' + state.type() : undefined"
|
|
95
|
+
[style.width.%]="state.percentage()"
|
|
72
96
|
>
|
|
73
|
-
<ng-template [auSlot]="state.children" [auSlotProps]="{state,
|
|
97
|
+
<ng-template [auSlot]="state.children()" [auSlotProps]="{state, api, directives}"></ng-template>
|
|
74
98
|
</div>
|
|
75
99
|
</div>
|
|
76
100
|
</ng-template>
|
|
@@ -80,63 +104,72 @@ export class ProgressbarDefaultSlotsComponent {
|
|
|
80
104
|
type: ViewChild,
|
|
81
105
|
args: ['structure', { static: true }]
|
|
82
106
|
}] }); })();
|
|
83
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ProgressbarDefaultSlotsComponent, { className: "ProgressbarDefaultSlotsComponent", filePath: "components/progressbar/progressbar.component.ts", lineNumber:
|
|
107
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ProgressbarDefaultSlotsComponent, { className: "ProgressbarDefaultSlotsComponent", filePath: "components/progressbar/progressbar.component.ts", lineNumber: 63 }); })();
|
|
108
|
+
/**
|
|
109
|
+
* Represents the default slot structure for the progress bar component.
|
|
110
|
+
*/
|
|
84
111
|
export const progressbarDefaultSlotStructure = new ComponentTemplate(ProgressbarDefaultSlotsComponent, 'structure');
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
112
|
+
/**
|
|
113
|
+
* ProgressbarComponent is a UI component that extends the BaseWidgetDirective
|
|
114
|
+
* to create a customizable progress bar widget. It provides various inputs
|
|
115
|
+
* to configure the appearance and behavior of the progress bar.
|
|
116
|
+
*
|
|
117
|
+
*/
|
|
88
118
|
export class ProgressbarComponent extends BaseWidgetDirective {
|
|
89
119
|
constructor() {
|
|
90
|
-
super(
|
|
91
|
-
this.defaultSlots = writable(defaultConfig);
|
|
92
|
-
this._widget = callWidgetFactory({
|
|
120
|
+
super(callWidgetFactory({
|
|
93
121
|
factory: createProgressbar,
|
|
94
122
|
widgetName: 'progressbar',
|
|
95
|
-
defaultConfig:
|
|
96
|
-
|
|
97
|
-
useDirectiveForHost(this._widget.directives.ariaDirective);
|
|
123
|
+
defaultConfig: {
|
|
124
|
+
structure: progressbarDefaultSlotStructure,
|
|
98
125
|
},
|
|
99
|
-
|
|
126
|
+
afterInit: (widget) => useDirectiveForHost(widget.directives.ariaDirective),
|
|
127
|
+
slotTemplates: () => ({
|
|
128
|
+
structure: this.slotStructureFromContent?.templateRef,
|
|
129
|
+
children: this.slotDefaultFromContent?.templateRef,
|
|
130
|
+
}),
|
|
131
|
+
slotChildren: () => this.slotChildren,
|
|
132
|
+
}));
|
|
100
133
|
}
|
|
101
|
-
|
|
102
|
-
this._widget.patchSlots({
|
|
103
|
-
children: undefined,
|
|
104
|
-
structure: this.slotStructureFromContent?.templateRef,
|
|
105
|
-
});
|
|
106
|
-
}
|
|
107
|
-
static { this.ɵfac = /*@__PURE__*/ (() => { let ɵProgressbarComponent_BaseFactory; return function ProgressbarComponent_Factory(t) { return (ɵProgressbarComponent_BaseFactory || (ɵProgressbarComponent_BaseFactory = i0.ɵɵgetInheritedFactory(ProgressbarComponent)))(t || ProgressbarComponent); }; })(); }
|
|
134
|
+
static { this.ɵfac = function ProgressbarComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ProgressbarComponent)(); }; }
|
|
108
135
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ProgressbarComponent, selectors: [["", "auProgressbar", ""]], contentQueries: function ProgressbarComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
|
136
|
+
i0.ɵɵcontentQuery(dirIndex, ProgressbarBodyDirective, 5);
|
|
109
137
|
i0.ɵɵcontentQuery(dirIndex, ProgressbarStructureDirective, 5);
|
|
110
138
|
} if (rf & 2) {
|
|
111
139
|
let _t;
|
|
140
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first);
|
|
112
141
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStructureFromContent = _t.first);
|
|
142
|
+
} }, viewQuery: function ProgressbarComponent_Query(rf, ctx) { if (rf & 1) {
|
|
143
|
+
i0.ɵɵviewQuery(_c2, 7);
|
|
144
|
+
} if (rf & 2) {
|
|
145
|
+
let _t;
|
|
146
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotChildren = _t.first);
|
|
113
147
|
} }, hostVars: 2, hostBindings: function ProgressbarComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
114
|
-
i0.ɵɵclassMap(ctx.state
|
|
115
|
-
} }, inputs: { ariaLabel: [0, "auAriaLabel", "ariaLabel"], min: [2, "auMin", "min", auNumberAttribute], max: [2, "auMax", "max", auNumberAttribute], value: [2, "auValue", "value", auNumberAttribute], className: [0, "auClassName", "className"], children: [0, "auChildren", "children"], structure: [0, "auStructure", "structure"], height: [0, "auHeight", "height"], animated: [2, "auAnimated", "animated", auBooleanAttribute], striped: [2, "auStriped", "striped", auBooleanAttribute], ariaValueTextFn: [0, "auAriaValueTextFn", "ariaValueTextFn"], type: [0, "auType", "type"] }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs:
|
|
148
|
+
i0.ɵɵclassMap(ctx.state.className());
|
|
149
|
+
} }, inputs: { ariaLabel: [0, "auAriaLabel", "ariaLabel"], min: [2, "auMin", "min", auNumberAttribute], max: [2, "auMax", "max", auNumberAttribute], value: [2, "auValue", "value", auNumberAttribute], className: [0, "auClassName", "className"], children: [0, "auChildren", "children"], structure: [0, "auStructure", "structure"], height: [0, "auHeight", "height"], animated: [2, "auAnimated", "animated", auBooleanAttribute], striped: [2, "auStriped", "striped", auBooleanAttribute], ariaValueTextFn: [0, "auAriaValueTextFn", "ariaValueTextFn"], type: [0, "auType", "type"] }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c3, ngContentSelectors: _c4, decls: 3, vars: 6, consts: [["content", ""], [3, "auSlot", "auSlotProps"]], template: function ProgressbarComponent_Template(rf, ctx) { if (rf & 1) {
|
|
116
150
|
i0.ɵɵprojectionDef();
|
|
117
|
-
i0.ɵɵtemplate(0, ProgressbarComponent_ng_template_0_Template, 1, 0, "ng-template", 0)(
|
|
151
|
+
i0.ɵɵtemplate(0, ProgressbarComponent_ng_template_0_Template, 1, 0, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor)(2, ProgressbarComponent_ng_template_2_Template, 0, 0, "ng-template", 1);
|
|
118
152
|
} if (rf & 2) {
|
|
119
|
-
i0.ɵɵ
|
|
120
|
-
i0.ɵɵ
|
|
121
|
-
|
|
122
|
-
} }, dependencies: [SlotDirective, ContentAsSlotDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
153
|
+
i0.ɵɵadvance(2);
|
|
154
|
+
i0.ɵɵproperty("auSlot", ctx.state.structure())("auSlotProps", i0.ɵɵpureFunction3(2, _c1, ctx.state, ctx.api, ctx.directives));
|
|
155
|
+
} }, dependencies: [SlotDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
123
156
|
}
|
|
124
157
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ProgressbarComponent, [{
|
|
125
158
|
type: Component,
|
|
126
159
|
args: [{
|
|
127
160
|
selector: '[auProgressbar]',
|
|
128
161
|
standalone: true,
|
|
129
|
-
imports: [SlotDirective
|
|
162
|
+
imports: [SlotDirective],
|
|
130
163
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
131
164
|
host: {
|
|
132
|
-
'[class]': 'state()
|
|
165
|
+
'[class]': 'state.className()',
|
|
133
166
|
},
|
|
134
167
|
template: `
|
|
135
|
-
<ng-template
|
|
136
|
-
<ng-template [auSlot]="state()
|
|
168
|
+
<ng-template #content><ng-content></ng-content></ng-template>
|
|
169
|
+
<ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}"></ng-template>
|
|
137
170
|
`,
|
|
138
171
|
}]
|
|
139
|
-
}],
|
|
172
|
+
}], () => [], { ariaLabel: [{
|
|
140
173
|
type: Input,
|
|
141
174
|
args: ['auAriaLabel']
|
|
142
175
|
}], min: [{
|
|
@@ -154,6 +187,9 @@ export class ProgressbarComponent extends BaseWidgetDirective {
|
|
|
154
187
|
}], children: [{
|
|
155
188
|
type: Input,
|
|
156
189
|
args: ['auChildren']
|
|
190
|
+
}], slotDefaultFromContent: [{
|
|
191
|
+
type: ContentChild,
|
|
192
|
+
args: [ProgressbarBodyDirective, { static: false }]
|
|
157
193
|
}], structure: [{
|
|
158
194
|
type: Input,
|
|
159
195
|
args: ['auStructure']
|
|
@@ -175,6 +211,9 @@ export class ProgressbarComponent extends BaseWidgetDirective {
|
|
|
175
211
|
}], type: [{
|
|
176
212
|
type: Input,
|
|
177
213
|
args: ['auType']
|
|
214
|
+
}], slotChildren: [{
|
|
215
|
+
type: ViewChild,
|
|
216
|
+
args: ['content', { static: true }]
|
|
178
217
|
}] }); })();
|
|
179
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ProgressbarComponent, { className: "ProgressbarComponent", filePath: "components/progressbar/progressbar.component.ts", lineNumber:
|
|
180
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progressbar.component.js","sourceRoot":"","sources":["../../../../src/components/progressbar/progressbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tContentAsSlotDirective,\n\tSlotDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport type {SlotContent} from '@agnos-ui/angular-headless';\nimport {type WritableSignal, writable} from '@amadeus-it-group/tansu';\nimport {NgClass} from '@angular/common';\nimport type {AfterContentChecked} from '@angular/core';\nimport {ChangeDetectionStrategy, Component, ContentChild, Directive, Input, TemplateRef, ViewChild, inject} from '@angular/core';\nimport type {ProgressbarContext, ProgressbarProps, ProgressbarWidget} from './progressbar.gen';\nimport {createProgressbar} from './progressbar.gen';\n\nimport {callWidgetFactory} from '../../config';\nimport type {BSContextualClass} from '@agnos-ui/core-bootstrap/types';\n\n@Directive({selector: 'ng-template[auProgressbarStructure]', standalone: true})\nexport class ProgressbarStructureDirective {\n\tpublic templateRef = inject(TemplateRef<ProgressbarContext>);\n\tstatic ngTemplateContextGuard(_dir: ProgressbarStructureDirective, context: unknown): context is ProgressbarContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [NgClass, SlotDirective, ProgressbarStructureDirective],\n\ttemplate: `\n\t\t<ng-template auProgressbarStructure #structure let-state=\"state\" let-widget=\"widget\">\n\t\t\t<div class=\"progress\" [style.height]=\"state.height\">\n\t\t\t\t<div\n\t\t\t\t\tclass=\"progress-bar\"\n\t\t\t\t\t[class.progress-bar-striped]=\"state.striped\"\n\t\t\t\t\t[class.progress-bar-animated]=\"state.animated\"\n\t\t\t\t\t[ngClass]=\"state.type ? 'text-bg-' + state.type : undefined\"\n\t\t\t\t\t[style.width.%]=\"state.percentage\"\n\t\t\t\t>\n\t\t\t\t\t<ng-template [auSlot]=\"state.children\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</ng-template>\n\t`,\n})\nexport class ProgressbarDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<ProgressbarContext>;\n}\n\nexport const progressbarDefaultSlotStructure = new ComponentTemplate(ProgressbarDefaultSlotsComponent, 'structure');\n\nexport type PartialProgressbarProps = Partial<ProgressbarProps>;\nconst defaultConfig: PartialProgressbarProps = {\n\tstructure: progressbarDefaultSlotStructure,\n};\n\n@Component({\n\tselector: '[auProgressbar]',\n\tstandalone: true,\n\timports: [SlotDirective, ContentAsSlotDirective],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\thost: {\n\t\t'[class]': 'state().className',\n\t},\n\ttemplate: `\n\t\t<ng-template [auContentAsSlot]=\"defaultSlots\"><ng-content></ng-content></ng-template>\n\t\t<ng-template [auSlot]=\"state().structure\" [auSlotProps]=\"{state: state(), widget}\"></ng-template>\n\t`,\n})\nexport class ProgressbarComponent extends BaseWidgetDirective<ProgressbarWidget> implements AfterContentChecked {\n\treadonly defaultSlots: WritableSignal<PartialProgressbarProps> = writable(defaultConfig);\n\n\t/**\n\t * The aria label.\n\t *\n\t * @defaultValue `'Progressbar'`\n\t */\n\t@Input('auAriaLabel') ariaLabel: string | undefined;\n\n\t/**\n\t * The minimum value.\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auMin', transform: auNumberAttribute}) min: number | undefined;\n\n\t/**\n\t * The maximum value.\n\t *\n\t * @defaultValue `100`\n\t */\n\t@Input({alias: 'auMax', transform: auNumberAttribute}) max: number | undefined;\n\n\t/**\n\t * The current value.\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auValue', transform: auNumberAttribute}) value: number | undefined;\n\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t/**\n\t * Label of the progress.\n\t */\n\t@Input('auChildren') children: SlotContent<ProgressbarContext>;\n\n\t/**\n\t * Global template for the Progressbar.\n\t */\n\t@Input('auStructure') structure: SlotContent<ProgressbarContext>;\n\t@ContentChild(ProgressbarStructureDirective, {static: false}) slotStructureFromContent: ProgressbarStructureDirective | undefined;\n\n\t/**\n\t * Height of the progressbar, can be any valid css height value.\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auHeight') height: string | undefined;\n\n\t/**\n\t * If `true`, animates a striped progressbar.\n\t * Takes effect only for browsers supporting CSS3 animations, and if `striped` is `true`.\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auAnimated', transform: auBooleanAttribute}) animated: boolean | undefined;\n\n\t/**\n\t * If `true`, shows a striped progressbar.\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auStriped', transform: auBooleanAttribute}) striped: boolean | undefined;\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute.\n\t * @param value - current value\n\t * @param minimum - minimum value\n\t * @param maximum - maximum value\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => undefined\n\t * ```\n\t */\n\t@Input('auAriaValueTextFn') ariaValueTextFn: ((value: number, minimum: number, maximum: number) => string | undefined) | undefined;\n\n\t/**\n\t * Type of the progressbar, following bootstrap types.\n\t */\n\t@Input('auType') type: BSContextualClass | undefined;\n\n\treadonly _widget = callWidgetFactory({\n\t\tfactory: createProgressbar,\n\t\twidgetName: 'progressbar',\n\t\tdefaultConfig: this.defaultSlots,\n\t\tafterInit: () => {\n\t\t\tuseDirectiveForHost(this._widget.directives.ariaDirective);\n\t\t},\n\t});\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tchildren: undefined,\n\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t});\n\t}\n}\n"]}
|
|
218
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ProgressbarComponent, { className: "ProgressbarComponent", filePath: "components/progressbar/progressbar.component.ts", lineNumber: 91 }); })();
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progressbar.component.js","sourceRoot":"","sources":["../../../../src/components/progressbar/progressbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport type {SlotContent} from '@agnos-ui/angular-headless';\nimport {NgClass} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, ContentChild, Directive, Input, TemplateRef, ViewChild, inject} from '@angular/core';\nimport type {ProgressbarContext, ProgressbarWidget} from './progressbar.gen';\nimport {createProgressbar} from './progressbar.gen';\n\nimport {callWidgetFactory} from '../../config';\nimport type {BSContextualClass} from '@agnos-ui/core-bootstrap/types';\n\n/**\n * Directive that provides a template reference for the progress bar context.\n * This directive provides a template reference for the {@link ProgressbarContext}.\n */\n@Directive({selector: 'ng-template[auProgressbarBody]', standalone: true})\nexport class ProgressbarBodyDirective {\n\tpublic templateRef = inject(TemplateRef<ProgressbarContext>);\n\tstatic ngTemplateContextGuard(_dir: ProgressbarStructureDirective, context: unknown): context is ProgressbarContext {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to define the structure of a progress bar.\n *\n * This directive provides a template reference for the {@link ProgressbarContext}.\n */\n@Directive({selector: 'ng-template[auProgressbarStructure]', standalone: true})\nexport class ProgressbarStructureDirective {\n\tpublic templateRef = inject(TemplateRef<ProgressbarContext>);\n\tstatic ngTemplateContextGuard(_dir: ProgressbarStructureDirective, context: unknown): context is ProgressbarContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [NgClass, SlotDirective, ProgressbarStructureDirective],\n\ttemplate: `\n\t\t<ng-template auProgressbarStructure #structure let-state=\"state\" let-api=\"api\" let-directives=\"directives\">\n\t\t\t<div class=\"progress\" [style.height]=\"state.height()\">\n\t\t\t\t<div\n\t\t\t\t\tclass=\"progress-bar\"\n\t\t\t\t\t[class.progress-bar-striped]=\"state.striped()\"\n\t\t\t\t\t[class.progress-bar-animated]=\"state.animated()\"\n\t\t\t\t\t[ngClass]=\"state.type() ? 'text-bg-' + state.type() : undefined\"\n\t\t\t\t\t[style.width.%]=\"state.percentage()\"\n\t\t\t\t>\n\t\t\t\t\t<ng-template [auSlot]=\"state.children()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</ng-template>\n\t`,\n})\nclass ProgressbarDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure!: TemplateRef<ProgressbarContext>;\n}\n\n/**\n * Represents the default slot structure for the progress bar component.\n */\nexport const progressbarDefaultSlotStructure: SlotContent<ProgressbarContext> = new ComponentTemplate(ProgressbarDefaultSlotsComponent, 'structure');\n\n/**\n * ProgressbarComponent is a UI component that extends the BaseWidgetDirective\n * to create a customizable progress bar widget. It provides various inputs\n * to configure the appearance and behavior of the progress bar.\n *\n */\n@Component({\n\tselector: '[auProgressbar]',\n\tstandalone: true,\n\timports: [SlotDirective],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\thost: {\n\t\t'[class]': 'state.className()',\n\t},\n\ttemplate: `\n\t\t<ng-template #content><ng-content></ng-content></ng-template>\n\t\t<ng-template [auSlot]=\"state.structure()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t`,\n})\nexport class ProgressbarComponent extends BaseWidgetDirective<ProgressbarWidget> {\n\t/**\n\t * The aria label.\n\t *\n\t * @defaultValue `'Progressbar'`\n\t */\n\t@Input('auAriaLabel') ariaLabel: string | undefined;\n\n\t/**\n\t * The minimum value.\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auMin', transform: auNumberAttribute}) min: number | undefined;\n\n\t/**\n\t * The maximum value.\n\t *\n\t * @defaultValue `100`\n\t */\n\t@Input({alias: 'auMax', transform: auNumberAttribute}) max: number | undefined;\n\n\t/**\n\t * The current value.\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auValue', transform: auNumberAttribute}) value: number | undefined;\n\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t/**\n\t * Label of the progress.\n\t */\n\t@Input('auChildren') children: SlotContent<ProgressbarContext>;\n\t@ContentChild(ProgressbarBodyDirective, {static: false})\n\tslotDefaultFromContent: ProgressbarBodyDirective | undefined;\n\n\t/**\n\t * Global template for the Progressbar.\n\t */\n\t@Input('auStructure') structure: SlotContent<ProgressbarContext>;\n\t@ContentChild(ProgressbarStructureDirective, {static: false}) slotStructureFromContent: ProgressbarStructureDirective | undefined;\n\n\t/**\n\t * Height of the progressbar, can be any valid css height value.\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auHeight') height: string | undefined;\n\n\t/**\n\t * If `true`, animates a striped progressbar.\n\t * Takes effect only for browsers supporting CSS3 animations, and if `striped` is `true`.\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auAnimated', transform: auBooleanAttribute}) animated: boolean | undefined;\n\n\t/**\n\t * If `true`, shows a striped progressbar.\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auStriped', transform: auBooleanAttribute}) striped: boolean | undefined;\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute.\n\t * @param value - current value\n\t * @param minimum - minimum value\n\t * @param maximum - maximum value\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => undefined\n\t * ```\n\t */\n\t@Input('auAriaValueTextFn') ariaValueTextFn: ((value: number, minimum: number, maximum: number) => string | undefined) | undefined;\n\n\t/**\n\t * Type of the progressbar, following bootstrap types.\n\t */\n\t@Input('auType') type: BSContextualClass | 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: createProgressbar,\n\t\t\t\twidgetName: 'progressbar',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\tstructure: progressbarDefaultSlotStructure,\n\t\t\t\t},\n\t\t\t\tafterInit: (widget) => useDirectiveForHost(widget.directives.ariaDirective),\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\t\t\tchildren: this.slotDefaultFromContent?.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_getProgressbarDefaultConfig as getProgressbarDefaultConfig };
|
|
|
12
12
|
*/
|
|
13
13
|
const export_createProgressbar = createProgressbar;
|
|
14
14
|
export { export_createProgressbar as createProgressbar };
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3NiYXIuZ2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvcHJvZ3Jlc3NiYXIvcHJvZ3Jlc3NiYXIuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQywyQkFBMkIsRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGlEQUFpRCxDQUFDO0FBTS9HOzs7R0FHRztBQUNILE1BQU0sa0NBQWtDLEdBQTJCLDJCQUFrQyxDQUFDO0FBQ3RHLE9BQU8sRUFBQyxrQ0FBa0MsSUFBSSwyQkFBMkIsRUFBQyxDQUFDO0FBa04zRTs7OztHQUlHO0FBRUgsTUFBTSx3QkFBd0IsR0FBcUMsaUJBQXdCLENBQUM7QUFDNUYsT0FBTyxFQUFDLHdCQUF3QixJQUFJLGlCQUFpQixFQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge2dldFByb2dyZXNzYmFyRGVmYXVsdENvbmZpZywgY3JlYXRlUHJvZ3Jlc3NiYXJ9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL3Byb2dyZXNzYmFyJztcbmltcG9ydCB0eXBlIHtXaWRnZXRTbG90Q29udGV4dCwgU2xvdENvbnRlbnQsIFdpZGdldCwgV2lkZ2V0RmFjdG9yeSwgRGlyZWN0aXZlfSBmcm9tICdAYWdub3MtdWkvYW5ndWxhci1oZWFkbGVzcyc7XG5pbXBvcnQgdHlwZSB7QlNDb250ZXh0dWFsQ2xhc3N9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC90eXBlcyc7XG5cblxuXG4vKipcbiAqIFJldHJpZXZlIGEgc2hhbGxvdyBjb3B5IG9mIHRoZSBkZWZhdWx0IFByb2dyZXNzYmFyIGNvbmZpZ1xuICogQHJldHVybnMgdGhlIGRlZmF1bHQgUHJvZ3Jlc3NiYXIgY29uZmlnXG4gKi9cbmNvbnN0IGV4cG9ydF9nZXRQcm9ncmVzc2JhckRlZmF1bHRDb25maWc6ICgpID0+IFByb2dyZXNzYmFyUHJvcHMgPSBnZXRQcm9ncmVzc2JhckRlZmF1bHRDb25maWcgYXMgYW55O1xuZXhwb3J0IHtleHBvcnRfZ2V0UHJvZ3Jlc3NiYXJEZWZhdWx0Q29uZmlnIGFzIGdldFByb2dyZXNzYmFyRGVmYXVsdENvbmZpZ307XG5cblxuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIGNvbnRleHQgZm9yIGEgUHJvZ3Jlc3NiYXIgd2lkZ2V0LlxuICogVGhpcyBpbnRlcmZhY2UgaXMgdXNlZCB0byBkZWZpbmUgdGhlIGNvbnRleHQgb2JqZWN0IHRoYXQgaXMgcGFzc2VkIHRvIHRoZSBQcm9ncmVzc2JhciB3aWRnZXQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUHJvZ3Jlc3NiYXJDb250ZXh0IGV4dGVuZHMgV2lkZ2V0U2xvdENvbnRleHQ8UHJvZ3Jlc3NiYXJXaWRnZXQ+IHt9XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgc3RhdGUgb2YgYSBQcm9ncmVzc2JhciBjb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUHJvZ3Jlc3NiYXJTdGF0ZSB7XG5cdFxuXHQvKipcblx0ICogUGVyY2VudGFnZSBvZiBjb21wbGV0aW9uLlxuXHQgKi9cblx0cGVyY2VudGFnZTogbnVtYmVyO1xuXHRcblx0LyoqXG5cdCAqIGB0cnVlYCBpZiB0aGUgdmFsdWUgaXMgYWJvdmUgaXRzIG1pbmltdW0gdmFsdWUuXG5cdCAqL1xuXHRzdGFydGVkOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIGB0cnVlYCBpZiB0aGUgdmFsdWUgaGFzIHJlYWNoZWQgaXRzIG1heGltdW0gdmFsdWUuXG5cdCAqL1xuXHRmaW5pc2hlZDogYm9vbGVhbjtcblx0XG5cdC8qKlxuXHQgKiBUaGUgYXJpYSB2YWx1ZSB0ZXh0LlxuXHQgKi9cblx0YXJpYVZhbHVlVGV4dDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXHRcblx0LyoqXG5cdCAqIFRoZSBtaW5pbXVtIHZhbHVlLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAwYFxuXHQgKi9cblx0bWluOiBudW1iZXI7XG5cdFxuXHQvKipcblx0ICogVGhlIG1heGltdW0gdmFsdWUuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYDEwMGBcblx0ICovXG5cdG1heDogbnVtYmVyO1xuXHRcblx0LyoqXG5cdCAqIFRoZSBjdXJyZW50IHZhbHVlLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAwYFxuXHQgKi9cblx0dmFsdWU6IG51bWJlcjtcblx0XG5cdC8qKlxuXHQgKiBUaGUgYXJpYSBsYWJlbC5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJ1Byb2dyZXNzYmFyJ2Bcblx0ICovXG5cdGFyaWFMYWJlbDogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIENTUyBjbGFzc2VzIHRvIGJlIGFwcGxpZWQgb24gdGhlIHdpZGdldCBtYWluIGNvbnRhaW5lclxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnJ2Bcblx0ICovXG5cdGNsYXNzTmFtZTogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIEdsb2JhbCB0ZW1wbGF0ZSBmb3IgdGhlIFByb2dyZXNzYmFyLlxuXHQgKi9cblx0c3RydWN0dXJlOiBTbG90Q29udGVudDxQcm9ncmVzc2JhckNvbnRleHQ+O1xuXHRcblx0LyoqXG5cdCAqIExhYmVsIG9mIHRoZSBwcm9ncmVzcy5cblx0ICovXG5cdGNoaWxkcmVuOiBTbG90Q29udGVudDxQcm9ncmVzc2JhckNvbnRleHQ+O1xuXHRcblx0LyoqXG5cdCAqIEhlaWdodCBvZiB0aGUgcHJvZ3Jlc3NiYXIsIGNhbiBiZSBhbnkgdmFsaWQgY3NzIGhlaWdodCB2YWx1ZS5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJydgXG5cdCAqL1xuXHRoZWlnaHQ6IHN0cmluZztcblx0XG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAsIHNob3dzIGEgc3RyaXBlZCBwcm9ncmVzc2Jhci5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgZmFsc2VgXG5cdCAqL1xuXHRzdHJpcGVkOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCwgYW5pbWF0ZXMgYSBzdHJpcGVkIHByb2dyZXNzYmFyLlxuXHQgKiBUYWtlcyBlZmZlY3Qgb25seSBmb3IgYnJvd3NlcnMgc3VwcG9ydGluZyBDU1MzIGFuaW1hdGlvbnMsIGFuZCBpZiBgc3RyaXBlZGAgaXMgYHRydWVgLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGBmYWxzZWBcblx0ICovXG5cdGFuaW1hdGVkOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIFR5cGUgb2YgdGhlIHByb2dyZXNzYmFyLCBmb2xsb3dpbmcgYm9vdHN0cmFwIHR5cGVzLlxuXHQgKi9cblx0dHlwZTogQlNDb250ZXh0dWFsQ2xhc3MgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHJlcHJlc2VudGluZyB0aGUgcHJvcGVydGllcyBmb3IgdGhlIFByb2dyZXNzYmFyIGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQcm9ncmVzc2JhclByb3BzIHtcblx0XG5cdC8qKlxuXHQgKiBSZXR1cm4gdGhlIHZhbHVlIGZvciB0aGUgJ2FyaWEtdmFsdWV0ZXh0JyBhdHRyaWJ1dGUuXG5cdCAqIEBwYXJhbSB2YWx1ZSAtIGN1cnJlbnQgdmFsdWVcblx0ICogQHBhcmFtIG1pbmltdW0gLSBtaW5pbXVtIHZhbHVlXG5cdCAqIEBwYXJhbSBtYXhpbXVtIC0gbWF4aW11bSB2YWx1ZVxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlXG5cdCAqIGBgYHRzXG5cdCAqICgpID0+IHVuZGVmaW5lZFxuXHQgKiBgYGBcblx0ICovXG5cdGFyaWFWYWx1ZVRleHRGbjogKHZhbHVlOiBudW1iZXIsIG1pbmltdW06IG51bWJlciwgbWF4aW11bTogbnVtYmVyKSA9PiBzdHJpbmcgfCB1bmRlZmluZWQ7XG5cdFxuXHQvKipcblx0ICogVGhlIG1pbmltdW0gdmFsdWUuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYDBgXG5cdCAqL1xuXHRtaW46IG51bWJlcjtcblx0XG5cdC8qKlxuXHQgKiBUaGUgbWF4aW11bSB2YWx1ZS5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgMTAwYFxuXHQgKi9cblx0bWF4OiBudW1iZXI7XG5cdFxuXHQvKipcblx0ICogVGhlIGN1cnJlbnQgdmFsdWUuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYDBgXG5cdCAqL1xuXHR2YWx1ZTogbnVtYmVyO1xuXHRcblx0LyoqXG5cdCAqIFRoZSBhcmlhIGxhYmVsLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnUHJvZ3Jlc3NiYXInYFxuXHQgKi9cblx0YXJpYUxhYmVsOiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogQ1NTIGNsYXNzZXMgdG8gYmUgYXBwbGllZCBvbiB0aGUgd2lkZ2V0IG1haW4gY29udGFpbmVyXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYCcnYFxuXHQgKi9cblx0Y2xhc3NOYW1lOiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogR2xvYmFsIHRlbXBsYXRlIGZvciB0aGUgUHJvZ3Jlc3NiYXIuXG5cdCAqL1xuXHRzdHJ1Y3R1cmU6IFNsb3RDb250ZW50PFByb2dyZXNzYmFyQ29udGV4dD47XG5cdFxuXHQvKipcblx0ICogTGFiZWwgb2YgdGhlIHByb2dyZXNzLlxuXHQgKi9cblx0Y2hpbGRyZW46IFNsb3RDb250ZW50PFByb2dyZXNzYmFyQ29udGV4dD47XG5cdFxuXHQvKipcblx0ICogSGVpZ2h0IG9mIHRoZSBwcm9ncmVzc2JhciwgY2FuIGJlIGFueSB2YWxpZCBjc3MgaGVpZ2h0IHZhbHVlLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnJ2Bcblx0ICovXG5cdGhlaWdodDogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCwgc2hvd3MgYSBzdHJpcGVkIHByb2dyZXNzYmFyLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGBmYWxzZWBcblx0ICovXG5cdHN0cmlwZWQ6IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogSWYgYHRydWVgLCBhbmltYXRlcyBhIHN0cmlwZWQgcHJvZ3Jlc3NiYXIuXG5cdCAqIFRha2VzIGVmZmVjdCBvbmx5IGZvciBicm93c2VycyBzdXBwb3J0aW5nIENTUzMgYW5pbWF0aW9ucywgYW5kIGlmIGBzdHJpcGVkYCBpcyBgdHJ1ZWAuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYGZhbHNlYFxuXHQgKi9cblx0YW5pbWF0ZWQ6IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogVHlwZSBvZiB0aGUgcHJvZ3Jlc3NiYXIsIGZvbGxvd2luZyBib290c3RyYXAgdHlwZXMuXG5cdCAqL1xuXHR0eXBlOiBCU0NvbnRleHR1YWxDbGFzcyB8IHVuZGVmaW5lZDtcbn1cblxuXG5cbi8qKlxuICogUmVwcmVzZW50cyBhIFByb2dyZXNzYmFyIHdpZGdldC5cbiAqXG4gKiBUaGlzIHR5cGUgZGVmaW5lcyB0aGUgc3RydWN0dXJlIG9mIGEgUHJvZ3Jlc3NiYXIgd2lkZ2V0LCBpbmNsdWRpbmcgaXRzIHByb3BlcnRpZXMsIHN0YXRlLCBhbmQgZGlyZWN0aXZlcy5cbiAqL1xuZXhwb3J0IHR5cGUgUHJvZ3Jlc3NiYXJXaWRnZXQgPSBXaWRnZXQ8UHJvZ3Jlc3NiYXJQcm9wcywgUHJvZ3Jlc3NiYXJTdGF0ZSwgb2JqZWN0LCBQcm9ncmVzc2JhckRpcmVjdGl2ZXM+O1xuXG5cblxuLyoqXG4gKiBDcmVhdGUgYSBQcm9ncmVzc2JhciB3aXRoIGdpdmVuIGNvbmZpZyBwcm9wc1xuICogQHBhcmFtIGNvbmZpZyAtIGFuIG9wdGlvbmFsIHByb2dyZXNzYmFyIGNvbmZpZ1xuICogQHJldHVybnMgYSBQcm9ncmVzc2JhcldpZGdldFxuICovXG5cbmNvbnN0IGV4cG9ydF9jcmVhdGVQcm9ncmVzc2JhcjogV2lkZ2V0RmFjdG9yeTxQcm9ncmVzc2JhcldpZGdldD4gPSBjcmVhdGVQcm9ncmVzc2JhciBhcyBhbnk7XG5leHBvcnQge2V4cG9ydF9jcmVhdGVQcm9ncmVzc2JhciBhcyBjcmVhdGVQcm9ncmVzc2Jhcn07XG5cbi8qKlxuICogSW50ZXJmYWNlIHJlcHJlc2VudGluZyBkaXJlY3RpdmVzIGZvciBhIHByb2dyZXNzIGJhciBjb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUHJvZ3Jlc3NiYXJEaXJlY3RpdmVzIHtcblx0XG5cdC8qKlxuXHQgKiBBIGRpcmVjdGl2ZSB0byBiZSBhcHBsaWVkIHRvIHRoZSBtYWluIGNvbnRhaW5lciB0aGF0IGhhbmRsZXMgYXJpYSBhdHRyaWJ1dGVzLlxuXHQgKi9cblx0YXJpYURpcmVjdGl2ZTogRGlyZWN0aXZlO1xufVxuXG4iXX0=
|