@seniorsistemas/angular-components 19.0.9 → 19.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (123) hide show
  1. package/breadcrumb/lib/breadcrumb/breadcrumb-models.d.ts +2 -0
  2. package/button/lib/button/button.component.d.ts +8 -2
  3. package/checkbox/lib/checkbox/checkbox.component.d.ts +5 -1
  4. package/dialog/lib/src/dialog/dialog.component.d.ts +7 -1
  5. package/esm2022/accordion/lib/accordion/components/accordion-panel/accordion-panel.component.mjs +2 -2
  6. package/esm2022/breadcrumb/lib/breadcrumb/breadcrumb-models.mjs +1 -1
  7. package/esm2022/breadcrumb/lib/breadcrumb/breadcrumb.component.mjs +3 -3
  8. package/esm2022/breadcrumb/lib/dynamic-breadcrumb/dynamic-breadcrumb.component.mjs +8 -6
  9. package/esm2022/button/lib/button/button.component.mjs +20 -8
  10. package/esm2022/checkbox/lib/checkbox/checkbox.component.mjs +8 -5
  11. package/esm2022/confirm-dialog/lib/popup-confirm-dialog/popup-confirm-dialog.component.mjs +2 -2
  12. package/esm2022/content-generator/lib/content-generator/content-generator.component.mjs +1 -1
  13. package/esm2022/dialog/lib/src/dialog/dialog.component.mjs +9 -3
  14. package/esm2022/dynamic-form/dynamic-form/components/grid/row/row.component.mjs +1 -1
  15. package/esm2022/dynamic-form/dynamic-form/components/lookup/lookup.component.mjs +2 -2
  16. package/esm2022/dynamic-form/dynamic-form/form-field/fields/bignumber/bignumber-field.component.mjs +1 -1
  17. package/esm2022/dynamic-form/dynamic-form/form-field/fields/boolean/boolean-radio-field/boolean-field.component.mjs +1 -1
  18. package/esm2022/dynamic-form/dynamic-form/form-field/fields/boolean/boolean-switch-field/boolean-switch-field.component.mjs +2 -2
  19. package/esm2022/dynamic-form/dynamic-form/form-field/fields/button-field/button-field.component.mjs +1 -1
  20. package/esm2022/dynamic-form/dynamic-form/form-field/fields/number/number-field.component.mjs +1 -1
  21. package/esm2022/dynamic-form/dynamic-form/form-field/fields/password/password-field.component.mjs +1 -1
  22. package/esm2022/dynamic-form/dynamic-form/form-field/fields/radio-button/radio-button-field.component.mjs +1 -1
  23. package/esm2022/dynamic-form/dynamic-form/form-field/fields/select/select-field.component.mjs +2 -2
  24. package/esm2022/dynamic-form/dynamic-form/form-field/fields/text/text-field.component.mjs +1 -1
  25. package/esm2022/empty-state/lib/empty-state/empty-state.component.mjs +1 -1
  26. package/esm2022/file-picker/lib/file-picker/file-picker.component.mjs +1 -1
  27. package/esm2022/global-search/lib/global-search/components/dropdown/global-search-dropdown-item.component.mjs +1 -1
  28. package/esm2022/global-search/lib/global-search/global-search.component.mjs +1 -1
  29. package/esm2022/help-popover/lib/help-popover/help-popover/help-popover.component.mjs +1 -1
  30. package/esm2022/image-cropper/lib/image-cropper/image-cropper.component.mjs +1 -1
  31. package/esm2022/inline-edit/lib/inline-edit/components/fields/inline-edit-number/inline-edit-number.component.mjs +1 -1
  32. package/esm2022/inline-edit/lib/inline-edit/components/inline-edit-item/inline-edit-item.component.mjs +1 -1
  33. package/esm2022/kanban/lib/kanban/components/kanban-column/kanban-column.component.mjs +1 -1
  34. package/esm2022/kanban/lib/kanban/components/kanban-item/kanban-item.component.mjs +1 -1
  35. package/esm2022/lib/locale/fallback.mjs +13 -2
  36. package/esm2022/navigation-button/lib/navigation-button/navigation-button.component.mjs +1 -1
  37. package/esm2022/object-card/lib/object-card/elements/field/object-card-field.component.mjs +1 -1
  38. package/esm2022/object-card/lib/object-card/elements/main/object-card-main.component.mjs +1 -1
  39. package/esm2022/paginator/lib/paginator/paginator.component.mjs +2 -2
  40. package/esm2022/picklist/lib/picklist/picklist.component.mjs +1 -1
  41. package/esm2022/profile-picture-picker/lib/profile-picture-picker/profile-picture-picker.component.mjs +1 -1
  42. package/esm2022/select/lib/select/components/select-option/select-option.component.mjs +3 -3
  43. package/esm2022/select/lib/select/select.component.mjs +132 -20
  44. package/esm2022/shared/lib/accessibility/paginator-accessibility.directive.mjs +182 -0
  45. package/esm2022/shared/lib/accessibility/table-checkbox-accessibility.directive.mjs +174 -0
  46. package/esm2022/shared/public-api.mjs +6 -4
  47. package/esm2022/switch/lib/switch/switch.component.mjs +19 -8
  48. package/esm2022/table/lib/table/table-paging/table-paging.component.mjs +1 -1
  49. package/esm2022/tiered-menu/lib/tiered-menu/components/tiered-menu/tiered-menu.component.mjs +18 -8
  50. package/esm2022/tiered-menu/lib/tiered-menu/components/tiered-menu-item/tiered-menu-item.component.mjs +1 -1
  51. package/esm2022/tiered-menu/lib/tiered-menu/services/tiered-menu.service.mjs +1 -1
  52. package/esm2022/tiered-menu/lib/tiered-menu/tiered-menu.directive.mjs +11 -3
  53. package/esm2022/tooltip/lib/tooltip/tooltip.component.mjs +17 -11
  54. package/esm2022/tooltip/lib/tooltip/tooltip.directive.mjs +108 -241
  55. package/esm2022/tooltip/lib/tooltip/tooltip.module.mjs +4 -6
  56. package/esm2022/topbar/lib/topbar/topbar.component.mjs +2 -2
  57. package/fesm2022/seniorsistemas-angular-components-accordion.mjs +1 -1
  58. package/fesm2022/seniorsistemas-angular-components-accordion.mjs.map +1 -1
  59. package/fesm2022/seniorsistemas-angular-components-breadcrumb.mjs +9 -7
  60. package/fesm2022/seniorsistemas-angular-components-breadcrumb.mjs.map +1 -1
  61. package/fesm2022/seniorsistemas-angular-components-button.mjs +19 -7
  62. package/fesm2022/seniorsistemas-angular-components-button.mjs.map +1 -1
  63. package/fesm2022/seniorsistemas-angular-components-checkbox.mjs +7 -4
  64. package/fesm2022/seniorsistemas-angular-components-checkbox.mjs.map +1 -1
  65. package/fesm2022/seniorsistemas-angular-components-confirm-dialog.mjs +1 -1
  66. package/fesm2022/seniorsistemas-angular-components-confirm-dialog.mjs.map +1 -1
  67. package/fesm2022/seniorsistemas-angular-components-content-generator.mjs +1 -1
  68. package/fesm2022/seniorsistemas-angular-components-content-generator.mjs.map +1 -1
  69. package/fesm2022/seniorsistemas-angular-components-dialog.mjs +8 -2
  70. package/fesm2022/seniorsistemas-angular-components-dialog.mjs.map +1 -1
  71. package/fesm2022/seniorsistemas-angular-components-dynamic-form.mjs +11 -11
  72. package/fesm2022/seniorsistemas-angular-components-dynamic-form.mjs.map +1 -1
  73. package/fesm2022/seniorsistemas-angular-components-empty-state.mjs +1 -1
  74. package/fesm2022/seniorsistemas-angular-components-empty-state.mjs.map +1 -1
  75. package/fesm2022/seniorsistemas-angular-components-file-picker.mjs +1 -1
  76. package/fesm2022/seniorsistemas-angular-components-file-picker.mjs.map +1 -1
  77. package/fesm2022/seniorsistemas-angular-components-global-search.mjs +2 -2
  78. package/fesm2022/seniorsistemas-angular-components-global-search.mjs.map +1 -1
  79. package/fesm2022/seniorsistemas-angular-components-help-popover.mjs +1 -1
  80. package/fesm2022/seniorsistemas-angular-components-help-popover.mjs.map +1 -1
  81. package/fesm2022/seniorsistemas-angular-components-image-cropper.mjs +1 -1
  82. package/fesm2022/seniorsistemas-angular-components-image-cropper.mjs.map +1 -1
  83. package/fesm2022/seniorsistemas-angular-components-inline-edit.mjs +2 -2
  84. package/fesm2022/seniorsistemas-angular-components-inline-edit.mjs.map +1 -1
  85. package/fesm2022/seniorsistemas-angular-components-kanban.mjs +2 -2
  86. package/fesm2022/seniorsistemas-angular-components-kanban.mjs.map +1 -1
  87. package/fesm2022/seniorsistemas-angular-components-navigation-button.mjs +1 -1
  88. package/fesm2022/seniorsistemas-angular-components-navigation-button.mjs.map +1 -1
  89. package/fesm2022/seniorsistemas-angular-components-object-card.mjs +2 -2
  90. package/fesm2022/seniorsistemas-angular-components-object-card.mjs.map +1 -1
  91. package/fesm2022/seniorsistemas-angular-components-paginator.mjs +1 -1
  92. package/fesm2022/seniorsistemas-angular-components-paginator.mjs.map +1 -1
  93. package/fesm2022/seniorsistemas-angular-components-picklist.mjs +1 -1
  94. package/fesm2022/seniorsistemas-angular-components-picklist.mjs.map +1 -1
  95. package/fesm2022/seniorsistemas-angular-components-profile-picture-picker.mjs +1 -1
  96. package/fesm2022/seniorsistemas-angular-components-profile-picture-picker.mjs.map +1 -1
  97. package/fesm2022/seniorsistemas-angular-components-select.mjs +133 -21
  98. package/fesm2022/seniorsistemas-angular-components-select.mjs.map +1 -1
  99. package/fesm2022/seniorsistemas-angular-components-shared.mjs +354 -2
  100. package/fesm2022/seniorsistemas-angular-components-shared.mjs.map +1 -1
  101. package/fesm2022/seniorsistemas-angular-components-switch.mjs +18 -7
  102. package/fesm2022/seniorsistemas-angular-components-switch.mjs.map +1 -1
  103. package/fesm2022/seniorsistemas-angular-components-table.mjs +1 -1
  104. package/fesm2022/seniorsistemas-angular-components-table.mjs.map +1 -1
  105. package/fesm2022/seniorsistemas-angular-components-tiered-menu.mjs +26 -8
  106. package/fesm2022/seniorsistemas-angular-components-tiered-menu.mjs.map +1 -1
  107. package/fesm2022/seniorsistemas-angular-components-tooltip.mjs +125 -254
  108. package/fesm2022/seniorsistemas-angular-components-tooltip.mjs.map +1 -1
  109. package/fesm2022/seniorsistemas-angular-components-topbar.mjs +2 -2
  110. package/fesm2022/seniorsistemas-angular-components-topbar.mjs.map +1 -1
  111. package/fesm2022/seniorsistemas-angular-components.mjs +12 -1
  112. package/fesm2022/seniorsistemas-angular-components.mjs.map +1 -1
  113. package/package.json +1 -1
  114. package/select/lib/select/select.component.d.ts +23 -2
  115. package/shared/lib/accessibility/paginator-accessibility.directive.d.ts +30 -0
  116. package/shared/lib/accessibility/table-checkbox-accessibility.directive.d.ts +46 -0
  117. package/shared/public-api.d.ts +7 -5
  118. package/switch/lib/switch/switch.component.d.ts +9 -5
  119. package/tiered-menu/lib/tiered-menu/components/tiered-menu/tiered-menu.component.d.ts +1 -0
  120. package/tiered-menu/lib/tiered-menu/tiered-menu.directive.d.ts +4 -2
  121. package/tooltip/lib/tooltip/tooltip.component.d.ts +13 -7
  122. package/tooltip/lib/tooltip/tooltip.directive.d.ts +27 -40
  123. package/tooltip/lib/tooltip/tooltip.module.d.ts +3 -4
