@seniorsistemas/angular-components 19.0.9 → 19.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/breadcrumb/lib/breadcrumb/breadcrumb-models.d.ts +2 -0
- package/button/lib/button/button.component.d.ts +8 -2
- package/checkbox/lib/checkbox/checkbox.component.d.ts +5 -1
- package/dialog/lib/src/dialog/dialog.component.d.ts +7 -1
- package/esm2022/accordion/lib/accordion/components/accordion-panel/accordion-panel.component.mjs +2 -2
- package/esm2022/breadcrumb/lib/breadcrumb/breadcrumb-models.mjs +1 -1
- package/esm2022/breadcrumb/lib/breadcrumb/breadcrumb.component.mjs +3 -3
- package/esm2022/breadcrumb/lib/dynamic-breadcrumb/dynamic-breadcrumb.component.mjs +8 -6
- package/esm2022/button/lib/button/button.component.mjs +20 -8
- package/esm2022/checkbox/lib/checkbox/checkbox.component.mjs +8 -5
- package/esm2022/confirm-dialog/lib/popup-confirm-dialog/popup-confirm-dialog.component.mjs +2 -2
- package/esm2022/content-generator/lib/content-generator/content-generator.component.mjs +1 -1
- package/esm2022/dialog/lib/src/dialog/dialog.component.mjs +9 -3
- package/esm2022/dynamic-form/dynamic-form/components/grid/row/row.component.mjs +1 -1
- package/esm2022/dynamic-form/dynamic-form/components/lookup/lookup.component.mjs +2 -2
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/bignumber/bignumber-field.component.mjs +1 -1
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/boolean/boolean-radio-field/boolean-field.component.mjs +1 -1
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/boolean/boolean-switch-field/boolean-switch-field.component.mjs +2 -2
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/button-field/button-field.component.mjs +1 -1
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/number/number-field.component.mjs +1 -1
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/password/password-field.component.mjs +1 -1
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/radio-button/radio-button-field.component.mjs +1 -1
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/select/select-field.component.mjs +2 -2
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/text/text-field.component.mjs +1 -1
- package/esm2022/empty-state/lib/empty-state/empty-state.component.mjs +1 -1
- package/esm2022/file-picker/lib/file-picker/file-picker.component.mjs +1 -1
- package/esm2022/global-search/lib/global-search/components/dropdown/global-search-dropdown-item.component.mjs +1 -1
- package/esm2022/global-search/lib/global-search/global-search.component.mjs +1 -1
- package/esm2022/help-popover/lib/help-popover/help-popover/help-popover.component.mjs +1 -1
- package/esm2022/image-cropper/lib/image-cropper/image-cropper.component.mjs +1 -1
- package/esm2022/inline-edit/lib/inline-edit/components/fields/inline-edit-number/inline-edit-number.component.mjs +1 -1
- package/esm2022/inline-edit/lib/inline-edit/components/inline-edit-item/inline-edit-item.component.mjs +1 -1
- package/esm2022/kanban/lib/kanban/components/kanban-column/kanban-column.component.mjs +1 -1
- package/esm2022/kanban/lib/kanban/components/kanban-item/kanban-item.component.mjs +1 -1
- package/esm2022/lib/locale/fallback.mjs +13 -2
- package/esm2022/navigation-button/lib/navigation-button/navigation-button.component.mjs +1 -1
- package/esm2022/object-card/lib/object-card/elements/field/object-card-field.component.mjs +1 -1
- package/esm2022/object-card/lib/object-card/elements/main/object-card-main.component.mjs +1 -1
- package/esm2022/paginator/lib/paginator/paginator.component.mjs +2 -2
- package/esm2022/picklist/lib/picklist/picklist.component.mjs +1 -1
- package/esm2022/profile-picture-picker/lib/profile-picture-picker/profile-picture-picker.component.mjs +1 -1
- package/esm2022/select/lib/select/components/select-option/select-option.component.mjs +3 -3
- package/esm2022/select/lib/select/select.component.mjs +132 -20
- package/esm2022/shared/lib/accessibility/paginator-accessibility.directive.mjs +182 -0
- package/esm2022/shared/lib/accessibility/table-checkbox-accessibility.directive.mjs +174 -0
- package/esm2022/shared/public-api.mjs +6 -4
- package/esm2022/switch/lib/switch/switch.component.mjs +19 -8
- package/esm2022/table/lib/table/table-paging/table-paging.component.mjs +1 -1
- package/esm2022/table/public-api.mjs +2 -1
- package/esm2022/tiered-menu/lib/tiered-menu/components/tiered-menu/tiered-menu.component.mjs +18 -8
- package/esm2022/tiered-menu/lib/tiered-menu/components/tiered-menu-item/tiered-menu-item.component.mjs +1 -1
- package/esm2022/tiered-menu/lib/tiered-menu/services/tiered-menu.service.mjs +1 -1
- package/esm2022/tiered-menu/lib/tiered-menu/tiered-menu.directive.mjs +11 -3
- package/esm2022/tooltip/lib/tooltip/tooltip.component.mjs +17 -11
- package/esm2022/tooltip/lib/tooltip/tooltip.directive.mjs +108 -241
- package/esm2022/tooltip/lib/tooltip/tooltip.module.mjs +4 -6
- package/esm2022/topbar/lib/topbar/topbar.component.mjs +2 -2
- package/fesm2022/seniorsistemas-angular-components-accordion.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-accordion.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-breadcrumb.mjs +9 -7
- package/fesm2022/seniorsistemas-angular-components-breadcrumb.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-button.mjs +19 -7
- package/fesm2022/seniorsistemas-angular-components-button.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-checkbox.mjs +7 -4
- package/fesm2022/seniorsistemas-angular-components-checkbox.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-confirm-dialog.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-confirm-dialog.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-content-generator.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-content-generator.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-dialog.mjs +8 -2
- package/fesm2022/seniorsistemas-angular-components-dialog.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-dynamic-form.mjs +11 -11
- package/fesm2022/seniorsistemas-angular-components-dynamic-form.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-empty-state.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-empty-state.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-file-picker.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-file-picker.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-global-search.mjs +2 -2
- package/fesm2022/seniorsistemas-angular-components-global-search.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-help-popover.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-help-popover.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-image-cropper.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-image-cropper.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-inline-edit.mjs +2 -2
- package/fesm2022/seniorsistemas-angular-components-inline-edit.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-kanban.mjs +2 -2
- package/fesm2022/seniorsistemas-angular-components-kanban.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-navigation-button.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-navigation-button.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-object-card.mjs +2 -2
- package/fesm2022/seniorsistemas-angular-components-object-card.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-paginator.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-paginator.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-picklist.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-picklist.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-profile-picture-picker.mjs +1 -1
- package/fesm2022/seniorsistemas-angular-components-profile-picture-picker.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-select.mjs +133 -21
- package/fesm2022/seniorsistemas-angular-components-select.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-shared.mjs +354 -2
- package/fesm2022/seniorsistemas-angular-components-shared.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-switch.mjs +18 -7
- package/fesm2022/seniorsistemas-angular-components-switch.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-table.mjs +2 -2
- package/fesm2022/seniorsistemas-angular-components-table.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-tiered-menu.mjs +26 -8
- package/fesm2022/seniorsistemas-angular-components-tiered-menu.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-tooltip.mjs +125 -254
- package/fesm2022/seniorsistemas-angular-components-tooltip.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-topbar.mjs +2 -2
- package/fesm2022/seniorsistemas-angular-components-topbar.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components.mjs +12 -1
- package/fesm2022/seniorsistemas-angular-components.mjs.map +1 -1
- package/package.json +1 -1
- package/select/lib/select/select.component.d.ts +23 -2
- package/shared/lib/accessibility/paginator-accessibility.directive.d.ts +30 -0
- package/shared/lib/accessibility/table-checkbox-accessibility.directive.d.ts +46 -0
- package/shared/public-api.d.ts +7 -5
- package/switch/lib/switch/switch.component.d.ts +9 -5
- package/table/public-api.d.ts +1 -0
- package/tiered-menu/lib/tiered-menu/components/tiered-menu/tiered-menu.component.d.ts +1 -0
- package/tiered-menu/lib/tiered-menu/tiered-menu.directive.d.ts +4 -2
- package/tooltip/lib/tooltip/tooltip.component.d.ts +13 -7
- package/tooltip/lib/tooltip/tooltip.directive.d.ts +27 -40
- 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
|
|
2
|
-
export { BorderButtonComponent } from
|
|
3
|
-
export { BorderButtonModule } from
|
|
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
|
-
|
|
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: "
|
|
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 ||
|
|
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 ||
|
|
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,
|
|
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", "
|
|
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,
|
|
@@ -3,4 +3,5 @@ export * from './lib/table/row-toggler/row-toggler.directive';
|
|
|
3
3
|
export * from './lib/table/table-column/index';
|
|
4
4
|
export * from './lib/table/table-paging/index';
|
|
5
5
|
export * from './lib/table/table.module';
|
|
6
|
-
|
|
6
|
+
export { ExportUtils } from './lib/table/export-utils';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItY29tcG9uZW50cy90YWJsZS9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvdGFibGUvbmF2aWdhdGlvbi9uYXZpZ2F0aW9uLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS9yb3ctdG9nZ2xlci9yb3ctdG9nZ2xlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFibGUvdGFibGUtY29sdW1uL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYmxlL3RhYmxlLXBhZ2luZy9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS90YWJsZS5tb2R1bGUnO1xuZXhwb3J0IHsgRXhwb3J0VXRpbHMgfSBmcm9tICcuL2xpYi90YWJsZS9leHBvcnQtdXRpbHMnO1xuIl19
|