@rededor/site-front-end-lib 1.3.50 → 1.3.51
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.
|
@@ -205,4 +205,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
205
205
|
type: HostBinding,
|
|
206
206
|
args: ['style']
|
|
207
207
|
}] } });
|
|
208
|
-
//# 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 {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostBinding,\r\n  OnInit,\r\n  PLATFORM_ID,\r\n  input,\r\n  model,\r\n  output,\r\n  inject,\r\n  computed,\r\n  signal,\r\n  CUSTOM_ELEMENTS_SCHEMA,\r\n} from '@angular/core';\r\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\r\nimport { CuraService } from '../../../services';\r\nimport { MediaQueries } from '../../../helpers/mediaQueries';\r\nimport { FilterEvent, FilterPlanosConveniosChange } from '../../../models/filters/filter-planos-convenios.model';\r\nimport { FilterAction, FilterControlValue, FilterSection } from '../../../models/filters/filter-section.type';\r\nimport { CuraCheckboxCustomEvent, CuraInputTextCustomEvent, CuraRadioCustomEvent, CuraSelectCustomEvent } from '@rededor/cura';\r\n\r\nexport interface SelectSelectedEvent {\r\n  value: string;\r\n}\r\nexport interface CheckboxChangeEvent {\r\n  value: string;\r\n  checked: boolean;\r\n  indeterminate: boolean;\r\n}\r\n\r\nexport interface RadioChangeEvent {\r\n  value: string;\r\n  checked: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'rdsite-filter-generic',\r\n  imports: [CommonModule, ReactiveFormsModule],\r\n  standalone: true,\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  private readonly curaApiService = inject(CuraService);\r\n  private readonly cdr = inject(ChangeDetectorRef);\r\n  private readonly platformId = inject(PLATFORM_ID);\r\n\r\n  readonly filterChange = output<FilterEvent>();\r\n  readonly closeModal = output<boolean>();\r\n  readonly openMobileFilter = output<void>();\r\n\r\n  readonly withContainerStyle = input(true);\r\n  readonly showClearButton = input(true);\r\n  readonly showApplyButton = input(true);\r\n  readonly showCloseButton = input(false);\r\n  readonly disableButtons = input(false);\r\n  readonly showBadge = input(true);\r\n  readonly showToggleIcon = input(true);\r\n  isFilterOpen = model(true);\r\n  readonly mobileBehavior = input(false);\r\n  readonly forceCollapsed = input(false);\r\n  readonly emitOnReset = input(false);\r\n  readonly textTitle = input('Filtrar por');\r\n  readonly sections = input<FilterSection[]>([]);\r\n\r\n  readonly windowWidth = signal(0);\r\n\r\n  selectedFiltersCount = computed(() => {\r\n    return this.sections().reduce((count, section) => {\r\n      if ((section.type !== 'custom' && !section.config?.control) || (section.type === 'custom' && !section.config?.count)) return count;\r\n\r\n      const value = section.config.control?.value || null;\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        case 'custom':\r\n          return count + (section.config.count || 0);\r\n        default:\r\n          return count + (value ? 1 : 0);\r\n      }\r\n    }, 0);\r\n  });\r\n\r\n  @HostBinding('style') styleBinding = {\r\n    '--font-family': this.curaApiService.getFontFamily(''),\r\n    '--neutral-opacity-black': this.curaApiService.getColor('neutral-black', 0.2),\r\n    '--neutral-dark': this.curaApiService.getColor('neutral-dark'),\r\n    '--neutral-darker': this.curaApiService.getColor('neutral-darker'),\r\n    '--neutral-medium': this.curaApiService.getColor('neutral-medium'),\r\n    '--neutral-light': this.curaApiService.getColor('neutral-light'),\r\n    '--neutral-lighter': this.curaApiService.getColor('neutral-lighter'),\r\n    '--neutral-purewhite': this.curaApiService.getColor('neutral-purewhite'),\r\n    '--primary-base': this.curaApiService.getColor('primary-base'),\r\n    '--primary-lighter': this.curaApiService.getColor('primary-lighter'),\r\n  };\r\n\r\n  ngOnInit(): void {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      this.windowWidth.set(window.innerWidth);\r\n    }\r\n\r\n    if (this.forceCollapsed() && this.isMobile()) {\r\n      this.isFilterOpen.set(false);\r\n    }\r\n  }\r\n\r\n  handleInputChange(event: CuraInputTextCustomEvent<string | number>, control: FormControl): void {\r\n    control.setValue(event.target.value);\r\n  }\r\n\r\n  handleSelectChange(event: CuraSelectCustomEvent<any>, control: FormControl): void {\r\n    if (event !== undefined) {\r\n      control.setValue(event.target.value);\r\n    }\r\n  }\r\n\r\n  handleCheckboxChange(event: CuraCheckboxCustomEvent<any>, options: any[]): void {\r\n    const changedOption = options.find((opt) => opt.value === event.target.value);\r\n    if (changedOption) changedOption.checked = event.target.checked;\r\n\r\n    this.updateCheckboxGroup(options);\r\n  }\r\n\r\n  handleRadioChange(event: CuraRadioCustomEvent<any>, control: FormControl): void {\r\n    const selectedValue = event.target.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\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(undefined);\r\n    } else {\r\n      this.isFilterOpen.set(!this.isFilterOpen());\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  hasSelection(): boolean {\r\n    return this.selectedFiltersCount() > 0;\r\n  }\r\n\r\n  readonly isMobile = computed(() => {\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  hasScroll(section: FilterSection): boolean {\r\n    switch (section.type) {\r\n      case 'checkbox-group':\r\n        return section.config.options && section.config.options.length > 6;\r\n      case 'radio-group':\r\n        return section.config.options && section.config.options.length > 6;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  getSectionClass(section: FilterSection): string {\r\n    return this.hasScroll(section) ? 'scrollable' : '';\r\n  }\r\n\r\n  shouldHandleMobileClick(): boolean {\r\n    return this.mobileBehavior() && this.isMobile() && this.forceCollapsed();\r\n  }\r\n\r\n  handleMobileClick(): void {\r\n    if (this.shouldHandleMobileClick()) {\r\n      this.openMobileFilter.emit();\r\n    }\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 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]);\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\r\n  class=\"filter-generic\"\r\n  [ngClass]=\"{ 'container-style': withContainerStyle(), 'clickable-mobile': shouldHandleMobileClick() }\"\r\n  aria-label=\"Filtros\"\r\n  (click)=\"handleMobileClick()\"\r\n>\r\n  <div class=\"filter-header-container\" [ngClass]=\"{ 'no-padding': !isFilterOpen(), hidden: !isFilterOpen() }\">\r\n    <div class=\"filter-title-wrapper\">\r\n      <cura-label size=\"medium\" level=\"4\" color=\"neutral-black\" weight=\"regular\" margin-block=\"0\" line-height=\"16px\">\r\n        {{ textTitle() }}\r\n      </cura-label>\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\r\n        size=\"small\"\r\n        font-color=\"dark\"\r\n        color=\"primary\"\r\n        text-align=\"center\"\r\n        (click)=\"toggleFilter()\"\r\n        [attr.aria-expanded]=\"isFilterOpen()\"\r\n        [aria-label]=\"isFilterOpen() ? 'Fechar filtros' : 'Abrir filtros'\"\r\n      >\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                [icon-name]=\"section.config.iconName || ''\"\r\n                [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                [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 [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 [value]=\"option?.value\">{{ option?.label }}</cura-select-option>\r\n                }\r\n              </cura-select>\r\n            }\r\n            @case ('checkbox-group') {\r\n              @if (section.config.title) {\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 }}\r\n                  </cura-heading>\r\n                </div>\r\n              }\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\" [class.scrollable]=\"hasScroll(section)\">\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                    [name]=\"option.label\"\r\n                    [label]=\"option.label\"\r\n                    [value]=\"option.value\"\r\n                    [checked]=\"option.checked || false\"\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\" [class.scrollable]=\"hasScroll(section)\">\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]=\"disableButtons() || !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]=\"disableButtons() || !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 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"]}
|
|
208
|
+
//# 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 {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostBinding,\r\n  OnInit,\r\n  PLATFORM_ID,\r\n  input,\r\n  model,\r\n  output,\r\n  inject,\r\n  computed,\r\n  signal,\r\n  CUSTOM_ELEMENTS_SCHEMA,\r\n} from '@angular/core';\r\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\r\nimport { CuraService } from '../../../services';\r\nimport { MediaQueries } from '../../../helpers/mediaQueries';\r\nimport { FilterEvent, FilterPlanosConveniosChange } from '../../../models/filters/filter-planos-convenios.model';\r\nimport { FilterAction, FilterControlValue, FilterSection } from '../../../models/filters/filter-section.type';\r\nimport { CuraInputTextCustomEvent, CuraSelectCustomEvent, CuraCheckboxCustomEvent, CuraRadioCustomEvent } from '@rededor/cura/dist/types/components';\r\n\r\nexport interface SelectSelectedEvent {\r\n  value: string;\r\n}\r\nexport interface CheckboxChangeEvent {\r\n  value: string;\r\n  checked: boolean;\r\n  indeterminate: boolean;\r\n}\r\n\r\nexport interface RadioChangeEvent {\r\n  value: string;\r\n  checked: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'rdsite-filter-generic',\r\n  imports: [CommonModule, ReactiveFormsModule],\r\n  standalone: true,\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  private readonly curaApiService = inject(CuraService);\r\n  private readonly cdr = inject(ChangeDetectorRef);\r\n  private readonly platformId = inject(PLATFORM_ID);\r\n\r\n  readonly filterChange = output<FilterEvent>();\r\n  readonly closeModal = output<boolean>();\r\n  readonly openMobileFilter = output<void>();\r\n\r\n  readonly withContainerStyle = input(true);\r\n  readonly showClearButton = input(true);\r\n  readonly showApplyButton = input(true);\r\n  readonly showCloseButton = input(false);\r\n  readonly disableButtons = input(false);\r\n  readonly showBadge = input(true);\r\n  readonly showToggleIcon = input(true);\r\n  isFilterOpen = model(true);\r\n  readonly mobileBehavior = input(false);\r\n  readonly forceCollapsed = input(false);\r\n  readonly emitOnReset = input(false);\r\n  readonly textTitle = input('Filtrar por');\r\n  readonly sections = input<FilterSection[]>([]);\r\n\r\n  readonly windowWidth = signal(0);\r\n\r\n  selectedFiltersCount = computed(() => {\r\n    return this.sections().reduce((count, section) => {\r\n      if ((section.type !== 'custom' && !section.config?.control) || (section.type === 'custom' && !section.config?.count)) return count;\r\n\r\n      const value = section.config.control?.value || null;\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        case 'custom':\r\n          return count + (section.config.count || 0);\r\n        default:\r\n          return count + (value ? 1 : 0);\r\n      }\r\n    }, 0);\r\n  });\r\n\r\n  @HostBinding('style') styleBinding = {\r\n    '--font-family': this.curaApiService.getFontFamily(''),\r\n    '--neutral-opacity-black': this.curaApiService.getColor('neutral-black', 0.2),\r\n    '--neutral-dark': this.curaApiService.getColor('neutral-dark'),\r\n    '--neutral-darker': this.curaApiService.getColor('neutral-darker'),\r\n    '--neutral-medium': this.curaApiService.getColor('neutral-medium'),\r\n    '--neutral-light': this.curaApiService.getColor('neutral-light'),\r\n    '--neutral-lighter': this.curaApiService.getColor('neutral-lighter'),\r\n    '--neutral-purewhite': this.curaApiService.getColor('neutral-purewhite'),\r\n    '--primary-base': this.curaApiService.getColor('primary-base'),\r\n    '--primary-lighter': this.curaApiService.getColor('primary-lighter'),\r\n  };\r\n\r\n  ngOnInit(): void {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      this.windowWidth.set(window.innerWidth);\r\n    }\r\n\r\n    if (this.forceCollapsed() && this.isMobile()) {\r\n      this.isFilterOpen.set(false);\r\n    }\r\n  }\r\n\r\n  handleInputChange(event: CuraInputTextCustomEvent<string | number>, control: FormControl): void {\r\n    control.setValue(event.target.value);\r\n  }\r\n\r\n  handleSelectChange(event: CuraSelectCustomEvent<any>, control: FormControl): void {\r\n    if (event !== undefined) {\r\n      control.setValue(event.target.value);\r\n    }\r\n  }\r\n\r\n  handleCheckboxChange(event: CuraCheckboxCustomEvent<any>, options: any[]): void {\r\n    const changedOption = options.find((opt) => opt.value === event.target.value);\r\n    if (changedOption) changedOption.checked = event.target.checked;\r\n\r\n    this.updateCheckboxGroup(options);\r\n  }\r\n\r\n  handleRadioChange(event: CuraRadioCustomEvent<any>, control: FormControl): void {\r\n    const selectedValue = event.target.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\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(undefined);\r\n    } else {\r\n      this.isFilterOpen.set(!this.isFilterOpen());\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  hasSelection(): boolean {\r\n    return this.selectedFiltersCount() > 0;\r\n  }\r\n\r\n  readonly isMobile = computed(() => {\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  hasScroll(section: FilterSection): boolean {\r\n    switch (section.type) {\r\n      case 'checkbox-group':\r\n        return section.config.options && section.config.options.length > 6;\r\n      case 'radio-group':\r\n        return section.config.options && section.config.options.length > 6;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  getSectionClass(section: FilterSection): string {\r\n    return this.hasScroll(section) ? 'scrollable' : '';\r\n  }\r\n\r\n  shouldHandleMobileClick(): boolean {\r\n    return this.mobileBehavior() && this.isMobile() && this.forceCollapsed();\r\n  }\r\n\r\n  handleMobileClick(): void {\r\n    if (this.shouldHandleMobileClick()) {\r\n      this.openMobileFilter.emit();\r\n    }\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 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]);\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\r\n  class=\"filter-generic\"\r\n  [ngClass]=\"{ 'container-style': withContainerStyle(), 'clickable-mobile': shouldHandleMobileClick() }\"\r\n  aria-label=\"Filtros\"\r\n  (click)=\"handleMobileClick()\"\r\n>\r\n  <div class=\"filter-header-container\" [ngClass]=\"{ 'no-padding': !isFilterOpen(), hidden: !isFilterOpen() }\">\r\n    <div class=\"filter-title-wrapper\">\r\n      <cura-label size=\"medium\" level=\"4\" color=\"neutral-black\" weight=\"regular\" margin-block=\"0\" line-height=\"16px\">\r\n        {{ textTitle() }}\r\n      </cura-label>\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\r\n        size=\"small\"\r\n        font-color=\"dark\"\r\n        color=\"primary\"\r\n        text-align=\"center\"\r\n        (click)=\"toggleFilter()\"\r\n        [attr.aria-expanded]=\"isFilterOpen()\"\r\n        [aria-label]=\"isFilterOpen() ? 'Fechar filtros' : 'Abrir filtros'\"\r\n      >\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                [icon-name]=\"section.config.iconName || ''\"\r\n                [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                [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 [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 [value]=\"option?.value\">{{ option?.label }}</cura-select-option>\r\n                }\r\n              </cura-select>\r\n            }\r\n            @case ('checkbox-group') {\r\n              @if (section.config.title) {\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 }}\r\n                  </cura-heading>\r\n                </div>\r\n              }\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\" [class.scrollable]=\"hasScroll(section)\">\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                    [name]=\"option.label\"\r\n                    [label]=\"option.label\"\r\n                    [value]=\"option.value\"\r\n                    [checked]=\"option.checked || false\"\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\" [class.scrollable]=\"hasScroll(section)\">\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]=\"disableButtons() || !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]=\"disableButtons() || !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 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"]}
|