@rededor/site-front-end-lib 20.0.26 → 20.0.27

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 (915) hide show
  1. package/CHANGELOG.md +828 -0
  2. package/components/algolia-dropdown/algolia-dropdown.component.html +19 -0
  3. package/components/algolia-dropdown/algolia-dropdown.component.scss +0 -0
  4. package/components/algolia-dropdown/algolia-dropdown.component.spec.ts +22 -0
  5. package/components/algolia-dropdown/algolia-dropdown.component.ts +103 -0
  6. package/components/algolia-dropdown/index.ts +1 -0
  7. package/components/algolia-dropdown/ng-package.json +6 -0
  8. package/components/algolia-dropdown/public-api.ts +1 -0
  9. package/components/algolia-search/components/algolia-search/algolia-search.component.html +96 -0
  10. package/components/algolia-search/components/algolia-search/algolia-search.component.scss +588 -0
  11. package/components/algolia-search/components/algolia-search/algolia-search.component.spec.ts +21 -0
  12. package/components/algolia-search/components/algolia-search/algolia-search.component.ts +415 -0
  13. package/components/algolia-search/components/algolia-search-field/algolia-search-field.component.html +23 -0
  14. package/components/algolia-search/components/algolia-search-field/algolia-search-field.component.scss +5 -0
  15. package/components/algolia-search/components/algolia-search-field/algolia-search-field.component.spec.ts +22 -0
  16. package/components/algolia-search/components/algolia-search-field/algolia-search-field.component.ts +90 -0
  17. package/components/algolia-search/components/algolia-search-result-item/algolia-search-result-item.component.html +70 -0
  18. package/components/algolia-search/components/algolia-search-result-item/algolia-search-result-item.component.scss +27 -0
  19. package/components/algolia-search/components/algolia-search-result-item/algolia-search-result-item.component.spec.ts +21 -0
  20. package/components/algolia-search/components/algolia-search-result-item/algolia-search-result-item.component.ts +77 -0
  21. package/components/algolia-search/components/algolia-search-results/algolia-search-results.component.html +6 -0
  22. package/components/algolia-search/components/algolia-search-results/algolia-search-results.component.scss +0 -0
  23. package/components/algolia-search/components/algolia-search-results/algolia-search-results.component.spec.ts +21 -0
  24. package/components/algolia-search/components/algolia-search-results/algolia-search-results.component.ts +90 -0
  25. package/components/algolia-search/components/algolia-search-tooltip/algolia-search-tooltip.component.html +1 -0
  26. package/components/algolia-search/components/algolia-search-tooltip/algolia-search-tooltip.component.scss +0 -0
  27. package/components/algolia-search/components/algolia-search-tooltip/algolia-search-tooltip.component.spec.ts +21 -0
  28. package/components/algolia-search/components/algolia-search-tooltip/algolia-search-tooltip.component.ts +9 -0
  29. package/components/algolia-search/index.ts +1 -0
  30. package/components/algolia-search/models/algolia-component-style.enum.ts +4 -0
  31. package/components/algolia-search/models/algolia-config.model.ts +8 -0
  32. package/components/algolia-search/models/algolia-hint.model.ts +4 -0
  33. package/components/algolia-search/models/algolia-hit-description.model.ts +6 -0
  34. package/components/algolia-search/models/algolia-multiple-index.model.ts +7 -0
  35. package/components/algolia-search/models/algolia-results-item.model.ts +8 -0
  36. package/components/algolia-search/models/algolia-results-multiple.model.ts +6 -0
  37. package/components/algolia-search/models/algolia-search-params.model.ts +83 -0
  38. package/components/algolia-search/ng-package.json +6 -0
  39. package/components/algolia-search/public-api.ts +13 -0
  40. package/components/banner/content-banner/content-banner.component.html +51 -0
  41. package/components/banner/content-banner/content-banner.component.scss +91 -0
  42. package/components/banner/content-banner/content-banner.component.spec.ts +27 -0
  43. package/components/banner/content-banner/content-banner.component.ts +36 -0
  44. package/components/banner/index.ts +1 -0
  45. package/components/banner/ng-package.json +6 -0
  46. package/components/banner/public-api.ts +1 -0
  47. package/components/breadcrumbs/breadcrumbs.component.html +56 -0
  48. package/components/breadcrumbs/breadcrumbs.component.scss +55 -0
  49. package/components/breadcrumbs/breadcrumbs.component.spec.ts +22 -0
  50. package/components/breadcrumbs/breadcrumbs.component.ts +142 -0
  51. package/components/breadcrumbs/index.ts +1 -0
  52. package/components/breadcrumbs/ng-package.json +6 -0
  53. package/components/breadcrumbs/public-api.ts +1 -0
  54. package/components/cards/card-unidade-planos-convenios/card-unidade-planos-convenios.component.html +91 -0
  55. package/components/cards/card-unidade-planos-convenios/card-unidade-planos-convenios.component.scss +143 -0
  56. package/components/cards/card-unidade-planos-convenios/card-unidade-planos-convenios.component.spec.ts +22 -0
  57. package/components/cards/card-unidade-planos-convenios/card-unidade-planos-convenios.component.ts +66 -0
  58. package/components/cards/expandable-card/expandable-card.component.html +30 -0
  59. package/components/cards/expandable-card/expandable-card.component.scss +100 -0
  60. package/components/cards/expandable-card/expandable-card.component.spec.ts +27 -0
  61. package/components/cards/expandable-card/expandable-card.component.ts +60 -0
  62. package/components/cards/index.ts +1 -0
  63. package/components/cards/ng-package.json +6 -0
  64. package/components/cards/public-api.ts +3 -0
  65. package/components/cards/testimonial-card/testimonial-card.component.html +41 -0
  66. package/components/cards/testimonial-card/testimonial-card.component.scss +96 -0
  67. package/components/cards/testimonial-card/testimonial-card.component.spec.ts +27 -0
  68. package/components/cards/testimonial-card/testimonial-card.component.ts +65 -0
  69. package/components/carousels/index.ts +1 -0
  70. package/components/carousels/ng-package.json +6 -0
  71. package/components/carousels/public-api.ts +1 -0
  72. package/components/carousels/testimonials-carousel/testimonials-carousel.component.html +30 -0
  73. package/components/carousels/testimonials-carousel/testimonials-carousel.component.scss +91 -0
  74. package/components/carousels/testimonials-carousel/testimonials-carousel.component.spec.ts +27 -0
  75. package/components/carousels/testimonials-carousel/testimonials-carousel.component.ts +73 -0
  76. package/components/cta-wrapper/cta-wrapper.component.html +54 -0
  77. package/components/cta-wrapper/cta-wrapper.component.scss +123 -0
  78. package/components/cta-wrapper/cta-wrapper.component.spec.ts +22 -0
  79. package/components/cta-wrapper/cta-wrapper.component.ts +77 -0
  80. package/components/cta-wrapper/index.ts +1 -0
  81. package/components/cta-wrapper/ng-package.json +6 -0
  82. package/components/cta-wrapper/public-api.ts +1 -0
  83. package/components/error/error.component.html +65 -0
  84. package/components/error/error.component.scss +26 -0
  85. package/components/error/error.component.spec.ts +22 -0
  86. package/components/error/error.component.ts +182 -0
  87. package/components/error/index.ts +1 -0
  88. package/components/error/ng-package.json +6 -0
  89. package/components/error/public-api.ts +1 -0
  90. package/components/filter-letter-and-terms/filter-letter-and-terms.component.html +33 -0
  91. package/components/filter-letter-and-terms/filter-letter-and-terms.component.scss +98 -0
  92. package/components/filter-letter-and-terms/filter-letter-and-terms.component.spec.ts +22 -0
  93. package/components/filter-letter-and-terms/filter-letter-and-terms.component.ts +87 -0
  94. package/components/filter-letter-and-terms/index.ts +1 -0
  95. package/components/filter-letter-and-terms/ng-package.json +6 -0
  96. package/components/filter-letter-and-terms/public-api.ts +1 -0
  97. package/components/filters/filter-generic/USAGE.md +147 -0
  98. package/components/filters/filter-generic/filter-generic.component.html +174 -0
  99. package/components/filters/filter-generic/filter-generic.component.scss +266 -0
  100. package/components/filters/filter-generic/filter-generic.component.spec.ts +21 -0
  101. package/components/filters/filter-generic/filter-generic.component.ts +266 -0
  102. package/components/filters/filter-generic/index.ts +1 -0
  103. package/components/filters/filter-generic/ng-package.json +6 -0
  104. package/components/filters/filter-generic/public-api.ts +1 -0
  105. package/components/filters/filter-planos-convenios/filter-planos-convenios.component.html +76 -0
  106. package/components/filters/filter-planos-convenios/filter-planos-convenios.component.scss +84 -0
  107. package/components/filters/filter-planos-convenios/filter-planos-convenios.component.spec.ts +21 -0
  108. package/components/filters/filter-planos-convenios/filter-planos-convenios.component.ts +149 -0
  109. package/components/filters/filter-planos-convenios/index.ts +1 -0
  110. package/components/filters/filter-planos-convenios/ng-package.json +6 -0
  111. package/components/filters/filter-planos-convenios/public-api.ts +1 -0
  112. package/components/footer/footer.component.html +125 -0
  113. package/components/footer/footer.component.scss +451 -0
  114. package/components/footer/footer.component.spec.ts +22 -0
  115. package/components/footer/footer.component.ts +94 -0
  116. package/components/footer/helpers/footerTheme.func.ts +119 -0
  117. package/components/footer/index.ts +1 -0
  118. package/components/footer/models/FooterTheme.model.ts +8 -0
  119. package/components/footer/ng-package.json +6 -0
  120. package/components/footer/public-api.ts +1 -0
  121. package/components/header/components/action/header-action-menu/header-action-menu.component.html +41 -0
  122. package/components/header/components/action/header-action-menu/header-action-menu.component.scss +158 -0
  123. package/components/header/components/action/header-action-menu/header-action-menu.component.spec.ts +22 -0
  124. package/components/header/components/action/header-action-menu/header-action-menu.component.ts +30 -0
  125. package/components/header/components/action/index.ts +1 -0
  126. package/components/header/components/action/ng-package.json +6 -0
  127. package/components/header/components/action/public-api.ts +1 -0
  128. package/components/header/components/auxiliar/header-aux-menu-item/header-aux-menu-item.component.html +33 -0
  129. package/components/header/components/auxiliar/header-aux-menu-item/header-aux-menu-item.component.scss +60 -0
  130. package/components/header/components/auxiliar/header-aux-menu-item/header-aux-menu-item.component.spec.ts +22 -0
  131. package/components/header/components/auxiliar/header-aux-menu-item/header-aux-menu-item.component.ts +46 -0
  132. package/components/header/components/auxiliar/header-aux-menu-item-dropdown/header-aux-menu-item-dropdown.component.html +7 -0
  133. package/components/header/components/auxiliar/header-aux-menu-item-dropdown/header-aux-menu-item-dropdown.component.scss +27 -0
  134. package/components/header/components/auxiliar/header-aux-menu-item-dropdown/header-aux-menu-item-dropdown.component.spec.ts +22 -0
  135. package/components/header/components/auxiliar/header-aux-menu-item-dropdown/header-aux-menu-item-dropdown.component.ts +19 -0
  136. package/components/header/components/auxiliar/index.ts +1 -0
  137. package/components/header/components/auxiliar/ng-package.json +6 -0
  138. package/components/header/components/auxiliar/public-api.ts +2 -0
  139. package/components/header/components/header-logo/header-logo.component.html +5 -0
  140. package/components/header/components/header-logo/header-logo.component.scss +20 -0
  141. package/components/header/components/header-logo/header-logo.component.spec.ts +22 -0
  142. package/components/header/components/header-logo/header-logo.component.ts +23 -0
  143. package/components/header/components/main/header-main-menu-item/header-main-menu-item.component.html +30 -0
  144. package/components/header/components/main/header-main-menu-item/header-main-menu-item.component.scss +53 -0
  145. package/components/header/components/main/header-main-menu-item/header-main-menu-item.component.spec.ts +22 -0
  146. package/components/header/components/main/header-main-menu-item/header-main-menu-item.component.ts +88 -0
  147. package/components/header/components/main/header-main-menu-item-dropdown/header-main-menu-item-dropdown.component.html +112 -0
  148. package/components/header/components/main/header-main-menu-item-dropdown/header-main-menu-item-dropdown.component.scss +259 -0
  149. package/components/header/components/main/header-main-menu-item-dropdown/header-main-menu-item-dropdown.component.spec.ts +22 -0
  150. package/components/header/components/main/header-main-menu-item-dropdown/header-main-menu-item-dropdown.component.ts +107 -0
  151. package/components/header/components/main/index.ts +1 -0
  152. package/components/header/components/main/ng-package.json +6 -0
  153. package/components/header/components/main/public-api.ts +2 -0
  154. package/components/header/components/side/header-side-menu/header-side-menu.component.html +32 -0
  155. package/components/header/components/side/header-side-menu/header-side-menu.component.scss +81 -0
  156. package/components/header/components/side/header-side-menu/header-side-menu.component.spec.ts +22 -0
  157. package/components/header/components/side/header-side-menu/header-side-menu.component.ts +29 -0
  158. package/components/header/components/side/header-side-menu-item/header-side-menu-item.component.html +26 -0
  159. package/components/header/components/side/header-side-menu-item/header-side-menu-item.component.scss +104 -0
  160. package/components/header/components/side/header-side-menu-item/header-side-menu-item.component.spec.ts +22 -0
  161. package/components/header/components/side/header-side-menu-item/header-side-menu-item.component.ts +45 -0
  162. package/components/header/components/side/index.ts +1 -0
  163. package/components/header/components/side/ng-package.json +6 -0
  164. package/components/header/components/side/public-api.ts +2 -0
  165. package/components/header/header.component.html +81 -0
  166. package/components/header/header.component.scss +171 -0
  167. package/components/header/header.component.spec.ts +22 -0
  168. package/components/header/header.component.ts +135 -0
  169. package/components/header/helpers/headerTheme.func.ts +288 -0
  170. package/components/header/index.ts +1 -0
  171. package/components/header/models/HeaderTheme.model.ts +9 -0
  172. package/components/header/ng-package.json +6 -0
  173. package/components/header/public-api.ts +2 -0
  174. package/components/header/services/header.service.spec.ts +16 -0
  175. package/components/header/services/header.service.ts +40 -0
  176. package/components/header/services/index.ts +1 -0
  177. package/components/header/services/ng-package.json +6 -0
  178. package/components/header/services/public-api.ts +1 -0
  179. package/components/image/image.component.html +9 -0
  180. package/components/image/image.component.scss +12 -0
  181. package/components/image/image.component.spec.ts +22 -0
  182. package/components/image/image.component.ts +43 -0
  183. package/components/image/index.ts +1 -0
  184. package/components/image/ng-package.json +6 -0
  185. package/components/image/public-api.ts +1 -0
  186. package/components/load-screen/index.ts +1 -0
  187. package/components/load-screen/load-screen.component.html +128 -0
  188. package/components/load-screen/load-screen.component.scss +46 -0
  189. package/components/load-screen/load-screen.component.spec.ts +27 -0
  190. package/components/load-screen/load-screen.component.ts +18 -0
  191. package/components/load-screen/ng-package.json +6 -0
  192. package/components/load-screen/public-api.ts +1 -0
  193. package/components/modal/index.ts +1 -0
  194. package/components/modal/modal.component.html +12 -0
  195. package/components/modal/modal.component.scss +34 -0
  196. package/components/modal/modal.component.spec.ts +22 -0
  197. package/components/modal/modal.component.ts +74 -0
  198. package/components/modal/ng-package.json +6 -0
  199. package/components/modal/public-api.ts +1 -0
  200. package/components/modal-drawer/index.ts +1 -0
  201. package/components/modal-drawer/modal-drawer.component.html +22 -0
  202. package/components/modal-drawer/modal-drawer.component.scss +250 -0
  203. package/components/modal-drawer/modal-drawer.component.spec.ts +22 -0
  204. package/components/modal-drawer/modal-drawer.component.ts +148 -0
  205. package/components/modal-drawer/ng-package.json +6 -0
  206. package/components/modal-drawer/public-api.ts +1 -0
  207. package/components/overlay/index.ts +1 -0
  208. package/components/overlay/ng-package.json +6 -0
  209. package/components/overlay/overlay.component.html +1 -0
  210. package/components/overlay/overlay.component.scss +13 -0
  211. package/components/overlay/overlay.component.spec.ts +22 -0
  212. package/components/overlay/overlay.component.ts +15 -0
  213. package/components/overlay/public-api.ts +1 -0
  214. package/components/page-header/index.ts +1 -0
  215. package/components/page-header/ng-package.json +6 -0
  216. package/components/page-header/page-header.component.html +25 -0
  217. package/components/page-header/page-header.component.scss +110 -0
  218. package/components/page-header/page-header.component.spec.ts +22 -0
  219. package/components/page-header/page-header.component.ts +41 -0
  220. package/components/page-header/public-api.ts +1 -0
  221. package/components/page-template-fullcontent/index.ts +1 -0
  222. package/components/page-template-fullcontent/ng-package.json +6 -0
  223. package/components/page-template-fullcontent/page-template-fullcontent.component.html +37 -0
  224. package/components/page-template-fullcontent/page-template-fullcontent.component.scss +41 -0
  225. package/components/page-template-fullcontent/page-template-fullcontent.component.ts +22 -0
  226. package/components/page-template-fullcontent/public-api.ts +1 -0
  227. package/components/page-template-sidebar/index.ts +1 -0
  228. package/components/page-template-sidebar/ng-package.json +6 -0
  229. package/components/page-template-sidebar/page-template-sidebar.component.html +50 -0
  230. package/components/page-template-sidebar/page-template-sidebar.component.scss +80 -0
  231. package/components/page-template-sidebar/page-template-sidebar.component.spec.ts +22 -0
  232. package/components/page-template-sidebar/page-template-sidebar.component.ts +25 -0
  233. package/components/page-template-sidebar/public-api.ts +1 -0
  234. package/components/pagination/index.ts +1 -0
  235. package/components/pagination/ng-package.json +6 -0
  236. package/components/pagination/pagination.component.html +53 -0
  237. package/components/pagination/pagination.component.scss +124 -0
  238. package/components/pagination/pagination.component.spec.ts +22 -0
  239. package/components/pagination/pagination.component.ts +48 -0
  240. package/components/pagination/public-api.ts +1 -0
  241. package/components/search/index.ts +1 -0
  242. package/components/search/ng-package.json +6 -0
  243. package/components/search/public-api.ts +1 -0
  244. package/components/search/search.component.html +32 -0
  245. package/components/search/search.component.scss +59 -0
  246. package/components/search/search.component.spec.ts +22 -0
  247. package/components/search/search.component.ts +122 -0
  248. package/components/section-navigation/index.ts +1 -0
  249. package/components/section-navigation/ng-package.json +6 -0
  250. package/components/section-navigation/public-api.ts +1 -0
  251. package/components/section-navigation/section-navigation.component.html +23 -0
  252. package/components/section-navigation/section-navigation.component.scss +50 -0
  253. package/components/section-navigation/section-navigation.component.spec.ts +22 -0
  254. package/components/section-navigation/section-navigation.component.ts +159 -0
  255. package/components/side-ctas/components/side-ctas-bottom/side-ctas-bottom.component.html +8 -0
  256. package/components/side-ctas/components/side-ctas-bottom/side-ctas-bottom.component.scss +56 -0
  257. package/components/side-ctas/components/side-ctas-bottom/side-ctas-bottom.component.spec.ts +22 -0
  258. package/components/side-ctas/components/side-ctas-bottom/side-ctas-bottom.component.ts +31 -0
  259. package/components/side-ctas/components/side-ctas-right-bottom/side-ctas-right-bottom.component.html +11 -0
  260. package/components/side-ctas/components/side-ctas-right-bottom/side-ctas-right-bottom.component.scss +0 -0
  261. package/components/side-ctas/components/side-ctas-right-bottom/side-ctas-right-bottom.component.spec.ts +22 -0
  262. package/components/side-ctas/components/side-ctas-right-bottom/side-ctas-right-bottom.component.ts +23 -0
  263. package/components/side-ctas/components/side-ctas-right-middle/side-ctas-right-middle.component.html +10 -0
  264. package/components/side-ctas/components/side-ctas-right-middle/side-ctas-right-middle.component.scss +54 -0
  265. package/components/side-ctas/components/side-ctas-right-middle/side-ctas-right-middle.component.spec.ts +22 -0
  266. package/components/side-ctas/components/side-ctas-right-middle/side-ctas-right-middle.component.ts +30 -0
  267. package/components/side-ctas/components/side-ctas-right-top/side-ctas-right-top.component.html +1 -0
  268. package/components/side-ctas/components/side-ctas-right-top/side-ctas-right-top.component.scss +11 -0
  269. package/components/side-ctas/components/side-ctas-right-top/side-ctas-right-top.component.spec.ts +22 -0
  270. package/components/side-ctas/components/side-ctas-right-top/side-ctas-right-top.component.ts +9 -0
  271. package/components/side-ctas/index.ts +1 -0
  272. package/components/side-ctas/models/SideCta.model.ts +5 -0
  273. package/components/side-ctas/ng-package.json +6 -0
  274. package/components/side-ctas/public-api.ts +6 -0
  275. package/components/side-ctas/side-ctas.component.html +28 -0
  276. package/components/side-ctas/side-ctas.component.scss +62 -0
  277. package/components/side-ctas/side-ctas.component.spec.ts +22 -0
  278. package/components/side-ctas/side-ctas.component.ts +17 -0
  279. package/components/sidebar-navigation/index.ts +1 -0
  280. package/components/sidebar-navigation/ng-package.json +6 -0
  281. package/components/sidebar-navigation/public-api.ts +1 -0
  282. package/components/sidebar-navigation/sidebar-navigation.component.html +42 -0
  283. package/components/sidebar-navigation/sidebar-navigation.component.scss +25 -0
  284. package/components/sidebar-navigation/sidebar-navigation.component.ts +122 -0
  285. package/components/sticky-navigation/index.ts +1 -0
  286. package/components/sticky-navigation/ng-package.json +6 -0
  287. package/components/sticky-navigation/public-api.ts +1 -0
  288. package/components/sticky-navigation/sticky-navigation.component.html +39 -0
  289. package/components/sticky-navigation/sticky-navigation.component.scss +48 -0
  290. package/components/sticky-navigation/sticky-navigation.component.ts +134 -0
  291. package/components/whatsapp/index.ts +1 -0
  292. package/components/whatsapp/ng-package.json +6 -0
  293. package/components/whatsapp/public-api.ts +1 -0
  294. package/components/whatsapp/whatsapp.component.html +23 -0
  295. package/components/whatsapp/whatsapp.component.scss +113 -0
  296. package/components/whatsapp/whatsapp.component.spec.ts +22 -0
  297. package/components/whatsapp/whatsapp.component.ts +40 -0
  298. package/core/directives/rdsite-link/rdsite-link.directive.spec.ts +8 -0
  299. package/core/directives/rdsite-link/rdsite-link.directive.ts +200 -0
  300. package/core/directives/rdsite-phone-modal/rdsite-phone-modal.directive.spec.ts +8 -0
  301. package/core/directives/rdsite-phone-modal/rdsite-phone-modal.directive.ts +41 -0
  302. package/core/enums/RdsiteModalComponentStyle.enum.ts +13 -0
  303. package/core/enums/RdsiteModalDrawerComponentStyle.enum.ts +7 -0
  304. package/core/helpers/check-safari-agent.func.ts +6 -0
  305. package/core/helpers/djb2Hash.func.ts +18 -0
  306. package/core/helpers/executeWithRetry.func.ts +25 -0
  307. package/core/helpers/formatPhone.func.ts +22 -0
  308. package/core/helpers/getCircularReplacer.func.ts +45 -0
  309. package/core/helpers/getSiteUrl.func.ts +7 -0
  310. package/core/helpers/removeHtmlTags.func.ts +6 -0
  311. package/core/helpers/toQueryParams.func.ts +11 -0
  312. package/core/index.ts +1 -0
  313. package/core/interceptors/error.interceptor.ts +39 -0
  314. package/core/interceptors/log.interceptor.ts +35 -0
  315. package/core/interceptors/transfer-state-url.interceptor.ts +137 -0
  316. package/core/models/algolia-search-api.model.ts +213 -0
  317. package/core/models/breadcrumbs/breadcrumbs-items.model.ts +10 -0
  318. package/core/models/breadcrumbs/breadcrumbs-json-item.model.ts +8 -0
  319. package/core/models/centro-estudos-backend.model.ts +8 -0
  320. package/core/models/centro-medico.model.ts +33 -0
  321. package/core/models/content-banner.model.ts +7 -0
  322. package/core/models/cta-wrapper.model.ts +9 -0
  323. package/core/models/doenca-backend.model.ts +27 -0
  324. package/core/models/doenca-taxonomy.model.ts +21 -0
  325. package/core/models/especialidade-backend.model.ts +25 -0
  326. package/core/models/exame-backend.model.ts +26 -0
  327. package/core/models/filters/filter-planos-convenios.model.ts +34 -0
  328. package/core/models/filters/filter-section.type.ts +18 -0
  329. package/core/models/filters/filter-sections.model.ts +66 -0
  330. package/core/models/images/rdsite-image.model.ts +5 -0
  331. package/core/models/index.ts +1 -0
  332. package/core/models/medico-cv.model.ts +10 -0
  333. package/core/models/menu-de-unidade.model.ts +16 -0
  334. package/core/models/menu-item.model.ts +71 -0
  335. package/core/models/privacy-tools/privacy-tools.model.ts +9 -0
  336. package/core/models/rdsl-cobertura.model.ts +72 -0
  337. package/core/models/rdsl-convenio.model.ts +18 -0
  338. package/core/models/rdsl-especialidade.model.ts +36 -0
  339. package/core/models/rdsl-planos.model.ts +14 -0
  340. package/core/models/rdsl-post-category.model.ts +8 -0
  341. package/core/models/rdsl-unidade.model.ts +52 -0
  342. package/core/models/section-navigation.model.ts +10 -0
  343. package/core/models/seo/seo-data.model.ts +11 -0
  344. package/core/models/seo/seo-unidade.model.ts +6 -0
  345. package/core/models/social-meta-properties.model.ts +9 -0
  346. package/core/models/wordpress/WpEnvelopeResponse.model.ts +12 -0
  347. package/core/models/wordpress/WpHttpParams.model.ts +5 -0
  348. package/core/models/wordpress/WpQueryParams.model.ts +32 -0
  349. package/core/models/wordpress/WpResponse.model.ts +35 -0
  350. package/core/models/wordpress/category/wpCategory.model.ts +15 -0
  351. package/core/models/wordpress/category/wpCategoryRequestParams.model.ts +9 -0
  352. package/core/models/wordpress/flexiblecontent/flexiblecontent.model.ts +4 -0
  353. package/core/models/wordpress/general/content.model.ts +4 -0
  354. package/core/models/wordpress/general/excerpt.model.ts +4 -0
  355. package/core/models/wordpress/general/featuredMedia.model.ts +27 -0
  356. package/core/models/wordpress/general/guid.model.ts +3 -0
  357. package/core/models/wordpress/general/index.ts +10 -0
  358. package/core/models/wordpress/general/links.model.ts +47 -0
  359. package/core/models/wordpress/general/meta.model.ts +3 -0
  360. package/core/models/wordpress/general/title.model.ts +3 -0
  361. package/core/models/wordpress/general/yoastData.model.ts +4 -0
  362. package/core/models/wordpress/general/yoastHeadJson.model.ts +55 -0
  363. package/core/models/wordpress/general/yoastMeta.model.ts +5 -0
  364. package/core/models/wordpress/page/page.model.ts +11 -0
  365. package/core/models/wordpress/page/pageRequestParams.model.ts +11 -0
  366. package/core/models/wordpress/post/post.model.ts +37 -0
  367. package/core/models/wordpress/post/postRequestParams.model.ts +23 -0
  368. package/core/models/wordpress/unidade/wp-unidade-onco.model.ts +62 -0
  369. package/core/models/wordpress/unidade/wp-unidade-site-detalhe.model.ts +173 -0
  370. package/core/models/wordpress/unidade/wp-unidade-site.model.ts +48 -0
  371. package/core/ng-package.json +6 -0
  372. package/core/public-api.ts +79 -0
  373. package/core/services/error/error.service.spec.ts +16 -0
  374. package/core/services/error/error.service.ts +10 -0
  375. package/core/services/geoloc/geoloc.service.spec.ts +16 -0
  376. package/core/services/geoloc/geoloc.service.ts +225 -0
  377. package/core/services/http-client/http-client.service.spec.ts +16 -0
  378. package/core/services/http-client/http-client.service.ts +49 -0
  379. package/core/services/log/log.service.spec.ts +16 -0
  380. package/core/services/log/log.service.ts +36 -0
  381. package/core/services/mapbox/mapbox.service.spec.ts +16 -0
  382. package/core/services/mapbox/mapbox.service.ts +84 -0
  383. package/core/services/modal/modal.service.spec.ts +16 -0
  384. package/core/services/modal/modal.service.ts +124 -0
  385. package/core/services/modal-drawer/modal-drawer.service.spec.ts +16 -0
  386. package/core/services/modal-drawer/modal-drawer.service.ts +104 -0
  387. package/core/services/phone/phone.service.spec.ts +16 -0
  388. package/core/services/phone/phone.service.ts +19 -0
  389. package/core/services/privacy-tools/privacy-tools.service.spec.ts +16 -0
  390. package/core/services/privacy-tools/privacy-tools.service.ts +96 -0
  391. package/core/services/seo/seo.service.spec.ts +16 -0
  392. package/core/services/seo/seo.service.ts +537 -0
  393. package/core/services/server-response/server-response.service.spec.ts +16 -0
  394. package/core/services/server-response/server-response.service.ts +107 -0
  395. package/core/services/site-back-end/site-back-end.service.spec.ts +16 -0
  396. package/core/services/site-back-end/site-back-end.service.ts +48 -0
  397. package/core/services/ssr-response/ssr-response.service.spec.ts +16 -0
  398. package/core/services/ssr-response/ssr-response.service.ts +57 -0
  399. package/core/tokens/LibConfig.ts +64 -0
  400. package/core/tokens/express.tokens.ts +5 -0
  401. package/cura/accordion/cura-accordion/cura-accordion.component.html +1 -0
  402. package/cura/accordion/cura-accordion/cura-accordion.component.scss +7 -0
  403. package/cura/accordion/cura-accordion/cura-accordion.component.ts +203 -0
  404. package/cura/accordion/cura-accordion-item/cura-accordion-item.component.html +20 -0
  405. package/cura/accordion/cura-accordion-item/cura-accordion-item.component.scss +139 -0
  406. package/cura/accordion/cura-accordion-item/cura-accordion-item.component.ts +75 -0
  407. package/cura/accordion/cura-accordion.definitions.ts +5 -0
  408. package/cura/accordion/index.ts +1 -0
  409. package/cura/accordion/ng-package.json +6 -0
  410. package/cura/accordion/public-api.ts +3 -0
  411. package/cura/api/CuraConfig.ts +5 -0
  412. package/cura/api/cura-api.service.spec.ts +138 -0
  413. package/cura/api/cura-api.service.ts +104 -0
  414. package/cura/api/cura-api.types.ts +79 -0
  415. package/cura/api/index.ts +1 -0
  416. package/cura/api/modules/cura-theme-breakpoints.module.ts +22 -0
  417. package/cura/api/modules/cura-theme-colors.module.ts +89 -0
  418. package/cura/api/modules/cura-theme-fonts.module.ts +54 -0
  419. package/cura/api/modules/cura-theme-spacing.module.ts +23 -0
  420. package/cura/api/modules/cura-theme.module.ts +116 -0
  421. package/cura/api/ng-package.json +6 -0
  422. package/cura/api/public-api.ts +11 -0
  423. package/cura/api/theme-presets/static.ts +70 -0
  424. package/cura/api/theme-presets/theme-default.ts +49 -0
  425. package/cura/api/theme-presets/theme-maternidade-star.ts +49 -0
  426. package/cura/api/theme-presets/theme-presets.ts +13 -0
  427. package/cura/api/theme-presets/theme-star.ts +49 -0
  428. package/cura/badges/cura-badge-counter/cura-badge-counter.component.html +7 -0
  429. package/cura/badges/cura-badge-counter/cura-badge-counter.component.scss +41 -0
  430. package/cura/badges/cura-badge-counter/cura-badge-counter.component.ts +94 -0
  431. package/cura/badges/cura-badge-counter/index.ts +1 -0
  432. package/cura/badges/cura-badge-counter/ng-package.json +6 -0
  433. package/cura/badges/cura-badge-counter/public-api.ts +1 -0
  434. package/cura/badges/cura-badge-distance/cura-badge-distance.component.html +8 -0
  435. package/cura/badges/cura-badge-distance/cura-badge-distance.component.scss +16 -0
  436. package/cura/badges/cura-badge-distance/cura-badge-distance.component.ts +53 -0
  437. package/cura/badges/cura-badge-distance/index.ts +1 -0
  438. package/cura/badges/cura-badge-distance/ng-package.json +6 -0
  439. package/cura/badges/cura-badge-distance/public-api.ts +1 -0
  440. package/cura/badges/cura-badge-dot/cura-badge-dot.component.html +1 -0
  441. package/cura/badges/cura-badge-dot/cura-badge-dot.component.scss +50 -0
  442. package/cura/badges/cura-badge-dot/cura-badge-dot.component.ts +69 -0
  443. package/cura/badges/cura-badge-dot/index.ts +1 -0
  444. package/cura/badges/cura-badge-dot/ng-package.json +6 -0
  445. package/cura/badges/cura-badge-dot/public-api.ts +1 -0
  446. package/cura/badges/cura-badge-pill/cura-badge-pill.component.html +8 -0
  447. package/cura/badges/cura-badge-pill/cura-badge-pill.component.scss +74 -0
  448. package/cura/badges/cura-badge-pill/cura-badge-pill.component.ts +105 -0
  449. package/cura/badges/cura-badge-pill/index.ts +1 -0
  450. package/cura/badges/cura-badge-pill/ng-package.json +6 -0
  451. package/cura/badges/cura-badge-pill/public-api.ts +1 -0
  452. package/cura/badges/cura-badges.definitions.ts +5 -0
  453. package/cura/badges/index.ts +1 -0
  454. package/cura/badges/ng-package.json +6 -0
  455. package/cura/badges/public-api.ts +1 -0
  456. package/cura/buttons/cura-button/cura-button.component.html +47 -0
  457. package/cura/buttons/cura-button/cura-button.component.scss +66 -0
  458. package/cura/buttons/cura-button/cura-button.component.spec.ts +105 -0
  459. package/cura/buttons/cura-button/cura-button.component.ts +184 -0
  460. package/cura/buttons/cura-button/index.ts +1 -0
  461. package/cura/buttons/cura-button/ng-package.json +6 -0
  462. package/cura/buttons/cura-button/public-api.ts +1 -0
  463. package/cura/buttons/cura-button-outline/cura-button-outline.component.html +47 -0
  464. package/cura/buttons/cura-button-outline/cura-button-outline.component.scss +55 -0
  465. package/cura/buttons/cura-button-outline/cura-button-outline.component.spec.ts +57 -0
  466. package/cura/buttons/cura-button-outline/cura-button-outline.component.ts +184 -0
  467. package/cura/buttons/cura-button-outline/index.ts +1 -0
  468. package/cura/buttons/cura-button-outline/ng-package.json +6 -0
  469. package/cura/buttons/cura-button-outline/public-api.ts +1 -0
  470. package/cura/buttons/cura-button-select/cura-button-select.component.html +27 -0
  471. package/cura/buttons/cura-button-select/cura-button-select.component.scss +76 -0
  472. package/cura/buttons/cura-button-select/cura-button-select.component.spec.ts +96 -0
  473. package/cura/buttons/cura-button-select/cura-button-select.component.ts +140 -0
  474. package/cura/buttons/cura-button-select/index.ts +1 -0
  475. package/cura/buttons/cura-button-select/ng-package.json +6 -0
  476. package/cura/buttons/cura-button-select/public-api.ts +1 -0
  477. package/cura/buttons/cura-button-transparent/cura-button-transparent.component.html +47 -0
  478. package/cura/buttons/cura-button-transparent/cura-button-transparent.component.scss +29 -0
  479. package/cura/buttons/cura-button-transparent/cura-button-transparent.component.spec.ts +63 -0
  480. package/cura/buttons/cura-button-transparent/cura-button-transparent.component.ts +172 -0
  481. package/cura/buttons/cura-button-transparent/index.ts +1 -0
  482. package/cura/buttons/cura-button-transparent/ng-package.json +6 -0
  483. package/cura/buttons/cura-button-transparent/public-api.ts +1 -0
  484. package/cura/buttons/cura-button.definitions.ts +13 -0
  485. package/cura/buttons/index.ts +1 -0
  486. package/cura/buttons/ng-package.json +6 -0
  487. package/cura/buttons/public-api.ts +1 -0
  488. package/cura/cards/cura-card/cura-card.component.html +11 -0
  489. package/cura/cards/cura-card/cura-card.component.scss +167 -0
  490. package/cura/cards/cura-card/cura-card.component.ts +89 -0
  491. package/cura/cards/cura-card/cura-cards.definitions.ts +5 -0
  492. package/cura/cards/cura-card/index.ts +1 -0
  493. package/cura/cards/cura-card/ng-package.json +6 -0
  494. package/cura/cards/cura-card/public-api.ts +1 -0
  495. package/cura/feedback/cura-alert/cura-alert.component.html +21 -0
  496. package/cura/feedback/cura-alert/cura-alert.component.scss +32 -0
  497. package/cura/feedback/cura-alert/cura-alert.component.ts +94 -0
  498. package/cura/feedback/cura-alert/cura-alert.definitions.ts +15 -0
  499. package/cura/feedback/cura-alert/index.ts +1 -0
  500. package/cura/feedback/cura-alert/ng-package.json +6 -0
  501. package/cura/feedback/cura-alert/public-api.ts +2 -0
  502. package/cura/feedback/cura-modal/cura-modal.component.html +20 -0
  503. package/cura/feedback/cura-modal/cura-modal.component.scss +149 -0
  504. package/cura/feedback/cura-modal/cura-modal.component.ts +112 -0
  505. package/cura/feedback/cura-modal/cura-modal.definitions.ts +36 -0
  506. package/cura/feedback/cura-modal/index.ts +1 -0
  507. package/cura/feedback/cura-modal/ng-package.json +6 -0
  508. package/cura/feedback/cura-modal/public-api.ts +2 -0
  509. package/cura/feedback/cura-toast/cura-toast.component.html +23 -0
  510. package/cura/feedback/cura-toast/cura-toast.component.scss +96 -0
  511. package/cura/feedback/cura-toast/cura-toast.component.ts +213 -0
  512. package/cura/feedback/cura-toast/cura-toast.definitions.ts +22 -0
  513. package/cura/feedback/cura-toast/index.ts +1 -0
  514. package/cura/feedback/cura-toast/ng-package.json +6 -0
  515. package/cura/feedback/cura-toast/public-api.ts +2 -0
  516. package/cura/forms/cura-checkbox/cura-checkbox.component.html +35 -0
  517. package/cura/forms/cura-checkbox/cura-checkbox.component.scss +219 -0
  518. package/cura/forms/cura-checkbox/cura-checkbox.component.ts +284 -0
  519. package/cura/forms/cura-checkbox/cura-checkbox.definitions.ts +44 -0
  520. package/cura/forms/cura-checkbox/index.ts +1 -0
  521. package/cura/forms/cura-checkbox/ng-package.json +6 -0
  522. package/cura/forms/cura-checkbox/public-api.ts +2 -0
  523. package/cura/forms/cura-forms.definitions.ts +18 -0
  524. package/cura/forms/cura-input-text/cura-input-text.component.html +65 -0
  525. package/cura/forms/cura-input-text/cura-input-text.component.scss +165 -0
  526. package/cura/forms/cura-input-text/cura-input-text.component.ts +621 -0
  527. package/cura/forms/cura-input-text/cura-input-text.definitions.ts +104 -0
  528. package/cura/forms/cura-input-text/index.ts +1 -0
  529. package/cura/forms/cura-input-text/ng-package.json +6 -0
  530. package/cura/forms/cura-input-text/public-api.ts +2 -0
  531. package/cura/forms/cura-label/cura-label.component.html +3 -0
  532. package/cura/forms/cura-label/cura-label.component.scss +68 -0
  533. package/cura/forms/cura-label/cura-label.component.ts +93 -0
  534. package/cura/forms/cura-label/index.ts +1 -0
  535. package/cura/forms/cura-label/ng-package.json +6 -0
  536. package/cura/forms/cura-label/public-api.ts +1 -0
  537. package/cura/forms/cura-radio/cura-radio.component.html +28 -0
  538. package/cura/forms/cura-radio/cura-radio.component.scss +232 -0
  539. package/cura/forms/cura-radio/cura-radio.component.ts +261 -0
  540. package/cura/forms/cura-radio/cura-radio.definitions.ts +46 -0
  541. package/cura/forms/cura-radio/index.ts +1 -0
  542. package/cura/forms/cura-radio/ng-package.json +6 -0
  543. package/cura/forms/cura-radio/public-api.ts +2 -0
  544. package/cura/forms/cura-select/cura-select.component.html +88 -0
  545. package/cura/forms/cura-select/cura-select.component.scss +112 -0
  546. package/cura/forms/cura-select/cura-select.component.ts +459 -0
  547. package/cura/forms/cura-select/cura-select.definitions.ts +34 -0
  548. package/cura/forms/cura-select/index.ts +1 -0
  549. package/cura/forms/cura-select/ng-package.json +6 -0
  550. package/cura/forms/cura-select/public-api.ts +2 -0
  551. package/cura/forms/cura-select-option/cura-select-option.component.html +9 -0
  552. package/cura/forms/cura-select-option/cura-select-option.component.scss +33 -0
  553. package/cura/forms/cura-select-option/cura-select-option.component.ts +93 -0
  554. package/cura/forms/cura-select-option/cura-select-option.definitions.ts +12 -0
  555. package/cura/forms/cura-select-option/index.ts +1 -0
  556. package/cura/forms/cura-select-option/ng-package.json +6 -0
  557. package/cura/forms/cura-select-option/public-api.ts +2 -0
  558. package/cura/forms/cura-select-state/cura-select-state.component.html +14 -0
  559. package/cura/forms/cura-select-state/cura-select-state.component.ts +125 -0
  560. package/cura/forms/cura-select-state/cura-select-state.definitions.ts +19 -0
  561. package/cura/forms/cura-select-state/index.ts +1 -0
  562. package/cura/forms/cura-select-state/ng-package.json +6 -0
  563. package/cura/forms/cura-select-state/public-api.ts +2 -0
  564. package/cura/forms/cura-switch/cura-switch.component.html +25 -0
  565. package/cura/forms/cura-switch/cura-switch.component.scss +134 -0
  566. package/cura/forms/cura-switch/cura-switch.component.ts +196 -0
  567. package/cura/forms/cura-switch/cura-switch.definitions.ts +35 -0
  568. package/cura/forms/cura-switch/index.ts +1 -0
  569. package/cura/forms/cura-switch/ng-package.json +6 -0
  570. package/cura/forms/cura-switch/public-api.ts +2 -0
  571. package/cura/forms/cura-textarea/cura-textarea.component.html +44 -0
  572. package/cura/forms/cura-textarea/cura-textarea.component.scss +173 -0
  573. package/cura/forms/cura-textarea/cura-textarea.component.ts +226 -0
  574. package/cura/forms/cura-textarea/cura-textarea.definitions.ts +24 -0
  575. package/cura/forms/cura-textarea/index.ts +1 -0
  576. package/cura/forms/cura-textarea/ng-package.json +6 -0
  577. package/cura/forms/cura-textarea/public-api.ts +2 -0
  578. package/cura/forms/index.ts +1 -0
  579. package/cura/forms/ng-package.json +6 -0
  580. package/cura/forms/public-api.ts +1 -0
  581. package/cura/icons/cura-icon/cura-icon.component.html +3 -0
  582. package/cura/icons/cura-icon/cura-icon.component.scss +14 -0
  583. package/cura/icons/cura-icon/cura-icon.component.spec.ts +89 -0
  584. package/cura/icons/cura-icon/cura-icon.component.ts +79 -0
  585. package/cura/icons/cura-icon/cura-icon.definitions.ts +20 -0
  586. package/cura/icons/cura-icon/index.ts +1 -0
  587. package/cura/icons/cura-icon/ng-package.json +6 -0
  588. package/cura/icons/cura-icon/public-api.ts +2 -0
  589. package/cura/loaders/cura-loader-bar/cura-loader-bar.component.html +3 -0
  590. package/cura/loaders/cura-loader-bar/cura-loader-bar.component.scss +23 -0
  591. package/cura/loaders/cura-loader-bar/cura-loader-bar.component.ts +37 -0
  592. package/cura/loaders/cura-loader-bar/index.ts +1 -0
  593. package/cura/loaders/cura-loader-bar/ng-package.json +6 -0
  594. package/cura/loaders/cura-loader-bar/public-api.ts +1 -0
  595. package/cura/loaders/cura-loader-circle/cura-loader-circle.component.html +12 -0
  596. package/cura/loaders/cura-loader-circle/cura-loader-circle.component.scss +39 -0
  597. package/cura/loaders/cura-loader-circle/cura-loader-circle.component.ts +45 -0
  598. package/cura/loaders/cura-loader-circle/index.ts +1 -0
  599. package/cura/loaders/cura-loader-circle/ng-package.json +6 -0
  600. package/cura/loaders/cura-loader-circle/public-api.ts +1 -0
  601. package/cura/scss/mixins/buttons.scss +244 -0
  602. package/cura/scss/mixins/forms.scss +298 -0
  603. package/cura/scss/mixins/responsive.scss +69 -0
  604. package/cura/scss/mixins/shadows.scss +71 -0
  605. package/cura/scss/mixins/spacing.scss +33 -0
  606. package/cura/scss/mixins/text.scss +11 -0
  607. package/cura/texts/cura-display/cura-display.component.html +41 -0
  608. package/cura/texts/cura-display/cura-display.component.scss +91 -0
  609. package/cura/texts/cura-display/cura-display.component.ts +85 -0
  610. package/cura/texts/cura-display/index.ts +1 -0
  611. package/cura/texts/cura-display/ng-package.json +6 -0
  612. package/cura/texts/cura-display/public-api.ts +1 -0
  613. package/cura/texts/cura-heading/cura-heading.component.html +41 -0
  614. package/cura/texts/cura-heading/cura-heading.component.scss +160 -0
  615. package/cura/texts/cura-heading/cura-heading.component.ts +111 -0
  616. package/cura/texts/cura-heading/index.ts +1 -0
  617. package/cura/texts/cura-heading/ng-package.json +6 -0
  618. package/cura/texts/cura-heading/public-api.ts +1 -0
  619. package/cura/texts/cura-paragraph/cura-paragraph.component.html +3 -0
  620. package/cura/texts/cura-paragraph/cura-paragraph.component.scss +130 -0
  621. package/cura/texts/cura-paragraph/cura-paragraph.component.ts +94 -0
  622. package/cura/texts/cura-paragraph/index.ts +1 -0
  623. package/cura/texts/cura-paragraph/ng-package.json +6 -0
  624. package/cura/texts/cura-paragraph/public-api.ts +1 -0
  625. package/cura/texts/cura-texts.definitions.ts +9 -0
  626. package/cura/texts/index.ts +1 -0
  627. package/cura/texts/ng-package.json +6 -0
  628. package/cura/texts/public-api.ts +1 -0
  629. package/enums/EnumError.enum.ts +4 -0
  630. package/enums/EnumThemes.enum.ts +8 -0
  631. package/enums/Estados.enum.ts +29 -0
  632. package/enums/IconCuraDefaultType.enum.ts +119 -0
  633. package/enums/ImageMimeType.enum.ts +5 -0
  634. package/enums/UnidadeCoverageType.enum.ts +5 -0
  635. package/enums/index.ts +1 -0
  636. package/enums/ng-package.json +6 -0
  637. package/enums/public-api.ts +6 -0
  638. package/ng-package.json +8 -0
  639. package/package.json +9 -312
  640. package/services/algolia/algolia.service.spec.ts +16 -0
  641. package/services/algolia/algolia.service.ts +36 -0
  642. package/services/algolia/index.ts +1 -0
  643. package/services/algolia/ng-package.json +6 -0
  644. package/services/algolia/public-api.ts +1 -0
  645. package/services/algolia-search-api/algolia-search-api.service.spec.ts +16 -0
  646. package/services/algolia-search-api/algolia-search-api.service.ts +72 -0
  647. package/services/algolia-search-api/index.ts +1 -0
  648. package/services/algolia-search-api/ng-package.json +6 -0
  649. package/services/algolia-search-api/public-api.ts +1 -0
  650. package/services/ngu-carousel/index.ts +1 -0
  651. package/services/ngu-carousel/ng-package.json +6 -0
  652. package/services/ngu-carousel/ngu-carousel.service.spec.ts +16 -0
  653. package/services/ngu-carousel/ngu-carousel.service.ts +80 -0
  654. package/services/ngu-carousel/public-api.ts +1 -0
  655. package/services/ssr-loading/index.ts +1 -0
  656. package/services/ssr-loading/ng-package.json +6 -0
  657. package/services/ssr-loading/public-api.ts +1 -0
  658. package/services/ssr-loading/ssr-loading.service.spec.ts +16 -0
  659. package/services/ssr-loading/ssr-loading.service.ts +41 -0
  660. package/services/transfer-state/index.ts +1 -0
  661. package/services/transfer-state/ng-package.json +6 -0
  662. package/services/transfer-state/public-api.ts +1 -0
  663. package/services/transfer-state/transfer-state.service.spec.ts +16 -0
  664. package/services/transfer-state/transfer-state.service.ts +38 -0
  665. package/services/youtube/index.ts +1 -0
  666. package/services/youtube/ng-package.json +6 -0
  667. package/services/youtube/public-api.ts +1 -0
  668. package/services/youtube/youtube.service.spec.ts +16 -0
  669. package/services/youtube/youtube.service.ts +28 -0
  670. package/shared/directives/rdsite-click-outside/rdsite-click-outside.directive.spec.ts +8 -0
  671. package/shared/directives/rdsite-click-outside/rdsite-click-outside.directive.ts +18 -0
  672. package/shared/helpers/clean-text.func.ts +15 -0
  673. package/shared/helpers/mediaQueries.ts +11 -0
  674. package/shared/helpers/removeDuplicateObjectsFromArray.func.ts +5 -0
  675. package/shared/helpers/removeDuplicateValuesFromArray.func.ts +5 -0
  676. package/shared/helpers/stringToSlug.func.ts +32 -0
  677. package/shared/index.ts +1 -0
  678. package/shared/ng-package.json +6 -0
  679. package/shared/pipes/phone/phone.pipe.spec.ts +8 -0
  680. package/shared/pipes/phone/phone.pipe.ts +11 -0
  681. package/shared/public-api.ts +9 -0
  682. package/src/public-api.ts +5 -0
  683. package/styles/_mixins.scss +49 -0
  684. package/styles/_utilities.scss +22 -0
  685. package/tsconfig.lib.json +13 -0
  686. package/tsconfig.lib.prod.json +10 -0
  687. package/tsconfig.spec.json +14 -0
  688. package/components/algolia-dropdown/index.d.ts +0 -38
  689. package/components/algolia-search/index.d.ts +0 -304
  690. package/components/banner/index.d.ts +0 -20
  691. package/components/breadcrumbs/index.d.ts +0 -42
  692. package/components/cards/index.d.ts +0 -102
  693. package/components/carousels/index.d.ts +0 -28
  694. package/components/cta-wrapper/index.d.ts +0 -33
  695. package/components/error/index.d.ts +0 -47
  696. package/components/filter-letter-and-terms/index.d.ts +0 -38
  697. package/components/filters/filter-generic/index.d.ts +0 -70
  698. package/components/filters/filter-planos-convenios/index.d.ts +0 -41
  699. package/components/footer/index.d.ts +0 -44
  700. package/components/header/components/action/index.d.ts +0 -17
  701. package/components/header/components/auxiliar/index.d.ts +0 -31
  702. package/components/header/components/main/index.d.ts +0 -72
  703. package/components/header/components/side/index.d.ts +0 -35
  704. package/components/header/index.d.ts +0 -63
  705. package/components/header/services/index.d.ts +0 -14
  706. package/components/image/index.d.ts +0 -23
  707. package/components/load-screen/index.d.ts +0 -14
  708. package/components/modal/index.d.ts +0 -28
  709. package/components/modal-drawer/index.d.ts +0 -46
  710. package/components/overlay/index.d.ts +0 -10
  711. package/components/page-header/index.d.ts +0 -30
  712. package/components/page-template-fullcontent/index.d.ts +0 -17
  713. package/components/page-template-sidebar/index.d.ts +0 -20
  714. package/components/pagination/index.d.ts +0 -30
  715. package/components/search/index.d.ts +0 -45
  716. package/components/section-navigation/index.d.ts +0 -45
  717. package/components/side-ctas/index.d.ts +0 -70
  718. package/components/sidebar-navigation/index.d.ts +0 -40
  719. package/components/sticky-navigation/index.d.ts +0 -42
  720. package/components/whatsapp/index.d.ts +0 -27
  721. package/core/index.d.ts +0 -2049
  722. package/cura/accordion/index.d.ts +0 -120
  723. package/cura/api/index.d.ts +0 -359
  724. package/cura/badges/cura-badge-counter/index.d.ts +0 -38
  725. package/cura/badges/cura-badge-distance/index.d.ts +0 -21
  726. package/cura/badges/cura-badge-dot/index.d.ts +0 -29
  727. package/cura/badges/cura-badge-pill/index.d.ts +0 -42
  728. package/cura/badges/index.d.ts +0 -5
  729. package/cura/buttons/cura-button/index.d.ts +0 -90
  730. package/cura/buttons/cura-button-outline/index.d.ts +0 -90
  731. package/cura/buttons/cura-button-select/index.d.ts +0 -39
  732. package/cura/buttons/cura-button-transparent/index.d.ts +0 -87
  733. package/cura/buttons/index.d.ts +0 -15
  734. package/cura/cards/cura-card/index.d.ts +0 -49
  735. package/cura/feedback/cura-alert/index.d.ts +0 -55
  736. package/cura/feedback/cura-modal/index.d.ts +0 -97
  737. package/cura/feedback/cura-toast/index.d.ts +0 -104
  738. package/cura/forms/cura-checkbox/index.d.ts +0 -157
  739. package/cura/forms/cura-input-text/index.d.ts +0 -236
  740. package/cura/forms/cura-label/index.d.ts +0 -47
  741. package/cura/forms/cura-radio/index.d.ts +0 -148
  742. package/cura/forms/cura-select/index.d.ts +0 -155
  743. package/cura/forms/cura-select-option/index.d.ts +0 -54
  744. package/cura/forms/cura-select-state/index.d.ts +0 -72
  745. package/cura/forms/cura-switch/index.d.ts +0 -113
  746. package/cura/forms/cura-textarea/index.d.ts +0 -113
  747. package/cura/forms/index.d.ts +0 -20
  748. package/cura/icons/cura-icon/index.d.ts +0 -46
  749. package/cura/loaders/cura-loader-bar/index.d.ts +0 -22
  750. package/cura/loaders/cura-loader-circle/index.d.ts +0 -24
  751. package/cura/texts/cura-display/index.d.ts +0 -54
  752. package/cura/texts/cura-heading/index.d.ts +0 -65
  753. package/cura/texts/cura-paragraph/index.d.ts +0 -54
  754. package/cura/texts/index.d.ts +0 -7
  755. package/enums/index.d.ts +0 -177
  756. package/fesm2022/rededor-site-front-end-lib-components-algolia-dropdown.mjs +0 -108
  757. package/fesm2022/rededor-site-front-end-lib-components-algolia-dropdown.mjs.map +0 -1
  758. package/fesm2022/rededor-site-front-end-lib-components-algolia-search.mjs +0 -604
  759. package/fesm2022/rededor-site-front-end-lib-components-algolia-search.mjs.map +0 -1
  760. package/fesm2022/rededor-site-front-end-lib-components-banner.mjs +0 -44
  761. package/fesm2022/rededor-site-front-end-lib-components-banner.mjs.map +0 -1
  762. package/fesm2022/rededor-site-front-end-lib-components-breadcrumbs.mjs +0 -120
  763. package/fesm2022/rededor-site-front-end-lib-components-breadcrumbs.mjs.map +0 -1
  764. package/fesm2022/rededor-site-front-end-lib-components-cards.mjs +0 -178
  765. package/fesm2022/rededor-site-front-end-lib-components-cards.mjs.map +0 -1
  766. package/fesm2022/rededor-site-front-end-lib-components-carousels.mjs +0 -75
  767. package/fesm2022/rededor-site-front-end-lib-components-carousels.mjs.map +0 -1
  768. package/fesm2022/rededor-site-front-end-lib-components-cta-wrapper.mjs +0 -78
  769. package/fesm2022/rededor-site-front-end-lib-components-cta-wrapper.mjs.map +0 -1
  770. package/fesm2022/rededor-site-front-end-lib-components-error.mjs +0 -176
  771. package/fesm2022/rededor-site-front-end-lib-components-error.mjs.map +0 -1
  772. package/fesm2022/rededor-site-front-end-lib-components-filter-letter-and-terms.mjs +0 -93
  773. package/fesm2022/rededor-site-front-end-lib-components-filter-letter-and-terms.mjs.map +0 -1
  774. package/fesm2022/rededor-site-front-end-lib-components-filters-filter-generic.mjs +0 -245
  775. package/fesm2022/rededor-site-front-end-lib-components-filters-filter-generic.mjs.map +0 -1
  776. package/fesm2022/rededor-site-front-end-lib-components-filters-filter-planos-convenios.mjs +0 -139
  777. package/fesm2022/rededor-site-front-end-lib-components-filters-filter-planos-convenios.mjs.map +0 -1
  778. package/fesm2022/rededor-site-front-end-lib-components-footer.mjs +0 -199
  779. package/fesm2022/rededor-site-front-end-lib-components-footer.mjs.map +0 -1
  780. package/fesm2022/rededor-site-front-end-lib-components-header-components-action.mjs +0 -34
  781. package/fesm2022/rededor-site-front-end-lib-components-header-components-action.mjs.map +0 -1
  782. package/fesm2022/rededor-site-front-end-lib-components-header-components-auxiliar.mjs +0 -62
  783. package/fesm2022/rededor-site-front-end-lib-components-header-components-auxiliar.mjs.map +0 -1
  784. package/fesm2022/rededor-site-front-end-lib-components-header-components-main.mjs +0 -167
  785. package/fesm2022/rededor-site-front-end-lib-components-header-components-main.mjs.map +0 -1
  786. package/fesm2022/rededor-site-front-end-lib-components-header-components-side.mjs +0 -71
  787. package/fesm2022/rededor-site-front-end-lib-components-header-components-side.mjs.map +0 -1
  788. package/fesm2022/rededor-site-front-end-lib-components-header-services.mjs +0 -50
  789. package/fesm2022/rededor-site-front-end-lib-components-header-services.mjs.map +0 -1
  790. package/fesm2022/rededor-site-front-end-lib-components-header.mjs +0 -416
  791. package/fesm2022/rededor-site-front-end-lib-components-header.mjs.map +0 -1
  792. package/fesm2022/rededor-site-front-end-lib-components-image.mjs +0 -48
  793. package/fesm2022/rededor-site-front-end-lib-components-image.mjs.map +0 -1
  794. package/fesm2022/rededor-site-front-end-lib-components-load-screen.mjs +0 -30
  795. package/fesm2022/rededor-site-front-end-lib-components-load-screen.mjs.map +0 -1
  796. package/fesm2022/rededor-site-front-end-lib-components-modal-drawer.mjs +0 -145
  797. package/fesm2022/rededor-site-front-end-lib-components-modal-drawer.mjs.map +0 -1
  798. package/fesm2022/rededor-site-front-end-lib-components-modal.mjs +0 -82
  799. package/fesm2022/rededor-site-front-end-lib-components-modal.mjs.map +0 -1
  800. package/fesm2022/rededor-site-front-end-lib-components-overlay.mjs +0 -24
  801. package/fesm2022/rededor-site-front-end-lib-components-overlay.mjs.map +0 -1
  802. package/fesm2022/rededor-site-front-end-lib-components-page-header.mjs +0 -52
  803. package/fesm2022/rededor-site-front-end-lib-components-page-header.mjs.map +0 -1
  804. package/fesm2022/rededor-site-front-end-lib-components-page-template-fullcontent.mjs +0 -27
  805. package/fesm2022/rededor-site-front-end-lib-components-page-template-fullcontent.mjs.map +0 -1
  806. package/fesm2022/rededor-site-front-end-lib-components-page-template-sidebar.mjs +0 -30
  807. package/fesm2022/rededor-site-front-end-lib-components-page-template-sidebar.mjs.map +0 -1
  808. package/fesm2022/rededor-site-front-end-lib-components-pagination.mjs +0 -55
  809. package/fesm2022/rededor-site-front-end-lib-components-pagination.mjs.map +0 -1
  810. package/fesm2022/rededor-site-front-end-lib-components-search.mjs +0 -119
  811. package/fesm2022/rededor-site-front-end-lib-components-search.mjs.map +0 -1
  812. package/fesm2022/rededor-site-front-end-lib-components-section-navigation.mjs +0 -141
  813. package/fesm2022/rededor-site-front-end-lib-components-section-navigation.mjs.map +0 -1
  814. package/fesm2022/rededor-site-front-end-lib-components-side-ctas.mjs +0 -118
  815. package/fesm2022/rededor-site-front-end-lib-components-side-ctas.mjs.map +0 -1
  816. package/fesm2022/rededor-site-front-end-lib-components-sidebar-navigation.mjs +0 -109
  817. package/fesm2022/rededor-site-front-end-lib-components-sidebar-navigation.mjs.map +0 -1
  818. package/fesm2022/rededor-site-front-end-lib-components-sticky-navigation.mjs +0 -120
  819. package/fesm2022/rededor-site-front-end-lib-components-sticky-navigation.mjs.map +0 -1
  820. package/fesm2022/rededor-site-front-end-lib-components-whatsapp.mjs +0 -49
  821. package/fesm2022/rededor-site-front-end-lib-components-whatsapp.mjs.map +0 -1
  822. package/fesm2022/rededor-site-front-end-lib-core.mjs +0 -1812
  823. package/fesm2022/rededor-site-front-end-lib-core.mjs.map +0 -1
  824. package/fesm2022/rededor-site-front-end-lib-cura-accordion.mjs +0 -252
  825. package/fesm2022/rededor-site-front-end-lib-cura-accordion.mjs.map +0 -1
  826. package/fesm2022/rededor-site-front-end-lib-cura-api.mjs +0 -643
  827. package/fesm2022/rededor-site-front-end-lib-cura-api.mjs.map +0 -1
  828. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-counter.mjs +0 -90
  829. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-counter.mjs.map +0 -1
  830. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-distance.mjs +0 -55
  831. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-distance.mjs.map +0 -1
  832. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-dot.mjs +0 -66
  833. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-dot.mjs.map +0 -1
  834. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-pill.mjs +0 -91
  835. package/fesm2022/rededor-site-front-end-lib-cura-badges-cura-badge-pill.mjs.map +0 -1
  836. package/fesm2022/rededor-site-front-end-lib-cura-badges.mjs +0 -4
  837. package/fesm2022/rededor-site-front-end-lib-cura-badges.mjs.map +0 -1
  838. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-outline.mjs +0 -170
  839. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-outline.mjs.map +0 -1
  840. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-select.mjs +0 -135
  841. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-select.mjs.map +0 -1
  842. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-transparent.mjs +0 -161
  843. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button-transparent.mjs.map +0 -1
  844. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button.mjs +0 -170
  845. package/fesm2022/rededor-site-front-end-lib-cura-buttons-cura-button.mjs.map +0 -1
  846. package/fesm2022/rededor-site-front-end-lib-cura-buttons.mjs +0 -13
  847. package/fesm2022/rededor-site-front-end-lib-cura-buttons.mjs.map +0 -1
  848. package/fesm2022/rededor-site-front-end-lib-cura-cards-cura-card.mjs +0 -72
  849. package/fesm2022/rededor-site-front-end-lib-cura-cards-cura-card.mjs.map +0 -1
  850. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-alert.mjs +0 -90
  851. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-alert.mjs.map +0 -1
  852. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-modal.mjs +0 -105
  853. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-modal.mjs.map +0 -1
  854. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-toast.mjs +0 -198
  855. package/fesm2022/rededor-site-front-end-lib-cura-feedback-cura-toast.mjs.map +0 -1
  856. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-checkbox.mjs +0 -258
  857. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-checkbox.mjs.map +0 -1
  858. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-input-text.mjs +0 -587
  859. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-input-text.mjs.map +0 -1
  860. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-label.mjs +0 -82
  861. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-label.mjs.map +0 -1
  862. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-radio.mjs +0 -243
  863. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-radio.mjs.map +0 -1
  864. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-select-option.mjs +0 -89
  865. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-select-option.mjs.map +0 -1
  866. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-select-state.mjs +0 -123
  867. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-select-state.mjs.map +0 -1
  868. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-select.mjs +0 -389
  869. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-select.mjs.map +0 -1
  870. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-switch.mjs +0 -182
  871. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-switch.mjs.map +0 -1
  872. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-textarea.mjs +0 -209
  873. package/fesm2022/rededor-site-front-end-lib-cura-forms-cura-textarea.mjs.map +0 -1
  874. package/fesm2022/rededor-site-front-end-lib-cura-forms.mjs +0 -21
  875. package/fesm2022/rededor-site-front-end-lib-cura-forms.mjs.map +0 -1
  876. package/fesm2022/rededor-site-front-end-lib-cura-icons-cura-icon.mjs +0 -88
  877. package/fesm2022/rededor-site-front-end-lib-cura-icons-cura-icon.mjs.map +0 -1
  878. package/fesm2022/rededor-site-front-end-lib-cura-loaders-cura-loader-bar.mjs +0 -44
  879. package/fesm2022/rededor-site-front-end-lib-cura-loaders-cura-loader-bar.mjs.map +0 -1
  880. package/fesm2022/rededor-site-front-end-lib-cura-loaders-cura-loader-circle.mjs +0 -49
  881. package/fesm2022/rededor-site-front-end-lib-cura-loaders-cura-loader-circle.mjs.map +0 -1
  882. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-display.mjs +0 -84
  883. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-display.mjs.map +0 -1
  884. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-heading.mjs +0 -104
  885. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-heading.mjs.map +0 -1
  886. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-paragraph.mjs +0 -89
  887. package/fesm2022/rededor-site-front-end-lib-cura-texts-cura-paragraph.mjs.map +0 -1
  888. package/fesm2022/rededor-site-front-end-lib-cura-texts.mjs +0 -4
  889. package/fesm2022/rededor-site-front-end-lib-cura-texts.mjs.map +0 -1
  890. package/fesm2022/rededor-site-front-end-lib-enums.mjs +0 -188
  891. package/fesm2022/rededor-site-front-end-lib-enums.mjs.map +0 -1
  892. package/fesm2022/rededor-site-front-end-lib-services-algolia-search-api.mjs +0 -74
  893. package/fesm2022/rededor-site-front-end-lib-services-algolia-search-api.mjs.map +0 -1
  894. package/fesm2022/rededor-site-front-end-lib-services-algolia.mjs +0 -41
  895. package/fesm2022/rededor-site-front-end-lib-services-algolia.mjs.map +0 -1
  896. package/fesm2022/rededor-site-front-end-lib-services-ngu-carousel.mjs +0 -88
  897. package/fesm2022/rededor-site-front-end-lib-services-ngu-carousel.mjs.map +0 -1
  898. package/fesm2022/rededor-site-front-end-lib-services-ssr-loading.mjs +0 -52
  899. package/fesm2022/rededor-site-front-end-lib-services-ssr-loading.mjs.map +0 -1
  900. package/fesm2022/rededor-site-front-end-lib-services-transfer-state.mjs +0 -49
  901. package/fesm2022/rededor-site-front-end-lib-services-transfer-state.mjs.map +0 -1
  902. package/fesm2022/rededor-site-front-end-lib-services-youtube.mjs +0 -40
  903. package/fesm2022/rededor-site-front-end-lib-services-youtube.mjs.map +0 -1
  904. package/fesm2022/rededor-site-front-end-lib-shared.mjs +0 -110
  905. package/fesm2022/rededor-site-front-end-lib-shared.mjs.map +0 -1
  906. package/fesm2022/rededor-site-front-end-lib.mjs +0 -11
  907. package/fesm2022/rededor-site-front-end-lib.mjs.map +0 -1
  908. package/index.d.ts +0 -3
  909. package/services/algolia/index.d.ts +0 -18
  910. package/services/algolia-search-api/index.d.ts +0 -17
  911. package/services/ngu-carousel/index.d.ts +0 -16
  912. package/services/ssr-loading/index.d.ts +0 -14
  913. package/services/transfer-state/index.d.ts +0 -13
  914. package/services/youtube/index.d.ts +0 -13
  915. package/shared/index.d.ts +0 -40
