@rededor/site-front-end-lib 20.0.12 → 20.0.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (143) hide show
  1. package/README.md +124 -124
  2. package/fesm2022/rededor-site-front-end-lib-components-algolia-dropdown.mjs +4 -4
  3. package/fesm2022/rededor-site-front-end-lib-components-algolia-dropdown.mjs.map +1 -1
  4. package/fesm2022/rededor-site-front-end-lib-components-algolia-search.mjs +20 -20
  5. package/fesm2022/rededor-site-front-end-lib-components-algolia-search.mjs.map +1 -1
  6. package/fesm2022/rededor-site-front-end-lib-components-banner.mjs +4 -4
  7. package/fesm2022/rededor-site-front-end-lib-components-banner.mjs.map +1 -1
  8. package/fesm2022/rededor-site-front-end-lib-components-breadcrumbs.mjs +4 -4
  9. package/fesm2022/rededor-site-front-end-lib-components-breadcrumbs.mjs.map +1 -1
  10. package/fesm2022/rededor-site-front-end-lib-components-cards.mjs +12 -12
  11. package/fesm2022/rededor-site-front-end-lib-components-cards.mjs.map +1 -1
  12. package/fesm2022/rededor-site-front-end-lib-components-carousels.mjs +4 -4
  13. package/fesm2022/rededor-site-front-end-lib-components-carousels.mjs.map +1 -1
  14. package/fesm2022/rededor-site-front-end-lib-components-cta-wrapper.mjs +4 -4
  15. package/fesm2022/rededor-site-front-end-lib-components-cta-wrapper.mjs.map +1 -1
  16. package/fesm2022/rededor-site-front-end-lib-components-error.mjs +4 -4
  17. package/fesm2022/rededor-site-front-end-lib-components-error.mjs.map +1 -1
  18. package/fesm2022/rededor-site-front-end-lib-components-filter-letter-and-terms.mjs +4 -4
  19. package/fesm2022/rededor-site-front-end-lib-components-filter-letter-and-terms.mjs.map +1 -1
  20. package/fesm2022/rededor-site-front-end-lib-components-filters-filter-generic.mjs +4 -4
  21. package/fesm2022/rededor-site-front-end-lib-components-filters-filter-generic.mjs.map +1 -1
  22. package/fesm2022/rededor-site-front-end-lib-components-filters-filter-planos-convenios.mjs +4 -4
  23. package/fesm2022/rededor-site-front-end-lib-components-filters-filter-planos-convenios.mjs.map +1 -1
  24. package/fesm2022/rededor-site-front-end-lib-components-footer.mjs +4 -4
  25. package/fesm2022/rededor-site-front-end-lib-components-footer.mjs.map +1 -1
  26. package/fesm2022/rededor-site-front-end-lib-components-header-components-action.mjs +4 -4
  27. package/fesm2022/rededor-site-front-end-lib-components-header-components-action.mjs.map +1 -1
  28. package/fesm2022/rededor-site-front-end-lib-components-header-components-auxiliar.mjs +8 -8
  29. package/fesm2022/rededor-site-front-end-lib-components-header-components-auxiliar.mjs.map +1 -1
  30. package/fesm2022/rededor-site-front-end-lib-components-header-components-main.mjs +8 -8
  31. package/fesm2022/rededor-site-front-end-lib-components-header-components-main.mjs.map +1 -1
  32. package/fesm2022/rededor-site-front-end-lib-components-header-components-side.mjs +8 -8
  33. package/fesm2022/rededor-site-front-end-lib-components-header-components-side.mjs.map +1 -1
  34. package/fesm2022/rededor-site-front-end-lib-components-header-services.mjs +3 -3
  35. package/fesm2022/rededor-site-front-end-lib-components-header-services.mjs.map +1 -1
  36. package/fesm2022/rededor-site-front-end-lib-components-header.mjs +8 -8
  37. package/fesm2022/rededor-site-front-end-lib-components-header.mjs.map +1 -1
  38. package/fesm2022/rededor-site-front-end-lib-components-image.mjs +4 -4
  39. package/fesm2022/rededor-site-front-end-lib-components-image.mjs.map +1 -1
  40. package/fesm2022/rededor-site-front-end-lib-components-load-screen.mjs +4 -4
  41. package/fesm2022/rededor-site-front-end-lib-components-load-screen.mjs.map +1 -1
  42. package/fesm2022/rededor-site-front-end-lib-components-modal-drawer.mjs +4 -4
  43. package/fesm2022/rededor-site-front-end-lib-components-modal-drawer.mjs.map +1 -1
  44. package/fesm2022/rededor-site-front-end-lib-components-modal.mjs +4 -4
  45. package/fesm2022/rededor-site-front-end-lib-components-modal.mjs.map +1 -1
  46. package/fesm2022/rededor-site-front-end-lib-components-overlay.mjs +4 -4
  47. package/fesm2022/rededor-site-front-end-lib-components-overlay.mjs.map +1 -1
  48. package/fesm2022/rededor-site-front-end-lib-components-page-header.mjs +4 -4
  49. package/fesm2022/rededor-site-front-end-lib-components-page-header.mjs.map +1 -1
  50. package/fesm2022/rededor-site-front-end-lib-components-page-template-fullcontent.mjs +4 -4
  51. package/fesm2022/rededor-site-front-end-lib-components-page-template-fullcontent.mjs.map +1 -1
  52. package/fesm2022/rededor-site-front-end-lib-components-page-template-sidebar.mjs +4 -4
  53. package/fesm2022/rededor-site-front-end-lib-components-page-template-sidebar.mjs.map +1 -1
  54. package/fesm2022/rededor-site-front-end-lib-components-pagination.mjs +4 -4
  55. package/fesm2022/rededor-site-front-end-lib-components-pagination.mjs.map +1 -1
  56. package/fesm2022/rededor-site-front-end-lib-components-search.mjs +4 -4
  57. package/fesm2022/rededor-site-front-end-lib-components-search.mjs.map +1 -1
  58. package/fesm2022/rededor-site-front-end-lib-components-section-navigation.mjs +4 -4
  59. package/fesm2022/rededor-site-front-end-lib-components-section-navigation.mjs.map +1 -1
  60. package/fesm2022/rededor-site-front-end-lib-components-side-ctas.mjs +20 -20
  61. package/fesm2022/rededor-site-front-end-lib-components-side-ctas.mjs.map +1 -1
  62. package/fesm2022/rededor-site-front-end-lib-components-sidebar-navigation.mjs +4 -4
  63. package/fesm2022/rededor-site-front-end-lib-components-sidebar-navigation.mjs.map +1 -1
  64. package/fesm2022/rededor-site-front-end-lib-components-sticky-navigation.mjs +4 -4
  65. package/fesm2022/rededor-site-front-end-lib-components-sticky-navigation.mjs.map +1 -1
  66. package/fesm2022/rededor-site-front-end-lib-components-whatsapp.mjs +4 -4
  67. package/fesm2022/rededor-site-front-end-lib-components-whatsapp.mjs.map +1 -1
  68. package/fesm2022/rededor-site-front-end-lib-core.mjs +54 -54
  69. package/fesm2022/rededor-site-front-end-lib-core.mjs.map +1 -1
  70. package/fesm2022/rededor-site-front-end-lib-cura-accordion.mjs +8 -8
  71. package/fesm2022/rededor-site-front-end-lib-cura-accordion.mjs.map +1 -1
  72. package/fesm2022/rededor-site-front-end-lib-cura-api.mjs +128 -26
  73. package/fesm2022/rededor-site-front-end-lib-cura-api.mjs.map +1 -1
  74. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-counter.mjs +4 -4
  75. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-counter.mjs.map +1 -1
  76. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-distance.mjs +4 -4
  77. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-distance.mjs.map +1 -1
  78. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-dot.mjs +4 -4
  79. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-dot.mjs.map +1 -1
  80. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-pill.mjs +4 -4
  81. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-pill.mjs.map +1 -1
  82. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-outline.mjs +4 -4
  83. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-outline.mjs.map +1 -1
  84. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-select.mjs +4 -4
  85. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-select.mjs.map +1 -1
  86. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-transparent.mjs +4 -4
  87. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-transparent.mjs.map +1 -1
  88. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button.mjs +4 -4
  89. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button.mjs.map +1 -1
  90. package/fesm2022/rededor-site-front-end-lib-cura-buttons.mjs.map +1 -1
  91. package/fesm2022/rededor-site-front-end-lib-cura-cards-cura-card.mjs +4 -4
  92. package/fesm2022/rededor-site-front-end-lib-cura-cards-cura-card.mjs.map +1 -1
  93. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-alert.mjs +4 -4
  94. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-alert.mjs.map +1 -1
  95. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-modal.mjs +4 -4
  96. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-modal.mjs.map +1 -1
  97. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-toast.mjs +4 -4
  98. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-toast.mjs.map +1 -1
  99. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-checkbox.mjs +5 -5
  100. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-checkbox.mjs.map +1 -1
  101. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-input-text.mjs +5 -5
  102. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-input-text.mjs.map +1 -1
  103. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-label.mjs +4 -4
  104. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-label.mjs.map +1 -1
  105. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-radio.mjs +5 -5
  106. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-radio.mjs.map +1 -1
  107. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-select-option.mjs +4 -4
  108. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-select-option.mjs.map +1 -1
  109. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-select.mjs +5 -5
  110. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-select.mjs.map +1 -1
  111. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-switch.mjs +5 -5
  112. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-switch.mjs.map +1 -1
  113. package/fesm2022/rededor-site-front-end-lib-cura-forms.mjs.map +1 -1
  114. package/fesm2022/rededor-site-front-end-lib-cura-icons-cura-icon.mjs +4 -4
  115. package/fesm2022/rededor-site-front-end-lib-cura-icons-cura-icon.mjs.map +1 -1
  116. package/fesm2022/rededor-site-front-end-lib-cura-loaders-cura-loader-bar.mjs +4 -4
  117. package/fesm2022/rededor-site-front-end-lib-cura-loaders-cura-loader-bar.mjs.map +1 -1
  118. package/fesm2022/rededor-site-front-end-lib-cura-loaders-cura-loader-circle.mjs +4 -4
  119. package/fesm2022/rededor-site-front-end-lib-cura-loaders-cura-loader-circle.mjs.map +1 -1
  120. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-display.mjs +4 -4
  121. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-display.mjs.map +1 -1
  122. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-heading.mjs +4 -4
  123. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-heading.mjs.map +1 -1
  124. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-paragraph.mjs +4 -4
  125. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-paragraph.mjs.map +1 -1
  126. package/fesm2022/rededor-site-front-end-lib-enums.mjs.map +1 -1
  127. package/fesm2022/rededor-site-front-end-lib-services-algolia-search-api.mjs +3 -3
  128. package/fesm2022/rededor-site-front-end-lib-services-algolia-search-api.mjs.map +1 -1
  129. package/fesm2022/rededor-site-front-end-lib-services-algolia.mjs +3 -3
  130. package/fesm2022/rededor-site-front-end-lib-services-algolia.mjs.map +1 -1
  131. package/fesm2022/rededor-site-front-end-lib-services-ngu-carousel.mjs +3 -3
  132. package/fesm2022/rededor-site-front-end-lib-services-ngu-carousel.mjs.map +1 -1
  133. package/fesm2022/rededor-site-front-end-lib-services-ssr-loading.mjs +3 -3
  134. package/fesm2022/rededor-site-front-end-lib-services-ssr-loading.mjs.map +1 -1
  135. package/fesm2022/rededor-site-front-end-lib-services-transfer-state.mjs +3 -3
  136. package/fesm2022/rededor-site-front-end-lib-services-transfer-state.mjs.map +1 -1
  137. package/fesm2022/rededor-site-front-end-lib-services-youtube.mjs +3 -3
  138. package/fesm2022/rededor-site-front-end-lib-services-youtube.mjs.map +1 -1
  139. package/fesm2022/rededor-site-front-end-lib-shared.mjs +6 -6
  140. package/fesm2022/rededor-site-front-end-lib-shared.mjs.map +1 -1
  141. package/fesm2022/rededor-site-front-end-lib.mjs.map +1 -1
  142. package/package.json +1 -1
  143. package/styles/_breakpoints.scss +5 -5
