@cute-widgets/base 20.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (183) hide show
  1. package/CHANGELOG.md +1 -0
  2. package/LICENSE.md +191 -0
  3. package/README.md +190 -0
  4. package/abstract/index.d.ts +327 -0
  5. package/alert/index.d.ts +68 -0
  6. package/autocomplete/index.d.ts +442 -0
  7. package/badge/index.d.ts +26 -0
  8. package/bottom-sheet/index.d.ts +231 -0
  9. package/button/index.d.ts +182 -0
  10. package/button-toggle/index.d.ts +225 -0
  11. package/card/index.d.ts +163 -0
  12. package/checkbox/index.d.ts +174 -0
  13. package/chips/index.d.ts +963 -0
  14. package/collapse/index.d.ts +97 -0
  15. package/core/animation/index.d.ts +43 -0
  16. package/core/datetime/index.d.ts +404 -0
  17. package/core/directives/index.d.ts +168 -0
  18. package/core/error/index.d.ts +74 -0
  19. package/core/index.d.ts +1039 -0
  20. package/core/interfaces/index.d.ts +114 -0
  21. package/core/layout/index.d.ts +53 -0
  22. package/core/line/index.d.ts +37 -0
  23. package/core/nav/index.d.ts +321 -0
  24. package/core/observers/index.d.ts +124 -0
  25. package/core/option/index.d.ts +185 -0
  26. package/core/pipes/index.d.ts +53 -0
  27. package/core/ripple/index.d.ts +66 -0
  28. package/core/testing/index.d.ts +154 -0
  29. package/core/theming/index.d.ts +118 -0
  30. package/core/types/index.d.ts +53 -0
  31. package/core/utils/index.d.ts +129 -0
  32. package/cute-widgets-base-20.0.1.tgz +0 -0
  33. package/datepicker/index.d.ts +1817 -0
  34. package/dialog/index.d.ts +484 -0
  35. package/divider/index.d.ts +24 -0
  36. package/expansion/README.md +8 -0
  37. package/expansion/index.d.ts +308 -0
  38. package/fesm2022/cute-widgets-base-abstract.mjs +547 -0
  39. package/fesm2022/cute-widgets-base-abstract.mjs.map +1 -0
  40. package/fesm2022/cute-widgets-base-alert.mjs +198 -0
  41. package/fesm2022/cute-widgets-base-alert.mjs.map +1 -0
  42. package/fesm2022/cute-widgets-base-autocomplete.mjs +1217 -0
  43. package/fesm2022/cute-widgets-base-autocomplete.mjs.map +1 -0
  44. package/fesm2022/cute-widgets-base-badge.mjs +75 -0
  45. package/fesm2022/cute-widgets-base-badge.mjs.map +1 -0
  46. package/fesm2022/cute-widgets-base-bottom-sheet.mjs +416 -0
  47. package/fesm2022/cute-widgets-base-bottom-sheet.mjs.map +1 -0
  48. package/fesm2022/cute-widgets-base-button-toggle.mjs +640 -0
  49. package/fesm2022/cute-widgets-base-button-toggle.mjs.map +1 -0
  50. package/fesm2022/cute-widgets-base-button.mjs +546 -0
  51. package/fesm2022/cute-widgets-base-button.mjs.map +1 -0
  52. package/fesm2022/cute-widgets-base-card.mjs +471 -0
  53. package/fesm2022/cute-widgets-base-card.mjs.map +1 -0
  54. package/fesm2022/cute-widgets-base-checkbox.mjs +390 -0
  55. package/fesm2022/cute-widgets-base-checkbox.mjs.map +1 -0
  56. package/fesm2022/cute-widgets-base-chips.mjs +2360 -0
  57. package/fesm2022/cute-widgets-base-chips.mjs.map +1 -0
  58. package/fesm2022/cute-widgets-base-collapse.mjs +259 -0
  59. package/fesm2022/cute-widgets-base-collapse.mjs.map +1 -0
  60. package/fesm2022/cute-widgets-base-core-animation.mjs +53 -0
  61. package/fesm2022/cute-widgets-base-core-animation.mjs.map +1 -0
  62. package/fesm2022/cute-widgets-base-core-datetime.mjs +568 -0
  63. package/fesm2022/cute-widgets-base-core-datetime.mjs.map +1 -0
  64. package/fesm2022/cute-widgets-base-core-directives.mjs +404 -0
  65. package/fesm2022/cute-widgets-base-core-directives.mjs.map +1 -0
  66. package/fesm2022/cute-widgets-base-core-error.mjs +105 -0
  67. package/fesm2022/cute-widgets-base-core-error.mjs.map +1 -0
  68. package/fesm2022/cute-widgets-base-core-interfaces.mjs +22 -0
  69. package/fesm2022/cute-widgets-base-core-interfaces.mjs.map +1 -0
  70. package/fesm2022/cute-widgets-base-core-layout.mjs +74 -0
  71. package/fesm2022/cute-widgets-base-core-layout.mjs.map +1 -0
  72. package/fesm2022/cute-widgets-base-core-line.mjs +87 -0
  73. package/fesm2022/cute-widgets-base-core-line.mjs.map +1 -0
  74. package/fesm2022/cute-widgets-base-core-nav.mjs +863 -0
  75. package/fesm2022/cute-widgets-base-core-nav.mjs.map +1 -0
  76. package/fesm2022/cute-widgets-base-core-observers.mjs +304 -0
  77. package/fesm2022/cute-widgets-base-core-observers.mjs.map +1 -0
  78. package/fesm2022/cute-widgets-base-core-option.mjs +373 -0
  79. package/fesm2022/cute-widgets-base-core-option.mjs.map +1 -0
  80. package/fesm2022/cute-widgets-base-core-pipes.mjs +97 -0
  81. package/fesm2022/cute-widgets-base-core-pipes.mjs.map +1 -0
  82. package/fesm2022/cute-widgets-base-core-ripple.mjs +172 -0
  83. package/fesm2022/cute-widgets-base-core-ripple.mjs.map +1 -0
  84. package/fesm2022/cute-widgets-base-core-testing.mjs +210 -0
  85. package/fesm2022/cute-widgets-base-core-testing.mjs.map +1 -0
  86. package/fesm2022/cute-widgets-base-core-theming.mjs +314 -0
  87. package/fesm2022/cute-widgets-base-core-theming.mjs.map +1 -0
  88. package/fesm2022/cute-widgets-base-core-types.mjs +22 -0
  89. package/fesm2022/cute-widgets-base-core-types.mjs.map +1 -0
  90. package/fesm2022/cute-widgets-base-core-utils.mjs +257 -0
  91. package/fesm2022/cute-widgets-base-core-utils.mjs.map +1 -0
  92. package/fesm2022/cute-widgets-base-core.mjs +1600 -0
  93. package/fesm2022/cute-widgets-base-core.mjs.map +1 -0
  94. package/fesm2022/cute-widgets-base-datepicker.mjs +4827 -0
  95. package/fesm2022/cute-widgets-base-datepicker.mjs.map +1 -0
  96. package/fesm2022/cute-widgets-base-dialog.mjs +1046 -0
  97. package/fesm2022/cute-widgets-base-dialog.mjs.map +1 -0
  98. package/fesm2022/cute-widgets-base-divider.mjs +86 -0
  99. package/fesm2022/cute-widgets-base-divider.mjs.map +1 -0
  100. package/fesm2022/cute-widgets-base-expansion.mjs +623 -0
  101. package/fesm2022/cute-widgets-base-expansion.mjs.map +1 -0
  102. package/fesm2022/cute-widgets-base-form-field.mjs +969 -0
  103. package/fesm2022/cute-widgets-base-form-field.mjs.map +1 -0
  104. package/fesm2022/cute-widgets-base-grid-list.mjs +715 -0
  105. package/fesm2022/cute-widgets-base-grid-list.mjs.map +1 -0
  106. package/fesm2022/cute-widgets-base-icon.mjs +1105 -0
  107. package/fesm2022/cute-widgets-base-icon.mjs.map +1 -0
  108. package/fesm2022/cute-widgets-base-input.mjs +726 -0
  109. package/fesm2022/cute-widgets-base-input.mjs.map +1 -0
  110. package/fesm2022/cute-widgets-base-layout-container.mjs +95 -0
  111. package/fesm2022/cute-widgets-base-layout-container.mjs.map +1 -0
  112. package/fesm2022/cute-widgets-base-layout-stack.mjs +166 -0
  113. package/fesm2022/cute-widgets-base-layout-stack.mjs.map +1 -0
  114. package/fesm2022/cute-widgets-base-layout.mjs +250 -0
  115. package/fesm2022/cute-widgets-base-layout.mjs.map +1 -0
  116. package/fesm2022/cute-widgets-base-list.mjs +1557 -0
  117. package/fesm2022/cute-widgets-base-list.mjs.map +1 -0
  118. package/fesm2022/cute-widgets-base-menu.mjs +1283 -0
  119. package/fesm2022/cute-widgets-base-menu.mjs.map +1 -0
  120. package/fesm2022/cute-widgets-base-navbar.mjs +359 -0
  121. package/fesm2022/cute-widgets-base-navbar.mjs.map +1 -0
  122. package/fesm2022/cute-widgets-base-paginator.mjs +485 -0
  123. package/fesm2022/cute-widgets-base-paginator.mjs.map +1 -0
  124. package/fesm2022/cute-widgets-base-progress.mjs +321 -0
  125. package/fesm2022/cute-widgets-base-progress.mjs.map +1 -0
  126. package/fesm2022/cute-widgets-base-radio.mjs +637 -0
  127. package/fesm2022/cute-widgets-base-radio.mjs.map +1 -0
  128. package/fesm2022/cute-widgets-base-select.mjs +1208 -0
  129. package/fesm2022/cute-widgets-base-select.mjs.map +1 -0
  130. package/fesm2022/cute-widgets-base-sidenav.mjs +1095 -0
  131. package/fesm2022/cute-widgets-base-sidenav.mjs.map +1 -0
  132. package/fesm2022/cute-widgets-base-slider.mjs +99 -0
  133. package/fesm2022/cute-widgets-base-slider.mjs.map +1 -0
  134. package/fesm2022/cute-widgets-base-snack-bar.mjs +897 -0
  135. package/fesm2022/cute-widgets-base-snack-bar.mjs.map +1 -0
  136. package/fesm2022/cute-widgets-base-sort.mjs +639 -0
  137. package/fesm2022/cute-widgets-base-sort.mjs.map +1 -0
  138. package/fesm2022/cute-widgets-base-spinner.mjs +154 -0
  139. package/fesm2022/cute-widgets-base-spinner.mjs.map +1 -0
  140. package/fesm2022/cute-widgets-base-stepper.mjs +673 -0
  141. package/fesm2022/cute-widgets-base-stepper.mjs.map +1 -0
  142. package/fesm2022/cute-widgets-base-table.mjs +1023 -0
  143. package/fesm2022/cute-widgets-base-table.mjs.map +1 -0
  144. package/fesm2022/cute-widgets-base-tabs.mjs +729 -0
  145. package/fesm2022/cute-widgets-base-tabs.mjs.map +1 -0
  146. package/fesm2022/cute-widgets-base-timepicker.mjs +965 -0
  147. package/fesm2022/cute-widgets-base-timepicker.mjs.map +1 -0
  148. package/fesm2022/cute-widgets-base-toolbar.mjs +120 -0
  149. package/fesm2022/cute-widgets-base-toolbar.mjs.map +1 -0
  150. package/fesm2022/cute-widgets-base-tooltip.mjs +947 -0
  151. package/fesm2022/cute-widgets-base-tooltip.mjs.map +1 -0
  152. package/fesm2022/cute-widgets-base-tree.mjs +598 -0
  153. package/fesm2022/cute-widgets-base-tree.mjs.map +1 -0
  154. package/fesm2022/cute-widgets-base.mjs +68 -0
  155. package/fesm2022/cute-widgets-base.mjs.map +1 -0
  156. package/form-field/index.d.ts +401 -0
  157. package/grid-list/index.d.ts +361 -0
  158. package/icon/index.d.ts +477 -0
  159. package/index.d.ts +3 -0
  160. package/input/index.d.ts +256 -0
  161. package/layout/container/index.d.ts +31 -0
  162. package/layout/index.d.ts +78 -0
  163. package/layout/stack/index.d.ts +52 -0
  164. package/list/index.d.ts +659 -0
  165. package/menu/index.d.ts +497 -0
  166. package/navbar/index.d.ts +91 -0
  167. package/package.json +279 -0
  168. package/paginator/index.d.ts +216 -0
  169. package/progress/index.d.ts +130 -0
  170. package/radio/index.d.ts +259 -0
  171. package/select/index.d.ts +426 -0
  172. package/sidenav/index.d.ts +369 -0
  173. package/slider/index.d.ts +48 -0
  174. package/snack-bar/index.d.ts +374 -0
  175. package/sort/index.d.ts +334 -0
  176. package/spinner/index.d.ts +70 -0
  177. package/stepper/index.d.ts +295 -0
  178. package/table/index.d.ts +395 -0
  179. package/tabs/index.d.ts +307 -0
  180. package/timepicker/index.d.ts +350 -0
  181. package/toolbar/index.d.ts +36 -0
  182. package/tooltip/index.d.ts +299 -0
  183. package/tree/index.d.ts +314 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cute-widgets-base-navbar.mjs","sources":["../../../../projects/cute-widgets/base/navbar/src/navbar-content.component.ts","../../../../projects/cute-widgets/base/navbar/src/navbar.component.ts","../../../../projects/cute-widgets/base/navbar/src/navbar-brand.directive.ts","../../../../projects/cute-widgets/base/navbar/src/navbar-nav.directive.ts","../../../../projects/cute-widgets/base/navbar/src/navbar-text.directive.ts","../../../../projects/cute-widgets/base/navbar/src/navbar-toggler.directive.ts","../../../../projects/cute-widgets/base/navbar/src/navbar.module.ts","../../../../projects/cute-widgets/base/navbar/cute-widgets-base-navbar.ts"],"sourcesContent":["/**\r\n * @license Apache-2.0\r\n *\r\n * Copyright (c) 2025 CuteWidgets Team. All Rights Reserved.\r\n *\r\n * You may not use this file except in compliance with the License\r\n * that can be found at http://www.apache.org/licenses/LICENSE-2.0\r\n */\r\nimport {ChangeDetectionStrategy, Component, inject, signal, ViewEncapsulation} from \"@angular/core\";\r\nimport {CuteCollapse, CuteCollapseState} from \"@cute-widgets/base/collapse\";\r\nimport {CUTE_NAVBAR} from './navbar.component';\r\nimport {Subscription} from 'rxjs';\r\n\r\n/**\r\n * Collapsible navbar content.\r\n */\r\n@Component({\r\n selector: 'cute-navbar-content',\r\n template: `\r\n <ng-content></ng-content>\r\n `,\r\n exportAs: 'cuteNavbarContent',\r\n host: {\r\n 'class': 'navbar-collapse collapse',\r\n '[class.show]': 'expanded',\r\n },\r\n encapsulation: ViewEncapsulation.None,\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n standalone: true,\r\n})\r\nexport class CuteNavbarContent extends CuteCollapse {\r\n private _subscription: Subscription = new Subscription();\r\n protected _navbar = inject(CUTE_NAVBAR);\r\n protected _breakpointMatches = signal<boolean>(false);\r\n\r\n constructor() {\r\n super();\r\n\r\n this._subscription.add(\r\n this._navbar.breakpointState.subscribe(state => {\r\n this._breakpointMatches.set(state.matches);\r\n if (!state.matches) {\r\n this.close(); // if content was in the 'expanded' state when the screen width changed\r\n this._navbar.expansionChange.emit(false);\r\n }\r\n })\r\n );\r\n this._subscription.add(\r\n this.afterExpand.subscribe(() => {\r\n if (this._breakpointMatches()) {\r\n this._navbar.expansionChange.emit(true);\r\n }\r\n })\r\n );\r\n this._subscription.add(\r\n this.afterCollapse.subscribe(() => this._navbar.expansionChange.emit(false))\r\n );\r\n }\r\n\r\n override getState(): CuteCollapseState {\r\n if (this._breakpointMatches()) {\r\n return super.getState();\r\n }\r\n // Parent class, CuteCollapse, uses this state to trigger the expanding process.\r\n // But we use it for the sake of `visibility` property only.\r\n // TODO: Change to a simpler and clearer algorithm.\r\n return 'expanded';\r\n }\r\n\r\n override ngOnDestroy() {\r\n super.ngOnDestroy();\r\n this._subscription.unsubscribe();\r\n }\r\n\r\n}\r\n","/**\r\n * @license Apache-2.0\r\n *\r\n * Copyright (c) 2025 CuteWidgets Team. All Rights Reserved.\r\n *\r\n * You may not use this file except in compliance with the License\r\n * that can be found at http://www.apache.org/licenses/LICENSE-2.0\r\n */\r\nimport {\r\n ChangeDetectionStrategy,\r\n Component, computed, ContentChildren, EventEmitter,\r\n HostBinding,\r\n InjectionToken,\r\n Input, isDevMode, Output, QueryList, signal, ViewEncapsulation,\r\n} from \"@angular/core\";\r\nimport {CuteLayoutControl} from \"@cute-widgets/base/abstract\";\r\nimport {CuteContainer} from \"@cute-widgets/base/layout\";\r\nimport {CuteNavbarContent} from './navbar-content.component';\r\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\r\n\r\n/** Navbar's vertical non-static position. */\r\nexport type NavbarPosition=\"fixed-top\"|\"fixed-bottom\"|\"sticky-top\"|\"sticky-bottom\";\r\n\r\nexport const CUTE_NAVBAR = new InjectionToken<CuteNavbar>(\"CUTE_NAVBAR\");\r\n\r\nlet nextId = 0;\r\n\r\n/**\r\n * Powerful and responsive navigation header in which responsive behavior depends on `CuteCollapse` component.\r\n * Includes support for branding, navigation, and more.\r\n */\r\n@Component({\r\n selector: 'cute-navbar',\r\n template: `\r\n <cute-container fluid>\r\n <ng-content></ng-content>\r\n </cute-container>\r\n `,\r\n styles: [`\r\n .cute-navbar {\r\n z-index: 1000; /* CWT: 'cdk-overlay-container' has a rule {z-index: 1000} */\r\n }\r\n `],\r\n exportAs: 'cuteNavbar',\r\n host: {\r\n 'class': 'cute-navbar navbar',\r\n '[class.shadow]': 'contentExpanded()',\r\n '[attr.role]': 'role || null',\r\n },\r\n providers: [{ provide: CUTE_NAVBAR, useExisting: CuteNavbar }],\r\n imports: [ CuteContainer ],\r\n encapsulation: ViewEncapsulation.None,\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class CuteNavbar extends CuteLayoutControl {\r\n @ContentChildren(CuteNavbarContent, {descendants: true}) navContent: QueryList<CuteNavbarContent> | undefined;\r\n\r\n /** Placement `navbar` in non-static position, if the `position` differs from the default. */\r\n @Input() position: NavbarPosition | undefined;\r\n\r\n /** Event emitted when the navbar's content expansion status changed. */\r\n @Output() expansionChange = new EventEmitter<boolean>();\r\n\r\n readonly contentExpanded = computed(() => this._expanded());\r\n private _expanded = signal<boolean>(false);\r\n\r\n @HostBinding(\"class\")\r\n get classBinding(): string {\r\n let classList = \"\";\r\n\r\n if (this.breakpoint) {\r\n classList += \"navbar-expand-\"+this.breakpoint;\r\n }\r\n switch (this.position) {\r\n case \"fixed-top\":\r\n case \"fixed-bottom\":\r\n classList += \" \"+this.position;\r\n break;\r\n case \"sticky-top\":\r\n case \"sticky-bottom\":\r\n if (this.breakpoint) {\r\n classList += \" \"+this.position.replace(\"-\", \"-\"+this.breakpoint+\"-\");\r\n } else {\r\n classList += \" \"+this.position;\r\n }\r\n break;\r\n }\r\n return classList;\r\n }\r\n\r\n constructor() {\r\n super();\r\n this.role = \"navigation\";\r\n this.expansionChange.pipe(takeUntilDestroyed()).subscribe(state => this._expanded.set(state));\r\n }\r\n\r\n protected generateId(): string {\r\n return `cute-navbar-${++nextId}`;\r\n }\r\n\r\n override ngAfterContentInit() {\r\n super.ngAfterContentInit();\r\n\r\n const count = this.navContent?.length || 0;\r\n if (count > 1 && isDevMode()) {\r\n throw new Error(\"More than one 'cute-navbar-content' elements are found in the 'cute-navbar' component.\");\r\n }\r\n }\r\n\r\n}\r\n","/**\r\n * @license Apache-2.0\r\n *\r\n * Copyright (c) 2025 CuteWidgets Team. All Rights Reserved.\r\n *\r\n * You may not use this file except in compliance with the License\r\n * that can be found at http://www.apache.org/licenses/LICENSE-2.0\r\n */\r\nimport {Directive} from \"@angular/core\";\r\n\r\n/**\r\n * Subcomponent for company, product, or project name\r\n */\r\n@Directive({\r\n selector: '[cuteNavbarBrand], [cute-navbar-brand]',\r\n exportAs: 'cuteNavbarBrand',\r\n host: {\r\n 'class': 'cute-navbar-brand navbar-brand'\r\n },\r\n standalone: true,\r\n})\r\nexport class CuteNavbarBrand {}\r\n","/**\r\n * @license Apache-2.0\r\n *\r\n * Copyright (c) 2025 CuteWidgets Team. All Rights Reserved.\r\n *\r\n * You may not use this file except in compliance with the License\r\n * that can be found at http://www.apache.org/licenses/LICENSE-2.0\r\n */\r\nimport {booleanAttribute, Directive, Input} from \"@angular/core\";\r\nimport {CuteNav, CUTE_NAV} from \"@cute-widgets/base/core/nav\";\r\n\r\n@Directive({\r\n selector: '[cuteNavbarNav], [cute-navbar-nav]',\r\n exportAs: 'cuteNavbarNav',\r\n host: {\r\n 'class': 'cute-navbar-nav navbar-nav align-items-start',\r\n '[class.navbar-nav-scroll]': 'scrollable',\r\n '[style.--bs-scroll-height]': 'scrollHeight',\r\n },\r\n standalone: true,\r\n providers: [{provide: CUTE_NAV, useExisting: CuteNavbarNav}],\r\n})\r\nexport class CuteNavbarNav extends CuteNav {\r\n\r\n /**\r\n * Enable/disable vertical scrolling within the toggleable contents of a collapsed `navbar`.\r\n * By default, scrolling kicks in at 75vh (or 75% of the viewport height).\r\n */\r\n @Input({transform: booleanAttribute}) scrollable: boolean = false;\r\n\r\n /** The minimum height of the expanded content that triggers the scrolling mode when `scrollable` property is enabled. Default is **75vh**. */\r\n @Input()\r\n get scrollHeight(): string | undefined {return this._scrollHeight;}\r\n set scrollHeight(value: string | number | undefined) {\r\n if (value !== this._scrollHeight) {\r\n if (typeof value===\"number\") {\r\n value = `${value}px`;\r\n }\r\n this._scrollHeight = value;\r\n }\r\n }\r\n private _scrollHeight: string | undefined;\r\n\r\n constructor() {\r\n super();\r\n }\r\n\r\n}\r\n","/**\r\n * @license Apache-2.0\r\n *\r\n * Copyright (c) 2025 CuteWidgets Team. All Rights Reserved.\r\n *\r\n * You may not use this file except in compliance with the License\r\n * that can be found at http://www.apache.org/licenses/LICENSE-2.0\r\n */\r\nimport {Directive} from \"@angular/core\";\r\n\r\n/**\r\n * This directive adjusts vertical alignment and horizontal spacing for strings of text.\r\n */\r\n@Directive({\r\n selector: 'cute-navbar-text, [cuteNavbarText], [cute-navbar-text]',\r\n exportAs: 'cuteNavbarText',\r\n host: {\r\n 'class': 'navbar-text'\r\n },\r\n standalone: true,\r\n})\r\nexport class CuteNavbarText {}\r\n","/**\r\n * @license Apache-2.0\r\n *\r\n * Copyright (c) 2025 CuteWidgets Team. All Rights Reserved.\r\n *\r\n * You may not use this file except in compliance with the License\r\n * that can be found at http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * This code is a modification of the `@angular/material` original\r\n * code licensed under MIT-style License (https://angular.dev/license).\r\n */\r\nimport {Directive} from \"@angular/core\";\r\nimport {CuteCollapseTrigger} from \"@cute-widgets/base/collapse\";\r\n\r\n@Directive({\r\n selector: '[cuteNavbarToggler], [cute-navbar-toggler]',\r\n exportAs: 'cuteNavbarToggler',\r\n host: {\r\n 'class': 'navbar-toggler border-secondary-subtle',\r\n 'type': 'button',\r\n },\r\n hostDirectives: [\r\n {\r\n directive: CuteCollapseTrigger,\r\n inputs: ['cuteCollapseTriggerFor:cuteNavbarTogglerFor'],\r\n outputs: [],\r\n }\r\n ],\r\n standalone: true,\r\n})\r\nexport class CuteNavbarToggler {}\r\n","/**\r\n * @license Apache-2.0\r\n *\r\n * Copyright (c) 2025 CuteWidgets Team. All Rights Reserved.\r\n *\r\n * You may not use this file except in compliance with the License\r\n * that can be found at http://www.apache.org/licenses/LICENSE-2.0\r\n */\r\nimport { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport {CuteNavbar} from \"./navbar.component\";\r\nimport {CuteNavbarBrand} from \"./navbar-brand.directive\";\r\nimport {CuteNavbarContent} from \"./navbar-content.component\";\r\nimport {CuteNavbarToggler} from \"./navbar-toggler.directive\";\r\nimport {CuteNavbarNav} from \"./navbar-nav.directive\";\r\nimport {CuteNavbarText} from \"./navbar-text.directive\";\r\n\r\n@NgModule({\r\n declarations: [],\r\n imports: [\r\n CommonModule,\r\n CuteNavbar,\r\n CuteNavbarBrand,\r\n CuteNavbarContent,\r\n CuteNavbarNav,\r\n CuteNavbarText,\r\n CuteNavbarToggler,\r\n ],\r\n exports: [\r\n CuteNavbar,\r\n CuteNavbarBrand,\r\n CuteNavbarContent,\r\n CuteNavbarNav,\r\n CuteNavbarText,\r\n CuteNavbarToggler,\r\n ],\r\n providers: [],\r\n})\r\nexport class CuteNavbarModule { }\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,485 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Injectable, InjectionToken, numberAttribute, EventEmitter, booleanAttribute, Output, Input, Optional, Inject, ViewEncapsulation, ChangeDetectionStrategy, Component, NgModule } from '@angular/core';