@@ -1,245 +0,0 @@
1
- import * as i1 from '@angular/common';
2
- import { isPlatformBrowser, CommonModule } from '@angular/common';
3
- import * as i0 from '@angular/core';
4
- import { inject, ChangeDetectorRef, PLATFORM_ID, output, input, model, signal, computed, HostBinding, Component } from '@angular/core';
5
- import { ReactiveFormsModule } from '@angular/forms';
6
- import { CuraApiService } from '@rededor/site-front-end-lib/cura/api';
7
- import { CuraBadgeCounterComponent } from '@rededor/site-front-end-lib/cura/badges/cura-badge-counter';
8
- import { CuraButtonComponent } from '@rededor/site-front-end-lib/cura/buttons/cura-button';
9
- import { CuraButtonTransparentComponent } from '@rededor/site-front-end-lib/cura/buttons/cura-button-transparent';
10
- import { CuraCheckboxComponent } from '@rededor/site-front-end-lib/cura/forms/cura-checkbox';
11
- import { CuraInputTextComponent } from '@rededor/site-front-end-lib/cura/forms/cura-input-text';
12
- import { CuraLabelComponent } from '@rededor/site-front-end-lib/cura/forms/cura-label';
13
- import { CuraRadioComponent } from '@rededor/site-front-end-lib/cura/forms/cura-radio';
14
- import { CuraSelectComponent } from '@rededor/site-front-end-lib/cura/forms/cura-select';
15
- import { CuraSelectOptionComponent } from '@rededor/site-front-end-lib/cura/forms/cura-select-option';
16
- import { CuraIconComponent } from '@rededor/site-front-end-lib/cura/icons/cura-icon';
17
- import { CuraHeadingComponent } from '@rededor/site-front-end-lib/cura/texts/cura-heading';
18
- import { CuraParagraphComponent } from '@rededor/site-front-end-lib/cura/texts/cura-paragraph';
19
- import { MediaQueries } from '@rededor/site-front-end-lib/shared';
20
-
21
- class FilterGenericComponent {
22
- constructor() {
23
- this.curaApiService = inject(CuraApiService);
24
- this.cdr = inject(ChangeDetectorRef);
25
- this.platformId = inject(PLATFORM_ID);
26
- this.filterChange = output();
27
- this.closeModal = output();
28
- this.openMobileFilter = output();
29
- this.withContainerStyle = input(true, ...(ngDevMode ? [{ debugName: "withContainerStyle" }] : []));
30
- this.showClearButton = input(true, ...(ngDevMode ? [{ debugName: "showClearButton" }] : []));
31
- this.showApplyButton = input(true, ...(ngDevMode ? [{ debugName: "showApplyButton" }] : []));
32
- this.showCloseButton = input(false, ...(ngDevMode ? [{ debugName: "showCloseButton" }] : []));
33
- this.disableButtons = input(false, ...(ngDevMode ? [{ debugName: "disableButtons" }] : []));
34
- this.showBadge = input(true, ...(ngDevMode ? [{ debugName: "showBadge" }] : []));
35
- this.showToggleIcon = input(true, ...(ngDevMode ? [{ debugName: "showToggleIcon" }] : []));
36
- this.isFilterOpen = model(true, ...(ngDevMode ? [{ debugName: "isFilterOpen" }] : []));
37
- this.mobileBehavior = input(false, ...(ngDevMode ? [{ debugName: "mobileBehavior" }] : []));
38
- this.forceCollapsed = input(false, ...(ngDevMode ? [{ debugName: "forceCollapsed" }] : []));
39
- this.emitOnReset = input(false, ...(ngDevMode ? [{ debugName: "emitOnReset" }] : []));
40
- this.textTitle = input('Filtrar por', ...(ngDevMode ? [{ debugName: "textTitle" }] : []));
41
- this.sections = input([], ...(ngDevMode ? [{ debugName: "sections" }] : []));
42
- this.windowWidth = signal(0, ...(ngDevMode ? [{ debugName: "windowWidth" }] : []));
43
- this.isStarTheme = input(false, ...(ngDevMode ? [{ debugName: "isStarTheme" }] : []));
44
- this.isMaternityStarTheme = input(false, ...(ngDevMode ? [{ debugName: "isMaternityStarTheme" }] : []));
45
- this.selectedFiltersCount = computed(() => {
46
- return this.sections().reduce((count, section) => {
47
- if ((section.type !== 'custom' && !section.config?.control) || (section.type === 'custom' && !section.config?.count))
48
- return count;
49
- const value = section.config.control?.value || null;
50
- switch (section.type) {
51
- case 'checkbox-group':
52
- return count + (Array.isArray(value) ? value.filter((item) => item?.checked).length : 0);
53
- case 'radio-group':
54
- return count + (value?.value ? 1 : 0);
55
- case 'custom':
56
- const customCount = section.config.count || 0;
57
- return count + customCount;
58
- default:
59
- return count + (value ? 1 : 0);
60
- }
61
- }, 0);
62
- }, ...(ngDevMode ? [{ debugName: "selectedFiltersCount" }] : []));
63
- this.styleBinding = {
64
- '--font-family': this.curaApiService.theme.fonts.getFamily(''),
65
- '--neutral-opacity-black': this.curaApiService.theme.colors.getColor('neutral-black', 0.2),
66
- '--neutral-dark': this.curaApiService.theme.colors.getColor('neutral-dark'),
67
- '--neutral-darker': this.curaApiService.theme.colors.getColor('neutral-darker'),
68
- '--neutral-medium': this.curaApiService.theme.colors.getColor('neutral-medium'),
69
- '--neutral-light': this.curaApiService.theme.colors.getColor('neutral-light'),
70
- '--neutral-lighter': this.curaApiService.theme.colors.getColor('neutral-lighter'),
71
- '--neutral-purewhite': this.curaApiService.theme.colors.getColor('neutral-purewhite'),
72
- '--primary-base': this.curaApiService.theme.colors.getColor('primary-base'),
73
- '--primary-lighter': this.curaApiService.theme.colors.getColor('primary-lighter'),
74
- };
75
- this.isMobile = computed(() => {
76
- return this.windowWidth() <= MediaQueries.smallBreakpoint;
77
- }, ...(ngDevMode ? [{ debugName: "isMobile" }] : []));
78
- }
79
- ngOnInit() {
80
- if (isPlatformBrowser(this.platformId)) {
81
- this.windowWidth.set(window.innerWidth);
82
- }
83
- if (this.forceCollapsed() && this.isMobile()) {
84
- this.isFilterOpen.set(false);
85
- }
86
- }
87
- handleInputChange(event, control) {
88
- control.setValue(event);
89
- }
90
- handleSelectChange({ value }, control) {
91
- if (value !== undefined) {
92
- control.setValue(value);
93
- }
94
- }
95
- handleCheckboxChange({ value, checked }, options) {
96
- const changedOption = options.find((opt) => opt.value === value);
97
- if (changedOption)
98
- changedOption.checked = checked;
99
- this.updateCheckboxGroup(options);
100
- }
101
- handleRadioChange({ value }, control) {
102
- const selectedValue = value;
103
- control.setValue(control.value?.value === selectedValue ? null : { value: selectedValue });
104
- }
105
- filter() {
106
- this.emitFilterChange('filter');
107
- if (this.mobileBehavior() || this.showCloseButton())
108
- this.close();
109
- }
110
- reset() {
111
- this.resetAllControls();
112
- if (this.emitOnReset()) {
113
- this.emitFilterChange('reset');
114
- this.close();
115
- }
116
- }
117
- close() {
118
- this.closeModal.emit(true);
119
- }
120
- toggleFilter() {
121
- if (this.mobileBehavior() && this.isMobile()) {
122
- this.openMobileFilter.emit(undefined);
123
- }
124
- else {
125
- this.isFilterOpen.set(!this.isFilterOpen());
126
- }
127
- this.cdr.detectChanges();
128
- }
129
- hasSelection() {
130
- return this.selectedFiltersCount() > 0;
131
- }
132
- getRadioGroupValue(control) {
133
- const value = control?.value;
134
- return value && typeof value === 'object' && 'value' in value ? value.value : null;
135
- }
136
- hasScroll(section) {
137
- switch (section.type) {
138
- case 'checkbox-group':
139
- return section.config.options && section.config.options.length > 6;
140
- case 'radio-group':
141
- return section.config.options && section.config.options.length > 6;
142
- default:
143
- return false;
144
- }
145
- }
146
- getSectionClass(section) {
147
- return this.hasScroll(section) ? 'scrollable' : '';
148
- }
149
- shouldHandleMobileClick() {
150
- return this.mobileBehavior() && this.isMobile() && this.forceCollapsed();
151
- }
152
- handleMobileClick() {
153
- if (this.shouldHandleMobileClick()) {
154
- this.openMobileFilter.emit();
155
- }
156
- }
157
- emitFilterChange(action) {
158
- const filterData = this.buildFilterData();
159
- const isEmpty = this.isFilterDataEmpty(filterData);
160
- this.filterChange.emit({
161
- data: this.emitOnReset() || !isEmpty ? filterData : null,
162
- action: action,
163
- });
164
- }
165
- resetAllControls() {
166
- this.sections().forEach((section) => {
167
- if (!section.config?.control)
168
- return;
169
- if (section.type === 'checkbox-group') {
170
- const resetOptions = section?.config?.options?.map((option) => ({ ...option, checked: false })) || [];
171
- section.config.options = resetOptions;
172
- section.config.control.setValue(resetOptions, { emitEvent: false });
173
- }
174
- else {
175
- section.config.control.reset('', { emitEvent: false });
176
- }
177
- });
178
- }
179
- updateCheckboxGroup(options) {
180
- this.sections()
181
- .filter((section) => section.type === 'checkbox-group')
182
- .forEach((section) => {
183
- section.config.options = [...options];
184
- section.config.control.setValue([...options]);
185
- });
186
- }
187
- buildFilterData() {
188
- const filterData = {
189
- unidade: '',
190
- estado: '',
191
- cobertura: [],
192
- };
193
- this.sections().forEach((section) => {
194
- if (!section.config?.control)
195
- return;
196
- const value = section.config.control.value;
197
- switch (section.type) {
198
- case 'input':
199
- filterData.unidade = value || '';
200
- break;
201
- case 'select':
202
- filterData.estado = value || '';
203
- break;
204
- case 'checkbox-group':
205
- filterData.cobertura = Array.isArray(value) ? value.filter((item) => item.checked) : [];
206
- break;
207
- }
208
- });
209
- return filterData;
210
- }
211
- isFilterDataEmpty(filterData) {
212
- return Object.values(filterData).every((val) => val === null || val === '' || (Array.isArray(val) && val.length === 0));
213
- }
214
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: FilterGenericComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
215
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.16", type: FilterGenericComponent, isStandalone: true, selector: "rdsite-filter-generic", inputs: { withContainerStyle: { classPropertyName: "withContainerStyle", publicName: "withContainerStyle", isSignal: true, isRequired: false, transformFunction: null }, showClearButton: { classPropertyName: "showClearButton", publicName: "showClearButton", isSignal: true, isRequired: false, transformFunction: null }, showApplyButton: { classPropertyName: "showApplyButton", publicName: "showApplyButton", isSignal: true, isRequired: false, transformFunction: null }, showCloseButton: { classPropertyName: "showCloseButton", publicName: "showCloseButton", isSignal: true, isRequired: false, transformFunction: null }, disableButtons: { classPropertyName: "disableButtons", publicName: "disableButtons", isSignal: true, isRequired: false, transformFunction: null }, showBadge: { classPropertyName: "showBadge", publicName: "showBadge", isSignal: true, isRequired: false, transformFunction: null }, showToggleIcon: { classPropertyName: "showToggleIcon", publicName: "showToggleIcon", isSignal: true, isRequired: false, transformFunction: null }, isFilterOpen: { classPropertyName: "isFilterOpen", publicName: "isFilterOpen", isSignal: true, isRequired: false, transformFunction: null }, mobileBehavior: { classPropertyName: "mobileBehavior", publicName: "mobileBehavior", isSignal: true, isRequired: false, transformFunction: null }, forceCollapsed: { classPropertyName: "forceCollapsed", publicName: "forceCollapsed", isSignal: true, isRequired: false, transformFunction: null }, emitOnReset: { classPropertyName: "emitOnReset", publicName: "emitOnReset", isSignal: true, isRequired: false, transformFunction: null }, textTitle: { classPropertyName: "textTitle", publicName: "textTitle", isSignal: true, isRequired: false, transformFunction: null }, sections: { classPropertyName: "sections", publicName: "sections", isSignal: true, isRequired: false, transformFunction: null }, isStarTheme: { classPropertyName: "isStarTheme", publicName: "isStarTheme", isSignal: true, isRequired: false, transformFunction: null }, isMaternityStarTheme: { classPropertyName: "isMaternityStarTheme", publicName: "isMaternityStarTheme", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { filterChange: "filterChange", closeModal: "closeModal", openMobileFilter: "openMobileFilter", isFilterOpen: "isFilterOpenChange" }, host: { properties: { "style": "this.styleBinding" } }, ngImport: i0, template: "<div\n class=\"filter-generic\"\n [ngClass]=\"{ 'container-style': withContainerStyle(), 'clickable-mobile': shouldHandleMobileClick() }\"\n aria-label=\"Filtros\"\n (click)=\"handleMobileClick()\"\n>\n <div class=\"filter-header-container\" [ngClass]=\"{ 'no-padding': !isFilterOpen(), hidden: !isFilterOpen() }\">\n <div class=\"filter-title-wrapper\">\n <cura-label size=\"medium\" level=\"4\" color=\"neutral-black\" weight=\"regular\" marginBlock=\"0\" lineHeight=\"16px\">\n {{ textTitle() }}\n </cura-label>\n\n @if (showBadge()) {\n <cura-badge-counter\n [type]=\"'solid'\"\n [color]=\"hasSelection() ? 'primary' : 'neutral'\"\n [number]=\"selectedFiltersCount()\"\n class=\"filter-badge\"\n ></cura-badge-counter>\n }\n </div>\n\n @if (showToggleIcon()) {\n <cura-button-transparent\n size=\"small\"\n fontColor=\"dark\"\n color=\"primary\"\n textAlign=\"center\"\n (click)=\"toggleFilter()\"\n [attr.aria-expanded]=\"isFilterOpen()\"\n [ariaLabel]=\"isFilterOpen() ? 'Fechar filtros' : 'Abrir filtros'\"\n >\n <cura-icon [name]=\"isFilterOpen() ? 'up' : 'down'\" size=\"16\" class=\"filter-icon\" color=\"primary-dark\"></cura-icon>\n </cura-button-transparent>\n }\n </div>\n\n <div class=\"filter-content\" [class.hidden]=\"!isFilterOpen() || (forceCollapsed() && isMobile())\">\n @for (section of sections(); track section.type) {\n @if (section.visible !== false) {\n <div class=\"filter-section\">\n @switch (section.type) {\n @case ('input') {\n <cura-input-text\n [placeholder]=\"section.config.placeholder || ''\"\n [name]=\"section.config.name || ''\"\n [iconName]=\"section.config.iconName || ''\"\n [value]=\"section.config.control.value\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : isMaternityStarTheme() ? '2rem' : '4px'\"\n (valueChange)=\"handleInputChange($event, section.config.control)\"\n ></cura-input-text>\n }\n @case ('select') {\n <cura-select\n [label]=\"section.config.label || ''\"\n [placeholder]=\"section.config.placeholder || ''\"\n [value]=\"section.config.control.value\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : isMaternityStarTheme() ? '2rem' : '4px'\"\n (selected)=\"handleSelectChange($event, section.config.control)\"\n >\n @if (section.config.includeDefaultOption) {\n <cura-select-option [value]=\"''\">{{ section.config.defaultOptionText || 'Fa\u00E7a a sua Sele\u00E7\u00E3o' }}</cura-select-option>\n }\n @for (option of section.config.options || []; track option?.value) {\n <cura-select-option [value]=\"option?.value\">{{ option?.label }}</cura-select-option>\n }\n </cura-select>\n }\n @case ('checkbox-group') {\n @if (section.config.title) {\n <div class=\"filter-header\">\n <cura-icon name=\"filter\" size=\"20\" color=\"primary-dark\"></cura-icon>\n <cura-heading size=\"xsmall\" [level]=\"5\" weight=\"bold\" color=\"neutral-black\" marginBlock=\"0\" lineHeight=\"16px\">\n {{ section.config.title }}\n </cura-heading>\n </div>\n }\n\n @if (section.config.subtitle) {\n <div class=\"filter-subtitle\">\n <cura-heading size=\"xsmall\" weight=\"bold\" color=\"neutral-black\" marginBlock=\"0\">\n {{ section.config.subtitle }}\n </cura-heading>\n </div>\n }\n\n @if (section.config.description) {\n <div class=\"filter-description\">\n <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" marginBlock=\"0\">\n {{ section.config.description }}\n </cura-paragraph>\n </div>\n }\n\n <div class=\"filter-checkboxes\" [class.scrollable]=\"hasScroll(section)\">\n @for (option of section.config.options || []; track option.value) {\n <cura-checkbox\n color=\"primary\"\n size=\"small\"\n iconColor=\"light\"\n [name]=\"option.label\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n [checked]=\"option.checked || false\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : '4px'\"\n (onchange)=\"handleCheckboxChange($event, section.config.options)\"\n ></cura-checkbox>\n }\n </div>\n }\n @case ('radio-group') {\n <div class=\"filter-radios\" [class.scrollable]=\"hasScroll(section)\">\n @for (option of section.config.options || []; track option?.value) {\n <cura-radio\n [name]=\"section.config.name || 'radio-group'\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n [checked]=\"getRadioGroupValue(section.config.control) === option.value\"\n (onchange)=\"handleRadioChange($event, section.config.control)\"\n ></cura-radio>\n }\n </div>\n }\n @case ('custom') {\n <ng-container *ngTemplateOutlet=\"section.config.template\"></ng-container>\n }\n }\n </div>\n }\n }\n </div>\n\n <div class=\"filter-actions\" [class.hidden]=\"!isFilterOpen() || (forceCollapsed() && isMobile())\">\n <div class=\"main-actions\">\n @if (showClearButton()) {\n <cura-button-transparent\n size=\"small\"\n fontColor=\"dark\"\n color=\"primary\"\n textAlign=\"center\"\n [disabled]=\"disableButtons() || !hasSelection()\"\n (click)=\"reset()\"\n >\n <span>Limpar todos os filtros</span>\n </cura-button-transparent>\n }\n\n @if (showApplyButton()) {\n <cura-button\n size=\"medium\"\n fontColor=\"light\"\n color=\"primary\"\n textAlign=\"center\"\n (click)=\"filter()\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : isMaternityStarTheme() ? '2rem' : '4px'\"\n [disabled]=\"disableButtons() || !hasSelection()\"\n class=\"filter-button\"\n >\n Filtrar\n </cura-button>\n }\n </div>\n\n @if (showCloseButton()) {\n <div class=\"divider-strong\"></div>\n <div class=\"close-action-wrapper\">\n <div class=\"close-action\" (click)=\"close()\">\n <cura-icon name=\"close\" color=\"error-dark\" size=\"small\"></cura-icon>\n <cura-button-transparent type=\"button\" color=\"error\" target=\"_self\"> Fechar </cura-button-transparent>\n </div>\n </div>\n }\n </div>\n</div>\n", styles: [":host *{font-family:var(--font-family)}.filter-generic{display:flex;flex-direction:column;gap:18px}.filter-generic.clickable-mobile{cursor:pointer}.filter-generic.clickable-mobile:hover{background-color:var(--primary-lighter)}.filter-generic.container-style{width:100%;padding:20px;border-radius:12px;border:2px solid var(--neutral-lighter);background-color:var(--neutral-purewhite)}.filter-generic cura-loader-circle{display:flex;justify-content:center;align-items:center;width:100%;min-height:100px}.filter-header-container{display:flex;padding-bottom:12px;align-items:center}.filter-header-container.no-padding{padding-bottom:0}.filter-header-container .filter-title-wrapper{display:flex;align-items:center;justify-content:space-between;flex:1 0 0}.filter-header-container .filter-badge{display:flex;height:20px;min-width:20px;justify-content:center;align-items:center;gap:4px}.filter-header-container .filter-icon{display:block}.filter-content,.filter-actions{transition:all .3s ease}.filter-content.hidden,.filter-actions.hidden{display:none;height:0;overflow:hidden;opacity:0;margin:0;padding:0}.filter-section{display:flex;flex-direction:column;gap:24px}.filter-section .filter-header{display:flex;align-items:center;gap:14px}.filter-section .filter-subtitle{font-weight:500}.filter-section .filter-description{display:flex;flex-direction:column;gap:8px}.filter-section .filter-description:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:12px;grid-column:1/-1}.filter-section .filter-checkboxes{display:grid;grid-template-columns:repeat(2,1fr);gap:11px 0px}.filter-section .filter-checkboxes.scrollable{max-height:100px;overflow-y:auto;grid-template-columns:1fr;padding-right:8px;gap:12px}.filter-section .filter-checkboxes.scrollable::-webkit-scrollbar{width:8px}.filter-section .filter-checkboxes.scrollable::-webkit-scrollbar-thumb{background:var(--neutral-medium)}.filter-section .filter-checkboxes.scrollable::-webkit-scrollbar-thumb:hover{background:var(--primary-base)}.filter-section .filter-checkboxes.scrollable::-webkit-scrollbar-track{background:var(--neutral-opacity-black)}.filter-section .filter-checkboxes.scrollable:after{display:none}.filter-section .filter-radios{display:flex;flex-direction:column;gap:12px}.filter-section .filter-radios.scrollable{max-height:100px;overflow-y:auto;padding-right:8px;gap:8px}.filter-section .filter-radios.scrollable::-webkit-scrollbar{width:8px}.filter-section .filter-radios.scrollable::-webkit-scrollbar-thumb{background:var(--neutral-medium)}.filter-section .filter-radios.scrollable::-webkit-scrollbar-thumb:hover{background:var(--primary-base)}.filter-section .filter-radios.scrollable::-webkit-scrollbar-track{background:var(--neutral-opacity-black)}.filter-section .filter-radios.scrollable:after{display:none}@media screen and (max-width: 1024px){.filter-checkboxes.scrollable,.filter-radios.scrollable{max-height:100px}.filter-checkboxes:after{display:none;background-color:transparent}}.filter-actions{display:flex;flex-direction:column;gap:0}.filter-actions:before{content:\"\";display:block;width:100%;height:1px;background:linear-gradient(90deg,var(--neutral-light) 75%,transparent 15%);background-size:10px 1px;background-repeat:repeat-x;margin-bottom:20px}.filter-actions .main-actions{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.filter-actions .divider-strong{height:1px;width:100%;margin-top:20px;margin-bottom:16px;background:linear-gradient(90deg,#e2e2e2 70%,transparent 70%);background-size:4px 1px;background-repeat:repeat-x}.filter-actions .close-action-wrapper{display:flex;justify-content:center;width:100%}.filter-actions .close-action{display:inline-flex;align-items:center;gap:8px}.filter-actions .close-action cura-button-transparent{padding:0;margin:0;background:transparent;border:none;color:inherit}.filter-actions cura-button-transparent{display:flex;justify-content:flex-start;text-align:left;flex:0 1 auto}.filter-actions cura-button{display:flex;justify-content:flex-start;text-align:left;flex:1 0 auto}@media screen and (max-width: 1024px){.filter-checkboxes:after{background-color:transparent}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: CuraLabelComponent, selector: "cura-label", inputs: ["size", "weight", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }, { kind: "component", type: CuraBadgeCounterComponent, selector: "cura-badge-counter", inputs: ["number", "color", "disabled", "type"] }, { kind: "component", type: CuraButtonTransparentComponent, selector: "cura-button-transparent", inputs: ["type", "size", "disabled", "isLoading", "iconName", "iconset", "iconPosition", "iconOnly", "href", "target", "color", "fontColor", "textAlign", "justify", "ariaLabel"], outputs: ["buttonClick"] }, { kind: "component", type: CuraInputTextComponent, selector: "cura-input-text", inputs: ["mode", "status", "size", "type", "inputMode", "label", "name", "placeholder", "value", "iconName", "disabled", "required", "maskPreset", "enableSelectionMode", "maskRegex", "maskAdvanced", "maxlength", "readOnly", "isLoading", "clearIcon", "hideErrorIcon", "autocomplete"], outputs: ["valueChange", "inputClear"] }, { kind: "component", type: CuraIconComponent, selector: "cura-icon", inputs: ["name", "color", "size", "iconset", "disabled"] }, { kind: "component", type: CuraSelectComponent, selector: "cura-select", inputs: ["name", "label", "placeholder", "value", "mode", "size", "iconName", "status", "disabled", "required", "searchBehavior", "caseSensitive", "maxHeight"], outputs: ["valueChange", "selected", "searchTermInput"] }, { kind: "component", type: CuraSelectOptionComponent, selector: "cura-select-option", inputs: ["value", "selected", "active", "size", "visible"], outputs: ["selectedChange", "activeChange", "sizeChange", "visibleChange"] }, { kind: "component", type: CuraHeadingComponent, selector: "cura-heading", inputs: ["level", "size", "weight", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }, { kind: "component", type: CuraCheckboxComponent, selector: "cura-checkbox", inputs: ["disableCheckIcon", "checked", "indeterminate", "status", "disabled", "required", "label", "ontabindex", "position", "value", "name", "size", "background", "iconColor", "color", "overflowLabel", "overflowHelper"], outputs: ["checkedChange", "indeterminateChange", "valueChange", "onchange"] }, { kind: "component", type: CuraRadioComponent, selector: "cura-radio", inputs: ["checked", "status", "disabled", "required", "label", "ontabindex", "position", "value", "name", "background", "size", "color", "isSquare", "overflowLabel", "overflowHelper"], outputs: ["checkedChange", "valueChange", "onchange"] }, { kind: "component", type: CuraButtonComponent, selector: "cura-button", inputs: ["type", "size", "disabled", "isLoading", "iconName", "iconset", "iconPosition", "iconOnly", "href", "target", "color", "background", "fontColor", "textAlign", "justify", "ariaLabel"], outputs: ["buttonClick"] }, { kind: "component", type: CuraParagraphComponent, selector: "cura-paragraph", inputs: ["size", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }] }); }
216
- }
217
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: FilterGenericComponent, decorators: [{
218
- type: Component,
219
- args: [{ selector: 'rdsite-filter-generic', imports: [
220
- CommonModule,
221
- ReactiveFormsModule,
222
- CuraLabelComponent,
223
- CuraBadgeCounterComponent,
224
- CuraButtonTransparentComponent,
225
- CuraInputTextComponent,
226
- CuraIconComponent,
227
- CuraSelectComponent,
228
- CuraSelectOptionComponent,
229
- CuraHeadingComponent,
230
- CuraCheckboxComponent,
231
- CuraRadioComponent,
232
- CuraButtonComponent,
233
- CuraParagraphComponent,
234
- ], template: "<div\n class=\"filter-generic\"\n [ngClass]=\"{ 'container-style': withContainerStyle(), 'clickable-mobile': shouldHandleMobileClick() }\"\n aria-label=\"Filtros\"\n (click)=\"handleMobileClick()\"\n>\n <div class=\"filter-header-container\" [ngClass]=\"{ 'no-padding': !isFilterOpen(), hidden: !isFilterOpen() }\">\n <div class=\"filter-title-wrapper\">\n <cura-label size=\"medium\" level=\"4\" color=\"neutral-black\" weight=\"regular\" marginBlock=\"0\" lineHeight=\"16px\">\n {{ textTitle() }}\n </cura-label>\n\n @if (showBadge()) {\n <cura-badge-counter\n [type]=\"'solid'\"\n [color]=\"hasSelection() ? 'primary' : 'neutral'\"\n [number]=\"selectedFiltersCount()\"\n class=\"filter-badge\"\n ></cura-badge-counter>\n }\n </div>\n\n @if (showToggleIcon()) {\n <cura-button-transparent\n size=\"small\"\n fontColor=\"dark\"\n color=\"primary\"\n textAlign=\"center\"\n (click)=\"toggleFilter()\"\n [attr.aria-expanded]=\"isFilterOpen()\"\n [ariaLabel]=\"isFilterOpen() ? 'Fechar filtros' : 'Abrir filtros'\"\n >\n <cura-icon [name]=\"isFilterOpen() ? 'up' : 'down'\" size=\"16\" class=\"filter-icon\" color=\"primary-dark\"></cura-icon>\n </cura-button-transparent>\n }\n </div>\n\n <div class=\"filter-content\" [class.hidden]=\"!isFilterOpen() || (forceCollapsed() && isMobile())\">\n @for (section of sections(); track section.type) {\n @if (section.visible !== false) {\n <div class=\"filter-section\">\n @switch (section.type) {\n @case ('input') {\n <cura-input-text\n [placeholder]=\"section.config.placeholder || ''\"\n [name]=\"section.config.name || ''\"\n [iconName]=\"section.config.iconName || ''\"\n [value]=\"section.config.control.value\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : isMaternityStarTheme() ? '2rem' : '4px'\"\n (valueChange)=\"handleInputChange($event, section.config.control)\"\n ></cura-input-text>\n }\n @case ('select') {\n <cura-select\n [label]=\"section.config.label || ''\"\n [placeholder]=\"section.config.placeholder || ''\"\n [value]=\"section.config.control.value\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : isMaternityStarTheme() ? '2rem' : '4px'\"\n (selected)=\"handleSelectChange($event, section.config.control)\"\n >\n @if (section.config.includeDefaultOption) {\n <cura-select-option [value]=\"''\">{{ section.config.defaultOptionText || 'Fa\u00E7a a sua Sele\u00E7\u00E3o' }}</cura-select-option>\n }\n @for (option of section.config.options || []; track option?.value) {\n <cura-select-option [value]=\"option?.value\">{{ option?.label }}</cura-select-option>\n }\n </cura-select>\n }\n @case ('checkbox-group') {\n @if (section.config.title) {\n <div class=\"filter-header\">\n <cura-icon name=\"filter\" size=\"20\" color=\"primary-dark\"></cura-icon>\n <cura-heading size=\"xsmall\" [level]=\"5\" weight=\"bold\" color=\"neutral-black\" marginBlock=\"0\" lineHeight=\"16px\">\n {{ section.config.title }}\n </cura-heading>\n </div>\n }\n\n @if (section.config.subtitle) {\n <div class=\"filter-subtitle\">\n <cura-heading size=\"xsmall\" weight=\"bold\" color=\"neutral-black\" marginBlock=\"0\">\n {{ section.config.subtitle }}\n </cura-heading>\n </div>\n }\n\n @if (section.config.description) {\n <div class=\"filter-description\">\n <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" marginBlock=\"0\">\n {{ section.config.description }}\n </cura-paragraph>\n </div>\n }\n\n <div class=\"filter-checkboxes\" [class.scrollable]=\"hasScroll(section)\">\n @for (option of section.config.options || []; track option.value) {\n <cura-checkbox\n color=\"primary\"\n size=\"small\"\n iconColor=\"light\"\n [name]=\"option.label\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n [checked]=\"option.checked || false\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : '4px'\"\n (onchange)=\"handleCheckboxChange($event, section.config.options)\"\n ></cura-checkbox>\n }\n </div>\n }\n @case ('radio-group') {\n <div class=\"filter-radios\" [class.scrollable]=\"hasScroll(section)\">\n @for (option of section.config.options || []; track option?.value) {\n <cura-radio\n [name]=\"section.config.name || 'radio-group'\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n [checked]=\"getRadioGroupValue(section.config.control) === option.value\"\n (onchange)=\"handleRadioChange($event, section.config.control)\"\n ></cura-radio>\n }\n </div>\n }\n @case ('custom') {\n <ng-container *ngTemplateOutlet=\"section.config.template\"></ng-container>\n }\n }\n </div>\n }\n }\n </div>\n\n <div class=\"filter-actions\" [class.hidden]=\"!isFilterOpen() || (forceCollapsed() && isMobile())\">\n <div class=\"main-actions\">\n @if (showClearButton()) {\n <cura-button-transparent\n size=\"small\"\n fontColor=\"dark\"\n color=\"primary\"\n textAlign=\"center\"\n [disabled]=\"disableButtons() || !hasSelection()\"\n (click)=\"reset()\"\n >\n <span>Limpar todos os filtros</span>\n </cura-button-transparent>\n }\n\n @if (showApplyButton()) {\n <cura-button\n size=\"medium\"\n fontColor=\"light\"\n color=\"primary\"\n textAlign=\"center\"\n (click)=\"filter()\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : isMaternityStarTheme() ? '2rem' : '4px'\"\n [disabled]=\"disableButtons() || !hasSelection()\"\n class=\"filter-button\"\n >\n Filtrar\n </cura-button>\n }\n </div>\n\n @if (showCloseButton()) {\n <div class=\"divider-strong\"></div>\n <div class=\"close-action-wrapper\">\n <div class=\"close-action\" (click)=\"close()\">\n <cura-icon name=\"close\" color=\"error-dark\" size=\"small\"></cura-icon>\n <cura-button-transparent type=\"button\" color=\"error\" target=\"_self\"> Fechar </cura-button-transparent>\n </div>\n </div>\n }\n </div>\n</div>\n", styles: [":host *{font-family:var(--font-family)}.filter-generic{display:flex;flex-direction:column;gap:18px}.filter-generic.clickable-mobile{cursor:pointer}.filter-generic.clickable-mobile:hover{background-color:var(--primary-lighter)}.filter-generic.container-style{width:100%;padding:20px;border-radius:12px;border:2px solid var(--neutral-lighter);background-color:var(--neutral-purewhite)}.filter-generic cura-loader-circle{display:flex;justify-content:center;align-items:center;width:100%;min-height:100px}.filter-header-container{display:flex;padding-bottom:12px;align-items:center}.filter-header-container.no-padding{padding-bottom:0}.filter-header-container .filter-title-wrapper{display:flex;align-items:center;justify-content:space-between;flex:1 0 0}.filter-header-container .filter-badge{display:flex;height:20px;min-width:20px;justify-content:center;align-items:center;gap:4px}.filter-header-container .filter-icon{display:block}.filter-content,.filter-actions{transition:all .3s ease}.filter-content.hidden,.filter-actions.hidden{display:none;height:0;overflow:hidden;opacity:0;margin:0;padding:0}.filter-section{display:flex;flex-direction:column;gap:24px}.filter-section .filter-header{display:flex;align-items:center;gap:14px}.filter-section .filter-subtitle{font-weight:500}.filter-section .filter-description{display:flex;flex-direction:column;gap:8px}.filter-section .filter-description:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:12px;grid-column:1/-1}.filter-section .filter-checkboxes{display:grid;grid-template-columns:repeat(2,1fr);gap:11px 0px}.filter-section .filter-checkboxes.scrollable{max-height:100px;overflow-y:auto;grid-template-columns:1fr;padding-right:8px;gap:12px}.filter-section .filter-checkboxes.scrollable::-webkit-scrollbar{width:8px}.filter-section .filter-checkboxes.scrollable::-webkit-scrollbar-thumb{background:var(--neutral-medium)}.filter-section .filter-checkboxes.scrollable::-webkit-scrollbar-thumb:hover{background:var(--primary-base)}.filter-section .filter-checkboxes.scrollable::-webkit-scrollbar-track{background:var(--neutral-opacity-black)}.filter-section .filter-checkboxes.scrollable:after{display:none}.filter-section .filter-radios{display:flex;flex-direction:column;gap:12px}.filter-section .filter-radios.scrollable{max-height:100px;overflow-y:auto;padding-right:8px;gap:8px}.filter-section .filter-radios.scrollable::-webkit-scrollbar{width:8px}.filter-section .filter-radios.scrollable::-webkit-scrollbar-thumb{background:var(--neutral-medium)}.filter-section .filter-radios.scrollable::-webkit-scrollbar-thumb:hover{background:var(--primary-base)}.filter-section .filter-radios.scrollable::-webkit-scrollbar-track{background:var(--neutral-opacity-black)}.filter-section .filter-radios.scrollable:after{display:none}@media screen and (max-width: 1024px){.filter-checkboxes.scrollable,.filter-radios.scrollable{max-height:100px}.filter-checkboxes:after{display:none;background-color:transparent}}.filter-actions{display:flex;flex-direction:column;gap:0}.filter-actions:before{content:\"\";display:block;width:100%;height:1px;background:linear-gradient(90deg,var(--neutral-light) 75%,transparent 15%);background-size:10px 1px;background-repeat:repeat-x;margin-bottom:20px}.filter-actions .main-actions{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.filter-actions .divider-strong{height:1px;width:100%;margin-top:20px;margin-bottom:16px;background:linear-gradient(90deg,#e2e2e2 70%,transparent 70%);background-size:4px 1px;background-repeat:repeat-x}.filter-actions .close-action-wrapper{display:flex;justify-content:center;width:100%}.filter-actions .close-action{display:inline-flex;align-items:center;gap:8px}.filter-actions .close-action cura-button-transparent{padding:0;margin:0;background:transparent;border:none;color:inherit}.filter-actions cura-button-transparent{display:flex;justify-content:flex-start;text-align:left;flex:0 1 auto}.filter-actions cura-button{display:flex;justify-content:flex-start;text-align:left;flex:1 0 auto}@media screen and (max-width: 1024px){.filter-checkboxes:after{background-color:transparent}}\n"] }]
235
- }], propDecorators: { filterChange: [{ type: i0.Output, args: ["filterChange"] }], closeModal: [{ type: i0.Output, args: ["closeModal"] }], openMobileFilter: [{ type: i0.Output, args: ["openMobileFilter"] }], withContainerStyle: [{ type: i0.Input, args: [{ isSignal: true, alias: "withContainerStyle", required: false }] }], showClearButton: [{ type: i0.Input, args: [{ isSignal: true, alias: "showClearButton", required: false }] }], showApplyButton: [{ type: i0.Input, args: [{ isSignal: true, alias: "showApplyButton", required: false }] }], showCloseButton: [{ type: i0.Input, args: [{ isSignal: true, alias: "showCloseButton", required: false }] }], disableButtons: [{ type: i0.Input, args: [{ isSignal: true, alias: "disableButtons", required: false }] }], showBadge: [{ type: i0.Input, args: [{ isSignal: true, alias: "showBadge", required: false }] }], showToggleIcon: [{ type: i0.Input, args: [{ isSignal: true, alias: "showToggleIcon", required: false }] }], isFilterOpen: [{ type: i0.Input, args: [{ isSignal: true, alias: "isFilterOpen", required: false }] }, { type: i0.Output, args: ["isFilterOpenChange"] }], mobileBehavior: [{ type: i0.Input, args: [{ isSignal: true, alias: "mobileBehavior", required: false }] }], forceCollapsed: [{ type: i0.Input, args: [{ isSignal: true, alias: "forceCollapsed", required: false }] }], emitOnReset: [{ type: i0.Input, args: [{ isSignal: true, alias: "emitOnReset", required: false }] }], textTitle: [{ type: i0.Input, args: [{ isSignal: true, alias: "textTitle", required: false }] }], sections: [{ type: i0.Input, args: [{ isSignal: true, alias: "sections", required: false }] }], isStarTheme: [{ type: i0.Input, args: [{ isSignal: true, alias: "isStarTheme", required: false }] }], isMaternityStarTheme: [{ type: i0.Input, args: [{ isSignal: true, alias: "isMaternityStarTheme", required: false }] }], styleBinding: [{
236
- type: HostBinding,
237
- args: ['style']
238
- }] } });
239
-
240
- /**
241
- * Generated bundle index. Do not edit.
242
- */
243
-
244
- export { FilterGenericComponent };
245
- //# sourceMappingURL=rededor-site-front-end-lib-components-filters-filter-generic.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"rededor-site-front-end-lib-components-filters-filter-generic.mjs","sources":["../../../projects/site-front-end-lib/components/filters/filter-generic/filter-generic.component.ts","../../../projects/site-front-end-lib/components/filters/filter-generic/filter-generic.component.html","../../../projects/site-front-end-lib/components/filters/filter-generic/rededor-site-front-end-lib-components-filters-filter-generic.ts"],"sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\nimport { ChangeDetectorRef, Component, HostBinding, OnInit, PLATFORM_ID, input, model, output, inject, computed, signal } from '@angular/core';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { FilterAction, FilterControlValue, FilterSection, FilterEvent, FilterPlanosConveniosChange } from '@rededor/site-front-end-lib/core';\nimport { CuraApiService } from '@rededor/site-front-end-lib/cura/api';\nimport { CuraBadgeCounterComponent } from '@rededor/site-front-end-lib/cura/badges/cura-badge-counter';\nimport { CuraButtonComponent } from '@rededor/site-front-end-lib/cura/buttons/cura-button';\nimport { CuraButtonTransparentComponent } from '@rededor/site-front-end-lib/cura/buttons/cura-button-transparent';\nimport { CheckboxChangeEvent } from '@rededor/site-front-end-lib/cura/forms/cura-checkbox';\nimport { CuraCheckboxComponent } from '@rededor/site-front-end-lib/cura/forms/cura-checkbox';\nimport { CuraInputTextComponent } from '@rededor/site-front-end-lib/cura/forms/cura-input-text';\nimport { CuraLabelComponent } from '@rededor/site-front-end-lib/cura/forms/cura-label';\nimport { RadioChangeEvent } from '@rededor/site-front-end-lib/cura/forms/cura-radio';\nimport { CuraRadioComponent } from '@rededor/site-front-end-lib/cura/forms/cura-radio';\nimport { SelectSelectedEvent } from '@rededor/site-front-end-lib/cura/forms/cura-select';\nimport { CuraSelectComponent } from '@rededor/site-front-end-lib/cura/forms/cura-select';\nimport { CuraSelectOptionComponent } from '@rededor/site-front-end-lib/cura/forms/cura-select-option';\nimport { CuraIconComponent } from '@rededor/site-front-end-lib/cura/icons/cura-icon';\nimport { CuraHeadingComponent } from '@rededor/site-front-end-lib/cura/texts/cura-heading';\nimport { CuraParagraphComponent } from '@rededor/site-front-end-lib/cura/texts/cura-paragraph';\nimport { MediaQueries } from '@rededor/site-front-end-lib/shared';\n\n@Component({\n selector: 'rdsite-filter-generic',\n imports: [\n CommonModule,\n ReactiveFormsModule,\n CuraLabelComponent,\n CuraBadgeCounterComponent,\n CuraButtonTransparentComponent,\n CuraInputTextComponent,\n CuraIconComponent,\n CuraSelectComponent,\n CuraSelectOptionComponent,\n CuraHeadingComponent,\n CuraCheckboxComponent,\n CuraRadioComponent,\n CuraButtonComponent,\n CuraParagraphComponent,\n ],\n templateUrl: './filter-generic.component.html',\n styleUrls: ['./filter-generic.component.scss'],\n})\nexport class FilterGenericComponent implements OnInit {\n private readonly curaApiService = inject(CuraApiService);\n private readonly cdr = inject(ChangeDetectorRef);\n private readonly platformId = inject(PLATFORM_ID);\n\n readonly filterChange = output<FilterEvent>();\n readonly closeModal = output<boolean>();\n readonly openMobileFilter = output<void>();\n\n readonly withContainerStyle = input(true);\n readonly showClearButton = input(true);\n readonly showApplyButton = input(true);\n readonly showCloseButton = input(false);\n readonly disableButtons = input(false);\n readonly showBadge = input(true);\n readonly showToggleIcon = input(true);\n isFilterOpen = model(true);\n readonly mobileBehavior = input(false);\n readonly forceCollapsed = input(false);\n readonly emitOnReset = input(false);\n readonly textTitle = input('Filtrar por');\n readonly sections = input<FilterSection[]>([]);\n\n readonly windowWidth = signal(0);\n\n readonly isStarTheme = input<boolean>(false);\n readonly isMaternityStarTheme = input<boolean>(false);\n\n readonly selectedFiltersCount = computed(() => {\n return this.sections().reduce((count, section) => {\n if ((section.type !== 'custom' && !section.config?.control) || (section.type === 'custom' && !section.config?.count)) return count;\n\n const value = section.config.control?.value || null;\n\n switch (section.type) {\n case 'checkbox-group':\n return count + (Array.isArray(value) ? value.filter((item) => item?.checked).length : 0);\n case 'radio-group':\n return count + (value?.value ? 1 : 0);\n case 'custom':\n const customCount = section.config.count || 0;\n return count + customCount;\n default:\n return count + (value ? 1 : 0);\n }\n }, 0);\n });\n\n @HostBinding('style') styleBinding = {\n '--font-family': this.curaApiService.theme.fonts.getFamily(''),\n '--neutral-opacity-black': this.curaApiService.theme.colors.getColor('neutral-black', 0.2),\n '--neutral-dark': this.curaApiService.theme.colors.getColor('neutral-dark'),\n '--neutral-darker': this.curaApiService.theme.colors.getColor('neutral-darker'),\n '--neutral-medium': this.curaApiService.theme.colors.getColor('neutral-medium'),\n '--neutral-light': this.curaApiService.theme.colors.getColor('neutral-light'),\n '--neutral-lighter': this.curaApiService.theme.colors.getColor('neutral-lighter'),\n '--neutral-purewhite': this.curaApiService.theme.colors.getColor('neutral-purewhite'),\n '--primary-base': this.curaApiService.theme.colors.getColor('primary-base'),\n '--primary-lighter': this.curaApiService.theme.colors.getColor('primary-lighter'),\n };\n\n ngOnInit(): void {\n if (isPlatformBrowser(this.platformId)) {\n this.windowWidth.set(window.innerWidth);\n }\n\n if (this.forceCollapsed() && this.isMobile()) {\n this.isFilterOpen.set(false);\n }\n }\n\n handleInputChange(event: string | number, control: FormControl): void {\n control.setValue(event);\n }\n\n handleSelectChange({ value }: SelectSelectedEvent, control: FormControl): void {\n if (value !== undefined) {\n control.setValue(value);\n }\n }\n\n handleCheckboxChange({ value, checked }: CheckboxChangeEvent, options: any[]): void {\n const changedOption = options.find((opt) => opt.value === value);\n if (changedOption) changedOption.checked = checked;\n\n this.updateCheckboxGroup(options);\n }\n\n handleRadioChange({ value }: RadioChangeEvent, control: FormControl): void {\n const selectedValue = value;\n control.setValue(control.value?.value === selectedValue ? null : { value: selectedValue });\n }\n\n filter(): void {\n this.emitFilterChange('filter');\n if (this.mobileBehavior() || this.showCloseButton()) this.close();\n }\n\n reset(): void {\n this.resetAllControls();\n\n if (this.emitOnReset()) {\n this.emitFilterChange('reset');\n this.close();\n }\n }\n\n close(): void {\n this.closeModal.emit(true);\n }\n\n toggleFilter(): void {\n if (this.mobileBehavior() && this.isMobile()) {\n this.openMobileFilter.emit(undefined);\n } else {\n this.isFilterOpen.set(!this.isFilterOpen());\n }\n this.cdr.detectChanges();\n }\n\n hasSelection(): boolean {\n return this.selectedFiltersCount() > 0;\n }\n\n readonly isMobile = computed(() => {\n return this.windowWidth() <= MediaQueries.smallBreakpoint;\n });\n\n getRadioGroupValue(control?: FormControl<FilterControlValue>): any {\n const value = control?.value;\n return value && typeof value === 'object' && 'value' in value ? value.value : null;\n }\n\n hasScroll(section: FilterSection): boolean {\n switch (section.type) {\n case 'checkbox-group':\n return section.config.options && section.config.options.length > 6;\n case 'radio-group':\n return section.config.options && section.config.options.length > 6;\n default:\n return false;\n }\n }\n\n getSectionClass(section: FilterSection): string {\n return this.hasScroll(section) ? 'scrollable' : '';\n }\n\n shouldHandleMobileClick(): boolean {\n return this.mobileBehavior() && this.isMobile() && this.forceCollapsed();\n }\n\n handleMobileClick(): void {\n if (this.shouldHandleMobileClick()) {\n this.openMobileFilter.emit();\n }\n }\n\n private emitFilterChange(action: FilterAction): void {\n const filterData = this.buildFilterData();\n const isEmpty = this.isFilterDataEmpty(filterData);\n\n this.filterChange.emit({\n data: this.emitOnReset() || !isEmpty ? filterData : null,\n action: action,\n });\n }\n\n private resetAllControls(): void {\n this.sections().forEach((section) => {\n if (!section.config?.control) return;\n\n if (section.type === 'checkbox-group') {\n const resetOptions = section?.config?.options?.map((option: any) => ({ ...option, checked: false })) || [];\n section.config.options = resetOptions;\n section.config.control.setValue(resetOptions, { emitEvent: false });\n } else {\n section.config.control.reset('', { emitEvent: false });\n }\n });\n }\n\n private updateCheckboxGroup(options: any[]): void {\n this.sections()\n .filter((section) => section.type === 'checkbox-group')\n .forEach((section) => {\n section.config.options = [...options];\n section.config.control.setValue([...options]);\n });\n }\n\n private buildFilterData(): FilterPlanosConveniosChange | any {\n const filterData: FilterPlanosConveniosChange = {\n unidade: '',\n estado: '',\n cobertura: [],\n };\n\n this.sections().forEach((section) => {\n if (!section.config?.control) return;\n\n const value = section.config.control.value;\n\n switch (section.type) {\n case 'input':\n filterData.unidade = value || '';\n break;\n case 'select':\n filterData.estado = value || '';\n break;\n case 'checkbox-group':\n filterData.cobertura = Array.isArray(value) ? value.filter((item) => item.checked) : [];\n break;\n }\n });\n\n return filterData;\n }\n\n private isFilterDataEmpty(filterData: FilterPlanosConveniosChange): boolean {\n return Object.values(filterData).every((val) => val === null || val === '' || (Array.isArray(val) && val.length === 0));\n }\n}\n","<div\n class=\"filter-generic\"\n [ngClass]=\"{ 'container-style': withContainerStyle(), 'clickable-mobile': shouldHandleMobileClick() }\"\n aria-label=\"Filtros\"\n (click)=\"handleMobileClick()\"\n>\n <div class=\"filter-header-container\" [ngClass]=\"{ 'no-padding': !isFilterOpen(), hidden: !isFilterOpen() }\">\n <div class=\"filter-title-wrapper\">\n <cura-label size=\"medium\" level=\"4\" color=\"neutral-black\" weight=\"regular\" marginBlock=\"0\" lineHeight=\"16px\">\n {{ textTitle() }}\n </cura-label>\n\n @if (showBadge()) {\n <cura-badge-counter\n [type]=\"'solid'\"\n [color]=\"hasSelection() ? 'primary' : 'neutral'\"\n [number]=\"selectedFiltersCount()\"\n class=\"filter-badge\"\n ></cura-badge-counter>\n }\n </div>\n\n @if (showToggleIcon()) {\n <cura-button-transparent\n size=\"small\"\n fontColor=\"dark\"\n color=\"primary\"\n textAlign=\"center\"\n (click)=\"toggleFilter()\"\n [attr.aria-expanded]=\"isFilterOpen()\"\n [ariaLabel]=\"isFilterOpen() ? 'Fechar filtros' : 'Abrir filtros'\"\n >\n <cura-icon [name]=\"isFilterOpen() ? 'up' : 'down'\" size=\"16\" class=\"filter-icon\" color=\"primary-dark\"></cura-icon>\n </cura-button-transparent>\n }\n </div>\n\n <div class=\"filter-content\" [class.hidden]=\"!isFilterOpen() || (forceCollapsed() && isMobile())\">\n @for (section of sections(); track section.type) {\n @if (section.visible !== false) {\n <div class=\"filter-section\">\n @switch (section.type) {\n @case ('input') {\n <cura-input-text\n [placeholder]=\"section.config.placeholder || ''\"\n [name]=\"section.config.name || ''\"\n [iconName]=\"section.config.iconName || ''\"\n [value]=\"section.config.control.value\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : isMaternityStarTheme() ? '2rem' : '4px'\"\n (valueChange)=\"handleInputChange($event, section.config.control)\"\n ></cura-input-text>\n }\n @case ('select') {\n <cura-select\n [label]=\"section.config.label || ''\"\n [placeholder]=\"section.config.placeholder || ''\"\n [value]=\"section.config.control.value\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : isMaternityStarTheme() ? '2rem' : '4px'\"\n (selected)=\"handleSelectChange($event, section.config.control)\"\n >\n @if (section.config.includeDefaultOption) {\n <cura-select-option [value]=\"''\">{{ section.config.defaultOptionText || 'Faça a sua Seleção' }}</cura-select-option>\n }\n @for (option of section.config.options || []; track option?.value) {\n <cura-select-option [value]=\"option?.value\">{{ option?.label }}</cura-select-option>\n }\n </cura-select>\n }\n @case ('checkbox-group') {\n @if (section.config.title) {\n <div class=\"filter-header\">\n <cura-icon name=\"filter\" size=\"20\" color=\"primary-dark\"></cura-icon>\n <cura-heading size=\"xsmall\" [level]=\"5\" weight=\"bold\" color=\"neutral-black\" marginBlock=\"0\" lineHeight=\"16px\">\n {{ section.config.title }}\n </cura-heading>\n </div>\n }\n\n @if (section.config.subtitle) {\n <div class=\"filter-subtitle\">\n <cura-heading size=\"xsmall\" weight=\"bold\" color=\"neutral-black\" marginBlock=\"0\">\n {{ section.config.subtitle }}\n </cura-heading>\n </div>\n }\n\n @if (section.config.description) {\n <div class=\"filter-description\">\n <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" marginBlock=\"0\">\n {{ section.config.description }}\n </cura-paragraph>\n </div>\n }\n\n <div class=\"filter-checkboxes\" [class.scrollable]=\"hasScroll(section)\">\n @for (option of section.config.options || []; track option.value) {\n <cura-checkbox\n color=\"primary\"\n size=\"small\"\n iconColor=\"light\"\n [name]=\"option.label\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n [checked]=\"option.checked || false\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : '4px'\"\n (onchange)=\"handleCheckboxChange($event, section.config.options)\"\n ></cura-checkbox>\n }\n </div>\n }\n @case ('radio-group') {\n <div class=\"filter-radios\" [class.scrollable]=\"hasScroll(section)\">\n @for (option of section.config.options || []; track option?.value) {\n <cura-radio\n [name]=\"section.config.name || 'radio-group'\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n [checked]=\"getRadioGroupValue(section.config.control) === option.value\"\n (onchange)=\"handleRadioChange($event, section.config.control)\"\n ></cura-radio>\n }\n </div>\n }\n @case ('custom') {\n <ng-container *ngTemplateOutlet=\"section.config.template\"></ng-container>\n }\n }\n </div>\n }\n }\n </div>\n\n <div class=\"filter-actions\" [class.hidden]=\"!isFilterOpen() || (forceCollapsed() && isMobile())\">\n <div class=\"main-actions\">\n @if (showClearButton()) {\n <cura-button-transparent\n size=\"small\"\n fontColor=\"dark\"\n color=\"primary\"\n textAlign=\"center\"\n [disabled]=\"disableButtons() || !hasSelection()\"\n (click)=\"reset()\"\n >\n <span>Limpar todos os filtros</span>\n </cura-button-transparent>\n }\n\n @if (showApplyButton()) {\n <cura-button\n size=\"medium\"\n fontColor=\"light\"\n color=\"primary\"\n textAlign=\"center\"\n (click)=\"filter()\"\n [style.--border-radius]=\"isStarTheme() ? '0px' : isMaternityStarTheme() ? '2rem' : '4px'\"\n [disabled]=\"disableButtons() || !hasSelection()\"\n class=\"filter-button\"\n >\n Filtrar\n </cura-button>\n }\n </div>\n\n @if (showCloseButton()) {\n <div class=\"divider-strong\"></div>\n <div class=\"close-action-wrapper\">\n <div class=\"close-action\" (click)=\"close()\">\n <cura-icon name=\"close\" color=\"error-dark\" size=\"small\"></cura-icon>\n <cura-button-transparent type=\"button\" color=\"error\" target=\"_self\"> Fechar </cura-button-transparent>\n </div>\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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"}
@@ -1,139 +0,0 @@
1
- import * as i0 from '@angular/core';
2
- import { inject, output, input, HostBinding, Component } from '@angular/core';
3
- import * as i1 from '@angular/common';
4
- import { CommonModule } from '@angular/common';
5
- import { FormControl, ReactiveFormsModule } from '@angular/forms';
6
- import { CuraApiService } from '@rededor/site-front-end-lib/cura/api';
7
- import { Estados } from '@rededor/site-front-end-lib/enums';
8
- import { CuraHeadingComponent } from '@rededor/site-front-end-lib/cura/texts/cura-heading';
9
- import { CuraInputTextComponent } from '@rededor/site-front-end-lib/cura/forms/cura-input-text';
10
- import { CuraSelectComponent } from '@rededor/site-front-end-lib/cura/forms/cura-select';
11
- import { CuraSelectOptionComponent } from '@rededor/site-front-end-lib/cura/forms/cura-select-option';
12
- import { CuraIconComponent } from '@rededor/site-front-end-lib/cura/icons/cura-icon';
13
- import { CuraParagraphComponent } from '@rededor/site-front-end-lib/cura/texts/cura-paragraph';
14
- import { CuraCheckboxComponent } from '@rededor/site-front-end-lib/cura/forms/cura-checkbox';
15
- import { CuraButtonTransparentComponent } from '@rededor/site-front-end-lib/cura/buttons/cura-button-transparent';
16
- import { CuraButtonComponent } from '@rededor/site-front-end-lib/cura/buttons/cura-button';
17
- import { CuraLoaderCircleComponent } from '@rededor/site-front-end-lib/cura/loaders/cura-loader-circle';
18
-
19
- class FilterPlanosConveniosComponent {
20
- constructor() {
21
- this.curaApiService = inject(CuraApiService);
22
- this.filterChange = output();
23
- this.closeModal = output();
24
- this.withContainerStyle = input(false, ...(ngDevMode ? [{ debugName: "withContainerStyle" }] : []));
25
- this.isLoading = input(false, ...(ngDevMode ? [{ debugName: "isLoading" }] : []));
26
- this.emitOnChange = input(false, ...(ngDevMode ? [{ debugName: "emitOnChange" }] : []));
27
- this.initialEstado = input(null, ...(ngDevMode ? [{ debugName: "initialEstado" }] : []));
28
- this.estados = input(Object.entries(Estados).map(([key, value]) => ({
29
- label: value,
30
- value: key,
31
- })), ...(ngDevMode ? [{ debugName: "estados" }] : []));
32
- this.coberturas = input([
33
- { label: 'Consultas', value: 'FLAG_ACEITA_AMBULATORIO', checked: false },
34
- { label: 'Emergência', value: 'FLAG_ACEITA_PS', checked: false },
35
- { label: 'Exames', value: 'FLAG_ACEITA_EXAME', checked: false },
36
- { label: 'Internação', value: 'FLAG_ACEITA_INTERNACAO', checked: false },
37
- ], ...(ngDevMode ? [{ debugName: "coberturas" }] : []));
38
- this.unidadeControl = input(new FormControl(''), ...(ngDevMode ? [{ debugName: "unidadeControl" }] : []));
39
- this.estadoControl = input(new FormControl(''), ...(ngDevMode ? [{ debugName: "estadoControl" }] : []));
40
- this.coberturaControl = new FormControl(this.coberturas() || []);
41
- this.styleBinding = {
42
- '--neutral-darker': this.curaApiService.theme.colors.getColor('neutral-darker'),
43
- '--neutral-light': this.curaApiService.theme.colors.getColor('neutral-light'),
44
- '--neutral-lighter': this.curaApiService.theme.colors.getColor('neutral-lighter'),
45
- '--neutral-purewhite': this.curaApiService.theme.colors.getColor('neutral-purewhite'),
46
- };
47
- }
48
- ngAfterViewInit() {
49
- const estados = this.estados();
50
- if (this.initialEstado() && Array.isArray(estados) && estados.find((estado) => estado.value === this.initialEstado())) {
51
- setTimeout(() => {
52
- this.estadoControl().setValue(this.initialEstado());
53
- this.filter();
54
- }, 50);
55
- }
56
- }
57
- inputTextChange(detail) {
58
- this.unidadeControl().setValue(detail);
59
- if (this.emitOnChange()) {
60
- this.filterChange.emit({
61
- unidade: detail,
62
- estado: this.estadoControl().value,
63
- cobertura: this.coberturaControl.value || [],
64
- });
65
- }
66
- }
67
- selectChange({ value }) {
68
- this.estadoControl().setValue(value);
69
- if (this.emitOnChange()) {
70
- this.filterChange.emit({
71
- unidade: this.unidadeControl().value,
72
- estado: value,
73
- cobertura: this.coberturaControl.value || [],
74
- });
75
- }
76
- }
77
- checkboxChange(detail) {
78
- const coberturas = this.coberturas();
79
- if (!coberturas)
80
- return;
81
- const currOption = coberturas.find((option) => option.value == detail.value);
82
- if (currOption) {
83
- currOption.checked = detail.checked;
84
- }
85
- this.coberturaControl.setValue(coberturas);
86
- if (this.emitOnChange()) {
87
- this.filterChange.emit({
88
- unidade: this.unidadeControl().value,
89
- estado: this.estadoControl().value,
90
- cobertura: this.coberturaControl.value || [],
91
- });
92
- }
93
- }
94
- filter() {
95
- this.filterChange.emit({
96
- unidade: this.unidadeControl().value,
97
- estado: this.estadoControl().value,
98
- cobertura: this.coberturaControl.value || [],
99
- });
100
- }
101
- reset() {
102
- const hasCoverage = this.coberturaControl.value.some((cob) => cob.checked);
103
- const hasFilter = Boolean(this.unidadeControl().value) || Boolean(this.estadoControl().value) || Boolean(hasCoverage);
104
- this.closeModal.emit(!hasFilter);
105
- this.unidadeControl().reset('');
106
- this.estadoControl().reset('');
107
- this.coberturas().forEach((cobertura) => (cobertura.checked = false));
108
- this.coberturaControl.reset(this.coberturas());
109
- }
110
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: FilterPlanosConveniosComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
111
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.16", type: FilterPlanosConveniosComponent, isStandalone: true, selector: "rdsite-filter-planos-convenios", inputs: { withContainerStyle: { classPropertyName: "withContainerStyle", publicName: "withContainerStyle", isSignal: true, isRequired: false, transformFunction: null }, isLoading: { classPropertyName: "isLoading", publicName: "isLoading", isSignal: true, isRequired: false, transformFunction: null }, emitOnChange: { classPropertyName: "emitOnChange", publicName: "emitOnChange", isSignal: true, isRequired: false, transformFunction: null }, initialEstado: { classPropertyName: "initialEstado", publicName: "initialEstado", isSignal: true, isRequired: false, transformFunction: null }, estados: { classPropertyName: "estados", publicName: "estados", isSignal: true, isRequired: false, transformFunction: null }, coberturas: { classPropertyName: "coberturas", publicName: "coberturas", isSignal: true, isRequired: false, transformFunction: null }, unidadeControl: { classPropertyName: "unidadeControl", publicName: "unidadeControl", isSignal: true, isRequired: false, transformFunction: null }, estadoControl: { classPropertyName: "estadoControl", publicName: "estadoControl", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { filterChange: "filterChange", closeModal: "closeModal" }, host: { properties: { "style": "this.styleBinding" } }, ngImport: i0, template: "<div class=\"filter-planos-convenios\" [ngClass]=\"{ 'container-style': withContainerStyle() }\">\n @if (!isLoading()) {\n <cura-heading size=\"small\" [level]=\"4\" weight=\"bold\" color=\"neutral-black\" marginBlock=\"0\" lineHeight=\"16px\"> Refine sua busca </cura-heading>\n\n <div class=\"filter-planos-convenios-unidade\">\n <cura-input-text\n placeholder=\"Nome da unidade\"\n name=\"unidade-input\"\n iconName=\"search\"\n autocomplete=\"off\"\n [value]=\"unidadeControl().value\"\n (valueChange)=\"inputTextChange($event)\"\n ></cura-input-text>\n </div>\n\n <div class=\"filter-planos-convenios-estado\">\n @if (estados()) {\n <cura-select\n label=\"Selecione o estado\"\n placeholder=\"Fa\u00E7a a sua Sele\u00E7\u00E3o\"\n mode=\"default\"\n size=\"medium\"\n status=\"default\"\n [value]=\"estadoControl().value\"\n (selected)=\"selectChange($event)\"\n >\n <cura-select-option [value]=\"''\">Fa\u00E7a a sua Sele\u00E7\u00E3o</cura-select-option>\n\n @for (estado of estados() || []; track estado?.value) {\n <cura-select-option [value]=\"estado?.value\">{{ estado?.label }}</cura-select-option>\n }\n </cura-select>\n }\n </div>\n\n <div class=\"filter-planos-convenios-cobertura\">\n <cura-icon name=\"filter\" size=\"20\" color=\"info-dark\"></cura-icon>\n <cura-heading size=\"xsmall\" [level]=\"5\" weight=\"bold\" color=\"neutral-black\" marginBlock=\"0\" lineHeight=\"16px\">\n Filtre pela cobertura do seu plano\n </cura-heading>\n </div>\n\n <div class=\"filter-planos-convenios-content\">\n <cura-heading size=\"xsmall\" [level]=\"5\" color=\"neutral-black\" marginBlock=\"0\" lineHeight=\"16px\"> Tipos de cobertura </cura-heading>\n <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" marginBlock=\"0\">\n Voc\u00EA pode selecionar uma ou mais portas de entrada, de acordo com a cobertura do seu plano.\n </cura-paragraph>\n </div>\n\n <div class=\"filter-planos-convenios-checkboxes\">\n @for (option of coberturas() || []; track option.value) {\n <cura-checkbox\n color=\"primary\"\n size=\"small\"\n iconColor=\"light\"\n [name]=\"option.label\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n [checked]=\"option.checked\"\n (onchange)=\"checkboxChange($event)\"\n >\n </cura-checkbox>\n }\n </div>\n\n <div class=\"filter-planos-convenios-buttons\">\n <cura-button-transparent size=\"small\" color=\"primary\" fontColor=\"dark\" textAlign=\"center\" (click)=\"reset()\">\n <span> Limpar todos os filtros </span>\n </cura-button-transparent>\n\n <cura-button size=\"medium\" color=\"primary\" fontColor=\"light\" background=\"light\" textAlign=\"center\" (click)=\"filter()\"> Filtrar </cura-button>\n </div>\n } @else {\n <cura-loader-circle color=\"primary\" size=\"small\"> </cura-loader-circle>\n }\n</div>\n", styles: [".filter-planos-convenios{display:flex;flex-direction:column;gap:23px}.filter-planos-convenios.container-style{width:100%;padding:20px;border-radius:4px;border:1px solid var(--neutral-lighter, #e2e2e2);background-color:var(--neutral-purewhite, #ffffff)}.filter-planos-convenios-cobertura{color:var(--neutral-darker);display:flex;align-items:center;gap:14px}.filter-planos-convenios-content{display:flex;flex-direction:column;gap:10px}.filter-planos-convenios-content:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:13px}.filter-planos-convenios-checkboxes{display:grid;grid-template-columns:repeat(2,1fr);gap:11px 0px}.filter-planos-convenios-checkboxes:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:12px;grid-column:1/-1}.filter-planos-convenios-buttons{display:flex;gap:10px;justify-content:space-between}.filter-planos-convenios-buttons cura-button-transparent{display:flex;flex:1 0 0;max-width:170px}.filter-planos-convenios-buttons cura-button-transparent span{line-height:13px;letter-spacing:.72px;text-align:left}.filter-planos-convenios-buttons cura-button{display:flex;flex:0 0 100px}cura-loader-circle{display:flex;justify-content:center;align-items:center;width:100%;min-height:100px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: CuraHeadingComponent, selector: "cura-heading", inputs: ["level", "size", "weight", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }, { kind: "component", type: CuraInputTextComponent, selector: "cura-input-text", inputs: ["mode", "status", "size", "type", "inputMode", "label", "name", "placeholder", "value", "iconName", "disabled", "required", "maskPreset", "enableSelectionMode", "maskRegex", "maskAdvanced", "maxlength", "readOnly", "isLoading", "clearIcon", "hideErrorIcon", "autocomplete"], outputs: ["valueChange", "inputClear"] }, { kind: "component", type: CuraSelectComponent, selector: "cura-select", inputs: ["name", "label", "placeholder", "value", "mode", "size", "iconName", "status", "disabled", "required", "searchBehavior", "caseSensitive", "maxHeight"], outputs: ["valueChange", "selected", "searchTermInput"] }, { kind: "component", type: CuraSelectOptionComponent, selector: "cura-select-option", inputs: ["value", "selected", "active", "size", "visible"], outputs: ["selectedChange", "activeChange", "sizeChange", "visibleChange"] }, { kind: "component", type: CuraIconComponent, selector: "cura-icon", inputs: ["name", "color", "size", "iconset", "disabled"] }, { kind: "component", type: CuraParagraphComponent, selector: "cura-paragraph", inputs: ["size", "spotColor", "color", "marginBlock", "lineHeight", "textOverflow"] }, { kind: "component", type: CuraCheckboxComponent, selector: "cura-checkbox", inputs: ["disableCheckIcon", "checked", "indeterminate", "status", "disabled", "required", "label", "ontabindex", "position", "value", "name", "size", "background", "iconColor", "color", "overflowLabel", "overflowHelper"], outputs: ["checkedChange", "indeterminateChange", "valueChange", "onchange"] }, { kind: "component", type: CuraButtonTransparentComponent, selector: "cura-button-transparent", inputs: ["type", "size", "disabled", "isLoading", "iconName", "iconset", "iconPosition", "iconOnly", "href", "target", "color", "fontColor", "textAlign", "justify", "ariaLabel"], outputs: ["buttonClick"] }, { kind: "component", type: CuraButtonComponent, selector: "cura-button", inputs: ["type", "size", "disabled", "isLoading", "iconName", "iconset", "iconPosition", "iconOnly", "href", "target", "color", "background", "fontColor", "textAlign", "justify", "ariaLabel"], outputs: ["buttonClick"] }, { kind: "component", type: CuraLoaderCircleComponent, selector: "cura-loader-circle", inputs: ["size", "color"] }] }); }
112
- }
113
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: FilterPlanosConveniosComponent, decorators: [{
114
- type: Component,
115
- args: [{ selector: 'rdsite-filter-planos-convenios', imports: [
116
- CommonModule,
117
- ReactiveFormsModule,
118
- CuraHeadingComponent,
119
- CuraInputTextComponent,
120
- CuraSelectComponent,
121
- CuraSelectOptionComponent,
122
- CuraIconComponent,
123
- CuraParagraphComponent,
124
- CuraCheckboxComponent,
125
- CuraButtonTransparentComponent,
126
- CuraButtonComponent,
127
- CuraLoaderCircleComponent,
128
- ], template: "<div class=\"filter-planos-convenios\" [ngClass]=\"{ 'container-style': withContainerStyle() }\">\n @if (!isLoading()) {\n <cura-heading size=\"small\" [level]=\"4\" weight=\"bold\" color=\"neutral-black\" marginBlock=\"0\" lineHeight=\"16px\"> Refine sua busca </cura-heading>\n\n <div class=\"filter-planos-convenios-unidade\">\n <cura-input-text\n placeholder=\"Nome da unidade\"\n name=\"unidade-input\"\n iconName=\"search\"\n autocomplete=\"off\"\n [value]=\"unidadeControl().value\"\n (valueChange)=\"inputTextChange($event)\"\n ></cura-input-text>\n </div>\n\n <div class=\"filter-planos-convenios-estado\">\n @if (estados()) {\n <cura-select\n label=\"Selecione o estado\"\n placeholder=\"Fa\u00E7a a sua Sele\u00E7\u00E3o\"\n mode=\"default\"\n size=\"medium\"\n status=\"default\"\n [value]=\"estadoControl().value\"\n (selected)=\"selectChange($event)\"\n >\n <cura-select-option [value]=\"''\">Fa\u00E7a a sua Sele\u00E7\u00E3o</cura-select-option>\n\n @for (estado of estados() || []; track estado?.value) {\n <cura-select-option [value]=\"estado?.value\">{{ estado?.label }}</cura-select-option>\n }\n </cura-select>\n }\n </div>\n\n <div class=\"filter-planos-convenios-cobertura\">\n <cura-icon name=\"filter\" size=\"20\" color=\"info-dark\"></cura-icon>\n <cura-heading size=\"xsmall\" [level]=\"5\" weight=\"bold\" color=\"neutral-black\" marginBlock=\"0\" lineHeight=\"16px\">\n Filtre pela cobertura do seu plano\n </cura-heading>\n </div>\n\n <div class=\"filter-planos-convenios-content\">\n <cura-heading size=\"xsmall\" [level]=\"5\" color=\"neutral-black\" marginBlock=\"0\" lineHeight=\"16px\"> Tipos de cobertura </cura-heading>\n <cura-paragraph size=\"xsmall\" color=\"neutral-dark\" marginBlock=\"0\">\n Voc\u00EA pode selecionar uma ou mais portas de entrada, de acordo com a cobertura do seu plano.\n </cura-paragraph>\n </div>\n\n <div class=\"filter-planos-convenios-checkboxes\">\n @for (option of coberturas() || []; track option.value) {\n <cura-checkbox\n color=\"primary\"\n size=\"small\"\n iconColor=\"light\"\n [name]=\"option.label\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n [checked]=\"option.checked\"\n (onchange)=\"checkboxChange($event)\"\n >\n </cura-checkbox>\n }\n </div>\n\n <div class=\"filter-planos-convenios-buttons\">\n <cura-button-transparent size=\"small\" color=\"primary\" fontColor=\"dark\" textAlign=\"center\" (click)=\"reset()\">\n <span> Limpar todos os filtros </span>\n </cura-button-transparent>\n\n <cura-button size=\"medium\" color=\"primary\" fontColor=\"light\" background=\"light\" textAlign=\"center\" (click)=\"filter()\"> Filtrar </cura-button>\n </div>\n } @else {\n <cura-loader-circle color=\"primary\" size=\"small\"> </cura-loader-circle>\n }\n</div>\n", styles: [".filter-planos-convenios{display:flex;flex-direction:column;gap:23px}.filter-planos-convenios.container-style{width:100%;padding:20px;border-radius:4px;border:1px solid var(--neutral-lighter, #e2e2e2);background-color:var(--neutral-purewhite, #ffffff)}.filter-planos-convenios-cobertura{color:var(--neutral-darker);display:flex;align-items:center;gap:14px}.filter-planos-convenios-content{display:flex;flex-direction:column;gap:10px}.filter-planos-convenios-content:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:13px}.filter-planos-convenios-checkboxes{display:grid;grid-template-columns:repeat(2,1fr);gap:11px 0px}.filter-planos-convenios-checkboxes:after{content:\"\";display:block;width:100%;height:1px;background-color:var(--neutral-light);margin-top:12px;grid-column:1/-1}.filter-planos-convenios-buttons{display:flex;gap:10px;justify-content:space-between}.filter-planos-convenios-buttons cura-button-transparent{display:flex;flex:1 0 0;max-width:170px}.filter-planos-convenios-buttons cura-button-transparent span{line-height:13px;letter-spacing:.72px;text-align:left}.filter-planos-convenios-buttons cura-button{display:flex;flex:0 0 100px}cura-loader-circle{display:flex;justify-content:center;align-items:center;width:100%;min-height:100px}\n"] }]
129
- }], propDecorators: { filterChange: [{ type: i0.Output, args: ["filterChange"] }], closeModal: [{ type: i0.Output, args: ["closeModal"] }], withContainerStyle: [{ type: i0.Input, args: [{ isSignal: true, alias: "withContainerStyle", required: false }] }], isLoading: [{ type: i0.Input, args: [{ isSignal: true, alias: "isLoading", required: false }] }], emitOnChange: [{ type: i0.Input, args: [{ isSignal: true, alias: "emitOnChange", required: false }] }], initialEstado: [{ type: i0.Input, args: [{ isSignal: true, alias: "initialEstado", required: false }] }], estados: [{ type: i0.Input, args: [{ isSignal: true, alias: "estados", required: false }] }], coberturas: [{ type: i0.Input, args: [{ isSignal: true, alias: "coberturas", required: false }] }], unidadeControl: [{ type: i0.Input, args: [{ isSignal: true, alias: "unidadeControl", required: false }] }], estadoControl: [{ type: i0.Input, args: [{ isSignal: true, alias: "estadoControl", required: false }] }], styleBinding: [{
130
- type: HostBinding,
131
- args: ['style']
132
- }] } });
133
-
134
- /**
135
- * Generated bundle index. Do not edit.
136
- */
137
-
138
- export { FilterPlanosConveniosComponent };
139
- //# sourceMappingURL=rededor-site-front-end-lib-components-filters-filter-planos-convenios.mjs.map