@@ -1 +1 @@
1
- {"version":3,"file":"rededor-site-front-end-lib-cura-forms-cura-input-text.mjs","sources":["../../../projects/site-front-end-lib/cura/forms/cura-input-text/cura-input-text.definitions.ts","../../../projects/site-front-end-lib/cura/forms/cura-input-text/cura-input-text.component.ts","../../../projects/site-front-end-lib/cura/forms/cura-input-text/cura-input-text.component.html","../../../projects/site-front-end-lib/cura/forms/cura-input-text/rededor-site-front-end-lib-cura-forms-cura-input-text.ts"],"sourcesContent":["/**\r\n * Display mode options for the input text component\r\n */\r\nexport type InputTextMode = 'default' | 'transparent';\r\n\r\n/**\r\n * Size options for the input text component\r\n */\r\nexport type InputTextSize = 'small' | 'medium' | 'large';\r\n\r\n/**\r\n * Status options for the input text component\r\n */\r\nexport type InputTextStatus = 'success' | 'error' | 'default';\r\n\r\n/**\r\n * Input type options for the input text component\r\n */\r\nexport type InputTextType = 'text' | 'number' | 'email' | 'password' | 'tel' | 'url';\r\n\r\n/**\r\n * Input mode options for the input text component\r\n */\r\nexport type InputTextInputMode = 'text' | 'decimal' | 'numeric' | 'tel' | 'search' | 'email' | 'url';\r\n\r\n/**\r\n * Mask preset options for input formatting\r\n */\r\nexport type MaskPreset = 'cpf' | 'cnpj' | 'cpf_cnpj' | 'phone' | 'date' | 'dateRange';\r\n\r\n/**\r\n * Event payload emitted when the input value changes\r\n */\r\nexport interface InputTextValueChangeEvent {\r\n /**\r\n * The new value of the input\r\n */\r\n value: string | number;\r\n}\r\n\r\n/**\r\n * Event payload emitted when the clear button is clicked\r\n */\r\nexport interface InputTextClearEvent {\r\n /**\r\n * The value that was cleared (usually empty string)\r\n */\r\n value: string | number;\r\n}\r\n\r\n/**\r\n * Mask options map for IMask library\r\n */\r\nexport interface MaskOptionsMap {\r\n [key: string]: any;\r\n}\r\n\r\n/**\r\n * Mask configuration for different presets\r\n */\r\nexport const maskOptions: MaskOptionsMap = {\r\n cpf_cnpj: {\r\n mask: [{ mask: '000.000.000-00' }, { mask: '00.000.000/0000-00' }],\r\n placeholderChar: '_',\r\n },\r\n cpf: {\r\n mask: '000.000.000-00',\r\n placeholderChar: '_',\r\n },\r\n cnpj: {\r\n mask: '00.000.000/0000-00',\r\n placeholderChar: '_',\r\n },\r\n phone: {\r\n mask: '(00) 00000-0000',\r\n blocks: {\r\n '(00)': {\r\n mask: '(00)',\r\n maxLength: 2,\r\n placeholderChar: '',\r\n },\r\n '00000': {\r\n mask: '00000',\r\n maxLength: 5,\r\n placeholderChar: '_',\r\n },\r\n '-': {\r\n mask: '-',\r\n },\r\n '0000': {\r\n mask: '0000',\r\n maxLength: 4,\r\n placeholderChar: '_',\r\n },\r\n },\r\n placeholderChar: '_',\r\n },\r\n date: {\r\n mask: '00/00/0000',\r\n },\r\n dateRange: {\r\n mask: '00/00/0000 - 00/00/0000',\r\n },\r\n};\r\n","import {\r\n Component,\r\n input,\r\n output,\r\n signal,\r\n computed,\r\n inject,\r\n forwardRef,\r\n ElementRef,\r\n AfterViewInit,\r\n OnDestroy,\r\n viewChild,\r\n model,\r\n effect,\r\n PLATFORM_ID,\r\n} from '@angular/core';\r\nimport { CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { CuraApiService } from '@rededor/site-front-end-lib/cura/api';\r\nimport { CuraLabelComponent } from '@rededor/site-front-end-lib/cura/forms/cura-label';\r\nimport { CuraIconComponent } from '@rededor/site-front-end-lib/cura/icons/cura-icon';\r\nimport { CuraLoaderCircleComponent } from '@rededor/site-front-end-lib/cura/loaders/cura-loader-circle';\r\nimport IMask, { FactoryArg, InputMask } from 'imask';\r\nimport {\r\n InputTextMode,\r\n InputTextSize,\r\n InputTextStatus,\r\n InputTextType,\r\n InputTextInputMode,\r\n MaskPreset,\r\n InputTextValueChangeEvent,\r\n InputTextClearEvent,\r\n maskOptions,\r\n} from './cura-input-text.definitions';\r\n\r\n@Component({\r\n selector: 'cura-input-text',\r\n imports: [CommonModule, FormsModule, CuraLabelComponent, CuraIconComponent, CuraLoaderCircleComponent],\r\n templateUrl: './cura-input-text.component.html',\r\n styleUrls: ['./cura-input-text.component.scss'],\r\n host: {\r\n role: 'textbox',\r\n '[attr.aria-disabled]': 'disabled()',\r\n '[attr.aria-required]': 'required()',\r\n '[attr.aria-invalid]': 'status() === \"error\"',\r\n },\r\n providers: [\r\n {\r\n provide: NG_VALUE_ACCESSOR,\r\n useExisting: forwardRef(() => CuraInputTextComponent),\r\n multi: true,\r\n },\r\n ],\r\n})\r\nexport class CuraInputTextComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\r\n private curaApi: CuraApiService = inject(CuraApiService);\r\n private elementRef = inject(ElementRef);\r\n private platformId = inject(PLATFORM_ID);\r\n /**\r\n * Mode of the input: 'default' or 'transparent'\r\n */\r\n mode = input<InputTextMode>('default');\r\n\r\n /**\r\n * Status of the input component\r\n */\r\n status = input<InputTextStatus>('default');\r\n\r\n /**\r\n * Size of the input component\r\n */\r\n size = input<InputTextSize>('medium');\r\n\r\n /**\r\n * Type of the input\r\n */\r\n type = input<InputTextType>('text');\r\n\r\n /**\r\n * Input mode for mobile keyboards\r\n */\r\n inputMode = input<InputTextInputMode>('text');\r\n\r\n /**\r\n * Label text for the input\r\n */\r\n label = input<string>('');\r\n\r\n /**\r\n * Name attribute for the input\r\n */\r\n name = input<string>('');\r\n\r\n /**\r\n * Placeholder text for the input\r\n */\r\n placeholder = input<string | null>(null);\r\n\r\n /**\r\n * Current value of the input\r\n */\r\n value = model<string | number | any>('');\r\n\r\n /**\r\n * Icon name to display\r\n */\r\n iconName = input<string>('');\r\n\r\n /**\r\n * Helper text displayed below the input\r\n */\r\n // helperText = input<string>(''); // Não está sendo usado\r\n\r\n /**\r\n * Whether the input is disabled\r\n */\r\n disabled = input<boolean>(false);\r\n\r\n /**\r\n * Whether the input is required\r\n */\r\n required = input<boolean>(false);\r\n\r\n /**\r\n * Mask preset for input formatting\r\n */\r\n maskPreset = input<MaskPreset | undefined>(undefined);\r\n\r\n /**\r\n * Controls whether the selection functionality is active\r\n */\r\n enableSelectionMode = input<boolean>(false);\r\n\r\n /**\r\n * Regular expression for custom input masking\r\n */\r\n maskRegex = input<string | null>(null);\r\n\r\n /**\r\n * Advanced mask object for IMask library\r\n */\r\n maskAdvanced = input<any | string | null>(null);\r\n\r\n /**\r\n * Maximum length of the input value\r\n */\r\n maxlength = input<number | undefined>(undefined);\r\n\r\n /**\r\n * Whether the input is read-only\r\n */\r\n readOnly = input<boolean>(false);\r\n\r\n /**\r\n * Whether the input is in loading state\r\n */\r\n isLoading = input<boolean>(false);\r\n\r\n /**\r\n * Whether to show the clear button\r\n */\r\n clearIcon = input<boolean>(true);\r\n\r\n /**\r\n * Removes the error icon when necessary\r\n */\r\n hideErrorIcon = input<boolean>(false);\r\n\r\n /**\r\n * Autocomplete attribute for the input\r\n */\r\n autocomplete = input<string>('on');\r\n\r\n /**\r\n * Event emitted when the value changes\r\n */\r\n valueChange = output<InputTextValueChangeEvent>();\r\n\r\n /**\r\n * Event emitted when the clear button is clicked\r\n */\r\n inputClear = output<InputTextClearEvent>();\r\n\r\n // Internal state signals\r\n private isHovered = signal<boolean>(false);\r\n private isFocused = signal<boolean>(false);\r\n\r\n // Form control callbacks\r\n private onChange = (value: string | number) => {};\r\n private onTouched = () => {};\r\n\r\n // ViewChild references\r\n inputElement = viewChild<ElementRef<HTMLInputElement>>('inputElement');\r\n\r\n /**\r\n * Instance of InputMask is returned when IMask constructor is called.\r\n */\r\n maskedInput?: InputMask<FactoryArg>;\r\n\r\n // Reference to input element (equivalent to inputRef in Stencil)\r\n private inputRef?: HTMLInputElement;\r\n\r\n // Utility functions (equivalent to Stencil utils)\r\n private checkMobile(): boolean {\r\n if (isPlatformBrowser(this.platformId)) {\r\n return window?.innerWidth < 768; // Static.breakpoints.medium.min equivalent\r\n }\r\n return false;\r\n }\r\n\r\n private checkIOS(): boolean {\r\n if (isPlatformBrowser(this.platformId)) {\r\n return (\r\n ['iPad Simulator', 'iPhone Simulator', 'iPod Simulator', 'iPad', 'iPhone', 'iPod'].includes(navigator.userAgent) ||\r\n // iPad on iOS 13 detection\r\n (navigator.userAgent.includes('Mac') && 'ontouchend' in document)\r\n );\r\n }\r\n return false;\r\n }\r\n\r\n private fakeInputIOSHack(targetElement: HTMLElement): HTMLInputElement | null {\r\n if (!this.checkMobile() || !this.checkIOS()) return null;\r\n const fakeInput = document.createElement('input');\r\n fakeInput.setAttribute('type', 'text');\r\n fakeInput.style.position = 'absolute';\r\n fakeInput.style.opacity = '0';\r\n fakeInput.style.height = '0';\r\n fakeInput.style.fontSize = '16px'; // disable auto zoom\r\n targetElement.prepend(fakeInput);\r\n // focus so that subsequent async focus will work\r\n fakeInput.focus();\r\n return fakeInput;\r\n }\r\n\r\n // Computed styles\r\n styles = computed(() => {\r\n const { fonts, colors } = this.curaApi?.theme || { fonts: null, colors: null };\r\n\r\n const baseStyles: { [key: string]: string } = {};\r\n\r\n if (fonts) {\r\n const fontWeights = fonts.getWeights();\r\n baseStyles['--font-weight-medium'] = fontWeights.medium;\r\n baseStyles['--font-weight-bold'] = fontWeights.bold;\r\n baseStyles['--font-weight-regular'] = fontWeights.regular;\r\n baseStyles['--font-color'] = fonts.getColor();\r\n baseStyles['--font-family'] = fonts.getFamily();\r\n baseStyles['--font-size'] = fonts.getSize();\r\n }\r\n\r\n if (colors) {\r\n const colorKeys = [\r\n 'primary-base',\r\n 'neutral-purewhite',\r\n 'neutral-white',\r\n 'neutral-black',\r\n 'neutral-medium',\r\n 'neutral-base',\r\n 'neutral-dark',\r\n 'success-dark',\r\n 'success-darker',\r\n 'success-lighter',\r\n 'error-lighter',\r\n 'error-dark',\r\n 'error-darker',\r\n 'error-base',\r\n 'info-base',\r\n ];\r\n\r\n colorKeys.forEach((key) => {\r\n baseStyles[`--${key}`] = colors.getColor(key);\r\n });\r\n }\r\n\r\n return baseStyles;\r\n });\r\n\r\n constructor() {\r\n effect(() => {\r\n if (this.inputRef && (this.maskPreset() || this.maskRegex() || this.maskAdvanced())) {\r\n this.initializeMask();\r\n } else {\r\n this.destroyMask();\r\n }\r\n });\r\n }\r\n\r\n ngAfterViewInit() {\r\n const inputEl = this.inputElement();\r\n if (inputEl) {\r\n this.inputRef = inputEl.nativeElement;\r\n this.initializeMask();\r\n }\r\n }\r\n\r\n ngOnDestroy() {\r\n this.destroyMask();\r\n }\r\n\r\n // ControlValueAccessor implementation\r\n writeValue(value: string | number): void {\r\n this.value.set(value);\r\n }\r\n\r\n registerOnChange(fn: (value: string | number) => void): void {\r\n this.onChange = fn;\r\n }\r\n\r\n registerOnTouched(fn: () => void): void {\r\n this.onTouched = fn;\r\n }\r\n\r\n // Public methods\r\n async setFocus(): Promise<void> {\r\n // IOS needs large timeout value to work\r\n const timeoutMs = this.checkMobile() && this.checkIOS() ? 1000 : 200;\r\n // IOS fake input hack\r\n let fakeInput = this.fakeInputIOSHack(this.elementRef.nativeElement);\r\n\r\n setTimeout(() => {\r\n if (this.inputRef) {\r\n this.inputRef.focus();\r\n }\r\n if (fakeInput) {\r\n fakeInput.remove();\r\n }\r\n }, timeoutMs);\r\n }\r\n\r\n // Computed signals\r\n classes = computed(() => ({\r\n [this.size().toLowerCase()]: this.mode() === 'default',\r\n disabled: this.disabled(),\r\n isLoading: this.isLoading(),\r\n isFocused: this.isFocused() && !this.disabled() && !this.readOnly() && !this.isLoading(),\r\n isHovered: this.isHovered(),\r\n [this.status()]: true,\r\n transparent: this.mode() === 'transparent',\r\n selection: this.enableSelectionMode(),\r\n }));\r\n\r\n labelColor = computed(() => {\r\n if (this.disabled()) {\r\n return 'neutral-medium';\r\n } else if (this.isLoading() && this.mode() === 'transparent' && !this.isHovered()) {\r\n return 'neutral-dark';\r\n } else if (((this.isFocused() || this.isHovered() || this.status() === 'success' || this.status() === 'error') && !this.readOnly()) || this.isHovered()) {\r\n return 'neutral-black';\r\n } else {\r\n return 'neutral-dark';\r\n }\r\n });\r\n\r\n iconConfig = computed(() => {\r\n const shouldShowIcon = (() => {\r\n if (\r\n (this.iconName() === '' && this.status() === 'default') ||\r\n (this.mode() === 'transparent' && this.isLoading()) ||\r\n (this.mode() === 'transparent' && this.status() === 'default')\r\n ) {\r\n return false;\r\n }\r\n if (this.status() === 'error' && this.hideErrorIcon()) {\r\n return false;\r\n }\r\n return true;\r\n })();\r\n\r\n if (!shouldShowIcon) {\r\n return {\r\n icon: null,\r\n size: 0,\r\n };\r\n }\r\n\r\n const iconSizeDefaultMode = this.size() === 'large' ? 20 : 16;\r\n const size = this.mode() === 'transparent' ? 20 : iconSizeDefaultMode;\r\n\r\n const iconMap: { [key: string]: { name: string; color: string } } = {\r\n loading: { name: this.iconName(), color: 'primary-base' },\r\n success: { name: 'checkCircle', color: 'success-dark' },\r\n error: { name: 'alertCircle', color: 'error-dark' },\r\n default: { name: this.iconName(), color: 'neutral-dark' },\r\n disabled: { name: this.iconName(), color: 'neutral-medium' },\r\n };\r\n\r\n const icon = iconMap[this.isLoading() ? 'loading' : this.disabled() ? 'disabled' : this.status() || 'default'];\r\n\r\n return {\r\n icon,\r\n size,\r\n };\r\n });\r\n\r\n helperText = computed(() => {\r\n const isError = this.status() === 'error';\r\n const isSuccess = this.status() === 'success';\r\n const isDefault = this.status() === 'default';\r\n const helperTextSize = this.size() === 'large' ? 'small' : 'xsmall';\r\n\r\n const colorText = (() => {\r\n if (this.disabled()) return 'neutral-medium';\r\n if (this.isLoading()) return 'primary-base';\r\n if (this.isFocused() || this.isHovered()) return 'neutral-black';\r\n return 'neutral-dark';\r\n })();\r\n\r\n return {\r\n size: helperTextSize,\r\n color: isDefault ? colorText : isError ? (this.mode() === 'transparent' ? 'neutral-black' : 'error-dark') : isSuccess ? 'success-dark' : colorText,\r\n };\r\n });\r\n\r\n shouldShowClearButton = computed(() => {\r\n return !!(this.clearIcon() && !this.readOnly() && !this.isLoading() && !this.disabled() && this.value() && this.isFocused());\r\n });\r\n\r\n // Event handlers\r\n handleMouseEnter(): void {\r\n this.isHovered.set(true);\r\n }\r\n\r\n handleMouseLeave(): void {\r\n this.isHovered.set(false);\r\n }\r\n\r\n handleInputFocus(): void {\r\n this.handleMaskUpdate();\r\n this.isFocused.set(true);\r\n }\r\n\r\n handleInputBlur(): void {\r\n this.handleMaskUpdate();\r\n this.onTouched();\r\n setTimeout(() => {\r\n this.isFocused.set(false);\r\n }, 150);\r\n }\r\n\r\n handleInputChange(event: Event): void {\r\n const inputValue = (event.target as HTMLInputElement).value;\r\n\r\n if (this.type() === 'number') {\r\n this.handleNumberInputChange(inputValue);\r\n } else {\r\n this.handleTextInputChange(inputValue);\r\n }\r\n }\r\n\r\n handleKeyDown(event: KeyboardEvent): void {\r\n if (this.type() === 'number') {\r\n this.handleBlockInvalidNumber(event);\r\n }\r\n }\r\n\r\n handleClearInput(): void {\r\n this.handleMaskUpdate();\r\n this.value.set('');\r\n if (this.inputRef) {\r\n this.inputRef.value = '';\r\n }\r\n this.valueChange.emit({ value: this.value() });\r\n this.inputClear.emit({ value: this.value() });\r\n this.onChange(this.value());\r\n this.handleMaskUpdate();\r\n this.setFocus();\r\n }\r\n\r\n // Private methods\r\n private handleNumberInputChange(inputValue: string): void {\r\n const numericValue = parseFloat(inputValue);\r\n if (!isNaN(numericValue)) {\r\n this.value.set(numericValue);\r\n } else {\r\n console.error('Invalid numeric input:', inputValue);\r\n }\r\n this.valueChange.emit({ value: inputValue });\r\n }\r\n\r\n private handleTextInputChange(inputValue: string): void {\r\n if (this.maskedInput) {\r\n if (this.maskedInput.mask instanceof Date || this.maskedInput.mask === Number) {\r\n this.maskedInput.typedValue = inputValue;\r\n }\r\n this.maskedInput.value = inputValue;\r\n this.valueChange.emit({ value: this.maskedInput.value });\r\n } else {\r\n this.valueChange.emit({ value: inputValue });\r\n }\r\n }\r\n\r\n private handleBlockInvalidNumber(e: KeyboardEvent): void {\r\n if (['e', 'E', '+', '-'].includes(e.key)) {\r\n e.preventDefault();\r\n }\r\n }\r\n\r\n private shouldDisplayMask(): boolean {\r\n return !!(this.maskPreset() || this.maskRegex() || this.maskAdvanced());\r\n }\r\n\r\n private initializeMask(): void {\r\n if (this.shouldDisplayMask()) {\r\n if (this.maskedInput) {\r\n this.destroyMask();\r\n }\r\n if (this.maskPreset()) {\r\n this.initializePresetMask();\r\n } else if (this.maskRegex()) {\r\n this.initializeRegexMask();\r\n } else if (this.maskAdvanced()) {\r\n this.initializeAdvancedMask();\r\n }\r\n this.applyValueToMask();\r\n } else {\r\n this.clearMaskValue();\r\n }\r\n }\r\n\r\n initializePresetMask() {\r\n const preset = this.maskPreset();\r\n if (!preset) return;\r\n\r\n const options = maskOptions[preset];\r\n\r\n if (options && this.inputRef) {\r\n this.maskedInput = IMask(this.inputRef, options);\r\n } else {\r\n console.error(`Mask preset \"${preset}\" not found.`);\r\n }\r\n }\r\n\r\n initializeRegexMask() {\r\n const regex = this.maskRegex();\r\n if (!regex || !this.inputRef) return;\r\n\r\n const cleanedRegexString = regex.replace(/^\\/|\\/[gimsuy]*$/g, '');\r\n const flags = (regex.match(/\\/[gimsuy]*$/g) || [''])[0].slice(1);\r\n this.maskedInput = IMask(this.inputRef, { mask: new RegExp(cleanedRegexString, flags) });\r\n }\r\n\r\n initializeAdvancedMask() {\r\n if (!this.inputRef) return;\r\n\r\n try {\r\n const config = typeof this.maskAdvanced() === 'string' ? JSON.parse(this.maskAdvanced()) : this.maskAdvanced();\r\n this.maskedInput = IMask(this.inputRef, config);\r\n } catch (error) {\r\n console.error('Error defining maskAdvanced:', error);\r\n }\r\n }\r\n\r\n private applyValueToMask(): void {\r\n if (this.maskedInput) {\r\n if (this.maskedInput.mask === Date || this.maskedInput.mask === Number) {\r\n this.maskedInput.typedValue = this.value();\r\n } else {\r\n this.maskedInput.value = this.value() as string;\r\n }\r\n this.handleMaskUpdate();\r\n }\r\n }\r\n\r\n private clearMaskValue(): void {\r\n if (this.inputRef) {\r\n this.inputRef.value = this.value() as string;\r\n }\r\n }\r\n\r\n private destroyMask(): void {\r\n if (this.maskedInput) {\r\n this.maskedInput.destroy();\r\n this.maskedInput = undefined;\r\n }\r\n }\r\n\r\n private handleMaskUpdate(): void {\r\n if (this.maskedInput) {\r\n this.maskedInput.updateValue();\r\n }\r\n }\r\n}\r\n","<div class=\"cura-input-group\" [ngClass]=\"classes()\" [style]=\"styles()\" (mouseenter)=\"handleMouseEnter()\" (mouseleave)=\"handleMouseLeave()\">\r\n <div class=\"input-wrapper\">\r\n @if (label()) {\r\n <cura-label class=\"label\" weight=\"bold\" [size]=\"size() === 'large' ? 'small' : 'xsmall'\" [color]=\"labelColor()\">\r\n {{ label() }}\r\n @if (required()) {\r\n <span class=\"required\">*</span>\r\n }\r\n </cura-label>\r\n }\r\n\r\n <div class=\"cura-input-field\" [style]=\"styles()\">\r\n @if (iconConfig().icon) {\r\n <div class=\"feedback-icon\" [style]=\"styles()\">\r\n <cura-icon [name]=\"iconConfig().icon!.name\" iconset=\"default\" [size]=\"iconConfig().size\" [color]=\"iconConfig().icon!.color\"> </cura-icon>\r\n </div>\r\n }\r\n\r\n <input\r\n #inputElement\r\n [name]=\"name() || ''\"\r\n [type]=\"type()\"\r\n [placeholder]=\"placeholder()\"\r\n [disabled]=\"disabled() || isLoading()\"\r\n [required]=\"required()\"\r\n [readonly]=\"readOnly()\"\r\n [attr.maxlength]=\"maxlength()\"\r\n [(ngModel)]=\"value\"\r\n [attr.inputmode]=\"maskPreset() ? 'tel' : inputMode()\"\r\n [autocomplete]=\"autocomplete()\"\r\n [ngClass]=\"classes()\"\r\n [style]=\"styles()\"\r\n (focus)=\"handleInputFocus()\"\r\n (blur)=\"handleInputBlur()\"\r\n (input)=\"handleInputChange($event)\"\r\n (keydown)=\"handleKeyDown($event)\"\r\n />\r\n\r\n @if (shouldShowClearButton()) {\r\n <cura-icon\r\n [size]=\"size() === 'large' || mode() === 'transparent' ? 20 : 16\"\r\n color=\"primary-base\"\r\n name=\"closeCircle\"\r\n iconset=\"default\"\r\n class=\"clear-button\"\r\n (click)=\"handleClearInput()\"\r\n >\r\n </cura-icon>\r\n }\r\n\r\n @if (isLoading()) {\r\n <cura-loader-circle [size]=\"size() === 'large' ? 'medium' : 'small'\" color=\"primary-base\"> </cura-loader-circle>\r\n }\r\n </div>\r\n\r\n @if (helperText()) {\r\n <div [style]=\"styles()\" class=\"helper-text\" part=\"cura-input-text-helper\">\r\n <cura-label size=\"xsmall\" lineHeight=\"xsmall\" [color]=\"helperText().color\">\r\n <ng-content></ng-content>\r\n </cura-label>\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"rededor-site-front-end-lib-cura-forms-cura-input-text.mjs","sources":["../../../projects/site-front-end-lib/cura/forms/cura-input-text/cura-input-text.definitions.ts","../../../projects/site-front-end-lib/cura/forms/cura-input-text/cura-input-text.component.ts","../../../projects/site-front-end-lib/cura/forms/cura-input-text/cura-input-text.component.html","../../../projects/site-front-end-lib/cura/forms/cura-input-text/rededor-site-front-end-lib-cura-forms-cura-input-text.ts"],"sourcesContent":["/**\n * Display mode options for the input text component\n */\nexport type InputTextMode = 'default' | 'transparent';\n\n/**\n * Size options for the input text component\n */\nexport type InputTextSize = 'small' | 'medium' | 'large';\n\n/**\n * Status options for the input text component\n */\nexport type InputTextStatus = 'success' | 'error' | 'default';\n\n/**\n * Input type options for the input text component\n */\nexport type InputTextType = 'text' | 'number' | 'email' | 'password' | 'tel' | 'url';\n\n/**\n * Input mode options for the input text component\n */\nexport type InputTextInputMode = 'text' | 'decimal' | 'numeric' | 'tel' | 'search' | 'email' | 'url';\n\n/**\n * Mask preset options for input formatting\n */\nexport type MaskPreset = 'cpf' | 'cnpj' | 'cpf_cnpj' | 'phone' | 'date' | 'dateRange';\n\n/**\n * Event payload emitted when the input value changes\n */\nexport interface InputTextValueChangeEvent {\n /**\n * The new value of the input\n */\n value: string | number;\n}\n\n/**\n * Event payload emitted when the clear button is clicked\n */\nexport interface InputTextClearEvent {\n /**\n * The value that was cleared (usually empty string)\n */\n value: string | number;\n}\n\n/**\n * Mask options map for IMask library\n */\nexport interface MaskOptionsMap {\n [key: string]: any;\n}\n\n/**\n * Mask configuration for different presets\n */\nexport const maskOptions: MaskOptionsMap = {\n cpf_cnpj: {\n mask: [{ mask: '000.000.000-00' }, { mask: '00.000.000/0000-00' }],\n placeholderChar: '_',\n },\n cpf: {\n mask: '000.000.000-00',\n placeholderChar: '_',\n },\n cnpj: {\n mask: '00.000.000/0000-00',\n placeholderChar: '_',\n },\n phone: {\n mask: '(00) 00000-0000',\n blocks: {\n '(00)': {\n mask: '(00)',\n maxLength: 2,\n placeholderChar: '',\n },\n '00000': {\n mask: '00000',\n maxLength: 5,\n placeholderChar: '_',\n },\n '-': {\n mask: '-',\n },\n '0000': {\n mask: '0000',\n maxLength: 4,\n placeholderChar: '_',\n },\n },\n placeholderChar: '_',\n },\n date: {\n mask: '00/00/0000',\n },\n dateRange: {\n mask: '00/00/0000 - 00/00/0000',\n },\n};\n","import {\n Component,\n input,\n output,\n signal,\n computed,\n inject,\n forwardRef,\n ElementRef,\n AfterViewInit,\n OnDestroy,\n viewChild,\n model,\n effect,\n PLATFORM_ID,\n} from '@angular/core';\nimport { CommonModule, isPlatformBrowser } from '@angular/common';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { CuraApiService } from '@rededor/site-front-end-lib/cura/api';\nimport { CuraLabelComponent } from '@rededor/site-front-end-lib/cura/forms/cura-label';\nimport { CuraIconComponent } from '@rededor/site-front-end-lib/cura/icons/cura-icon';\nimport { CuraLoaderCircleComponent } from '@rededor/site-front-end-lib/cura/loaders/cura-loader-circle';\nimport IMask, { FactoryArg, InputMask } from 'imask';\nimport {\n InputTextMode,\n InputTextSize,\n InputTextStatus,\n InputTextType,\n InputTextInputMode,\n MaskPreset,\n InputTextValueChangeEvent,\n InputTextClearEvent,\n maskOptions,\n} from './cura-input-text.definitions';\n\n@Component({\n selector: 'cura-input-text',\n imports: [CommonModule, FormsModule, CuraLabelComponent, CuraIconComponent, CuraLoaderCircleComponent],\n templateUrl: './cura-input-text.component.html',\n styleUrls: ['./cura-input-text.component.scss'],\n host: {\n role: 'textbox',\n '[attr.aria-disabled]': 'disabled()',\n '[attr.aria-required]': 'required()',\n '[attr.aria-invalid]': 'status() === \"error\"',\n },\n providers: [\n {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(() => CuraInputTextComponent),\n multi: true,\n },\n ],\n})\nexport class CuraInputTextComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\n private curaApi: CuraApiService = inject(CuraApiService);\n private elementRef = inject(ElementRef);\n private platformId = inject(PLATFORM_ID);\n /**\n * Mode of the input: 'default' or 'transparent'\n */\n mode = input<InputTextMode>('default');\n\n /**\n * Status of the input component\n */\n status = input<InputTextStatus>('default');\n\n /**\n * Size of the input component\n */\n size = input<InputTextSize>('medium');\n\n /**\n * Type of the input\n */\n type = input<InputTextType>('text');\n\n /**\n * Input mode for mobile keyboards\n */\n inputMode = input<InputTextInputMode>('text');\n\n /**\n * Label text for the input\n */\n label = input<string>('');\n\n /**\n * Name attribute for the input\n */\n name = input<string>('');\n\n /**\n * Placeholder text for the input\n */\n placeholder = input<string | null>(null);\n\n /**\n * Current value of the input\n */\n value = model<string | number | any>('');\n\n /**\n * Icon name to display\n */\n iconName = input<string>('');\n\n /**\n * Helper text displayed below the input\n */\n // helperText = input<string>(''); // Não está sendo usado\n\n /**\n * Whether the input is disabled\n */\n disabled = input<boolean>(false);\n\n /**\n * Whether the input is required\n */\n required = input<boolean>(false);\n\n /**\n * Mask preset for input formatting\n */\n maskPreset = input<MaskPreset | undefined>(undefined);\n\n /**\n * Controls whether the selection functionality is active\n */\n enableSelectionMode = input<boolean>(false);\n\n /**\n * Regular expression for custom input masking\n */\n maskRegex = input<string | null>(null);\n\n /**\n * Advanced mask object for IMask library\n */\n maskAdvanced = input<any | string | null>(null);\n\n /**\n * Maximum length of the input value\n */\n maxlength = input<number | undefined>(undefined);\n\n /**\n * Whether the input is read-only\n */\n readOnly = input<boolean>(false);\n\n /**\n * Whether the input is in loading state\n */\n isLoading = input<boolean>(false);\n\n /**\n * Whether to show the clear button\n */\n clearIcon = input<boolean>(true);\n\n /**\n * Removes the error icon when necessary\n */\n hideErrorIcon = input<boolean>(false);\n\n /**\n * Autocomplete attribute for the input\n */\n autocomplete = input<string>('on');\n\n /**\n * Event emitted when the value changes\n */\n valueChange = output<InputTextValueChangeEvent>();\n\n /**\n * Event emitted when the clear button is clicked\n */\n inputClear = output<InputTextClearEvent>();\n\n // Internal state signals\n private isHovered = signal<boolean>(false);\n private isFocused = signal<boolean>(false);\n\n // Form control callbacks\n private onChange = (value: string | number) => {};\n private onTouched = () => {};\n\n // ViewChild references\n inputElement = viewChild<ElementRef<HTMLInputElement>>('inputElement');\n\n /**\n * Instance of InputMask is returned when IMask constructor is called.\n */\n maskedInput?: InputMask<FactoryArg>;\n\n // Reference to input element (equivalent to inputRef in Stencil)\n private inputRef?: HTMLInputElement;\n\n // Utility functions (equivalent to Stencil utils)\n private checkMobile(): boolean {\n if (isPlatformBrowser(this.platformId)) {\n return window?.innerWidth < 768; // Static.breakpoints.medium.min equivalent\n }\n return false;\n }\n\n private checkIOS(): boolean {\n if (isPlatformBrowser(this.platformId)) {\n return (\n ['iPad Simulator', 'iPhone Simulator', 'iPod Simulator', 'iPad', 'iPhone', 'iPod'].includes(navigator.userAgent) ||\n // iPad on iOS 13 detection\n (navigator.userAgent.includes('Mac') && 'ontouchend' in document)\n );\n }\n return false;\n }\n\n private fakeInputIOSHack(targetElement: HTMLElement): HTMLInputElement | null {\n if (!this.checkMobile() || !this.checkIOS()) return null;\n const fakeInput = document.createElement('input');\n fakeInput.setAttribute('type', 'text');\n fakeInput.style.position = 'absolute';\n fakeInput.style.opacity = '0';\n fakeInput.style.height = '0';\n fakeInput.style.fontSize = '16px'; // disable auto zoom\n targetElement.prepend(fakeInput);\n // focus so that subsequent async focus will work\n fakeInput.focus();\n return fakeInput;\n }\n\n // Computed styles\n styles = computed(() => {\n const { fonts, colors } = this.curaApi?.theme || { fonts: null, colors: null };\n\n const baseStyles: { [key: string]: string } = {};\n\n if (fonts) {\n const fontWeights = fonts.getWeights();\n baseStyles['--font-weight-medium'] = fontWeights.medium;\n baseStyles['--font-weight-bold'] = fontWeights.bold;\n baseStyles['--font-weight-regular'] = fontWeights.regular;\n baseStyles['--font-color'] = fonts.getColor();\n baseStyles['--font-family'] = fonts.getFamily();\n baseStyles['--font-size'] = fonts.getSize();\n }\n\n if (colors) {\n const colorKeys = [\n 'primary-base',\n 'neutral-purewhite',\n 'neutral-white',\n 'neutral-black',\n 'neutral-medium',\n 'neutral-base',\n 'neutral-dark',\n 'success-dark',\n 'success-darker',\n 'success-lighter',\n 'error-lighter',\n 'error-dark',\n 'error-darker',\n 'error-base',\n 'info-base',\n ];\n\n colorKeys.forEach((key) => {\n baseStyles[`--${key}`] = colors.getColor(key);\n });\n }\n\n return baseStyles;\n });\n\n constructor() {\n effect(() => {\n if (this.inputRef && (this.maskPreset() || this.maskRegex() || this.maskAdvanced())) {\n this.initializeMask();\n } else {\n this.destroyMask();\n }\n });\n }\n\n ngAfterViewInit() {\n const inputEl = this.inputElement();\n if (inputEl) {\n this.inputRef = inputEl.nativeElement;\n this.initializeMask();\n }\n }\n\n ngOnDestroy() {\n this.destroyMask();\n }\n\n // ControlValueAccessor implementation\n writeValue(value: string | number): void {\n this.value.set(value);\n }\n\n registerOnChange(fn: (value: string | number) => void): void {\n this.onChange = fn;\n }\n\n registerOnTouched(fn: () => void): void {\n this.onTouched = fn;\n }\n\n // Public methods\n async setFocus(): Promise<void> {\n // IOS needs large timeout value to work\n const timeoutMs = this.checkMobile() && this.checkIOS() ? 1000 : 200;\n // IOS fake input hack\n let fakeInput = this.fakeInputIOSHack(this.elementRef.nativeElement);\n\n setTimeout(() => {\n if (this.inputRef) {\n this.inputRef.focus();\n }\n if (fakeInput) {\n fakeInput.remove();\n }\n }, timeoutMs);\n }\n\n // Computed signals\n classes = computed(() => ({\n [this.size().toLowerCase()]: this.mode() === 'default',\n disabled: this.disabled(),\n isLoading: this.isLoading(),\n isFocused: this.isFocused() && !this.disabled() && !this.readOnly() && !this.isLoading(),\n isHovered: this.isHovered(),\n [this.status()]: true,\n transparent: this.mode() === 'transparent',\n selection: this.enableSelectionMode(),\n }));\n\n labelColor = computed(() => {\n if (this.disabled()) {\n return 'neutral-medium';\n } else if (this.isLoading() && this.mode() === 'transparent' && !this.isHovered()) {\n return 'neutral-dark';\n } else if (((this.isFocused() || this.isHovered() || this.status() === 'success' || this.status() === 'error') && !this.readOnly()) || this.isHovered()) {\n return 'neutral-black';\n } else {\n return 'neutral-dark';\n }\n });\n\n iconConfig = computed(() => {\n const shouldShowIcon = (() => {\n if (\n (this.iconName() === '' && this.status() === 'default') ||\n (this.mode() === 'transparent' && this.isLoading()) ||\n (this.mode() === 'transparent' && this.status() === 'default')\n ) {\n return false;\n }\n if (this.status() === 'error' && this.hideErrorIcon()) {\n return false;\n }\n return true;\n })();\n\n if (!shouldShowIcon) {\n return {\n icon: null,\n size: 0,\n };\n }\n\n const iconSizeDefaultMode = this.size() === 'large' ? 20 : 16;\n const size = this.mode() === 'transparent' ? 20 : iconSizeDefaultMode;\n\n const iconMap: { [key: string]: { name: string; color: string } } = {\n loading: { name: this.iconName(), color: 'primary-base' },\n success: { name: 'checkCircle', color: 'success-dark' },\n error: { name: 'alertCircle', color: 'error-dark' },\n default: { name: this.iconName(), color: 'neutral-dark' },\n disabled: { name: this.iconName(), color: 'neutral-medium' },\n };\n\n const icon = iconMap[this.isLoading() ? 'loading' : this.disabled() ? 'disabled' : this.status() || 'default'];\n\n return {\n icon,\n size,\n };\n });\n\n helperText = computed(() => {\n const isError = this.status() === 'error';\n const isSuccess = this.status() === 'success';\n const isDefault = this.status() === 'default';\n const helperTextSize = this.size() === 'large' ? 'small' : 'xsmall';\n\n const colorText = (() => {\n if (this.disabled()) return 'neutral-medium';\n if (this.isLoading()) return 'primary-base';\n if (this.isFocused() || this.isHovered()) return 'neutral-black';\n return 'neutral-dark';\n })();\n\n return {\n size: helperTextSize,\n color: isDefault ? colorText : isError ? (this.mode() === 'transparent' ? 'neutral-black' : 'error-dark') : isSuccess ? 'success-dark' : colorText,\n };\n });\n\n shouldShowClearButton = computed(() => {\n return !!(this.clearIcon() && !this.readOnly() && !this.isLoading() && !this.disabled() && this.value() && this.isFocused());\n });\n\n // Event handlers\n handleMouseEnter(): void {\n this.isHovered.set(true);\n }\n\n handleMouseLeave(): void {\n this.isHovered.set(false);\n }\n\n handleInputFocus(): void {\n this.handleMaskUpdate();\n this.isFocused.set(true);\n }\n\n handleInputBlur(): void {\n this.handleMaskUpdate();\n this.onTouched();\n setTimeout(() => {\n this.isFocused.set(false);\n }, 150);\n }\n\n handleInputChange(event: Event): void {\n const inputValue = (event.target as HTMLInputElement).value;\n\n if (this.type() === 'number') {\n this.handleNumberInputChange(inputValue);\n } else {\n this.handleTextInputChange(inputValue);\n }\n }\n\n handleKeyDown(event: KeyboardEvent): void {\n if (this.type() === 'number') {\n this.handleBlockInvalidNumber(event);\n }\n }\n\n handleClearInput(): void {\n this.handleMaskUpdate();\n this.value.set('');\n if (this.inputRef) {\n this.inputRef.value = '';\n }\n this.valueChange.emit({ value: this.value() });\n this.inputClear.emit({ value: this.value() });\n this.onChange(this.value());\n this.handleMaskUpdate();\n this.setFocus();\n }\n\n // Private methods\n private handleNumberInputChange(inputValue: string): void {\n const numericValue = parseFloat(inputValue);\n if (!isNaN(numericValue)) {\n this.value.set(numericValue);\n } else {\n console.error('Invalid numeric input:', inputValue);\n }\n this.valueChange.emit({ value: inputValue });\n }\n\n private handleTextInputChange(inputValue: string): void {\n if (this.maskedInput) {\n if (this.maskedInput.mask instanceof Date || this.maskedInput.mask === Number) {\n this.maskedInput.typedValue = inputValue;\n }\n this.maskedInput.value = inputValue;\n this.valueChange.emit({ value: this.maskedInput.value });\n } else {\n this.valueChange.emit({ value: inputValue });\n }\n }\n\n private handleBlockInvalidNumber(e: KeyboardEvent): void {\n if (['e', 'E', '+', '-'].includes(e.key)) {\n e.preventDefault();\n }\n }\n\n private shouldDisplayMask(): boolean {\n return !!(this.maskPreset() || this.maskRegex() || this.maskAdvanced());\n }\n\n private initializeMask(): void {\n if (this.shouldDisplayMask()) {\n if (this.maskedInput) {\n this.destroyMask();\n }\n if (this.maskPreset()) {\n this.initializePresetMask();\n } else if (this.maskRegex()) {\n this.initializeRegexMask();\n } else if (this.maskAdvanced()) {\n this.initializeAdvancedMask();\n }\n this.applyValueToMask();\n } else {\n this.clearMaskValue();\n }\n }\n\n initializePresetMask() {\n const preset = this.maskPreset();\n if (!preset) return;\n\n const options = maskOptions[preset];\n\n if (options && this.inputRef) {\n this.maskedInput = IMask(this.inputRef, options);\n } else {\n console.error(`Mask preset \"${preset}\" not found.`);\n }\n }\n\n initializeRegexMask() {\n const regex = this.maskRegex();\n if (!regex || !this.inputRef) return;\n\n const cleanedRegexString = regex.replace(/^\\/|\\/[gimsuy]*$/g, '');\n const flags = (regex.match(/\\/[gimsuy]*$/g) || [''])[0].slice(1);\n this.maskedInput = IMask(this.inputRef, { mask: new RegExp(cleanedRegexString, flags) });\n }\n\n initializeAdvancedMask() {\n if (!this.inputRef) return;\n\n try {\n const config = typeof this.maskAdvanced() === 'string' ? JSON.parse(this.maskAdvanced()) : this.maskAdvanced();\n this.maskedInput = IMask(this.inputRef, config);\n } catch (error) {\n console.error('Error defining maskAdvanced:', error);\n }\n }\n\n private applyValueToMask(): void {\n if (this.maskedInput) {\n if (this.maskedInput.mask === Date || this.maskedInput.mask === Number) {\n this.maskedInput.typedValue = this.value();\n } else {\n this.maskedInput.value = this.value() as string;\n }\n this.handleMaskUpdate();\n }\n }\n\n private clearMaskValue(): void {\n if (this.inputRef) {\n this.inputRef.value = this.value() as string;\n }\n }\n\n private destroyMask(): void {\n if (this.maskedInput) {\n this.maskedInput.destroy();\n this.maskedInput = undefined;\n }\n }\n\n private handleMaskUpdate(): void {\n if (this.maskedInput) {\n this.maskedInput.updateValue();\n }\n }\n}\n","<div class=\"cura-input-group\" [ngClass]=\"classes()\" [style]=\"styles()\" (mouseenter)=\"handleMouseEnter()\" (mouseleave)=\"handleMouseLeave()\">\n <div class=\"input-wrapper\">\n @if (label()) {\n <cura-label class=\"label\" weight=\"bold\" [size]=\"size() === 'large' ? 'small' : 'xsmall'\" [color]=\"labelColor()\">\n {{ label() }}\n @if (required()) {\n <span class=\"required\">*</span>\n }\n </cura-label>\n }\n\n <div class=\"cura-input-field\" [style]=\"styles()\">\n @if (iconConfig().icon) {\n <div class=\"feedback-icon\" [style]=\"styles()\">\n <cura-icon [name]=\"iconConfig().icon!.name\" iconset=\"default\" [size]=\"iconConfig().size\" [color]=\"iconConfig().icon!.color\"> </cura-icon>\n </div>\n }\n\n <input\n #inputElement\n [name]=\"name() || ''\"\n [type]=\"type()\"\n [placeholder]=\"placeholder()\"\n [disabled]=\"disabled() || isLoading()\"\n [required]=\"required()\"\n [readonly]=\"readOnly()\"\n [attr.maxlength]=\"maxlength()\"\n [(ngModel)]=\"value\"\n [attr.inputmode]=\"maskPreset() ? 'tel' : inputMode()\"\n [autocomplete]=\"autocomplete()\"\n [ngClass]=\"classes()\"\n [style]=\"styles()\"\n (focus)=\"handleInputFocus()\"\n (blur)=\"handleInputBlur()\"\n (input)=\"handleInputChange($event)\"\n (keydown)=\"handleKeyDown($event)\"\n />\n\n @if (shouldShowClearButton()) {\n <cura-icon\n [size]=\"size() === 'large' || mode() === 'transparent' ? 20 : 16\"\n color=\"primary-base\"\n name=\"closeCircle\"\n iconset=\"default\"\n class=\"clear-button\"\n (click)=\"handleClearInput()\"\n >\n </cura-icon>\n }\n\n @if (isLoading()) {\n <cura-loader-circle [size]=\"size() === 'large' ? 'medium' : 'small'\" color=\"primary-base\"> </cura-loader-circle>\n }\n </div>\n\n @if (helperText()) {\n <div [style]=\"styles()\" class=\"helper-text\" part=\"cura-input-text-helper\">\n <cura-label size=\"xsmall\" lineHeight=\"xsmall\" [color]=\"helperText().color\">\n <ng-content></ng-content>\n </cura-label>\n </div>\n }\n </div>\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
@@ -63,15 +63,15 @@ class CuraLabelComponent {
63
63
  return classes.join(' ');
64
64
  }, ...(ngDevMode ? [{ debugName: "containerClasses" }] : []));
65
65
  }
