@ethlete/cdk 3.10.0 → 3.12.0

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 (238) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/esm2022/lib/components/accordion/components/accordion/accordion.component.mjs +3 -3
  3. package/esm2022/lib/components/accordion/components/accordion-group/accordion-group.component.mjs +3 -3
  4. package/esm2022/lib/components/accordion/partials/accordion-hint/accordion-hint.directive.mjs +3 -3
  5. package/esm2022/lib/components/accordion/partials/accordion-hint-wrapper/accordion-hint-wrapper.directive.mjs +3 -3
  6. package/esm2022/lib/components/accordion/partials/accordion-label/accordion-label.directive.mjs +3 -3
  7. package/esm2022/lib/components/accordion/partials/accordion-label-wrapper/accordion-label-wrapper.directive.mjs +3 -3
  8. package/esm2022/lib/components/bracket/components/bracket/bracket.component.mjs +3 -3
  9. package/esm2022/lib/components/bracket/directives/bracket-match/bracket-match.directive.mjs +3 -3
  10. package/esm2022/lib/components/bracket/directives/bracket-round/bracket-round.directive.mjs +3 -3
  11. package/esm2022/lib/components/bracket/partials/bracket-match/bracket-match.component.mjs +3 -3
  12. package/esm2022/lib/components/bracket/partials/bracket-round-header/bracket-round-header.component.mjs +3 -3
  13. package/esm2022/lib/components/button/components/button/button.component.mjs +3 -3
  14. package/esm2022/lib/components/button/components/query-button/query-button.component.mjs +3 -3
  15. package/esm2022/lib/components/button/directives/button/button.directive.mjs +3 -3
  16. package/esm2022/lib/components/button/directives/query-button/query-button.directive.mjs +3 -3
  17. package/esm2022/lib/components/filter-overlay/components/filter-overlay-page-outlet/filter-overlay-page-outlet.component.mjs +30 -16
  18. package/esm2022/lib/components/filter-overlay/constants/filter-overlay.constants.mjs +3 -0
  19. package/esm2022/lib/components/filter-overlay/constants/index.mjs +2 -0
  20. package/esm2022/lib/components/filter-overlay/constants/public-api.mjs +2 -0
  21. package/esm2022/lib/components/filter-overlay/directives/filter-overlay-link/filter-overlay-link.directive.mjs +26 -6
  22. package/esm2022/lib/components/filter-overlay/directives/filter-overlay-reset/filter-overlay-reset.directive.mjs +25 -6
  23. package/esm2022/lib/components/filter-overlay/directives/filter-overlay-submit/filter-overlay-submit.directive.mjs +25 -6
  24. package/esm2022/lib/components/filter-overlay/public-api.mjs +2 -1
  25. package/esm2022/lib/components/filter-overlay/services/filter-overlay.service.mjs +37 -0
  26. package/esm2022/lib/components/filter-overlay/services/public-api.mjs +2 -0
  27. package/esm2022/lib/components/filter-overlay/types/filter-overlay-config.types.mjs +2 -0
  28. package/esm2022/lib/components/filter-overlay/types/index.mjs +2 -0
  29. package/esm2022/lib/components/filter-overlay/types/public-api.mjs +2 -0
  30. package/esm2022/lib/components/filter-overlay/utils/filter-overlay-ref.mjs +50 -0
  31. package/esm2022/lib/components/filter-overlay/utils/index.mjs +2 -0
  32. package/esm2022/lib/components/filter-overlay/utils/public-api.mjs +2 -0
  33. package/esm2022/lib/components/forms/components/checkbox/components/checkbox/checkbox.component.mjs +3 -3
  34. package/esm2022/lib/components/forms/components/checkbox/components/checkbox-field/checkbox-field.component.mjs +3 -3
  35. package/esm2022/lib/components/forms/components/checkbox/components/checkbox-group/checkbox-group.component.mjs +3 -3
  36. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox/checkbox.directive.mjs +3 -3
  37. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-field/checkbox-field.directive.mjs +3 -3
  38. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-group/checkbox-group.directive.mjs +3 -3
  39. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-group-control/checkbox-group-control.directive.mjs +3 -3
  40. package/esm2022/lib/components/forms/components/error/components/error/error.component.mjs +3 -3
  41. package/esm2022/lib/components/forms/components/input/components/date-input/date-input.component.mjs +3 -3
  42. package/esm2022/lib/components/forms/components/input/components/email-input/email-input.component.mjs +3 -3
  43. package/esm2022/lib/components/forms/components/input/components/input-field/input-field.component.mjs +3 -3
  44. package/esm2022/lib/components/forms/components/input/components/number-input/number-input.component.mjs +3 -3
  45. package/esm2022/lib/components/forms/components/input/components/password-input/password-input.component.mjs +3 -3
  46. package/esm2022/lib/components/forms/components/input/components/search-input/search-input.component.mjs +3 -3
  47. package/esm2022/lib/components/forms/components/input/components/text-input/text-input.component.mjs +3 -3
  48. package/esm2022/lib/components/forms/components/input/components/textarea-input/textarea-input.component.mjs +3 -3
  49. package/esm2022/lib/components/forms/components/input/directives/autosize-textarea/autosize-textarea.directive.mjs +3 -3
  50. package/esm2022/lib/components/forms/components/input/directives/date-input/date-input.directive.mjs +3 -3
  51. package/esm2022/lib/components/forms/components/input/directives/email-input/email-input.directive.mjs +3 -3
  52. package/esm2022/lib/components/forms/components/input/directives/number-input/number-input.directive.mjs +3 -3
  53. package/esm2022/lib/components/forms/components/input/directives/password-input/password-input.directive.mjs +3 -3
  54. package/esm2022/lib/components/forms/components/input/directives/search-input/search-input.directive.mjs +3 -3
  55. package/esm2022/lib/components/forms/components/input/directives/text-input/text-input.directive.mjs +3 -3
  56. package/esm2022/lib/components/forms/components/input/directives/textarea-input/textarea-input.directive.mjs +3 -3
  57. package/esm2022/lib/components/forms/components/input/partials/password-input-toggle/password-input-toggle.component.mjs +3 -3
  58. package/esm2022/lib/components/forms/components/input/partials/search-input-clear/search-input-clear.component.mjs +3 -3
  59. package/esm2022/lib/components/forms/components/label/components/label/label.component.mjs +3 -3
  60. package/esm2022/lib/components/forms/components/label/directives/label-suffix/label-suffix.directive.mjs +3 -3
  61. package/esm2022/lib/components/forms/components/radio/components/radio/radio.component.mjs +3 -3
  62. package/esm2022/lib/components/forms/components/radio/components/radio-field/radio-field.component.mjs +3 -3
  63. package/esm2022/lib/components/forms/components/radio/components/radio-group/radio-group.component.mjs +3 -3
  64. package/esm2022/lib/components/forms/components/radio/directives/radio/radio.directive.mjs +3 -3
  65. package/esm2022/lib/components/forms/components/radio/directives/radio-field/radio-field.directive.mjs +3 -3
  66. package/esm2022/lib/components/forms/components/radio/directives/radio-group/radio-group.directive.mjs +3 -3
  67. package/esm2022/lib/components/forms/components/segmented-button/components/segmented-button/segmented-button.component.mjs +3 -3
  68. package/esm2022/lib/components/forms/components/segmented-button/components/segmented-button-field/segmented-button-field.component.mjs +3 -3
  69. package/esm2022/lib/components/forms/components/segmented-button/components/segmented-button-group/segmented-button-group.component.mjs +3 -3
  70. package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button/segmented-button.directive.mjs +3 -3
  71. package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button-field/segmented-button-field.directive.mjs +3 -3
  72. package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button-group/segmented-button-group.directive.mjs +3 -3
  73. package/esm2022/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.mjs +6 -4
  74. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.mjs +3 -3
  75. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-empty-template/combobox-body-empty-template.directive.mjs +3 -3
  76. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-error-template/combobox-body-error-template.directive.mjs +3 -3
  77. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-loading-template/combobox-body-loading-template.directive.mjs +3 -3
  78. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-more-items-hint-template/combobox-body-more-items-hint-template.directive.mjs +3 -3
  79. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-option-template/combobox-option-template.directive.mjs +3 -3
  80. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-selected-option-template/combobox-selected-option-template.directive.mjs +3 -3
  81. package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-body/combobox-body.component.mjs +3 -3
  82. package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.mjs +3 -3
  83. package/esm2022/lib/components/forms/components/select/components/native-select/components/native-select/native-select.component.mjs +3 -3
  84. package/esm2022/lib/components/forms/components/select/components/native-select/directives/native-select-input/native-select-input.directive.mjs +3 -3
  85. package/esm2022/lib/components/forms/components/select/components/native-select/directives/native-select-option/native-select-option.directive.mjs +3 -3
  86. package/esm2022/lib/components/forms/components/select/components/native-select/partials/native-select-option/native-select-option.component.mjs +3 -3
  87. package/esm2022/lib/components/forms/components/select/components/select/components/select/select.component.mjs +3 -3
  88. package/esm2022/lib/components/forms/components/select/components/select/directives/select/select.directive.mjs +3 -3
  89. package/esm2022/lib/components/forms/components/select/components/select/directives/select-body/select-body.directive.mjs +3 -3
  90. package/esm2022/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.mjs +3 -3
  91. package/esm2022/lib/components/forms/components/select/components/select/partials/select-body/select-body.component.mjs +3 -3
  92. package/esm2022/lib/components/forms/components/select/components/select/partials/select-option/select-option.component.mjs +3 -3
  93. package/esm2022/lib/components/forms/components/select/components/select-field/select-field.component.mjs +3 -3
  94. package/esm2022/lib/components/forms/components/select/directives/select-field/select-field.directive.mjs +3 -3
  95. package/esm2022/lib/components/forms/components/selection-list/components/selection-list-field/selection-list-field.component.mjs +3 -3
  96. package/esm2022/lib/components/forms/components/selection-list/components/selection-list-option/selection-list-option.component.mjs +3 -3
  97. package/esm2022/lib/components/forms/components/selection-list/directives/selection-list-field/selection-list-field.directive.mjs +3 -3
  98. package/esm2022/lib/components/forms/components/selection-list/directives/selection-list-option/selection-list-option.directive.mjs +3 -3
  99. package/esm2022/lib/components/forms/components/slide-toggle/components/slide-toggle/slide-toggle.component.mjs +3 -3
  100. package/esm2022/lib/components/forms/components/slide-toggle/components/slide-toggle-field/slide-toggle-field.component.mjs +3 -3
  101. package/esm2022/lib/components/forms/components/slide-toggle/directives/slide-toggle/slide-toggle.directive.mjs +3 -3
  102. package/esm2022/lib/components/forms/components/slider/components/slider/slider.component.mjs +3 -3
  103. package/esm2022/lib/components/forms/components/slider/components/slider-field/slider-field.component.mjs +3 -3
  104. package/esm2022/lib/components/forms/directives/dynamic-form-field/dynamic-form-field.directive.mjs +3 -3
  105. package/esm2022/lib/components/forms/directives/dynamic-form-group/dynamic-form-group.directive.mjs +3 -3
  106. package/esm2022/lib/components/forms/directives/expose-input-vars/expose-input-vars.directive.mjs +3 -3
  107. package/esm2022/lib/components/forms/directives/if-input-empty/if-input-empty.directive.mjs +3 -3
  108. package/esm2022/lib/components/forms/directives/if-input-filled/if-input-filled.directive.mjs +3 -3
  109. package/esm2022/lib/components/forms/directives/input/input.directive.mjs +3 -3
  110. package/esm2022/lib/components/forms/directives/input-prefix/input-prefix.directive.mjs +3 -3
  111. package/esm2022/lib/components/forms/directives/input-suffix/input-suffix.directive.mjs +3 -3
  112. package/esm2022/lib/components/forms/directives/native-input-ref/native-input-ref.directive.mjs +3 -3
  113. package/esm2022/lib/components/forms/directives/static-form-field/static-form-field.directive.mjs +3 -3
  114. package/esm2022/lib/components/forms/directives/static-form-group/static-form-group.directive.mjs +3 -3
  115. package/esm2022/lib/components/forms/directives/writeable-input/writeable-input.directive.mjs +3 -3
  116. package/esm2022/lib/components/forms/services/default-validator-errors.service.mjs +3 -3
  117. package/esm2022/lib/components/forms/services/form-field-state.service.mjs +3 -3
  118. package/esm2022/lib/components/forms/services/form-group-state.service.mjs +3 -3
  119. package/esm2022/lib/components/forms/services/input-state.service.mjs +3 -3
  120. package/esm2022/lib/components/forms/utils/decorated-form-field.base.mjs +3 -3
  121. package/esm2022/lib/components/forms/utils/decorated-input.base.mjs +3 -3
  122. package/esm2022/lib/components/forms/utils/input.base.mjs +3 -3
  123. package/esm2022/lib/components/icons/chevron-icon/chevron-icon.component.mjs +3 -3
  124. package/esm2022/lib/components/masonry/components/masonry/masonry.component.mjs +3 -3
  125. package/esm2022/lib/components/masonry/partials/masonry-item/masonry-item.component.mjs +3 -3
  126. package/esm2022/lib/components/overlay/components/bottom-sheet/components/bottom-sheet-container/bottom-sheet-container.component.mjs +3 -3
  127. package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-container-base/bottom-sheet-container-base.component.mjs +3 -3
  128. package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-drag-handle/bottom-sheet-drag-handle.component.mjs +3 -3
  129. package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-title/bottom-sheet-title.directive.mjs +3 -3
  130. package/esm2022/lib/components/overlay/components/bottom-sheet/services/bottom-sheet-base.service.mjs +3 -3
  131. package/esm2022/lib/components/overlay/components/bottom-sheet/services/bottom-sheet-swipe-handler.service.mjs +3 -3
  132. package/esm2022/lib/components/overlay/components/bottom-sheet/services/bottom-sheet.service.mjs +3 -3
  133. package/esm2022/lib/components/overlay/components/dialog/components/dialog-container/dialog-container.component.mjs +3 -3
  134. package/esm2022/lib/components/overlay/components/dialog/partials/dialog-close/dialog-close.directive.mjs +3 -3
  135. package/esm2022/lib/components/overlay/components/dialog/partials/dialog-container-base/dialog-container-base.component.mjs +3 -3
  136. package/esm2022/lib/components/overlay/components/dialog/partials/dialog-title/dialog-title.directive.mjs +3 -3
  137. package/esm2022/lib/components/overlay/components/dialog/services/dialog-base.service.mjs +3 -3
  138. package/esm2022/lib/components/overlay/components/dialog/services/dialog.service.mjs +3 -3
  139. package/esm2022/lib/components/overlay/components/menu/context-menu-trigger.mjs +6 -6
  140. package/esm2022/lib/components/overlay/components/menu/menu-aim.mjs +6 -6
  141. package/esm2022/lib/components/overlay/components/menu/menu-bar.mjs +3 -3
  142. package/esm2022/lib/components/overlay/components/menu/menu-base.mjs +3 -3
  143. package/esm2022/lib/components/overlay/components/menu/menu-group.mjs +3 -3
  144. package/esm2022/lib/components/overlay/components/menu/menu-item-checkbox.mjs +3 -3
  145. package/esm2022/lib/components/overlay/components/menu/menu-item-radio.mjs +3 -3
  146. package/esm2022/lib/components/overlay/components/menu/menu-item-selectable.mjs +3 -3
  147. package/esm2022/lib/components/overlay/components/menu/menu-item.mjs +3 -3
  148. package/esm2022/lib/components/overlay/components/menu/menu-module.mjs +4 -4
  149. package/esm2022/lib/components/overlay/components/menu/menu-stack.mjs +3 -3
  150. package/esm2022/lib/components/overlay/components/menu/menu-trigger-base.mjs +3 -3
  151. package/esm2022/lib/components/overlay/components/menu/menu-trigger.mjs +3 -3
  152. package/esm2022/lib/components/overlay/components/menu/menu.mjs +3 -3
  153. package/esm2022/lib/components/overlay/components/overlay/components/overlay-container/overlay-container.component.mjs +15 -11
  154. package/esm2022/lib/components/overlay/components/overlay/partials/overlay-close/overlay-close.directive.mjs +5 -5
  155. package/esm2022/lib/components/overlay/components/overlay/partials/overlay-title/overlay-title.directive.mjs +3 -3
  156. package/esm2022/lib/components/overlay/components/overlay/services/overlay.service.mjs +143 -48
  157. package/esm2022/lib/components/overlay/components/overlay/types/overlay.types.mjs +1 -1
  158. package/esm2022/lib/components/overlay/components/overlay/utils/overlay-position-builder.mjs +26 -7
  159. package/esm2022/lib/components/overlay/components/overlay/utils/overlay-ref.mjs +5 -5
  160. package/esm2022/lib/components/overlay/components/toggletip/components/toggletip/toggletip.component.mjs +3 -3
  161. package/esm2022/lib/components/overlay/components/toggletip/directives/toggletip/toggletip.directive.mjs +3 -3
  162. package/esm2022/lib/components/overlay/components/tooltip/components/tooltip/tooltip.component.mjs +3 -3
  163. package/esm2022/lib/components/overlay/components/tooltip/directives/tooltip/tooltip.directive.mjs +3 -3
  164. package/esm2022/lib/components/overlay/directives/dynamic-overlay-title/dynamic-overlay-title.directive.mjs +3 -3
  165. package/esm2022/lib/components/overlay/index.mjs +2 -0
  166. package/esm2022/lib/components/overlay/services/dynamic-overlay.service.mjs +3 -3
  167. package/esm2022/lib/components/pagination/components/pagination/pagination.component.mjs +3 -3
  168. package/esm2022/lib/components/pagination/partials/pagination-link/pagination-link.directive.mjs +3 -3
  169. package/esm2022/lib/components/pagination/services/pagination-head.service.mjs +3 -3
  170. package/esm2022/lib/components/picture/picture-data.directive.mjs +3 -3
  171. package/esm2022/lib/components/picture/picture.component.mjs +3 -3
  172. package/esm2022/lib/components/progress-spinner/progress-spinner.component.mjs +3 -3
  173. package/esm2022/lib/components/query-error/components/query-error/query-error.component.mjs +3 -3
  174. package/esm2022/lib/components/query-error/directives/query-error/query-error.directive.mjs +3 -3
  175. package/esm2022/lib/components/scrollable/components/scrollable/scrollable.component.mjs +3 -3
  176. package/esm2022/lib/components/skeleton/components/skeleton/skeleton.component.mjs +3 -3
  177. package/esm2022/lib/components/skeleton/partials/skeleton-item/skeleton-item.component.mjs +3 -3
  178. package/esm2022/lib/components/sort/components/sort-header/sort-header.component.mjs +3 -3
  179. package/esm2022/lib/components/sort/partials/sort/sort.directive.mjs +3 -3
  180. package/esm2022/lib/components/sort/services/sort-header-intl.mjs +3 -3
  181. package/esm2022/lib/components/table/components/table/table.component.mjs +3 -3
  182. package/esm2022/lib/components/table/partials/cells/cell/cell.directive.mjs +3 -3
  183. package/esm2022/lib/components/table/partials/cells/cell-def/cell-def.directive.mjs +3 -3
  184. package/esm2022/lib/components/table/partials/cells/column-def/column-def.directive.mjs +3 -3
  185. package/esm2022/lib/components/table/partials/cells/footer-cell/footer-cell.directive.mjs +3 -3
  186. package/esm2022/lib/components/table/partials/cells/footer-cell-def/footer-cell-def.directive.mjs +3 -3
  187. package/esm2022/lib/components/table/partials/cells/header-cell/header-cell.directive.mjs +3 -3
  188. package/esm2022/lib/components/table/partials/cells/header-cell-def/header-cell-def.directive.mjs +3 -3
  189. package/esm2022/lib/components/table/partials/cells/text-column/text-column.component.mjs +3 -3
  190. package/esm2022/lib/components/table/partials/rows/footer-row/footer-row.component.mjs +3 -3
  191. package/esm2022/lib/components/table/partials/rows/footer-row-def/footer-row-def.directive.mjs +3 -3
  192. package/esm2022/lib/components/table/partials/rows/header-row/header-row.component.mjs +3 -3
  193. package/esm2022/lib/components/table/partials/rows/header-row-def/header-row-def.directive.mjs +3 -3
  194. package/esm2022/lib/components/table/partials/rows/no-data-row/no-data-row.directive.mjs +3 -3
  195. package/esm2022/lib/components/table/partials/rows/recycle-rows/recycle-rows.directive.mjs +3 -3
  196. package/esm2022/lib/components/table/partials/rows/row/row.component.mjs +3 -3
  197. package/esm2022/lib/components/table/partials/rows/row-def/row-def.directive.mjs +3 -3
  198. package/esm2022/lib/components/table/partials/table-busy/table-busy.directive.mjs +3 -3
  199. package/esm2022/lib/components/table/partials/table-busy-outlet/table-busy-outlet.directive.mjs +3 -3
  200. package/esm2022/lib/components/tabs/components/inline-tabs/inline-tabs.component.mjs +3 -3
  201. package/esm2022/lib/components/tabs/components/nav-tabs/nav-tabs.component.mjs +3 -3
  202. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab/inline-tab.component.mjs +3 -3
  203. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-body/inline-tab-body.component.mjs +3 -3
  204. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-body-host/inline-tab-body-host.directive.mjs +3 -3
  205. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-content/inline-tab-content.directive.mjs +3 -3
  206. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-header/inline-tab-header.component.mjs +3 -3
  207. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-label/inline-tab-label.directive.mjs +3 -3
  208. package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-label-wrapper/inline-tab-label-wrapper.directive.mjs +3 -3
  209. package/esm2022/lib/components/tabs/partials/nav-tabs/nav-tab-link/nav-tab-link.directive.mjs +3 -3
  210. package/esm2022/lib/components/tabs/partials/nav-tabs/nav-tabs-outlet/nav-tabs-outlet.component.mjs +3 -3
  211. package/esm2022/lib/components/tabs/utils/active-tab-underline.util.mjs +3 -3
  212. package/esm2022/lib/components/tabs/utils/paginated-tab-header.directive.mjs +3 -3
  213. package/esm2022/lib/services/swipe-handler.service.mjs +6 -6
  214. package/fesm2022/ethlete-cdk.mjs +8717 -8449
  215. package/fesm2022/ethlete-cdk.mjs.map +1 -1
  216. package/lib/components/filter-overlay/components/filter-overlay-page-outlet/filter-overlay-page-outlet.component.d.ts +4 -0
  217. package/lib/components/filter-overlay/constants/filter-overlay.constants.d.ts +3 -0
  218. package/lib/components/filter-overlay/constants/index.d.ts +1 -0
  219. package/lib/components/filter-overlay/constants/public-api.d.ts +1 -0
  220. package/lib/components/filter-overlay/directives/filter-overlay-link/filter-overlay-link.directive.d.ts +5 -1
  221. package/lib/components/filter-overlay/directives/filter-overlay-reset/filter-overlay-reset.directive.d.ts +5 -1
  222. package/lib/components/filter-overlay/directives/filter-overlay-submit/filter-overlay-submit.directive.d.ts +5 -1
  223. package/lib/components/filter-overlay/public-api.d.ts +1 -0
  224. package/lib/components/filter-overlay/services/filter-overlay.service.d.ts +13 -0
  225. package/lib/components/filter-overlay/services/public-api.d.ts +1 -0
  226. package/lib/components/filter-overlay/types/filter-overlay-config.types.d.ts +26 -0
  227. package/lib/components/filter-overlay/types/index.d.ts +1 -0
  228. package/lib/components/filter-overlay/types/public-api.d.ts +1 -0
  229. package/lib/components/filter-overlay/utils/filter-overlay-ref.d.ts +16 -0
  230. package/lib/components/filter-overlay/utils/index.d.ts +1 -0
  231. package/lib/components/filter-overlay/utils/public-api.d.ts +1 -0
  232. package/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.d.ts +1 -1
  233. package/lib/components/overlay/components/overlay/types/overlay.types.d.ts +13 -1
  234. package/lib/components/overlay/components/overlay/utils/overlay-position-builder.d.ts +11 -0
  235. package/lib/components/overlay/components/overlay/utils/overlay-ref.d.ts +1 -1
  236. package/lib/components/overlay/index.d.ts +1 -0
  237. package/package.json +3 -3
  238. package/src/lib/styles/cdk.css +3 -1