@@ -0,0 +1,182 @@
1
+ import { Directive } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@ngx-translate/core";
4
+ /**
5
+ * Diretiva para melhorar a acessibilidade dos botões do paginador PrimeNG
6
+ * Adiciona tabindex="0" aos botões habilitados e tabindex="-1" aos desabilitados
7
+ * Adiciona aria-labels traduzidos para os botões do paginador
8
+ */
9
+ export class PaginatorAccessibilityDirective {
10
+ el;
11
+ renderer;
12
+ translateService;
13
+ observer = null;
14
+ equalWebSpanMarker = 'data-equalweb-sr-only';
15
+ isObserverPaused = false;
16
+ observedPaginatorElement = null;
17
+ constructor(el, renderer, translateService) {
18
+ this.el = el;
19
+ this.renderer = renderer;
20
+ this.translateService = translateService;
21
+ }
22
+ ngOnInit() {
23
+ // Aguarda o próximo ciclo para garantir que o paginador foi renderizado
24
+ setTimeout(() => {
25
+ this.updatePaginatorButtons();
26
+ this.observePaginatorChanges();
27
+ });
28
+ }
29
+ ngOnDestroy() {
30
+ if (this.observer) {
31
+ this.observer.disconnect();
32
+ }
33
+ }
34
+ updatePaginatorButtons() {
35
+ const paginatorElement = this.el.nativeElement.querySelector('p-paginator');
36
+ if (!paginatorElement) {
37
+ return;
38
+ }
39
+ // Atualiza botões de navegação (first, prev, next, last)
40
+ const navigationSelectors = {
41
+ '.p-paginator-first': this.translateService.instant('platform.angular_components.aria_first_page'),
42
+ '.p-paginator-prev': this.translateService.instant('platform.angular_components.aria_previous_page'),
43
+ '.p-paginator-next': this.translateService.instant('platform.angular_components.aria_next_page'),
44
+ '.p-paginator-last': this.translateService.instant('platform.angular_components.aria_last_page'),
45
+ '.p-select-label': this.translateService.instant('platform.angular_components.aria_page_selection')
46
+ };
47
+ Object.entries(navigationSelectors).forEach(([selector, label]) => {
48
+ const button = paginatorElement.querySelector(selector);
49
+ if (button) {
50
+ const isDisabled = this.isButtonDisabled(button);
51
+ this.updateTabIndex(button, isDisabled);
52
+ if (isDisabled) {
53
+ this.renderer.removeAttribute(button, 'data-ind-readable');
54
+ }
55
+ else {
56
+ this.renderer.setAttribute(button, 'data-ind-readable', 'true');
57
+ }
58
+ this.renderer.setAttribute(button, 'aria-label', label);
59
+ this.applyEqualWebTextFix(button, label, isDisabled);
60
+ }
61
+ });
62
+ // Atualiza botões de página numérica
63
+ const pageButtons = paginatorElement.querySelectorAll('.p-paginator-page');
64
+ pageButtons.forEach((button) => {
65
+ const pageNumber = this.getPaginatorPageNumber(button);
66
+ if (pageNumber) {
67
+ const isDisabled = this.isButtonDisabled(button);
68
+ const isSelected = button.classList.contains('p-paginator-page-selected');
69
+ const ariaLabel = isSelected
70
+ ? this.translateService.instant('platform.angular_components.aria_current_page', { page: pageNumber })
71
+ : this.translateService.instant('platform.angular_components.aria_page_number', { page: pageNumber });
72
+ this.renderer.setAttribute(button, 'aria-label', ariaLabel);
73
+ this.updateTabIndex(button, isDisabled);
74
+ this.applyEqualWebTextFix(button, ariaLabel, isDisabled);
75
+ if (isSelected) {
76
+ this.renderer.setAttribute(button, 'aria-current', 'page');
77
+ }
78
+ else {
79
+ this.renderer.removeAttribute(button, 'aria-current');
80
+ }
81
+ }
82
+ });
83
+ }
84
+ isButtonDisabled(button) {
85
+ return button.hasAttribute('disabled') || button.classList.contains('p-disabled');
86
+ }
87
+ updateTabIndex(button, isDisabled) {
88
+ if (isDisabled) {
89
+ this.renderer.removeAttribute(button, 'tabindex');
90
+ return;
91
+ }
92
+ this.renderer.setAttribute(button, 'tabindex', '0');
93
+ }
94
+ getPaginatorPageNumber(button) {
95
+ const buttonElement = button;
96
+ // Evita pegar texto do span sr-only criado pela diretiva.
97
+ const visualLabel = buttonElement.querySelector(`span:not([${this.equalWebSpanMarker}])`);
98
+ const visualText = visualLabel?.textContent?.trim();
99
+ if (visualText) {
100
+ return visualText;
101
+ }
102
+ // Fallback para casos em que o PrimeNG renderiza sem span interno.
103
+ const srOnlyText = buttonElement.querySelector(`span[${this.equalWebSpanMarker}="true"]`)?.textContent?.trim() || '';
104
+ const fullText = buttonElement.textContent?.trim() || '';
105
+ return fullText.replace(srOnlyText, '').trim();
106
+ }
107
+ applyEqualWebTextFix(button, accessibleText, isDisabled) {
108
+ const buttonElement = button;
109
+ // Oculta spans visuais do PrimeNG para o script do EqualWeb.
110
+ const visualSpans = buttonElement.querySelectorAll(`span:not([${this.equalWebSpanMarker}])`);
111
+ visualSpans.forEach((span) => {
112
+ this.renderer.setAttribute(span, 'aria-hidden', 'true');
113
+ });
114
+ const existingSrOnly = buttonElement.querySelector(`span[${this.equalWebSpanMarker}="true"]`);
115
+ // Não mantém texto extra em botões desabilitados.
116
+ if (isDisabled) {
117
+ if (existingSrOnly) {
118
+ this.renderer.removeChild(buttonElement, existingSrOnly);
119
+ }
120
+ return;
121
+ }
122
+ if (existingSrOnly) {
123
+ this.renderer.removeAttribute(existingSrOnly, 'tabindex');
124
+ this.renderer.setProperty(existingSrOnly, 'textContent', accessibleText);
125
+ return;
126
+ }
127
+ const srOnlySpan = this.renderer.createElement('span');
128
+ this.renderer.addClass(srOnlySpan, 'sr-only');
129
+ this.renderer.setAttribute(srOnlySpan, this.equalWebSpanMarker, 'true');
130
+ this.renderer.removeAttribute(srOnlySpan, 'tabindex');
131
+ const srOnlyText = this.renderer.createText(accessibleText);
132
+ this.renderer.appendChild(srOnlySpan, srOnlyText);
133
+ this.renderer.appendChild(buttonElement, srOnlySpan);
134
+ }
135
+ observePaginatorChanges() {
136
+ const paginatorElement = this.el.nativeElement.querySelector('p-paginator');
137
+ if (!paginatorElement) {
138
+ return;
139
+ }
140
+ this.observedPaginatorElement = paginatorElement;
141
+ // Observa mudanças no paginador (quando botões são habilitados/desabilitados)
142
+ this.observer = new MutationObserver(() => {
143
+ this.updateWithObserverPaused();
144
+ });
145
+ this.startObserving();
146
+ }
147
+ updateWithObserverPaused() {
148
+ if (!this.observer || this.isObserverPaused) {
149
+ return;
150
+ }
151
+ this.isObserverPaused = true;
152
+ this.observer.disconnect();
153
+ try {
154
+ this.updatePaginatorButtons();
155
+ }
156
+ finally {
157
+ this.startObserving();
158
+ this.isObserverPaused = false;
159
+ }
160
+ }
161
+ startObserving() {
162
+ if (!this.observer || !this.observedPaginatorElement) {
163
+ return;
164
+ }
165
+ this.observer.observe(this.observedPaginatorElement, {
166
+ attributes: true,
167
+ childList: true,
168
+ subtree: true,
169
+ attributeFilter: ['disabled', 'class', 'tabindex']
170
+ });
171
+ }
172
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PaginatorAccessibilityDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Directive });
173
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: PaginatorAccessibilityDirective, isStandalone: true, selector: "[sPaginatorAccessibility]", ngImport: i0 });
174
+ }
175
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PaginatorAccessibilityDirective, decorators: [{
176
+ type: Directive,
177
+ args: [{
178
+ selector: '[sPaginatorAccessibility]',
179
+ standalone: true
180
+ }]
181
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.TranslateService }] });
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator-accessibility.directive.js","sourceRoot":"","sources":["../../../../../projects/angular-components/shared/src/lib/accessibility/paginator-accessibility.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, OnInit, Renderer2, OnDestroy } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\n\n/**\n * Diretiva para melhorar a acessibilidade dos botões do paginador PrimeNG\n * Adiciona tabindex=\"0\" aos botões habilitados e tabindex=\"-1\" aos desabilitados\n * Adiciona aria-labels traduzidos para os botões do paginador\n */\n@Directive({\n  selector: '[sPaginatorAccessibility]',\n  standalone: true\n})\nexport class PaginatorAccessibilityDirective implements OnInit, OnDestroy {\n  private observer: MutationObserver | null = null;\n  private readonly equalWebSpanMarker = 'data-equalweb-sr-only';\n  private isObserverPaused = false;\n  private observedPaginatorElement: Element | null = null;\n\n  constructor(\n    private readonly el: ElementRef,\n    private readonly renderer: Renderer2,\n    private readonly translateService: TranslateService\n  ) {}\n\n  ngOnInit() {\n    // Aguarda o próximo ciclo para garantir que o paginador foi renderizado\n    setTimeout(() => {\n      this.updatePaginatorButtons();\n      this.observePaginatorChanges();\n    });\n  }\n\n  ngOnDestroy() {\n    if (this.observer) {\n      this.observer.disconnect();\n      }\n    }\n\n  private updatePaginatorButtons() {\n    const paginatorElement = this.el.nativeElement.querySelector('p-paginator');\n    if (!paginatorElement) {\n      return;\n    }\n\n    // Atualiza botões de navegação (first, prev, next, last)\n    const navigationSelectors = {\n      '.p-paginator-first': this.translateService.instant('platform.angular_components.aria_first_page'),\n      '.p-paginator-prev': this.translateService.instant('platform.angular_components.aria_previous_page'),\n      '.p-paginator-next': this.translateService.instant('platform.angular_components.aria_next_page'),\n      '.p-paginator-last': this.translateService.instant('platform.angular_components.aria_last_page'),\n      '.p-select-label': this.translateService.instant('platform.angular_components.aria_page_selection')\n    };\n\n    Object.entries(navigationSelectors).forEach(([selector, label]) => {\n      const button = paginatorElement.querySelector(selector);\n      if (button) {\n        const isDisabled = this.isButtonDisabled(button);\n        this.updateTabIndex(button, isDisabled);\n        if (isDisabled) {\n          this.renderer.removeAttribute(button, 'data-ind-readable');\n        } else {\n          this.renderer.setAttribute(button, 'data-ind-readable', 'true');\n        }\n        this.renderer.setAttribute(button, 'aria-label', label);\n        this.applyEqualWebTextFix(button, label, isDisabled);\n      }\n    });\n\n    // Atualiza botões de página numérica\n    const pageButtons = paginatorElement.querySelectorAll('.p-paginator-page');\n    pageButtons.forEach((button: Element) => {\n      const pageNumber = this.getPaginatorPageNumber(button);\n      if (pageNumber) {\n        const isDisabled = this.isButtonDisabled(button);\n        const isSelected = button.classList.contains('p-paginator-page-selected');\n        const ariaLabel = isSelected \n          ? this.translateService.instant('platform.angular_components.aria_current_page', { page: pageNumber })\n          : this.translateService.instant('platform.angular_components.aria_page_number', { page: pageNumber });\n        this.renderer.setAttribute(button, 'aria-label', ariaLabel);\n        this.updateTabIndex(button, isDisabled);\n        this.applyEqualWebTextFix(button, ariaLabel, isDisabled);\n        \n        if (isSelected) {\n          this.renderer.setAttribute(button, 'aria-current', 'page');\n        } else {\n          this.renderer.removeAttribute(button, 'aria-current');\n        }\n      }\n    });\n  }\n\n  private isButtonDisabled(button: Element): boolean {\n    return button.hasAttribute('disabled') || button.classList.contains('p-disabled');\n  }\n\n  private updateTabIndex(button: Element, isDisabled: boolean) {\n    if (isDisabled) {\n      this.renderer.removeAttribute(button, 'tabindex');\n      return;\n    }\n\n    this.renderer.setAttribute(button, 'tabindex', '0');\n  }\n\n  private getPaginatorPageNumber(button: Element): string {\n    const buttonElement = button as HTMLElement;\n\n    // Evita pegar texto do span sr-only criado pela diretiva.\n    const visualLabel = buttonElement.querySelector(`span:not([${this.equalWebSpanMarker}])`);\n    const visualText = visualLabel?.textContent?.trim();\n    if (visualText) {\n      return visualText;\n    }\n\n    // Fallback para casos em que o PrimeNG renderiza sem span interno.\n    const srOnlyText = buttonElement.querySelector(`span[${this.equalWebSpanMarker}=\"true\"]`)?.textContent?.trim() || '';\n    const fullText = buttonElement.textContent?.trim() || '';\n    return fullText.replace(srOnlyText, '').trim();\n  }\n\n  private applyEqualWebTextFix(button: Element, accessibleText: string, isDisabled: boolean) {\n    const buttonElement = button as HTMLElement;\n\n    // Oculta spans visuais do PrimeNG para o script do EqualWeb.\n    const visualSpans = buttonElement.querySelectorAll(`span:not([${this.equalWebSpanMarker}])`);\n    visualSpans.forEach((span: Element) => {\n      this.renderer.setAttribute(span, 'aria-hidden', 'true');\n    });\n\n    const existingSrOnly = buttonElement.querySelector(`span[${this.equalWebSpanMarker}=\"true\"]`);\n\n    // Não mantém texto extra em botões desabilitados.\n    if (isDisabled) {\n      if (existingSrOnly) {\n        this.renderer.removeChild(buttonElement, existingSrOnly);\n      }\n      return;\n    }\n\n    if (existingSrOnly) {\n      this.renderer.removeAttribute(existingSrOnly, 'tabindex');\n      this.renderer.setProperty(existingSrOnly, 'textContent', accessibleText);\n      return;\n    }\n\n    const srOnlySpan = this.renderer.createElement('span');\n    this.renderer.addClass(srOnlySpan, 'sr-only');\n    this.renderer.setAttribute(srOnlySpan, this.equalWebSpanMarker, 'true');\n    this.renderer.removeAttribute(srOnlySpan, 'tabindex');\n    const srOnlyText = this.renderer.createText(accessibleText);\n    this.renderer.appendChild(srOnlySpan, srOnlyText);\n    this.renderer.appendChild(buttonElement, srOnlySpan);\n  }\n\n  private observePaginatorChanges() {\n    const paginatorElement = this.el.nativeElement.querySelector('p-paginator');\n    if (!paginatorElement) {\n      return;\n    }\n\n    this.observedPaginatorElement = paginatorElement;\n\n    // Observa mudanças no paginador (quando botões são habilitados/desabilitados)\n    this.observer = new MutationObserver(() => {\n      this.updateWithObserverPaused();\n    });\n\n    this.startObserving();\n  }\n\n  private updateWithObserverPaused() {\n    if (!this.observer || this.isObserverPaused) {\n      return;\n    }\n\n    this.isObserverPaused = true;\n    this.observer.disconnect();\n\n    try {\n      this.updatePaginatorButtons();\n    } finally {\n      this.startObserving();\n      this.isObserverPaused = false;\n    }\n  }\n\n  private startObserving() {\n    if (!this.observer || !this.observedPaginatorElement) {\n      return;\n    }\n\n    this.observer.observe(this.observedPaginatorElement, {\n      attributes: true,\n      childList: true,\n      subtree: true,\n      attributeFilter: ['disabled', 'class', 'tabindex']\n    });\n  }\n}\n"]}
@@ -0,0 +1,174 @@
1
+ import { Directive } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ /**
4
+ * Diretiva para corrigir a acessibilidade de checkboxes em tabelas PrimeNG.
5
+ *
6
+ * Propaga o `aria-label` dos custom elements wrapper (`p-tablecheckbox` e
7
+ * `p-tableheadercheckbox`) para os `<input type="checkbox">` internos e
8
+ * remove o atributo do wrapper, eliminando as violações WCAG 4.1.2:
9
+ * - `label` (crítica): input sem nome acessível
10
+ * - `aria-prohibited-attr` (séria): aria-label em custom element sem role ARIA
11
+ *
12
+ * Remove também o `aria-label` do `p-checkbox` intermediário e monitora
13
+ * mutations de atributo para re-aplicar o label correto caso o binding
14
+ * interno do PrimeNG sobrescreva o valor no input via change detection.
15
+ *
16
+ * Utiliza MutationObserver para tratar linhas adicionadas dinamicamente
17
+ * (paginação, lazy loading).
18
+ *
19
+ * Uso: `<p-table sTableCheckboxAccessibility ...>`
20
+ */
21
+ export class TableCheckboxAccessibilityDirective {
22
+ el;
23
+ childListObserver = null;
24
+ attributeObserver = null;
25
+ isChildListPaused = false;
26
+ isAttributePaused = false;
27
+ observedElements = [];
28
+ inputLabelMap = new Map();
29
+ static CHECKBOX_SELECTOR = 'p-tablecheckbox, p-tableheadercheckbox';
30
+ static INNER_CHECKBOX_SELECTOR = 'p-checkbox';
31
+ static INPUT_SELECTOR = 'input[type="checkbox"]';
32
+ static ARIA_LABEL_ATTR = 'aria-label';
33
+ constructor(el) {
34
+ this.el = el;
35
+ }
36
+ ngOnInit() {
37
+ setTimeout(() => {
38
+ this.updateCheckboxLabels();
39
+ this.observeTableChanges();
40
+ });
41
+ }
42
+ ngOnDestroy() {
43
+ this.childListObserver?.disconnect();
44
+ this.attributeObserver?.disconnect();
45
+ this.inputLabelMap.clear();
46
+ }
47
+ updateCheckboxLabels() {
48
+ const host = this.el.nativeElement;
49
+ const checkboxWrappers = host.querySelectorAll(TableCheckboxAccessibilityDirective.CHECKBOX_SELECTOR);
50
+ checkboxWrappers.forEach((wrapper) => {
51
+ const wrapperAriaLabel = wrapper.getAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR);
52
+ if (!wrapperAriaLabel?.trim()) {
53
+ return;
54
+ }
55
+ const input = wrapper.querySelector(TableCheckboxAccessibilityDirective.INPUT_SELECTOR);
56
+ if (!input) {
57
+ return;
58
+ }
59
+ this.applyLabelToInput(input, wrapperAriaLabel);
60
+ wrapper.removeAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR);
61
+ this.removeInnerCheckboxAriaLabel(wrapper);
62
+ });
63
+ }
64
+ applyLabelToInput(input, label) {
65
+ this.inputLabelMap.set(input, label);
66
+ input.setAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR, label);
67
+ }
68
+ removeInnerCheckboxAriaLabel(wrapper) {
69
+ const innerCheckbox = wrapper.querySelector(TableCheckboxAccessibilityDirective.INNER_CHECKBOX_SELECTOR);
70
+ if (innerCheckbox) {
71
+ innerCheckbox.removeAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR);
72
+ }
73
+ }
74
+ observeTableChanges() {
75
+ const host = this.el.nativeElement;
76
+ const tbody = host.querySelector('tbody');
77
+ const thead = host.querySelector('thead');
78
+ if (tbody) {
79
+ this.observedElements.push(tbody);
80
+ }
81
+ if (thead) {
82
+ this.observedElements.push(thead);
83
+ }
84
+ if (this.observedElements.length === 0) {
85
+ return;
86
+ }
87
+ this.childListObserver = new MutationObserver(() => {
88
+ this.handleChildListMutation();
89
+ });
90
+ this.attributeObserver = new MutationObserver((mutations) => {
91
+ this.handleAttributeMutations(mutations);
92
+ });
93
+ this.startObserving();
94
+ }
95
+ handleAttributeMutations(mutations) {
96
+ if (this.isAttributePaused) {
97
+ return;
98
+ }
99
+ this.isAttributePaused = true;
100
+ try {
101
+ mutations
102
+ .filter((m) => m.attributeName === TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR)
103
+ .forEach((mutation) => {
104
+ const target = mutation.target;
105
+ const tagName = target.tagName?.toLowerCase();
106
+ if (tagName === 'p-checkbox') {
107
+ target.removeAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR);
108
+ }
109
+ else if (tagName === 'input') {
110
+ this.enforceInputLabel(target);
111
+ }
112
+ else {
113
+ // Outros elementos não precisam de tratamento
114
+ }
115
+ });
116
+ }
117
+ finally {
118
+ this.isAttributePaused = false;
119
+ }
120
+ }
121
+ enforceInputLabel(input) {
122
+ const correctLabel = this.inputLabelMap.get(input);
123
+ if (!correctLabel) {
124
+ return;
125
+ }
126
+ const currentLabel = input.getAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR);
127
+ if (currentLabel !== correctLabel) {
128
+ input.setAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR, correctLabel);
129
+ }
130
+ }
131
+ handleChildListMutation() {
132
+ if (!this.childListObserver || this.isChildListPaused) {
133
+ return;
134
+ }
135
+ this.isChildListPaused = true;
136
+ this.childListObserver.disconnect();
137
+ try {
138
+ this.updateCheckboxLabels();
139
+ }
140
+ finally {
141
+ this.startObserving();
142
+ this.isChildListPaused = false;
143
+ }
144
+ }
145
+ startObserving() {
146
+ const { childListObserver, attributeObserver, observedElements } = this;
147
+ if (!childListObserver) {
148
+ return;
149
+ }
150
+ observedElements.forEach((element) => {
151
+ childListObserver.observe(element, {
152
+ childList: true,
153
+ subtree: true,
154
+ });
155
+ if (attributeObserver) {
156
+ attributeObserver.observe(element, {
157
+ attributes: true,
158
+ subtree: true,
159
+ attributeFilter: [TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR],
160
+ });
161
+ }
162
+ });
163
+ }
164
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TableCheckboxAccessibilityDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
165
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: TableCheckboxAccessibilityDirective, isStandalone: true, selector: "[sTableCheckboxAccessibility]", ngImport: i0 });
166
+ }
167
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TableCheckboxAccessibilityDirective, decorators: [{
168
+ type: Directive,
169
+ args: [{
170
+ selector: '[sTableCheckboxAccessibility]',
171
+ standalone: true,
172
+ }]
173
+ }], ctorParameters: () => [{ type: i0.ElementRef }] });
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-checkbox-accessibility.directive.js","sourceRoot":"","sources":["../../../../../projects/angular-components/shared/src/lib/accessibility/table-checkbox-accessibility.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAiC,MAAM,eAAe,CAAC;;AAEzE;;;;;;;;;;;;;;;;;GAiBG;AAKH,MAAM,OAAO,mCAAmC;IAaf;IAZrB,iBAAiB,GAA4B,IAAI,CAAC;IAClD,iBAAiB,GAA4B,IAAI,CAAC;IAClD,iBAAiB,GAAG,KAAK,CAAC;IAC1B,iBAAiB,GAAG,KAAK,CAAC;IACjB,gBAAgB,GAAc,EAAE,CAAC;IACjC,aAAa,GAAG,IAAI,GAAG,EAAmB,CAAC;IAEpD,MAAM,CAAU,iBAAiB,GAAG,wCAAwC,CAAC;IAC7E,MAAM,CAAU,uBAAuB,GAAG,YAAY,CAAC;IACvD,MAAM,CAAU,cAAc,GAAG,wBAAwB,CAAC;IAC1D,MAAM,CAAU,eAAe,GAAG,YAAY,CAAC;IAEvD,YAA6B,EAA2B;QAA3B,OAAE,GAAF,EAAE,CAAyB;IAAG,CAAC;IAE5D,QAAQ;QACJ,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC/B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACP,IAAI,CAAC,iBAAiB,EAAE,UAAU,EAAE,CAAC;QACrC,IAAI,CAAC,iBAAiB,EAAE,UAAU,EAAE,CAAC;QACrC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAEO,oBAAoB;QACxB,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;QACnC,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,mCAAmC,CAAC,iBAAiB,CAAC,CAAC;QAEtG,gBAAgB,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACjC,MAAM,gBAAgB,GAAG,OAAO,CAAC,YAAY,CAAC,mCAAmC,CAAC,eAAe,CAAC,CAAC;YACnG,IAAI,CAAC,gBAAgB,EAAE,IAAI,EAAE,EAAE,CAAC;gBAC5B,OAAO;YACX,CAAC;YAED,MAAM,KAAK,GAAG,OAAO,CAAC,aAAa,CAAC,mCAAmC,CAAC,cAAc,CAAC,CAAC;YACxF,IAAI,CAAC,KAAK,EAAE,CAAC;gBACT,OAAO;YACX,CAAC;YAED,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,gBAAgB,CAAC,CAAC;YAChD,OAAO,CAAC,eAAe,CAAC,mCAAmC,CAAC,eAAe,CAAC,CAAC;YAC7E,IAAI,CAAC,4BAA4B,CAAC,OAAO,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,iBAAiB,CAAC,KAAc,EAAE,KAAa;QACnD,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACrC,KAAK,CAAC,YAAY,CAAC,mCAAmC,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;IACnF,CAAC;IAEO,4BAA4B,CAAC,OAAgB;QACjD,MAAM,aAAa,GAAG,OAAO,CAAC,aAAa,CAAC,mCAAmC,CAAC,uBAAuB,CAAC,CAAC;QACzG,IAAI,aAAa,EAAE,CAAC;YAChB,aAAa,CAAC,eAAe,CAAC,mCAAmC,CAAC,eAAe,CAAC,CAAC;QACvF,CAAC;IACL,CAAC;IAEO,mBAAmB;QACvB,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;QACnC,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAE1C,IAAI,KAAK,EAAE,CAAC;YACR,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,KAAK,EAAE,CAAC;YACR,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC;QAED,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACrC,OAAO;QACX,CAAC;QAED,IAAI,CAAC,iBAAiB,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE;YAC/C,IAAI,CAAC,uBAAuB,EAAE,CAAC;QACnC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,GAAG,IAAI,gBAAgB,CAAC,CAAC,SAAS,EAAE,EAAE;YACxD,IAAI,CAAC,wBAAwB,CAAC,SAAS,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAEO,wBAAwB,CAAC,SAA2B;QACxD,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,OAAO;QACX,CAAC;QAED,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAE9B,IAAI,CAAC;YACD,SAAS;iBACJ,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,KAAK,mCAAmC,CAAC,eAAe,CAAC;iBACtF,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;gBAClB,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAiB,CAAC;gBAC1C,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,EAAE,WAAW,EAAE,CAAC;gBAE9C,IAAI,OAAO,KAAK,YAAY,EAAE,CAAC;oBAC3B,MAAM,CAAC,eAAe,CAAC,mCAAmC,CAAC,eAAe,CAAC,CAAC;gBAChF,CAAC;qBAAM,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;oBAC7B,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;gBACnC,CAAC;qBAAM,CAAC;oBACJ,8CAA8C;gBAClD,CAAC;YACL,CAAC,CAAC,CAAC;QACX,CAAC;gBAAS,CAAC;YACP,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QACnC,CAAC;IACL,CAAC;IAEO,iBAAiB,CAAC,KAAc;QACpC,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,YAAY,EAAE,CAAC;YAChB,OAAO;QACX,CAAC;QAED,MAAM,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC,mCAAmC,CAAC,eAAe,CAAC,CAAC;QAC7F,IAAI,YAAY,KAAK,YAAY,EAAE,CAAC;YAChC,KAAK,CAAC,YAAY,CAAC,mCAAmC,CAAC,eAAe,EAAE,YAAY,CAAC,CAAC;QAC1F,CAAC;IACL,CAAC;IAEO,uBAAuB;QAC3B,IAAI,CAAC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACpD,OAAO;QACX,CAAC;QAED,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,CAAC;QAEpC,IAAI,CAAC;YACD,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAChC,CAAC;gBAAS,CAAC;YACP,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QACnC,CAAC;IACL,CAAC;IAEO,cAAc;QAClB,MAAM,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,GAAG,IAAI,CAAC;QAExE,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACrB,OAAO;QACX,CAAC;QAED,gBAAgB,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACjC,iBAAiB,CAAC,OAAO,CAAC,OAAO,EAAE;gBAC/B,SAAS,EAAE,IAAI;gBACf,OAAO,EAAE,IAAI;aAChB,CAAC,CAAC;YAEH,IAAI,iBAAiB,EAAE,CAAC;gBACpB,iBAAiB,CAAC,OAAO,CAAC,OAAO,EAAE;oBAC/B,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,IAAI;oBACb,eAAe,EAAE,CAAC,mCAAmC,CAAC,eAAe,CAAC;iBACzE,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;wGApKQ,mCAAmC;4FAAnC,mCAAmC;;4FAAnC,mCAAmC;kBAJ/C,SAAS;mBAAC;oBACP,QAAQ,EAAE,+BAA+B;oBACzC,UAAU,EAAE,IAAI;iBACnB","sourcesContent":["import { Directive, ElementRef, OnInit, OnDestroy } from '@angular/core';\n\n/**\n * Diretiva para corrigir a acessibilidade de checkboxes em tabelas PrimeNG.\n *\n * Propaga o `aria-label` dos custom elements wrapper (`p-tablecheckbox` e\n * `p-tableheadercheckbox`) para os `<input type=\"checkbox\">` internos e\n * remove o atributo do wrapper, eliminando as violações WCAG 4.1.2:\n * - `label` (crítica): input sem nome acessível\n * - `aria-prohibited-attr` (séria): aria-label em custom element sem role ARIA\n *\n * Remove também o `aria-label` do `p-checkbox` intermediário e monitora\n * mutations de atributo para re-aplicar o label correto caso o binding\n * interno do PrimeNG sobrescreva o valor no input via change detection.\n *\n * Utiliza MutationObserver para tratar linhas adicionadas dinamicamente\n * (paginação, lazy loading).\n *\n * Uso: `<p-table sTableCheckboxAccessibility ...>`\n */\n@Directive({\n    selector: '[sTableCheckboxAccessibility]',\n    standalone: true,\n})\nexport class TableCheckboxAccessibilityDirective implements OnInit, OnDestroy {\n    private childListObserver: MutationObserver | null = null;\n    private attributeObserver: MutationObserver | null = null;\n    private isChildListPaused = false;\n    private isAttributePaused = false;\n    private readonly observedElements: Element[] = [];\n    private readonly inputLabelMap = new Map<Element, string>();\n\n    private static readonly CHECKBOX_SELECTOR = 'p-tablecheckbox, p-tableheadercheckbox';\n    private static readonly INNER_CHECKBOX_SELECTOR = 'p-checkbox';\n    private static readonly INPUT_SELECTOR = 'input[type=\"checkbox\"]';\n    private static readonly ARIA_LABEL_ATTR = 'aria-label';\n\n    constructor(private readonly el: ElementRef<HTMLElement>) {}\n\n    ngOnInit() {\n        setTimeout(() => {\n            this.updateCheckboxLabels();\n            this.observeTableChanges();\n        });\n    }\n\n    ngOnDestroy() {\n        this.childListObserver?.disconnect();\n        this.attributeObserver?.disconnect();\n        this.inputLabelMap.clear();\n    }\n\n    private updateCheckboxLabels() {\n        const host = this.el.nativeElement;\n        const checkboxWrappers = host.querySelectorAll(TableCheckboxAccessibilityDirective.CHECKBOX_SELECTOR);\n\n        checkboxWrappers.forEach((wrapper) => {\n            const wrapperAriaLabel = wrapper.getAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR);\n            if (!wrapperAriaLabel?.trim()) {\n                return;\n            }\n\n            const input = wrapper.querySelector(TableCheckboxAccessibilityDirective.INPUT_SELECTOR);\n            if (!input) {\n                return;\n            }\n\n            this.applyLabelToInput(input, wrapperAriaLabel);\n            wrapper.removeAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR);\n            this.removeInnerCheckboxAriaLabel(wrapper);\n        });\n    }\n\n    private applyLabelToInput(input: Element, label: string) {\n        this.inputLabelMap.set(input, label);\n        input.setAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR, label);\n    }\n\n    private removeInnerCheckboxAriaLabel(wrapper: Element) {\n        const innerCheckbox = wrapper.querySelector(TableCheckboxAccessibilityDirective.INNER_CHECKBOX_SELECTOR);\n        if (innerCheckbox) {\n            innerCheckbox.removeAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR);\n        }\n    }\n\n    private observeTableChanges() {\n        const host = this.el.nativeElement;\n        const tbody = host.querySelector('tbody');\n        const thead = host.querySelector('thead');\n\n        if (tbody) {\n            this.observedElements.push(tbody);\n        }\n        if (thead) {\n            this.observedElements.push(thead);\n        }\n\n        if (this.observedElements.length === 0) {\n            return;\n        }\n\n        this.childListObserver = new MutationObserver(() => {\n            this.handleChildListMutation();\n        });\n\n        this.attributeObserver = new MutationObserver((mutations) => {\n            this.handleAttributeMutations(mutations);\n        });\n\n        this.startObserving();\n    }\n\n    private handleAttributeMutations(mutations: MutationRecord[]) {\n        if (this.isAttributePaused) {\n            return;\n        }\n\n        this.isAttributePaused = true;\n\n        try {\n            mutations\n                .filter((m) => m.attributeName === TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR)\n                .forEach((mutation) => {\n                    const target = mutation.target as Element;\n                    const tagName = target.tagName?.toLowerCase();\n\n                    if (tagName === 'p-checkbox') {\n                        target.removeAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR);\n                    } else if (tagName === 'input') {\n                        this.enforceInputLabel(target);\n                    } else {\n                        // Outros elementos não precisam de tratamento\n                    }\n                });\n        } finally {\n            this.isAttributePaused = false;\n        }\n    }\n\n    private enforceInputLabel(input: Element) {\n        const correctLabel = this.inputLabelMap.get(input);\n        if (!correctLabel) {\n            return;\n        }\n\n        const currentLabel = input.getAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR);\n        if (currentLabel !== correctLabel) {\n            input.setAttribute(TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR, correctLabel);\n        }\n    }\n\n    private handleChildListMutation() {\n        if (!this.childListObserver || this.isChildListPaused) {\n            return;\n        }\n\n        this.isChildListPaused = true;\n        this.childListObserver.disconnect();\n\n        try {\n            this.updateCheckboxLabels();\n        } finally {\n            this.startObserving();\n            this.isChildListPaused = false;\n        }\n    }\n\n    private startObserving() {\n        const { childListObserver, attributeObserver, observedElements } = this;\n\n        if (!childListObserver) {\n            return;\n        }\n\n        observedElements.forEach((element) => {\n            childListObserver.observe(element, {\n                childList: true,\n                subtree: true,\n            });\n\n            if (attributeObserver) {\n                attributeObserver.observe(element, {\n                    attributes: true,\n                    subtree: true,\n                    attributeFilter: [TableCheckboxAccessibilityDirective.ARIA_LABEL_ATTR],\n                });\n            }\n        });\n    }\n}\n"]}
@@ -1,5 +1,7 @@
1
- export { EnumSeverity } from "./lib/shared/models/severities";
2
- export { BorderButtonComponent } from "./lib/shared/border-button/border-button.component";
3
- export { BorderButtonModule } from "./lib/shared/border-button/border-button.module";
1
+ export { EnumSeverity } from './lib/shared/models/severities';
2
+ export { BorderButtonComponent } from './lib/shared/border-button/border-button.component';
3
+ export { BorderButtonModule } from './lib/shared/border-button/border-button.module';
4
4
  export * from './lib/shared/helpers';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItY29tcG9uZW50cy9zaGFyZWQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzlELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBQzNGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBQ3JGLGNBQWMsc0JBQXNCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSB7IEJvcmRlckJ1dHRvbk9wdGlvbnMgfSBmcm9tIFwiLi9saWIvc2hhcmVkL21vZGVscy9ib3JkZXItYnV0dG9uLW9wdGlvbnNcIjtcbmV4cG9ydCB0eXBlIHsgU2V2ZXJpdGllcyB9IGZyb20gXCIuL2xpYi9zaGFyZWQvbW9kZWxzL3NldmVyaXRpZXNcIjtcbmV4cG9ydCB7IEVudW1TZXZlcml0eSB9IGZyb20gXCIuL2xpYi9zaGFyZWQvbW9kZWxzL3NldmVyaXRpZXNcIjtcbmV4cG9ydCB7IEJvcmRlckJ1dHRvbkNvbXBvbmVudCB9IGZyb20gXCIuL2xpYi9zaGFyZWQvYm9yZGVyLWJ1dHRvbi9ib3JkZXItYnV0dG9uLmNvbXBvbmVudFwiO1xuZXhwb3J0IHsgQm9yZGVyQnV0dG9uTW9kdWxlIH0gZnJvbSBcIi4vbGliL3NoYXJlZC9ib3JkZXItYnV0dG9uL2JvcmRlci1idXR0b24ubW9kdWxlXCI7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zaGFyZWQvaGVscGVycydcbiJdfQ==
5
+ export { PaginatorAccessibilityDirective } from './lib/accessibility/paginator-accessibility.directive';
6
+ export { TableCheckboxAccessibilityDirective } from './lib/accessibility/table-checkbox-accessibility.directive';
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItY29tcG9uZW50cy9zaGFyZWQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzlELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBQzNGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBQ3JGLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDeEcsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0sNERBQTRELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSB7IEJvcmRlckJ1dHRvbk9wdGlvbnMgfSBmcm9tICcuL2xpYi9zaGFyZWQvbW9kZWxzL2JvcmRlci1idXR0b24tb3B0aW9ucyc7XG5leHBvcnQgdHlwZSB7IFNldmVyaXRpZXMgfSBmcm9tICcuL2xpYi9zaGFyZWQvbW9kZWxzL3NldmVyaXRpZXMnO1xuZXhwb3J0IHsgRW51bVNldmVyaXR5IH0gZnJvbSAnLi9saWIvc2hhcmVkL21vZGVscy9zZXZlcml0aWVzJztcbmV4cG9ydCB7IEJvcmRlckJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vbGliL3NoYXJlZC9ib3JkZXItYnV0dG9uL2JvcmRlci1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCB7IEJvcmRlckJ1dHRvbk1vZHVsZSB9IGZyb20gJy4vbGliL3NoYXJlZC9ib3JkZXItYnV0dG9uL2JvcmRlci1idXR0b24ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NoYXJlZC9oZWxwZXJzJztcbmV4cG9ydCB7IFBhZ2luYXRvckFjY2Vzc2liaWxpdHlEaXJlY3RpdmUgfSBmcm9tICcuL2xpYi9hY2Nlc3NpYmlsaXR5L3BhZ2luYXRvci1hY2Nlc3NpYmlsaXR5LmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBUYWJsZUNoZWNrYm94QWNjZXNzaWJpbGl0eURpcmVjdGl2ZSB9IGZyb20gJy4vbGliL2FjY2Vzc2liaWxpdHkvdGFibGUtY2hlY2tib3gtYWNjZXNzaWJpbGl0eS5kaXJlY3RpdmUnO1xuXG4iXX0=
@@ -17,12 +17,14 @@ import * as i1 from "@angular/common";
17
17
  export class SwitchComponent {
18
18
  /** @description Impede alterações pelo usuário sem desabilitar o campo. @default false */
19
19
  readonly = false;
20
- /** @description Rótulo exibido quando o valor é `true`. */
21
- trueLabel;
22
- /** @description Rótulo exibido quando o valor é `false`. */
23
- falseLabel;
20
+ /** @description Rótulo exibido quando o valor é `true`. @default 'Ligado' */
21
+ trueLabel = 'Ligado';
22
+ /** @description Rótulo exibido quando o valor é `false`. @default 'Desligado' */
23
+ falseLabel = 'Desligado';
24
24
  /** @description `id` do elemento `<input>` interno para associação com `<label>`. */
25
25
  inputId;
26
+ /** @description Nome acessível descritivo do switch para tecnologias assistivas (aria-label). */
27
+ label;
26
28
  /** @description Atributo `name` do `<input>` interno. */
27
29
  inputName;
28
30
  /** @description Desabilita o componente, impedindo interação e alterações. @default false */
@@ -31,6 +33,8 @@ export class SwitchComponent {
31
33
  valueChanged = new EventEmitter();
32
34
  /** @description Valor atual do switch. @default false */
33
35
  value = false;
36
+ /** @description Controla se deve ou não exibir o value do componente. @default true */
37
+ showStatusLabel = true;
34
38
  switchRef;
35
39
  _onChange;
36
40
  _onTouched;
@@ -57,6 +61,9 @@ export class SwitchComponent {
57
61
  this.disabled = disabled;
58
62
  }
59
63
  toggleCheck() {
64
+ if (this.readonly) {
65
+ return;
66
+ }
60
67
  this.value = !this.value;
61
68
  this.valueChanged.emit(this.value);
62
69
  if (this._onChange) {
@@ -67,13 +74,13 @@ export class SwitchComponent {
67
74
  }
68
75
  }
69
76
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: SwitchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
70
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: SwitchComponent, selector: "s-switch", inputs: { readonly: "readonly", trueLabel: "trueLabel", falseLabel: "falseLabel", inputId: "inputId", inputName: "inputName", disabled: "disabled", value: "value" }, outputs: { valueChanged: "valueChanged" }, host: { listeners: { "focusin": "onFocusIn()", "focusout": "onFocusOut()" } }, providers: [
77
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: SwitchComponent, selector: "s-switch", inputs: { readonly: "readonly", trueLabel: "trueLabel", falseLabel: "falseLabel", inputId: "inputId", label: "label", inputName: "inputName", disabled: "disabled", value: "value", showStatusLabel: "showStatusLabel" }, outputs: { valueChanged: "valueChanged" }, host: { listeners: { "focusin": "onFocusIn()", "focusout": "onFocusOut()" } }, providers: [
71
78
  {
72
79
  provide: NG_VALUE_ACCESSOR,
73
80
  useExisting: forwardRef(() => SwitchComponent),
74
81
  multi: true,
75
82
  },
76
- ], viewQueries: [{ propertyName: "switchRef", first: true, predicate: ["switch"], descendants: true, static: true }], ngImport: i0, template: "<div\n #switch\n class=\"switch\"\n [ngClass]=\"{ 'switch--disabled': disabled }\"\n>\n <label class=\"switch-toggle\">\n <input\n #input\n [id]=\"inputId\"\n [name]=\"inputName\"\n type=\"checkbox\"\n [checked]=\"value\"\n [disabled]=\"readonly || disabled\"\n (change)=\"toggleCheck()\"\n />\n <span class=\"slider\"></span>\n </label>\n <span class=\"label\">\n {{ value ? trueLabel : falseLabel }}\n </span>\n</div>\n", styles: [".switch{display:inline-flex;align-items:center}.switch .switch-toggle{display:inline-block;height:24px;margin:0;position:relative;width:40px}.switch .switch-toggle input{height:0;opacity:0;width:0}.switch .switch-toggle input:checked+.slider{background-color:#428bca;border-radius:15px}.switch .switch-toggle input:checked+.slider:before{transform:translate(16px)}.switch .switch-toggle .slider{background-color:#a5a5b2;border-radius:15px;cursor:pointer;inset:0;position:absolute;transition:.4s}.switch .switch-toggle .slider:before{background-color:#fff;border-radius:50%;bottom:4px;content:\"\";height:16px;left:4px;position:absolute;transition:.4s;width:16px}.switch .label{color:#212533;font-family:\"Open Sans\" sans-serif;font-size:.875rem;font-weight:400;line-height:150%;margin-left:12px}.switch--disabled{opacity:.5}.switch--focus .switch-toggle .slider{box-shadow:0 0 0 2px #428bca80}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
83
+ ], viewQueries: [{ propertyName: "switchRef", first: true, predicate: ["switch"], descendants: true, static: true }], ngImport: i0, template: "<div\n #switch\n class=\"switch\"\n [ngClass]=\"{ 'switch--disabled': disabled }\"\n [attr.aria-disabled]=\"disabled || null\"\n>\n <label class=\"switch-toggle\">\n <input\n #input\n [id]=\"inputId\"\n [name]=\"inputName\"\n type=\"checkbox\"\n role=\"switch\"\n [attr.aria-checked]=\"value\"\n [attr.aria-label]=\"label || null\"\n [checked]=\"value\"\n [disabled]=\"disabled\"\n [attr.aria-readonly]=\"readonly || null\"\n (change)=\"toggleCheck()\"\n />\n <span\n class=\"slider\"\n aria-hidden=\"true\"\n ></span>\n </label>\n @if (showStatusLabel) {\n <span class=\"label\">{{ value ? trueLabel : falseLabel }}</span>\n }\n</div>\n\n", styles: [".switch{display:inline-flex;align-items:center}.switch .switch-toggle{display:inline-block;height:24px;margin:0;position:relative;width:40px}.switch .switch-toggle input{height:0;opacity:0;width:0}.switch .switch-toggle input:focus-visible+.slider{box-shadow:0 0 0 2px #000;outline:2px solid #000;outline-offset:1px}.switch .switch-toggle input:checked+.slider{background-color:#428bca;border-radius:15px}.switch .switch-toggle input:checked+.slider:before{transform:translate(16px)}.switch .switch-toggle .slider{background-color:#a5a5b2;border-radius:15px;cursor:pointer;inset:0;position:absolute;transition:.4s}.switch .switch-toggle .slider:before{background-color:#fff;border-radius:50%;bottom:4px;content:\"\";height:16px;left:4px;position:absolute;transition:.4s;width:16px}.switch .label{color:#212533;font-family:\"Open Sans\" sans-serif;font-size:.875rem;font-weight:400;line-height:150%;margin-left:12px}.switch .label.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.switch--disabled{opacity:.5}.switch--focus .switch-toggle .slider{box-shadow:0 0 0 2px #428bca80}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
77
84
  }
78
85
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: SwitchComponent, decorators: [{
79
86
  type: Component,
@@ -83,7 +90,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
83
90
  useExisting: forwardRef(() => SwitchComponent),
84
91
  multi: true,
85
92
  },
86
- ], template: "<div\n #switch\n class=\"switch\"\n [ngClass]=\"{ 'switch--disabled': disabled }\"\n>\n <label class=\"switch-toggle\">\n <input\n #input\n [id]=\"inputId\"\n [name]=\"inputName\"\n type=\"checkbox\"\n [checked]=\"value\"\n [disabled]=\"readonly || disabled\"\n (change)=\"toggleCheck()\"\n />\n <span class=\"slider\"></span>\n </label>\n <span class=\"label\">\n {{ value ? trueLabel : falseLabel }}\n </span>\n</div>\n", styles: [".switch{display:inline-flex;align-items:center}.switch .switch-toggle{display:inline-block;height:24px;margin:0;position:relative;width:40px}.switch .switch-toggle input{height:0;opacity:0;width:0}.switch .switch-toggle input:checked+.slider{background-color:#428bca;border-radius:15px}.switch .switch-toggle input:checked+.slider:before{transform:translate(16px)}.switch .switch-toggle .slider{background-color:#a5a5b2;border-radius:15px;cursor:pointer;inset:0;position:absolute;transition:.4s}.switch .switch-toggle .slider:before{background-color:#fff;border-radius:50%;bottom:4px;content:\"\";height:16px;left:4px;position:absolute;transition:.4s;width:16px}.switch .label{color:#212533;font-family:\"Open Sans\" sans-serif;font-size:.875rem;font-weight:400;line-height:150%;margin-left:12px}.switch--disabled{opacity:.5}.switch--focus .switch-toggle .slider{box-shadow:0 0 0 2px #428bca80}\n"] }]
93
+ ], template: "<div\n #switch\n class=\"switch\"\n [ngClass]=\"{ 'switch--disabled': disabled }\"\n [attr.aria-disabled]=\"disabled || null\"\n>\n <label class=\"switch-toggle\">\n <input\n #input\n [id]=\"inputId\"\n [name]=\"inputName\"\n type=\"checkbox\"\n role=\"switch\"\n [attr.aria-checked]=\"value\"\n [attr.aria-label]=\"label || null\"\n [checked]=\"value\"\n [disabled]=\"disabled\"\n [attr.aria-readonly]=\"readonly || null\"\n (change)=\"toggleCheck()\"\n />\n <span\n class=\"slider\"\n aria-hidden=\"true\"\n ></span>\n </label>\n @if (showStatusLabel) {\n <span class=\"label\">{{ value ? trueLabel : falseLabel }}</span>\n }\n</div>\n\n", styles: [".switch{display:inline-flex;align-items:center}.switch .switch-toggle{display:inline-block;height:24px;margin:0;position:relative;width:40px}.switch .switch-toggle input{height:0;opacity:0;width:0}.switch .switch-toggle input:focus-visible+.slider{box-shadow:0 0 0 2px #000;outline:2px solid #000;outline-offset:1px}.switch .switch-toggle input:checked+.slider{background-color:#428bca;border-radius:15px}.switch .switch-toggle input:checked+.slider:before{transform:translate(16px)}.switch .switch-toggle .slider{background-color:#a5a5b2;border-radius:15px;cursor:pointer;inset:0;position:absolute;transition:.4s}.switch .switch-toggle .slider:before{background-color:#fff;border-radius:50%;bottom:4px;content:\"\";height:16px;left:4px;position:absolute;transition:.4s;width:16px}.switch .label{color:#212533;font-family:\"Open Sans\" sans-serif;font-size:.875rem;font-weight:400;line-height:150%;margin-left:12px}.switch .label.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.switch--disabled{opacity:.5}.switch--focus .switch-toggle .slider{box-shadow:0 0 0 2px #428bca80}\n"] }]
87
94
  }], propDecorators: { readonly: [{
88
95
  type: Input
89
96
  }], trueLabel: [{
@@ -92,6 +99,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
92
99
  type: Input
93
100
  }], inputId: [{
94
101
  type: Input
102
+ }], label: [{
103
+ type: Input
95
104
  }], inputName: [{
96
105
  type: Input
97
106
  }], disabled: [{
@@ -100,6 +109,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
100
109
  type: Output
101
110
  }], value: [{
102
111
  type: Input
112
+ }], showStatusLabel: [{
113
+ type: Input
103
114
  }], switchRef: [{
104
115
  type: ViewChild,
105
116
  args: ['switch', { static: true }]
@@ -110,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
110
121
  type: HostListener,
111
122
  args: ['focusout']
112
123
  }] } });
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"switch.component.js","sourceRoot":"","sources":["../../../../../projects/angular-components/switch/src/lib/switch/switch.component.ts","../../../../../projects/angular-components/switch/src/lib/switch/switch.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n/**\n * @description Componente de chave tipo switch (liga/desliga) que implementa\n * `ControlValueAccessor` para uso em formulários Angular. Suporta rótulos\n * personalizados para os estados verdadeiro e falso, além de modo somente leitura.\n *\n * @example\n * ```html\n * <s-switch formControlName=\"ativo\" trueLabel=\"Ativo\" falseLabel=\"Inativo\" />\n * ```\n *\n * @category Inputs\n */\n@Component({\n    selector: 's-switch',\n    templateUrl: './switch.component.html',\n    styleUrls: ['./switch.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => SwitchComponent),\n            multi: true,\n        },\n    ],\n})\nexport class SwitchComponent implements ControlValueAccessor {\n    /** @description Impede alterações pelo usuário sem desabilitar o campo. @default false */\n    @Input()\n    public readonly = false;\n\n    /** @description Rótulo exibido quando o valor é `true`. */\n    @Input()\n    public trueLabel?: string;\n\n    /** @description Rótulo exibido quando o valor é `false`. */\n    @Input()\n    public falseLabel?: string;\n\n    /** @description `id` do elemento `<input>` interno para associação com `<label>`. */\n    @Input()\n    public inputId?: string;\n\n    /** @description Atributo `name` do `<input>` interno. */\n    @Input()\n    public inputName?: string;\n\n    /** @description Desabilita o componente, impedindo interação e alterações. @default false */\n    @Input()\n    public disabled = false;\n\n    /** @description Emitido quando o valor do switch muda, com o novo estado booleano. */\n    @Output()\n    public valueChanged = new EventEmitter<boolean>();\n\n    /** @description Valor atual do switch. @default false */\n    @Input()\n    public value = false;\n\n    @ViewChild('switch', { static: true })\n    public switchRef!: ElementRef;\n\n    private _onChange?: (value: boolean) => void;\n    private _onTouched?: (value: boolean) => void;\n\n    @HostListener('focusin')\n    public onFocusIn(): void {\n        const switchElement = this.switchRef.nativeElement as HTMLDivElement;\n        switchElement.classList.add('switch--focus');\n    }\n\n    @HostListener('focusout')\n    public onFocusOut(): void {\n        const switchElement = this.switchRef.nativeElement as HTMLDivElement;\n        switchElement.classList.remove('switch--focus');\n    }\n\n    public writeValue(value: boolean): void {\n        if (!this.disabled) {\n            this.value = value;\n        }\n    }\n\n    public registerOnChange(onChange: (value: boolean) => void): void {\n        this._onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: (value: boolean) => void): void {\n        this._onTouched = onTouched;\n    }\n\n    public setDisabledState?(disabled: boolean): void {\n        this.disabled = disabled;\n    }\n\n    public toggleCheck() {\n        this.value = !this.value;\n        this.valueChanged.emit(this.value);\n\n        if (this._onChange) {\n            this._onChange(this.value);\n        }\n\n        if (this._onTouched) {\n            this._onTouched(this.value);\n        }\n    }\n}\n\n","<div\n    #switch\n    class=\"switch\"\n    [ngClass]=\"{ 'switch--disabled': disabled }\"\n>\n    <label class=\"switch-toggle\">\n        <input\n            #input\n            [id]=\"inputId\"\n            [name]=\"inputName\"\n            type=\"checkbox\"\n            [checked]=\"value\"\n            [disabled]=\"readonly || disabled\"\n            (change)=\"toggleCheck()\"\n        />\n        <span class=\"slider\"></span>\n    </label>\n    <span class=\"label\">\n        {{ value ? trueLabel : falseLabel }}\n    </span>\n</div>\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"switch.component.js","sourceRoot":"","sources":["../../../../../projects/angular-components/switch/src/lib/switch/switch.component.ts","../../../../../projects/angular-components/switch/src/lib/switch/switch.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n/**\n * @description Componente de chave tipo switch (liga/desliga) que implementa\n * `ControlValueAccessor` para uso em formulários Angular. Suporta rótulos\n * personalizados para os estados verdadeiro e falso, além de modo somente leitura.\n *\n * @example\n * ```html\n * <s-switch formControlName=\"ativo\" trueLabel=\"Ativo\" falseLabel=\"Inativo\" />\n * ```\n *\n * @category Inputs\n */\n@Component({\n    selector: 's-switch',\n    templateUrl: './switch.component.html',\n    styleUrls: ['./switch.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => SwitchComponent),\n            multi: true,\n        },\n    ],\n})\nexport class SwitchComponent implements ControlValueAccessor {\n    /** @description Impede alterações pelo usuário sem desabilitar o campo. @default false */\n    @Input()\n    public readonly = false;\n\n    /** @description Rótulo exibido quando o valor é `true`. @default 'Ligado' */\n    @Input()\n    public trueLabel = 'Ligado';\n\n    /** @description Rótulo exibido quando o valor é `false`. @default 'Desligado' */\n    @Input()\n    public falseLabel = 'Desligado';\n\n    /** @description `id` do elemento `<input>` interno para associação com `<label>`. */\n    @Input()\n    public inputId?: string;\n    /** @description Nome acessível descritivo do switch para tecnologias assistivas (aria-label). */\n    @Input()\n    public label?: string;\n\n    /** @description Atributo `name` do `<input>` interno. */\n    @Input()\n    public inputName?: string;\n\n    /** @description Desabilita o componente, impedindo interação e alterações. @default false */\n    @Input()\n    public disabled = false;\n\n    /** @description Emitido quando o valor do switch muda, com o novo estado booleano. */\n    @Output()\n    public valueChanged = new EventEmitter<boolean>();\n\n    /** @description Valor atual do switch. @default false */\n    @Input()\n    public value = false;\n\n    /** @description Controla se deve ou não exibir o value do componente. @default true */\n    @Input()\n    public showStatusLabel = true;\n\n    @ViewChild('switch', { static: true })\n    public switchRef!: ElementRef;\n\n    private _onChange?: (value: boolean) => void;\n    private _onTouched?: (value: boolean) => void;\n\n    @HostListener('focusin')\n    public onFocusIn(): void {\n        const switchElement = this.switchRef.nativeElement as HTMLDivElement;\n        switchElement.classList.add('switch--focus');\n    }\n\n    @HostListener('focusout')\n    public onFocusOut(): void {\n        const switchElement = this.switchRef.nativeElement as HTMLDivElement;\n        switchElement.classList.remove('switch--focus');\n    }\n\n    public writeValue(value: boolean): void {\n        if (!this.disabled) {\n            this.value = value;\n        }\n    }\n\n    public registerOnChange(onChange: (value: boolean) => void): void {\n        this._onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: (value: boolean) => void): void {\n        this._onTouched = onTouched;\n    }\n\n    public setDisabledState?(disabled: boolean): void {\n        this.disabled = disabled;\n    }\n\n    public toggleCheck() {\n        if (this.readonly) {\n            return;\n        }\n        this.value = !this.value;\n        this.valueChanged.emit(this.value);\n\n        if (this._onChange) {\n            this._onChange(this.value);\n        }\n\n        if (this._onTouched) {\n            this._onTouched(this.value);\n        }\n    }\n}\n\n","<div\n    #switch\n    class=\"switch\"\n    [ngClass]=\"{ 'switch--disabled': disabled }\"\n    [attr.aria-disabled]=\"disabled || null\"\n>\n    <label class=\"switch-toggle\">\n        <input\n            #input\n            [id]=\"inputId\"\n            [name]=\"inputName\"\n            type=\"checkbox\"\n            role=\"switch\"\n            [attr.aria-checked]=\"value\"\n            [attr.aria-label]=\"label || null\"\n            [checked]=\"value\"\n            [disabled]=\"disabled\"\n            [attr.aria-readonly]=\"readonly || null\"\n            (change)=\"toggleCheck()\"\n        />\n        <span\n            class=\"slider\"\n            aria-hidden=\"true\"\n        ></span>\n    </label>\n    @if (showStatusLabel) {\n        <span class=\"label\">{{ value ? trueLabel : falseLabel }}</span>\n    }\n</div>\n\n"]}
@@ -295,7 +295,7 @@ export class TablePagingComponent {
295
295
  return tableData;
296
296
  }
297
297
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TablePagingComponent, deps: [{ token: i1.TranslateService }, { token: HostProjectConfigsInjectionToken }], target: i0.ɵɵFactoryTarget.Component });
298
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: TablePagingComponent, selector: "s-table-paging", inputs: { totalRecords: "totalRecords", exportFileName: "exportFileName", table: "table", exportable: "exportable", enableExportSelectedRecords: "enableExportSelectedRecords", customActions: "customActions", loadAllRecords: "loadAllRecords", loadCurrentPageRecords: "loadCurrentPageRecords", loadSelectedRecords: "loadSelectedRecords" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"paging-container\">\n <span class=\"total-records\">\n {{ totalRecordsText }}\n </span>\n @if (exportable) {\n <s-button\n class=\"export-button\"\n priority=\"default\"\n iconClass=\"fa fa-fw fa-file-export\"\n [disabled]=\"false\"\n [auxiliary]=\"true\"\n [tooltip]=\"getTooltipText()\"\n [menuOptions]=\"getActions()\"\n >\n </s-button>\n }\n</div>\n", styles: [".paging-container{display:flex;align-items:center}.export-button{margin-left:6px}\n"], dependencies: [{ kind: "component", type: i2.ButtonComponent, selector: "s-button", inputs: ["id", "label", "tooltip", "tooltipPosition", "iconClass", "rightIconClass", "caret", "styleClass", "baseZIndex", "disabled", "auxiliary", "type", "priority", "menuOptions", "menuAriaLabel", "size", "slide", "animation", "badge", "iconColor"], outputs: ["clicked"] }] });
298
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: TablePagingComponent, selector: "s-table-paging", inputs: { totalRecords: "totalRecords", exportFileName: "exportFileName", table: "table", exportable: "exportable", enableExportSelectedRecords: "enableExportSelectedRecords", customActions: "customActions", loadAllRecords: "loadAllRecords", loadCurrentPageRecords: "loadCurrentPageRecords", loadSelectedRecords: "loadSelectedRecords" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"paging-container\">\n <span class=\"total-records\">\n {{ totalRecordsText }}\n </span>\n @if (exportable) {\n <s-button\n class=\"export-button\"\n priority=\"default\"\n iconClass=\"fa fa-fw fa-file-export\"\n [disabled]=\"false\"\n [auxiliary]=\"true\"\n [tooltip]=\"getTooltipText()\"\n [menuOptions]=\"getActions()\"\n >\n </s-button>\n }\n</div>\n", styles: [".paging-container{display:flex;align-items:center}.export-button{margin-left:6px}\n"], dependencies: [{ kind: "component", type: i2.ButtonComponent, selector: "s-button", inputs: ["id", "label", "tooltip", "tooltipPosition", "iconClass", "rightIconClass", "caret", "styleClass", "baseZIndex", "disabled", "auxiliary", "type", "priority", "menuOptions", "size", "slide", "animation", "badge", "iconColor", "menuAriaLabel"], outputs: ["clicked"] }] });
299
299
  }
300
300
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TablePagingComponent, decorators: [{
301
301
  type: Component,