66
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CuraLabelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
67
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "20.3.15", type: CuraLabelComponent, isStandalone: true, selector: "cura-label", inputs: { size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, weight: { classPropertyName: "weight", publicName: "weight", isSignal: true, isRequired: false, transformFunction: null }, spotColor: { classPropertyName: "spotColor", publicName: "spotColor", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, marginBlock: { classPropertyName: "marginBlock", publicName: "marginBlock", isSignal: true, isRequired: false, transformFunction: null }, lineHeight: { classPropertyName: "lineHeight", publicName: "lineHeight", isSignal: true, isRequired: false, transformFunction: null }, textOverflow: { classPropertyName: "textOverflow", publicName: "textOverflow", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "style.--line-height": "lineHeight()", "style.--color-body": "bodyColor()" } }, ngImport: i0, template: "<p [class]=\"containerClasses()\">\r\n <ng-content></ng-content>\r\n</p>\r\n", styles: [":host{display:block;font-size:var(--cura-font-size)}:host p{font-family:var(--cura-font-body);font-size:1.143em;font-weight:500;color:var(--color-body);line-height:var(--line-height);margin-block:0px;letter-spacing:.32px}:host p.bold-weight{font-weight:700}:host p.large{font-size:1.357em;line-height:calc(var(--line-height) - 4%);letter-spacing:0px}:host p.small{font-size:1em;line-height:calc(var(--line-height) - 4%);letter-spacing:.56px}:host p.xsmall{font-size:.857em;line-height:calc(var(--line-height) - 17%);letter-spacing:.72px}:host p.textoverflow-single{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:host p ::ng-deep b,:host p ::ng-deep strong,:host p ::ng-deep u{font-weight:700}:host p ::ng-deep a{font-weight:700;color:rgba(var(--cura-color-accent-700));text-underline-offset:10%}:host p ::ng-deep u{text-underline-offset:10%}:host p ::ng-deep abbr{color:rgba(var(--cura-color-accent-700));text-decoration:underline dashed 1px rgba(var(--cura-color-accent-700));text-underline-offset:10%;cursor:default}\n"] }); }
66
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: CuraLabelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
67
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "20.3.16", type: CuraLabelComponent, isStandalone: true, selector: "cura-label", inputs: { size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, weight: { classPropertyName: "weight", publicName: "weight", isSignal: true, isRequired: false, transformFunction: null }, spotColor: { classPropertyName: "spotColor", publicName: "spotColor", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, marginBlock: { classPropertyName: "marginBlock", publicName: "marginBlock", isSignal: true, isRequired: false, transformFunction: null }, lineHeight: { classPropertyName: "lineHeight", publicName: "lineHeight", isSignal: true, isRequired: false, transformFunction: null }, textOverflow: { classPropertyName: "textOverflow", publicName: "textOverflow", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "style.--line-height": "lineHeight()", "style.--color-body": "bodyColor()" } }, ngImport: i0, template: "<p [class]=\"containerClasses()\">\n <ng-content></ng-content>\n</p>\n", styles: [":host{display:block;font-size:var(--cura-font-size)}:host p{font-family:var(--cura-font-body);font-size:1.143em;font-weight:500;color:var(--color-body);line-height:var(--line-height);margin-block:0px;letter-spacing:.32px}:host p.bold-weight{font-weight:700}:host p.large{font-size:1.357em;line-height:calc(var(--line-height) - 4%);letter-spacing:0px}:host p.small{font-size:1em;line-height:calc(var(--line-height) - 4%);letter-spacing:.56px}:host p.xsmall{font-size:.857em;line-height:calc(var(--line-height) - 17%);letter-spacing:.72px}:host p.textoverflow-single{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:host p ::ng-deep b,:host p ::ng-deep strong,:host p ::ng-deep u{font-weight:700}:host p ::ng-deep a{font-weight:700;color:rgba(var(--cura-color-accent-700));text-underline-offset:10%}:host p ::ng-deep u{text-underline-offset:10%}:host p ::ng-deep abbr{color:rgba(var(--cura-color-accent-700));text-decoration:underline dashed 1px rgba(var(--cura-color-accent-700));text-underline-offset:10%;cursor:default}\n"] }); }
68
68
  }
