@decaf-ts/for-angular 0.0.9 → 0.0.10

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 (120) hide show
  1. package/dist/{lib/components → components}/empty-state/empty-state.component.d.ts +3 -3
  2. package/dist/{lib/components → components}/fieldset/fieldset.component.d.ts +1 -1
  3. package/dist/{lib/components → components}/filter/filter.component.d.ts +2 -2
  4. package/dist/{lib/components → components}/layout/layout.component.d.ts +2 -2
  5. package/dist/{lib/components → components}/list/list.component.d.ts +3 -3
  6. package/dist/{lib/components → components}/list-item/list-item.component.d.ts +3 -3
  7. package/dist/{lib/components → components}/model-renderer/model-renderer.component.d.ts +1 -1
  8. package/dist/{lib/components → components}/pagination/constants.d.ts +1 -1
  9. package/dist/{lib/components → components}/pagination/pagination.component.d.ts +2 -2
  10. package/dist/{lib/components → components}/searchbar/searchbar.component.d.ts +2 -2
  11. package/dist/{lib/engine → engine}/NgxBaseComponent.d.ts +1 -1
  12. package/dist/{lib/esm2022 → esm2022}/components/component-renderer/component-renderer.component.mjs +3 -3
  13. package/dist/esm2022/components/crud-field/crud-field.component.mjs +301 -0
  14. package/dist/esm2022/components/crud-form/constants.mjs +14 -0
  15. package/dist/esm2022/components/crud-form/crud-form.component.mjs +139 -0
  16. package/dist/esm2022/components/crud-form/types.mjs +2 -0
  17. package/dist/esm2022/components/empty-state/empty-state.component.mjs +348 -0
  18. package/dist/esm2022/components/fieldset/fieldset.component.mjs +225 -0
  19. package/dist/esm2022/components/filter/filter.component.mjs +689 -0
  20. package/dist/esm2022/components/for-angular-components.module.mjs +71 -0
  21. package/dist/esm2022/components/index.mjs +20 -0
  22. package/dist/esm2022/components/layout/layout.component.mjs +176 -0
  23. package/dist/esm2022/components/list/constants.mjs +6 -0
  24. package/dist/esm2022/components/list/list.component.mjs +1236 -0
  25. package/dist/{lib/esm2022 → esm2022}/components/list-item/list-item.component.mjs +6 -6
  26. package/dist/esm2022/components/model-renderer/model-renderer.component.mjs +138 -0
  27. package/dist/esm2022/components/pagination/constants.mjs +2 -0
  28. package/dist/esm2022/components/pagination/pagination.component.mjs +323 -0
  29. package/dist/esm2022/components/searchbar/searchbar.component.mjs +493 -0
  30. package/dist/esm2022/decaf-ts-for-angular.mjs +5 -0
  31. package/dist/esm2022/directives/collapsable.directive.mjs +28 -0
  32. package/dist/esm2022/directives/index.mjs +2 -0
  33. package/dist/esm2022/engine/DynamicModule.mjs +18 -0
  34. package/dist/esm2022/engine/NgxBaseComponent.mjs +539 -0
  35. package/dist/esm2022/engine/NgxCrudFormField.mjs +125 -0
  36. package/dist/esm2022/engine/NgxFormService.mjs +315 -0
  37. package/dist/esm2022/engine/NgxRenderingEngine.mjs +192 -0
  38. package/dist/esm2022/engine/NgxRenderingEngine2.mjs +332 -0
  39. package/dist/esm2022/engine/ValidatorFactory.mjs +102 -0
  40. package/dist/esm2022/engine/constants.mjs +160 -0
  41. package/dist/esm2022/engine/decorators.mjs +38 -0
  42. package/dist/esm2022/engine/index.mjs +17 -0
  43. package/dist/esm2022/engine/types.mjs +4 -0
  44. package/dist/esm2022/for-angular.module.mjs +118 -0
  45. package/dist/esm2022/helpers/index.mjs +13 -0
  46. package/dist/esm2022/helpers/utils.mjs +415 -0
  47. package/dist/esm2022/interfaces.mjs +2 -0
  48. package/dist/esm2022/public-apis.mjs +14 -0
  49. package/dist/{lib/fesm2022 → fesm2022}/decaf-ts-for-angular.mjs +3029 -3036
  50. package/dist/fesm2022/decaf-ts-for-angular.mjs.map +1 -0
  51. package/package.json +4 -2
  52. package/dist/lib/esm2022/components/crud-field/crud-field.component.mjs +0 -301
  53. package/dist/lib/esm2022/components/crud-form/constants.mjs +0 -14
  54. package/dist/lib/esm2022/components/crud-form/crud-form.component.mjs +0 -139
  55. package/dist/lib/esm2022/components/crud-form/types.mjs +0 -2
  56. package/dist/lib/esm2022/components/empty-state/empty-state.component.mjs +0 -348
  57. package/dist/lib/esm2022/components/fieldset/fieldset.component.mjs +0 -225
  58. package/dist/lib/esm2022/components/filter/filter.component.mjs +0 -689
  59. package/dist/lib/esm2022/components/for-angular-components.module.mjs +0 -71
  60. package/dist/lib/esm2022/components/index.mjs +0 -20
  61. package/dist/lib/esm2022/components/layout/layout.component.mjs +0 -176
  62. package/dist/lib/esm2022/components/list/constants.mjs +0 -6
  63. package/dist/lib/esm2022/components/list/list.component.mjs +0 -1236
  64. package/dist/lib/esm2022/components/model-renderer/model-renderer.component.mjs +0 -138
  65. package/dist/lib/esm2022/components/pagination/constants.mjs +0 -2
  66. package/dist/lib/esm2022/components/pagination/pagination.component.mjs +0 -323
  67. package/dist/lib/esm2022/components/searchbar/searchbar.component.mjs +0 -493
  68. package/dist/lib/esm2022/decaf-ts-for-angular.mjs +0 -5
  69. package/dist/lib/esm2022/directives/collapsable.directive.mjs +0 -28
  70. package/dist/lib/esm2022/directives/index.mjs +0 -2
  71. package/dist/lib/esm2022/engine/DynamicModule.mjs +0 -18
  72. package/dist/lib/esm2022/engine/NgxBaseComponent.mjs +0 -540
  73. package/dist/lib/esm2022/engine/NgxCrudFormField.mjs +0 -125
  74. package/dist/lib/esm2022/engine/NgxFormService.mjs +0 -315
  75. package/dist/lib/esm2022/engine/NgxRenderingEngine.mjs +0 -192
  76. package/dist/lib/esm2022/engine/NgxRenderingEngine2.mjs +0 -332
  77. package/dist/lib/esm2022/engine/ValidatorFactory.mjs +0 -102
  78. package/dist/lib/esm2022/engine/constants.mjs +0 -160
  79. package/dist/lib/esm2022/engine/decorators.mjs +0 -38
  80. package/dist/lib/esm2022/engine/index.mjs +0 -17
  81. package/dist/lib/esm2022/engine/types.mjs +0 -4
  82. package/dist/lib/esm2022/for-angular.module.mjs +0 -118
  83. package/dist/lib/esm2022/helpers/index.mjs +0 -13
  84. package/dist/lib/esm2022/helpers/utils.mjs +0 -415
  85. package/dist/lib/esm2022/interfaces.mjs +0 -2
  86. package/dist/lib/esm2022/public-apis.mjs +0 -14
  87. package/dist/lib/fesm2022/decaf-ts-for-angular.mjs.map +0 -1
  88. /package/dist/{lib/README.md → README.md} +0 -0
  89. /package/dist/{lib/assets → assets}/i18n/en.json +0 -0
  90. /package/dist/{lib/assets → assets}/images/angular-logo.svg +0 -0
  91. /package/dist/{lib/assets → assets}/images/decaf-logo-black.svg +0 -0
  92. /package/dist/{lib/assets → assets}/images/decaf-logo-lw.svg +0 -0
  93. /package/dist/{lib/assets → assets}/images/decaf-logo-white.svg +0 -0
  94. /package/dist/{lib/assets → assets}/images/decaf-logo.svg +0 -0
  95. /package/dist/{lib/components → components}/component-renderer/component-renderer.component.d.ts +0 -0
  96. /package/dist/{lib/components → components}/crud-field/crud-field.component.d.ts +0 -0
  97. /package/dist/{lib/components → components}/crud-form/constants.d.ts +0 -0
  98. /package/dist/{lib/components → components}/crud-form/crud-form.component.d.ts +0 -0
  99. /package/dist/{lib/components → components}/crud-form/types.d.ts +0 -0
  100. /package/dist/{lib/components → components}/for-angular-components.module.d.ts +0 -0
  101. /package/dist/{lib/components → components}/index.d.ts +0 -0
  102. /package/dist/{lib/components → components}/list/constants.d.ts +0 -0
  103. /package/dist/{lib/directives → directives}/collapsable.directive.d.ts +0 -0
  104. /package/dist/{lib/directives → directives}/index.d.ts +0 -0
  105. /package/dist/{lib/engine → engine}/DynamicModule.d.ts +0 -0
  106. /package/dist/{lib/engine → engine}/NgxCrudFormField.d.ts +0 -0
  107. /package/dist/{lib/engine → engine}/NgxFormService.d.ts +0 -0
  108. /package/dist/{lib/engine → engine}/NgxRenderingEngine.d.ts +0 -0
  109. /package/dist/{lib/engine → engine}/NgxRenderingEngine2.d.ts +0 -0
  110. /package/dist/{lib/engine → engine}/ValidatorFactory.d.ts +0 -0
  111. /package/dist/{lib/engine → engine}/constants.d.ts +0 -0
  112. /package/dist/{lib/engine → engine}/decorators.d.ts +0 -0
  113. /package/dist/{lib/engine → engine}/index.d.ts +0 -0
  114. /package/dist/{lib/engine → engine}/types.d.ts +0 -0
  115. /package/dist/{lib/for-angular.module.d.ts → for-angular.module.d.ts} +0 -0
  116. /package/dist/{lib/helpers → helpers}/index.d.ts +0 -0
  117. /package/dist/{lib/helpers → helpers}/utils.d.ts +0 -0
  118. /package/dist/{lib/index.d.ts → index.d.ts} +0 -0
  119. /package/dist/{lib/interfaces.d.ts → interfaces.d.ts} +0 -0
  120. /package/dist/{lib/public-apis.d.ts → public-apis.d.ts} +0 -0
