@agnos-ui/angular-bootstrap 0.6.0 → 0.7.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/components/accordion/accordion.component.d.ts +39 -46
- package/components/alert/alert.component.d.ts +18 -22
- package/components/collapse/collapse.component.d.ts +11 -15
- package/components/modal/modal.component.d.ts +30 -36
- package/components/pagination/pagination.component.d.ts +38 -44
- package/components/progressbar/progressbar.component.d.ts +16 -21
- package/components/rating/rating.component.d.ts +17 -23
- package/components/select/select.component.d.ts +24 -27
- package/components/slider/slider.component.d.ts +22 -31
- package/components/slider/slider.gen.d.ts +5 -1
- package/components/toast/toast.component.d.ts +21 -27
- package/components/tree/tree.component.d.ts +16 -16
- package/components/tree/tree.gen.d.ts +1 -1
- package/fesm2022/agnos-ui-angular-bootstrap.mjs +1452 -1057
- package/fesm2022/agnos-ui-angular-bootstrap.mjs.map +1 -1
- package/package.json +6 -6
- package/esm2022/agnos-ui-angular-bootstrap.mjs +0 -5
- package/esm2022/agnos-ui-angular.module.mjs +0 -174
- package/esm2022/components/accordion/accordion.component.mjs +0 -586
- package/esm2022/components/accordion/accordion.gen.mjs +0 -33
- package/esm2022/components/accordion/index.mjs +0 -3
- package/esm2022/components/alert/alert.component.mjs +0 -270
- package/esm2022/components/alert/alert.gen.mjs +0 -15
- package/esm2022/components/alert/index.mjs +0 -3
- package/esm2022/components/collapse/collapse.component.mjs +0 -89
- package/esm2022/components/collapse/collapse.gen.mjs +0 -15
- package/esm2022/components/collapse/index.mjs +0 -3
- package/esm2022/components/modal/index.mjs +0 -4
- package/esm2022/components/modal/modal.component.mjs +0 -460
- package/esm2022/components/modal/modal.gen.mjs +0 -27
- package/esm2022/components/modal/modal.service.mjs +0 -57
- package/esm2022/components/pagination/index.mjs +0 -3
- package/esm2022/components/pagination/pagination.component.mjs +0 -600
- package/esm2022/components/pagination/pagination.gen.mjs +0 -15
- package/esm2022/components/progressbar/index.mjs +0 -3
- package/esm2022/components/progressbar/progressbar.component.mjs +0 -219
- package/esm2022/components/progressbar/progressbar.gen.mjs +0 -15
- package/esm2022/components/rating/index.mjs +0 -3
- package/esm2022/components/rating/rating.component.mjs +0 -205
- package/esm2022/components/rating/rating.gen.mjs +0 -15
- package/esm2022/components/select/index.mjs +0 -3
- package/esm2022/components/select/select.component.mjs +0 -282
- package/esm2022/components/select/select.gen.mjs +0 -15
- package/esm2022/components/slider/index.mjs +0 -3
- package/esm2022/components/slider/slider.component.mjs +0 -463
- package/esm2022/components/slider/slider.gen.mjs +0 -15
- package/esm2022/components/toast/index.mjs +0 -3
- package/esm2022/components/toast/toast.component.mjs +0 -324
- package/esm2022/components/toast/toast.gen.mjs +0 -15
- package/esm2022/components/tree/index.mjs +0 -3
- package/esm2022/components/tree/tree.component.mjs +0 -450
- package/esm2022/components/tree/tree.gen.mjs +0 -15
- package/esm2022/config.gen.mjs +0 -2
- package/esm2022/config.mjs +0 -21
- package/esm2022/index.mjs +0 -30
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { getPaginationDefaultConfig, createPagination } from '@agnos-ui/core-bootstrap/components/pagination';
|
|
2
|
-
/**
|
|
3
|
-
* Retrieve a shallow copy of the default Pagination config
|
|
4
|
-
* @returns the default Pagination config
|
|
5
|
-
*/
|
|
6
|
-
const export_getPaginationDefaultConfig = getPaginationDefaultConfig;
|
|
7
|
-
export { export_getPaginationDefaultConfig as getPaginationDefaultConfig };
|
|
8
|
-
/**
|
|
9
|
-
* Create a PaginationWidget with given config props
|
|
10
|
-
* @param config - an optional alert config
|
|
11
|
-
* @returns a PaginationWidget
|
|
12
|
-
*/
|
|
13
|
-
const export_createPagination = createPagination;
|
|
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;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,3 +0,0 @@
|
|
|
1
|
-
export * from './progressbar.component';
|
|
2
|
-
export * from './progressbar.gen';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9wcm9ncmVzc2Jhci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsbUJBQW1CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3Byb2dyZXNzYmFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3Byb2dyZXNzYmFyLmdlbic7XG4iXX0=
|
|
@@ -1,219 +0,0 @@
|
|
|
1
|
-
import { BaseWidgetDirective, ComponentTemplate, SlotDirective, auBooleanAttribute, auNumberAttribute, useDirectiveForHost, } from '@agnos-ui/angular-headless';
|
|
2
|
-
import { NgClass } from '@angular/common';
|
|
3
|
-
import { ChangeDetectionStrategy, Component, ContentChild, Directive, Input, TemplateRef, ViewChild, inject } from '@angular/core';
|
|
4
|
-
import { createProgressbar } from './progressbar.gen';
|
|
5
|
-
import { callWidgetFactory } from '../../config';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
const _c0 = ["structure"];
|
|
8
|
-
const _c1 = (a0, a1, a2) => ({ state: a0, api: a1, directives: a2 });
|
|
9
|
-
function ProgressbarDefaultSlotsComponent_ng_template_0_ng_template_2_Template(rf, ctx) { }
|
|
10
|
-
function ProgressbarDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
|
|
11
|
-
i0.ɵɵelementStart(0, "div", 2)(1, "div", 3);
|
|
12
|
-
i0.ɵɵtemplate(2, ProgressbarDefaultSlotsComponent_ng_template_0_ng_template_2_Template, 0, 0, "ng-template", 4);
|
|
13
|
-
i0.ɵɵelementEnd()();
|
|
14
|
-
} if (rf & 2) {
|
|
15
|
-
const state_r1 = ctx.state;
|
|
16
|
-
const api_r2 = ctx.api;
|
|
17
|
-
const directives_r3 = ctx.directives;
|
|
18
|
-
i0.ɵɵstyleProp("height", state_r1.height());
|
|
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);
|
|
23
|
-
i0.ɵɵadvance();
|
|
24
|
-
i0.ɵɵproperty("auSlot", state_r1.children())("auSlotProps", i0.ɵɵpureFunction3(11, _c1, state_r1, api_r2, directives_r3));
|
|
25
|
-
} }
|
|
26
|
-
const _c2 = ["content"];
|
|
27
|
-
const _c3 = ["auProgressbar", ""];
|
|
28
|
-
const _c4 = ["*"];
|
|
29
|
-
function ProgressbarComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
|
|
30
|
-
i0.ɵɵprojection(0);
|
|
31
|
-
} }
|
|
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
|
-
*/
|
|
56
|
-
export class ProgressbarStructureDirective {
|
|
57
|
-
constructor() {
|
|
58
|
-
this.templateRef = inject((TemplateRef));
|
|
59
|
-
}
|
|
60
|
-
static ngTemplateContextGuard(_dir, context) {
|
|
61
|
-
return true;
|
|
62
|
-
}
|
|
63
|
-
static { this.ɵfac = function ProgressbarStructureDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ProgressbarStructureDirective)(); }; }
|
|
64
|
-
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ProgressbarStructureDirective, selectors: [["ng-template", "auProgressbarStructure", ""]], standalone: true }); }
|
|
65
|
-
}
|
|
66
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ProgressbarStructureDirective, [{
|
|
67
|
-
type: Directive,
|
|
68
|
-
args: [{ selector: 'ng-template[auProgressbarStructure]', standalone: true }]
|
|
69
|
-
}], null, null); })();
|
|
70
|
-
class ProgressbarDefaultSlotsComponent {
|
|
71
|
-
static { this.ɵfac = function ProgressbarDefaultSlotsComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ProgressbarDefaultSlotsComponent)(); }; }
|
|
72
|
-
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ProgressbarDefaultSlotsComponent, selectors: [["ng-component"]], viewQuery: function ProgressbarDefaultSlotsComponent_Query(rf, ctx) { if (rf & 1) {
|
|
73
|
-
i0.ɵɵviewQuery(_c0, 7);
|
|
74
|
-
} if (rf & 2) {
|
|
75
|
-
let _t;
|
|
76
|
-
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.structure = _t.first);
|
|
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) {
|
|
78
|
-
i0.ɵɵtemplate(0, ProgressbarDefaultSlotsComponent_ng_template_0_Template, 3, 15, "ng-template", 1, 0, i0.ɵɵtemplateRefExtractor);
|
|
79
|
-
} }, dependencies: [NgClass, SlotDirective, ProgressbarStructureDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
80
|
-
}
|
|
81
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ProgressbarDefaultSlotsComponent, [{
|
|
82
|
-
type: Component,
|
|
83
|
-
args: [{
|
|
84
|
-
standalone: true,
|
|
85
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
86
|
-
imports: [NgClass, SlotDirective, ProgressbarStructureDirective],
|
|
87
|
-
template: `
|
|
88
|
-
<ng-template auProgressbarStructure #structure let-state="state" let-api="api" let-directives="directives">
|
|
89
|
-
<div class="progress" [style.height]="state.height()">
|
|
90
|
-
<div
|
|
91
|
-
class="progress-bar"
|
|
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()"
|
|
96
|
-
>
|
|
97
|
-
<ng-template [auSlot]="state.children()" [auSlotProps]="{state, api, directives}" />
|
|
98
|
-
</div>
|
|
99
|
-
</div>
|
|
100
|
-
</ng-template>
|
|
101
|
-
`,
|
|
102
|
-
}]
|
|
103
|
-
}], null, { structure: [{
|
|
104
|
-
type: ViewChild,
|
|
105
|
-
args: ['structure', { static: true }]
|
|
106
|
-
}] }); })();
|
|
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
|
-
*/
|
|
111
|
-
export const progressbarDefaultSlotStructure = new ComponentTemplate(ProgressbarDefaultSlotsComponent, 'structure');
|
|
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
|
-
*/
|
|
118
|
-
export class ProgressbarComponent extends BaseWidgetDirective {
|
|
119
|
-
constructor() {
|
|
120
|
-
super(callWidgetFactory({
|
|
121
|
-
factory: createProgressbar,
|
|
122
|
-
widgetName: 'progressbar',
|
|
123
|
-
defaultConfig: {
|
|
124
|
-
structure: progressbarDefaultSlotStructure,
|
|
125
|
-
},
|
|
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
|
-
}));
|
|
133
|
-
}
|
|
134
|
-
static { this.ɵfac = function ProgressbarComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ProgressbarComponent)(); }; }
|
|
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);
|
|
137
|
-
i0.ɵɵcontentQuery(dirIndex, ProgressbarStructureDirective, 5);
|
|
138
|
-
} if (rf & 2) {
|
|
139
|
-
let _t;
|
|
140
|
-
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first);
|
|
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);
|
|
147
|
-
} }, hostVars: 2, hostBindings: function ProgressbarComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
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) {
|
|
150
|
-
i0.ɵɵprojectionDef();
|
|
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);
|
|
152
|
-
} if (rf & 2) {
|
|
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 }); }
|
|
156
|
-
}
|
|
157
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ProgressbarComponent, [{
|
|
158
|
-
type: Component,
|
|
159
|
-
args: [{
|
|
160
|
-
selector: '[auProgressbar]',
|
|
161
|
-
standalone: true,
|
|
162
|
-
imports: [SlotDirective],
|
|
163
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
164
|
-
host: {
|
|
165
|
-
'[class]': 'state.className()',
|
|
166
|
-
},
|
|
167
|
-
template: `
|
|
168
|
-
<ng-template #content><ng-content /></ng-template>
|
|
169
|
-
<ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}" />
|
|
170
|
-
`,
|
|
171
|
-
}]
|
|
172
|
-
}], () => [], { ariaLabel: [{
|
|
173
|
-
type: Input,
|
|
174
|
-
args: ['auAriaLabel']
|
|
175
|
-
}], min: [{
|
|
176
|
-
type: Input,
|
|
177
|
-
args: [{ alias: 'auMin', transform: auNumberAttribute }]
|
|
178
|
-
}], max: [{
|
|
179
|
-
type: Input,
|
|
180
|
-
args: [{ alias: 'auMax', transform: auNumberAttribute }]
|
|
181
|
-
}], value: [{
|
|
182
|
-
type: Input,
|
|
183
|
-
args: [{ alias: 'auValue', transform: auNumberAttribute }]
|
|
184
|
-
}], className: [{
|
|
185
|
-
type: Input,
|
|
186
|
-
args: ['auClassName']
|
|
187
|
-
}], children: [{
|
|
188
|
-
type: Input,
|
|
189
|
-
args: ['auChildren']
|
|
190
|
-
}], slotDefaultFromContent: [{
|
|
191
|
-
type: ContentChild,
|
|
192
|
-
args: [ProgressbarBodyDirective, { static: false }]
|
|
193
|
-
}], structure: [{
|
|
194
|
-
type: Input,
|
|
195
|
-
args: ['auStructure']
|
|
196
|
-
}], slotStructureFromContent: [{
|
|
197
|
-
type: ContentChild,
|
|
198
|
-
args: [ProgressbarStructureDirective, { static: false }]
|
|
199
|
-
}], height: [{
|
|
200
|
-
type: Input,
|
|
201
|
-
args: ['auHeight']
|
|
202
|
-
}], animated: [{
|
|
203
|
-
type: Input,
|
|
204
|
-
args: [{ alias: 'auAnimated', transform: auBooleanAttribute }]
|
|
205
|
-
}], striped: [{
|
|
206
|
-
type: Input,
|
|
207
|
-
args: [{ alias: 'auStriped', transform: auBooleanAttribute }]
|
|
208
|
-
}], ariaValueTextFn: [{
|
|
209
|
-
type: Input,
|
|
210
|
-
args: ['auAriaValueTextFn']
|
|
211
|
-
}], type: [{
|
|
212
|
-
type: Input,
|
|
213
|
-
args: ['auType']
|
|
214
|
-
}], slotChildren: [{
|
|
215
|
-
type: ViewChild,
|
|
216
|
-
args: ['content', { static: true }]
|
|
217
|
-
}] }); })();
|
|
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}\" />\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-template>\n\t\t<ng-template [auSlot]=\"state.structure()\" [auSlotProps]=\"{state, api, directives}\" />\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"]}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { getProgressbarDefaultConfig, createProgressbar } from '@agnos-ui/core-bootstrap/components/progressbar';
|
|
2
|
-
/**
|
|
3
|
-
* Retrieve a shallow copy of the default Progressbar config
|
|
4
|
-
* @returns the default Progressbar config
|
|
5
|
-
*/
|
|
6
|
-
const export_getProgressbarDefaultConfig = getProgressbarDefaultConfig;
|
|
7
|
-
export { export_getProgressbarDefaultConfig as getProgressbarDefaultConfig };
|
|
8
|
-
/**
|
|
9
|
-
* Create a Progressbar with given config props
|
|
10
|
-
* @param config - an optional progressbar config
|
|
11
|
-
* @returns a ProgressbarWidget
|
|
12
|
-
*/
|
|
13
|
-
const export_createProgressbar = createProgressbar;
|
|
14
|
-
export { export_createProgressbar as createProgressbar };
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3NiYXIuZ2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvcHJvZ3Jlc3NiYXIvcHJvZ3Jlc3NiYXIuZ2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQywyQkFBMkIsRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGlEQUFpRCxDQUFDO0FBTS9HOzs7R0FHRztBQUNILE1BQU0sa0NBQWtDLEdBQTJCLDJCQUFrQyxDQUFDO0FBQ3RHLE9BQU8sRUFBQyxrQ0FBa0MsSUFBSSwyQkFBMkIsRUFBQyxDQUFDO0FBa04zRTs7OztHQUlHO0FBRUgsTUFBTSx3QkFBd0IsR0FBcUMsaUJBQXdCLENBQUM7QUFDNUYsT0FBTyxFQUFDLHdCQUF3QixJQUFJLGlCQUFpQixFQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge2dldFByb2dyZXNzYmFyRGVmYXVsdENvbmZpZywgY3JlYXRlUHJvZ3Jlc3NiYXJ9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL3Byb2dyZXNzYmFyJztcbmltcG9ydCB0eXBlIHtXaWRnZXRTbG90Q29udGV4dCwgU2xvdENvbnRlbnQsIFdpZGdldCwgV2lkZ2V0RmFjdG9yeSwgRGlyZWN0aXZlfSBmcm9tICdAYWdub3MtdWkvYW5ndWxhci1oZWFkbGVzcyc7XG5pbXBvcnQgdHlwZSB7QlNDb250ZXh0dWFsQ2xhc3N9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC90eXBlcyc7XG5cblxuXG4vKipcbiAqIFJldHJpZXZlIGEgc2hhbGxvdyBjb3B5IG9mIHRoZSBkZWZhdWx0IFByb2dyZXNzYmFyIGNvbmZpZ1xuICogQHJldHVybnMgdGhlIGRlZmF1bHQgUHJvZ3Jlc3NiYXIgY29uZmlnXG4gKi9cbmNvbnN0IGV4cG9ydF9nZXRQcm9ncmVzc2JhckRlZmF1bHRDb25maWc6ICgpID0+IFByb2dyZXNzYmFyUHJvcHMgPSBnZXRQcm9ncmVzc2JhckRlZmF1bHRDb25maWcgYXMgYW55O1xuZXhwb3J0IHtleHBvcnRfZ2V0UHJvZ3Jlc3NiYXJEZWZhdWx0Q29uZmlnIGFzIGdldFByb2dyZXNzYmFyRGVmYXVsdENvbmZpZ307XG5cblxuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIGNvbnRleHQgZm9yIGEgUHJvZ3Jlc3NiYXIgd2lkZ2V0LlxuICogVGhpcyBpbnRlcmZhY2UgaXMgdXNlZCB0byBkZWZpbmUgdGhlIGNvbnRleHQgb2JqZWN0IHRoYXQgaXMgcGFzc2VkIHRvIHRoZSBQcm9ncmVzc2JhciB3aWRnZXQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUHJvZ3Jlc3NiYXJDb250ZXh0IGV4dGVuZHMgV2lkZ2V0U2xvdENvbnRleHQ8UHJvZ3Jlc3NiYXJXaWRnZXQ+IHt9XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgc3RhdGUgb2YgYSBQcm9ncmVzc2JhciBjb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUHJvZ3Jlc3NiYXJTdGF0ZSB7XG5cdFxuXHQvKipcblx0ICogUGVyY2VudGFnZSBvZiBjb21wbGV0aW9uLlxuXHQgKi9cblx0cGVyY2VudGFnZTogbnVtYmVyO1xuXHRcblx0LyoqXG5cdCAqIGB0cnVlYCBpZiB0aGUgdmFsdWUgaXMgYWJvdmUgaXRzIG1pbmltdW0gdmFsdWUuXG5cdCAqL1xuXHRzdGFydGVkOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIGB0cnVlYCBpZiB0aGUgdmFsdWUgaGFzIHJlYWNoZWQgaXRzIG1heGltdW0gdmFsdWUuXG5cdCAqL1xuXHRmaW5pc2hlZDogYm9vbGVhbjtcblx0XG5cdC8qKlxuXHQgKiBUaGUgYXJpYSB2YWx1ZSB0ZXh0LlxuXHQgKi9cblx0YXJpYVZhbHVlVGV4dDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXHRcblx0LyoqXG5cdCAqIFRoZSBtaW5pbXVtIHZhbHVlLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAwYFxuXHQgKi9cblx0bWluOiBudW1iZXI7XG5cdFxuXHQvKipcblx0ICogVGhlIG1heGltdW0gdmFsdWUuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYDEwMGBcblx0ICovXG5cdG1heDogbnVtYmVyO1xuXHRcblx0LyoqXG5cdCAqIFRoZSBjdXJyZW50IHZhbHVlLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAwYFxuXHQgKi9cblx0dmFsdWU6IG51bWJlcjtcblx0XG5cdC8qKlxuXHQgKiBUaGUgYXJpYSBsYWJlbC5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJ1Byb2dyZXNzYmFyJ2Bcblx0ICovXG5cdGFyaWFMYWJlbDogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIENTUyBjbGFzc2VzIHRvIGJlIGFwcGxpZWQgb24gdGhlIHdpZGdldCBtYWluIGNvbnRhaW5lclxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnJ2Bcblx0ICovXG5cdGNsYXNzTmFtZTogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIEdsb2JhbCB0ZW1wbGF0ZSBmb3IgdGhlIFByb2dyZXNzYmFyLlxuXHQgKi9cblx0c3RydWN0dXJlOiBTbG90Q29udGVudDxQcm9ncmVzc2JhckNvbnRleHQ+O1xuXHRcblx0LyoqXG5cdCAqIExhYmVsIG9mIHRoZSBwcm9ncmVzcy5cblx0ICovXG5cdGNoaWxkcmVuOiBTbG90Q29udGVudDxQcm9ncmVzc2JhckNvbnRleHQ+O1xuXHRcblx0LyoqXG5cdCAqIEhlaWdodCBvZiB0aGUgcHJvZ3Jlc3NiYXIsIGNhbiBiZSBhbnkgdmFsaWQgY3NzIGhlaWdodCB2YWx1ZS5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgJydgXG5cdCAqL1xuXHRoZWlnaHQ6IHN0cmluZztcblx0XG5cdC8qKlxuXHQgKiBJZiBgdHJ1ZWAsIHNob3dzIGEgc3RyaXBlZCBwcm9ncmVzc2Jhci5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgZmFsc2VgXG5cdCAqL1xuXHRzdHJpcGVkOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCwgYW5pbWF0ZXMgYSBzdHJpcGVkIHByb2dyZXNzYmFyLlxuXHQgKiBUYWtlcyBlZmZlY3Qgb25seSBmb3IgYnJvd3NlcnMgc3VwcG9ydGluZyBDU1MzIGFuaW1hdGlvbnMsIGFuZCBpZiBgc3RyaXBlZGAgaXMgYHRydWVgLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGBmYWxzZWBcblx0ICovXG5cdGFuaW1hdGVkOiBib29sZWFuO1xuXHRcblx0LyoqXG5cdCAqIFR5cGUgb2YgdGhlIHByb2dyZXNzYmFyLCBmb2xsb3dpbmcgYm9vdHN0cmFwIHR5cGVzLlxuXHQgKi9cblx0dHlwZTogQlNDb250ZXh0dWFsQ2xhc3MgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHJlcHJlc2VudGluZyB0aGUgcHJvcGVydGllcyBmb3IgdGhlIFByb2dyZXNzYmFyIGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQcm9ncmVzc2JhclByb3BzIHtcblx0XG5cdC8qKlxuXHQgKiBSZXR1cm4gdGhlIHZhbHVlIGZvciB0aGUgJ2FyaWEtdmFsdWV0ZXh0JyBhdHRyaWJ1dGUuXG5cdCAqIEBwYXJhbSB2YWx1ZSAtIGN1cnJlbnQgdmFsdWVcblx0ICogQHBhcmFtIG1pbmltdW0gLSBtaW5pbXVtIHZhbHVlXG5cdCAqIEBwYXJhbSBtYXhpbXVtIC0gbWF4aW11bSB2YWx1ZVxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlXG5cdCAqIGBgYHRzXG5cdCAqICgpID0+IHVuZGVmaW5lZFxuXHQgKiBgYGBcblx0ICovXG5cdGFyaWFWYWx1ZVRleHRGbjogKHZhbHVlOiBudW1iZXIsIG1pbmltdW06IG51bWJlciwgbWF4aW11bTogbnVtYmVyKSA9PiBzdHJpbmcgfCB1bmRlZmluZWQ7XG5cdFxuXHQvKipcblx0ICogVGhlIG1pbmltdW0gdmFsdWUuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYDBgXG5cdCAqL1xuXHRtaW46IG51bWJlcjtcblx0XG5cdC8qKlxuXHQgKiBUaGUgbWF4aW11bSB2YWx1ZS5cblx0ICpcblx0ICogQGRlZmF1bHRWYWx1ZSBgMTAwYFxuXHQgKi9cblx0bWF4OiBudW1iZXI7XG5cdFxuXHQvKipcblx0ICogVGhlIGN1cnJlbnQgdmFsdWUuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYDBgXG5cdCAqL1xuXHR2YWx1ZTogbnVtYmVyO1xuXHRcblx0LyoqXG5cdCAqIFRoZSBhcmlhIGxhYmVsLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnUHJvZ3Jlc3NiYXInYFxuXHQgKi9cblx0YXJpYUxhYmVsOiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogQ1NTIGNsYXNzZXMgdG8gYmUgYXBwbGllZCBvbiB0aGUgd2lkZ2V0IG1haW4gY29udGFpbmVyXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYCcnYFxuXHQgKi9cblx0Y2xhc3NOYW1lOiBzdHJpbmc7XG5cdFxuXHQvKipcblx0ICogR2xvYmFsIHRlbXBsYXRlIGZvciB0aGUgUHJvZ3Jlc3NiYXIuXG5cdCAqL1xuXHRzdHJ1Y3R1cmU6IFNsb3RDb250ZW50PFByb2dyZXNzYmFyQ29udGV4dD47XG5cdFxuXHQvKipcblx0ICogTGFiZWwgb2YgdGhlIHByb2dyZXNzLlxuXHQgKi9cblx0Y2hpbGRyZW46IFNsb3RDb250ZW50PFByb2dyZXNzYmFyQ29udGV4dD47XG5cdFxuXHQvKipcblx0ICogSGVpZ2h0IG9mIHRoZSBwcm9ncmVzc2JhciwgY2FuIGJlIGFueSB2YWxpZCBjc3MgaGVpZ2h0IHZhbHVlLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGAnJ2Bcblx0ICovXG5cdGhlaWdodDogc3RyaW5nO1xuXHRcblx0LyoqXG5cdCAqIElmIGB0cnVlYCwgc2hvd3MgYSBzdHJpcGVkIHByb2dyZXNzYmFyLlxuXHQgKlxuXHQgKiBAZGVmYXVsdFZhbHVlIGBmYWxzZWBcblx0ICovXG5cdHN0cmlwZWQ6IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogSWYgYHRydWVgLCBhbmltYXRlcyBhIHN0cmlwZWQgcHJvZ3Jlc3NiYXIuXG5cdCAqIFRha2VzIGVmZmVjdCBvbmx5IGZvciBicm93c2VycyBzdXBwb3J0aW5nIENTUzMgYW5pbWF0aW9ucywgYW5kIGlmIGBzdHJpcGVkYCBpcyBgdHJ1ZWAuXG5cdCAqXG5cdCAqIEBkZWZhdWx0VmFsdWUgYGZhbHNlYFxuXHQgKi9cblx0YW5pbWF0ZWQ6IGJvb2xlYW47XG5cdFxuXHQvKipcblx0ICogVHlwZSBvZiB0aGUgcHJvZ3Jlc3NiYXIsIGZvbGxvd2luZyBib290c3RyYXAgdHlwZXMuXG5cdCAqL1xuXHR0eXBlOiBCU0NvbnRleHR1YWxDbGFzcyB8IHVuZGVmaW5lZDtcbn1cblxuXG5cbi8qKlxuICogUmVwcmVzZW50cyBhIFByb2dyZXNzYmFyIHdpZGdldC5cbiAqXG4gKiBUaGlzIHR5cGUgZGVmaW5lcyB0aGUgc3RydWN0dXJlIG9mIGEgUHJvZ3Jlc3NiYXIgd2lkZ2V0LCBpbmNsdWRpbmcgaXRzIHByb3BlcnRpZXMsIHN0YXRlLCBhbmQgZGlyZWN0aXZlcy5cbiAqL1xuZXhwb3J0IHR5cGUgUHJvZ3Jlc3NiYXJXaWRnZXQgPSBXaWRnZXQ8UHJvZ3Jlc3NiYXJQcm9wcywgUHJvZ3Jlc3NiYXJTdGF0ZSwgb2JqZWN0LCBQcm9ncmVzc2JhckRpcmVjdGl2ZXM+O1xuXG5cblxuLyoqXG4gKiBDcmVhdGUgYSBQcm9ncmVzc2JhciB3aXRoIGdpdmVuIGNvbmZpZyBwcm9wc1xuICogQHBhcmFtIGNvbmZpZyAtIGFuIG9wdGlvbmFsIHByb2dyZXNzYmFyIGNvbmZpZ1xuICogQHJldHVybnMgYSBQcm9ncmVzc2JhcldpZGdldFxuICovXG5cbmNvbnN0IGV4cG9ydF9jcmVhdGVQcm9ncmVzc2JhcjogV2lkZ2V0RmFjdG9yeTxQcm9ncmVzc2JhcldpZGdldD4gPSBjcmVhdGVQcm9ncmVzc2JhciBhcyBhbnk7XG5leHBvcnQge2V4cG9ydF9jcmVhdGVQcm9ncmVzc2JhciBhcyBjcmVhdGVQcm9ncmVzc2Jhcn07XG5cbi8qKlxuICogSW50ZXJmYWNlIHJlcHJlc2VudGluZyBkaXJlY3RpdmVzIGZvciBhIHByb2dyZXNzIGJhciBjb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUHJvZ3Jlc3NiYXJEaXJlY3RpdmVzIHtcblx0XG5cdC8qKlxuXHQgKiBBIGRpcmVjdGl2ZSB0byBiZSBhcHBsaWVkIHRvIHRoZSBtYWluIGNvbnRhaW5lciB0aGF0IGhhbmRsZXMgYXJpYSBhdHRyaWJ1dGVzLlxuXHQgKi9cblx0YXJpYURpcmVjdGl2ZTogRGlyZWN0aXZlO1xufVxuXG4iXX0=
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export * from './rating.component';
|
|
2
|
-
export * from './rating.gen';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9yYXRpbmcvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcmF0aW5nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JhdGluZy5nZW4nO1xuIl19
|
|
@@ -1,205 +0,0 @@
|
|
|
1
|
-
import { BaseWidgetDirective, SlotDirective, UseDirective, auBooleanAttribute, auNumberAttribute, useDirectiveForHost, } from '@agnos-ui/angular-headless';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewEncapsulation, forwardRef, inject, } from '@angular/core';
|
|
3
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
-
import { callWidgetFactory } from '../../config';
|
|
5
|
-
import { createRating } from './rating.gen';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
const _c0 = ["auRating", ""];
|
|
8
|
-
const _c1 = a0 => ({ index: a0 });
|
|
9
|
-
const _c2 = (a0, a1) => [a0, a1];
|
|
10
|
-
function RatingComponent_For_1_ng_template_3_Template(rf, ctx) { }
|
|
11
|
-
function RatingComponent_For_1_Template(rf, ctx) { if (rf & 1) {
|
|
12
|
-
i0.ɵɵelementStart(0, "span", 0);
|
|
13
|
-
i0.ɵɵtext(1);
|
|
14
|
-
i0.ɵɵelementEnd();
|
|
15
|
-
i0.ɵɵelementStart(2, "span", 1);
|
|
16
|
-
i0.ɵɵtemplate(3, RatingComponent_For_1_ng_template_3_Template, 0, 0, "ng-template", 2);
|
|
17
|
-
i0.ɵɵelementEnd();
|
|
18
|
-
} if (rf & 2) {
|
|
19
|
-
const ɵ$index_1_r1 = ctx.$index;
|
|
20
|
-
const ctx_r1 = i0.ɵɵnextContext();
|
|
21
|
-
i0.ɵɵadvance();
|
|
22
|
-
i0.ɵɵtextInterpolate1("(", ɵ$index_1_r1 < ctx_r1.state.visibleRating() ? "*" : " ", ")");
|
|
23
|
-
i0.ɵɵadvance();
|
|
24
|
-
i0.ɵɵproperty("auUse", i0.ɵɵpureFunction2(6, _c2, ctx_r1.directives.starDirective, i0.ɵɵpureFunction1(4, _c1, ɵ$index_1_r1)));
|
|
25
|
-
i0.ɵɵadvance();
|
|
26
|
-
i0.ɵɵproperty("auSlot", ctx_r1.state.star())("auSlotProps", ctx_r1.state.stars()[ɵ$index_1_r1]);
|
|
27
|
-
} }
|
|
28
|
-
/**
|
|
29
|
-
* Directive to represent a rating star.
|
|
30
|
-
*
|
|
31
|
-
* This directive uses a template reference to render the {@link StarContext}.
|
|
32
|
-
*/
|
|
33
|
-
export class RatingStarDirective {
|
|
34
|
-
constructor() {
|
|
35
|
-
this.templateRef = inject((TemplateRef));
|
|
36
|
-
}
|
|
37
|
-
static ngTemplateContextGuard(_dir, context) {
|
|
38
|
-
return true;
|
|
39
|
-
}
|
|
40
|
-
static { this.ɵfac = function RatingStarDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || RatingStarDirective)(); }; }
|
|
41
|
-
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: RatingStarDirective, selectors: [["ng-template", "auRatingStar", ""]], standalone: true }); }
|
|
42
|
-
}
|
|
43
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RatingStarDirective, [{
|
|
44
|
-
type: Directive,
|
|
45
|
-
args: [{ selector: 'ng-template[auRatingStar]', standalone: true }]
|
|
46
|
-
}], null, null); })();
|
|
47
|
-
/**
|
|
48
|
-
* The `RatingComponent` is an Angular component that allows users to provide a rating.
|
|
49
|
-
* It extends `BaseWidgetDirective` and implements `ControlValueAccessor` to integrate with Angular forms.
|
|
50
|
-
*/
|
|
51
|
-
export class RatingComponent extends BaseWidgetDirective {
|
|
52
|
-
writeValue(value) {
|
|
53
|
-
this['_widget'].patch({ rating: value });
|
|
54
|
-
}
|
|
55
|
-
registerOnChange(fn) {
|
|
56
|
-
this.onChange = fn;
|
|
57
|
-
}
|
|
58
|
-
registerOnTouched(fn) {
|
|
59
|
-
this.onTouched = fn;
|
|
60
|
-
}
|
|
61
|
-
setDisabledState(disabled) {
|
|
62
|
-
this['_widget'].patch({ disabled });
|
|
63
|
-
}
|
|
64
|
-
constructor() {
|
|
65
|
-
super(callWidgetFactory({
|
|
66
|
-
factory: createRating,
|
|
67
|
-
widgetName: 'rating',
|
|
68
|
-
events: {
|
|
69
|
-
onHover: (event) => this.hover.emit(event),
|
|
70
|
-
onLeave: (event) => this.leave.emit(event),
|
|
71
|
-
onRatingChange: (rating) => {
|
|
72
|
-
this.ratingChange.emit(rating);
|
|
73
|
-
this.onChange(rating);
|
|
74
|
-
},
|
|
75
|
-
},
|
|
76
|
-
afterInit: (widget) => {
|
|
77
|
-
useDirectiveForHost(widget.directives.containerDirective);
|
|
78
|
-
},
|
|
79
|
-
slotTemplates: () => ({
|
|
80
|
-
star: this.slotStarFromContent?.templateRef,
|
|
81
|
-
}),
|
|
82
|
-
}));
|
|
83
|
-
this.onChange = (_) => { };
|
|
84
|
-
this.onTouched = () => { };
|
|
85
|
-
/**
|
|
86
|
-
* An event emitted when the user is hovering over a given rating.
|
|
87
|
-
*
|
|
88
|
-
* Event payload is equal to the rating being hovered over.
|
|
89
|
-
*
|
|
90
|
-
* @defaultValue
|
|
91
|
-
* ```ts
|
|
92
|
-
* () => {}
|
|
93
|
-
* ```
|
|
94
|
-
*/
|
|
95
|
-
this.hover = new EventEmitter();
|
|
96
|
-
/**
|
|
97
|
-
* An event emitted when the user stops hovering over a given rating.
|
|
98
|
-
*
|
|
99
|
-
* Event payload is equal to the rating of the last item being hovered over.
|
|
100
|
-
*
|
|
101
|
-
* @defaultValue
|
|
102
|
-
* ```ts
|
|
103
|
-
* () => {}
|
|
104
|
-
* ```
|
|
105
|
-
*/
|
|
106
|
-
this.leave = new EventEmitter();
|
|
107
|
-
/**
|
|
108
|
-
* An event emitted when the rating is changed.
|
|
109
|
-
*
|
|
110
|
-
* Event payload is equal to the newly selected rating.
|
|
111
|
-
*
|
|
112
|
-
* @defaultValue
|
|
113
|
-
* ```ts
|
|
114
|
-
* () => {}
|
|
115
|
-
* ```
|
|
116
|
-
*/
|
|
117
|
-
this.ratingChange = new EventEmitter();
|
|
118
|
-
}
|
|
119
|
-
trackByIndex(index) {
|
|
120
|
-
return index;
|
|
121
|
-
}
|
|
122
|
-
static { this.ɵfac = function RatingComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || RatingComponent)(); }; }
|
|
123
|
-
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: RatingComponent, selectors: [["", "auRating", ""]], contentQueries: function RatingComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
|
124
|
-
i0.ɵɵcontentQuery(dirIndex, RatingStarDirective, 5);
|
|
125
|
-
} if (rf & 2) {
|
|
126
|
-
let _t;
|
|
127
|
-
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStarFromContent = _t.first);
|
|
128
|
-
} }, hostAttrs: [1, "d-inline-flex"], hostBindings: function RatingComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
129
|
-
i0.ɵɵlistener("blur", function RatingComponent_blur_HostBindingHandler() { return ctx.onTouched(); });
|
|
130
|
-
} }, inputs: { ariaValueTextFn: [0, "auAriaValueTextFn", "ariaValueTextFn"], disabled: [2, "auDisabled", "disabled", auBooleanAttribute], maxRating: [2, "auMaxRating", "maxRating", auNumberAttribute], rating: [2, "auRating", "rating", auNumberAttribute], readonly: [2, "auReadonly", "readonly", auBooleanAttribute], resettable: [2, "auResettable", "resettable", auBooleanAttribute], star: [0, "auStar", "star"], tabindex: [2, "auTabindex", "tabindex", auNumberAttribute], className: [0, "auClassName", "className"], ariaLabel: [0, "auAriaLabel", "ariaLabel"], ariaLabelledBy: [0, "auAriaLabelledBy", "ariaLabelledBy"] }, outputs: { hover: "auHover", leave: "auLeave", ratingChange: "auRatingChange" }, standalone: true, features: [i0.ɵɵProvidersFeature([{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RatingComponent), multi: true }]), i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c0, decls: 2, vars: 0, consts: [[1, "visually-hidden"], [3, "auUse"], [3, "auSlot", "auSlotProps"]], template: function RatingComponent_Template(rf, ctx) { if (rf & 1) {
|
|
131
|
-
i0.ɵɵrepeaterCreate(0, RatingComponent_For_1_Template, 4, 9, null, null, ctx.trackByIndex, true);
|
|
132
|
-
} if (rf & 2) {
|
|
133
|
-
i0.ɵɵrepeater(ctx.state.stars());
|
|
134
|
-
} }, dependencies: [UseDirective, SlotDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
135
|
-
}
|
|
136
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RatingComponent, [{
|
|
137
|
-
type: Component,
|
|
138
|
-
args: [{
|
|
139
|
-
selector: '[auRating]',
|
|
140
|
-
standalone: true,
|
|
141
|
-
imports: [UseDirective, SlotDirective],
|
|
142
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
143
|
-
encapsulation: ViewEncapsulation.None,
|
|
144
|
-
host: {
|
|
145
|
-
class: 'd-inline-flex',
|
|
146
|
-
'(blur)': 'onTouched()',
|
|
147
|
-
},
|
|
148
|
-
template: `
|
|
149
|
-
@for (item of state.stars(); track trackByIndex(index); let index = $index) {
|
|
150
|
-
<span class="visually-hidden">({{ index < state.visibleRating() ? '*' : ' ' }})</span>
|
|
151
|
-
<span [auUse]="[directives.starDirective, {index}]">
|
|
152
|
-
<ng-template [auSlot]="state.star()" [auSlotProps]="state.stars()[index]" />
|
|
153
|
-
</span>
|
|
154
|
-
}
|
|
155
|
-
`,
|
|
156
|
-
providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RatingComponent), multi: true }],
|
|
157
|
-
}]
|
|
158
|
-
}], () => [], { ariaValueTextFn: [{
|
|
159
|
-
type: Input,
|
|
160
|
-
args: ['auAriaValueTextFn']
|
|
161
|
-
}], disabled: [{
|
|
162
|
-
type: Input,
|
|
163
|
-
args: [{ alias: 'auDisabled', transform: auBooleanAttribute }]
|
|
164
|
-
}], maxRating: [{
|
|
165
|
-
type: Input,
|
|
166
|
-
args: [{ alias: 'auMaxRating', transform: auNumberAttribute }]
|
|
167
|
-
}], rating: [{
|
|
168
|
-
type: Input,
|
|
169
|
-
args: [{ alias: 'auRating', transform: auNumberAttribute }]
|
|
170
|
-
}], readonly: [{
|
|
171
|
-
type: Input,
|
|
172
|
-
args: [{ alias: 'auReadonly', transform: auBooleanAttribute }]
|
|
173
|
-
}], resettable: [{
|
|
174
|
-
type: Input,
|
|
175
|
-
args: [{ alias: 'auResettable', transform: auBooleanAttribute }]
|
|
176
|
-
}], star: [{
|
|
177
|
-
type: Input,
|
|
178
|
-
args: ['auStar']
|
|
179
|
-
}], slotStarFromContent: [{
|
|
180
|
-
type: ContentChild,
|
|
181
|
-
args: [RatingStarDirective, { static: false }]
|
|
182
|
-
}], tabindex: [{
|
|
183
|
-
type: Input,
|
|
184
|
-
args: [{ alias: 'auTabindex', transform: auNumberAttribute }]
|
|
185
|
-
}], className: [{
|
|
186
|
-
type: Input,
|
|
187
|
-
args: ['auClassName']
|
|
188
|
-
}], ariaLabel: [{
|
|
189
|
-
type: Input,
|
|
190
|
-
args: ['auAriaLabel']
|
|
191
|
-
}], ariaLabelledBy: [{
|
|
192
|
-
type: Input,
|
|
193
|
-
args: ['auAriaLabelledBy']
|
|
194
|
-
}], hover: [{
|
|
195
|
-
type: Output,
|
|
196
|
-
args: ['auHover']
|
|
197
|
-
}], leave: [{
|
|
198
|
-
type: Output,
|
|
199
|
-
args: ['auLeave']
|
|
200
|
-
}], ratingChange: [{
|
|
201
|
-
type: Output,
|
|
202
|
-
args: ['auRatingChange']
|
|
203
|
-
}] }); })();
|
|
204
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RatingComponent, { className: "RatingComponent", filePath: "components/rating/rating.component.ts", lineNumber: 66 }); })();
|
|
205
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rating.component.js","sourceRoot":"","sources":["../../../../src/components/rating/rating.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n\tuseDirectiveForHost,\n} from '@agnos-ui/angular-headless';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewEncapsulation,\n\tforwardRef,\n\tinject,\n} from '@angular/core';\nimport type {ControlValueAccessor} from '@angular/forms';\nimport {NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {callWidgetFactory} from '../../config';\nimport type {RatingWidget, StarContext} from './rating.gen';\nimport {createRating} from './rating.gen';\n\n/**\n * Directive to represent a rating star.\n *\n * This directive uses a template reference to render the {@link StarContext}.\n */\n@Directive({selector: 'ng-template[auRatingStar]', standalone: true})\nexport class RatingStarDirective {\n\tpublic templateRef = inject(TemplateRef<StarContext>);\n\tstatic ngTemplateContextGuard(_dir: RatingStarDirective, context: unknown): context is StarContext {\n\t\treturn true;\n\t}\n}\n\n/**\n * The `RatingComponent` is an Angular component that allows users to provide a rating.\n * It extends `BaseWidgetDirective` and implements `ControlValueAccessor` to integrate with Angular forms.\n */\n@Component({\n\tselector: '[auRating]',\n\tstandalone: true,\n\timports: [UseDirective, SlotDirective],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tencapsulation: ViewEncapsulation.None,\n\thost: {\n\t\tclass: 'd-inline-flex',\n\t\t'(blur)': 'onTouched()',\n\t},\n\ttemplate: `\n\t\t@for (item of state.stars(); track trackByIndex(index); let index = $index) {\n\t\t\t<span class=\"visually-hidden\">({{ index < state.visibleRating() ? '*' : ' ' }})</span>\n\t\t\t<span [auUse]=\"[directives.starDirective, {index}]\">\n\t\t\t\t<ng-template [auSlot]=\"state.star()\" [auSlotProps]=\"state.stars()[index]\" />\n\t\t\t</span>\n\t\t}\n\t`,\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RatingComponent), multi: true}],\n})\nexport class RatingComponent extends BaseWidgetDirective<RatingWidget> implements ControlValueAccessor {\n\tonChange = (_: any) => {};\n\tonTouched = () => {};\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute.\n\t * @param rating - Current rating value.\n\t * @param maxRating - maxRating value.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (rating: number, maxRating: number) => `${rating} out of ${maxRating}`\n\t * ```\n\t */\n\t@Input('auAriaValueTextFn') ariaValueTextFn: ((rating: number, maxRating: number) => string) | undefined;\n\n\t/**\n\t * If `true`, the rating is disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auDisabled', transform: auBooleanAttribute}) disabled: boolean | undefined;\n\n\t/**\n\t * The maximum rating that can be given.\n\t *\n\t * @defaultValue `10`\n\t */\n\t@Input({alias: 'auMaxRating', transform: auNumberAttribute}) maxRating: number | undefined;\n\n\t/**\n\t * The current rating. Could be a decimal value like `3.75`.\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auRating', transform: auNumberAttribute}) rating: number | undefined;\n\n\t/**\n\t * If `true`, the rating can't be changed.\n\t *\n\t * @defaultValue `false`\n\t */\n\t@Input({alias: 'auReadonly', transform: auBooleanAttribute}) readonly: boolean | undefined;\n\n\t/**\n\t * Define if the rating can be reset.\n\t *\n\t * If set to true, the user can 'unset' the rating value by cliking on the current rating value.\n\t *\n\t * @defaultValue `true`\n\t */\n\t@Input({alias: 'auResettable', transform: auBooleanAttribute}) resettable: boolean | undefined;\n\n\t/**\n\t * The template to override the way each star is displayed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({fill}: StarContext) => String.fromCharCode(fill === 100 ? 9733 : 9734)\n\t * ```\n\t */\n\t@Input('auStar') star: SlotContent<StarContext>;\n\t@ContentChild(RatingStarDirective, {static: false}) slotStarFromContent: RatingStarDirective | undefined;\n\n\t/**\n\t * Allows setting a custom rating tabindex.\n\t * If the component is disabled, `tabindex` will still be set to `-1`.\n\t *\n\t * @defaultValue `0`\n\t */\n\t@Input({alias: 'auTabindex', transform: auNumberAttribute}) tabindex: 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 * The aria label\n\t *\n\t * @defaultValue `'Rating'`\n\t */\n\t@Input('auAriaLabel') ariaLabel: string | undefined;\n\n\t/**\n\t * The aria labelled by\n\t *\n\t * @defaultValue `''`\n\t */\n\t@Input('auAriaLabelledBy') ariaLabelledBy: string | undefined;\n\n\t/**\n\t * An event emitted when the user is hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auHover') hover = new EventEmitter<number>();\n\n\t/**\n\t * An event emitted when the user stops hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating of the last item being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auLeave') leave = new EventEmitter<number>();\n\n\t/**\n\t * An event emitted when the rating is changed.\n\t *\n\t * Event payload is equal to the newly selected rating.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auRatingChange') ratingChange = new EventEmitter<number>();\n\n\twriteValue(value: any): void {\n\t\tthis['_widget'].patch({rating: value});\n\t}\n\n\tregisterOnChange(fn: (value: any) => any): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => any): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState(disabled: boolean): void {\n\t\tthis['_widget'].patch({disabled});\n\t}\n\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory({\n\t\t\t\tfactory: createRating,\n\t\t\t\twidgetName: 'rating',\n\t\t\t\tevents: {\n\t\t\t\t\tonHover: (event) => this.hover.emit(event),\n\t\t\t\t\tonLeave: (event) => this.leave.emit(event),\n\t\t\t\t\tonRatingChange: (rating: number) => {\n\t\t\t\t\t\tthis.ratingChange.emit(rating);\n\t\t\t\t\t\tthis.onChange(rating);\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t\tafterInit: (widget) => {\n\t\t\t\t\tuseDirectiveForHost(widget.directives.containerDirective);\n\t\t\t\t},\n\t\t\t\tslotTemplates: () => ({\n\t\t\t\t\tstar: this.slotStarFromContent?.templateRef,\n\t\t\t\t}),\n\t\t\t}),\n\t\t);\n\t}\n\n\ttrackByIndex(index: number) {\n\t\treturn index;\n\t}\n}\n"]}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { getRatingDefaultConfig, createRating } from '@agnos-ui/core-bootstrap/components/rating';
|
|
2
|
-
/**
|
|
3
|
-
* Retrieve a shallow copy of the default Rating config
|
|
4
|
-
* @returns the default Rating config
|
|
5
|
-
*/
|
|
6
|
-
const export_getRatingDefaultConfig = getRatingDefaultConfig;
|
|
7
|
-
export { export_getRatingDefaultConfig as getRatingDefaultConfig };
|
|
8
|
-
/**
|
|
9
|
-
* Create a RatingWidget with given config props
|
|
10
|
-
* @param config - an optional rating config
|
|
11
|
-
* @returns a RatingWidget
|
|
12
|
-
*/
|
|
13
|
-
const export_createRating = createRating;
|
|
14
|
-
export { export_createRating as createRating };
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rating.gen.js","sourceRoot":"","sources":["../../../../src/components/rating/rating.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAE,YAAY,EAAC,MAAM,4CAA4C,CAAC;AAKhG;;;GAGG;AACH,MAAM,6BAA6B,GAAsB,sBAA6B,CAAC;AACvF,OAAO,EAAC,6BAA6B,IAAI,sBAAsB,EAAC,CAAC;AAoQjE;;;;GAIG;AAEH,MAAM,mBAAmB,GAAgC,YAAmB,CAAC;AAC7E,OAAO,EAAC,mBAAmB,IAAI,YAAY,EAAC,CAAC","sourcesContent":["import {getRatingDefaultConfig, createRating} from '@agnos-ui/core-bootstrap/components/rating';\nimport type {SlotContent, Widget, WidgetFactory, Directive} from '@agnos-ui/angular-headless';\n\n\n\n/**\n * Retrieve a shallow copy of the default Rating config\n * @returns the default Rating config\n */\nconst export_getRatingDefaultConfig: () => RatingProps = getRatingDefaultConfig as any;\nexport {export_getRatingDefaultConfig as getRatingDefaultConfig};\n\n/**\n * Represents the state of a rating component.\n */\nexport interface RatingState {\n\t\n\t/**\n\t * the aria value of the rating\n\t */\n\tariaValueText: string;\n\t\n\t/**\n\t * the visible value of the rating (it changes when hovering over the rating even though the real value did not change)\n\t */\n\tvisibleRating: number;\n\t\n\t/**\n\t * is the rating interactive i.e. listening to hover, click and keyboard events\n\t */\n\tinteractive: boolean;\n\t\n\t/**\n\t * the list of stars\n\t */\n\tstars: StarContext[];\n\t\n\t/**\n\t * The current rating. Could be a decimal value like `3.75`.\n\t *\n\t * @defaultValue `0`\n\t */\n\trating: number;\n\t\n\n\t/**\n\t * The maximum rating that can be given.\n\t *\n\t * @defaultValue `10`\n\t */\n\tmaxRating: number;\n\t\n\n\t/**\n\t * If `true`, the rating is disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true`, the rating can't be changed.\n\t *\n\t * @defaultValue `false`\n\t */\n\treadonly: boolean;\n\t\n\n\t/**\n\t * Define if the rating can be reset.\n\t *\n\t * If set to true, the user can 'unset' the rating value by cliking on the current rating value.\n\t *\n\t * @defaultValue `true`\n\t */\n\tresettable: boolean;\n\t\n\n\t/**\n\t * Allows setting a custom rating tabindex.\n\t * If the component is disabled, `tabindex` will still be set to `-1`.\n\t *\n\t * @defaultValue `0`\n\t */\n\ttabindex: number;\n\t\n\n\t/**\n\t * The aria label\n\t *\n\t * @defaultValue `'Rating'`\n\t */\n\tariaLabel: string;\n\t\n\n\t/**\n\t * The aria labelled by\n\t *\n\t * @defaultValue `''`\n\t */\n\tariaLabelledBy: 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 * The template to override the way each star is displayed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({fill}: StarContext) => String.fromCharCode(fill === 100 ? 9733 : 9734)\n\t * ```\n\t */\n\tstar: SlotContent<StarContext>;\n}\n\n/**\n * Represents the properties for the Rating component.\n */\nexport interface RatingProps {\n\t\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute.\n\t * @param rating - Current rating value.\n\t * @param maxRating - maxRating value.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * (rating: number, maxRating: number) => `${rating} out of ${maxRating}`\n\t * ```\n\t */\n\tariaValueTextFn: (rating: number, maxRating: number) => string;\n\t\n\n\t/**\n\t * An event emitted when the rating is changed.\n\t *\n\t * Event payload is equal to the newly selected rating.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonRatingChange: (rating: number) => void;\n\t\n\n\t/**\n\t * An event emitted when the user is hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonHover: (rating: number) => void;\n\t\n\n\t/**\n\t * An event emitted when the user stops hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating of the last item being hovered over.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonLeave: (rating: number) => void;\n\t\n\t/**\n\t * The current rating. Could be a decimal value like `3.75`.\n\t *\n\t * @defaultValue `0`\n\t */\n\trating: number;\n\t\n\n\t/**\n\t * The maximum rating that can be given.\n\t *\n\t * @defaultValue `10`\n\t */\n\tmaxRating: number;\n\t\n\n\t/**\n\t * If `true`, the rating is disabled.\n\t *\n\t * @defaultValue `false`\n\t */\n\tdisabled: boolean;\n\t\n\n\t/**\n\t * If `true`, the rating can't be changed.\n\t *\n\t * @defaultValue `false`\n\t */\n\treadonly: boolean;\n\t\n\n\t/**\n\t * Define if the rating can be reset.\n\t *\n\t * If set to true, the user can 'unset' the rating value by cliking on the current rating value.\n\t *\n\t * @defaultValue `true`\n\t */\n\tresettable: boolean;\n\t\n\n\t/**\n\t * Allows setting a custom rating tabindex.\n\t * If the component is disabled, `tabindex` will still be set to `-1`.\n\t *\n\t * @defaultValue `0`\n\t */\n\ttabindex: number;\n\t\n\n\t/**\n\t * The aria label\n\t *\n\t * @defaultValue `'Rating'`\n\t */\n\tariaLabel: string;\n\t\n\n\t/**\n\t * The aria labelled by\n\t *\n\t * @defaultValue `''`\n\t */\n\tariaLabelledBy: 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 * The template to override the way each star is displayed.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * ({fill}: StarContext) => String.fromCharCode(fill === 100 ? 9733 : 9734)\n\t * ```\n\t */\n\tstar: SlotContent<StarContext>;\n}\n\n\n\n/**\n * Represents a Rating Widget component.\n */\nexport type RatingWidget = Widget<RatingProps, RatingState, RatingApi, RatingDirectives>;\n\n\n\n/**\n * Create a RatingWidget with given config props\n * @param config - an optional rating config\n * @returns a RatingWidget\n */\n\nconst export_createRating: WidgetFactory<RatingWidget> = createRating as any;\nexport {export_createRating as createRating};\n\n\n\n/**\n * Represents the context for a star in a rating component.\n */\nexport interface StarContext {\n\t/**\n\t * indicates how much the current star is filled, from 0 to 100\n\t */\n\tfill: number;\n\t/**\n\t * the position of the star in the rating\n\t */\n\tindex: number;\n}\n\n/**\n * Interface representing directives for a rating component.\n */\nexport interface RatingDirectives {\n\t\n\t/**\n\t * A directive to be applied to the main container\n\t * This will handle the keydown, mouseleave, tabindex and aria attributes\n\t */\n\tcontainerDirective: Directive;\n\t\n\n\t/**\n\t * A directive to be applied on each star element\n\t */\n\tstarDirective: Directive<{index: number}>;\n}\n\n/**\n * Interface representing the API that can be performed on a rating component.\n */\nexport interface RatingApi {\n\t\n\t/**\n\t * Sets the rating value.\n\t *\n\t * @param index - Star index, starting from 1\n\t */\n\tsetRating(index: number): void;\n\t\n\n\t/**\n\t * Sets the hovered rating value.\n\t *\n\t * @param index - Star index, starting from 1\n\t */\n\tsetHoveredRating(index: number): void;\n\t\n\n\t/**\n\t * Leave the rating, resetting the visible rating to the rating value and triggering the onLeave callback\n\t */\n\tleave(): void;\n}\n\n"]}
|