69
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CuraLabelComponent, decorators: [{
69
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: CuraLabelComponent, decorators: [{
70
70
  type: Component,
71
71
  args: [{ selector: 'cura-label', host: {
72
72
  '[style.--line-height]': 'lineHeight()',
73
73
  '[style.--color-body]': 'bodyColor()',
74
- }, template: "<p [class]=\"containerClasses()\">\r\n <ng-content></ng-content>\r\n</p>\r\n", styles: [":host{display:block;font-size:var(--cura-font-size)}:host p{font-family:var(--cura-font-body);font-size:1.143em;font-weight:500;color:var(--color-body);line-height:var(--line-height);margin-block:0px;letter-spacing:.32px}:host p.bold-weight{font-weight:700}:host p.large{font-size:1.357em;line-height:calc(var(--line-height) - 4%);letter-spacing:0px}:host p.small{font-size:1em;line-height:calc(var(--line-height) - 4%);letter-spacing:.56px}:host p.xsmall{font-size:.857em;line-height:calc(var(--line-height) - 17%);letter-spacing:.72px}:host p.textoverflow-single{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:host p ::ng-deep b,:host p ::ng-deep strong,:host p ::ng-deep u{font-weight:700}:host p ::ng-deep a{font-weight:700;color:rgba(var(--cura-color-accent-700));text-underline-offset:10%}:host p ::ng-deep u{text-underline-offset:10%}:host p ::ng-deep abbr{color:rgba(var(--cura-color-accent-700));text-decoration:underline dashed 1px rgba(var(--cura-color-accent-700));text-underline-offset:10%;cursor:default}\n"] }]
74
+ }, template: "<p [class]=\"containerClasses()\">\n <ng-content></ng-content>\n</p>\n", styles: [":host{display:block;font-size:var(--cura-font-size)}:host p{font-family:var(--cura-font-body);font-size:1.143em;font-weight:500;color:var(--color-body);line-height:var(--line-height);margin-block:0px;letter-spacing:.32px}:host p.bold-weight{font-weight:700}:host p.large{font-size:1.357em;line-height:calc(var(--line-height) - 4%);letter-spacing:0px}:host p.small{font-size:1em;line-height:calc(var(--line-height) - 4%);letter-spacing:.56px}:host p.xsmall{font-size:.857em;line-height:calc(var(--line-height) - 17%);letter-spacing:.72px}:host p.textoverflow-single{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:host p ::ng-deep b,:host p ::ng-deep strong,:host p ::ng-deep u{font-weight:700}:host p ::ng-deep a{font-weight:700;color:rgba(var(--cura-color-accent-700));text-underline-offset:10%}:host p ::ng-deep u{text-underline-offset:10%}:host p ::ng-deep abbr{color:rgba(var(--cura-color-accent-700));text-decoration:underline dashed 1px rgba(var(--cura-color-accent-700));text-underline-offset:10%;cursor:default}\n"] }]
75
75
  }], propDecorators: { size: [{ type: i0.Input, args: [{ isSignal: true, alias: "size", required: false }] }], weight: [{ type: i0.Input, args: [{ isSignal: true, alias: "weight", required: false }] }], spotColor: [{ type: i0.Input, args: [{ isSignal: true, alias: "spotColor", required: false }] }], color: [{ type: i0.Input, args: [{ isSignal: true, alias: "color", required: false }] }], marginBlock: [{ type: i0.Input, args: [{ isSignal: true, alias: "marginBlock", required: false }] }], lineHeight: [{ type: i0.Input, args: [{ isSignal: true, alias: "lineHeight", required: false }] }], textOverflow: [{ type: i0.Input, args: [{ isSignal: true, alias: "textOverflow", required: false }] }] } });
76
76
 