3
+ import { CuteFormField, CuteLabel } from '@cute-widgets/base/form-field';
4
+ import { CuteSelect } from '@cute-widgets/base/select';
5
+ import { CuteTooltip } from '@cute-widgets/base/tooltip';
6
+ import { CuteFocusableControl } from '@cute-widgets/base/abstract';
7
+ import { CuteOption } from '@cute-widgets/base/core/option';
8
+ import { Subject } from 'rxjs';
9
+ import { CommonModule } from '@angular/common';
10
+
11
+ /**
12
+ * @license Apache-2.0
13
+ *
14
+ * Copyright (c) 2025 CuteWidgets Team. All Rights Reserved.
15
+ *
16
+ * You may not use this file except in compliance with the License
17
+ * that can be found at http://www.apache.org/licenses/LICENSE-2.0
18
+ *
19
+ * This code is a modification of the `@angular/material` original
20
+ * code licensed under MIT-style License (https://angular.dev/license).
21
+ */
22
+ /**
23
+ * To modify the labels and text displayed, create a new instance of CutePaginatorIntl and
24
+ * include it in a custom provider
25
+ */
26
+ class CutePaginatorIntl {
27
+ constructor() {
28
+ /**
29
+ * Stream to emit from when labels are changed. Use this to notify components when the labels have
30
+ * changed after initialization.
31
+ */
32
+ this.changes = new Subject();
33
+ /** A label for the page size selector. */
34
+ this.itemsPerPageLabel = 'Items per page:';
35
+ /** A label for the button that increments the current page. */
36
+ this.nextPageLabel = 'Next';
37
+ /** A hint for the button that increments the current page. */
38
+ this.nextPageLabelHint = 'Next page';
39
+ /** A label for the button that decrements the current page. */
40
+ this.previousPageLabel = 'Previous';
41
+ /** A hint for the button that decrements the current page. */
42
+ this.previousPageLabelHint = 'Previous page';
43
+ /** A label for the button that moves to the first page. */
44
+ this.firstPageLabel = 'First';
45
+ /** A hint for the button that moves to the first page. */
46
+ this.firstPageLabelHint = 'First page';
47
+ /** A label for the button that moves to the last page. */
48
+ this.lastPageLabel = 'Last';
49
+ /** A hint for the button that moves to the last page. */
50
+ this.lastPageLabelHint = 'Last page';
51
+ /** A label for the range of items within the current page and the length of the whole list. */
52
+ this.getRangeLabel = (page, pageSize, length) => {
53
+ let range = "0";
54
+ if (length != 0 && pageSize != 0) {
55
+ length = Math.max(length, 0);
56
+ const startIndex = page * pageSize;
57
+ // If the start index exceeds the list length, do not try and fix the end index to the end.
58
+ const endIndex = startIndex < length ? Math.min(startIndex + pageSize, length) : startIndex + pageSize;
59
+ range = `${startIndex + 1} – ${endIndex}`;
60
+ }
61
+ return `${range} of ${length}`;
62
+ };
63
+ }
64
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CutePaginatorIntl, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
65
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CutePaginatorIntl, providedIn: 'root' }); }
66
+ }
67
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CutePaginatorIntl, decorators: [{
68
+ type: Injectable,
69
+ args: [{ providedIn: 'root' }]
70
+ }] });
71
+
72
+ /**
73
+ * @license Apache-2.0
74
+ *
75
+ * Copyright (c) 2025 CuteWidgets Team. All Rights Reserved.
76
+ *
77
+ * You may not use this file except in compliance with the License
78
+ * that can be found at http://www.apache.org/licenses/LICENSE-2.0
79
+ *
80
+ * This code is a modification of the `@angular/material` original
81
+ * code licensed under MIT-style License (https://angular.dev/license).
82
+ */
83
+ /** The default page size if there is no page size and there are no provided page size options. */
84
+ const DEFAULT_PAGE_SIZE = 50;
85
+ /** Maximum visible page indexes */
86
+ const MAX_VISIBLE_PAGES = 5;
87
+ /** Injection token that can be used to provide the default options for the paginator module. */
88
+ const CUTE_PAGINATOR_DEFAULT_OPTIONS = new InjectionToken('CUTE_PAGINATOR_DEFAULT_OPTIONS');
89
+ let nextUniqueId = 0;
90
+ /**
91
+ * Component to provide navigation between paged information. Displays the size of the current
92
+ * page, user-selectable options to change that size, what items are being shown, and
93
+ * navigational button to go to the previous or next page.
94
+ */
95
+ class CutePaginator extends CuteFocusableControl {
96
+ /** The zero-based page index of the displayed list of items. Defaulted to 0. */
97
+ get pageIndex() { return this._pageIndex; }
98
+ set pageIndex(value) {
99
+ const oldIndex = this._pageIndex;
100
+ if (oldIndex != value) {
101
+ this._pageIndex = Math.max(value || 0, 0);
102
+ this._updateFirstLastVisibleIndexes(this._pageIndex, oldIndex);
103
+ this.markForCheck();
104
+ }
105
+ }
106
+ /** The total number of items that are being paginated. Defaulted to 0. */
107
+ get length() { return this._length; }
108
+ set length(value) {
109
+ this._length = value || 0;
110
+ this.markForCheck();
111
+ }
112
+ /** Number of items to display on a page. By default, set to 50. */
113
+ get pageSize() { return this._pageSize; }
114
+ set pageSize(value) {
115
+ this._pageSize = Math.max(value || 0, 0);
116
+ this._updateDisplayedPageSizeOptions();
117
+ }
118
+ /** The set of provided page size options to display to the user. */
119
+ get pageSizeOptions() { return this._pageSizeOptions; }
120
+ set pageSizeOptions(value) {
121
+ this._pageSizeOptions = (value || []).map(p => numberAttribute(p, 0));
122
+ this._updateDisplayedPageSizeOptions();
123
+ }
124
+ constructor(_intl, defaults) {
125
+ super();
126
+ this._intl = _intl;
127
+ this._firstVisiblePageIndex = 0;
128
+ this._lastVisiblePageIndex = NaN;
129
+ /** If set, styles the "page size" form field with the designated style. */
130
+ //_formFieldAppearance?: CuteFormFieldAppearance;
131
+ /** ID for the DOM node containing the pagination's items per-page label. */
132
+ this._pageSizeLabelId = `cute-paginator-page-size-label-${nextUniqueId++}`;
133
+ this.hideActive = false;
134
+ this._pageIndex = 0;
135
+ this._length = 0;
136
+ this._pageSize = 0;
137
+ this._pageSizeOptions = [];
138
+ /** Whether to hide the page size selection UI from the user. */
139
+ this.hidePageSize = false;
140
+ /** Whether to show the first/last buttons UI to the user. */
141
+ this.showFirstLastButtons = false;
142
+ /** Whether to change the previous/next buttons UI with a text labels */
143
+ this.showPrevNextLabels = false;
144
+ /** Whether to hide all internal borders in the paginator */
145
+ this.hideBorders = false;
146
+ /** Style of the pagination's middle section. Note that previous/next buttons are always shown. */
147
+ this.middleSectionStyle = 'range';
148
+ /** Changes the alignment of the pagination sections in the parent container */
149
+ this.alignment = "between";
150
+ /** Used to configure the underlying `CuteSelect` inside the paginator. */
151
+ this.selectConfig = {};
152
+ /** Event emitted when the paginator changes the page size or page index. */
153
+ this.page = new EventEmitter();
154
+ /** Displayed a set of page size options. Will be sorted and include the current page size. */
155
+ this._displayedPageSizeOptions = [];
156
+ this.isNaN = isNaN;
157
+ this.onmousedown = onmousedown;
158
+ this._intlChanges = _intl.changes.subscribe(() => this.markForCheck());
159
+ if (defaults) {
160
+ const { pageSize, pageSizeOptions, hidePageSize, showFirstLastButtons, showPrevNextLabels, hideBorders, } = defaults;
161
+ if (pageSize != null) {
162
+ this._pageSize = pageSize;
163
+ }
164
+ if (pageSizeOptions != null) {
165
+ this._pageSizeOptions = pageSizeOptions;
166
+ }
167
+ if (hidePageSize != null) {
168
+ this.hidePageSize = hidePageSize;
169
+ }
170
+ if (showFirstLastButtons != null) {
171
+ this.showFirstLastButtons = showFirstLastButtons;
172
+ }
173
+ if (showPrevNextLabels != null) {
174
+ this.showPrevNextLabels = showPrevNextLabels;
175
+ }
176
+ if (hideBorders != null) {
177
+ this.hideBorders = hideBorders;
178
+ }
179
+ }
180
+ //this._formFieldAppearance = defaults?.formFieldAppearance || 'outline';
181
+ }
182
+ generateId() {
183
+ return `cute-paginator-${nextUniqueId++}`;
184
+ }
185
+ ngOnInit() {
186
+ super.ngOnInit();
187
+ this._updateDisplayedPageSizeOptions();
188
+ }
189
+ ngOnChanges(changes) {
190
+ super.ngOnChanges(changes);
191
+ this._updateFirstLastVisibleIndexes(this.pageIndex, this.pageIndex);
192
+ }
193
+ ngAfterViewChecked() {
194
+ this.hideActive = false;
195
+ }
196
+ ngOnDestroy() {
197
+ super.ngOnDestroy();
198
+ this._intlChanges.unsubscribe();
199
+ }
200
+ onMouseDown(event) {
201
+ if (this.middleSectionStyle == "5-pages") {
202
+ this.hideActive = true;
203
+ this._changeDetectorRef.detectChanges();
204
+ }
205
+ }
206
+ /** Whether the specified index is the `active` page of the paginator */
207
+ isActivePage(index) {
208
+ return index == this.pageIndex;
209
+ }
210
+ _updateFirstLastVisibleIndexes(newIndex, oldIndex) {
211
+ if (this.middleSectionStyle != "5-pages") {
212
+ return;
213
+ }
214
+ const numPages = this.getNumberOfPages();
215
+ if (numPages > 0 && (newIndex >= 0 && newIndex < numPages)) {
216
+ const numVisiblePages = Math.min(numPages, MAX_VISIBLE_PAGES);
217
+ const middleIndex = this._firstVisiblePageIndex + Math.ceil(numVisiblePages / 2) - 1;
218
+ if (newIndex <= middleIndex && numPages <= numVisiblePages) {
219
+ this._firstVisiblePageIndex = 0;
220
+ this._lastVisiblePageIndex = numVisiblePages - 1;
221
+ }
222
+ else if (newIndex == (numPages - 1)) {
223
+ this._firstVisiblePageIndex = newIndex - numVisiblePages + 1;
224
+ this._lastVisiblePageIndex = newIndex;
225
+ }
226
+ else if (newIndex > middleIndex) {
227
+ // go forward
228
+ this._lastVisiblePageIndex += newIndex - middleIndex;
229
+ this._lastVisiblePageIndex = Math.min(this._lastVisiblePageIndex, numPages - 1);
230
+ this._firstVisiblePageIndex = this._lastVisiblePageIndex - numVisiblePages + 1;
231
+ this._firstVisiblePageIndex = Math.max(this._firstVisiblePageIndex, 0);
232
+ }
233
+ else if (newIndex < middleIndex) {
234
+ // go backward
235
+ this._firstVisiblePageIndex -= middleIndex - newIndex;
236
+ this._firstVisiblePageIndex = Math.max(this._firstVisiblePageIndex, 0);
237
+ this._lastVisiblePageIndex = this._firstVisiblePageIndex + numVisiblePages - 1;
238
+ }
239
+ }
240
+ }
241
+ /** Advances to the next page if it exists. */
242
+ nextPage() {
243
+ if (!this.hasNextPage()) {
244
+ return;
245
+ }
246
+ const previousPageIndex = this.pageIndex;
247
+ this.pageIndex = this.pageIndex + 1;
248
+ this._emitPageEvent(previousPageIndex);
249
+ }
250
+ /** Move back to the previous page if it exists. */
251
+ previousPage() {
252
+ if (!this.hasPreviousPage()) {
253
+ return;
254
+ }
255
+ const previousPageIndex = this.pageIndex;
256
+ this.pageIndex = this.pageIndex - 1;
257
+ this._emitPageEvent(previousPageIndex);
258
+ }
259
+ /** Move to the first page if not already there. */
260
+ firstPage() {
261
+ // hasPreviousPage being false implies at the start
262
+ if (!this.hasPreviousPage()) {
263
+ return;
264
+ }
265
+ const previousPageIndex = this.pageIndex;
266
+ this.pageIndex = 0;
267
+ this._emitPageEvent(previousPageIndex);
268
+ }
269
+ /** Move to the last page if not already there. */
270
+ lastPage() {
271
+ // hasNextPage being false implies at the end
272
+ if (!this.hasNextPage()) {
273
+ return;
274
+ }
275
+ const previousPageIndex = this.pageIndex;
276
+ this.pageIndex = this.getNumberOfPages() - 1;
277
+ this._emitPageEvent(previousPageIndex);
278
+ }
279
+ /**
280
+ * Move to the page with the specified index
281
+ * @param index Zero based page number to move
282
+ */
283
+ gotoPage(index) {
284
+ if (index >= 0 && index < this.getNumberOfPages() && !this.isActivePage(index)) {
285
+ const previousPageIndex = this.pageIndex;
286
+ this.pageIndex = index;
287
+ this._emitPageEvent(previousPageIndex);
288
+ }
289
+ }
290
+ /** Whether there is a previous page. */
291
+ hasPreviousPage() {
292
+ return this.pageIndex >= 1 && this.pageSize != 0;
293
+ }
294
+ /** Whether there is a next page. */
295
+ hasNextPage() {
296
+ const maxPageIndex = this.getNumberOfPages() - 1;
297
+ return this.pageIndex < maxPageIndex && this.pageSize != 0;
298
+ }
299
+ /** Calculate the number of pages */
300
+ getNumberOfPages() {
301
+ if (!this.pageSize) {
302
+ return 0;
303
+ }
304
+ return Math.ceil(this.length / this.pageSize);
305
+ }
306
+ /** Whether the paginator hasn't any page to paginate */
307
+ empty() {
308
+ return this.getNumberOfPages() == 0;
309
+ }
310
+ /** Transforms the calculated total pages' value to an array of page numbers */
311
+ getPageNumbers() {
312
+ let count = this.getNumberOfPages();
313
+ if (count == 0) {
314
+ return [];
315
+ }
316
+ let pages = [];
317
+ if (this.middleSectionStyle == "5-pages") {
318
+ if (isNaN(this._lastVisiblePageIndex)) {
319
+ return [];
320
+ }
321
+ count = this._lastVisiblePageIndex - this._firstVisiblePageIndex + 1;
322
+ pages = Array(count);
323
+ for (let i = 0; i < count; i++) {
324
+ pages[i] = i + this._firstVisiblePageIndex;
325
+ }
326
+ }
327
+ else {
328
+ pages = Array(count);
329
+ for (let i = 0; i < count; i++) {
330
+ pages[i] = i;
331
+ }
332
+ }
333
+ return pages;
334
+ }
335
+ /**
336
+ * Changes the page size so that the first item displayed on the page will still be
337
+ * displayed using the new page size.
338
+ *
339
+ * For example, if the page size is 10 and on the second page (items indexed 10-19), then
340
+ * switching so that the page size is 5 will set the third page as the current page so
341
+ * that the 10th item will still be displayed.
342
+ */
343
+ _changePageSize(pageSize) {
344
+ // The current page needs to be updated to reflect the new page size. Navigate to the page
345
+ // containing the previous page's first item.
346
+ const startIndex = this.pageIndex * this.pageSize;
347
+ const previousPageIndex = this.pageIndex;
348
+ this.pageIndex = Math.floor(startIndex / pageSize) || 0;
349
+ this.pageSize = pageSize;
350
+ this._updateFirstLastVisibleIndexes(this.pageIndex, previousPageIndex);
351
+ this.markForCheck();
352
+ this._emitPageEvent(previousPageIndex);
353
+ }
354
+ /** Checks whether the buttons for going forwards should be disabled. */
355
+ _nextButtonDisabled() {
356
+ return this.disabled || !this.hasNextPage();
357
+ }
358
+ /** Checks whether the buttons for going backwards should be disabled. */
359
+ _previousButtonDisabled() {
360
+ return this.disabled || !this.hasPreviousPage();
361
+ }
362
+ _getMagnitudeCssClass() {
363
+ if (this.magnitude == "large") {
364
+ return "pagination-lg";
365
+ }
366
+ else if (this.magnitude == "small") {
367
+ return "pagination-sm";
368
+ }
369
+ return "";
370
+ }
371
+ /**
372
+ * Updates the list of page size options to display to the user. Includes making sure that
373
+ * the page size is an option and that the list is sorted.
374
+ */
375
+ _updateDisplayedPageSizeOptions() {
376
+ if (!this.isInitialized) {
377
+ return;
378
+ }
379
+ // If no page size is provided, use the first page size option or the default page size.
380
+ if (!this.pageSize) {
381
+ this._pageSize =
382
+ this.pageSizeOptions.length != 0 ? this.pageSizeOptions[0] : DEFAULT_PAGE_SIZE;
383
+ }
384
+ this._displayedPageSizeOptions = this.pageSizeOptions.slice();
385
+ if (this._displayedPageSizeOptions.indexOf(this.pageSize) === -1) {
386
+ this._displayedPageSizeOptions.push(this.pageSize);
387
+ }
388
+ // Sort the numbers using a number-specific sort function.
389
+ this._displayedPageSizeOptions.sort((a, b) => a - b);
390
+ this.markForCheck();
391
+ }
392
+ /** Emits an event notifying that a change of the paginator's properties has been triggered. */
393
+ _emitPageEvent(previousPageIndex) {
394
+ this.page.emit({
395
+ previousPageIndex,
396
+ pageIndex: this.pageIndex,
397
+ pageSize: this.pageSize,
398
+ length: this.length,
399
+ });
400
+ }
401
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CutePaginator, deps: [{ token: CutePaginatorIntl }, { token: CUTE_PAGINATOR_DEFAULT_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
402
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.15", type: CutePaginator, isStandalone: true, selector: "cute-paginator", inputs: { pageIndex: ["pageIndex", "pageIndex", numberAttribute], length: ["length", "length", numberAttribute], pageSize: ["pageSize", "pageSize", numberAttribute], pageSizeOptions: "pageSizeOptions", hidePageSize: ["hidePageSize", "hidePageSize", booleanAttribute], showFirstLastButtons: ["showFirstLastButtons", "showFirstLastButtons", booleanAttribute], showPrevNextLabels: ["showPrevNextLabels", "showPrevNextLabels", booleanAttribute], hideBorders: ["hideBorders", "hideBorders", booleanAttribute], middleSectionStyle: "middleSectionStyle", alignment: "alignment", magnitude: "magnitude", selectConfig: "selectConfig" }, outputs: { page: "page" }, host: { attributes: { "tabindex": "-1", "role": "group" }, properties: { "class.pe-none": "disabled", "class.opacity-75": "disabled", "class": "alignment ? \"justify-content-\"+alignment : undefined" }, classAttribute: "cute-paginator" }, exportAs: ["cutePaginator"], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "@if (!hidePageSize) {\r\n <div class=\"page-size\">\r\n\r\n <cute-label class=\"page-size-label\"\r\n [magnitude]=\"magnitude\"\r\n [attr.id]=\"_pageSizeLabelId\">\r\n {{_intl.itemsPerPageLabel}}\r\n </cute-label>\r\n\r\n @if (_displayedPageSizeOptions.length > 1) {\r\n\r\n <cute-form-field\r\n class=\"page-size-select\"\r\n [class.me-auto]=\"true\"\r\n subscriptSizing=\"dynamic\"\r\n [color]=\"color\">\r\n\r\n <cute-select\r\n [value]=\"pageSize\"\r\n [disabled]=\"disabled\"\r\n [color]=\"color\"\r\n [magnitude]=\"magnitude\"\r\n [aria-labelledby]=\"_pageSizeLabelId\"\r\n [panelClass]=\"selectConfig.panelClass || 'shadow-lg'\"\r\n [disableOptionCentering]=\"selectConfig.disableOptionCentering\"\r\n (selectionChange)=\"_changePageSize($event.value)\"\r\n hideSingleSelectionIndicator>\r\n @for (pageSizeOption of _displayedPageSizeOptions; track pageSizeOption) {\r\n <cute-option [value]=\"pageSizeOption\">\r\n {{pageSizeOption}}\r\n </cute-option>\r\n }\r\n </cute-select>\r\n </cute-form-field>\r\n } @else {\r\n <div class=\"page-size-value\">{{pageSize}}</div>\r\n }\r\n </div>\r\n}\r\n\r\n<nav [attr.aria-label]=\"ariaLabel\">\r\n\r\n <ul class=\"pagination\"\r\n [class]=\"_getMagnitudeCssClass()+(alignment=='between' ? '' : ' justify-content-'+alignment)\"\r\n [class.gap-1]=\"hideBorders\"\r\n [style.--bs-focus-ring-color]='color ? \"rgba(var(--bs-\"+color+\"-rgb), var(--bs-focus-ring-opacity))\" : \"\"'\r\n [style.--bs-pagination-color]='color ? \"var(--bs-\"+color+\")\" : \"\"'\r\n [style.--bs-pagination-active-bg]='color ? \"var(--bs-\"+color+\")\" : \"\"'\r\n [style.--bs-pagination-active-border-color]='color ? \"rgb(var(--bs-\"+color+\"-rgb))\" : \"\"'\r\n [style.--bs-pagination-border-width]=\"hideBorders ? 0 : undefined\"\r\n >\r\n @if (showFirstLastButtons) {\r\n <li class=\"page-item page-first\">\r\n <a class=\"page-link\"\r\n [tabindex]=\"_previousButtonDisabled() ? -1 : 0\"\r\n [class.disabled]=\"_previousButtonDisabled()\"\r\n [class]=\"color && !_previousButtonDisabled() ? 'link-'+color : ''\"\r\n [class.focus-ring]=\"color != null\"\r\n [style.float]=\"'left'\"\r\n [attr.aria-label]=\"_intl.firstPageLabelHint || _intl.firstPageLabel\"\r\n [cuteTooltip]=\"_intl.firstPageLabelHint || _intl.firstPageLabel\"\r\n [cuteTooltipDisabled]=\"_previousButtonDisabled()\"\r\n [cuteTooltipPosition]=\"'above'\"\r\n (click)=\"firstPage()\"\r\n (keydown.space)=\"firstPage();$event.preventDefault();\"\r\n >\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\"\r\n fill=\"currentColor\" class=\"bi bi-chevron-double-left\"\r\n viewBox=\"0 0 16 16\"\r\n focusable=\"false\" aria-hidden=\"true\">\r\n <path fill-rule=\"evenodd\" d=\"M8.354 1.646a.5.5 0 0 1 0 .708L2.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"/>\r\n <path fill-rule=\"evenodd\" d=\"M12.354 1.646a.5.5 0 0 1 0 .708L6.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"/>\r\n </svg>\r\n </a>\r\n </li>\r\n }\r\n\r\n <li class=\"page-item\" [class.me-auto]=\"alignment=='between'\">\r\n <a class=\"page-link page-prev rounded-start-1\"\r\n [tabindex]=\"_previousButtonDisabled() ? -1 : 0\"\r\n [class]=\"color && !_previousButtonDisabled() ? 'link-'+color : ''\"\r\n [class.disabled]=\"_previousButtonDisabled()\"\r\n [class.focus-ring]=\"color != null\"\r\n [class.rounded-start-1]=\"hideBorders\"\r\n [attr.aria-label]=\"_intl.previousPageLabelHint || _intl.previousPageLabel\"\r\n [cuteTooltip]=\"_intl.previousPageLabelHint || _intl.previousPageLabel\"\r\n [cuteTooltipDisabled]=\"_previousButtonDisabled()\"\r\n [cuteTooltipPosition]=\"'above'\"\r\n (mousedown)=\"onMouseDown($event)\"\r\n (click)=\"previousPage()\"\r\n (keydown.space)=\"previousPage();$event.preventDefault();\"\r\n >\r\n @if (showPrevNextLabels) {\r\n {{_intl.previousPageLabel}}\r\n } @else {\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\"\r\n fill=\"currentColor\" class=\"bi bi-chevron-left\"\r\n viewBox=\"0 0 16 16\"\r\n focusable=\"false\" aria-hidden=\"true\">\r\n <path fill-rule=\"evenodd\" d=\"M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"/>\r\n </svg>\r\n }\r\n </a>\r\n </li>\r\n\r\n @if (middleSectionStyle.endsWith('pages')) {\r\n @for (pageNo of getPageNumbers(); track pageNo) {\r\n <li class=\"page-item\">\r\n <a [attr.tabindex]=\"isNaN(pageNo)?-1:0\"\r\n class=\"page-link page-number\"\r\n [class.active]=\"isActivePage(pageNo) && !hideActive\"\r\n [class.shadow]=\"isActivePage(pageNo) && !hideActive\"\r\n [class.rounded-1]=\"hideBorders\"\r\n [class]=\"color && !isActivePage(pageNo) ? 'link-'+color : ''\"\r\n [class.focus-ring]=\"color != null\"\r\n [attr.aria-current]=\"isActivePage(pageNo) ? 'page' : ''\"\r\n (mousedown)=\"onMouseDown($event)\"\r\n (click)=\"gotoPage(pageNo);\"\r\n (keydown.space)=\"gotoPage(pageNo);$event.preventDefault();\"\r\n >\r\n {{pageNo + 1}}\r\n </a>\r\n </li>\r\n }\r\n\r\n } @else if (middleSectionStyle=='range') {\r\n <li class=\"cute-paginator-range-label\"\r\n [class]=\"color ? 'link-'+color : ''\"\r\n aria-live=\"polite\">\r\n {{_intl.getRangeLabel(pageIndex, pageSize, length)}}\r\n </li>\r\n }\r\n\r\n <li class=\"page-item\" [class.ms-auto]=\"alignment=='between'\">\r\n <a class=\"page-link page-next rounded-end-1\"\r\n [tabindex]=\"_nextButtonDisabled() ? -1 : 0\"\r\n [class]=\"color && !_nextButtonDisabled() ? 'link-'+color : ''\"\r\n [class.disabled]=\"_nextButtonDisabled()\"\r\n [class.focus-ring]=\"color != null\"\r\n [class.rounded-end-1]=\"hideBorders\"\r\n [attr.aria-label]=\"_intl.nextPageLabelHint || _intl.nextPageLabel\"\r\n [cuteTooltip]=\"_intl.nextPageLabelHint || _intl.nextPageLabel\"\r\n [cuteTooltipDisabled]=\"_nextButtonDisabled()\"\r\n [cuteTooltipPosition]=\"'above'\"\r\n (mousedown)=\"onMouseDown($event)\"\r\n (click)=\"nextPage()\"\r\n (keydown.space)=\"nextPage();$event.preventDefault();\"\r\n >\r\n @if (showPrevNextLabels) {\r\n {{_intl.nextPageLabel}}\r\n } @else {\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\"\r\n fill=\"currentColor\" class=\"bi bi-chevron-right\"\r\n viewBox=\"0 0 16 16\"\r\n focusable=\"false\" aria-hidden=\"true\">\r\n <path fill-rule=\"evenodd\" d=\"M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z\"/>\r\n </svg>\r\n }\r\n </a>\r\n </li>\r\n\r\n @if (showFirstLastButtons) {\r\n <li class=\"page-item\">\r\n <a class=\"page-link page-last\"\r\n [tabindex]=\"_nextButtonDisabled() ? -1 : 0\"\r\n [class.disabled]=\"_nextButtonDisabled()\"\r\n [class]=\"color && !_nextButtonDisabled() ? 'link-'+color : ''\"\r\n [class.focus-ring]=\"color != null\"\r\n [attr.aria-label]=\"_intl.lastPageLabelHint || _intl.lastPageLabel\"\r\n [cuteTooltip]=\"_intl.lastPageLabelHint || _intl.lastPageLabel\"\r\n [cuteTooltipDisabled]=\"_nextButtonDisabled()\"\r\n [cuteTooltipPosition]=\"'above'\"\r\n (click)=\"lastPage()\"\r\n (keydown.space)=\"lastPage();$event.preventDefault();\"\r\n >\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\"\r\n fill=\"currentColor\" class=\"bi bi-chevron-double-right\"\r\n viewBox=\"0 0 16 16\"\r\n focusable=\"false\" aria-hidden=\"true\">\r\n <path fill-rule=\"evenodd\" d=\"M3.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L9.293 8 3.646 2.354a.5.5 0 0 1 0-.708z\"/>\r\n <path fill-rule=\"evenodd\" d=\"M7.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L13.293 8 7.646 2.354a.5.5 0 0 1 0-.708z\"/>\r\n </svg>\r\n </a>\r\n </li>\r\n }\r\n </ul>\r\n</nav>\r\n", styles: [".cute-paginator{display:flex;max-width:100%;align-items:center;gap:.5rem}.cute-paginator .page-size{display:flex;font-size:var(--bs-pagination-font-size);color:var(--bs-pagination-color);background-color:var(--bs-pagination-bg);align-items:center}.cute-paginator .page-size .page-size-label{margin-right:.25rem;overflow:hidden;white-space:nowrap;text-align:center;text-overflow:ellipsis}.cute-paginator .page-size .page-size-select{width:6rem;padding:0 .25rem}.cute-paginator .pagination{align-items:center;margin:0;--bs-pagination-color: var(--bs-secondary-color)}.cute-paginator .pagination .page-item{cursor:pointer}.cute-paginator .pagination .page-item:has(.page-prev,.page-next){display:grid}.cute-paginator .pagination .page-item .page-link{-webkit-user-select:none;user-select:none}.cute-paginator .pagination .page-item .page-link:not(:has(>svg)){white-space:nowrap;text-align:center;text-overflow:ellipsis}.cute-paginator .pagination .page-item:has(.page-link.disabled,.disabled>.page-link){cursor:auto}[dir=rtl] .cute-paginator .pagination .page-item:last-child .page-link{border-radius:var(--bs-pagination-border-radius) 0 0 var(--bs-pagination-border-radius)}[dir=rtl] .cute-paginator .pagination .page-item:last-child .page-link>svg{transform:rotate(180deg)}[dir=rtl] .cute-paginator .pagination .page-item:first-child .page-link{border-radius:0 var(--bs-pagination-border-radius) var(--bs-pagination-border-radius) 0}[dir=rtl] .cute-paginator .pagination .page-item:first-child .page-link>svg{transform:rotate(180deg)}[dir=rtl] .cute-paginator .pagination .page-item .page-next>svg,[dir=rtl] .cute-paginator .pagination .page-item .page-prev>svg{transform:rotate(180deg)}.cute-paginator .pagination .cute-paginator-range-label{display:inline-block;overflow:hidden;white-space:nowrap;text-align:center;text-overflow:ellipsis;text-decoration:none;min-width:7rem;padding:var(--bs-pagination-padding-y) var(--bs-pagination-padding-x);font-size:var(--bs-pagination-font-size);color:var(--bs-pagination-color);background-color:var(--bs-pagination-bg)}.cute-paginator .pagination-sm svg{width:.875rem}.cute-paginator .pagination-lg svg{width:1.25rem}\n"], dependencies: [{ kind: "component", type: CuteFormField, selector: "cute-form-field", inputs: ["hideValidStyle", "hideRequiredMarker", "magnitude", "floatLabel", "subscriptSizing", "hintLabel"], exportAs: ["cuteFormField"] }, { kind: "component", type: CuteSelect, selector: "cute-select", inputs: ["aria-describedby", "panelClass", "disableRipple", "hideSingleSelectionIndicator", "placeholder", "multiple", "disableOptionCentering", "compareWith", "value", "errorStateMatcher", "magnitude", "typeaheadDebounceInterval", "sortComparator", "panelWidth", "panelHeight", "canSelectNullableOptions"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["cuteSelect"] }, { kind: "directive", type: CuteTooltip, selector: "[cuteTooltip]", inputs: ["cuteTooltipPosition", "cuteTooltipPositionAtOrigin", "cuteTooltipDisabled", "cuteTooltipShowDelay", "cuteTooltipHideDelay", "cuteTooltipTouchGestures", "cuteTooltip", "cuteTooltipClass"], exportAs: ["cuteTooltip"] }, { kind: "component", type: CuteOption, selector: "cute-option", inputs: ["value"], outputs: ["onSelectionChange"], exportAs: ["cuteOption"] }, { kind: "directive", type: CuteLabel, selector: "cute-label", inputs: ["magnitude"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
403
+ }
404
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CutePaginator, decorators: [{
405
+ type: Component,
406
+ args: [{ selector: 'cute-paginator', exportAs: 'cutePaginator', host: {
407
+ 'class': 'cute-paginator',
408
+ '[class.pe-none]': 'disabled',
409
+ '[class.opacity-75]': 'disabled',
410
+ '[class]': 'alignment ? "justify-content-"+alignment : undefined',
411
+ 'tabindex': '-1',
412
+ 'role': 'group',
413
+ }, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, imports: [CuteFormField, CuteSelect, CuteTooltip, CuteOption, CuteLabel], template: "@if (!hidePageSize) {\r\n <div class=\"page-size\">\r\n\r\n <cute-label class=\"page-size-label\"\r\n [magnitude]=\"magnitude\"\r\n [attr.id]=\"_pageSizeLabelId\">\r\n {{_intl.itemsPerPageLabel}}\r\n </cute-label>\r\n\r\n @if (_displayedPageSizeOptions.length > 1) {\r\n\r\n <cute-form-field\r\n class=\"page-size-select\"\r\n [class.me-auto]=\"true\"\r\n subscriptSizing=\"dynamic\"\r\n [color]=\"color\">\r\n\r\n <cute-select\r\n [value]=\"pageSize\"\r\n [disabled]=\"disabled\"\r\n [color]=\"color\"\r\n [magnitude]=\"magnitude\"\r\n [aria-labelledby]=\"_pageSizeLabelId\"\r\n [panelClass]=\"selectConfig.panelClass || 'shadow-lg'\"\r\n [disableOptionCentering]=\"selectConfig.disableOptionCentering\"\r\n (selectionChange)=\"_changePageSize($event.value)\"\r\n hideSingleSelectionIndicator>\r\n @for (pageSizeOption of _displayedPageSizeOptions; track pageSizeOption) {\r\n <cute-option [value]=\"pageSizeOption\">\r\n {{pageSizeOption}}\r\n </cute-option>\r\n }\r\n </cute-select>\r\n </cute-form-field>\r\n } @else {\r\n <div class=\"page-size-value\">{{pageSize}}</div>\r\n }\r\n </div>\r\n}\r\n\r\n<nav [attr.aria-label]=\"ariaLabel\">\r\n\r\n <ul class=\"pagination\"\r\n [class]=\"_getMagnitudeCssClass()+(alignment=='between' ? '' : ' justify-content-'+alignment)\"\r\n [class.gap-1]=\"hideBorders\"\r\n [style.--bs-focus-ring-color]='color ? \"rgba(var(--bs-\"+color+\"-rgb), var(--bs-focus-ring-opacity))\" : \"\"'\r\n [style.--bs-pagination-color]='color ? \"var(--bs-\"+color+\")\" : \"\"'\r\n [style.--bs-pagination-active-bg]='color ? \"var(--bs-\"+color+\")\" : \"\"'\r\n [style.--bs-pagination-active-border-color]='color ? \"rgb(var(--bs-\"+color+\"-rgb))\" : \"\"'\r\n [style.--bs-pagination-border-width]=\"hideBorders ? 0 : undefined\"\r\n >\r\n @if (showFirstLastButtons) {\r\n <li class=\"page-item page-first\">\r\n <a class=\"page-link\"\r\n [tabindex]=\"_previousButtonDisabled() ? -1 : 0\"\r\n [class.disabled]=\"_previousButtonDisabled()\"\r\n [class]=\"color && !_previousButtonDisabled() ? 'link-'+color : ''\"\r\n [class.focus-ring]=\"color != null\"\r\n [style.float]=\"'left'\"\r\n [attr.aria-label]=\"_intl.firstPageLabelHint || _intl.firstPageLabel\"\r\n [cuteTooltip]=\"_intl.firstPageLabelHint || _intl.firstPageLabel\"\r\n [cuteTooltipDisabled]=\"_previousButtonDisabled()\"\r\n [cuteTooltipPosition]=\"'above'\"\r\n (click)=\"firstPage()\"\r\n (keydown.space)=\"firstPage();$event.preventDefault();\"\r\n >\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\"\r\n fill=\"currentColor\" class=\"bi bi-chevron-double-left\"\r\n viewBox=\"0 0 16 16\"\r\n focusable=\"false\" aria-hidden=\"true\">\r\n <path fill-rule=\"evenodd\" d=\"M8.354 1.646a.5.5 0 0 1 0 .708L2.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"/>\r\n <path fill-rule=\"evenodd\" d=\"M12.354 1.646a.5.5 0 0 1 0 .708L6.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"/>\r\n </svg>\r\n </a>\r\n </li>\r\n }\r\n\r\n <li class=\"page-item\" [class.me-auto]=\"alignment=='between'\">\r\n <a class=\"page-link page-prev rounded-start-1\"\r\n [tabindex]=\"_previousButtonDisabled() ? -1 : 0\"\r\n [class]=\"color && !_previousButtonDisabled() ? 'link-'+color : ''\"\r\n [class.disabled]=\"_previousButtonDisabled()\"\r\n [class.focus-ring]=\"color != null\"\r\n [class.rounded-start-1]=\"hideBorders\"\r\n [attr.aria-label]=\"_intl.previousPageLabelHint || _intl.previousPageLabel\"\r\n [cuteTooltip]=\"_intl.previousPageLabelHint || _intl.previousPageLabel\"\r\n [cuteTooltipDisabled]=\"_previousButtonDisabled()\"\r\n [cuteTooltipPosition]=\"'above'\"\r\n (mousedown)=\"onMouseDown($event)\"\r\n (click)=\"previousPage()\"\r\n (keydown.space)=\"previousPage();$event.preventDefault();\"\r\n >\r\n @if (showPrevNextLabels) {\r\n {{_intl.previousPageLabel}}\r\n } @else {\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\"\r\n fill=\"currentColor\" class=\"bi bi-chevron-left\"\r\n viewBox=\"0 0 16 16\"\r\n focusable=\"false\" aria-hidden=\"true\">\r\n <path fill-rule=\"evenodd\" d=\"M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"/>\r\n </svg>\r\n }\r\n </a>\r\n </li>\r\n\r\n @if (middleSectionStyle.endsWith('pages')) {\r\n @for (pageNo of getPageNumbers(); track pageNo) {\r\n <li class=\"page-item\">\r\n <a [attr.tabindex]=\"isNaN(pageNo)?-1:0\"\r\n class=\"page-link page-number\"\r\n [class.active]=\"isActivePage(pageNo) && !hideActive\"\r\n [class.shadow]=\"isActivePage(pageNo) && !hideActive\"\r\n [class.rounded-1]=\"hideBorders\"\r\n [class]=\"color && !isActivePage(pageNo) ? 'link-'+color : ''\"\r\n [class.focus-ring]=\"color != null\"\r\n [attr.aria-current]=\"isActivePage(pageNo) ? 'page' : ''\"\r\n (mousedown)=\"onMouseDown($event)\"\r\n (click)=\"gotoPage(pageNo);\"\r\n (keydown.space)=\"gotoPage(pageNo);$event.preventDefault();\"\r\n >\r\n {{pageNo + 1}}\r\n </a>\r\n </li>\r\n }\r\n\r\n } @else if (middleSectionStyle=='range') {\r\n <li class=\"cute-paginator-range-label\"\r\n [class]=\"color ? 'link-'+color : ''\"\r\n aria-live=\"polite\">\r\n {{_intl.getRangeLabel(pageIndex, pageSize, length)}}\r\n </li>\r\n }\r\n\r\n <li class=\"page-item\" [class.ms-auto]=\"alignment=='between'\">\r\n <a class=\"page-link page-next rounded-end-1\"\r\n [tabindex]=\"_nextButtonDisabled() ? -1 : 0\"\r\n [class]=\"color && !_nextButtonDisabled() ? 'link-'+color : ''\"\r\n [class.disabled]=\"_nextButtonDisabled()\"\r\n [class.focus-ring]=\"color != null\"\r\n [class.rounded-end-1]=\"hideBorders\"\r\n [attr.aria-label]=\"_intl.nextPageLabelHint || _intl.nextPageLabel\"\r\n [cuteTooltip]=\"_intl.nextPageLabelHint || _intl.nextPageLabel\"\r\n [cuteTooltipDisabled]=\"_nextButtonDisabled()\"\r\n [cuteTooltipPosition]=\"'above'\"\r\n (mousedown)=\"onMouseDown($event)\"\r\n (click)=\"nextPage()\"\r\n (keydown.space)=\"nextPage();$event.preventDefault();\"\r\n >\r\n @if (showPrevNextLabels) {\r\n {{_intl.nextPageLabel}}\r\n } @else {\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\"\r\n fill=\"currentColor\" class=\"bi bi-chevron-right\"\r\n viewBox=\"0 0 16 16\"\r\n focusable=\"false\" aria-hidden=\"true\">\r\n <path fill-rule=\"evenodd\" d=\"M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z\"/>\r\n </svg>\r\n }\r\n </a>\r\n </li>\r\n\r\n @if (showFirstLastButtons) {\r\n <li class=\"page-item\">\r\n <a class=\"page-link page-last\"\r\n [tabindex]=\"_nextButtonDisabled() ? -1 : 0\"\r\n [class.disabled]=\"_nextButtonDisabled()\"\r\n [class]=\"color && !_nextButtonDisabled() ? 'link-'+color : ''\"\r\n [class.focus-ring]=\"color != null\"\r\n [attr.aria-label]=\"_intl.lastPageLabelHint || _intl.lastPageLabel\"\r\n [cuteTooltip]=\"_intl.lastPageLabelHint || _intl.lastPageLabel\"\r\n [cuteTooltipDisabled]=\"_nextButtonDisabled()\"\r\n [cuteTooltipPosition]=\"'above'\"\r\n (click)=\"lastPage()\"\r\n (keydown.space)=\"lastPage();$event.preventDefault();\"\r\n >\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\"\r\n fill=\"currentColor\" class=\"bi bi-chevron-double-right\"\r\n viewBox=\"0 0 16 16\"\r\n focusable=\"false\" aria-hidden=\"true\">\r\n <path fill-rule=\"evenodd\" d=\"M3.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L9.293 8 3.646 2.354a.5.5 0 0 1 0-.708z\"/>\r\n <path fill-rule=\"evenodd\" d=\"M7.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L13.293 8 7.646 2.354a.5.5 0 0 1 0-.708z\"/>\r\n </svg>\r\n </a>\r\n </li>\r\n }\r\n </ul>\r\n</nav>\r\n", styles: [".cute-paginator{display:flex;max-width:100%;align-items:center;gap:.5rem}.cute-paginator .page-size{display:flex;font-size:var(--bs-pagination-font-size);color:var(--bs-pagination-color);background-color:var(--bs-pagination-bg);align-items:center}.cute-paginator .page-size .page-size-label{margin-right:.25rem;overflow:hidden;white-space:nowrap;text-align:center;text-overflow:ellipsis}.cute-paginator .page-size .page-size-select{width:6rem;padding:0 .25rem}.cute-paginator .pagination{align-items:center;margin:0;--bs-pagination-color: var(--bs-secondary-color)}.cute-paginator .pagination .page-item{cursor:pointer}.cute-paginator .pagination .page-item:has(.page-prev,.page-next){display:grid}.cute-paginator .pagination .page-item .page-link{-webkit-user-select:none;user-select:none}.cute-paginator .pagination .page-item .page-link:not(:has(>svg)){white-space:nowrap;text-align:center;text-overflow:ellipsis}.cute-paginator .pagination .page-item:has(.page-link.disabled,.disabled>.page-link){cursor:auto}[dir=rtl] .cute-paginator .pagination .page-item:last-child .page-link{border-radius:var(--bs-pagination-border-radius) 0 0 var(--bs-pagination-border-radius)}[dir=rtl] .cute-paginator .pagination .page-item:last-child .page-link>svg{transform:rotate(180deg)}[dir=rtl] .cute-paginator .pagination .page-item:first-child .page-link{border-radius:0 var(--bs-pagination-border-radius) var(--bs-pagination-border-radius) 0}[dir=rtl] .cute-paginator .pagination .page-item:first-child .page-link>svg{transform:rotate(180deg)}[dir=rtl] .cute-paginator .pagination .page-item .page-next>svg,[dir=rtl] .cute-paginator .pagination .page-item .page-prev>svg{transform:rotate(180deg)}.cute-paginator .pagination .cute-paginator-range-label{display:inline-block;overflow:hidden;white-space:nowrap;text-align:center;text-overflow:ellipsis;text-decoration:none;min-width:7rem;padding:var(--bs-pagination-padding-y) var(--bs-pagination-padding-x);font-size:var(--bs-pagination-font-size);color:var(--bs-pagination-color);background-color:var(--bs-pagination-bg)}.cute-paginator .pagination-sm svg{width:.875rem}.cute-paginator .pagination-lg svg{width:1.25rem}\n"] }]
414
+ }], ctorParameters: () => [{ type: CutePaginatorIntl }, { type: undefined, decorators: [{
415
+ type: Optional
416
+ }, {
417
+ type: Inject,
418
+ args: [CUTE_PAGINATOR_DEFAULT_OPTIONS]
419
+ }] }], propDecorators: { pageIndex: [{
420
+ type: Input,
421
+ args: [{ transform: numberAttribute }]
422
+ }], length: [{
423
+ type: Input,
424
+ args: [{ transform: numberAttribute }]
425
+ }], pageSize: [{
426
+ type: Input,
427
+ args: [{ transform: numberAttribute }]
428
+ }], pageSizeOptions: [{
429
+ type: Input
430
+ }], hidePageSize: [{
431
+ type: Input,
432
+ args: [{ transform: booleanAttribute }]
433
+ }], showFirstLastButtons: [{
434
+ type: Input,
435
+ args: [{ transform: booleanAttribute }]
436
+ }], showPrevNextLabels: [{
437
+ type: Input,
438
+ args: [{ transform: booleanAttribute }]
439
+ }], hideBorders: [{
440
+ type: Input,
441
+ args: [{ transform: booleanAttribute }]
442
+ }], middleSectionStyle: [{
443
+ type: Input
444
+ }], alignment: [{
445
+ type: Input
446
+ }], magnitude: [{
447
+ type: Input
448
+ }], selectConfig: [{
449
+ type: Input
450
+ }], page: [{
451
+ type: Output
452
+ }] } });
453
+
454
+ /**
455
+ * @license Apache-2.0
456
+ *
457
+ * Copyright (c) 2025 CuteWidgets Team. All Rights Reserved.
458
+ *
459
+ * You may not use this file except in compliance with the License
460
+ * that can be found at http://www.apache.org/licenses/LICENSE-2.0
461
+ *
462
+ * This code is a modification of the `@angular/material` original
463
+ * code licensed under MIT-style License (https://angular.dev/license).
464
+ */
465
+ const TYPES = [CutePaginator];
466
+ class CutePaginatorModule {
467
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CutePaginatorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
468
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.3.15", ngImport: i0, type: CutePaginatorModule, imports: [CommonModule, CutePaginator], exports: [CutePaginator] }); }
469
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CutePaginatorModule, imports: [CommonModule, TYPES] }); }
470
+ }
471
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CutePaginatorModule, decorators: [{
472
+ type: NgModule,
473
+ args: [{
474
+ imports: [CommonModule, ...TYPES],
475
+ exports: TYPES,
476
+ declarations: [],
477
+ }]
478
+ }] });
479
+
480
+ /**
481
+ * Generated bundle index. Do not edit.
482
+ */
483
+
484
+ export { CUTE_PAGINATOR_DEFAULT_OPTIONS, CutePaginator, CutePaginatorModule };
485
+ //# sourceMappingURL=cute-widgets-base-paginator.mjs.map