@@ -0,0 +1,323 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { IonIcon } from '@ionic/angular/standalone';
3
+ import { addIcons } from 'ionicons';
4
+ import { chevronBackOutline, chevronForwardOutline } from 'ionicons/icons';
5
+ import { ForAngularModule } from '../../for-angular.module';
6
+ import { NgxBaseComponent } from '../../engine/NgxBaseComponent';
7
+ import { EventConstants } from '../../engine';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/common";
10
+ import * as i2 from "@ngx-translate/core";
11
+ /**
12
+ * @description A pagination component for navigating through multiple pages of content.
13
+ * @summary This component provides a user interface for paginated content navigation,
14
+ * displaying page numbers and navigation controls. It supports customizable page counts,
15
+ * current page tracking, and emits events when users navigate between pages.
16
+ *
17
+ * The component intelligently handles large numbers of pages by showing a subset of page
18
+ * numbers with ellipses to indicate skipped pages, ensuring the UI remains clean and usable
19
+ * even with many pages.
20
+ *
21
+ * @mermaid
22
+ * sequenceDiagram
23
+ * participant U as User
24
+ * participant P as PaginationComponent
25
+ * participant E as External Component
26
+ *
27
+ * U->>P: Click page number
28
+ * P->>P: navigate(page)
29
+ * P->>P: handleClick(direction, page)
30
+ * P->>E: Emit clickEvent with PaginationCustomEvent
31
+ *
32
+ * U->>P: Click next button
33
+ * P->>P: next()
34
+ * P->>P: handleClick('next')
35
+ * P->>E: Emit clickEvent with PaginationCustomEvent
36
+ *
37
+ * U->>P: Click previous button
38
+ * P->>P: previous()
39
+ * P->>P: handleClick('previous')
40
+ * P->>E: Emit clickEvent with PaginationCustomEvent
41
+ *
42
+ * @example
43
+ * <ngx-decaf-pagination
44
+ * [pages]="10"
45
+ * [current]="3"
46
+ * (clickEvent)="handlePageChange($event)">
47
+ * </ngx-decaf-pagination>
48
+ *
49
+ * @extends {NgxBaseComponent}
50
+ * @implements {OnInit}
51
+ */
52
+ export class PaginationComponent extends NgxBaseComponent {
53
+ /**
54
+ * @constructor
55
+ * @description Initializes a new instance of the PaginationComponent.
56
+ * Calls the parent constructor with the component name for generate base locale string.
57
+ */
58
+ constructor() {
59
+ super("PaginationComponent");
60
+ /**
61
+ * @description Controls whether the component uses translation services.
62
+ * @summary When set to true, the component will attempt to use translation services
63
+ * for any text content. This allows for internationalization of the pagination component.
64
+ *
65
+ * @type {StringOrBoolean}
66
+ * @default true
67
+ * @memberOf PaginationComponent
68
+ */
69
+ this.translatable = true;
70
+ /**
71
+ * @description The currently active page number.
72
+ * @summary Specifies which page is currently active or selected. This value is used
73
+ * to highlight the current page in the UI and as a reference point for navigation.
74
+ *
75
+ * @type {number}
76
+ * @default 1
77
+ * @memberOf PaginationComponent
78
+ */
79
+ this.current = 1;
80
+ /**
81
+ * @description Event emitter for pagination navigation events.
82
+ * @summary Emits a custom event when users navigate between pages, either by clicking
83
+ * on page numbers or using the next/previous buttons. The event contains information
84
+ * about the navigation direction and the target page number.
85
+ *
86
+ * @type {EventEmitter<PaginationCustomEvent>}
87
+ * @memberOf PaginationComponent
88
+ */
89
+ this.clickEvent = new EventEmitter();
90
+ addIcons({ chevronBackOutline, chevronForwardOutline });
91
+ }
92
+ /**
93
+ * @description Initializes the component after Angular sets the input properties.
94
+ * @summary Sets up the component by initializing the locale settings based on the
95
+ * translatable property, generating the page numbers based on the total pages and
96
+ * current page, and storing the last page number for boundary checking.
97
+ *
98
+ * @mermaid
99
+ * sequenceDiagram
100
+ * participant A as Angular Lifecycle
101
+ * participant P as PaginationComponent
102
+ *
103
+ * A->>P: ngOnInit()
104
+ * P->>P: getLocale(translatable)
105
+ * P->>P: Set locale
106
+ * P->>P: getPages(data, current)
107
+ * P->>P: Set pages array
108
+ * P->>P: Set last page number
109
+ *
110
+ * @returns {void}
111
+ * @memberOf PaginationComponent
112
+ */
113
+ ngOnInit() {
114
+ this.locale = this.getLocale(this.translatable);
115
+ this.pages = this.getPages(this.totalPages, this.current);
116
+ this.last = this.totalPages;
117
+ }
118
+ /**
119
+ * @description Handles click events on pagination controls.
120
+ * @summary Processes user interactions with the pagination component, updating the
121
+ * current page if specified and emitting an event with navigation details. This method
122
+ * is called when users click on page numbers or navigation buttons.
123
+ *
124
+ * @param {('next' | 'previous')} direction - The direction of navigation
125
+ * @param {number} [page] - Optional page number to navigate to directly
126
+ * @returns {void}
127
+ *
128
+ * @mermaid
129
+ * sequenceDiagram
130
+ * participant U as User
131
+ * participant P as PaginationComponent
132
+ * participant E as External Component
133
+ *
134
+ * U->>P: Click pagination control
135
+ * P->>P: handleClick(direction, page?)
136
+ * alt page is provided
137
+ * P->>P: Update current page
138
+ * end
139
+ * P->>E: Emit clickEvent with direction and page
140
+ *
141
+ * @memberOf PaginationComponent
142
+ */
143
+ handleClick(direction, page) {
144
+ if (page)
145
+ this.current = page;
146
+ this.clickEvent.emit({
147
+ name: EventConstants.CLICK_EVENT,
148
+ data: {
149
+ direction,
150
+ page: this.current
151
+ },
152
+ component: this.componentName
153
+ });
154
+ }
155
+ /**
156
+ * @description Generates the array of page objects for display.
157
+ * @summary Creates an array of page objects based on the total number of pages and
158
+ * the current page. For small page counts (≤5), all pages are shown. For larger page
159
+ * counts, a subset is shown with ellipses to indicate skipped pages. This ensures
160
+ * the pagination UI remains clean and usable even with many pages.
161
+ *
162
+ * @param {number} total - The total number of pages
163
+ * @param {number} [current] - The current active page (defaults to this.current)
164
+ * @returns {KeyValue[]} Array of page objects with index and text properties
165
+ *
166
+ * @mermaid
167
+ * flowchart TD
168
+ * A[Start] --> B{total <= 5?}
169
+ * B -->|Yes| C[Show all pages]
170
+ * B -->|No| D[Show first page]
171
+ * D --> E[Show last pages]
172
+ * E --> F[Add ellipses for skipped pages]
173
+ * C --> G[Return pages array]
174
+ * F --> G
175
+ *
176
+ * @memberOf PaginationComponent
177
+ */
178
+ getPages(total, current) {
179
+ if (!current)
180
+ current = this.current;
181
+ const pages = [];
182
+ function getPage(index, text = '') {
183
+ if (pages.some(item => item['index'] === index))
184
+ return;
185
+ pages.push({ index, text: index != null ? index.toString().padStart(2, '0') : text });
186
+ }
187
+ if (total <= 5) {
188
+ for (let i = 1; i <= total; i++)
189
+ getPage(i);
190
+ }
191
+ else {
192
+ // Adiciona os dois primeiros
193
+ getPage(1);
194
+ getPage(2);
195
+ // Adiciona "..." entre os blocos
196
+ if (current && current > 3)
197
+ getPage(null, '...');
198
+ // Adiciona a página atual (se estiver no meio)
199
+ if (current && current > 2 && current < total - 1)
200
+ getPage(current);
201
+ // Adiciona "..." entre os blocos
202
+ if (current && current < total - 2)
203
+ getPage(null, '...');
204
+ // Adiciona os dois últimos
205
+ getPage(total - 1);
206
+ getPage(total);
207
+ }
208
+ return pages;
209
+ }
210
+ /**
211
+ * @description Gets the current active page number.
212
+ * @summary Returns the current page number that is active in the pagination component.
213
+ * This method provides a way to access the current page state from outside the component.
214
+ *
215
+ * @returns {number} The current page number
216
+ * @memberOf PaginationComponent
217
+ */
218
+ getCurrent() {
219
+ return this.current;
220
+ }
221
+ /**
222
+ * @description Navigates to the next page.
223
+ * @summary Increments the current page number if not at the last page and triggers
224
+ * the click event handler with 'next' direction. This method is typically called
225
+ * when the user clicks on the "next" button in the pagination UI.
226
+ *
227
+ * @returns {void}
228
+ *
229
+ * @mermaid
230
+ * sequenceDiagram
231
+ * participant U as User
232
+ * participant P as PaginationComponent
233
+ *
234
+ * U->>P: Click next button
235
+ * P->>P: next()
236
+ * alt page <= max pages
237
+ * P->>P: Increment current page
238
+ * P->>P: handleClick('next')
239
+ * end
240
+ *
241
+ * @memberOf PaginationComponent
242
+ */
243
+ next() {
244
+ const page = this.current + 1;
245
+ if (page <= Object.keys(this.pages)?.length || 0) {
246
+ this.current = page;
247
+ this.handleClick('next');
248
+ }
249
+ }
250
+ /**
251
+ * @description Navigates to the previous page.
252
+ * @summary Decrements the current page number if not at the first page and triggers
253
+ * the click event handler with 'previous' direction. This method is typically called
254
+ * when the user clicks on the "previous" button in the pagination UI.
255
+ *
256
+ * @returns {void}
257
+ *
258
+ * @mermaid
259
+ * sequenceDiagram
260
+ * participant U as User
261
+ * participant P as PaginationComponent
262
+ *
263
+ * U->>P: Click previous button
264
+ * P->>P: previous()
265
+ * alt page > 0
266
+ * P->>P: Decrement current page
267
+ * P->>P: handleClick('previous')
268
+ * end
269
+ *
270
+ * @memberOf PaginationComponent
271
+ */
272
+ previous() {
273
+ const page = this.current - 1;
274
+ if (page > 0) {
275
+ this.current = page;
276
+ this.handleClick('previous');
277
+ }
278
+ }
279
+ /**
280
+ * @description Navigates to a specific page number.
281
+ * @summary Updates the current page to the specified page number and triggers
282
+ * the click event handler with the appropriate direction. This method is typically
283
+ * called when the user clicks directly on a page number in the pagination UI.
284
+ *
285
+ * @param {number | null} page - The page number to navigate to
286
+ * @returns {void}
287
+ *
288
+ * @mermaid
289
+ * sequenceDiagram
290
+ * participant U as User
291
+ * participant P as PaginationComponent
292
+ *
293
+ * U->>P: Click page number
294
+ * P->>P: navigate(page)
295
+ * alt page is not null and different from current
296
+ * P->>P: Determine direction (next/previous)
297
+ * P->>P: handleClick(direction, page)
298
+ * end
299
+ *
300
+ * @memberOf PaginationComponent
301
+ */
302
+ navigate(page) {
303
+ if (page !== null && this.current !== page)
304
+ this.handleClick(page > this.current ? 'next' : 'previous', page);
305
+ }
306
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PaginationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
307
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: PaginationComponent, isStandalone: true, selector: "ngx-decaf-pagination", inputs: { totalPages: "totalPages", current: "current" }, outputs: { clickEvent: "clickEvent" }, usesInheritance: true, ngImport: i0, template: " <div id=\"dcf-paginator-container\" class=\"dcf-flex dcf-flex-center\">\n <div class=\"dcf-width-1-1\">\n <div class=\"dcf-pagination-resume\" [innerHTML]=\"locale + '.resume' | translate: {value0: current, value1: last}\"></div>\n <div #paginationComponent class=\"dcf-pagination aeon-pagination dcf-flex-center\">\n <div\n aria-label=\"previous\"\n tabindex=\"0\"\n (click)=\"previous()\"\n (keydown.enter)=\"previous()\" [ngClass]=\"{'dcf-disabled': current === 1}\">\n <ion-icon name=\"chevron-back-outline\" aria-hidden=\"true\"></ion-icon>\n </div>\n @for(page of pages; track page) {\n <div tabindex=\"0\" (click)=\"navigate(page['index'])\"\n (keydown.enter)=\"navigate(page['index'])\"\n [ngClass]=\"{'dcf-active': current === page['index'], 'dcf-disabled': page['index'] === ndivl}\">\n <span class=\"page-item\">{{ page['text'] }}</span>\n </div>\n }\n <div\n tabindex=\"0\" (click)=\"next()\"\n (keydown.enter)=\"next()\"\n [ngClass]=\"{'dcf-disabled': current === last}\">\n <ion-icon name=\"chevron-forward-outline\" aria-hidden=\"true\"></ion-icon>\n </div>\n </div>\n </div>\n</div>\n", styles: ["#dcf-paginator-container{margin-bottom:1rem}.dcf-pagination{display:flex;flex-wrap:wrap;align-items:center;margin-left:0;padding:0;list-style:none}.dcf-pagination .page-item{display:flex;justify-content:center;align-items:top;color:var(--ion-color-gray-7);font-weight:600;width:36px;line-height:34px;padding:0!important;border-radius:50%;box-sizing:border-box}.dcf-pagination>*{flex:none;padding-left:0;position:relative;margin:0px .15rem}.dcf-pagination>*:not(.disabled){cursor:pointer}.dcf-pagination>*:hover .page-item{color:var(--ion-color-primary)}.dcf-pagination>* .page-item{color:var(--ion-color-gray-7);font-weight:600}.dcf-pagination>*.dcf-active .page-item{background:rgba(var(--ion-color-primary-rgb),.15)}.dcf-pagination>*>*{display:flex;align-items:center;column-gap:.25em;padding:5px 10px;color:var(--ion-color-gray-8);transition:color .1s ease-in-out}.dcf-pagination>*>:hover{color:var(--ion-color-gray-6);text-decoration:none}.dcf-pagination .dcf-disabled>*{opacity:.5;color:var(--ion-color-gray-6)}.dcf-pagination-resume{color:var(--ion-color-gray-8);margin:1rem 0px;text-align:center}\n"], dependencies: [{ kind: "ngmodule", type: ForAngularModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }] }); }
308
+ }
309
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PaginationComponent, decorators: [{
310
+ type: Component,
311
+ args: [{ selector: 'ngx-decaf-pagination', imports: [
312
+ ForAngularModule,
313
+ IonIcon
314
+ ], standalone: true, template: " <div id=\"dcf-paginator-container\" class=\"dcf-flex dcf-flex-center\">\n <div class=\"dcf-width-1-1\">\n <div class=\"dcf-pagination-resume\" [innerHTML]=\"locale + '.resume' | translate: {value0: current, value1: last}\"></div>\n <div #paginationComponent class=\"dcf-pagination aeon-pagination dcf-flex-center\">\n <div\n aria-label=\"previous\"\n tabindex=\"0\"\n (click)=\"previous()\"\n (keydown.enter)=\"previous()\" [ngClass]=\"{'dcf-disabled': current === 1}\">\n <ion-icon name=\"chevron-back-outline\" aria-hidden=\"true\"></ion-icon>\n </div>\n @for(page of pages; track page) {\n <div tabindex=\"0\" (click)=\"navigate(page['index'])\"\n (keydown.enter)=\"navigate(page['index'])\"\n [ngClass]=\"{'dcf-active': current === page['index'], 'dcf-disabled': page['index'] === ndivl}\">\n <span class=\"page-item\">{{ page['text'] }}</span>\n </div>\n }\n <div\n tabindex=\"0\" (click)=\"next()\"\n (keydown.enter)=\"next()\"\n [ngClass]=\"{'dcf-disabled': current === last}\">\n <ion-icon name=\"chevron-forward-outline\" aria-hidden=\"true\"></ion-icon>\n </div>\n </div>\n </div>\n</div>\n", styles: ["#dcf-paginator-container{margin-bottom:1rem}.dcf-pagination{display:flex;flex-wrap:wrap;align-items:center;margin-left:0;padding:0;list-style:none}.dcf-pagination .page-item{display:flex;justify-content:center;align-items:top;color:var(--ion-color-gray-7);font-weight:600;width:36px;line-height:34px;padding:0!important;border-radius:50%;box-sizing:border-box}.dcf-pagination>*{flex:none;padding-left:0;position:relative;margin:0px .15rem}.dcf-pagination>*:not(.disabled){cursor:pointer}.dcf-pagination>*:hover .page-item{color:var(--ion-color-primary)}.dcf-pagination>* .page-item{color:var(--ion-color-gray-7);font-weight:600}.dcf-pagination>*.dcf-active .page-item{background:rgba(var(--ion-color-primary-rgb),.15)}.dcf-pagination>*>*{display:flex;align-items:center;column-gap:.25em;padding:5px 10px;color:var(--ion-color-gray-8);transition:color .1s ease-in-out}.dcf-pagination>*>:hover{color:var(--ion-color-gray-6);text-decoration:none}.dcf-pagination .dcf-disabled>*{opacity:.5;color:var(--ion-color-gray-6)}.dcf-pagination-resume{color:var(--ion-color-gray-8);margin:1rem 0px;text-align:center}\n"] }]
315
+ }], ctorParameters: () => [], propDecorators: { totalPages: [{
316
+ type: Input,
317
+ args: [{ required: true }]
318
+ }], current: [{
319
+ type: Input
320
+ }], clickEvent: [{
321
+ type: Output
322
+ }] } });
323
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../src/lib/components/pagination/pagination.component.ts","../../../../src/lib/components/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { IonIcon } from '@ionic/angular/standalone';\nimport { addIcons } from 'ionicons';\nimport { chevronBackOutline, chevronForwardOutline } from 'ionicons/icons';\nimport { ForAngularModule } from '../../for-angular.module';\nimport { NgxBaseComponent } from '../../engine/NgxBaseComponent';\nimport { EventConstants, KeyValue, StringOrBoolean } from '../../engine';\nimport { PaginationCustomEvent } from './constants';\n\n/**\n * @description A pagination component for navigating through multiple pages of content.\n * @summary This component provides a user interface for paginated content navigation,\n * displaying page numbers and navigation controls. It supports customizable page counts,\n * current page tracking, and emits events when users navigate between pages.\n *\n * The component intelligently handles large numbers of pages by showing a subset of page\n * numbers with ellipses to indicate skipped pages, ensuring the UI remains clean and usable\n * even with many pages.\n *\n * @mermaid\n * sequenceDiagram\n *   participant U as User\n *   participant P as PaginationComponent\n *   participant E as External Component\n *\n *   U->>P: Click page number\n *   P->>P: navigate(page)\n *   P->>P: handleClick(direction, page)\n *   P->>E: Emit clickEvent with PaginationCustomEvent\n *\n *   U->>P: Click next button\n *   P->>P: next()\n *   P->>P: handleClick('next')\n *   P->>E: Emit clickEvent with PaginationCustomEvent\n *\n *   U->>P: Click previous button\n *   P->>P: previous()\n *   P->>P: handleClick('previous')\n *   P->>E: Emit clickEvent with PaginationCustomEvent\n *\n * @example\n * <ngx-decaf-pagination\n *   [pages]=\"10\"\n *   [current]=\"3\"\n *   (clickEvent)=\"handlePageChange($event)\">\n * </ngx-decaf-pagination>\n *\n * @extends {NgxBaseComponent}\n * @implements {OnInit}\n */\n@Component({\n  selector: 'ngx-decaf-pagination',\n  templateUrl: './pagination.component.html',\n  styleUrls: ['./pagination.component.scss'],\n  imports: [\n    ForAngularModule,\n    IonIcon\n  ],\n  standalone: true,\n\n})\nexport class PaginationComponent extends NgxBaseComponent implements OnInit {\n\n  /**\n   * @description Controls whether the component uses translation services.\n   * @summary When set to true, the component will attempt to use translation services\n   * for any text content. This allows for internationalization of the pagination component.\n   *\n   * @type {StringOrBoolean}\n   * @default true\n   * @memberOf PaginationComponent\n   */\n  override translatable: StringOrBoolean = true;\n\n  /**\n   * @description The total number of pages to display in the pagination component.\n   * @summary Specifies the total number of pages available for navigation. This is a required\n   * input that determines how many page numbers will be generated and displayed.\n   *\n   * @type {number}\n   * @required\n   * @memberOf PaginationComponent\n   */\n  @Input({ required: true })\n  totalPages!: number;\n\n  /**\n   * @description The currently active page number.\n   * @summary Specifies which page is currently active or selected. This value is used\n   * to highlight the current page in the UI and as a reference point for navigation.\n   *\n   * @type {number}\n   * @default 1\n   * @memberOf PaginationComponent\n   */\n  @Input()\n  current = 1;\n\n  /**\n   * @description Array of page objects for rendering in the template.\n   * @summary Contains the processed page data used for rendering the pagination UI.\n   * Each object includes an index (page number) and text representation.\n   *\n   * @type {KeyValue[]}\n   * @memberOf PaginationComponent\n   */\n  pages!: KeyValue[];\n\n  /**\n   * @description The last page number in the pagination.\n   * @summary Stores the number of the last page for boundary checking during navigation.\n   *\n   * @type {number}\n   * @memberOf PaginationComponent\n   */\n  last!: number;\n\n  /**\n   * @description Event emitter for pagination navigation events.\n   * @summary Emits a custom event when users navigate between pages, either by clicking\n   * on page numbers or using the next/previous buttons. The event contains information\n   * about the navigation direction and the target page number.\n   *\n   * @type {EventEmitter<PaginationCustomEvent>}\n   * @memberOf PaginationComponent\n   */\n  @Output()\n  clickEvent: EventEmitter<PaginationCustomEvent> = new EventEmitter<PaginationCustomEvent>();\n\n  /**\n   * @constructor\n   * @description Initializes a new instance of the PaginationComponent.\n   * Calls the parent constructor with the component name for generate base locale string.\n   */\n  constructor() {\n    super(\"PaginationComponent\");\n     addIcons({chevronBackOutline, chevronForwardOutline});\n  }\n\n  /**\n   * @description Initializes the component after Angular sets the input properties.\n   * @summary Sets up the component by initializing the locale settings based on the\n   * translatable property, generating the page numbers based on the total pages and\n   * current page, and storing the last page number for boundary checking.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as Angular Lifecycle\n   *   participant P as PaginationComponent\n   *\n   *   A->>P: ngOnInit()\n   *   P->>P: getLocale(translatable)\n   *   P->>P: Set locale\n   *   P->>P: getPages(data, current)\n   *   P->>P: Set pages array\n   *   P->>P: Set last page number\n   *\n   * @returns {void}\n   * @memberOf PaginationComponent\n   */\n  ngOnInit(): void {\n    this.locale = this.getLocale(this.translatable);\n    this.pages = this.getPages(this.totalPages, this.current) as KeyValue[];\n    this.last = this.totalPages;\n  }\n\n  /**\n   * @description Handles click events on pagination controls.\n   * @summary Processes user interactions with the pagination component, updating the\n   * current page if specified and emitting an event with navigation details. This method\n   * is called when users click on page numbers or navigation buttons.\n   *\n   * @param {('next' | 'previous')} direction - The direction of navigation\n   * @param {number} [page] - Optional page number to navigate to directly\n   * @returns {void}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant P as PaginationComponent\n   *   participant E as External Component\n   *\n   *   U->>P: Click pagination control\n   *   P->>P: handleClick(direction, page?)\n   *   alt page is provided\n   *     P->>P: Update current page\n   *   end\n   *   P->>E: Emit clickEvent with direction and page\n   *\n   * @memberOf PaginationComponent\n   */\n  handleClick(direction: 'next' | 'previous', page?: number): void {\n    if(page)\n      this.current = page;\n    this.clickEvent.emit({\n      name: EventConstants.CLICK_EVENT,\n      data: {\n        direction,\n        page: this.current\n      },\n      component: this.componentName\n    } as PaginationCustomEvent);\n  }\n\n  /**\n   * @description Generates the array of page objects for display.\n   * @summary Creates an array of page objects based on the total number of pages and\n   * the current page. For small page counts (≤5), all pages are shown. For larger page\n   * counts, a subset is shown with ellipses to indicate skipped pages. This ensures\n   * the pagination UI remains clean and usable even with many pages.\n   *\n   * @param {number} total - The total number of pages\n   * @param {number} [current] - The current active page (defaults to this.current)\n   * @returns {KeyValue[]} Array of page objects with index and text properties\n   *\n   * @mermaid\n   * flowchart TD\n   *   A[Start] --> B{total <= 5?}\n   *   B -->|Yes| C[Show all pages]\n   *   B -->|No| D[Show first page]\n   *   D --> E[Show last pages]\n   *   E --> F[Add ellipses for skipped pages]\n   *   C --> G[Return pages array]\n   *   F --> G\n   *\n   * @memberOf PaginationComponent\n   */\n  getPages(total: number, current?: number): KeyValue[] {\n    if (!current) current = this.current;\n\n    const pages: KeyValue[] = [];\n\n    function getPage(index: number | null, text = '') {\n        if (pages.some(item => item['index'] === index)) return;\n        pages.push({ index, text: index != null ? index.toString().padStart(2, '0') : text });\n    }\n\n    if (total <= 5) {\n        for (let i = 1; i <= total; i++) getPage(i);\n    } else {\n      // Adiciona os dois primeiros\n      getPage(1);\n      getPage(2);\n\n      // Adiciona \"...\" entre os blocos\n      if (current && current > 3) getPage(null, '...');\n\n      // Adiciona a página atual (se estiver no meio)\n      if (current && current > 2 && current < total - 1) getPage(current);\n\n      // Adiciona \"...\" entre os blocos\n      if (current && current < total - 2) getPage(null, '...');\n\n      // Adiciona os dois últimos\n      getPage(total - 1);\n      getPage(total);\n    }\n\n    return pages;\n  }\n\n  /**\n   * @description Gets the current active page number.\n   * @summary Returns the current page number that is active in the pagination component.\n   * This method provides a way to access the current page state from outside the component.\n   *\n   * @returns {number} The current page number\n   * @memberOf PaginationComponent\n   */\n  getCurrent(): number {\n    return this.current;\n  }\n\n  /**\n   * @description Navigates to the next page.\n   * @summary Increments the current page number if not at the last page and triggers\n   * the click event handler with 'next' direction. This method is typically called\n   * when the user clicks on the \"next\" button in the pagination UI.\n   *\n   * @returns {void}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant P as PaginationComponent\n   *\n   *   U->>P: Click next button\n   *   P->>P: next()\n   *   alt page <= max pages\n   *     P->>P: Increment current page\n   *     P->>P: handleClick('next')\n   *   end\n   *\n   * @memberOf PaginationComponent\n   */\n  next(): void {\n    const page = this.current + 1;\n    if(page <= Object.keys(this.pages)?.length || 0) {\n      this.current = page;\n      this.handleClick('next');\n    }\n  }\n\n  /**\n   * @description Navigates to the previous page.\n   * @summary Decrements the current page number if not at the first page and triggers\n   * the click event handler with 'previous' direction. This method is typically called\n   * when the user clicks on the \"previous\" button in the pagination UI.\n   *\n   * @returns {void}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant P as PaginationComponent\n   *\n   *   U->>P: Click previous button\n   *   P->>P: previous()\n   *   alt page > 0\n   *     P->>P: Decrement current page\n   *     P->>P: handleClick('previous')\n   *   end\n   *\n   * @memberOf PaginationComponent\n   */\n  previous(): void {\n    const page = this.current - 1;\n    if(page > 0) {\n      this.current = page;\n      this.handleClick('previous');\n    }\n  }\n\n  /**\n   * @description Navigates to a specific page number.\n   * @summary Updates the current page to the specified page number and triggers\n   * the click event handler with the appropriate direction. This method is typically\n   * called when the user clicks directly on a page number in the pagination UI.\n   *\n   * @param {number | null} page - The page number to navigate to\n   * @returns {void}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant P as PaginationComponent\n   *\n   *   U->>P: Click page number\n   *   P->>P: navigate(page)\n   *   alt page is not null and different from current\n   *     P->>P: Determine direction (next/previous)\n   *     P->>P: handleClick(direction, page)\n   *   end\n   *\n   * @memberOf PaginationComponent\n   */\n  navigate(page: number | null): void {\n    if(page !== null && this.current !== page as number)\n      this.handleClick(page > this.current ? 'next' : 'previous', page);\n  }\n}\n"," <div id=\"dcf-paginator-container\" class=\"dcf-flex dcf-flex-center\">\n  <div class=\"dcf-width-1-1\">\n    <div class=\"dcf-pagination-resume\" [innerHTML]=\"locale + '.resume' | translate: {value0: current, value1: last}\"></div>\n    <div #paginationComponent class=\"dcf-pagination aeon-pagination dcf-flex-center\">\n      <div\n        aria-label=\"previous\"\n        tabindex=\"0\"\n        (click)=\"previous()\"\n        (keydown.enter)=\"previous()\" [ngClass]=\"{'dcf-disabled': current === 1}\">\n        <ion-icon name=\"chevron-back-outline\" aria-hidden=\"true\"></ion-icon>\n      </div>\n      @for(page of pages; track page) {\n        <div tabindex=\"0\" (click)=\"navigate(page['index'])\"\n          (keydown.enter)=\"navigate(page['index'])\"\n          [ngClass]=\"{'dcf-active': current === page['index'], 'dcf-disabled': page['index'] === ndivl}\">\n          <span class=\"page-item\">{{ page['text'] }}</span>\n        </div>\n      }\n      <div\n        tabindex=\"0\" (click)=\"next()\"\n        (keydown.enter)=\"next()\"\n        [ngClass]=\"{'dcf-disabled': current === last}\">\n        <ion-icon name=\"chevron-forward-outline\" aria-hidden=\"true\"></ion-icon>\n      </div>\n    </div>\n  </div>\n</div>\n"]}