77
77
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"rededor-site-front-end-lib-cura-forms-cura-label.mjs","sources":["../../../projects/site-front-end-lib/cura/forms/cura-label/cura-label.component.ts","../../../projects/site-front-end-lib/cura/forms/cura-label/cura-label.component.html","../../../projects/site-front-end-lib/cura/forms/cura-label/rededor-site-front-end-lib-cura-forms-cura-label.ts"],"sourcesContent":["import { Component, inject, input, computed } from '@angular/core';\r\nimport { CuraApiService } from '@rededor/site-front-end-lib/cura/api';\r\nimport { LabelSize, LabelWeight, TextOverflow } from '@rededor/site-front-end-lib/cura/forms';\r\n\r\n@Component({\r\n selector: 'cura-label',\r\n templateUrl: './cura-label.component.html',\r\n styleUrls: ['./cura-label.component.scss'],\r\n host: {\r\n '[style.--line-height]': 'lineHeight()',\r\n '[style.--color-body]': 'bodyColor()',\r\n },\r\n // '[style.--margin-block]': 'marginBlock()',\r\n // '[style.--font-weight-medium]': 'weights().medium',\r\n // '[style.--font-weight-bold]': 'weights().bold',\r\n // '[style.--font-size-base]': 'fontSizeBase()',\r\n // '[style.--font-family]': 'fontFamily()',\r\n // '[style.--color-link]': 'linkColor()',\r\n})\r\nexport class CuraLabelComponent {\r\n private curaApi = inject(CuraApiService);\r\n\r\n /**\r\n * Set size of body text.\r\n * Values: medium (default) | large | small | xsmall.\r\n */\r\n size = input<LabelSize>('medium');\r\n\r\n /**\r\n * Label font weight. It is possible to use regular HTML tags like <b> or <strong> as well.\r\n * Values: regular (default) | bold.\r\n */\r\n weight = input<LabelWeight>('regular');\r\n\r\n /**\r\n * Apply design system color to interactive elements like <a> and <abbr> inside the text.\r\n * Values: Color from design system scheme. Default to 'accent-dark'.\r\n */\r\n spotColor = input<string>('accent-dark'); // Desativado em nosso projeto, mas funcional no projeto cura.\r\n\r\n /**\r\n * Text color.\r\n * Values: Color from design system scheme. Default to the font color from the theme.\r\n */\r\n color = input<string>('');\r\n\r\n /**\r\n * CSS margin-block property values.\r\n * Default to '0'\r\n */\r\n marginBlock = input<string>('0');\r\n\r\n /**\r\n * CSS line-height property values.\r\n * Default to '125%'\r\n */\r\n lineHeight = input<string>('125%');\r\n\r\n /**\r\n * Apply text-overflow ellipsis definitions.\r\n * Default to 'none'\r\n */\r\n textOverflow = input<TextOverflow>('none');\r\n\r\n // Computed signals\r\n // weights = computed(() => this.curaApi.theme.fonts.getWeights());\r\n // fontSizeBase = computed(() => this.curaApi.theme.fonts.getSize());\r\n // fontFamily = computed(() => this.curaApi.theme.fonts.getFamily('body'));\r\n\r\n // linkColor = computed(() => {\r\n // return this.curaApi.theme.colors.getColor(this.spotColor());\r\n // });\r\n\r\n bodyColor = computed(() => {\r\n if (this.color()) {\r\n return this.curaApi.theme.colors.getColor(this.color());\r\n }\r\n return this.curaApi.theme.fonts.getColor() || this.curaApi.theme.colors.getColor('neutral-darker');\r\n });\r\n\r\n containerClasses = computed(() => {\r\n const classes = [];\r\n\r\n classes.push(this.size().toLowerCase());\r\n classes.push(`${this.weight().toLowerCase()}-weight`);\r\n\r\n if (this.textOverflow() === 'single') {\r\n classes.push('textoverflow-single');\r\n }\r\n\r\n return classes.join(' ');\r\n });\r\n}\r\n","<p [class]=\"containerClasses()\">\r\n <ng-content></ng-content>\r\n</p>\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":";;;;MAmBa,kBAAkB,CAAA;AAf/B,IAAA,WAAA,GAAA;AAgBU,QAAA,IAAA,CAAA,OAAO,GAAG,MAAM,CAAC,cAAc,CAAC;AAExC;;;AAGG;AACH,QAAA,IAAA,CAAA,IAAI,GAAG,KAAK,CAAY,QAAQ,gDAAC;AAEjC;;;AAGG;AACH,QAAA,IAAA,CAAA,MAAM,GAAG,KAAK,CAAc,SAAS,kDAAC;AAEtC;;;AAGG;AACH,QAAA,IAAA,CAAA,SAAS,GAAG,KAAK,CAAS,aAAa,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,WAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAAC,CAAC;AAEzC;;;AAGG;AACH,QAAA,IAAA,CAAA,KAAK,GAAG,KAAK,CAAS,EAAE,iDAAC;AAEzB;;;AAGG;AACH,QAAA,IAAA,CAAA,WAAW,GAAG,KAAK,CAAS,GAAG,uDAAC;AAEhC;;;AAGG;AACH,QAAA,IAAA,CAAA,UAAU,GAAG,KAAK,CAAS,MAAM,sDAAC;AAElC;;;AAGG;AACH,QAAA,IAAA,CAAA,YAAY,GAAG,KAAK,CAAe,MAAM,wDAAC;;;;;;;;AAW1C,QAAA,IAAA,CAAA,SAAS,GAAG,QAAQ,CAAC,MAAK;AACxB,YAAA,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE;AAChB,gBAAA,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YACzD;YACA,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAAC;AACpG,QAAA,CAAC,qDAAC;AAEF,QAAA,IAAA,CAAA,gBAAgB,GAAG,QAAQ,CAAC,MAAK;YAC/B,MAAM,OAAO,GAAG,EAAE;YAElB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;AACvC,YAAA,OAAO,CAAC,IAAI,CAAC,CAAA,EAAG,IAAI,CAAC,MAAM,EAAE,CAAC,WAAW,EAAE,CAAA,OAAA,CAAS,CAAC;AAErD,YAAA,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,QAAQ,EAAE;AACpC,gBAAA,OAAO,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACrC;AAEA,YAAA,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC;AAC1B,QAAA,CAAC,4DAAC;AACH,IAAA;+GAzEY,kBAAkB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;AAAlB,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,IAAA,EAAA,kBAAkB,kkCCnB/B,+EAGA,EAAA,MAAA,EAAA,CAAA,0gCAAA,CAAA,EAAA,CAAA,CAAA;;4FDgBa,kBAAkB,EAAA,UAAA,EAAA,CAAA;kBAf9B,SAAS;AACE,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,YAAY,EAAA,IAAA,EAGhB;AACJ,wBAAA,uBAAuB,EAAE,cAAc;AACvC,wBAAA,sBAAsB,EAAE,aAAa;AACtC,qBAAA,EAAA,QAAA,EAAA,+EAAA,EAAA,MAAA,EAAA,CAAA,0gCAAA,CAAA,EAAA;;;AEXH;;AAEG;;;;"}
1
+ {"version":3,"file":"rededor-site-front-end-lib-cura-forms-cura-label.mjs","sources":["../../../projects/site-front-end-lib/cura/forms/cura-label/cura-label.component.ts","../../../projects/site-front-end-lib/cura/forms/cura-label/cura-label.component.html","../../../projects/site-front-end-lib/cura/forms/cura-label/rededor-site-front-end-lib-cura-forms-cura-label.ts"],"sourcesContent":["import { Component, inject, input, computed } from '@angular/core';\nimport { CuraApiService } from '@rededor/site-front-end-lib/cura/api';\nimport { LabelSize, LabelWeight, TextOverflow } from '@rededor/site-front-end-lib/cura/forms';\n\n@Component({\n selector: 'cura-label',\n templateUrl: './cura-label.component.html',\n styleUrls: ['./cura-label.component.scss'],\n host: {\n '[style.--line-height]': 'lineHeight()',\n '[style.--color-body]': 'bodyColor()',\n },\n // '[style.--margin-block]': 'marginBlock()',\n // '[style.--font-weight-medium]': 'weights().medium',\n // '[style.--font-weight-bold]': 'weights().bold',\n // '[style.--font-size-base]': 'fontSizeBase()',\n // '[style.--font-family]': 'fontFamily()',\n // '[style.--color-link]': 'linkColor()',\n})\nexport class CuraLabelComponent {\n private curaApi = inject(CuraApiService);\n\n /**\n * Set size of body text.\n * Values: medium (default) | large | small | xsmall.\n */\n size = input<LabelSize>('medium');\n\n /**\n * Label font weight. It is possible to use regular HTML tags like <b> or <strong> as well.\n * Values: regular (default) | bold.\n */\n weight = input<LabelWeight>('regular');\n\n /**\n * Apply design system color to interactive elements like <a> and <abbr> inside the text.\n * Values: Color from design system scheme. Default to 'accent-dark'.\n */\n spotColor = input<string>('accent-dark'); // Desativado em nosso projeto, mas funcional no projeto cura.\n\n /**\n * Text color.\n * Values: Color from design system scheme. Default to the font color from the theme.\n */\n color = input<string>('');\n\n /**\n * CSS margin-block property values.\n * Default to '0'\n */\n marginBlock = input<string>('0');\n\n /**\n * CSS line-height property values.\n * Default to '125%'\n */\n lineHeight = input<string>('125%');\n\n /**\n * Apply text-overflow ellipsis definitions.\n * Default to 'none'\n */\n textOverflow = input<TextOverflow>('none');\n\n // Computed signals\n // weights = computed(() => this.curaApi.theme.fonts.getWeights());\n // fontSizeBase = computed(() => this.curaApi.theme.fonts.getSize());\n // fontFamily = computed(() => this.curaApi.theme.fonts.getFamily('body'));\n\n // linkColor = computed(() => {\n // return this.curaApi.theme.colors.getColor(this.spotColor());\n // });\n\n bodyColor = computed(() => {\n if (this.color()) {\n return this.curaApi.theme.colors.getColor(this.color());\n }\n return this.curaApi.theme.fonts.getColor() || this.curaApi.theme.colors.getColor('neutral-darker');\n });\n\n containerClasses = computed(() => {\n const classes = [];\n\n classes.push(this.size().toLowerCase());\n classes.push(`${this.weight().toLowerCase()}-weight`);\n\n if (this.textOverflow() === 'single') {\n classes.push('textoverflow-single');\n }\n\n return classes.join(' ');\n });\n}\n","<p [class]=\"containerClasses()\">\n <ng-content></ng-content>\n</p>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":";;;;MAmBa,kBAAkB,CAAA;AAf/B,IAAA,WAAA,GAAA;AAgBU,QAAA,IAAA,CAAA,OAAO,GAAG,MAAM,CAAC,cAAc,CAAC;AAExC;;;AAGG;AACH,QAAA,IAAA,CAAA,IAAI,GAAG,KAAK,CAAY,QAAQ,gDAAC;AAEjC;;;AAGG;AACH,QAAA,IAAA,CAAA,MAAM,GAAG,KAAK,CAAc,SAAS,kDAAC;AAEtC;;;AAGG;AACH,QAAA,IAAA,CAAA,SAAS,GAAG,KAAK,CAAS,aAAa,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,WAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAAC,CAAC;AAEzC;;;AAGG;AACH,QAAA,IAAA,CAAA,KAAK,GAAG,KAAK,CAAS,EAAE,iDAAC;AAEzB;;;AAGG;AACH,QAAA,IAAA,CAAA,WAAW,GAAG,KAAK,CAAS,GAAG,uDAAC;AAEhC;;;AAGG;AACH,QAAA,IAAA,CAAA,UAAU,GAAG,KAAK,CAAS,MAAM,sDAAC;AAElC;;;AAGG;AACH,QAAA,IAAA,CAAA,YAAY,GAAG,KAAK,CAAe,MAAM,wDAAC;;;;;;;;AAW1C,QAAA,IAAA,CAAA,SAAS,GAAG,QAAQ,CAAC,MAAK;AACxB,YAAA,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE;AAChB,gBAAA,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YACzD;YACA,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAAC;AACpG,QAAA,CAAC,qDAAC;AAEF,QAAA,IAAA,CAAA,gBAAgB,GAAG,QAAQ,CAAC,MAAK;YAC/B,MAAM,OAAO,GAAG,EAAE;YAElB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;AACvC,YAAA,OAAO,CAAC,IAAI,CAAC,CAAA,EAAG,IAAI,CAAC,MAAM,EAAE,CAAC,WAAW,EAAE,CAAA,OAAA,CAAS,CAAC;AAErD,YAAA,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,QAAQ,EAAE;AACpC,gBAAA,OAAO,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACrC;AAEA,YAAA,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC;AAC1B,QAAA,CAAC,4DAAC;AACH,IAAA;+GAzEY,kBAAkB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;AAAlB,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,IAAA,EAAA,kBAAkB,kkCCnB/B,yEAGA,EAAA,MAAA,EAAA,CAAA,0gCAAA,CAAA,EAAA,CAAA,CAAA;;4FDgBa,kBAAkB,EAAA,UAAA,EAAA,CAAA;kBAf9B,SAAS;AACE,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,YAAY,EAAA,IAAA,EAGhB;AACJ,wBAAA,uBAAuB,EAAE,cAAc;AACvC,wBAAA,sBAAsB,EAAE,aAAa;AACtC,qBAAA,EAAA,QAAA,EAAA,yEAAA,EAAA,MAAA,EAAA,CAAA,0gCAAA,CAAA,EAAA;;;AEXH;;AAEG;;;;"}
@@ -203,16 +203,16 @@ class CuraRadioComponent {
203
203
  this.onTouched();
204
204
  this.onchange.emit({ value: this.value(), checked: newCheckedState });
205
205
  }
206
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CuraRadioComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
207
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.15", type: CuraRadioComponent, isStandalone: true, selector: "cura-radio", inputs: { checked: { classPropertyName: "checked", publicName: "checked", isSignal: true, isRequired: false, transformFunction: null }, status: { classPropertyName: "status", publicName: "status", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, ontabindex: { classPropertyName: "ontabindex", publicName: "ontabindex", isSignal: true, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "position", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, background: { classPropertyName: "background", publicName: "background", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, overflowLabel: { classPropertyName: "overflowLabel", publicName: "overflowLabel", isSignal: true, isRequired: false, transformFunction: null }, overflowHelper: { classPropertyName: "overflowHelper", publicName: "overflowHelper", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { checked: "checkedChange", value: "valueChange", onchange: "onchange" }, host: { attributes: { "role": "radio" }, properties: { "attr.aria-checked": "checked()", "attr.aria-disabled": "disabled()", "attr.aria-required": "required()", "attr.aria-invalid": "status() === \"error\"" } }, providers: [
206
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: CuraRadioComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
207
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.16", type: CuraRadioComponent, isStandalone: true, selector: "cura-radio", inputs: { checked: { classPropertyName: "checked", publicName: "checked", isSignal: true, isRequired: false, transformFunction: null }, status: { classPropertyName: "status", publicName: "status", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, ontabindex: { classPropertyName: "ontabindex", publicName: "ontabindex", isSignal: true, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "position", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, background: { classPropertyName: "background", publicName: "background", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, overflowLabel: { classPropertyName: "overflowLabel", publicName: "overflowLabel", isSignal: true, isRequired: false, transformFunction: null }, overflowHelper: { classPropertyName: "overflowHelper", publicName: "overflowHelper", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { checked: "checkedChange", value: "valueChange", onchange: "onchange" }, host: { attributes: { "role": "radio" }, properties: { "attr.aria-checked": "checked()", "attr.aria-disabled": "disabled()", "attr.aria-required": "required()", "attr.aria-invalid": "status() === \"error\"" } }, providers: [
208
208
  {
209
209
  provide: NG_VALUE_ACCESSOR,
210
210
  useExisting: forwardRef(() => CuraRadioComponent),
211
211
  multi: true,
212
212
  },
213
- ], ngImport: i0, template: "<div [class]=\"containerClasses()\" [style]=\"styles()\" (click)=\"handleClick()\">\r\n <div class=\"info\">\r\n <div class=\"label-wrapper\">\r\n <cura-label [textOverflow]=\"overflowLabel()\" [class]=\"labelClasses()\" [size]=\"labelSize()\" [color]=\"labelColor()\">\r\n {{ label() }}\r\n </cura-label>\r\n\r\n @if (required()) {\r\n <cura-paragraph lineHeight=\"0%\" marginBlock=\"0\" color=\"error-base\"> * </cura-paragraph>\r\n }\r\n </div>\r\n\r\n <cura-label [textOverflow]=\"overflowHelper()\" [color]=\"messageColor()\" size=\"xsmall\" [class]=\"messageClasses()\">\r\n <ng-content></ng-content>\r\n </cura-label>\r\n </div>\r\n\r\n <input\r\n type=\"radio\"\r\n [class]=\"'radio ' + size().toLowerCase()\"\r\n [name]=\"name()\"\r\n [value]=\"value()\"\r\n [required]=\"required()\"\r\n [tabIndex]=\"ontabindex()\"\r\n [disabled]=\"disabled()\"\r\n [checked]=\"checked()\"\r\n />\r\n</div>\r\n", styles: ["@charset \"UTF-8\";:host{display:block;box-sizing:border-box;min-width:0}:host .container{display:flex;align-items:center;flex-direction:row-reverse;justify-content:start;gap:var(--gap);cursor:pointer}:host .position.container{flex-direction:row}:host .position .label-wrapper{justify-content:end}:host .position .message{text-align:right}:host .position .label{order:1}:host .info{display:flex;flex-direction:column;overflow:hidden}:host .label-wrapper{display:flex;justify-content:start;align-items:center;gap:5px}:host .control{width:fit-content;cursor:pointer;position:relative}:host .radio{margin:0;appearance:none;-webkit-appearance:none;-moz-appearance:none;border-radius:50%;border:2px solid var(--primary-base-neutral-medium);background:var(--neutral-purewhite);box-sizing:border-box;transition:border-color .3s;position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;width:var(--size);height:var(--size);flex:0 0 var(--size)}:host .radio:after{content:\"\";background:var(--color-base-light);border-radius:50%;opacity:0;transition:opacity .3s;width:var(--size-after);height:var(--size-after)}:host .radio:focus{border-color:var(--info-base)!important}:host .success .radio{border-color:var(--success-base);background:var(--success-lighter)}:host .success .radio:hover{border-color:var(--success-base)!important}:host .success.checked .radio{border-color:var(--success-base)}:host .success.checked .radio:after{background:var(--success-base)}:host .success.checked .radio:hover{background:var(--success-lighter)!important;border-color:var(--success-base)!important}:host .success.checked .radio:hover:after{background:var(--success-base)!important}:host .error .radio{border-color:var(--error-base);background:var(--error-lighter)}:host .error .radio:hover{border-color:var(--error-base)!important}:host .error.checked .radio{border-color:var(--error-base)}:host .error.checked .radio:after{background:var(--error-base)}:host .error.checked .radio:hover{background:var(--error-lighter)!important;border-color:var(--error-base)!important}:host .error.checked .radio:hover:after{background:var(--error-base)!important}:host .checked .radio:after{opacity:1;background:var(--color-base)}:host .checked .radio{border-color:var(--color-dark)}:host .checked .radio:hover{border-color:var(--color-light)!important}:host .checked .radio:hover:after{background:var(--color-light)}:host .disabled .radio{background:var(--primary-base-neutral-white);border-color:var(--primary-darker-neutral-base);cursor:not-allowed}:host .disabled .radio:after{background:var(--neutral-lighter)}:host .disabled.checked .radio{border-color:var(--primary-base-neutral-base)!important;background:var(--primary-darker-neutral-white)!important}:host .disabled.checked .radio:after{background:var(--primary-base-neutral-base)!important}:host .label.textoverflow-single{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%}:host .message.textoverflow-single{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%}:host :not(.disabled):not(.checked) .radio:hover{border-color:var(--primary-base-neutral-dark)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: CuraLabelComponent, selector: "cura-label", inputs: ["size", "weight", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }, { kind: "component", type: CuraParagraphComponent, selector: "cura-paragraph", inputs: ["size", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }] }); }
213
+ ], ngImport: i0, template: "<div [class]=\"containerClasses()\" [style]=\"styles()\" (click)=\"handleClick()\">\n <div class=\"info\">\n <div class=\"label-wrapper\">\n <cura-label [textOverflow]=\"overflowLabel()\" [class]=\"labelClasses()\" [size]=\"labelSize()\" [color]=\"labelColor()\">\n {{ label() }}\n </cura-label>\n\n @if (required()) {\n <cura-paragraph lineHeight=\"0%\" marginBlock=\"0\" color=\"error-base\"> * </cura-paragraph>\n }\n </div>\n\n <cura-label [textOverflow]=\"overflowHelper()\" [color]=\"messageColor()\" size=\"xsmall\" [class]=\"messageClasses()\">\n <ng-content></ng-content>\n </cura-label>\n </div>\n\n <input\n type=\"radio\"\n [class]=\"'radio ' + size().toLowerCase()\"\n [name]=\"name()\"\n [value]=\"value()\"\n [required]=\"required()\"\n [tabIndex]=\"ontabindex()\"\n [disabled]=\"disabled()\"\n [checked]=\"checked()\"\n />\n</div>\n", styles: ["@charset \"UTF-8\";:host{display:block;box-sizing:border-box;min-width:0}:host .container{display:flex;align-items:center;flex-direction:row-reverse;justify-content:start;gap:var(--gap);cursor:pointer}:host .position.container{flex-direction:row}:host .position .label-wrapper{justify-content:end}:host .position .message{text-align:right}:host .position .label{order:1}:host .info{display:flex;flex-direction:column;overflow:hidden}:host .label-wrapper{display:flex;justify-content:start;align-items:center;gap:5px}:host .control{width:fit-content;cursor:pointer;position:relative}:host .radio{margin:0;appearance:none;-webkit-appearance:none;-moz-appearance:none;border-radius:50%;border:2px solid var(--primary-base-neutral-medium);background:var(--neutral-purewhite);box-sizing:border-box;transition:border-color .3s;position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;width:var(--size);height:var(--size);flex:0 0 var(--size)}:host .radio:after{content:\"\";background:var(--color-base-light);border-radius:50%;opacity:0;transition:opacity .3s;width:var(--size-after);height:var(--size-after)}:host .radio:focus{border-color:var(--info-base)!important}:host .success .radio{border-color:var(--success-base);background:var(--success-lighter)}:host .success .radio:hover{border-color:var(--success-base)!important}:host .success.checked .radio{border-color:var(--success-base)}:host .success.checked .radio:after{background:var(--success-base)}:host .success.checked .radio:hover{background:var(--success-lighter)!important;border-color:var(--success-base)!important}:host .success.checked .radio:hover:after{background:var(--success-base)!important}:host .error .radio{border-color:var(--error-base);background:var(--error-lighter)}:host .error .radio:hover{border-color:var(--error-base)!important}:host .error.checked .radio{border-color:var(--error-base)}:host .error.checked .radio:after{background:var(--error-base)}:host .error.checked .radio:hover{background:var(--error-lighter)!important;border-color:var(--error-base)!important}:host .error.checked .radio:hover:after{background:var(--error-base)!important}:host .checked .radio:after{opacity:1;background:var(--color-base)}:host .checked .radio{border-color:var(--color-dark)}:host .checked .radio:hover{border-color:var(--color-light)!important}:host .checked .radio:hover:after{background:var(--color-light)}:host .disabled .radio{background:var(--primary-base-neutral-white);border-color:var(--primary-darker-neutral-base);cursor:not-allowed}:host .disabled .radio:after{background:var(--neutral-lighter)}:host .disabled.checked .radio{border-color:var(--primary-base-neutral-base)!important;background:var(--primary-darker-neutral-white)!important}:host .disabled.checked .radio:after{background:var(--primary-base-neutral-base)!important}:host .label.textoverflow-single{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%}:host .message.textoverflow-single{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%}:host :not(.disabled):not(.checked) .radio:hover{border-color:var(--primary-base-neutral-dark)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: CuraLabelComponent, selector: "cura-label", inputs: ["size", "weight", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }, { kind: "component", type: CuraParagraphComponent, selector: "cura-paragraph", inputs: ["size", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }] }); }
214
214
  }
