@rededor/site-front-end-lib 1.3.9 → 1.3.11
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/esm2022/lib/components/filter-letter-and-terms/filter-letter-and-terms.component.mjs +6 -3
- package/esm2022/lib/components/filters/filter-generic/filter-generic.component.mjs +220 -0
- package/esm2022/lib/components/filters/filter-planos-convenios/filter-planos-convenios.component.mjs +3 -3
- package/esm2022/lib/components/index.mjs +2 -1
- package/esm2022/lib/enums/Filter.enum.mjs +9 -0
- package/esm2022/lib/enums/index.mjs +2 -1
- package/esm2022/lib/models/filters/filter-planos-convenios.model.mjs +1 -1
- package/esm2022/lib/models/filters/filter-section.type.mjs +2 -0
- package/esm2022/lib/models/filters/filter-sections.model.mjs +2 -0
- package/fesm2022/rededor-site-front-end-lib.mjs +230 -5
- package/fesm2022/rededor-site-front-end-lib.mjs.map +1 -1
- package/lib/components/filter-letter-and-terms/filter-letter-and-terms.component.d.ts +3 -0
- package/lib/components/filters/filter-generic/filter-generic.component.d.ts +56 -0
- package/lib/components/index.d.ts +1 -0
- package/lib/enums/Filter.enum.d.ts +7 -0
- package/lib/enums/index.d.ts +1 -0
- package/lib/models/filters/filter-planos-convenios.model.d.ts +16 -0
- package/lib/models/filters/filter-section.type.d.ts +13 -0
- package/lib/models/filters/filter-sections.model.d.ts +51 -0
- package/package.json +1 -1
package/esm2022/lib/components/filter-letter-and-terms/filter-letter-and-terms.component.mjs
CHANGED
|
@@ -18,6 +18,9 @@ export class FilterLetterAndTermsComponent {
|
|
|
18
18
|
return {
|
|
19
19
|
'--font-family': this.curaService.getFontFamily(''),
|
|
20
20
|
'--neutral-purewhite': this.curaService.getColor('neutral-purewhite'),
|
|
21
|
+
'--neutral-pale': this.curaService.getColor('neutral-pale'),
|
|
22
|
+
'--neutral-light': this.curaService.getColor('neutral-light'),
|
|
23
|
+
'--neutral-dark': this.curaService.getColor('neutral-dark'),
|
|
21
24
|
'--neutral-black': this.curaService.getColor('neutral-black'),
|
|
22
25
|
'--color-one-light': this.curaService.getColor('primary-light'),
|
|
23
26
|
'--color-one-base': this.curaService.getColor('primary-base'),
|
|
@@ -62,11 +65,11 @@ export class FilterLetterAndTermsComponent {
|
|
|
62
65
|
}
|
|
63
66
|
}
|
|
64
67
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterLetterAndTermsComponent, deps: [{ token: i1.CuraService }, { token: DOCUMENT }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: FilterLetterAndTermsComponent, isStandalone: true, selector: "rdsite-filter-letter-and-terms", inputs: { options: "options", baseUrl: "baseUrl", baseUrlAll: "baseUrlAll", enableScroll: "enableScroll", selectedOption: "selectedOption" }, outputs: { optionSelected: "optionSelected" }, host: { properties: { "style": "this.style" } }, ngImport: i0, template: "<div class=\"filter-letter-and-terms\">\r\n <a\r\n id=\"todas\"\r\n rdsitelink\r\n class=\"filter-option\"\r\n [class.selected]=\"selectedOption === ''\"\r\n [href]=\"baseUrlAll ? baseUrlAll : baseUrl ? baseUrl : '#'\"\r\n (click)=\"selectOption('', $event)\"\r\n >\r\n TODAS\r\n </a>\r\n\r\n @for (option of options; track option) {\r\n <a\r\n [id]=\"option\"\r\n rdsitelink\r\n class=\"filter-option\"\r\n [class.selected]=\"selectedOption === option\"\r\n [href]=\"baseUrl ? baseUrl + option.toLowerCase() : '#'\"\r\n (click)=\"selectOption(option, $event)\"\r\n >\r\n {{ option }}\r\n </a>\r\n }\r\n</div>\r\n", styles: [".filter-letter-and-terms{display:flex;flex-wrap:nowrap;align-items:center;justify-content:flex-start;gap:12px;width:100vw;margin-inline:-5vw;padding-inline:5vw;padding-block:12px;overflow-x:scroll}@media only screen and (min-width: 992px){.filter-letter-and-terms{flex-wrap:wrap;width:100%;padding:12px 0;margin:0;overflow-x:auto}}.filter-letter-and-terms .filter-option{flex:0 0 28px;display:flex;justify-content:center;align-items:center;padding:6px;color:var(--neutral-
|
|
68
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: FilterLetterAndTermsComponent, isStandalone: true, selector: "rdsite-filter-letter-and-terms", inputs: { options: "options", baseUrl: "baseUrl", baseUrlAll: "baseUrlAll", enableScroll: "enableScroll", selectedOption: "selectedOption" }, outputs: { optionSelected: "optionSelected" }, host: { properties: { "style": "this.style" } }, ngImport: i0, template: "<div class=\"filter-letter-and-terms\">\r\n <a\r\n id=\"todas\"\r\n rdsitelink\r\n class=\"filter-option\"\r\n [class.selected]=\"selectedOption === ''\"\r\n [href]=\"baseUrlAll ? baseUrlAll : baseUrl ? baseUrl : '#'\"\r\n (click)=\"selectOption('', $event)\"\r\n >\r\n TODAS\r\n </a>\r\n\r\n @for (option of options; track option) {\r\n <a\r\n [id]=\"option\"\r\n rdsitelink\r\n class=\"filter-option\"\r\n [class.selected]=\"selectedOption === option\"\r\n [href]=\"baseUrl ? baseUrl + option.toLowerCase() : '#'\"\r\n (click)=\"selectOption(option, $event)\"\r\n >\r\n {{ option }}\r\n </a>\r\n }\r\n</div>\r\n", styles: [".filter-letter-and-terms{display:flex;flex-wrap:nowrap;align-items:center;justify-content:flex-start;gap:12px;width:100vw;margin-inline:-5vw;padding-inline:5vw;padding-block:12px;overflow-x:scroll}@media only screen and (min-width: 992px){.filter-letter-and-terms{flex-wrap:wrap;width:100%;padding:12px 0;margin:0;overflow-x:auto}}.filter-letter-and-terms .filter-option{flex:0 0 28px;display:flex;justify-content:center;align-items:center;padding:6px;color:var(--neutral-dark);font-family:var(--font-family);font-size:12px;border-radius:4px;background-color:var(--neutral-pale);border:1px solid var(--neutral-light);transition:background-color .07s linear,box-shadow .07s linear,border-color .07s linear}.filter-letter-and-terms .filter-option:hover{background-color:var(--color-one-base)}.filter-letter-and-terms .filter-option:focus{outline:2px solid var(--color-one-light)}.filter-letter-and-terms .filter-option.selected{color:var(--neutral-purewhite);background-color:var(--color-one-base)}.filter-letter-and-terms .filter-option.selected:hover{background-color:var(--color-one-dark)}\n"] }); }
|
|
66
69
|
}
|
|
67
70
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterLetterAndTermsComponent, decorators: [{
|
|
68
71
|
type: Component,
|
|
69
|
-
args: [{ selector: 'rdsite-filter-letter-and-terms', standalone: true, imports: [], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<div class=\"filter-letter-and-terms\">\r\n <a\r\n id=\"todas\"\r\n rdsitelink\r\n class=\"filter-option\"\r\n [class.selected]=\"selectedOption === ''\"\r\n [href]=\"baseUrlAll ? baseUrlAll : baseUrl ? baseUrl : '#'\"\r\n (click)=\"selectOption('', $event)\"\r\n >\r\n TODAS\r\n </a>\r\n\r\n @for (option of options; track option) {\r\n <a\r\n [id]=\"option\"\r\n rdsitelink\r\n class=\"filter-option\"\r\n [class.selected]=\"selectedOption === option\"\r\n [href]=\"baseUrl ? baseUrl + option.toLowerCase() : '#'\"\r\n (click)=\"selectOption(option, $event)\"\r\n >\r\n {{ option }}\r\n </a>\r\n }\r\n</div>\r\n", styles: [".filter-letter-and-terms{display:flex;flex-wrap:nowrap;align-items:center;justify-content:flex-start;gap:12px;width:100vw;margin-inline:-5vw;padding-inline:5vw;padding-block:12px;overflow-x:scroll}@media only screen and (min-width: 992px){.filter-letter-and-terms{flex-wrap:wrap;width:100%;padding:12px 0;margin:0;overflow-x:auto}}.filter-letter-and-terms .filter-option{flex:0 0 28px;display:flex;justify-content:center;align-items:center;padding:6px;color:var(--neutral-
|
|
72
|
+
args: [{ selector: 'rdsite-filter-letter-and-terms', standalone: true, imports: [], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<div class=\"filter-letter-and-terms\">\r\n <a\r\n id=\"todas\"\r\n rdsitelink\r\n class=\"filter-option\"\r\n [class.selected]=\"selectedOption === ''\"\r\n [href]=\"baseUrlAll ? baseUrlAll : baseUrl ? baseUrl : '#'\"\r\n (click)=\"selectOption('', $event)\"\r\n >\r\n TODAS\r\n </a>\r\n\r\n @for (option of options; track option) {\r\n <a\r\n [id]=\"option\"\r\n rdsitelink\r\n class=\"filter-option\"\r\n [class.selected]=\"selectedOption === option\"\r\n [href]=\"baseUrl ? baseUrl + option.toLowerCase() : '#'\"\r\n (click)=\"selectOption(option, $event)\"\r\n >\r\n {{ option }}\r\n </a>\r\n }\r\n</div>\r\n", styles: [".filter-letter-and-terms{display:flex;flex-wrap:nowrap;align-items:center;justify-content:flex-start;gap:12px;width:100vw;margin-inline:-5vw;padding-inline:5vw;padding-block:12px;overflow-x:scroll}@media only screen and (min-width: 992px){.filter-letter-and-terms{flex-wrap:wrap;width:100%;padding:12px 0;margin:0;overflow-x:auto}}.filter-letter-and-terms .filter-option{flex:0 0 28px;display:flex;justify-content:center;align-items:center;padding:6px;color:var(--neutral-dark);font-family:var(--font-family);font-size:12px;border-radius:4px;background-color:var(--neutral-pale);border:1px solid var(--neutral-light);transition:background-color .07s linear,box-shadow .07s linear,border-color .07s linear}.filter-letter-and-terms .filter-option:hover{background-color:var(--color-one-base)}.filter-letter-and-terms .filter-option:focus{outline:2px solid var(--color-one-light)}.filter-letter-and-terms .filter-option.selected{color:var(--neutral-purewhite);background-color:var(--color-one-base)}.filter-letter-and-terms .filter-option.selected:hover{background-color:var(--color-one-dark)}\n"] }]
|
|
70
73
|
}], ctorParameters: () => [{ type: i1.CuraService }, { type: Document, decorators: [{
|
|
71
74
|
type: Inject,
|
|
72
75
|
args: [DOCUMENT]
|
|
@@ -89,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
89
92
|
type: HostBinding,
|
|
90
93
|
args: ['style']
|
|
91
94
|
}] } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-letter-and-terms.component.js","sourceRoot":"","sources":["../../../../../../projects/site-front-end-lib/src/lib/components/filter-letter-and-terms/filter-letter-and-terms.component.ts","../../../../../../projects/site-front-end-lib/src/lib/components/filter-letter-and-terms/filter-letter-and-terms.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, HostBinding, Inject, Input, Output, PLATFORM_ID } from '@angular/core';\r\nimport { CuraService } from '../../services';\r\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common';\r\n\r\n@Component({\r\n  selector: 'rdsite-filter-letter-and-terms',\r\n  standalone: true,\r\n  imports: [],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  templateUrl: './filter-letter-and-terms.component.html',\r\n  styleUrl: './filter-letter-and-terms.component.scss',\r\n})\r\nexport class FilterLetterAndTermsComponent implements AfterViewInit {\r\n  @Input() options: string[] = [];\r\n  @Input() baseUrl: string = '';\r\n  @Input() baseUrlAll: string = '';\r\n  @Input() enableScroll = false;\r\n  private isFirstScroll = true;\r\n  private _selectedOption: string = '';\r\n\r\n  @Input()\r\n  set selectedOption(value: string) {\r\n    if (this._selectedOption === value) return;\r\n    this._selectedOption = value;\r\n    if (this.enableScroll && !this.isFirstScroll) {\r\n      this.scrollToSelectedOption(value);\r\n    }\r\n  }\r\n\r\n  get selectedOption(): string {\r\n    return this._selectedOption;\r\n  }\r\n\r\n  @Output() optionSelected: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  @HostBinding('style') get style() {\r\n    return {\r\n      '--font-family': this.curaService.getFontFamily(''),\r\n      '--neutral-purewhite': this.curaService.getColor('neutral-purewhite'),\r\n      '--neutral-pale': this.curaService.getColor('neutral-pale'),\r\n      '--neutral-light': this.curaService.getColor('neutral-light'),\r\n      '--neutral-dark': this.curaService.getColor('neutral-dark'),\r\n      '--neutral-black': this.curaService.getColor('neutral-black'),\r\n      '--color-one-light': this.curaService.getColor('primary-light'),\r\n      '--color-one-base': this.curaService.getColor('primary-base'),\r\n      '--color-one-dark': this.curaService.getColor('primary-dark'),\r\n      '--color-one-darker': this.curaService.getColor('primary-darker'),\r\n    };\r\n  }\r\n\r\n  constructor(\r\n    private readonly curaService: CuraService,\r\n    @Inject(DOCUMENT) private document: Document,\r\n    @Inject(PLATFORM_ID) private readonly platformId: object,\r\n  ) {}\r\n\r\n  ngAfterViewInit() {\r\n    if (this.selectedOption) {\r\n      this.scrollToSelectedOption(this.selectedOption);\r\n      this.isFirstScroll = false;\r\n    }\r\n  }\r\n\r\n  selectOption(option: string, event: Event): void {\r\n    event.preventDefault();\r\n    this.selectedOption = option;\r\n    this.optionSelected.emit(option);\r\n  }\r\n\r\n  scrollToSelectedOption(value: string) {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      const elementId = value || 'todas';\r\n      const selectedElement = elementId === 'todas' ? this.document.getElementById('todas') : this.document.getElementById(value);\r\n      if (selectedElement) {\r\n        selectedElement.scrollIntoView({\r\n          behavior: 'smooth',\r\n          inline: 'center',\r\n          block: 'nearest',\r\n        });\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div class=\"filter-letter-and-terms\">\r\n  <a\r\n    id=\"todas\"\r\n    rdsitelink\r\n    class=\"filter-option\"\r\n    [class.selected]=\"selectedOption === ''\"\r\n    [href]=\"baseUrlAll ? baseUrlAll : baseUrl ? baseUrl : '#'\"\r\n    (click)=\"selectOption('', $event)\"\r\n  >\r\n    TODAS\r\n  </a>\r\n\r\n  @for (option of options; track option) {\r\n    <a\r\n      [id]=\"option\"\r\n      rdsitelink\r\n      class=\"filter-option\"\r\n      [class.selected]=\"selectedOption === option\"\r\n      [href]=\"baseUrl ? baseUrl + option.toLowerCase() : '#'\"\r\n      (click)=\"selectOption(option, $event)\"\r\n    >\r\n      {{ option }}\r\n    </a>\r\n  }\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
import { CommonModule, isPlatformBrowser } from '@angular/common';
|
|
2
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, HostBinding, Inject, Input, Output, PLATFORM_ID } from '@angular/core';
|
|
3
|
+
import { ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { MediaQueries } from '../../../helpers/mediaQueries';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../../services";
|
|
7
|
+
import * as i2 from "@angular/common";
|
|
8
|
+
export class FilterGenericComponent {
|
|
9
|
+
constructor(curaService, cdr, platformId) {
|
|
10
|
+
this.curaService = curaService;
|
|
11
|
+
this.cdr = cdr;
|
|
12
|
+
this.platformId = platformId;
|
|
13
|
+
this.filterChange = new EventEmitter();
|
|
14
|
+
this.closeModal = new EventEmitter();
|
|
15
|
+
this.openMobileFilter = new EventEmitter();
|
|
16
|
+
this.withContainerStyle = true;
|
|
17
|
+
this.showClearButton = true;
|
|
18
|
+
this.showApplyButton = true;
|
|
19
|
+
this.showCloseButton = false;
|
|
20
|
+
this.disableButtonsWithoutSelection = false;
|
|
21
|
+
this.showBadge = true;
|
|
22
|
+
this.showToggleIcon = true;
|
|
23
|
+
this.isFilterOpen = true;
|
|
24
|
+
this.mobileBehavior = false;
|
|
25
|
+
this.forceCollapsed = false;
|
|
26
|
+
this.emitOnReset = false;
|
|
27
|
+
this.textTitle = 'Filtrar por';
|
|
28
|
+
this.sections = [];
|
|
29
|
+
this.selectedFiltersCount = 0;
|
|
30
|
+
this.windowWidth = 0;
|
|
31
|
+
this.styleBinding = {
|
|
32
|
+
'--neutral-darker': this.curaService.getColor('neutral-darker'),
|
|
33
|
+
'--neutral-light': this.curaService.getColor('neutral-light'),
|
|
34
|
+
'--neutral-lighter': this.curaService.getColor('neutral-lighter'),
|
|
35
|
+
'--neutral-purewhite': this.curaService.getColor('neutral-purewhite'),
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
ngOnInit() {
|
|
39
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
40
|
+
this.windowWidth = window.innerWidth;
|
|
41
|
+
}
|
|
42
|
+
if (this.forceCollapsed && this.isMobile()) {
|
|
43
|
+
this.isFilterOpen = false;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
handleInputChange(event, control) {
|
|
47
|
+
control.setValue(event.detail);
|
|
48
|
+
this.updateSelectedFiltersCount();
|
|
49
|
+
}
|
|
50
|
+
handleSelectChange(event, control) {
|
|
51
|
+
if (event?.detail !== undefined) {
|
|
52
|
+
control.setValue(event.detail);
|
|
53
|
+
this.updateSelectedFiltersCount();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
handleCheckboxChange(event, options) {
|
|
57
|
+
const changedOption = options.find((opt) => opt.value === event.detail.value);
|
|
58
|
+
if (changedOption)
|
|
59
|
+
changedOption.checked = event.detail.checked;
|
|
60
|
+
this.updateCheckboxGroup(options);
|
|
61
|
+
this.updateSelectedFiltersCount();
|
|
62
|
+
}
|
|
63
|
+
handleRadioChange(event, control) {
|
|
64
|
+
const selectedValue = event.detail.value;
|
|
65
|
+
control.setValue(control.value?.value === selectedValue ? null : { value: selectedValue });
|
|
66
|
+
}
|
|
67
|
+
filter() {
|
|
68
|
+
this.emitFilterChange('filter');
|
|
69
|
+
if (this.mobileBehavior || this.showCloseButton)
|
|
70
|
+
this.close();
|
|
71
|
+
}
|
|
72
|
+
reset() {
|
|
73
|
+
this.resetAllControls();
|
|
74
|
+
this.updateSelectedFiltersCount();
|
|
75
|
+
if (this.emitOnReset) {
|
|
76
|
+
this.emitFilterChange('reset');
|
|
77
|
+
this.close();
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
close() {
|
|
81
|
+
this.closeModal.emit(true);
|
|
82
|
+
}
|
|
83
|
+
toggleFilter() {
|
|
84
|
+
if (this.mobileBehavior && this.isMobile()) {
|
|
85
|
+
this.openMobileFilter.emit();
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
this.isFilterOpen = !this.isFilterOpen;
|
|
89
|
+
}
|
|
90
|
+
this.cdr.detectChanges();
|
|
91
|
+
}
|
|
92
|
+
hasSelection() {
|
|
93
|
+
this.updateSelectedFiltersCount();
|
|
94
|
+
return this.selectedFiltersCount > 0;
|
|
95
|
+
}
|
|
96
|
+
isMobile() {
|
|
97
|
+
return this.windowWidth <= MediaQueries.smallBreakpoint;
|
|
98
|
+
}
|
|
99
|
+
getRadioGroupValue(control) {
|
|
100
|
+
const value = control?.value;
|
|
101
|
+
return value && typeof value === 'object' && 'value' in value ? value.value : null;
|
|
102
|
+
}
|
|
103
|
+
emitFilterChange(action) {
|
|
104
|
+
const filterData = this.buildFilterData();
|
|
105
|
+
const isEmpty = this.isFilterDataEmpty(filterData);
|
|
106
|
+
this.filterChange.emit({
|
|
107
|
+
data: this.emitOnReset || !isEmpty ? filterData : null,
|
|
108
|
+
action: action,
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
updateSelectedFiltersCount() {
|
|
112
|
+
this.selectedFiltersCount = this.sections.reduce((count, section) => {
|
|
113
|
+
if (!section.config?.control)
|
|
114
|
+
return count;
|
|
115
|
+
const value = section.config.control.value;
|
|
116
|
+
switch (section.type) {
|
|
117
|
+
case 'checkbox-group':
|
|
118
|
+
return count + (Array.isArray(value) ? value.filter((item) => item?.checked).length : 0);
|
|
119
|
+
case 'radio-group':
|
|
120
|
+
return count + (value?.value ? 1 : 0);
|
|
121
|
+
default:
|
|
122
|
+
return count + (value ? 1 : 0);
|
|
123
|
+
}
|
|
124
|
+
}, 0);
|
|
125
|
+
}
|
|
126
|
+
resetAllControls() {
|
|
127
|
+
this.sections.forEach((section) => {
|
|
128
|
+
if (!section.config?.control)
|
|
129
|
+
return;
|
|
130
|
+
if (section.type === 'checkbox-group') {
|
|
131
|
+
const resetOptions = section.config.options.map((option) => ({ ...option, checked: false }));
|
|
132
|
+
section.config.options = resetOptions;
|
|
133
|
+
section.config.control.setValue(resetOptions, { emitEvent: false });
|
|
134
|
+
}
|
|
135
|
+
else {
|
|
136
|
+
section.config.control.reset('', { emitEvent: false });
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
updateCheckboxGroup(options) {
|
|
141
|
+
this.sections
|
|
142
|
+
.filter((section) => section.type === 'checkbox-group')
|
|
143
|
+
.forEach((section) => {
|
|
144
|
+
section.config.options = [...options];
|
|
145
|
+
section.config.control.setValue([...options]);
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
buildFilterData() {
|
|
149
|
+
const filterData = {
|
|
150
|
+
unidade: '',
|
|
151
|
+
estado: '',
|
|
152
|
+
cobertura: [],
|
|
153
|
+
};
|
|
154
|
+
this.sections.forEach((section) => {
|
|
155
|
+
if (!section.config?.control)
|
|
156
|
+
return;
|
|
157
|
+
const value = section.config.control.value;
|
|
158
|
+
switch (section.type) {
|
|
159
|
+
case 'input':
|
|
160
|
+
filterData.unidade = value || '';
|
|
161
|
+
break;
|
|
162
|
+
case 'select':
|
|
163
|
+
filterData.estado = value || '';
|
|
164
|
+
break;
|
|
165
|
+
case 'checkbox-group':
|
|
166
|
+
filterData.cobertura = Array.isArray(value) ? value.filter((item) => item.checked) : [];
|
|
167
|
+
break;
|
|
168
|
+
}
|
|
169
|
+
});
|
|
170
|
+
return filterData;
|
|
171
|
+
}
|
|
172
|
+
isFilterDataEmpty(filterData) {
|
|
173
|
+
return Object.values(filterData).every((val) => val === null || val === '' || (Array.isArray(val) && val.length === 0));
|
|
174
|
+
}
|
|
175
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterGenericComponent, deps: [{ token: i1.CuraService }, { token: i0.ChangeDetectorRef }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
176
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: FilterGenericComponent, isStandalone: true, selector: "rdsite-filter-generic", inputs: { withContainerStyle: "withContainerStyle", showClearButton: "showClearButton", showApplyButton: "showApplyButton", showCloseButton: "showCloseButton", disableButtonsWithoutSelection: "disableButtonsWithoutSelection", showBadge: "showBadge", showToggleIcon: "showToggleIcon", isFilterOpen: "isFilterOpen", mobileBehavior: "mobileBehavior", forceCollapsed: "forceCollapsed", emitOnReset: "emitOnReset", textTitle: "textTitle", sections: "sections" }, outputs: { filterChange: "filterChange", closeModal: "closeModal", openMobileFilter: "openMobileFilter" }, host: { properties: { "style": "this.styleBinding" } }, ngImport: i0, template: "<div class=\"filter-generic\" [ngClass]=\"{ 'container-style': withContainerStyle }\" aria-label=\"Filtros\">\r\n <div class=\"filter-header-container\" [ngClass]=\"{ 'no-padding': !isFilterOpen, hidden: !isFilterOpen }\">\r\n <div class=\"filter-title-wrapper\">\r\n <cura-heading size=\"small\" level=\"4\" color=\"neutral-black\" weight=\"bold\" margin-block=\"0\" line-height=\"16px\">\r\n {{ textTitle }}\r\n </cura-heading>\r\n\r\n @if (showBadge) {\r\n <cura-badge-counter\r\n [type]=\"'solid'\"\r\n [color]=\"hasSelection() ? 'primary' : 'neutral'\"\r\n [number]=\"selectedFiltersCount\"\r\n class=\"filter-badge\"\r\n ></cura-badge-counter>\r\n }\r\n </div>\r\n\r\n @if (showToggleIcon) {\r\n <cura-button-transparent size=\"small\" font-color=\"dark\" color=\"primary\" text-align=\"center\" (click)=\"toggleFilter()\" [attr.aria-expanded]=\"isFilterOpen\">\r\n <cura-icon [name]=\"isFilterOpen ? 'up' : 'down'\" size=\"16\" class=\"filter-icon\" color=\"primary-dark\"></cura-icon>\r\n </cura-button-transparent>\r\n }\r\n </div>\r\n\r\n <div class=\"filter-content\" [class.hidden]=\"!isFilterOpen || (forceCollapsed && isMobile())\">\r\n @for (section of sections; track section.type) {\r\n @if (section.visible !== false) {\r\n <div class=\"filter-section\">\r\n @switch (section.type) {\r\n @case ('input') {\r\n <cura-input-text\r\n [placeholder]=\"section.config.placeholder || ''\"\r\n [name]=\"section.config.name || ''\"\r\n [iconName]=\"section.config.iconName || ''\"\r\n [attr.value]=\"section.config.control.value\"\r\n (valueChange)=\"handleInputChange($event, section.config.control)\"\r\n ></cura-input-text>\r\n }\r\n @case ('select') {\r\n <cura-select\r\n [label]=\"section.config.label || ''\"\r\n [placeholder]=\"section.config.placeholder || ''\"\r\n [attr.value]=\"section.config.control.value\"\r\n (selected)=\"handleSelectChange($event, section.config.control)\"\r\n >\r\n @if (section.config.includeDefaultOption) {\r\n <cura-select-option [attr.value]=\"''\">{{ section.config.defaultOptionText || 'Fa\u00E7a a sua Sele\u00E7\u00E3o' }}</cura-select-option>\r\n }\r\n @for (option of section.config.options || []; track option?.value) {\r\n <cura-select-option [attr.value]=\"option?.value\">{{ option?.label }}</cura-select-option>\r\n }\r\n </cura-select>\r\n }\r\n @case ('checkbox-group') {\r\n <div class=\"filter-header\">\r\n <cura-icon name=\"filter\" size=\"20\" color=\"info-dark\"></cura-icon>\r\n <cura-heading size=\"xsmall\" level=\"5\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\">\r\n {{ section.config.title || 'Filtre por' }}\r\n </cura-heading>\r\n </div>\r\n\r\n @if (section.config.subtitle) {\r\n <div class=\"filter-subtitle\">\r\n <cura-heading size=\"xsmall\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\">\r\n {{ section.config.subtitle }}\r\n </cura-heading>\r\n </div>\r\n }\r\n\r\n @if (section.config.description) {\r\n <div class=\"filter-description\">\r\n <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" margin-block=\"0\">\r\n {{ section.config.description }}\r\n </cura-paragraph>\r\n </div>\r\n }\r\n\r\n <div class=\"filter-checkboxes\">\r\n @for (option of section.config.options || []; track option?.value) {\r\n <cura-checkbox\r\n color=\"primary\"\r\n size=\"small\"\r\n icon-color=\"light\"\r\n [attr.name]=\"option?.label\"\r\n [attr.label]=\"option?.label\"\r\n [attr.value]=\"option?.value\"\r\n [attr.checked]=\"option?.checked\"\r\n (onchange)=\"handleCheckboxChange($event, section.config.options)\"\r\n ></cura-checkbox>\r\n }\r\n </div>\r\n }\r\n @case ('radio-group') {\r\n <div class=\"filter-radios\">\r\n @for (option of section.config.options || []; track option?.value) {\r\n <cura-radio\r\n [name]=\"section.config.name || 'radio-group'\"\r\n [label]=\"option.label\"\r\n [value]=\"option.value\"\r\n [checked]=\"getRadioGroupValue(section.config.control) === option.value\"\r\n (onchange)=\"handleRadioChange($event, section.config.control)\"\r\n ></cura-radio>\r\n }\r\n </div>\r\n }\r\n @case ('custom') {\r\n <ng-container *ngTemplateOutlet=\"section.config.template\"></ng-container>\r\n }\r\n }\r\n </div>\r\n }\r\n }\r\n </div>\r\n\r\n <div class=\"filter-actions\" [class.hidden]=\"!isFilterOpen || (forceCollapsed && isMobile())\">\r\n <div class=\"main-actions\">\r\n @if (showClearButton) {\r\n <cura-button-transparent\r\n size=\"small\"\r\n font-color=\"dark\"\r\n color=\"primary\"\r\n text-align=\"center\"\r\n [disabled]=\"disableButtonsWithoutSelection && !hasSelection()\"\r\n (click)=\"reset()\"\r\n >\r\n <span>Limpar todos os filtros</span>\r\n </cura-button-transparent>\r\n }\r\n\r\n @if (showApplyButton) {\r\n <cura-button\r\n size=\"medium\"\r\n font-color=\"light\"\r\n color=\"primary\"\r\n text-align=\"center\"\r\n (click)=\"filter()\"\r\n [disabled]=\"disableButtonsWithoutSelection && !hasSelection()\"\r\n class=\"filter-button\"\r\n >\r\n Filtrar\r\n </cura-button>\r\n }\r\n </div>\r\n\r\n @if (showCloseButton) {\r\n <div class=\"divider-strong\"></div>\r\n <div class=\"close-action-wrapper\">\r\n <div class=\"close-action\" (click)=\"close()\">\r\n <cura-icon name=\"close\" color=\"error-dark\" size=\"small\"></cura-icon>\r\n <cura-button-transparent size=\"\" type=\"button\" color=\"error\" target=\"_self\"> Fechar </cura-button-transparent>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n", styles: [":host *{font-family:Gotham,Roboto,sans-serif}.filter-generic{display:flex;flex-direction:column;gap:18px}.filter-generic.container-style{width:100%;padding:20px;border-radius:12px;border:2px solid var(--neutral-lighter);background-color:var(--neutral-purewhite)}.filter-generic cura-loader-circle{display:flex;justify-content:center;align-items:center;width:100%;min-height:100px}.filter-header-container{display:flex;padding-bottom:12px;align-items:center}.filter-header-container.no-padding{padding-bottom:0}.filter-header-container .filter-title-wrapper{display:flex;align-items:center;justify-content:space-between;flex:1 0 0}.filter-header-container .filter-badge{display:flex;height:20px;min-width:20px;justify-content:center;align-items:center;gap:4px}.filter-header-container .filter-icon{display:block}.filter-content,.filter-actions{transition:all .3s ease}.filter-content.hidden,.filter-actions.hidden{display:none;height:0;overflow:hidden;opacity:0;margin:0;padding:0}.filter-section{display:flex;flex-direction:column;gap:24px}.filter-section .filter-header{display:flex;align-items:center;gap:14px}.filter-section .filter-subtitle{font-weight:500}.filter-section .filter-description{display:flex;flex-direction:column;gap:8px}.filter-section .filter-description:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:12px;grid-column:1/-1}.filter-section .filter-checkboxes{display:grid;grid-template-columns:repeat(2,1fr);gap:11px 0px}.filter-section .filter-checkboxes:after{content:\"\";display:block;width:100%;height:1px;margin-top:12px;background-color:var(--neutral-light);grid-column:1/-1}.filter-section .filter-radios{display:flex;flex-direction:column;gap:12px}.filter-section .filter-radios:after{content:\"\";display:block;width:100%;height:1px;background:linear-gradient(90deg,var(--neutral-light) 75%,transparent 15%);background-size:10px 1px;background-repeat:repeat-x;margin-top:6px;grid-column:1/-1}.filter-actions{display:flex;flex-direction:column;gap:0}.filter-actions .main-actions{display:flex;justify-content:space-between;gap:16px;align-items:center}.filter-actions .divider-strong{height:1px;width:100%;margin-top:20px;margin-bottom:16px;background:linear-gradient(90deg,#e2e2e2 70%,transparent 70%);background-size:4px 1px;background-repeat:repeat-x}.filter-actions .close-action-wrapper{display:flex;justify-content:center;width:100%}.filter-actions .close-action{display:inline-flex;align-items:center;gap:8px}.filter-actions .close-action cura-button-transparent{padding:0;margin:0;background:transparent;border:none;color:inherit}.filter-actions cura-button,.filter-actions cura-button-transparent{flex:1}@media screen and (max-width: 1024px){.filter-checkboxes:after{background-color:transparent}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: ReactiveFormsModule }] }); }
|
|
177
|
+
}
|
|
178
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterGenericComponent, decorators: [{
|
|
179
|
+
type: Component,
|
|
180
|
+
args: [{ selector: 'rdsite-filter-generic', standalone: true, imports: [CommonModule, ReactiveFormsModule], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<div class=\"filter-generic\" [ngClass]=\"{ 'container-style': withContainerStyle }\" aria-label=\"Filtros\">\r\n <div class=\"filter-header-container\" [ngClass]=\"{ 'no-padding': !isFilterOpen, hidden: !isFilterOpen }\">\r\n <div class=\"filter-title-wrapper\">\r\n <cura-heading size=\"small\" level=\"4\" color=\"neutral-black\" weight=\"bold\" margin-block=\"0\" line-height=\"16px\">\r\n {{ textTitle }}\r\n </cura-heading>\r\n\r\n @if (showBadge) {\r\n <cura-badge-counter\r\n [type]=\"'solid'\"\r\n [color]=\"hasSelection() ? 'primary' : 'neutral'\"\r\n [number]=\"selectedFiltersCount\"\r\n class=\"filter-badge\"\r\n ></cura-badge-counter>\r\n }\r\n </div>\r\n\r\n @if (showToggleIcon) {\r\n <cura-button-transparent size=\"small\" font-color=\"dark\" color=\"primary\" text-align=\"center\" (click)=\"toggleFilter()\" [attr.aria-expanded]=\"isFilterOpen\">\r\n <cura-icon [name]=\"isFilterOpen ? 'up' : 'down'\" size=\"16\" class=\"filter-icon\" color=\"primary-dark\"></cura-icon>\r\n </cura-button-transparent>\r\n }\r\n </div>\r\n\r\n <div class=\"filter-content\" [class.hidden]=\"!isFilterOpen || (forceCollapsed && isMobile())\">\r\n @for (section of sections; track section.type) {\r\n @if (section.visible !== false) {\r\n <div class=\"filter-section\">\r\n @switch (section.type) {\r\n @case ('input') {\r\n <cura-input-text\r\n [placeholder]=\"section.config.placeholder || ''\"\r\n [name]=\"section.config.name || ''\"\r\n [iconName]=\"section.config.iconName || ''\"\r\n [attr.value]=\"section.config.control.value\"\r\n (valueChange)=\"handleInputChange($event, section.config.control)\"\r\n ></cura-input-text>\r\n }\r\n @case ('select') {\r\n <cura-select\r\n [label]=\"section.config.label || ''\"\r\n [placeholder]=\"section.config.placeholder || ''\"\r\n [attr.value]=\"section.config.control.value\"\r\n (selected)=\"handleSelectChange($event, section.config.control)\"\r\n >\r\n @if (section.config.includeDefaultOption) {\r\n <cura-select-option [attr.value]=\"''\">{{ section.config.defaultOptionText || 'Fa\u00E7a a sua Sele\u00E7\u00E3o' }}</cura-select-option>\r\n }\r\n @for (option of section.config.options || []; track option?.value) {\r\n <cura-select-option [attr.value]=\"option?.value\">{{ option?.label }}</cura-select-option>\r\n }\r\n </cura-select>\r\n }\r\n @case ('checkbox-group') {\r\n <div class=\"filter-header\">\r\n <cura-icon name=\"filter\" size=\"20\" color=\"info-dark\"></cura-icon>\r\n <cura-heading size=\"xsmall\" level=\"5\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\">\r\n {{ section.config.title || 'Filtre por' }}\r\n </cura-heading>\r\n </div>\r\n\r\n @if (section.config.subtitle) {\r\n <div class=\"filter-subtitle\">\r\n <cura-heading size=\"xsmall\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\">\r\n {{ section.config.subtitle }}\r\n </cura-heading>\r\n </div>\r\n }\r\n\r\n @if (section.config.description) {\r\n <div class=\"filter-description\">\r\n <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" margin-block=\"0\">\r\n {{ section.config.description }}\r\n </cura-paragraph>\r\n </div>\r\n }\r\n\r\n <div class=\"filter-checkboxes\">\r\n @for (option of section.config.options || []; track option?.value) {\r\n <cura-checkbox\r\n color=\"primary\"\r\n size=\"small\"\r\n icon-color=\"light\"\r\n [attr.name]=\"option?.label\"\r\n [attr.label]=\"option?.label\"\r\n [attr.value]=\"option?.value\"\r\n [attr.checked]=\"option?.checked\"\r\n (onchange)=\"handleCheckboxChange($event, section.config.options)\"\r\n ></cura-checkbox>\r\n }\r\n </div>\r\n }\r\n @case ('radio-group') {\r\n <div class=\"filter-radios\">\r\n @for (option of section.config.options || []; track option?.value) {\r\n <cura-radio\r\n [name]=\"section.config.name || 'radio-group'\"\r\n [label]=\"option.label\"\r\n [value]=\"option.value\"\r\n [checked]=\"getRadioGroupValue(section.config.control) === option.value\"\r\n (onchange)=\"handleRadioChange($event, section.config.control)\"\r\n ></cura-radio>\r\n }\r\n </div>\r\n }\r\n @case ('custom') {\r\n <ng-container *ngTemplateOutlet=\"section.config.template\"></ng-container>\r\n }\r\n }\r\n </div>\r\n }\r\n }\r\n </div>\r\n\r\n <div class=\"filter-actions\" [class.hidden]=\"!isFilterOpen || (forceCollapsed && isMobile())\">\r\n <div class=\"main-actions\">\r\n @if (showClearButton) {\r\n <cura-button-transparent\r\n size=\"small\"\r\n font-color=\"dark\"\r\n color=\"primary\"\r\n text-align=\"center\"\r\n [disabled]=\"disableButtonsWithoutSelection && !hasSelection()\"\r\n (click)=\"reset()\"\r\n >\r\n <span>Limpar todos os filtros</span>\r\n </cura-button-transparent>\r\n }\r\n\r\n @if (showApplyButton) {\r\n <cura-button\r\n size=\"medium\"\r\n font-color=\"light\"\r\n color=\"primary\"\r\n text-align=\"center\"\r\n (click)=\"filter()\"\r\n [disabled]=\"disableButtonsWithoutSelection && !hasSelection()\"\r\n class=\"filter-button\"\r\n >\r\n Filtrar\r\n </cura-button>\r\n }\r\n </div>\r\n\r\n @if (showCloseButton) {\r\n <div class=\"divider-strong\"></div>\r\n <div class=\"close-action-wrapper\">\r\n <div class=\"close-action\" (click)=\"close()\">\r\n <cura-icon name=\"close\" color=\"error-dark\" size=\"small\"></cura-icon>\r\n <cura-button-transparent size=\"\" type=\"button\" color=\"error\" target=\"_self\"> Fechar </cura-button-transparent>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n", styles: [":host *{font-family:Gotham,Roboto,sans-serif}.filter-generic{display:flex;flex-direction:column;gap:18px}.filter-generic.container-style{width:100%;padding:20px;border-radius:12px;border:2px solid var(--neutral-lighter);background-color:var(--neutral-purewhite)}.filter-generic cura-loader-circle{display:flex;justify-content:center;align-items:center;width:100%;min-height:100px}.filter-header-container{display:flex;padding-bottom:12px;align-items:center}.filter-header-container.no-padding{padding-bottom:0}.filter-header-container .filter-title-wrapper{display:flex;align-items:center;justify-content:space-between;flex:1 0 0}.filter-header-container .filter-badge{display:flex;height:20px;min-width:20px;justify-content:center;align-items:center;gap:4px}.filter-header-container .filter-icon{display:block}.filter-content,.filter-actions{transition:all .3s ease}.filter-content.hidden,.filter-actions.hidden{display:none;height:0;overflow:hidden;opacity:0;margin:0;padding:0}.filter-section{display:flex;flex-direction:column;gap:24px}.filter-section .filter-header{display:flex;align-items:center;gap:14px}.filter-section .filter-subtitle{font-weight:500}.filter-section .filter-description{display:flex;flex-direction:column;gap:8px}.filter-section .filter-description:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:12px;grid-column:1/-1}.filter-section .filter-checkboxes{display:grid;grid-template-columns:repeat(2,1fr);gap:11px 0px}.filter-section .filter-checkboxes:after{content:\"\";display:block;width:100%;height:1px;margin-top:12px;background-color:var(--neutral-light);grid-column:1/-1}.filter-section .filter-radios{display:flex;flex-direction:column;gap:12px}.filter-section .filter-radios:after{content:\"\";display:block;width:100%;height:1px;background:linear-gradient(90deg,var(--neutral-light) 75%,transparent 15%);background-size:10px 1px;background-repeat:repeat-x;margin-top:6px;grid-column:1/-1}.filter-actions{display:flex;flex-direction:column;gap:0}.filter-actions .main-actions{display:flex;justify-content:space-between;gap:16px;align-items:center}.filter-actions .divider-strong{height:1px;width:100%;margin-top:20px;margin-bottom:16px;background:linear-gradient(90deg,#e2e2e2 70%,transparent 70%);background-size:4px 1px;background-repeat:repeat-x}.filter-actions .close-action-wrapper{display:flex;justify-content:center;width:100%}.filter-actions .close-action{display:inline-flex;align-items:center;gap:8px}.filter-actions .close-action cura-button-transparent{padding:0;margin:0;background:transparent;border:none;color:inherit}.filter-actions cura-button,.filter-actions cura-button-transparent{flex:1}@media screen and (max-width: 1024px){.filter-checkboxes:after{background-color:transparent}}\n"] }]
|
|
181
|
+
}], ctorParameters: () => [{ type: i1.CuraService }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
|
182
|
+
type: Inject,
|
|
183
|
+
args: [PLATFORM_ID]
|
|
184
|
+
}] }], propDecorators: { filterChange: [{
|
|
185
|
+
type: Output
|
|
186
|
+
}], closeModal: [{
|
|
187
|
+
type: Output
|
|
188
|
+
}], openMobileFilter: [{
|
|
189
|
+
type: Output
|
|
190
|
+
}], withContainerStyle: [{
|
|
191
|
+
type: Input
|
|
192
|
+
}], showClearButton: [{
|
|
193
|
+
type: Input
|
|
194
|
+
}], showApplyButton: [{
|
|
195
|
+
type: Input
|
|
196
|
+
}], showCloseButton: [{
|
|
197
|
+
type: Input
|
|
198
|
+
}], disableButtonsWithoutSelection: [{
|
|
199
|
+
type: Input
|
|
200
|
+
}], showBadge: [{
|
|
201
|
+
type: Input
|
|
202
|
+
}], showToggleIcon: [{
|
|
203
|
+
type: Input
|
|
204
|
+
}], isFilterOpen: [{
|
|
205
|
+
type: Input
|
|
206
|
+
}], mobileBehavior: [{
|
|
207
|
+
type: Input
|
|
208
|
+
}], forceCollapsed: [{
|
|
209
|
+
type: Input
|
|
210
|
+
}], emitOnReset: [{
|
|
211
|
+
type: Input
|
|
212
|
+
}], textTitle: [{
|
|
213
|
+
type: Input
|
|
214
|
+
}], sections: [{
|
|
215
|
+
type: Input
|
|
216
|
+
}], styleBinding: [{
|
|
217
|
+
type: HostBinding,
|
|
218
|
+
args: ['style']
|
|
219
|
+
}] } });
|
|
220
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-generic.component.js","sourceRoot":"","sources":["../../../../../../../projects/site-front-end-lib/src/lib/components/filters/filter-generic/filter-generic.component.ts","../../../../../../../projects/site-front-end-lib/src/lib/components/filters/filter-generic/filter-generic.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, HostBinding, Inject, Input, OnInit, Output, PLATFORM_ID } from '@angular/core';\r\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\r\nimport { CuraService } from '../../../services';\r\nimport { MediaQueries } from '../../../helpers/mediaQueries';\r\nimport { FilterAction, FilterControlValue, FilterSection } from '../../../models/filters/filter-section.type';\r\nimport { FilterEvent, FilterPlanosConveniosChange } from '../../../models/filters/filter-planos-convenios.model';\r\n\r\n@Component({\r\n  selector: 'rdsite-filter-generic',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  templateUrl: './filter-generic.component.html',\r\n  styleUrls: ['./filter-generic.component.scss'],\r\n})\r\nexport class FilterGenericComponent implements OnInit {\r\n  @Output() filterChange = new EventEmitter<FilterEvent>();\r\n  @Output() closeModal = new EventEmitter<boolean>();\r\n  @Output() openMobileFilter = new EventEmitter<void>();\r\n\r\n  @Input() withContainerStyle = true;\r\n  @Input() showClearButton = true;\r\n  @Input() showApplyButton = true;\r\n  @Input() showCloseButton = false;\r\n  @Input() disableButtonsWithoutSelection = false;\r\n  @Input() showBadge = true;\r\n  @Input() showToggleIcon = true;\r\n  @Input() isFilterOpen = true;\r\n  @Input() mobileBehavior = false;\r\n  @Input() forceCollapsed = false;\r\n  @Input() emitOnReset = false;\r\n  @Input() textTitle = 'Filtrar por';\r\n  @Input() sections: FilterSection[] = [];\r\n\r\n  selectedFiltersCount: number = 0;\r\n  windowWidth: number = 0;\r\n\r\n  @HostBinding('style') styleBinding = {\r\n    '--neutral-darker': this.curaService.getColor('neutral-darker'),\r\n    '--neutral-light': this.curaService.getColor('neutral-light'),\r\n    '--neutral-lighter': this.curaService.getColor('neutral-lighter'),\r\n    '--neutral-purewhite': this.curaService.getColor('neutral-purewhite'),\r\n  };\r\n\r\n  constructor(\r\n    private readonly curaService: CuraService,\r\n    private readonly cdr: ChangeDetectorRef,\r\n    @Inject(PLATFORM_ID) private readonly platformId: object,\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      this.windowWidth = window.innerWidth;\r\n    }\r\n\r\n    if (this.forceCollapsed && this.isMobile()) {\r\n      this.isFilterOpen = false;\r\n    }\r\n  }\r\n\r\n  handleInputChange(event: any, control: FormControl): void {\r\n    control.setValue(event.detail);\r\n    this.updateSelectedFiltersCount();\r\n  }\r\n\r\n  handleSelectChange(event: any, control: FormControl): void {\r\n    if (event?.detail !== undefined) {\r\n      control.setValue(event.detail);\r\n      this.updateSelectedFiltersCount();\r\n    }\r\n  }\r\n\r\n  handleCheckboxChange(event: any, options: any[]): void {\r\n    const changedOption = options.find((opt) => opt.value === event.detail.value);\r\n    if (changedOption) changedOption.checked = event.detail.checked;\r\n\r\n    this.updateCheckboxGroup(options);\r\n    this.updateSelectedFiltersCount();\r\n  }\r\n\r\n  handleRadioChange(event: any, control: FormControl): void {\r\n    const selectedValue = event.detail.value;\r\n    control.setValue(control.value?.value === selectedValue ? null : { value: selectedValue });\r\n  }\r\n\r\n  filter(): void {\r\n    this.emitFilterChange('filter');\r\n    if (this.mobileBehavior || this.showCloseButton) this.close();\r\n  }\r\n\r\n  reset(): void {\r\n    this.resetAllControls();\r\n    this.updateSelectedFiltersCount();\r\n\r\n    if (this.emitOnReset) {\r\n      this.emitFilterChange('reset');\r\n      this.close();\r\n    }\r\n  }\r\n\r\n  close(): void {\r\n    this.closeModal.emit(true);\r\n  }\r\n\r\n  toggleFilter(): void {\r\n    if (this.mobileBehavior && this.isMobile()) {\r\n      this.openMobileFilter.emit();\r\n    } else {\r\n      this.isFilterOpen = !this.isFilterOpen;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  hasSelection(): boolean {\r\n    this.updateSelectedFiltersCount();\r\n    return this.selectedFiltersCount > 0;\r\n  }\r\n\r\n  isMobile(): boolean {\r\n    return this.windowWidth <= MediaQueries.smallBreakpoint;\r\n  }\r\n\r\n  getRadioGroupValue(control?: FormControl<FilterControlValue>): any {\r\n    const value = control?.value;\r\n    return value && typeof value === 'object' && 'value' in value ? value.value : null;\r\n  }\r\n\r\n  private emitFilterChange(action: FilterAction): void {\r\n    const filterData = this.buildFilterData();\r\n    const isEmpty = this.isFilterDataEmpty(filterData);\r\n\r\n    this.filterChange.emit({\r\n      data: this.emitOnReset || !isEmpty ? filterData : null,\r\n      action: action,\r\n    });\r\n  }\r\n\r\n  private updateSelectedFiltersCount(): void {\r\n    this.selectedFiltersCount = this.sections.reduce((count, section) => {\r\n      if (!section.config?.control) return count;\r\n\r\n      const value = section.config.control.value;\r\n\r\n      switch (section.type) {\r\n        case 'checkbox-group':\r\n          return count + (Array.isArray(value) ? value.filter((item) => item?.checked).length : 0);\r\n        case 'radio-group':\r\n          return count + (value?.value ? 1 : 0);\r\n        default:\r\n          return count + (value ? 1 : 0);\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  private resetAllControls(): void {\r\n    this.sections.forEach((section) => {\r\n      if (!section.config?.control) return;\r\n\r\n      if (section.type === 'checkbox-group') {\r\n        const resetOptions = section.config.options.map((option: any) => ({ ...option, checked: false }));\r\n        section.config.options = resetOptions;\r\n        section.config.control.setValue(resetOptions, { emitEvent: false });\r\n      } else {\r\n        section.config.control.reset('', { emitEvent: false });\r\n      }\r\n    });\r\n  }\r\n\r\n  private updateCheckboxGroup(options: any[]): void {\r\n    this.sections\r\n      .filter((section) => section.type === 'checkbox-group')\r\n      .forEach((section) => {\r\n        section.config.options = [...options];\r\n        section.config.control.setValue([...options]);\r\n      });\r\n  }\r\n\r\n  private buildFilterData(): FilterPlanosConveniosChange | any {\r\n    const filterData: FilterPlanosConveniosChange = {\r\n      unidade: '',\r\n      estado: '',\r\n      cobertura: [],\r\n    };\r\n\r\n    this.sections.forEach((section) => {\r\n      if (!section.config?.control) return;\r\n\r\n      const value = section.config.control.value;\r\n\r\n      switch (section.type) {\r\n        case 'input':\r\n          filterData.unidade = value || '';\r\n          break;\r\n        case 'select':\r\n          filterData.estado = value || '';\r\n          break;\r\n        case 'checkbox-group':\r\n          filterData.cobertura = Array.isArray(value) ? value.filter((item) => item.checked) : [];\r\n          break;\r\n      }\r\n    });\r\n\r\n    return filterData;\r\n  }\r\n\r\n  private isFilterDataEmpty(filterData: FilterPlanosConveniosChange): boolean {\r\n    return Object.values(filterData).every((val) => val === null || val === '' || (Array.isArray(val) && val.length === 0));\r\n  }\r\n}\r\n","<div class=\"filter-generic\" [ngClass]=\"{ 'container-style': withContainerStyle }\" aria-label=\"Filtros\">\r\n  <div class=\"filter-header-container\" [ngClass]=\"{ 'no-padding': !isFilterOpen, hidden: !isFilterOpen }\">\r\n    <div class=\"filter-title-wrapper\">\r\n      <cura-heading size=\"small\" level=\"4\" color=\"neutral-black\" weight=\"bold\" margin-block=\"0\" line-height=\"16px\">\r\n        {{ textTitle }}\r\n      </cura-heading>\r\n\r\n      @if (showBadge) {\r\n        <cura-badge-counter\r\n          [type]=\"'solid'\"\r\n          [color]=\"hasSelection() ? 'primary' : 'neutral'\"\r\n          [number]=\"selectedFiltersCount\"\r\n          class=\"filter-badge\"\r\n        ></cura-badge-counter>\r\n      }\r\n    </div>\r\n\r\n    @if (showToggleIcon) {\r\n      <cura-button-transparent size=\"small\" font-color=\"dark\" color=\"primary\" text-align=\"center\" (click)=\"toggleFilter()\" [attr.aria-expanded]=\"isFilterOpen\">\r\n        <cura-icon [name]=\"isFilterOpen ? 'up' : 'down'\" size=\"16\" class=\"filter-icon\" color=\"primary-dark\"></cura-icon>\r\n      </cura-button-transparent>\r\n    }\r\n  </div>\r\n\r\n  <div class=\"filter-content\" [class.hidden]=\"!isFilterOpen || (forceCollapsed && isMobile())\">\r\n    @for (section of sections; track section.type) {\r\n      @if (section.visible !== false) {\r\n        <div class=\"filter-section\">\r\n          @switch (section.type) {\r\n            @case ('input') {\r\n              <cura-input-text\r\n                [placeholder]=\"section.config.placeholder || ''\"\r\n                [name]=\"section.config.name || ''\"\r\n                [iconName]=\"section.config.iconName || ''\"\r\n                [attr.value]=\"section.config.control.value\"\r\n                (valueChange)=\"handleInputChange($event, section.config.control)\"\r\n              ></cura-input-text>\r\n            }\r\n            @case ('select') {\r\n              <cura-select\r\n                [label]=\"section.config.label || ''\"\r\n                [placeholder]=\"section.config.placeholder || ''\"\r\n                [attr.value]=\"section.config.control.value\"\r\n                (selected)=\"handleSelectChange($event, section.config.control)\"\r\n              >\r\n                @if (section.config.includeDefaultOption) {\r\n                  <cura-select-option [attr.value]=\"''\">{{ section.config.defaultOptionText || 'Faça a sua Seleção' }}</cura-select-option>\r\n                }\r\n                @for (option of section.config.options || []; track option?.value) {\r\n                  <cura-select-option [attr.value]=\"option?.value\">{{ option?.label }}</cura-select-option>\r\n                }\r\n              </cura-select>\r\n            }\r\n            @case ('checkbox-group') {\r\n              <div class=\"filter-header\">\r\n                <cura-icon name=\"filter\" size=\"20\" color=\"info-dark\"></cura-icon>\r\n                <cura-heading size=\"xsmall\" level=\"5\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\">\r\n                  {{ section.config.title || 'Filtre por' }}\r\n                </cura-heading>\r\n              </div>\r\n\r\n              @if (section.config.subtitle) {\r\n                <div class=\"filter-subtitle\">\r\n                  <cura-heading size=\"xsmall\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\">\r\n                    {{ section.config.subtitle }}\r\n                  </cura-heading>\r\n                </div>\r\n              }\r\n\r\n              @if (section.config.description) {\r\n                <div class=\"filter-description\">\r\n                  <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" margin-block=\"0\">\r\n                    {{ section.config.description }}\r\n                  </cura-paragraph>\r\n                </div>\r\n              }\r\n\r\n              <div class=\"filter-checkboxes\">\r\n                @for (option of section.config.options || []; track option?.value) {\r\n                  <cura-checkbox\r\n                    color=\"primary\"\r\n                    size=\"small\"\r\n                    icon-color=\"light\"\r\n                    [attr.name]=\"option?.label\"\r\n                    [attr.label]=\"option?.label\"\r\n                    [attr.value]=\"option?.value\"\r\n                    [attr.checked]=\"option?.checked\"\r\n                    (onchange)=\"handleCheckboxChange($event, section.config.options)\"\r\n                  ></cura-checkbox>\r\n                }\r\n              </div>\r\n            }\r\n            @case ('radio-group') {\r\n              <div class=\"filter-radios\">\r\n                @for (option of section.config.options || []; track option?.value) {\r\n                  <cura-radio\r\n                    [name]=\"section.config.name || 'radio-group'\"\r\n                    [label]=\"option.label\"\r\n                    [value]=\"option.value\"\r\n                    [checked]=\"getRadioGroupValue(section.config.control) === option.value\"\r\n                    (onchange)=\"handleRadioChange($event, section.config.control)\"\r\n                  ></cura-radio>\r\n                }\r\n              </div>\r\n            }\r\n            @case ('custom') {\r\n              <ng-container *ngTemplateOutlet=\"section.config.template\"></ng-container>\r\n            }\r\n          }\r\n        </div>\r\n      }\r\n    }\r\n  </div>\r\n\r\n  <div class=\"filter-actions\" [class.hidden]=\"!isFilterOpen || (forceCollapsed && isMobile())\">\r\n    <div class=\"main-actions\">\r\n      @if (showClearButton) {\r\n        <cura-button-transparent\r\n          size=\"small\"\r\n          font-color=\"dark\"\r\n          color=\"primary\"\r\n          text-align=\"center\"\r\n          [disabled]=\"disableButtonsWithoutSelection && !hasSelection()\"\r\n          (click)=\"reset()\"\r\n        >\r\n          <span>Limpar todos os filtros</span>\r\n        </cura-button-transparent>\r\n      }\r\n\r\n      @if (showApplyButton) {\r\n        <cura-button\r\n          size=\"medium\"\r\n          font-color=\"light\"\r\n          color=\"primary\"\r\n          text-align=\"center\"\r\n          (click)=\"filter()\"\r\n          [disabled]=\"disableButtonsWithoutSelection && !hasSelection()\"\r\n          class=\"filter-button\"\r\n        >\r\n          Filtrar\r\n        </cura-button>\r\n      }\r\n    </div>\r\n\r\n    @if (showCloseButton) {\r\n      <div class=\"divider-strong\"></div>\r\n      <div class=\"close-action-wrapper\">\r\n        <div class=\"close-action\" (click)=\"close()\">\r\n          <cura-icon name=\"close\" color=\"error-dark\" size=\"small\"></cura-icon>\r\n          <cura-button-transparent size=\"\" type=\"button\" color=\"error\" target=\"_self\"> Fechar </cura-button-transparent>\r\n        </div>\r\n      </div>\r\n    }\r\n  </div>\r\n</div>\r\n"]}
|
package/esm2022/lib/components/filters/filter-planos-convenios/filter-planos-convenios.component.mjs
CHANGED
|
@@ -95,11 +95,11 @@ export class FilterPlanosConveniosComponent {
|
|
|
95
95
|
this.coberturaControl.reset(this.coberturas);
|
|
96
96
|
}
|
|
97
97
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterPlanosConveniosComponent, deps: [{ token: i1.CuraService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
98
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: FilterPlanosConveniosComponent, isStandalone: true, selector: "rdsite-filter-planos-convenios", inputs: { withContainerStyle: "withContainerStyle", isLoading: "isLoading", emitOnChange: "emitOnChange", initialEstado: "initialEstado", estados: "estados", coberturas: "coberturas", unidadeControl: "unidadeControl", estadoControl: "estadoControl" }, outputs: { filterChange: "filterChange", closeModal: "closeModal" }, host: { properties: { "style": "this.styleBinding" } }, ngImport: i0, template: "<div class=\"filter-planos-convenios\" [ngClass]=\"{ 'container-style': withContainerStyle }\">\
|
|
98
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: FilterPlanosConveniosComponent, isStandalone: true, selector: "rdsite-filter-planos-convenios", inputs: { withContainerStyle: "withContainerStyle", isLoading: "isLoading", emitOnChange: "emitOnChange", initialEstado: "initialEstado", estados: "estados", coberturas: "coberturas", unidadeControl: "unidadeControl", estadoControl: "estadoControl" }, outputs: { filterChange: "filterChange", closeModal: "closeModal" }, host: { properties: { "style": "this.styleBinding" } }, ngImport: i0, template: "<div class=\"filter-planos-convenios\" [ngClass]=\"{ 'container-style': withContainerStyle }\">\n @if (!isLoading) {\n <cura-heading size=\"small\" level=\"4\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\"> Refine sua busca </cura-heading>\n\n <div class=\"filter-planos-convenios-unidade\">\n <cura-input-text\n placeholder=\"Nome da unidade\"\n name=\"unidade-input\"\n icon-name=\"search\"\n autocomplete=\"off\"\n [attr.value]=\"unidadeControl.value\"\n (valueChange)=\"inputTextChange($event)\"\n ></cura-input-text>\n </div>\n\n <div class=\"filter-planos-convenios-estado\">\n @if (estados) {\n <cura-select\n label=\"Selecione o estado\"\n placeholder=\"Fa\u00E7a a sua Sele\u00E7\u00E3o\"\n mode=\"default\"\n size=\"medium\"\n status=\"default\"\n [attr.value]=\"estadoControl.value\"\n (selected)=\"selectChange($event)\"\n >\n <cura-select-option [attr.value]=\"''\">Fa\u00E7a a sua Sele\u00E7\u00E3o</cura-select-option>\n\n @for (estado of estados || []; track estado?.value) {\n <cura-select-option [attr.value]=\"estado?.value\">{{ estado?.label }}</cura-select-option>\n }\n </cura-select>\n }\n </div>\n\n <div class=\"filter-planos-convenios-cobertura\">\n <cura-icon name=\"filter\" size=\"20\" color=\"info-dark\"></cura-icon>\n <cura-heading size=\"xsmall\" level=\"5\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\">\n Filtre pela cobertura do seu plano\n </cura-heading>\n </div>\n\n <div class=\"filter-planos-convenios-content\">\n <cura-heading size=\"xsmall\" level=\"5\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\"> Tipos de cobertura </cura-heading>\n <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" margin-block=\"0\">\n Voc\u00EA pode selecionar uma ou mais portas de entrada, de acordo com a cobertura do seu plano.\n </cura-paragraph>\n </div>\n\n <div class=\"filter-planos-convenios-checkboxes\">\n @for (option of coberturas || []; track option?.value) {\n <cura-checkbox\n color=\"primary\"\n size=\"small\"\n icon-color=\"light\"\n [attr.name]=\"option?.label\"\n [attr.label]=\"option?.label\"\n [attr.value]=\"option?.value\"\n [attr.checked]=\"option?.checked\"\n (onchange)=\"checkboxChange($event)\"\n >\n </cura-checkbox>\n }\n </div>\n\n <div class=\"filter-planos-convenios-buttons\">\n <cura-button-transparent size=\"small\" color=\"primary\" font-color=\"dark\" text-align=\"center\" (click)=\"reset()\">\n <span> Limpar todos os filtros </span>\n </cura-button-transparent>\n\n <cura-button size=\"medium\" color=\"primary\" font-color=\"light\" background=\"light\" text-align=\"center\" (click)=\"filter()\"> Filtrar </cura-button>\n </div>\n } @else {\n <cura-loader-circle color=\"primary\" size=\"small\"> </cura-loader-circle>\n }\n</div>\n", styles: [".filter-planos-convenios{display:flex;flex-direction:column;gap:23px}.filter-planos-convenios.container-style{width:100%;padding:20px;border-radius:4px;border:1px solid var(--neutral-lighter, #e2e2e2);background-color:var(--neutral-purewhite, #ffffff)}.filter-planos-convenios-cobertura{color:var(--neutral-darker);display:flex;align-items:center;gap:14px}.filter-planos-convenios-content{display:flex;flex-direction:column;gap:10px}.filter-planos-convenios-content:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:13px}.filter-planos-convenios-checkboxes{display:grid;grid-template-columns:repeat(2,1fr);gap:11px 0px}.filter-planos-convenios-checkboxes:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:12px;grid-column:1/-1}.filter-planos-convenios-buttons{display:flex;gap:10px;justify-content:space-between}.filter-planos-convenios-buttons cura-button-transparent{display:flex;flex:1 0 0;max-width:170px}.filter-planos-convenios-buttons cura-button-transparent span{line-height:13px;letter-spacing:.72px;text-align:left}.filter-planos-convenios-buttons cura-button{display:flex;flex:0 0 100px}cura-loader-circle{display:flex;justify-content:center;align-items:center;width:100%;min-height:100px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }] }); }
|
|
99
99
|
}
|
|
100
100
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterPlanosConveniosComponent, decorators: [{
|
|
101
101
|
type: Component,
|
|
102
|
-
args: [{ selector: 'rdsite-filter-planos-convenios', standalone: true, imports: [CommonModule, ReactiveFormsModule], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<div class=\"filter-planos-convenios\" [ngClass]=\"{ 'container-style': withContainerStyle }\">\
|
|
102
|
+
args: [{ selector: 'rdsite-filter-planos-convenios', standalone: true, imports: [CommonModule, ReactiveFormsModule], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<div class=\"filter-planos-convenios\" [ngClass]=\"{ 'container-style': withContainerStyle }\">\n @if (!isLoading) {\n <cura-heading size=\"small\" level=\"4\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\"> Refine sua busca </cura-heading>\n\n <div class=\"filter-planos-convenios-unidade\">\n <cura-input-text\n placeholder=\"Nome da unidade\"\n name=\"unidade-input\"\n icon-name=\"search\"\n autocomplete=\"off\"\n [attr.value]=\"unidadeControl.value\"\n (valueChange)=\"inputTextChange($event)\"\n ></cura-input-text>\n </div>\n\n <div class=\"filter-planos-convenios-estado\">\n @if (estados) {\n <cura-select\n label=\"Selecione o estado\"\n placeholder=\"Fa\u00E7a a sua Sele\u00E7\u00E3o\"\n mode=\"default\"\n size=\"medium\"\n status=\"default\"\n [attr.value]=\"estadoControl.value\"\n (selected)=\"selectChange($event)\"\n >\n <cura-select-option [attr.value]=\"''\">Fa\u00E7a a sua Sele\u00E7\u00E3o</cura-select-option>\n\n @for (estado of estados || []; track estado?.value) {\n <cura-select-option [attr.value]=\"estado?.value\">{{ estado?.label }}</cura-select-option>\n }\n </cura-select>\n }\n </div>\n\n <div class=\"filter-planos-convenios-cobertura\">\n <cura-icon name=\"filter\" size=\"20\" color=\"info-dark\"></cura-icon>\n <cura-heading size=\"xsmall\" level=\"5\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\">\n Filtre pela cobertura do seu plano\n </cura-heading>\n </div>\n\n <div class=\"filter-planos-convenios-content\">\n <cura-heading size=\"xsmall\" level=\"5\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\"> Tipos de cobertura </cura-heading>\n <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" margin-block=\"0\">\n Voc\u00EA pode selecionar uma ou mais portas de entrada, de acordo com a cobertura do seu plano.\n </cura-paragraph>\n </div>\n\n <div class=\"filter-planos-convenios-checkboxes\">\n @for (option of coberturas || []; track option?.value) {\n <cura-checkbox\n color=\"primary\"\n size=\"small\"\n icon-color=\"light\"\n [attr.name]=\"option?.label\"\n [attr.label]=\"option?.label\"\n [attr.value]=\"option?.value\"\n [attr.checked]=\"option?.checked\"\n (onchange)=\"checkboxChange($event)\"\n >\n </cura-checkbox>\n }\n </div>\n\n <div class=\"filter-planos-convenios-buttons\">\n <cura-button-transparent size=\"small\" color=\"primary\" font-color=\"dark\" text-align=\"center\" (click)=\"reset()\">\n <span> Limpar todos os filtros </span>\n </cura-button-transparent>\n\n <cura-button size=\"medium\" color=\"primary\" font-color=\"light\" background=\"light\" text-align=\"center\" (click)=\"filter()\"> Filtrar </cura-button>\n </div>\n } @else {\n <cura-loader-circle color=\"primary\" size=\"small\"> </cura-loader-circle>\n }\n</div>\n", styles: [".filter-planos-convenios{display:flex;flex-direction:column;gap:23px}.filter-planos-convenios.container-style{width:100%;padding:20px;border-radius:4px;border:1px solid var(--neutral-lighter, #e2e2e2);background-color:var(--neutral-purewhite, #ffffff)}.filter-planos-convenios-cobertura{color:var(--neutral-darker);display:flex;align-items:center;gap:14px}.filter-planos-convenios-content{display:flex;flex-direction:column;gap:10px}.filter-planos-convenios-content:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:13px}.filter-planos-convenios-checkboxes{display:grid;grid-template-columns:repeat(2,1fr);gap:11px 0px}.filter-planos-convenios-checkboxes:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:12px;grid-column:1/-1}.filter-planos-convenios-buttons{display:flex;gap:10px;justify-content:space-between}.filter-planos-convenios-buttons cura-button-transparent{display:flex;flex:1 0 0;max-width:170px}.filter-planos-convenios-buttons cura-button-transparent span{line-height:13px;letter-spacing:.72px;text-align:left}.filter-planos-convenios-buttons cura-button{display:flex;flex:0 0 100px}cura-loader-circle{display:flex;justify-content:center;align-items:center;width:100%;min-height:100px}\n"] }]
|
|
103
103
|
}], ctorParameters: () => [{ type: i1.CuraService }], propDecorators: { filterChange: [{
|
|
104
104
|
type: Output
|
|
105
105
|
}], closeModal: [{
|
|
@@ -124,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
124
124
|
type: HostBinding,
|
|
125
125
|
args: ['style']
|
|
126
126
|
}] } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-planos-convenios.component.js","sourceRoot":"","sources":["../../../../../../../projects/site-front-end-lib/src/lib/components/filters/filter-planos-convenios/filter-planos-convenios.component.ts","../../../../../../../projects/site-front-end-lib/src/lib/components/filters/filter-planos-convenios/filter-planos-convenios.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, HostBinding, Input, Output } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\r\nimport { Estados } from '../../../enums';\r\nimport { FilterPlanosConvenios, FilterPlanosConveniosChange, FilterPlanosConveniosCobertura } from '../../../models/filters/filter-planos-convenios.model';\r\nimport { CuraService } from '../../../services';\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nimport type * as _ from '@rededor/cura/dist/types/components.js';\r\n\r\ninterface CuraCheckboxOption<T = any> {\r\n  value: T;\r\n  checked: boolean;\r\n  indeterminate?: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'rdsite-filter-planos-convenios',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  templateUrl: './filter-planos-convenios.component.html',\r\n  styleUrls: ['./filter-planos-convenios.component.scss'],\r\n})\r\nexport class FilterPlanosConveniosComponent implements AfterViewInit {\r\n  @Output() filterChange = new EventEmitter<FilterPlanosConveniosChange>();\r\n  @Output() closeModal = new EventEmitter<boolean>();\r\n\r\n  @Input() withContainerStyle: boolean = false;\r\n  @Input() isLoading: boolean = false;\r\n  @Input() emitOnChange: boolean = false;\r\n\r\n  @Input() initialEstado: Estados | string | number | null = null;\r\n\r\n  @Input() estados: FilterPlanosConvenios[] = Object.entries(Estados).map(([key, value]) => ({\r\n    label: value,\r\n    value: key,\r\n  }));\r\n\r\n  @Input() coberturas: FilterPlanosConveniosCobertura[] = [\r\n    { label: 'Consultas', value: 'FLAG_ACEITA_AMBULATORIO', checked: false },\r\n    { label: 'Emergência', value: 'FLAG_ACEITA_PS', checked: false },\r\n    { label: 'Exames', value: 'FLAG_ACEITA_EXAME', checked: false },\r\n    { label: 'Internação', value: 'FLAG_ACEITA_INTERNACAO', checked: false },\r\n  ];\r\n\r\n  @Input() unidadeControl = new FormControl<string | number | null>('');\r\n  @Input() estadoControl = new FormControl<Estados | string | number | null>('');\r\n  coberturaControl = new FormControl<FilterPlanosConveniosCobertura[]>(this.coberturas || []);\r\n\r\n  @HostBinding('style') styleBinding = {\r\n    '--neutral-darker': this.curaService.getColor('neutral-darker'),\r\n    '--neutral-light': this.curaService.getColor('neutral-light'),\r\n    '--neutral-lighter': this.curaService.getColor('neutral-lighter'),\r\n    '--neutral-purewhite': this.curaService.getColor('neutral-purewhite'),\r\n  };\r\n\r\n  constructor(private readonly curaService: CuraService) {}\r\n\r\n  ngAfterViewInit() {\r\n    if (this.initialEstado && Array.isArray(this.estados) && this.estados.find((estado) => estado.value === this.initialEstado)) {\r\n      setTimeout(() => {\r\n        this.estadoControl.setValue(this.initialEstado);\r\n        this.filter();\r\n      }, 50);\r\n    }\r\n  }\r\n\r\n  inputTextChange({ detail }: CustomEvent<number | string>) {\r\n    this.unidadeControl.setValue(detail);\r\n    if (this.emitOnChange) {\r\n      this.filterChange.emit({\r\n        unidade: detail,\r\n        estado: this.estadoControl.value,\r\n        cobertura: this.coberturaControl.value || [],\r\n      });\r\n    }\r\n  }\r\n\r\n  selectChange({ detail }: CustomEvent<number | string>) {\r\n    this.estadoControl.setValue(detail);\r\n    if (this.emitOnChange) {\r\n      this.filterChange.emit({\r\n        unidade: this.unidadeControl.value,\r\n        estado: detail,\r\n        cobertura: this.coberturaControl.value || [],\r\n      });\r\n    }\r\n  }\r\n\r\n  checkboxChange({ detail }: CustomEvent<CuraCheckboxOption<string>>) {\r\n    if (!this.coberturas) return;\r\n    const currOption: FilterPlanosConveniosCobertura | undefined = this.coberturas.find(\r\n      (option: FilterPlanosConveniosCobertura) => option.value == detail.value,\r\n    );\r\n    if (currOption) {\r\n      currOption.checked = detail.checked;\r\n    }\r\n    this.coberturaControl.setValue(this.coberturas);\r\n    if (this.emitOnChange) {\r\n      this.filterChange.emit({\r\n        unidade: this.unidadeControl.value,\r\n        estado: this.estadoControl.value,\r\n        cobertura: this.coberturaControl.value || [],\r\n      });\r\n    }\r\n  }\r\n\r\n  filter(): void {\r\n    this.filterChange.emit({\r\n      unidade: this.unidadeControl.value,\r\n      estado: this.estadoControl.value,\r\n      cobertura: this.coberturaControl.value || [],\r\n    });\r\n  }\r\n\r\n  reset(): void {\r\n    const hasCoverage = this.coberturaControl.value!.some((cob) => cob.checked);\r\n    const hasFilter = Boolean(this.unidadeControl.value) || Boolean(this.estadoControl.value) || Boolean(hasCoverage);\r\n    this.closeModal.emit(!hasFilter);\r\n    this.unidadeControl.reset('');\r\n    this.estadoControl.reset('');\r\n    this.coberturas.forEach((cobertura) => (cobertura.checked = false));\r\n    this.coberturaControl.reset(this.coberturas);\r\n  }\r\n}\r\n","<div class=\"filter-planos-convenios\" [ngClass]=\"{ 'container-style': withContainerStyle }\">\r\n  @if (!isLoading) {\r\n    <cura-heading size=\"small\" level=\"4\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\"> Refine sua busca </cura-heading>\r\n\r\n    <div class=\"filter-planos-convenios-unidade\">\r\n      <cura-input-text\r\n        placeholder=\"Nome da unidade\"\r\n        name=\"unidade-input\"\r\n        icon-name=\"search\"\r\n        autocomplete=\"off\"\r\n        [attr.value]=\"unidadeControl.value\"\r\n        (valueChange)=\"inputTextChange($event)\"\r\n      ></cura-input-text>\r\n    </div>\r\n\r\n    <div class=\"filter-planos-convenios-estado\">\r\n      @if (estados) {\r\n        <cura-select\r\n          label=\"Selecione o estado\"\r\n          placeholder=\"Faça a sua Seleção\"\r\n          mode=\"default\"\r\n          size=\"medium\"\r\n          status=\"default\"\r\n          [attr.value]=\"estadoControl.value\"\r\n          (selected)=\"selectChange($event)\"\r\n        >\r\n          <cura-select-option [attr.value]=\"''\">Faça a sua Seleção</cura-select-option>\r\n\r\n          @for (estado of estados || []; track estado?.value) {\r\n            <cura-select-option [attr.value]=\"estado?.value\">{{ estado?.label }}</cura-select-option>\r\n          }\r\n        </cura-select>\r\n      }\r\n    </div>\r\n\r\n    <div class=\"filter-planos-convenios-cobertura\">\r\n      <cura-icon name=\"filter\" size=\"20\" color=\"info-dark\"></cura-icon>\r\n      <cura-heading size=\"xsmall\" level=\"5\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\">\r\n        Filtre pela cobertura do seu plano\r\n      </cura-heading>\r\n    </div>\r\n\r\n    <div class=\"filter-planos-convenios-content\">\r\n      <cura-heading size=\"xsmall\" level=\"5\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\"> Tipos de cobertura </cura-heading>\r\n      <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" margin-block=\"0\">\r\n        Você pode selecionar uma ou mais portas de entrada, de acordo com a cobertura do seu plano.\r\n      </cura-paragraph>\r\n    </div>\r\n\r\n    <div class=\"filter-planos-convenios-checkboxes\">\r\n      @for (option of coberturas || []; track option?.value) {\r\n        <cura-checkbox\r\n          color=\"primary\"\r\n          size=\"small\"\r\n          icon-color=\"light\"\r\n          [attr.name]=\"option?.label\"\r\n          [attr.label]=\"option?.label\"\r\n          [attr.value]=\"option?.value\"\r\n          [attr.checked]=\"option?.checked\"\r\n          (onchange)=\"checkboxChange($event)\"\r\n        >\r\n        </cura-checkbox>\r\n      }\r\n    </div>\r\n\r\n    <div class=\"filter-planos-convenios-buttons\">\r\n      <cura-button-transparent size=\"small\" color=\"primary\" font-color=\"dark\" text-align=\"center\" (click)=\"reset()\">\r\n        <span> Limpar todos os filtros </span>\r\n      </cura-button-transparent>\r\n\r\n      <cura-button size=\"medium\" color=\"primary\" font-color=\"light\" background=\"light\" text-align=\"center\" (click)=\"filter()\"> Filtrar </cura-button>\r\n    </div>\r\n  } @else {\r\n    <cura-loader-circle color=\"primary\" size=\"small\"> </cura-loader-circle>\r\n  }\r\n</div>\r\n"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-planos-convenios.component.js","sourceRoot":"","sources":["../../../../../../../projects/site-front-end-lib/src/lib/components/filters/filter-planos-convenios/filter-planos-convenios.component.ts","../../../../../../../projects/site-front-end-lib/src/lib/components/filters/filter-planos-convenios/filter-planos-convenios.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, HostBinding, Input, Output } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { Estados } from '../../../enums';\nimport { FilterPlanosConvenios, FilterPlanosConveniosChange, FilterPlanosConveniosCobertura } from '../../../models/filters/filter-planos-convenios.model';\nimport { CuraService } from '../../../services';\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nimport type * as _ from '@rededor/cura/dist/types/components.js';\n\ninterface CuraCheckboxOption<T = any> {\n  value: T;\n  checked: boolean;\n  indeterminate?: boolean;\n}\n\n@Component({\n  selector: 'rdsite-filter-planos-convenios',\n  standalone: true,\n  imports: [CommonModule, ReactiveFormsModule],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  templateUrl: './filter-planos-convenios.component.html',\n  styleUrls: ['./filter-planos-convenios.component.scss'],\n})\nexport class FilterPlanosConveniosComponent implements AfterViewInit {\n  @Output() filterChange = new EventEmitter<FilterPlanosConveniosChange>();\n  @Output() closeModal = new EventEmitter<boolean>();\n\n  @Input() withContainerStyle: boolean = false;\n  @Input() isLoading: boolean = false;\n  @Input() emitOnChange: boolean = false;\n\n  @Input() initialEstado: Estados | string | number | null = null;\n\n  @Input() estados: FilterPlanosConvenios[] = Object.entries(Estados).map(([key, value]) => ({\n    label: value,\n    value: key,\n  }));\n\n  @Input() coberturas: FilterPlanosConveniosCobertura[] = [\n    { label: 'Consultas', value: 'FLAG_ACEITA_AMBULATORIO', checked: false },\n    { label: 'Emergência', value: 'FLAG_ACEITA_PS', checked: false },\n    { label: 'Exames', value: 'FLAG_ACEITA_EXAME', checked: false },\n    { label: 'Internação', value: 'FLAG_ACEITA_INTERNACAO', checked: false },\n  ];\n\n  @Input() unidadeControl = new FormControl<string | number | null>('');\n  @Input() estadoControl = new FormControl<Estados | string | number | null>('');\n  coberturaControl = new FormControl<FilterPlanosConveniosCobertura[]>(this.coberturas || []);\n\n  @HostBinding('style') styleBinding = {\n    '--neutral-darker': this.curaService.getColor('neutral-darker'),\n    '--neutral-light': this.curaService.getColor('neutral-light'),\n    '--neutral-lighter': this.curaService.getColor('neutral-lighter'),\n    '--neutral-purewhite': this.curaService.getColor('neutral-purewhite'),\n  };\n\n  constructor(private readonly curaService: CuraService) {}\n\n  ngAfterViewInit() {\n    if (this.initialEstado && Array.isArray(this.estados) && this.estados.find((estado) => estado.value === this.initialEstado)) {\n      setTimeout(() => {\n        this.estadoControl.setValue(this.initialEstado);\n        this.filter();\n      }, 50);\n    }\n  }\n\n  inputTextChange({ detail }: CustomEvent<number | string>) {\n    this.unidadeControl.setValue(detail);\n    if (this.emitOnChange) {\n      this.filterChange.emit({\n        unidade: detail,\n        estado: this.estadoControl.value,\n        cobertura: this.coberturaControl.value || [],\n      });\n    }\n  }\n\n  selectChange({ detail }: CustomEvent<number | string>) {\n    this.estadoControl.setValue(detail);\n    if (this.emitOnChange) {\n      this.filterChange.emit({\n        unidade: this.unidadeControl.value,\n        estado: detail,\n        cobertura: this.coberturaControl.value || [],\n      });\n    }\n  }\n\n  checkboxChange({ detail }: CustomEvent<CuraCheckboxOption<string>>) {\n    if (!this.coberturas) return;\n    const currOption: FilterPlanosConveniosCobertura | undefined = this.coberturas.find(\n      (option: FilterPlanosConveniosCobertura) => option.value == detail.value,\n    );\n    if (currOption) {\n      currOption.checked = detail.checked;\n    }\n    this.coberturaControl.setValue(this.coberturas);\n    if (this.emitOnChange) {\n      this.filterChange.emit({\n        unidade: this.unidadeControl.value,\n        estado: this.estadoControl.value,\n        cobertura: this.coberturaControl.value || [],\n      });\n    }\n  }\n\n  filter(): void {\n    this.filterChange.emit({\n      unidade: this.unidadeControl.value,\n      estado: this.estadoControl.value,\n      cobertura: this.coberturaControl.value || [],\n    });\n  }\n\n  reset(): void {\n    const hasCoverage = this.coberturaControl.value!.some((cob) => cob.checked);\n    const hasFilter = Boolean(this.unidadeControl.value) || Boolean(this.estadoControl.value) || Boolean(hasCoverage);\n    this.closeModal.emit(!hasFilter);\n    this.unidadeControl.reset('');\n    this.estadoControl.reset('');\n    this.coberturas.forEach((cobertura) => (cobertura.checked = false));\n    this.coberturaControl.reset(this.coberturas);\n  }\n}\n","<div class=\"filter-planos-convenios\" [ngClass]=\"{ 'container-style': withContainerStyle }\">\n  @if (!isLoading) {\n    <cura-heading size=\"small\" level=\"4\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\"> Refine sua busca </cura-heading>\n\n    <div class=\"filter-planos-convenios-unidade\">\n      <cura-input-text\n        placeholder=\"Nome da unidade\"\n        name=\"unidade-input\"\n        icon-name=\"search\"\n        autocomplete=\"off\"\n        [attr.value]=\"unidadeControl.value\"\n        (valueChange)=\"inputTextChange($event)\"\n      ></cura-input-text>\n    </div>\n\n    <div class=\"filter-planos-convenios-estado\">\n      @if (estados) {\n        <cura-select\n          label=\"Selecione o estado\"\n          placeholder=\"Faça a sua Seleção\"\n          mode=\"default\"\n          size=\"medium\"\n          status=\"default\"\n          [attr.value]=\"estadoControl.value\"\n          (selected)=\"selectChange($event)\"\n        >\n          <cura-select-option [attr.value]=\"''\">Faça a sua Seleção</cura-select-option>\n\n          @for (estado of estados || []; track estado?.value) {\n            <cura-select-option [attr.value]=\"estado?.value\">{{ estado?.label }}</cura-select-option>\n          }\n        </cura-select>\n      }\n    </div>\n\n    <div class=\"filter-planos-convenios-cobertura\">\n      <cura-icon name=\"filter\" size=\"20\" color=\"info-dark\"></cura-icon>\n      <cura-heading size=\"xsmall\" level=\"5\" weight=\"bold\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\">\n        Filtre pela cobertura do seu plano\n      </cura-heading>\n    </div>\n\n    <div class=\"filter-planos-convenios-content\">\n      <cura-heading size=\"xsmall\" level=\"5\" color=\"neutral-black\" margin-block=\"0\" line-height=\"16px\"> Tipos de cobertura </cura-heading>\n      <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" margin-block=\"0\">\n        Você pode selecionar uma ou mais portas de entrada, de acordo com a cobertura do seu plano.\n      </cura-paragraph>\n    </div>\n\n    <div class=\"filter-planos-convenios-checkboxes\">\n      @for (option of coberturas || []; track option?.value) {\n        <cura-checkbox\n          color=\"primary\"\n          size=\"small\"\n          icon-color=\"light\"\n          [attr.name]=\"option?.label\"\n          [attr.label]=\"option?.label\"\n          [attr.value]=\"option?.value\"\n          [attr.checked]=\"option?.checked\"\n          (onchange)=\"checkboxChange($event)\"\n        >\n        </cura-checkbox>\n      }\n    </div>\n\n    <div class=\"filter-planos-convenios-buttons\">\n      <cura-button-transparent size=\"small\" color=\"primary\" font-color=\"dark\" text-align=\"center\" (click)=\"reset()\">\n        <span> Limpar todos os filtros </span>\n      </cura-button-transparent>\n\n      <cura-button size=\"medium\" color=\"primary\" font-color=\"light\" background=\"light\" text-align=\"center\" (click)=\"filter()\"> Filtrar </cura-button>\n    </div>\n  } @else {\n    <cura-loader-circle color=\"primary\" size=\"small\"> </cura-loader-circle>\n  }\n</div>\n"]}
|