@@ -5,7 +5,7 @@ import { ViewportService, createDestroy, equal } from '@ethlete/core';
5
5
  import { Subject, combineLatest, defer, map, of, pairwise, startWith, takeUntil, tap } from 'rxjs';
6
6
  import { OverlayContainerComponent } from '../components';
7
7
  import { OVERLAY_CONFIG, OVERLAY_DATA, OVERLAY_DEFAULT_OPTIONS, OVERLAY_SCROLL_STRATEGY } from '../constants';
8
- import { OverlayPositionBuilder, OverlayRef, createOverlayConfig } from '../utils';
8
+ import { ET_OVERLAY_BOTTOM_SHEET_CLASS, ET_OVERLAY_LEFT_SHEET_CLASS, ET_OVERLAY_RIGHT_SHEET_CLASS, ET_OVERLAY_TOP_SHEET_CLASS, OverlayPositionBuilder, OverlayRef, createOverlayConfig, } from '../utils';
9
9
  import * as i0 from "@angular/core";
10
10
  let uniqueId = 0;
11
11
  const ID_PREFIX = 'et-overlay-';
@@ -37,6 +37,15 @@ const setClass = (el, prevClass, currClass) => {
37
37
  }
38
38
  }
39
39
  };
40
+ const isHtmlElement = (element) => {
41
+ return element instanceof HTMLElement;
42
+ };
43
+ const isTouchEvent = (event) => {
44
+ return event.type[0] === 't';
45
+ };
46
+ const isPointerEvent = (event) => {
47
+ return event.type[0] === 'c';
48
+ };
40
49
  export class OverlayService {
41
50
  constructor() {
42
51
  this._destroy$ = createDestroy();
@@ -71,6 +80,7 @@ export class OverlayService {
71
80
  ...composedConfig,
72
81
  disableClose: true,
73
82
  closeOnDestroy: false,
83
+ panelClass: 'et-overlay-pane',
74
84
  container: {
75
85
  type: OverlayContainerComponent,
76
86
  providers: () => [
@@ -85,6 +95,7 @@ export class OverlayService {
85
95
  { provide: OverlayContainerComponent, useValue: overlayContainer },
86
96
  { provide: OVERLAY_DATA, useValue: cdkConfig.data },
87
97
  { provide: OverlayRef, useValue: overlayRef },
98
+ ...(composedConfig.providers ?? []),
88
99
  ];
89
100
  },
90
101
  });
@@ -92,59 +103,143 @@ export class OverlayService {
92
103
  overlayRef.componentRef = cdkRef.componentRef;
93
104
  overlayRef.componentInstance = cdkRef.componentInstance;
94
105
  cdkRef.containerInstance.overlayRef = overlayRef;
95
- if (composedConfig.positions?.length) {
96
- combineLatest(composedConfig.positions.map((breakpoint) => (breakpoint.breakpoint ? this._viewportService.observe({ min: breakpoint.breakpoint }) : of(true)).pipe(map((isActive) => ({
97
- isActive,
98
- config: breakpoint.config,
99
- size: typeof breakpoint.breakpoint === 'number'
100
- ? breakpoint.breakpoint
101
- : breakpoint.breakpoint === undefined
102
- ? 0
103
- : this._viewportService.getBreakpointSize(breakpoint.breakpoint, 'min'),
104
- })))))
105
- .pipe(takeUntil(overlayRef.afterClosed()), takeUntil(this._destroy$), map((entries) => {
106
- const activeBreakpoints = entries.filter((entry) => entry.isActive);
107
- const highestBreakpoint = activeBreakpoints.reduce((prev, curr) => (prev.size > curr.size ? prev : curr));
108
- return highestBreakpoint.config;
109
- }), startWith(null), pairwise(), tap(([prevConfig, currConfig]) => {
110
- if (!currConfig)
111
- return;
112
- const overlayPaneEl = cdkRef.overlayRef.overlayElement;
113
- const containerEl = overlayRef._containerInstance.elementRef.nativeElement;
114
- const backdropEl = cdkRef.overlayRef.backdropElement;
115
- const overlayWrapper = cdkRef.overlayRef.hostElement;
116
- setStyle(overlayPaneEl, 'min-width', currConfig.minWidth);
117
- setStyle(overlayPaneEl, 'min-height', currConfig.minHeight);
106
+ const containerEl = overlayRef._containerInstance.elementRef.nativeElement;
107
+ const overlayPaneEl = cdkRef.overlayRef.overlayElement;
108
+ const backdropEl = cdkRef.overlayRef.backdropElement;
109
+ const overlayWrapper = cdkRef.overlayRef.hostElement;
110
+ const defaultAnimationBuffer = 50; // 50px since the default animation uses spring physics and thus will overshoot.
111
+ const useDefaultAnimation = composedConfig.customAnimated !== true;
112
+ const origin = composedConfig.origin;
113
+ if (origin) {
114
+ const originX = isHtmlElement(origin)
115
+ ? origin.getBoundingClientRect().left
116
+ : isTouchEvent(origin)
117
+ ? origin.changedTouches[0].clientX
118
+ : isPointerEvent(origin)
119
+ ? origin.clientX !== 0
120
+ ? origin.clientX
121
+ : origin.target.getBoundingClientRect().left
122
+ : -1;
123
+ const originY = isHtmlElement(origin)
124
+ ? origin.getBoundingClientRect().top
125
+ : isTouchEvent(origin)
126
+ ? origin.changedTouches[0].clientY
127
+ : isPointerEvent(origin)
128
+ ? origin.clientY !== 0
129
+ ? origin.clientY
130
+ : origin.target.getBoundingClientRect().top
131
+ : -1;
132
+ if (originX !== -1 && originY !== -1) {
133
+ setStyle(containerEl, 'transform-origin', `${originX}px ${originY}px`);
134
+ }
135
+ }
136
+ combineLatest(composedConfig.positions.map((breakpoint) => (breakpoint.breakpoint ? this._viewportService.observe({ min: breakpoint.breakpoint }) : of(true)).pipe(map((isActive) => ({
137
+ isActive,
138
+ config: breakpoint.config,
139
+ size: typeof breakpoint.breakpoint === 'number'
140
+ ? breakpoint.breakpoint
141
+ : breakpoint.breakpoint === undefined
142
+ ? 0
143
+ : this._viewportService.getBreakpointSize(breakpoint.breakpoint, 'min'),
144
+ })))))
145
+ .pipe(takeUntil(overlayRef.afterClosed()), takeUntil(this._destroy$), map((entries) => {
146
+ const activeBreakpoints = entries.filter((entry) => entry.isActive);
147
+ const highestBreakpoint = activeBreakpoints.reduce((prev, curr) => (prev.size > curr.size ? prev : curr));
148
+ return highestBreakpoint.config;
149
+ }), startWith(null), pairwise(), tap(([prevConfig, currConfig]) => {
150
+ if (!currConfig)
151
+ return;
152
+ const containerClass = currConfig.containerClass;
153
+ const applyDefaultMaxWidths = () => {
118
154
  setStyle(overlayPaneEl, 'max-width', currConfig.maxWidth);
119
155
  setStyle(overlayPaneEl, 'max-height', currConfig.maxHeight);
120
- setStyle(overlayPaneEl, 'width', currConfig.width);
121
- setStyle(overlayPaneEl, 'height', currConfig.height);
122
- setClass(containerEl, prevConfig?.containerClass, currConfig?.containerClass);
123
- setClass(overlayPaneEl, prevConfig?.paneClass, currConfig?.paneClass);
124
- setClass(overlayWrapper, prevConfig?.overlayClass, currConfig?.overlayClass);
125
- if (backdropEl) {
126
- setClass(backdropEl, prevConfig?.backdropClass, currConfig?.backdropClass);
156
+ };
157
+ const combineOrMakeCalc = (value, append) => {
158
+ if (!value)
159
+ return append;
160
+ if (typeof value === 'number') {
161
+ return `calc(${value}px + ${append})`;
127
162
  }
128
- if (!equal(prevConfig?.position, currConfig?.position)) {
129
- overlayRef.updatePosition(currConfig.position);
163
+ else if (value.startsWith('calc(')) {
164
+ return `${value.slice(0, value.length - 1)} + ${append})`;
130
165
  }
131
- if (currConfig.positionStrategy) {
132
- cdkRef.overlayRef.updatePositionStrategy(currConfig.positionStrategy);
133
- }
134
- else {
135
- cdkRef.overlayRef.updatePosition();
166
+ return `calc(${value} + ${append})`;
167
+ };
168
+ if (useDefaultAnimation && containerClass?.length) {
169
+ if (containerClass?.includes(ET_OVERLAY_LEFT_SHEET_CLASS) ||
170
+ containerClass?.includes(ET_OVERLAY_RIGHT_SHEET_CLASS)) {
171
+ setStyle(overlayPaneEl, 'max-width', combineOrMakeCalc(currConfig.maxWidth, `${defaultAnimationBuffer}px`));
172
+ setStyle(overlayPaneEl, 'max-height', currConfig.maxHeight);
136
173
  }
137
- if (currConfig.dragToDismiss) {
138
- overlayRef._containerInstance._enableDragToDismiss(currConfig.dragToDismiss);
174
+ else if (containerClass?.includes(ET_OVERLAY_TOP_SHEET_CLASS) ||
175
+ containerClass?.includes(ET_OVERLAY_BOTTOM_SHEET_CLASS)) {
176
+ setStyle(overlayPaneEl, 'max-height', combineOrMakeCalc(currConfig.maxHeight, `${defaultAnimationBuffer}px`));
177
+ setStyle(overlayPaneEl, 'max-width', currConfig.maxWidth);
139
178
  }
140
179
  else {
141
- overlayRef._containerInstance._disableDragToDismiss();
180
+ applyDefaultMaxWidths();
142
181
  }
143
- }))
144
- .subscribe();
145
- }
182
+ }
183
+ else {
184
+ applyDefaultMaxWidths();
185
+ }
186
+ setStyle(overlayPaneEl, 'min-width', currConfig.minWidth);
187
+ setStyle(overlayPaneEl, 'min-height', currConfig.minHeight);
188
+ setStyle(overlayPaneEl, 'width', currConfig.width);
189
+ setStyle(overlayPaneEl, 'height', currConfig.height);
190
+ setClass(containerEl, prevConfig?.containerClass, currConfig?.containerClass);
191
+ setClass(overlayPaneEl, prevConfig?.paneClass, currConfig?.paneClass);
192
+ setClass(overlayWrapper, prevConfig?.overlayClass, currConfig?.overlayClass);
193
+ // FIXME: These classes should only be removed if no open overlays require them inside their config.
194
+ setClass(document.documentElement, prevConfig?.documentClass, currConfig?.documentClass);
195
+ setClass(document.body, prevConfig?.bodyClass, currConfig?.bodyClass);
196
+ if (backdropEl) {
197
+ setClass(backdropEl, prevConfig?.backdropClass, currConfig?.backdropClass);
198
+ }
199
+ if (!equal(prevConfig?.position, currConfig?.position)) {
200
+ overlayRef.updatePosition(currConfig.position);
201
+ }
202
+ if (currConfig.positionStrategy) {
203
+ cdkRef.overlayRef.updatePositionStrategy(currConfig.positionStrategy);
204
+ }
205
+ else {
206
+ cdkRef.overlayRef.updatePosition();
207
+ }
208
+ if (currConfig.dragToDismiss) {
209
+ overlayRef._containerInstance._enableDragToDismiss(currConfig.dragToDismiss);
210
+ }
211
+ else {
212
+ overlayRef._containerInstance._disableDragToDismiss();
213
+ }
214
+ }))
215
+ .subscribe();
146
216
  this.openOverlays.push(overlayRef);
147
217
  this.afterOpened.next(overlayRef);
218
+ overlayRef.beforeClosed().subscribe(() => {
219
+ // FIXME: These classes should only be removed if no open overlays require them inside their config.
220
+ const documentClasses = composedConfig.positions.map((position) => position.config.documentClass);
221
+ for (const klass of documentClasses) {
222
+ if (!klass)
223
+ continue;
224
+ if (Array.isArray(klass)) {
225
+ document.documentElement.classList.remove(...klass);
226
+ }
227
+ else {
228
+ document.documentElement.classList.remove(klass);
229
+ }
230
+ }
231
+ const bodyClasses = composedConfig.positions.map((position) => position.config.bodyClass);
232
+ for (const klass of bodyClasses) {
233
+ if (!klass)
234
+ continue;
235
+ if (Array.isArray(klass)) {
236
+ document.body.classList.remove(...klass);
237
+ }
238
+ else {
239
+ document.body.classList.remove(klass);
240
+ }
241
+ }
242
+ });
148
243
  overlayRef.afterClosed().subscribe(() => {
149
244
  const index = this.openOverlays.indexOf(overlayRef);
150
245
  if (index === -1)
@@ -173,10 +268,10 @@ export class OverlayService {
173
268
  const parent = this._parentOverlayService;
174
269
  return parent ? parent._getAfterAllClosed() : this._afterAllClosedAtThisLevel;
175
270
  }
176
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.4", ngImport: i0, type: OverlayService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
177
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.4", ngImport: i0, type: OverlayService }); }
271
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: OverlayService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
272
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: OverlayService }); }
178
273
  }
179
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.4", ngImport: i0, type: OverlayService, decorators: [{
274
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: OverlayService, decorators: [{
180
275
  type: Injectable
181
276
  }] });
182
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/services/overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { Dialog as CdkDialog, DialogConfig as CdkDialogConfig } from '@angular/cdk/dialog';\nimport { ComponentType } from '@angular/cdk/overlay';\nimport { ComponentRef, Injectable, OnDestroy, TemplateRef, inject } from '@angular/core';\nimport { ViewportService, createDestroy, equal } from '@ethlete/core';\nimport { Observable, Subject, combineLatest, defer, map, of, pairwise, startWith, takeUntil, tap } from 'rxjs';\nimport { OverlayContainerComponent } from '../components';\nimport { OVERLAY_CONFIG, OVERLAY_DATA, OVERLAY_DEFAULT_OPTIONS, OVERLAY_SCROLL_STRATEGY } from '../constants';\nimport { OverlayConfig } from '../types';\nimport { OverlayPositionBuilder, OverlayRef, createOverlayConfig } from '../utils';\n\nlet uniqueId = 0;\nconst ID_PREFIX = 'et-overlay-';\n\nconst setStyle = (el: HTMLElement, style: string, value: string | number | null | undefined) => {\n  if (value === null || value === undefined) {\n    el.style.removeProperty(style);\n  } else {\n    el.style.setProperty(style, coerceCssPixelValue(value));\n  }\n};\n\nconst setClass = (el: HTMLElement, prevClass?: string | string[], currClass?: string | string[]) => {\n  if (!equal(prevClass, currClass)) {\n    if (prevClass) {\n      if (Array.isArray(prevClass)) {\n        el.classList.remove(...prevClass);\n      } else {\n        el.classList.remove(prevClass);\n      }\n    }\n\n    if (currClass) {\n      if (Array.isArray(currClass)) {\n        el.classList.add(...currClass);\n      } else {\n        el.classList.add(currClass);\n      }\n    }\n  }\n};\n\n@Injectable()\nexport class OverlayService implements OnDestroy {\n  private readonly _destroy$ = createDestroy();\n  private readonly _defaultOptions = inject(OVERLAY_DEFAULT_OPTIONS, { optional: true });\n  private readonly _scrollStrategy = inject(OVERLAY_SCROLL_STRATEGY);\n  private readonly _parentOverlayService = inject(OverlayService, { optional: true, skipSelf: true });\n  private readonly _dialog = inject(CdkDialog);\n  private readonly _viewportService = inject(ViewportService);\n\n  private readonly _openOverlaysAtThisLevel: OverlayRef[] = [];\n  private readonly _afterAllClosedAtThisLevel = new Subject<void>();\n  private readonly _afterOpenedAtThisLevel = new Subject<OverlayRef>();\n\n  readonly positions = new OverlayPositionBuilder();\n\n  readonly afterAllClosed = defer(() =>\n    this.openOverlays.length ? this._getAfterAllClosed() : this._getAfterAllClosed().pipe(startWith(undefined)),\n  ) as Observable<void>;\n\n  get openOverlays(): OverlayRef[] {\n    return this._parentOverlayService ? this._parentOverlayService.openOverlays : this._openOverlaysAtThisLevel;\n  }\n\n  get afterOpened(): Subject<OverlayRef> {\n    return this._parentOverlayService ? this._parentOverlayService.afterOpened : this._afterOpenedAtThisLevel;\n  }\n\n  ngOnDestroy() {\n    this._closeOverlays(this._openOverlaysAtThisLevel);\n    this._afterAllClosedAtThisLevel.complete();\n    this._afterOpenedAtThisLevel.complete();\n  }\n\n  open<T, D = unknown, R = unknown>(component: ComponentType<T>, config: OverlayConfig<D>): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(template: TemplateRef<T>, config: OverlayConfig<D>): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(\n    template: ComponentType<T> | TemplateRef<T>,\n    config: OverlayConfig<D>,\n  ): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(\n    componentOrTemplateRef: ComponentType<T> | TemplateRef<T>,\n    config: OverlayConfig<D>,\n  ): OverlayRef<T, R> {\n    let overlayRef: OverlayRef<T, R>;\n\n    const composedConfig = createOverlayConfig<D>(this._defaultOptions as OverlayConfig<D>, config);\n    composedConfig.id = composedConfig.id || `${ID_PREFIX}${uniqueId++}`;\n    composedConfig.scrollStrategy = composedConfig.scrollStrategy || this._scrollStrategy();\n\n    const cdkRef = this._dialog.open<R, D, T>(componentOrTemplateRef, {\n      ...composedConfig,\n      disableClose: true,\n      closeOnDestroy: false,\n      container: {\n        type: OverlayContainerComponent,\n        providers: () => [\n          { provide: OVERLAY_CONFIG, useValue: composedConfig },\n          { provide: CdkDialogConfig, useValue: composedConfig },\n        ],\n      },\n      templateContext: () => ({ dialogRef: overlayRef }),\n      providers: (ref, cdkConfig, overlayContainer) => {\n        overlayRef = new OverlayRef(ref, composedConfig, overlayContainer as OverlayContainerComponent);\n\n        return [\n          { provide: OverlayContainerComponent, useValue: overlayContainer },\n          { provide: OVERLAY_DATA, useValue: cdkConfig.data },\n          { provide: OverlayRef, useValue: overlayRef },\n        ];\n      },\n    });\n\n    /* eslint-disable @typescript-eslint/no-non-null-assertion*/\n    (overlayRef! as { componentRef: ComponentRef<T> }).componentRef = cdkRef.componentRef!;\n    overlayRef!.componentInstance = cdkRef.componentInstance!;\n\n    (cdkRef.containerInstance as OverlayContainerComponent).overlayRef = overlayRef!;\n\n    if (composedConfig.positions?.length) {\n      combineLatest(\n        composedConfig.positions.map((breakpoint) =>\n          (breakpoint.breakpoint ? this._viewportService.observe({ min: breakpoint.breakpoint }) : of(true)).pipe(\n            map((isActive) => ({\n              isActive,\n              config: breakpoint.config,\n              size:\n                typeof breakpoint.breakpoint === 'number'\n                  ? breakpoint.breakpoint\n                  : breakpoint.breakpoint === undefined\n                  ? 0\n                  : this._viewportService.getBreakpointSize(breakpoint.breakpoint, 'min'),\n            })),\n          ),\n        ),\n      )\n        .pipe(\n          takeUntil(overlayRef!.afterClosed()),\n          takeUntil(this._destroy$),\n          map((entries) => {\n            const activeBreakpoints = entries.filter((entry) => entry.isActive);\n            const highestBreakpoint = activeBreakpoints.reduce((prev, curr) => (prev.size > curr.size ? prev : curr));\n\n            return highestBreakpoint.config;\n          }),\n          startWith(null),\n          pairwise(),\n          tap(([prevConfig, currConfig]) => {\n            if (!currConfig) return;\n\n            const overlayPaneEl = cdkRef.overlayRef.overlayElement;\n            const containerEl = overlayRef._containerInstance.elementRef.nativeElement;\n            const backdropEl = cdkRef.overlayRef.backdropElement;\n            const overlayWrapper = cdkRef.overlayRef.hostElement;\n\n            setStyle(overlayPaneEl, 'min-width', currConfig.minWidth);\n            setStyle(overlayPaneEl, 'min-height', currConfig.minHeight);\n            setStyle(overlayPaneEl, 'max-width', currConfig.maxWidth);\n            setStyle(overlayPaneEl, 'max-height', currConfig.maxHeight);\n            setStyle(overlayPaneEl, 'width', currConfig.width);\n            setStyle(overlayPaneEl, 'height', currConfig.height);\n\n            setClass(containerEl, prevConfig?.containerClass, currConfig?.containerClass);\n            setClass(overlayPaneEl, prevConfig?.paneClass, currConfig?.paneClass);\n            setClass(overlayWrapper, prevConfig?.overlayClass, currConfig?.overlayClass);\n\n            if (backdropEl) {\n              setClass(backdropEl, prevConfig?.backdropClass, currConfig?.backdropClass);\n            }\n\n            if (!equal(prevConfig?.position, currConfig?.position)) {\n              overlayRef.updatePosition(currConfig.position);\n            }\n\n            if (currConfig.positionStrategy) {\n              cdkRef.overlayRef.updatePositionStrategy(currConfig.positionStrategy);\n            } else {\n              cdkRef.overlayRef.updatePosition();\n            }\n\n            if (currConfig.dragToDismiss) {\n              overlayRef._containerInstance._enableDragToDismiss(currConfig.dragToDismiss);\n            } else {\n              overlayRef._containerInstance._disableDragToDismiss();\n            }\n          }),\n        )\n        .subscribe();\n    }\n\n    this.openOverlays.push(overlayRef!);\n    this.afterOpened.next(overlayRef!);\n\n    overlayRef!.afterClosed().subscribe(() => {\n      const index = this.openOverlays.indexOf(overlayRef);\n\n      if (index === -1) return;\n\n      this.openOverlays.splice(index, 1);\n\n      if (!this.openOverlays.length) {\n        this._getAfterAllClosed().next();\n      }\n    });\n\n    return overlayRef!;\n\n    /* eslint-enable @typescript-eslint/no-non-null-assertion*/\n  }\n\n  closeAll(): void {\n    this._closeOverlays(this.openOverlays);\n  }\n\n  getOverlayById(id: string): OverlayRef | undefined {\n    return this.openOverlays.find((overlay) => overlay.id === id);\n  }\n\n  private _closeOverlays(overlays: OverlayRef[]) {\n    let i = overlays.length;\n\n    while (i--) {\n      overlays[i].close();\n    }\n  }\n\n  private _getAfterAllClosed(): Subject<void> {\n    const parent = this._parentOverlayService;\n    return parent ? parent._getAfterAllClosed() : this._afterAllClosedAtThisLevel;\n  }\n}\n"]}
277
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/services/overlay.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,MAAM,IAAI,SAAS,EAAE,YAAY,IAAI,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAE3F,OAAO,EAAgB,UAAU,EAA0B,MAAM,EAAE,MAAM,eAAe,CAAC;AACzF,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACtE,OAAO,EAAc,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC/G,OAAO,EAAE,yBAAyB,EAAE,MAAM,eAAe,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,uBAAuB,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AAE9G,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,4BAA4B,EAC5B,0BAA0B,EAC1B,sBAAsB,EACtB,UAAU,EACV,mBAAmB,GACpB,MAAM,UAAU,CAAC;;AAElB,IAAI,QAAQ,GAAG,CAAC,CAAC;AACjB,MAAM,SAAS,GAAG,aAAa,CAAC;AAEhC,MAAM,QAAQ,GAAG,CAAC,EAAe,EAAE,KAAa,EAAE,KAAyC,EAAE,EAAE;IAC7F,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE;QACzC,EAAE,CAAC,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;KAChC;SAAM;QACL,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,EAAE,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;KACzD;AACH,CAAC,CAAC;AAEF,MAAM,QAAQ,GAAG,CAAC,EAAe,EAAE,SAA6B,EAAE,SAA6B,EAAE,EAAE;IACjG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,SAAS,CAAC,EAAE;QAChC,IAAI,SAAS,EAAE;YACb,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;gBAC5B,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,SAAS,CAAC,CAAC;aACnC;iBAAM;gBACL,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;aAChC;SACF;QAED,IAAI,SAAS,EAAE;YACb,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;gBAC5B,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC,CAAC;aAChC;iBAAM;gBACL,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;aAC7B;SACF;KACF;AACH,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,CAAC,OAA8B,EAA0B,EAAE;IAC/E,OAAO,OAAO,YAAY,WAAW,CAAC;AACxC,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,KAAY,EAAuB,EAAE;IACzD,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,cAAc,GAAG,CAAC,KAAY,EAAyB,EAAE;IAC7D,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC;AAC/B,CAAC,CAAC;AAGF,MAAM,OAAO,cAAc;IAD3B;QAEmB,cAAS,GAAG,aAAa,EAAE,CAAC;QAC5B,oBAAe,GAAG,MAAM,CAAC,uBAAuB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QACtE,oBAAe,GAAG,MAAM,CAAC,uBAAuB,CAAC,CAAC;QAClD,0BAAqB,GAAG,MAAM,CAAC,cAAc,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QACnF,YAAO,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAC5B,qBAAgB,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAE3C,6BAAwB,GAAiB,EAAE,CAAC;QAC5C,+BAA0B,GAAG,IAAI,OAAO,EAAQ,CAAC;QACjD,4BAAuB,GAAG,IAAI,OAAO,EAAc,CAAC;QAE5D,cAAS,GAAG,IAAI,sBAAsB,EAAE,CAAC;QAEzC,mBAAc,GAAG,KAAK,CAAC,GAAG,EAAE,CACnC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CACxF,CAAC;KAsRvB;IApRC,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,wBAAwB,CAAC;IAC9G,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC;IAC5G,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;QACnD,IAAI,CAAC,0BAA0B,CAAC,QAAQ,EAAE,CAAC;QAC3C,IAAI,CAAC,uBAAuB,CAAC,QAAQ,EAAE,CAAC;IAC1C,CAAC;IAQD,IAAI,CACF,sBAAyD,EACzD,MAAwB;QAExB,IAAI,UAA4B,CAAC;QAEjC,MAAM,cAAc,GAAG,mBAAmB,CAAI,IAAI,CAAC,eAAmC,EAAE,MAAM,CAAC,CAAC;QAChG,cAAc,CAAC,EAAE,GAAG,cAAc,CAAC,EAAE,IAAI,GAAG,SAAS,GAAG,QAAQ,EAAE,EAAE,CAAC;QACrE,cAAc,CAAC,cAAc,GAAG,cAAc,CAAC,cAAc,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;QAExF,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAU,sBAAsB,EAAE;YAChE,GAAG,cAAc;YACjB,YAAY,EAAE,IAAI;YAClB,cAAc,EAAE,KAAK;YACrB,UAAU,EAAE,iBAAiB;YAC7B,SAAS,EAAE;gBACT,IAAI,EAAE,yBAAyB;gBAC/B,SAAS,EAAE,GAAG,EAAE,CAAC;oBACf,EAAE,OAAO,EAAE,cAAc,EAAE,QAAQ,EAAE,cAAc,EAAE;oBACrD,EAAE,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,cAAc,EAAE;iBACvD;aACF;YACD,eAAe,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC;YAClD,SAAS,EAAE,CAAC,GAAG,EAAE,SAAS,EAAE,gBAAgB,EAAE,EAAE;gBAC9C,UAAU,GAAG,IAAI,UAAU,CAAC,GAAG,EAAE,cAAc,EAAE,gBAA6C,CAAC,CAAC;gBAEhG,OAAO;oBACL,EAAE,OAAO,EAAE,yBAAyB,EAAE,QAAQ,EAAE,gBAAgB,EAAE;oBAClE,EAAE,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,SAAS,CAAC,IAAI,EAAE;oBACnD,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE;oBAC7C,GAAG,CAAC,cAAc,CAAC,SAAS,IAAI,EAAE,CAAC;iBACpC,CAAC;YACJ,CAAC;SACF,CAAC,CAAC;QAEH,4DAA4D;QAC3D,UAAiD,CAAC,YAAY,GAAG,MAAM,CAAC,YAAa,CAAC;QACvF,UAAW,CAAC,iBAAiB,GAAG,MAAM,CAAC,iBAAkB,CAAC;QAEzD,MAAM,CAAC,iBAA+C,CAAC,UAAU,GAAG,UAAW,CAAC;QAEjF,MAAM,WAAW,GAAG,UAAW,CAAC,kBAAkB,CAAC,UAAU,CAAC,aAA4B,CAAC;QAC3F,MAAM,aAAa,GAAG,MAAM,CAAC,UAAU,CAAC,cAAc,CAAC;QACvD,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,eAAe,CAAC;QACrD,MAAM,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC;QACrD,MAAM,sBAAsB,GAAG,EAAE,CAAC,CAAC,gFAAgF;QACnH,MAAM,mBAAmB,GAAG,cAAc,CAAC,cAAc,KAAK,IAAI,CAAC;QACnE,MAAM,MAAM,GAAG,cAAc,CAAC,MAAM,CAAC;QAErC,IAAI,MAAM,EAAE;YACV,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,CAAC;gBACnC,CAAC,CAAC,MAAM,CAAC,qBAAqB,EAAE,CAAC,IAAI;gBACrC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC;oBACtB,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,OAAO;oBAClC,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC;wBACxB,CAAC,CAAC,MAAM,CAAC,OAAO,KAAK,CAAC;4BACpB,CAAC,CAAC,MAAM,CAAC,OAAO;4BAChB,CAAC,CAAE,MAAM,CAAC,MAAsB,CAAC,qBAAqB,EAAE,CAAC,IAAI;wBAC/D,CAAC,CAAC,CAAC,CAAC,CAAC;YACP,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,CAAC;gBACnC,CAAC,CAAC,MAAM,CAAC,qBAAqB,EAAE,CAAC,GAAG;gBACpC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC;oBACtB,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,OAAO;oBAClC,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC;wBACxB,CAAC,CAAC,MAAM,CAAC,OAAO,KAAK,CAAC;4BACpB,CAAC,CAAC,MAAM,CAAC,OAAO;4BAChB,CAAC,CAAE,MAAM,CAAC,MAAsB,CAAC,qBAAqB,EAAE,CAAC,GAAG;wBAC9D,CAAC,CAAC,CAAC,CAAC,CAAC;YAEP,IAAI,OAAO,KAAK,CAAC,CAAC,IAAI,OAAO,KAAK,CAAC,CAAC,EAAE;gBACpC,QAAQ,CAAC,WAAW,EAAE,kBAAkB,EAAE,GAAG,OAAO,MAAM,OAAO,IAAI,CAAC,CAAC;aACxE;SACF;QAED,aAAa,CACX,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAC1C,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,UAAU,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CACrG,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;YACjB,QAAQ;YACR,MAAM,EAAE,UAAU,CAAC,MAAM;YACzB,IAAI,EACF,OAAO,UAAU,CAAC,UAAU,KAAK,QAAQ;gBACvC,CAAC,CAAC,UAAU,CAAC,UAAU;gBACvB,CAAC,CAAC,UAAU,CAAC,UAAU,KAAK,SAAS;oBACrC,CAAC,CAAC,CAAC;oBACH,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,UAAU,CAAC,UAAU,EAAE,KAAK,CAAC;SAC5E,CAAC,CAAC,CACJ,CACF,CACF;aACE,IAAI,CACH,SAAS,CAAC,UAAW,CAAC,WAAW,EAAE,CAAC,EACpC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACd,MAAM,iBAAiB,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACpE,MAAM,iBAAiB,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YAE1G,OAAO,iBAAiB,CAAC,MAAM,CAAC;QAClC,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,EACf,QAAQ,EAAE,EACV,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,UAAU,CAAC,EAAE,EAAE;YAC/B,IAAI,CAAC,UAAU;gBAAE,OAAO;YAExB,MAAM,cAAc,GAAG,UAAU,CAAC,cAAc,CAAC;YAEjD,MAAM,qBAAqB,GAAG,GAAG,EAAE;gBACjC,QAAQ,CAAC,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;gBAC1D,QAAQ,CAAC,aAAa,EAAE,YAAY,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;YAC9D,CAAC,CAAC;YAEF,MAAM,iBAAiB,GAAG,CAAC,KAAyC,EAAE,MAAc,EAAE,EAAE;gBACtF,IAAI,CAAC,KAAK;oBAAE,OAAO,MAAM,CAAC;gBAE1B,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;oBAC7B,OAAO,QAAQ,KAAK,QAAQ,MAAM,GAAG,CAAC;iBACvC;qBAAM,IAAI,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE;oBACpC,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM,MAAM,GAAG,CAAC;iBAC3D;gBAED,OAAO,QAAQ,KAAK,MAAM,MAAM,GAAG,CAAC;YACtC,CAAC,CAAC;YAEF,IAAI,mBAAmB,IAAI,cAAc,EAAE,MAAM,EAAE;gBACjD,IACE,cAAc,EAAE,QAAQ,CAAC,2BAA2B,CAAC;oBACrD,cAAc,EAAE,QAAQ,CAAC,4BAA4B,CAAC,EACtD;oBACA,QAAQ,CACN,aAAa,EACb,WAAW,EACX,iBAAiB,CAAC,UAAU,CAAC,QAAQ,EAAE,GAAG,sBAAsB,IAAI,CAAC,CACtE,CAAC;oBACF,QAAQ,CAAC,aAAa,EAAE,YAAY,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;iBAC7D;qBAAM,IACL,cAAc,EAAE,QAAQ,CAAC,0BAA0B,CAAC;oBACpD,cAAc,EAAE,QAAQ,CAAC,6BAA6B,CAAC,EACvD;oBACA,QAAQ,CACN,aAAa,EACb,YAAY,EACZ,iBAAiB,CAAC,UAAU,CAAC,SAAS,EAAE,GAAG,sBAAsB,IAAI,CAAC,CACvE,CAAC;oBAEF,QAAQ,CAAC,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;iBAC3D;qBAAM;oBACL,qBAAqB,EAAE,CAAC;iBACzB;aACF;iBAAM;gBACL,qBAAqB,EAAE,CAAC;aACzB;YAED,QAAQ,CAAC,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YAC1D,QAAQ,CAAC,aAAa,EAAE,YAAY,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;YAE5D,QAAQ,CAAC,aAAa,EAAE,OAAO,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;YACnD,QAAQ,CAAC,aAAa,EAAE,QAAQ,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;YAErD,QAAQ,CAAC,WAAW,EAAE,UAAU,EAAE,cAAc,EAAE,UAAU,EAAE,cAAc,CAAC,CAAC;YAC9E,QAAQ,CAAC,aAAa,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC;YACtE,QAAQ,CAAC,cAAc,EAAE,UAAU,EAAE,YAAY,EAAE,UAAU,EAAE,YAAY,CAAC,CAAC;YAE7E,oGAAoG;YACpG,QAAQ,CAAC,QAAQ,CAAC,eAAe,EAAE,UAAU,EAAE,aAAa,EAAE,UAAU,EAAE,aAAa,CAAC,CAAC;YACzF,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC;YAEtE,IAAI,UAAU,EAAE;gBACd,QAAQ,CAAC,UAAU,EAAE,UAAU,EAAE,aAAa,EAAE,UAAU,EAAE,aAAa,CAAC,CAAC;aAC5E;YAED,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,CAAC,EAAE;gBACtD,UAAU,CAAC,cAAc,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;aAChD;YAED,IAAI,UAAU,CAAC,gBAAgB,EAAE;gBAC/B,MAAM,CAAC,UAAU,CAAC,sBAAsB,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;aACvE;iBAAM;gBACL,MAAM,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;aACpC;YAED,IAAI,UAAU,CAAC,aAAa,EAAE;gBAC5B,UAAU,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;aAC9E;iBAAM;gBACL,UAAU,CAAC,kBAAkB,CAAC,qBAAqB,EAAE,CAAC;aACvD;QACH,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;QAEf,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAW,CAAC,CAAC;QACpC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAW,CAAC,CAAC;QAEnC,UAAW,CAAC,YAAY,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YACxC,oGAAoG;YACpG,MAAM,eAAe,GAAG,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YAElG,KAAK,MAAM,KAAK,IAAI,eAAe,EAAE;gBACnC,IAAI,CAAC,KAAK;oBAAE,SAAS;gBAErB,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBACxB,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC;iBACrD;qBAAM;oBACL,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;iBAClD;aACF;YAED,MAAM,WAAW,GAAG,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YAE1F,KAAK,MAAM,KAAK,IAAI,WAAW,EAAE;gBAC/B,IAAI,CAAC,KAAK;oBAAE,SAAS;gBAErB,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBACxB,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC;iBAC1C;qBAAM;oBACL,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;iBACvC;aACF;QACH,CAAC,CAAC,CAAC;QAEH,UAAW,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YACvC,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YAEpD,IAAI,KAAK,KAAK,CAAC,CAAC;gBAAE,OAAO;YAEzB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAEnC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE;gBAC7B,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,EAAE,CAAC;aAClC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,UAAW,CAAC;QAEnB,2DAA2D;IAC7D,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACzC,CAAC;IAED,cAAc,CAAC,EAAU;QACvB,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;IAChE,CAAC;IAEO,cAAc,CAAC,QAAsB;QAC3C,IAAI,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;QAExB,OAAO,CAAC,EAAE,EAAE;YACV,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;SACrB;IACH,CAAC;IAEO,kBAAkB;QACxB,MAAM,MAAM,GAAG,IAAI,CAAC,qBAAqB,CAAC;QAC1C,OAAO,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,0BAA0B,CAAC;IAChF,CAAC;8GArSU,cAAc;kHAAd,cAAc;;2FAAd,cAAc;kBAD1B,UAAU","sourcesContent":["import { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { Dialog as CdkDialog, DialogConfig as CdkDialogConfig } from '@angular/cdk/dialog';\nimport { ComponentType } from '@angular/cdk/overlay';\nimport { ComponentRef, Injectable, OnDestroy, TemplateRef, inject } from '@angular/core';\nimport { ViewportService, createDestroy, equal } from '@ethlete/core';\nimport { Observable, Subject, combineLatest, defer, map, of, pairwise, startWith, takeUntil, tap } from 'rxjs';\nimport { OverlayContainerComponent } from '../components';\nimport { OVERLAY_CONFIG, OVERLAY_DATA, OVERLAY_DEFAULT_OPTIONS, OVERLAY_SCROLL_STRATEGY } from '../constants';\nimport { OverlayConfig } from '../types';\nimport {\n  ET_OVERLAY_BOTTOM_SHEET_CLASS,\n  ET_OVERLAY_LEFT_SHEET_CLASS,\n  ET_OVERLAY_RIGHT_SHEET_CLASS,\n  ET_OVERLAY_TOP_SHEET_CLASS,\n  OverlayPositionBuilder,\n  OverlayRef,\n  createOverlayConfig,\n} from '../utils';\n\nlet uniqueId = 0;\nconst ID_PREFIX = 'et-overlay-';\n\nconst setStyle = (el: HTMLElement, style: string, value: string | number | null | undefined) => {\n  if (value === null || value === undefined) {\n    el.style.removeProperty(style);\n  } else {\n    el.style.setProperty(style, coerceCssPixelValue(value));\n  }\n};\n\nconst setClass = (el: HTMLElement, prevClass?: string | string[], currClass?: string | string[]) => {\n  if (!equal(prevClass, currClass)) {\n    if (prevClass) {\n      if (Array.isArray(prevClass)) {\n        el.classList.remove(...prevClass);\n      } else {\n        el.classList.remove(prevClass);\n      }\n    }\n\n    if (currClass) {\n      if (Array.isArray(currClass)) {\n        el.classList.add(...currClass);\n      } else {\n        el.classList.add(currClass);\n      }\n    }\n  }\n};\n\nconst isHtmlElement = (element: HTMLElement | unknown): element is HTMLElement => {\n  return element instanceof HTMLElement;\n};\n\nconst isTouchEvent = (event: Event): event is TouchEvent => {\n  return event.type[0] === 't';\n};\n\nconst isPointerEvent = (event: Event): event is PointerEvent => {\n  return event.type[0] === 'c';\n};\n\n@Injectable()\nexport class OverlayService implements OnDestroy {\n  private readonly _destroy$ = createDestroy();\n  private readonly _defaultOptions = inject(OVERLAY_DEFAULT_OPTIONS, { optional: true });\n  private readonly _scrollStrategy = inject(OVERLAY_SCROLL_STRATEGY);\n  private readonly _parentOverlayService = inject(OverlayService, { optional: true, skipSelf: true });\n  private readonly _dialog = inject(CdkDialog);\n  private readonly _viewportService = inject(ViewportService);\n\n  private readonly _openOverlaysAtThisLevel: OverlayRef[] = [];\n  private readonly _afterAllClosedAtThisLevel = new Subject<void>();\n  private readonly _afterOpenedAtThisLevel = new Subject<OverlayRef>();\n\n  readonly positions = new OverlayPositionBuilder();\n\n  readonly afterAllClosed = defer(() =>\n    this.openOverlays.length ? this._getAfterAllClosed() : this._getAfterAllClosed().pipe(startWith(undefined)),\n  ) as Observable<void>;\n\n  get openOverlays(): OverlayRef[] {\n    return this._parentOverlayService ? this._parentOverlayService.openOverlays : this._openOverlaysAtThisLevel;\n  }\n\n  get afterOpened(): Subject<OverlayRef> {\n    return this._parentOverlayService ? this._parentOverlayService.afterOpened : this._afterOpenedAtThisLevel;\n  }\n\n  ngOnDestroy() {\n    this._closeOverlays(this._openOverlaysAtThisLevel);\n    this._afterAllClosedAtThisLevel.complete();\n    this._afterOpenedAtThisLevel.complete();\n  }\n\n  open<T, D = unknown, R = unknown>(component: ComponentType<T>, config: OverlayConfig<D>): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(template: TemplateRef<T>, config: OverlayConfig<D>): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(\n    template: ComponentType<T> | TemplateRef<T>,\n    config: OverlayConfig<D>,\n  ): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(\n    componentOrTemplateRef: ComponentType<T> | TemplateRef<T>,\n    config: OverlayConfig<D>,\n  ): OverlayRef<T, R> {\n    let overlayRef: OverlayRef<T, R>;\n\n    const composedConfig = createOverlayConfig<D>(this._defaultOptions as OverlayConfig<D>, config);\n    composedConfig.id = composedConfig.id || `${ID_PREFIX}${uniqueId++}`;\n    composedConfig.scrollStrategy = composedConfig.scrollStrategy || this._scrollStrategy();\n\n    const cdkRef = this._dialog.open<R, D, T>(componentOrTemplateRef, {\n      ...composedConfig,\n      disableClose: true,\n      closeOnDestroy: false,\n      panelClass: 'et-overlay-pane',\n      container: {\n        type: OverlayContainerComponent,\n        providers: () => [\n          { provide: OVERLAY_CONFIG, useValue: composedConfig },\n          { provide: CdkDialogConfig, useValue: composedConfig },\n        ],\n      },\n      templateContext: () => ({ dialogRef: overlayRef }),\n      providers: (ref, cdkConfig, overlayContainer) => {\n        overlayRef = new OverlayRef(ref, composedConfig, overlayContainer as OverlayContainerComponent);\n\n        return [\n          { provide: OverlayContainerComponent, useValue: overlayContainer },\n          { provide: OVERLAY_DATA, useValue: cdkConfig.data },\n          { provide: OverlayRef, useValue: overlayRef },\n          ...(composedConfig.providers ?? []),\n        ];\n      },\n    });\n\n    /* eslint-disable @typescript-eslint/no-non-null-assertion*/\n    (overlayRef! as { componentRef: ComponentRef<T> }).componentRef = cdkRef.componentRef!;\n    overlayRef!.componentInstance = cdkRef.componentInstance!;\n\n    (cdkRef.containerInstance as OverlayContainerComponent).overlayRef = overlayRef!;\n\n    const containerEl = overlayRef!._containerInstance.elementRef.nativeElement as HTMLElement;\n    const overlayPaneEl = cdkRef.overlayRef.overlayElement;\n    const backdropEl = cdkRef.overlayRef.backdropElement;\n    const overlayWrapper = cdkRef.overlayRef.hostElement;\n    const defaultAnimationBuffer = 50; // 50px since the default animation uses spring physics and thus will overshoot.\n    const useDefaultAnimation = composedConfig.customAnimated !== true;\n    const origin = composedConfig.origin;\n\n    if (origin) {\n      const originX = isHtmlElement(origin)\n        ? origin.getBoundingClientRect().left\n        : isTouchEvent(origin)\n        ? origin.changedTouches[0].clientX\n        : isPointerEvent(origin)\n        ? origin.clientX !== 0\n          ? origin.clientX\n          : (origin.target as HTMLElement).getBoundingClientRect().left\n        : -1;\n      const originY = isHtmlElement(origin)\n        ? origin.getBoundingClientRect().top\n        : isTouchEvent(origin)\n        ? origin.changedTouches[0].clientY\n        : isPointerEvent(origin)\n        ? origin.clientY !== 0\n          ? origin.clientY\n          : (origin.target as HTMLElement).getBoundingClientRect().top\n        : -1;\n\n      if (originX !== -1 && originY !== -1) {\n        setStyle(containerEl, 'transform-origin', `${originX}px ${originY}px`);\n      }\n    }\n\n    combineLatest(\n      composedConfig.positions.map((breakpoint) =>\n        (breakpoint.breakpoint ? this._viewportService.observe({ min: breakpoint.breakpoint }) : of(true)).pipe(\n          map((isActive) => ({\n            isActive,\n            config: breakpoint.config,\n            size:\n              typeof breakpoint.breakpoint === 'number'\n                ? breakpoint.breakpoint\n                : breakpoint.breakpoint === undefined\n                ? 0\n                : this._viewportService.getBreakpointSize(breakpoint.breakpoint, 'min'),\n          })),\n        ),\n      ),\n    )\n      .pipe(\n        takeUntil(overlayRef!.afterClosed()),\n        takeUntil(this._destroy$),\n        map((entries) => {\n          const activeBreakpoints = entries.filter((entry) => entry.isActive);\n          const highestBreakpoint = activeBreakpoints.reduce((prev, curr) => (prev.size > curr.size ? prev : curr));\n\n          return highestBreakpoint.config;\n        }),\n        startWith(null),\n        pairwise(),\n        tap(([prevConfig, currConfig]) => {\n          if (!currConfig) return;\n\n          const containerClass = currConfig.containerClass;\n\n          const applyDefaultMaxWidths = () => {\n            setStyle(overlayPaneEl, 'max-width', currConfig.maxWidth);\n            setStyle(overlayPaneEl, 'max-height', currConfig.maxHeight);\n          };\n\n          const combineOrMakeCalc = (value: string | number | null | undefined, append: string) => {\n            if (!value) return append;\n\n            if (typeof value === 'number') {\n              return `calc(${value}px + ${append})`;\n            } else if (value.startsWith('calc(')) {\n              return `${value.slice(0, value.length - 1)} + ${append})`;\n            }\n\n            return `calc(${value} + ${append})`;\n          };\n\n          if (useDefaultAnimation && containerClass?.length) {\n            if (\n              containerClass?.includes(ET_OVERLAY_LEFT_SHEET_CLASS) ||\n              containerClass?.includes(ET_OVERLAY_RIGHT_SHEET_CLASS)\n            ) {\n              setStyle(\n                overlayPaneEl,\n                'max-width',\n                combineOrMakeCalc(currConfig.maxWidth, `${defaultAnimationBuffer}px`),\n              );\n              setStyle(overlayPaneEl, 'max-height', currConfig.maxHeight);\n            } else if (\n              containerClass?.includes(ET_OVERLAY_TOP_SHEET_CLASS) ||\n              containerClass?.includes(ET_OVERLAY_BOTTOM_SHEET_CLASS)\n            ) {\n              setStyle(\n                overlayPaneEl,\n                'max-height',\n                combineOrMakeCalc(currConfig.maxHeight, `${defaultAnimationBuffer}px`),\n              );\n\n              setStyle(overlayPaneEl, 'max-width', currConfig.maxWidth);\n            } else {\n              applyDefaultMaxWidths();\n            }\n          } else {\n            applyDefaultMaxWidths();\n          }\n\n          setStyle(overlayPaneEl, 'min-width', currConfig.minWidth);\n          setStyle(overlayPaneEl, 'min-height', currConfig.minHeight);\n\n          setStyle(overlayPaneEl, 'width', currConfig.width);\n          setStyle(overlayPaneEl, 'height', currConfig.height);\n\n          setClass(containerEl, prevConfig?.containerClass, currConfig?.containerClass);\n          setClass(overlayPaneEl, prevConfig?.paneClass, currConfig?.paneClass);\n          setClass(overlayWrapper, prevConfig?.overlayClass, currConfig?.overlayClass);\n\n          // FIXME: These classes should only be removed if no open overlays require them inside their config.\n          setClass(document.documentElement, prevConfig?.documentClass, currConfig?.documentClass);\n          setClass(document.body, prevConfig?.bodyClass, currConfig?.bodyClass);\n\n          if (backdropEl) {\n            setClass(backdropEl, prevConfig?.backdropClass, currConfig?.backdropClass);\n          }\n\n          if (!equal(prevConfig?.position, currConfig?.position)) {\n            overlayRef.updatePosition(currConfig.position);\n          }\n\n          if (currConfig.positionStrategy) {\n            cdkRef.overlayRef.updatePositionStrategy(currConfig.positionStrategy);\n          } else {\n            cdkRef.overlayRef.updatePosition();\n          }\n\n          if (currConfig.dragToDismiss) {\n            overlayRef._containerInstance._enableDragToDismiss(currConfig.dragToDismiss);\n          } else {\n            overlayRef._containerInstance._disableDragToDismiss();\n          }\n        }),\n      )\n      .subscribe();\n\n    this.openOverlays.push(overlayRef!);\n    this.afterOpened.next(overlayRef!);\n\n    overlayRef!.beforeClosed().subscribe(() => {\n      // FIXME: These classes should only be removed if no open overlays require them inside their config.\n      const documentClasses = composedConfig.positions.map((position) => position.config.documentClass);\n\n      for (const klass of documentClasses) {\n        if (!klass) continue;\n\n        if (Array.isArray(klass)) {\n          document.documentElement.classList.remove(...klass);\n        } else {\n          document.documentElement.classList.remove(klass);\n        }\n      }\n\n      const bodyClasses = composedConfig.positions.map((position) => position.config.bodyClass);\n\n      for (const klass of bodyClasses) {\n        if (!klass) continue;\n\n        if (Array.isArray(klass)) {\n          document.body.classList.remove(...klass);\n        } else {\n          document.body.classList.remove(klass);\n        }\n      }\n    });\n\n    overlayRef!.afterClosed().subscribe(() => {\n      const index = this.openOverlays.indexOf(overlayRef);\n\n      if (index === -1) return;\n\n      this.openOverlays.splice(index, 1);\n\n      if (!this.openOverlays.length) {\n        this._getAfterAllClosed().next();\n      }\n    });\n\n    return overlayRef!;\n\n    /* eslint-enable @typescript-eslint/no-non-null-assertion*/\n  }\n\n  closeAll(): void {\n    this._closeOverlays(this.openOverlays);\n  }\n\n  getOverlayById(id: string): OverlayRef | undefined {\n    return this.openOverlays.find((overlay) => overlay.id === id);\n  }\n\n  private _closeOverlays(overlays: OverlayRef[]) {\n    let i = overlays.length;\n\n    while (i--) {\n      overlays[i].close();\n    }\n  }\n\n  private _getAfterAllClosed(): Subject<void> {\n    const parent = this._parentOverlayService;\n    return parent ? parent._getAfterAllClosed() : this._afterAllClosedAtThisLevel;\n  }\n}\n"]}
@@ -3,4 +3,4 @@ export const OVERLAY_STATE = {
3
3
  CLOSING: 'closing',
4
4
  CLOSED: 'closed',
5
5
  };
6
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.types.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/types/overlay.types.ts"],"names":[],"mappings":"AA0BA,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,IAAI,EAAE,MAAM;IACZ,OAAO,EAAE,SAAS;IAClB,MAAM,EAAE,QAAQ;CACR,CAAC","sourcesContent":["import { Direction } from '@angular/cdk/bidi';\nimport { PositionStrategy, ScrollStrategy } from '@angular/cdk/overlay';\nimport { Injector, ViewContainerRef } from '@angular/core';\nimport { Breakpoint } from '@ethlete/core';\n\n/** Options for where to set focus to automatically on overlay open */\nexport type OverlayAutoFocusTarget = 'dialog' | 'first-tabbable' | 'first-heading';\n\n/** Valid ARIA roles for a overlay element. */\nexport type OverlayRole = 'dialog' | 'alertdialog';\n\n/** Possible overrides for a overlay's position. */\nexport interface OverlayPosition {\n  /** Override for the overlay's top position. */\n  top?: string;\n\n  /** Override for the overlay's bottom position. */\n  bottom?: string;\n\n  /** Override for the overlay's left position. */\n  left?: string;\n\n  /** Override for the overlay's right position. */\n  right?: string;\n}\n\nexport const OVERLAY_STATE = {\n  OPEN: 'open',\n  CLOSING: 'closing',\n  CLOSED: 'closed',\n} as const;\n\nexport type OverlayState = (typeof OVERLAY_STATE)[keyof typeof OVERLAY_STATE];\n\nexport interface OverlayDragToDismissConfig {\n  /** Direction in which the overlay can be dragged. */\n  direction: 'to-top' | 'to-bottom' | 'to-left' | 'to-right';\n\n  /**\n   * The minimum distance in pixels that the user must swipe to dismiss the overlay.\n   *\n   * @default 150 // 150px\n   */\n  minDistanceToDismiss?: number;\n\n  /**\n   * The minimum velocity in pixels per second that the user must swipe to dismiss the overlay.\n   *\n   * @default 150 // 150px/s\n   */\n  minVelocityToDismiss?: number;\n}\n\nexport interface OverlayBreakpointConfig {\n  /** Min-width of the overlay. If a number is provided, assumes pixel units. */\n  minWidth?: number | string;\n\n  /** Max-width of the overlay. If a number is provided, assumes pixel units. */\n  maxWidth?: number | string;\n\n  /** Min-height of the overlay. If a number is provided, assumes pixel units. */\n  minHeight?: number | string;\n\n  /** Max-height of the overlay. If a number is provided, assumes pixel units. */\n  maxHeight?: number | string;\n\n  /** Width of the overlay. */\n  width?: number | string;\n\n  /** Height of the overlay. */\n  height?: number | string;\n\n  /** Position strategy to be used for the overlay. */\n  positionStrategy?: PositionStrategy;\n\n  /** Custom class for the overlay container. */\n  containerClass?: string | string[];\n\n  /** Custom class for the overlay pane. */\n  paneClass?: string | string[];\n\n  /** Extra CSS classes to be added to the overlay overlay container. */\n  overlayClass?: string | string[];\n\n  /** Custom class for the backdrop. */\n  backdropClass?: string | string[];\n\n  /** Position overrides. */\n  position?: OverlayPosition;\n\n  /** Determine if and in what direction the overlay should be able to be dragged to dismiss it. */\n  dragToDismiss?: OverlayDragToDismissConfig;\n}\n\nexport interface OverlayBreakpointConfigEntry {\n  /**\n   * Breakpoint to apply the config for. If a number is provided, it will be used as a pixel value.\n   * Always uses the min-width media query.\n   *\n   * @default 'xs' // 0px\n   */\n  breakpoint?: Breakpoint | number;\n\n  /**\n   * Overlay configuration to be applied when the breakpoint is active.\n   */\n  config: OverlayBreakpointConfig;\n}\n\nexport interface OverlayConfig<D = unknown> {\n  /**\n   * Conditionally applied overlay configurations based on breakpoints.\n   */\n  positions: OverlayBreakpointConfigEntry[];\n\n  /**\n   * Where the attached component should live in Angular's *logical* component tree.\n   * This affects what is available for injection and the change detection order for the\n   * component instantiated inside of the overlay. This does not affect where the overlay\n   * content will be rendered.\n   */\n  viewContainerRef?: ViewContainerRef;\n\n  /**\n   * Injector used for the instantiation of the component to be attached. If provided,\n   * takes precedence over the injector indirectly provided by `ViewContainerRef`.\n   */\n  injector?: Injector;\n\n  /** ID for the overlay. If omitted, a unique one will be generated. */\n  id?: string;\n\n  /**\n   * The ARIA role of the overlay element.\n   * @default 'dialog'\n   */\n  role?: OverlayRole;\n\n  /**\n   * Whether the overlay has a backdrop.\n   * @default true\n   */\n  hasBackdrop?: boolean;\n\n  /**\n   * Whether the user can use escape or clicking on the backdrop to close the modal.\n   * @default false\n   */\n  disableClose?: boolean;\n\n  /**\n   * Data being injected into the child component.\n   * @default null\n   */\n  data?: D | null;\n\n  /** Layout direction for the overlay's content. */\n  direction?: Direction;\n\n  /**\n   * ID of the element that describes the overlay.\n   * @default null\n   */\n  ariaDescribedBy?: string | null;\n\n  /**\n   * ID of the element that labels the overlay.\n   * @default null\n   */\n  ariaLabelledBy?: string | null;\n\n  /**\n   * Aria label to assign to the overlay element.\n   * @default null\n   */\n  ariaLabel?: string | null;\n\n  /**\n   * Whether this is a modal overlay. Used to set the `aria-modal` attribute.\n   * @default true\n   */\n  ariaModal?: boolean;\n\n  /**\n   * Whether the overlay uses a custom animation.\n   * @default false\n   */\n  customAnimated?: boolean;\n\n  /**\n   * Where the overlay should focus on open.\n   * Can be one of AutoFocusTarget, or a css selector string.\n   * @default 'first-tabbable'\n   */\n  autoFocus?: OverlayAutoFocusTarget | string;\n\n  /**\n   * Whether the overlay should restore focus to the\n   * previously-focused element, after it's closed.\n   * @default true\n   */\n  restoreFocus?: boolean;\n\n  /**\n   * Whether to wait for the opening animation to finish before trapping focus.\n   * @default true\n   */\n  delayFocusTrap?: boolean;\n\n  /** Scroll strategy to be used for the overlay. */\n  scrollStrategy?: ScrollStrategy;\n\n  /**\n   * Whether the overlay should close when the user goes backwards/forwards in history.\n   * Note that this usually doesn't include clicking on links (unless the user is using\n   * the `HashLocationStrategy`).\n   * @default true\n   */\n  closeOnNavigation?: boolean;\n}\n"]}
6
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.types.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/types/overlay.types.ts"],"names":[],"mappings":"AA0BA,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,IAAI,EAAE,MAAM;IACZ,OAAO,EAAE,SAAS;IAClB,MAAM,EAAE,QAAQ;CACR,CAAC","sourcesContent":["import { Direction } from '@angular/cdk/bidi';\nimport { PositionStrategy, ScrollStrategy } from '@angular/cdk/overlay';\nimport { Injector, StaticProvider, ViewContainerRef } from '@angular/core';\nimport { Breakpoint } from '@ethlete/core';\n\n/** Options for where to set focus to automatically on overlay open */\nexport type OverlayAutoFocusTarget = 'dialog' | 'first-tabbable' | 'first-heading';\n\n/** Valid ARIA roles for a overlay element. */\nexport type OverlayRole = 'dialog' | 'alertdialog';\n\n/** Possible overrides for a overlay's position. */\nexport interface OverlayPosition {\n  /** Override for the overlay's top position. */\n  top?: string;\n\n  /** Override for the overlay's bottom position. */\n  bottom?: string;\n\n  /** Override for the overlay's left position. */\n  left?: string;\n\n  /** Override for the overlay's right position. */\n  right?: string;\n}\n\nexport const OVERLAY_STATE = {\n  OPEN: 'open',\n  CLOSING: 'closing',\n  CLOSED: 'closed',\n} as const;\n\nexport type OverlayState = (typeof OVERLAY_STATE)[keyof typeof OVERLAY_STATE];\n\nexport interface OverlayDragToDismissConfig {\n  /** Direction in which the overlay can be dragged. */\n  direction: 'to-top' | 'to-bottom' | 'to-left' | 'to-right';\n\n  /**\n   * The minimum distance in pixels that the user must swipe to dismiss the overlay.\n   *\n   * @default 150 // 150px\n   */\n  minDistanceToDismiss?: number;\n\n  /**\n   * The minimum velocity in pixels per second that the user must swipe to dismiss the overlay.\n   *\n   * @default 150 // 150px/s\n   */\n  minVelocityToDismiss?: number;\n}\n\nexport interface OverlayBreakpointConfig {\n  /** Min-width of the overlay. If a number is provided, assumes pixel units. */\n  minWidth?: number | string;\n\n  /** Max-width of the overlay. If a number is provided, assumes pixel units. */\n  maxWidth?: number | string;\n\n  /** Min-height of the overlay. If a number is provided, assumes pixel units. */\n  minHeight?: number | string;\n\n  /** Max-height of the overlay. If a number is provided, assumes pixel units. */\n  maxHeight?: number | string;\n\n  /** Width of the overlay. */\n  width?: number | string;\n\n  /** Height of the overlay. */\n  height?: number | string;\n\n  /** Position strategy to be used for the overlay. */\n  positionStrategy?: PositionStrategy;\n\n  /** Custom class for the overlay container. */\n  containerClass?: string | string[];\n\n  /** Custom class for the overlay pane. */\n  paneClass?: string | string[];\n\n  /** Extra CSS classes to be added to the overlay overlay container. */\n  overlayClass?: string | string[];\n\n  /** Custom class for the backdrop. */\n  backdropClass?: string | string[];\n\n  /** Custom class for the document (`<html>` element). */\n  documentClass?: string | string[];\n\n  /** Custom class for the `<body>` element */\n  bodyClass?: string | string[];\n\n  /** Position overrides. */\n  position?: OverlayPosition;\n\n  /** Determine if and in what direction the overlay should be able to be dragged to dismiss it. */\n  dragToDismiss?: OverlayDragToDismissConfig;\n}\n\nexport interface OverlayBreakpointConfigEntry {\n  /**\n   * Breakpoint to apply the config for. If a number is provided, it will be used as a pixel value.\n   * Always uses the min-width media query.\n   *\n   * @default 'xs' // 0px\n   */\n  breakpoint?: Breakpoint | number;\n\n  /**\n   * Overlay configuration to be applied when the breakpoint is active.\n   */\n  config: OverlayBreakpointConfig;\n}\n\nexport interface OverlayConfig<D = unknown> {\n  /**\n   * Conditionally applied overlay configurations based on breakpoints.\n   */\n  positions: OverlayBreakpointConfigEntry[];\n\n  /**\n   * Where the attached component should live in Angular's *logical* component tree.\n   * This affects what is available for injection and the change detection order for the\n   * component instantiated inside of the overlay. This does not affect where the overlay\n   * content will be rendered.\n   */\n  viewContainerRef?: ViewContainerRef;\n\n  /**\n   * Injector used for the instantiation of the component to be attached. If provided,\n   * takes precedence over the injector indirectly provided by `ViewContainerRef`.\n   */\n  injector?: Injector;\n\n  /** ID for the overlay. If omitted, a unique one will be generated. */\n  id?: string;\n\n  /**\n   * The ARIA role of the overlay element.\n   * @default 'dialog'\n   */\n  role?: OverlayRole;\n\n  /**\n   * Whether the overlay has a backdrop.\n   * @default true\n   */\n  hasBackdrop?: boolean;\n\n  /**\n   * Whether the user can use escape or clicking on the backdrop to close the modal.\n   * @default false\n   */\n  disableClose?: boolean;\n\n  /**\n   * Data being injected into the child component.\n   * @default null\n   */\n  data?: D | null;\n\n  /** Layout direction for the overlay's content. */\n  direction?: Direction;\n\n  /**\n   * ID of the element that describes the overlay.\n   * @default null\n   */\n  ariaDescribedBy?: string | null;\n\n  /**\n   * ID of the element that labels the overlay.\n   * @default null\n   */\n  ariaLabelledBy?: string | null;\n\n  /**\n   * Aria label to assign to the overlay element.\n   * @default null\n   */\n  ariaLabel?: string | null;\n\n  /**\n   * Whether this is a modal overlay. Used to set the `aria-modal` attribute.\n   * @default true\n   */\n  ariaModal?: boolean;\n\n  /**\n   * Whether the overlay uses a custom animation.\n   * @default false\n   */\n  customAnimated?: boolean;\n\n  /**\n   * Where the overlay should focus on open.\n   * Can be one of AutoFocusTarget, or a css selector string.\n   * @default 'first-tabbable'\n   */\n  autoFocus?: OverlayAutoFocusTarget | string;\n\n  /**\n   * Whether the overlay should restore focus to the\n   * previously-focused element, after it's closed.\n   * @default true\n   */\n  restoreFocus?: boolean;\n\n  /**\n   * Whether to wait for the opening animation to finish before trapping focus.\n   * @default true\n   */\n  delayFocusTrap?: boolean;\n\n  /** Scroll strategy to be used for the overlay. */\n  scrollStrategy?: ScrollStrategy;\n\n  /**\n   * Whether the overlay should close when the user goes backwards/forwards in history.\n   * Note that this usually doesn't include clicking on links (unless the user is using\n   * the `HashLocationStrategy`).\n   * @default true\n   */\n  closeOnNavigation?: boolean;\n\n  /**\n   * Extra providers to be made available to the overlay.\n   */\n  providers?: StaticProvider[];\n\n  /**\n   * The origin element that triggered the overlay's opening.\n   */\n  origin?: HTMLElement | MouseEvent | TouchEvent | KeyboardEvent | PointerEvent;\n}\n"]}
@@ -1,5 +1,11 @@
1
1
  import { Overlay } from '@angular/cdk/overlay';
2
2
  import { inject } from '@angular/core';
3
+ export const ET_OVERLAY_LEFT_SHEET_CLASS = 'et-overlay--left-sheet';
4
+ export const ET_OVERLAY_RIGHT_SHEET_CLASS = 'et-overlay--right-sheet';
5
+ export const ET_OVERLAY_TOP_SHEET_CLASS = 'et-overlay--top-sheet';
6
+ export const ET_OVERLAY_BOTTOM_SHEET_CLASS = 'et-overlay--bottom-sheet';
7
+ export const ET_OVERLAY_DIALOG_CLASS = 'et-overlay--dialog';
8
+ export const ET_OVERLAY_FULL_SCREEN_DIALOG_CLASS = 'et-overlay--full-screen-dialog';
3
9
  export class OverlayPositionBuilder {
4
10
  constructor() {
5
11
  this._overlay = inject(Overlay);
@@ -11,7 +17,7 @@ export class OverlayPositionBuilder {
11
17
  maxWidth: '80vw',
12
18
  minHeight: undefined,
13
19
  minWidth: undefined,
14
- containerClass: 'et-overlay--dialog',
20
+ containerClass: ET_OVERLAY_DIALOG_CLASS,
15
21
  positionStrategy: this._overlay.position().global().centerHorizontally().centerVertically(),
16
22
  },
17
23
  fullScreenDialog: {
@@ -21,8 +27,9 @@ export class OverlayPositionBuilder {
21
27
  maxWidth: undefined,
22
28
  minHeight: undefined,
23
29
  minWidth: undefined,
24
- containerClass: 'et-overlay--full-screen-dialog',
30
+ containerClass: ET_OVERLAY_FULL_SCREEN_DIALOG_CLASS,
25
31
  positionStrategy: this._overlay.position().global().left('0').top('0').bottom('0').right('0'),
32
+ documentClass: 'et-overlay--full-screen-dialog-document',
26
33
  },
27
34
  bottomSheet: {
28
35
  width: '100%',
@@ -31,7 +38,7 @@ export class OverlayPositionBuilder {
31
38
  maxWidth: '640px',
32
39
  minHeight: undefined,
33
40
  minWidth: undefined,
34
- containerClass: 'et-overlay--bottom-sheet',
41
+ containerClass: ET_OVERLAY_BOTTOM_SHEET_CLASS,
35
42
  positionStrategy: this._overlay.position().global().centerHorizontally().bottom('0'),
36
43
  dragToDismiss: {
37
44
  direction: 'to-bottom',
@@ -44,7 +51,7 @@ export class OverlayPositionBuilder {
44
51
  maxWidth: '640px',
45
52
  minHeight: undefined,
46
53
  minWidth: undefined,
47
- containerClass: 'et-overlay--top-sheet',
54
+ containerClass: ET_OVERLAY_TOP_SHEET_CLASS,
48
55
  positionStrategy: this._overlay.position().global().centerHorizontally().top('0'),
49
56
  dragToDismiss: {
50
57
  direction: 'to-top',
@@ -57,7 +64,7 @@ export class OverlayPositionBuilder {
57
64
  maxWidth: '640px',
58
65
  minHeight: undefined,
59
66
  minWidth: undefined,
60
- containerClass: 'et-overlay--left-sheet',
67
+ containerClass: ET_OVERLAY_LEFT_SHEET_CLASS,
61
68
  positionStrategy: this._overlay.position().global().left('0').centerVertically(),
62
69
  dragToDismiss: {
63
70
  direction: 'to-left',
@@ -70,7 +77,7 @@ export class OverlayPositionBuilder {
70
77
  maxWidth: '640px',
71
78
  minHeight: undefined,
72
79
  minWidth: undefined,
73
- containerClass: 'et-overlay--right-sheet',
80
+ containerClass: ET_OVERLAY_RIGHT_SHEET_CLASS,
74
81
  positionStrategy: this._overlay.position().global().right('0').centerVertically(),
75
82
  dragToDismiss: {
76
83
  direction: 'to-right',
@@ -90,6 +97,18 @@ export class OverlayPositionBuilder {
90
97
  ];
91
98
  return data;
92
99
  }
100
+ transformingFullScreenDialogToRightSheet(customConfig) {
101
+ const data = [
102
+ {
103
+ config: this.mergeConfigs(this.DEFAULTS.fullScreenDialog, customConfig?.fullScreenDialog ?? {}),
104
+ },
105
+ {
106
+ breakpoint: 'md',
107
+ config: this.mergeConfigs(this.DEFAULTS.rightSheet, customConfig?.rightSheet ?? {}),
108
+ },
109
+ ];
110
+ return data;
111
+ }
93
112
  dialog(customConfig) {
94
113
  const data = [
95
114
  {
@@ -148,4 +167,4 @@ export class OverlayPositionBuilder {
148
167
  return config;
149
168
  }
150
169
  }
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay-position-builder.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/utils/overlay-position-builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport { inject } from '@angular/core';\nimport { OverlayBreakpointConfig, OverlayBreakpointConfigEntry } from '../types';\n\nexport class OverlayPositionBuilder {\n  private readonly _overlay = inject(Overlay);\n\n  readonly DEFAULTS = {\n    dialog: {\n      width: undefined,\n      height: undefined,\n      maxHeight: '80vh',\n      maxWidth: '80vw',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--dialog',\n      positionStrategy: this._overlay.position().global().centerHorizontally().centerVertically(),\n    },\n    fullScreenDialog: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: undefined,\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--full-screen-dialog',\n      positionStrategy: this._overlay.position().global().left('0').top('0').bottom('0').right('0'),\n    },\n    bottomSheet: {\n      width: '100%',\n      height: undefined,\n      maxHeight: 'calc(100% - 72px)',\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--bottom-sheet',\n      positionStrategy: this._overlay.position().global().centerHorizontally().bottom('0'),\n      dragToDismiss: {\n        direction: 'to-bottom',\n      },\n    },\n    topSheet: {\n      width: '100%',\n      height: undefined,\n      maxHeight: 'calc(100% - 72px)',\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--top-sheet',\n      positionStrategy: this._overlay.position().global().centerHorizontally().top('0'),\n      dragToDismiss: {\n        direction: 'to-top',\n      },\n    },\n    leftSheet: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--left-sheet',\n      positionStrategy: this._overlay.position().global().left('0').centerVertically(),\n      dragToDismiss: {\n        direction: 'to-left',\n      },\n    },\n    rightSheet: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--right-sheet',\n      positionStrategy: this._overlay.position().global().right('0').centerVertically(),\n      dragToDismiss: {\n        direction: 'to-right',\n      },\n    },\n  } satisfies Record<string, OverlayBreakpointConfig>;\n\n  transformingBottomSheetToDialog(customConfig?: {\n    bottomSheet?: OverlayBreakpointConfig;\n    dialog?: OverlayBreakpointConfig;\n  }) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.bottomSheet, customConfig?.bottomSheet ?? {}),\n      },\n      {\n        breakpoint: 'md',\n        config: this.mergeConfigs(this.DEFAULTS.dialog, customConfig?.dialog ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  dialog(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.dialog, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  fullScreenDialog(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.fullScreenDialog, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  bottomSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.bottomSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  topSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.topSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  leftSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.leftSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  rightSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.rightSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  mergeConfigs(...configs: OverlayBreakpointConfig[]) {\n    const config = configs.reduce((acc, curr) => {\n      return {\n        ...acc,\n        ...curr,\n      };\n    }, {} as OverlayBreakpointConfig);\n\n    return config;\n  }\n}\n"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay-position-builder.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/utils/overlay-position-builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport { inject } from '@angular/core';\nimport { OverlayBreakpointConfig, OverlayBreakpointConfigEntry } from '../types';\n\nexport const ET_OVERLAY_LEFT_SHEET_CLASS = 'et-overlay--left-sheet';\nexport const ET_OVERLAY_RIGHT_SHEET_CLASS = 'et-overlay--right-sheet';\nexport const ET_OVERLAY_TOP_SHEET_CLASS = 'et-overlay--top-sheet';\nexport const ET_OVERLAY_BOTTOM_SHEET_CLASS = 'et-overlay--bottom-sheet';\nexport const ET_OVERLAY_DIALOG_CLASS = 'et-overlay--dialog';\nexport const ET_OVERLAY_FULL_SCREEN_DIALOG_CLASS = 'et-overlay--full-screen-dialog';\n\nexport class OverlayPositionBuilder {\n  private readonly _overlay = inject(Overlay);\n\n  readonly DEFAULTS = {\n    dialog: {\n      width: undefined,\n      height: undefined,\n      maxHeight: '80vh',\n      maxWidth: '80vw',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_DIALOG_CLASS,\n      positionStrategy: this._overlay.position().global().centerHorizontally().centerVertically(),\n    },\n    fullScreenDialog: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: undefined,\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_FULL_SCREEN_DIALOG_CLASS,\n      positionStrategy: this._overlay.position().global().left('0').top('0').bottom('0').right('0'),\n      documentClass: 'et-overlay--full-screen-dialog-document',\n    },\n    bottomSheet: {\n      width: '100%',\n      height: undefined,\n      maxHeight: 'calc(100% - 72px)',\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_BOTTOM_SHEET_CLASS,\n      positionStrategy: this._overlay.position().global().centerHorizontally().bottom('0'),\n      dragToDismiss: {\n        direction: 'to-bottom',\n      },\n    },\n    topSheet: {\n      width: '100%',\n      height: undefined,\n      maxHeight: 'calc(100% - 72px)',\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_TOP_SHEET_CLASS,\n      positionStrategy: this._overlay.position().global().centerHorizontally().top('0'),\n      dragToDismiss: {\n        direction: 'to-top',\n      },\n    },\n    leftSheet: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_LEFT_SHEET_CLASS,\n      positionStrategy: this._overlay.position().global().left('0').centerVertically(),\n      dragToDismiss: {\n        direction: 'to-left',\n      },\n    },\n    rightSheet: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_RIGHT_SHEET_CLASS,\n      positionStrategy: this._overlay.position().global().right('0').centerVertically(),\n      dragToDismiss: {\n        direction: 'to-right',\n      },\n    },\n  } satisfies Record<string, OverlayBreakpointConfig>;\n\n  transformingBottomSheetToDialog(customConfig?: {\n    bottomSheet?: OverlayBreakpointConfig;\n    dialog?: OverlayBreakpointConfig;\n  }) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.bottomSheet, customConfig?.bottomSheet ?? {}),\n      },\n      {\n        breakpoint: 'md',\n        config: this.mergeConfigs(this.DEFAULTS.dialog, customConfig?.dialog ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  transformingFullScreenDialogToRightSheet(customConfig?: {\n    fullScreenDialog?: OverlayBreakpointConfig;\n    rightSheet?: OverlayBreakpointConfig;\n  }) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.fullScreenDialog, customConfig?.fullScreenDialog ?? {}),\n      },\n      {\n        breakpoint: 'md',\n        config: this.mergeConfigs(this.DEFAULTS.rightSheet, customConfig?.rightSheet ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  dialog(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.dialog, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  fullScreenDialog(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.fullScreenDialog, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  bottomSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.bottomSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  topSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.topSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  leftSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.leftSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  rightSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.rightSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  mergeConfigs(...configs: OverlayBreakpointConfig[]) {\n    const config = configs.reduce((acc, curr) => {\n      return {\n        ...acc,\n        ...curr,\n      };\n    }, {} as OverlayBreakpointConfig);\n\n    return config;\n  }\n}\n"]}