215
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CuraRadioComponent, decorators: [{
215
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: CuraRadioComponent, decorators: [{
216
216
  type: Component,
217
217
  args: [{ selector: 'cura-radio', imports: [CommonModule, CuraLabelComponent, CuraParagraphComponent], host: {
218
218
  role: 'radio',
@@ -226,7 +226,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImpo
226
226
  useExisting: forwardRef(() => CuraRadioComponent),
227
227
  multi: true,
228
228
  },
229
- ], template: "<div [class]=\"containerClasses()\" [style]=\"styles()\" (click)=\"handleClick()\">\r\n <div class=\"info\">\r\n <div class=\"label-wrapper\">\r\n <cura-label [textOverflow]=\"overflowLabel()\" [class]=\"labelClasses()\" [size]=\"labelSize()\" [color]=\"labelColor()\">\r\n {{ label() }}\r\n </cura-label>\r\n\r\n @if (required()) {\r\n <cura-paragraph lineHeight=\"0%\" marginBlock=\"0\" color=\"error-base\"> * </cura-paragraph>\r\n }\r\n </div>\r\n\r\n <cura-label [textOverflow]=\"overflowHelper()\" [color]=\"messageColor()\" size=\"xsmall\" [class]=\"messageClasses()\">\r\n <ng-content></ng-content>\r\n </cura-label>\r\n </div>\r\n\r\n <input\r\n type=\"radio\"\r\n [class]=\"'radio ' + size().toLowerCase()\"\r\n [name]=\"name()\"\r\n [value]=\"value()\"\r\n [required]=\"required()\"\r\n [tabIndex]=\"ontabindex()\"\r\n [disabled]=\"disabled()\"\r\n [checked]=\"checked()\"\r\n />\r\n</div>\r\n", styles: ["@charset \"UTF-8\";:host{display:block;box-sizing:border-box;min-width:0}:host .container{display:flex;align-items:center;flex-direction:row-reverse;justify-content:start;gap:var(--gap);cursor:pointer}:host .position.container{flex-direction:row}:host .position .label-wrapper{justify-content:end}:host .position .message{text-align:right}:host .position .label{order:1}:host .info{display:flex;flex-direction:column;overflow:hidden}:host .label-wrapper{display:flex;justify-content:start;align-items:center;gap:5px}:host .control{width:fit-content;cursor:pointer;position:relative}:host .radio{margin:0;appearance:none;-webkit-appearance:none;-moz-appearance:none;border-radius:50%;border:2px solid var(--primary-base-neutral-medium);background:var(--neutral-purewhite);box-sizing:border-box;transition:border-color .3s;position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;width:var(--size);height:var(--size);flex:0 0 var(--size)}:host .radio:after{content:\"\";background:var(--color-base-light);border-radius:50%;opacity:0;transition:opacity .3s;width:var(--size-after);height:var(--size-after)}:host .radio:focus{border-color:var(--info-base)!important}:host .success .radio{border-color:var(--success-base);background:var(--success-lighter)}:host .success .radio:hover{border-color:var(--success-base)!important}:host .success.checked .radio{border-color:var(--success-base)}:host .success.checked .radio:after{background:var(--success-base)}:host .success.checked .radio:hover{background:var(--success-lighter)!important;border-color:var(--success-base)!important}:host .success.checked .radio:hover:after{background:var(--success-base)!important}:host .error .radio{border-color:var(--error-base);background:var(--error-lighter)}:host .error .radio:hover{border-color:var(--error-base)!important}:host .error.checked .radio{border-color:var(--error-base)}:host .error.checked .radio:after{background:var(--error-base)}:host .error.checked .radio:hover{background:var(--error-lighter)!important;border-color:var(--error-base)!important}:host .error.checked .radio:hover:after{background:var(--error-base)!important}:host .checked .radio:after{opacity:1;background:var(--color-base)}:host .checked .radio{border-color:var(--color-dark)}:host .checked .radio:hover{border-color:var(--color-light)!important}:host .checked .radio:hover:after{background:var(--color-light)}:host .disabled .radio{background:var(--primary-base-neutral-white);border-color:var(--primary-darker-neutral-base);cursor:not-allowed}:host .disabled .radio:after{background:var(--neutral-lighter)}:host .disabled.checked .radio{border-color:var(--primary-base-neutral-base)!important;background:var(--primary-darker-neutral-white)!important}:host .disabled.checked .radio:after{background:var(--primary-base-neutral-base)!important}:host .label.textoverflow-single{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%}:host .message.textoverflow-single{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%}:host :not(.disabled):not(.checked) .radio:hover{border-color:var(--primary-base-neutral-dark)}\n"] }]
229
+ ], template: "<div [class]=\"containerClasses()\" [style]=\"styles()\" (click)=\"handleClick()\">\n <div class=\"info\">\n <div class=\"label-wrapper\">\n <cura-label [textOverflow]=\"overflowLabel()\" [class]=\"labelClasses()\" [size]=\"labelSize()\" [color]=\"labelColor()\">\n {{ label() }}\n </cura-label>\n\n @if (required()) {\n <cura-paragraph lineHeight=\"0%\" marginBlock=\"0\" color=\"error-base\"> * </cura-paragraph>\n }\n </div>\n\n <cura-label [textOverflow]=\"overflowHelper()\" [color]=\"messageColor()\" size=\"xsmall\" [class]=\"messageClasses()\">\n <ng-content></ng-content>\n </cura-label>\n </div>\n\n <input\n type=\"radio\"\n [class]=\"'radio ' + size().toLowerCase()\"\n [name]=\"name()\"\n [value]=\"value()\"\n [required]=\"required()\"\n [tabIndex]=\"ontabindex()\"\n [disabled]=\"disabled()\"\n [checked]=\"checked()\"\n />\n</div>\n", styles: ["@charset \"UTF-8\";:host{display:block;box-sizing:border-box;min-width:0}:host .container{display:flex;align-items:center;flex-direction:row-reverse;justify-content:start;gap:var(--gap);cursor:pointer}:host .position.container{flex-direction:row}:host .position .label-wrapper{justify-content:end}:host .position .message{text-align:right}:host .position .label{order:1}:host .info{display:flex;flex-direction:column;overflow:hidden}:host .label-wrapper{display:flex;justify-content:start;align-items:center;gap:5px}:host .control{width:fit-content;cursor:pointer;position:relative}:host .radio{margin:0;appearance:none;-webkit-appearance:none;-moz-appearance:none;border-radius:50%;border:2px solid var(--primary-base-neutral-medium);background:var(--neutral-purewhite);box-sizing:border-box;transition:border-color .3s;position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;width:var(--size);height:var(--size);flex:0 0 var(--size)}:host .radio:after{content:\"\";background:var(--color-base-light);border-radius:50%;opacity:0;transition:opacity .3s;width:var(--size-after);height:var(--size-after)}:host .radio:focus{border-color:var(--info-base)!important}:host .success .radio{border-color:var(--success-base);background:var(--success-lighter)}:host .success .radio:hover{border-color:var(--success-base)!important}:host .success.checked .radio{border-color:var(--success-base)}:host .success.checked .radio:after{background:var(--success-base)}:host .success.checked .radio:hover{background:var(--success-lighter)!important;border-color:var(--success-base)!important}:host .success.checked .radio:hover:after{background:var(--success-base)!important}:host .error .radio{border-color:var(--error-base);background:var(--error-lighter)}:host .error .radio:hover{border-color:var(--error-base)!important}:host .error.checked .radio{border-color:var(--error-base)}:host .error.checked .radio:after{background:var(--error-base)}:host .error.checked .radio:hover{background:var(--error-lighter)!important;border-color:var(--error-base)!important}:host .error.checked .radio:hover:after{background:var(--error-base)!important}:host .checked .radio:after{opacity:1;background:var(--color-base)}:host .checked .radio{border-color:var(--color-dark)}:host .checked .radio:hover{border-color:var(--color-light)!important}:host .checked .radio:hover:after{background:var(--color-light)}:host .disabled .radio{background:var(--primary-base-neutral-white);border-color:var(--primary-darker-neutral-base);cursor:not-allowed}:host .disabled .radio:after{background:var(--neutral-lighter)}:host .disabled.checked .radio{border-color:var(--primary-base-neutral-base)!important;background:var(--primary-darker-neutral-white)!important}:host .disabled.checked .radio:after{background:var(--primary-base-neutral-base)!important}:host .label.textoverflow-single{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%}:host .message.textoverflow-single{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%}:host :not(.disabled):not(.checked) .radio:hover{border-color:var(--primary-base-neutral-dark)}\n"] }]
230
230
  }], propDecorators: { checked: [{ type: i0.Input, args: [{ isSignal: true, alias: "checked", required: false }] }, { type: i0.Output, args: ["checkedChange"] }], status: [{ type: i0.Input, args: [{ isSignal: true, alias: "status", required: false }] }], disabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "disabled", required: false }] }], required: [{ type: i0.Input, args: [{ isSignal: true, alias: "required", required: false }] }], label: [{ type: i0.Input, args: [{ isSignal: true, alias: "label", required: false }] }], ontabindex: [{ type: i0.Input, args: [{ isSignal: true, alias: "ontabindex", required: false }] }], position: [{ type: i0.Input, args: [{ isSignal: true, alias: "position", required: false }] }], value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: false }] }, { type: i0.Output, args: ["valueChange"] }], name: [{ type: i0.Input, args: [{ isSignal: true, alias: "name", required: false }] }], background: [{ type: i0.Input, args: [{ isSignal: true, alias: "background", required: false }] }], size: [{ type: i0.Input, args: [{ isSignal: true, alias: "size", required: false }] }], color: [{ type: i0.Input, args: [{ isSignal: true, alias: "color", required: false }] }], overflowLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "overflowLabel", required: false }] }], overflowHelper: [{ type: i0.Input, args: [{ isSignal: true, alias: "overflowHelper", required: false }] }], onchange: [{ type: i0.Output, args: ["onchange"] }] } });
231
231
 
232
232
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"rededor-site-front-end-lib-cura-forms-cura-radio.mjs","sources":["../../../projects/site-front-end-lib/cura/forms/cura-radio/cura-radio.component.ts","../../../projects/site-front-end-lib/cura/forms/cura-radio/cura-radio.component.html","../../../projects/site-front-end-lib/cura/forms/cura-radio/rededor-site-front-end-lib-cura-forms-cura-radio.ts"],"sourcesContent":["import { Component, input, output, inject, computed, forwardRef, model } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { CuraApiService } from '@rededor/site-front-end-lib/cura/api';\r\nimport { CuraLabelComponent } from '@rededor/site-front-end-lib/cura/forms/cura-label';\r\nimport { CuraParagraphComponent } from '@rededor/site-front-end-lib/cura/texts/cura-paragraph';\r\nimport { formsSizes, TextOverflow } from '@rededor/site-front-end-lib/cura/forms';\r\nimport { RadioSize, RadioPosition, RadioBackground, RadioStatus, RadioChangeEvent } from './cura-radio.definitions';\r\n\r\n@Component({\r\n selector: 'cura-radio',\r\n imports: [CommonModule, CuraLabelComponent, CuraParagraphComponent],\r\n templateUrl: './cura-radio.component.html',\r\n styleUrls: ['./cura-radio.component.scss'],\r\n host: {\r\n role: 'radio',\r\n '[attr.aria-checked]': 'checked()',\r\n '[attr.aria-disabled]': 'disabled()',\r\n '[attr.aria-required]': 'required()',\r\n '[attr.aria-invalid]': 'status() === \"error\"',\r\n },\r\n providers: [\r\n {\r\n provide: NG_VALUE_ACCESSOR,\r\n useExisting: forwardRef(() => CuraRadioComponent),\r\n multi: true,\r\n },\r\n ],\r\n})\r\nexport class CuraRadioComponent implements ControlValueAccessor {\r\n private curaApi: CuraApiService = inject(CuraApiService);\r\n\r\n /**\r\n * Reflects the checked state of the radio button.\r\n */\r\n checked = model<boolean>(false);\r\n\r\n /**\r\n * Status of the radio button.\r\n */\r\n status = input<RadioStatus>('default');\r\n\r\n /**\r\n * Reflects the disabled state of the radio button.\r\n */\r\n disabled = input<boolean>(false);\r\n\r\n /**\r\n * Reflects the required state of the radio button.\r\n */\r\n required = input<boolean>(false);\r\n\r\n /**\r\n * Text label associated with the radio button.\r\n */\r\n label = input<string>('');\r\n\r\n /**\r\n * Specifies the tabindex of the radio button.\r\n */\r\n ontabindex = input<number>(0);\r\n\r\n /**\r\n * Position of the label relative to the radio button.\r\n */\r\n position = input<RadioPosition>('left');\r\n\r\n /**\r\n * Value associated with the radio button.\r\n */\r\n value = model<string>('');\r\n\r\n /**\r\n * Name attribute of the radio button.\r\n */\r\n name = input<string>('');\r\n\r\n /**\r\n * Background theme of the radio button.\r\n */\r\n background = input<RadioBackground>('light');\r\n\r\n /**\r\n * Size of the radio button.\r\n */\r\n size = input<RadioSize>('medium');\r\n\r\n /**\r\n * Color theme of the radio button.\r\n */\r\n color = input<string>('accent');\r\n\r\n /**\r\n * Controls how the label text should handle overflow.\r\n * - `'none'`: No overflow handling; the label displays normally.\r\n * - `'single'`: The label will be truncated with an ellipsis if it overflows a single line.\r\n * - `string`: Custom overflow handling mode.\r\n *\r\n * @default 'none'\r\n */\r\n overflowLabel = input<TextOverflow>('none');\r\n\r\n /**\r\n * Controls how the helper text should handle overflow.\r\n * - `'none'`: No overflow handling; the label displays normally.\r\n * - `'single'`: The label will be truncated with an ellipsis if it overflows a single line.\r\n * - `string`: Custom overflow handling mode.\r\n *\r\n * @default 'none'\r\n */\r\n overflowHelper = input<TextOverflow>('none');\r\n\r\n /**\r\n * Change event emitter\r\n */\r\n onchange = output<RadioChangeEvent>();\r\n\r\n // Form control callbacks\r\n private onChange = (value: string) => {};\r\n private onTouched = () => {};\r\n\r\n private sizes = {\r\n large: { size: 20 },\r\n medium: { size: 14 },\r\n small: { size: 10 },\r\n };\r\n\r\n // Computed signals\r\n private colorConfig = computed(() => {\r\n if (this.disabled()) {\r\n return {\r\n label: this.isDarkBackground() ? 'primary-darker' : 'neutral-medium',\r\n message: this.isDarkBackground() ? 'primary-darker' : 'neutral-medium',\r\n };\r\n }\r\n\r\n const darkBackground = this.isDarkBackground();\r\n const statusColors = {\r\n success: {\r\n label: darkBackground ? 'success-lighter' : 'success-darker',\r\n message: darkBackground ? 'success-base' : 'success-dark',\r\n },\r\n error: {\r\n label: darkBackground ? 'error-lighter' : 'neutral-darker',\r\n message: darkBackground ? 'error-base' : 'error-dark',\r\n },\r\n default: {\r\n label: darkBackground ? 'neutral-white' : 'neutral-black',\r\n message: darkBackground ? 'primary-lighter' : 'neutral-dark',\r\n },\r\n };\r\n\r\n return statusColors[this.status()];\r\n });\r\n\r\n labelColor = computed(() => this.colorConfig().label);\r\n messageColor = computed(() => this.colorConfig().message);\r\n labelSize = computed(() => (this.size() === 'large' ? 'medium' : 'xsmall'));\r\n labelClasses = computed(() => {\r\n const classes = ['label'];\r\n if (this.overflowLabel() === 'single') {\r\n classes.push('textoverflow-single');\r\n }\r\n return classes.join(' ');\r\n });\r\n messageClasses = computed(() => {\r\n const classes = ['message'];\r\n if (this.overflowHelper() === 'single') {\r\n classes.push('textoverflow-single');\r\n }\r\n return classes.join(' ');\r\n });\r\n containerClasses = computed(() => {\r\n const classes = ['container'];\r\n if (this.checked()) classes.push('checked');\r\n if (this.disabled()) classes.push('disabled');\r\n if (this.position() === 'right') classes.push('position');\r\n classes.push(this.status());\r\n return classes.join(' ');\r\n });\r\n\r\n // Computed signal para styles\r\n styles = computed(() => {\r\n const sizeConfig = this.sizes[this.size()];\r\n const formsSize = formsSizes[this.size()];\r\n\r\n const sizeStyles = {\r\n '--size-after': `${sizeConfig.size}px`,\r\n '--size': `${formsSize.size}px`,\r\n '--gap': `${formsSize.gap}px`,\r\n };\r\n\r\n const darkBackground = this.isDarkBackground();\r\n const colorValue = this.color();\r\n\r\n const colors = [\r\n { name: '--info-base', background: 'info-base' },\r\n { name: '--color-light', background: `${colorValue}-light` },\r\n { name: '--color-base', background: `${colorValue}-base` },\r\n { name: '--color-dark', background: `${colorValue}-dark` },\r\n { name: '--neutral-purewhite', background: 'neutral-purewhite' },\r\n { name: '--success-lighter', background: 'success-lighter' },\r\n { name: '--success-base', background: 'success-base' },\r\n { name: '--error-lighter', background: 'error-lighter' },\r\n { name: '--error-base', background: 'error-base' },\r\n { name: '--primary-base-neutral-medium', background: darkBackground ? 'primary-base' : 'neutral-medium' },\r\n { name: '--primary-base-neutral-white', background: darkBackground ? 'primary-base' : 'neutral-white' },\r\n { name: '--primary-darker-neutral-white', background: darkBackground ? 'primary-darker' : 'neutral-white' },\r\n { name: '--primary-darker-neutral-base', background: darkBackground ? 'primary-darker' : 'neutral-base' },\r\n { name: '--primary-base-neutral-base', background: darkBackground ? 'primary-base' : 'neutral-base' },\r\n { name: '--primary-base-neutral-dark', background: darkBackground ? 'primary-base' : 'neutral-dark' },\r\n { name: '--primary-base-neutral-medium', background: darkBackground ? 'primary-base' : 'neutral-medium' },\r\n { name: '--success-base-dark', background: darkBackground ? 'success-base' : 'success-dark' },\r\n { name: '--error-base-dark', background: darkBackground ? 'error-base' : 'error-dark' },\r\n ];\r\n\r\n const colorStyles: { [key: string]: string } = {};\r\n colors.forEach((color) => {\r\n if (this.curaApi) {\r\n colorStyles[color.name] = this.curaApi.theme.colors.getColor(color.background);\r\n }\r\n });\r\n\r\n return { ...sizeStyles, ...colorStyles };\r\n });\r\n\r\n // ControlValueAccessor implementation\r\n writeValue(value: string): void {\r\n this.checked.set(value === this.value());\r\n }\r\n\r\n registerOnChange(fn: (value: string) => void): void {\r\n this.onChange = fn;\r\n }\r\n\r\n registerOnTouched(fn: () => void): void {\r\n this.onTouched = fn;\r\n }\r\n\r\n private isDarkBackground(): boolean {\r\n return this.background() === 'dark';\r\n }\r\n\r\n handleClick(): void {\r\n if (this.disabled()) return;\r\n\r\n const newCheckedState = !this.checked();\r\n this.checked.set(newCheckedState);\r\n\r\n this.onChange(newCheckedState ? this.value() : '');\r\n this.onTouched();\r\n\r\n this.onchange.emit({ value: this.value(), checked: newCheckedState });\r\n }\r\n}\r\n","<div [class]=\"containerClasses()\" [style]=\"styles()\" (click)=\"handleClick()\">\r\n <div class=\"info\">\r\n <div class=\"label-wrapper\">\r\n <cura-label [textOverflow]=\"overflowLabel()\" [class]=\"labelClasses()\" [size]=\"labelSize()\" [color]=\"labelColor()\">\r\n {{ label() }}\r\n </cura-label>\r\n\r\n @if (required()) {\r\n <cura-paragraph lineHeight=\"0%\" marginBlock=\"0\" color=\"error-base\"> * </cura-paragraph>\r\n }\r\n </div>\r\n\r\n <cura-label [textOverflow]=\"overflowHelper()\" [color]=\"messageColor()\" size=\"xsmall\" [class]=\"messageClasses()\">\r\n <ng-content></ng-content>\r\n </cura-label>\r\n </div>\r\n\r\n <input\r\n type=\"radio\"\r\n [class]=\"'radio ' + size().toLowerCase()\"\r\n [name]=\"name()\"\r\n [value]=\"value()\"\r\n [required]=\"required()\"\r\n [tabIndex]=\"ontabindex()\"\r\n [disabled]=\"disabled()\"\r\n [checked]=\"checked()\"\r\n />\r\n</div>\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"rededor-site-front-end-lib-cura-forms-cura-radio.mjs","sources":["../../../projects/site-front-end-lib/cura/forms/cura-radio/cura-radio.component.ts","../../../projects/site-front-end-lib/cura/forms/cura-radio/cura-radio.component.html","../../../projects/site-front-end-lib/cura/forms/cura-radio/rededor-site-front-end-lib-cura-forms-cura-radio.ts"],"sourcesContent":["import { Component, input, output, inject, computed, forwardRef, model } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { CuraApiService } from '@rededor/site-front-end-lib/cura/api';\nimport { CuraLabelComponent } from '@rededor/site-front-end-lib/cura/forms/cura-label';\nimport { CuraParagraphComponent } from '@rededor/site-front-end-lib/cura/texts/cura-paragraph';\nimport { formsSizes, TextOverflow } from '@rededor/site-front-end-lib/cura/forms';\nimport { RadioSize, RadioPosition, RadioBackground, RadioStatus, RadioChangeEvent } from './cura-radio.definitions';\n\n@Component({\n selector: 'cura-radio',\n imports: [CommonModule, CuraLabelComponent, CuraParagraphComponent],\n templateUrl: './cura-radio.component.html',\n styleUrls: ['./cura-radio.component.scss'],\n host: {\n role: 'radio',\n '[attr.aria-checked]': 'checked()',\n '[attr.aria-disabled]': 'disabled()',\n '[attr.aria-required]': 'required()',\n '[attr.aria-invalid]': 'status() === \"error\"',\n },\n providers: [\n {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(() => CuraRadioComponent),\n multi: true,\n },\n ],\n})\nexport class CuraRadioComponent implements ControlValueAccessor {\n private curaApi: CuraApiService = inject(CuraApiService);\n\n /**\n * Reflects the checked state of the radio button.\n */\n checked = model<boolean>(false);\n\n /**\n * Status of the radio button.\n */\n status = input<RadioStatus>('default');\n\n /**\n * Reflects the disabled state of the radio button.\n */\n disabled = input<boolean>(false);\n\n /**\n * Reflects the required state of the radio button.\n */\n required = input<boolean>(false);\n\n /**\n * Text label associated with the radio button.\n */\n label = input<string>('');\n\n /**\n * Specifies the tabindex of the radio button.\n */\n ontabindex = input<number>(0);\n\n /**\n * Position of the label relative to the radio button.\n */\n position = input<RadioPosition>('left');\n\n /**\n * Value associated with the radio button.\n */\n value = model<string>('');\n\n /**\n * Name attribute of the radio button.\n */\n name = input<string>('');\n\n /**\n * Background theme of the radio button.\n */\n background = input<RadioBackground>('light');\n\n /**\n * Size of the radio button.\n */\n size = input<RadioSize>('medium');\n\n /**\n * Color theme of the radio button.\n */\n color = input<string>('accent');\n\n /**\n * Controls how the label text should handle overflow.\n * - `'none'`: No overflow handling; the label displays normally.\n * - `'single'`: The label will be truncated with an ellipsis if it overflows a single line.\n * - `string`: Custom overflow handling mode.\n *\n * @default 'none'\n */\n overflowLabel = input<TextOverflow>('none');\n\n /**\n * Controls how the helper text should handle overflow.\n * - `'none'`: No overflow handling; the label displays normally.\n * - `'single'`: The label will be truncated with an ellipsis if it overflows a single line.\n * - `string`: Custom overflow handling mode.\n *\n * @default 'none'\n */\n overflowHelper = input<TextOverflow>('none');\n\n /**\n * Change event emitter\n */\n onchange = output<RadioChangeEvent>();\n\n // Form control callbacks\n private onChange = (value: string) => {};\n private onTouched = () => {};\n\n private sizes = {\n large: { size: 20 },\n medium: { size: 14 },\n small: { size: 10 },\n };\n\n // Computed signals\n private colorConfig = computed(() => {\n if (this.disabled()) {\n return {\n label: this.isDarkBackground() ? 'primary-darker' : 'neutral-medium',\n message: this.isDarkBackground() ? 'primary-darker' : 'neutral-medium',\n };\n }\n\n const darkBackground = this.isDarkBackground();\n const statusColors = {\n success: {\n label: darkBackground ? 'success-lighter' : 'success-darker',\n message: darkBackground ? 'success-base' : 'success-dark',\n },\n error: {\n label: darkBackground ? 'error-lighter' : 'neutral-darker',\n message: darkBackground ? 'error-base' : 'error-dark',\n },\n default: {\n label: darkBackground ? 'neutral-white' : 'neutral-black',\n message: darkBackground ? 'primary-lighter' : 'neutral-dark',\n },\n };\n\n return statusColors[this.status()];\n });\n\n labelColor = computed(() => this.colorConfig().label);\n messageColor = computed(() => this.colorConfig().message);\n labelSize = computed(() => (this.size() === 'large' ? 'medium' : 'xsmall'));\n labelClasses = computed(() => {\n const classes = ['label'];\n if (this.overflowLabel() === 'single') {\n classes.push('textoverflow-single');\n }\n return classes.join(' ');\n });\n messageClasses = computed(() => {\n const classes = ['message'];\n if (this.overflowHelper() === 'single') {\n classes.push('textoverflow-single');\n }\n return classes.join(' ');\n });\n containerClasses = computed(() => {\n const classes = ['container'];\n if (this.checked()) classes.push('checked');\n if (this.disabled()) classes.push('disabled');\n if (this.position() === 'right') classes.push('position');\n classes.push(this.status());\n return classes.join(' ');\n });\n\n // Computed signal para styles\n styles = computed(() => {\n const sizeConfig = this.sizes[this.size()];\n const formsSize = formsSizes[this.size()];\n\n const sizeStyles = {\n '--size-after': `${sizeConfig.size}px`,\n '--size': `${formsSize.size}px`,\n '--gap': `${formsSize.gap}px`,\n };\n\n const darkBackground = this.isDarkBackground();\n const colorValue = this.color();\n\n const colors = [\n { name: '--info-base', background: 'info-base' },\n { name: '--color-light', background: `${colorValue}-light` },\n { name: '--color-base', background: `${colorValue}-base` },\n { name: '--color-dark', background: `${colorValue}-dark` },\n { name: '--neutral-purewhite', background: 'neutral-purewhite' },\n { name: '--success-lighter', background: 'success-lighter' },\n { name: '--success-base', background: 'success-base' },\n { name: '--error-lighter', background: 'error-lighter' },\n { name: '--error-base', background: 'error-base' },\n { name: '--primary-base-neutral-medium', background: darkBackground ? 'primary-base' : 'neutral-medium' },\n { name: '--primary-base-neutral-white', background: darkBackground ? 'primary-base' : 'neutral-white' },\n { name: '--primary-darker-neutral-white', background: darkBackground ? 'primary-darker' : 'neutral-white' },\n { name: '--primary-darker-neutral-base', background: darkBackground ? 'primary-darker' : 'neutral-base' },\n { name: '--primary-base-neutral-base', background: darkBackground ? 'primary-base' : 'neutral-base' },\n { name: '--primary-base-neutral-dark', background: darkBackground ? 'primary-base' : 'neutral-dark' },\n { name: '--primary-base-neutral-medium', background: darkBackground ? 'primary-base' : 'neutral-medium' },\n { name: '--success-base-dark', background: darkBackground ? 'success-base' : 'success-dark' },\n { name: '--error-base-dark', background: darkBackground ? 'error-base' : 'error-dark' },\n ];\n\n const colorStyles: { [key: string]: string } = {};\n colors.forEach((color) => {\n if (this.curaApi) {\n colorStyles[color.name] = this.curaApi.theme.colors.getColor(color.background);\n }\n });\n\n return { ...sizeStyles, ...colorStyles };\n });\n\n // ControlValueAccessor implementation\n writeValue(value: string): void {\n this.checked.set(value === this.value());\n }\n\n registerOnChange(fn: (value: string) => void): void {\n this.onChange = fn;\n }\n\n registerOnTouched(fn: () => void): void {\n this.onTouched = fn;\n }\n\n private isDarkBackground(): boolean {\n return this.background() === 'dark';\n }\n\n handleClick(): void {\n if (this.disabled()) return;\n\n const newCheckedState = !this.checked();\n this.checked.set(newCheckedState);\n\n this.onChange(newCheckedState ? this.value() : '');\n this.onTouched();\n\n this.onchange.emit({ value: this.value(), checked: newCheckedState });\n }\n}\n","<div [class]=\"containerClasses()\" [style]=\"styles()\" (click)=\"handleClick()\">\n <div class=\"info\">\n <div class=\"label-wrapper\">\n <cura-label [textOverflow]=\"overflowLabel()\" [class]=\"labelClasses()\" [size]=\"labelSize()\" [color]=\"labelColor()\">\n {{ label() }}\n </cura-label>\n\n @if (required()) {\n <cura-paragraph lineHeight=\"0%\" marginBlock=\"0\" color=\"error-base\"> * </cura-paragraph>\n }\n </div>\n\n <cura-label [textOverflow]=\"overflowHelper()\" [color]=\"messageColor()\" size=\"xsmall\" [class]=\"messageClasses()\">\n <ng-content></ng-content>\n </cura-label>\n </div>\n\n <input\n type=\"radio\"\n [class]=\"'radio ' + size().toLowerCase()\"\n [name]=\"name()\"\n [value]=\"value()\"\n [required]=\"required()\"\n [tabIndex]=\"ontabindex()\"\n [disabled]=\"disabled()\"\n [checked]=\"checked()\"\n />\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
@@ -68,17 +68,17 @@ class CuraSelectOptionComponent {
68
68
  return classes.join(' ');
69
69
  }, ...(ngDevMode ? [{ debugName: "classes" }] : []));
70
70
  }
71
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CuraSelectOptionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
72
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.15", type: CuraSelectOptionComponent, isStandalone: true, selector: "cura-select-option", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, selected: { classPropertyName: "selected", publicName: "selected", isSignal: true, isRequired: false, transformFunction: null }, active: { classPropertyName: "active", publicName: "active", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, visible: { classPropertyName: "visible", publicName: "visible", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selected: "selectedChange", active: "activeChange", size: "sizeChange", visible: "visibleChange" }, host: { attributes: { "role": "option" }, properties: { "attr.aria-selected": "selected()", "attr.id": "optionId()", "attr.aria-disabled": "false" } }, ngImport: i0, template: "<div [class]=\"classes()\" [style]=\"styles()\" [hidden]=\"!visible()\">\r\n <cura-label [color]=\"selected() ? 'primary-base' : 'neutral-black'\" [size]=\"internalSize().label\" marginBlock=\"0\">\r\n <ng-content></ng-content>\r\n </cura-label>\r\n\r\n @if (selected()) {\r\n <cura-icon name=\"check\" [size]=\"internalSize().icon\" color=\"primary-base\"> </cura-icon>\r\n }\r\n</div>\r\n", styles: [":host{display:block}.item{display:flex;padding:12px 8px;cursor:pointer;justify-content:space-between;align-items:center;box-sizing:border-box;background:var(--neutral-purewhite)}.item.selected{background-color:var(--primary-lighter-50);border-bottom:1px solid var(--primary-light)}.item:hover:not(.selected){background:var(--neutral-white);border-bottom:1px solid var(--neutral-light)}.item.active{background:var(--neutral-white)!important;border-bottom:1px solid var(--neutral-light)}.item.selected.active{background-color:var(--primary-lighter-50)!important;box-shadow:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: CuraLabelComponent, selector: "cura-label", inputs: ["size", "weight", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }, { kind: "component", type: CuraIconComponent, selector: "cura-icon", inputs: ["name", "color", "size", "iconset", "disabled"] }] }); }
71
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: CuraSelectOptionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
72
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.16", type: CuraSelectOptionComponent, isStandalone: true, selector: "cura-select-option", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, selected: { classPropertyName: "selected", publicName: "selected", isSignal: true, isRequired: false, transformFunction: null }, active: { classPropertyName: "active", publicName: "active", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, visible: { classPropertyName: "visible", publicName: "visible", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selected: "selectedChange", active: "activeChange", size: "sizeChange", visible: "visibleChange" }, host: { attributes: { "role": "option" }, properties: { "attr.aria-selected": "selected()", "attr.id": "optionId()", "attr.aria-disabled": "false" } }, ngImport: i0, template: "<div [class]=\"classes()\" [style]=\"styles()\" [hidden]=\"!visible()\">\n <cura-label [color]=\"selected() ? 'primary-base' : 'neutral-black'\" [size]=\"internalSize().label\" marginBlock=\"0\">\n <ng-content></ng-content>\n </cura-label>\n\n @if (selected()) {\n <cura-icon name=\"check\" [size]=\"internalSize().icon\" color=\"primary-base\"> </cura-icon>\n }\n</div>\n", styles: [":host{display:block}.item{display:flex;padding:12px 8px;cursor:pointer;justify-content:space-between;align-items:center;box-sizing:border-box;background:var(--neutral-purewhite)}.item.selected{background-color:var(--primary-lighter-50);border-bottom:1px solid var(--primary-light)}.item:hover:not(.selected){background:var(--neutral-white);border-bottom:1px solid var(--neutral-light)}.item.active{background:var(--neutral-white)!important;border-bottom:1px solid var(--neutral-light)}.item.selected.active{background-color:var(--primary-lighter-50)!important;box-shadow:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: CuraLabelComponent, selector: "cura-label", inputs: ["size", "weight", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }, { kind: "component", type: CuraIconComponent, selector: "cura-icon", inputs: ["name", "color", "size", "iconset", "disabled"] }] }); }
73
73
  }
74
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: CuraSelectOptionComponent, decorators: [{
74
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: CuraSelectOptionComponent, decorators: [{
75
75
  type: Component,
76
76
  args: [{ selector: 'cura-select-option', imports: [CommonModule, CuraLabelComponent, CuraIconComponent], host: {
77
77
  role: 'option',
78
78
  '[attr.aria-selected]': 'selected()',
79
79
  '[attr.id]': 'optionId()',
80
80
  '[attr.aria-disabled]': 'false',
81
- }, template: "<div [class]=\"classes()\" [style]=\"styles()\" [hidden]=\"!visible()\">\r\n <cura-label [color]=\"selected() ? 'primary-base' : 'neutral-black'\" [size]=\"internalSize().label\" marginBlock=\"0\">\r\n <ng-content></ng-content>\r\n </cura-label>\r\n\r\n @if (selected()) {\r\n <cura-icon name=\"check\" [size]=\"internalSize().icon\" color=\"primary-base\"> </cura-icon>\r\n }\r\n</div>\r\n", styles: [":host{display:block}.item{display:flex;padding:12px 8px;cursor:pointer;justify-content:space-between;align-items:center;box-sizing:border-box;background:var(--neutral-purewhite)}.item.selected{background-color:var(--primary-lighter-50);border-bottom:1px solid var(--primary-light)}.item:hover:not(.selected){background:var(--neutral-white);border-bottom:1px solid var(--neutral-light)}.item.active{background:var(--neutral-white)!important;border-bottom:1px solid var(--neutral-light)}.item.selected.active{background-color:var(--primary-lighter-50)!important;box-shadow:none}\n"] }]
81
+ }, template: "<div [class]=\"classes()\" [style]=\"styles()\" [hidden]=\"!visible()\">\n <cura-label [color]=\"selected() ? 'primary-base' : 'neutral-black'\" [size]=\"internalSize().label\" marginBlock=\"0\">\n <ng-content></ng-content>\n </cura-label>\n\n @if (selected()) {\n <cura-icon name=\"check\" [size]=\"internalSize().icon\" color=\"primary-base\"> </cura-icon>\n }\n</div>\n", styles: [":host{display:block}.item{display:flex;padding:12px 8px;cursor:pointer;justify-content:space-between;align-items:center;box-sizing:border-box;background:var(--neutral-purewhite)}.item.selected{background-color:var(--primary-lighter-50);border-bottom:1px solid var(--primary-light)}.item:hover:not(.selected){background:var(--neutral-white);border-bottom:1px solid var(--neutral-light)}.item.active{background:var(--neutral-white)!important;border-bottom:1px solid var(--neutral-light)}.item.selected.active{background-color:var(--primary-lighter-50)!important;box-shadow:none}\n"] }]
82
82
  }], propDecorators: { value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: false }] }], selected: [{ type: i0.Input, args: [{ isSignal: true, alias: "selected", required: false }] }, { type: i0.Output, args: ["selectedChange"] }], active: [{ type: i0.Input, args: [{ isSignal: true, alias: "active", required: false }] }, { type: i0.Output, args: ["activeChange"] }], size: [{ type: i0.Input, args: [{ isSignal: true, alias: "size", required: false }] }, { type: i0.Output, args: ["sizeChange"] }], visible: [{ type: i0.Input, args: [{ isSignal: true, alias: "visible", required: false }] }, { type: i0.Output, args: ["visibleChange"] }] } });
83
83
 
84
84
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"rededor-site-front-end-lib-cura-forms-cura-select-option.mjs","sources":["../../../projects/site-front-end-lib/cura/forms/cura-select-option/cura-select-option.component.ts","../../../projects/site-front-end-lib/cura/forms/cura-select-option/cura-select-option.component.html","../../../projects/site-front-end-lib/cura/forms/cura-select-option/rededor-site-front-end-lib-cura-forms-cura-select-option.ts"],"sourcesContent":["import { Component, input, computed, inject, model, ElementRef } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CuraApiService } from '@rededor/site-front-end-lib/cura/api';\r\nimport { CuraLabelComponent } from '@rededor/site-front-end-lib/cura/forms/cura-label';\r\nimport { CuraIconComponent } from '@rededor/site-front-end-lib/cura/icons/cura-icon';\r\nimport { SelectOptionSize, SelectOptionSizeConfig } from './cura-select-option.definitions';\r\n\r\n@Component({\r\n selector: 'cura-select-option',\r\n imports: [CommonModule, CuraLabelComponent, CuraIconComponent],\r\n templateUrl: './cura-select-option.component.html',\r\n styleUrls: ['./cura-select-option.component.scss'],\r\n host: {\r\n role: 'option',\r\n '[attr.aria-selected]': 'selected()',\r\n '[attr.id]': 'optionId()',\r\n '[attr.aria-disabled]': 'false',\r\n },\r\n})\r\nexport class CuraSelectOptionComponent {\r\n private curaApi: CuraApiService = inject(CuraApiService);\r\n public elementRef = inject(ElementRef);\r\n\r\n /**\r\n * Value associated with the select option\r\n */\r\n value = input<string | any>('');\r\n\r\n /**\r\n * Whether the option is selected\r\n */\r\n selected = model<boolean>(false);\r\n\r\n /**\r\n * Whether the option is active (highlighted)\r\n */\r\n active = model<boolean>(false);\r\n\r\n /**\r\n * Size of the select option\r\n */\r\n size = model<SelectOptionSize>('small');\r\n\r\n /**\r\n * Whether the option is visible (for search filtering)\r\n */\r\n visible = model<boolean>(true);\r\n\r\n /**\r\n * Unique ID for the option (for accessibility)\r\n */\r\n private componentId = `cura-select-option-${Math.random().toString(36).substring(2, 8)}`;\r\n\r\n // Computed signals\r\n optionId = computed(() => this.componentId);\r\n\r\n internalSize = computed(() => {\r\n const sizeMap: { [key in SelectOptionSize]: SelectOptionSizeConfig } = {\r\n large: { label: 'medium', icon: 20 },\r\n medium: { label: 'small', icon: 16 },\r\n small: { label: 'xsmall', icon: 'micro' },\r\n xsmall: { label: 'xsmall', icon: 'micro' },\r\n };\r\n return sizeMap[this.size()] || sizeMap['medium'];\r\n });\r\n\r\n styles = computed(() => {\r\n const colors = [\r\n { name: '--primary-lighter-50', theme: 'primary-lighter', opacity: 0.5 },\r\n { name: '--primary-light', theme: 'primary-light' },\r\n { name: '--neutral-light', theme: 'neutral-light' },\r\n { name: '--neutral-purewhite', theme: 'neutral-purewhite' },\r\n ];\r\n\r\n const colorStyles: { [key: string]: string } = {};\r\n colors.forEach((color) => {\r\n if (this.curaApi) {\r\n colorStyles[color.name] = this.curaApi.theme.colors.getColor(color.theme, color.opacity);\r\n }\r\n });\r\n\r\n return { ...colorStyles };\r\n });\r\n\r\n classes = computed(() => {\r\n const classes = ['item'];\r\n\r\n if (this.selected()) classes.push('selected');\r\n if (this.active()) classes.push('active');\r\n\r\n return classes.join(' ');\r\n });\r\n}\r\n","<div [class]=\"classes()\" [style]=\"styles()\" [hidden]=\"!visible()\">\r\n <cura-label [color]=\"selected() ? 'primary-base' : 'neutral-black'\" [size]=\"internalSize().label\" marginBlock=\"0\">\r\n <ng-content></ng-content>\r\n </cura-label>\r\n\r\n @if (selected()) {\r\n <cura-icon name=\"check\" [size]=\"internalSize().icon\" color=\"primary-base\"> </cura-icon>\r\n }\r\n</div>\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"rededor-site-front-end-lib-cura-forms-cura-select-option.mjs","sources":["../../../projects/site-front-end-lib/cura/forms/cura-select-option/cura-select-option.component.ts","../../../projects/site-front-end-lib/cura/forms/cura-select-option/cura-select-option.component.html","../../../projects/site-front-end-lib/cura/forms/cura-select-option/rededor-site-front-end-lib-cura-forms-cura-select-option.ts"],"sourcesContent":["import { Component, input, computed, inject, model, ElementRef } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { CuraApiService } from '@rededor/site-front-end-lib/cura/api';\nimport { CuraLabelComponent } from '@rededor/site-front-end-lib/cura/forms/cura-label';\nimport { CuraIconComponent } from '@rededor/site-front-end-lib/cura/icons/cura-icon';\nimport { SelectOptionSize, SelectOptionSizeConfig } from './cura-select-option.definitions';\n\n@Component({\n selector: 'cura-select-option',\n imports: [CommonModule, CuraLabelComponent, CuraIconComponent],\n templateUrl: './cura-select-option.component.html',\n styleUrls: ['./cura-select-option.component.scss'],\n host: {\n role: 'option',\n '[attr.aria-selected]': 'selected()',\n '[attr.id]': 'optionId()',\n '[attr.aria-disabled]': 'false',\n },\n})\nexport class CuraSelectOptionComponent {\n private curaApi: CuraApiService = inject(CuraApiService);\n public elementRef = inject(ElementRef);\n\n /**\n * Value associated with the select option\n */\n value = input<string | any>('');\n\n /**\n * Whether the option is selected\n */\n selected = model<boolean>(false);\n\n /**\n * Whether the option is active (highlighted)\n */\n active = model<boolean>(false);\n\n /**\n * Size of the select option\n */\n size = model<SelectOptionSize>('small');\n\n /**\n * Whether the option is visible (for search filtering)\n */\n visible = model<boolean>(true);\n\n /**\n * Unique ID for the option (for accessibility)\n */\n private componentId = `cura-select-option-${Math.random().toString(36).substring(2, 8)}`;\n\n // Computed signals\n optionId = computed(() => this.componentId);\n\n internalSize = computed(() => {\n const sizeMap: { [key in SelectOptionSize]: SelectOptionSizeConfig } = {\n large: { label: 'medium', icon: 20 },\n medium: { label: 'small', icon: 16 },\n small: { label: 'xsmall', icon: 'micro' },\n xsmall: { label: 'xsmall', icon: 'micro' },\n };\n return sizeMap[this.size()] || sizeMap['medium'];\n });\n\n styles = computed(() => {\n const colors = [\n { name: '--primary-lighter-50', theme: 'primary-lighter', opacity: 0.5 },\n { name: '--primary-light', theme: 'primary-light' },\n { name: '--neutral-light', theme: 'neutral-light' },\n { name: '--neutral-purewhite', theme: 'neutral-purewhite' },\n ];\n\n const colorStyles: { [key: string]: string } = {};\n colors.forEach((color) => {\n if (this.curaApi) {\n colorStyles[color.name] = this.curaApi.theme.colors.getColor(color.theme, color.opacity);\n }\n });\n\n return { ...colorStyles };\n });\n\n classes = computed(() => {\n const classes = ['item'];\n\n if (this.selected()) classes.push('selected');\n if (this.active()) classes.push('active');\n\n return classes.join(' ');\n });\n}\n","<div [class]=\"classes()\" [style]=\"styles()\" [hidden]=\"!visible()\">\n <cura-label [color]=\"selected() ? 'primary-base' : 'neutral-black'\" [size]=\"internalSize().label\" marginBlock=\"0\">\n <ng-content></ng-content>\n </cura-label>\n\n @if (selected()) {\n <cura-icon name=\"check\" [size]=\"internalSize().icon\" color=\"primary-base\"> </cura-icon>\n }\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}