@db-ux/wc-core-components 2.1.2 → 2.2.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 (280) hide show
  1. package/dist/cjs/app-globals-V2Kpy_OQ.js.map +1 -1
  2. package/dist/cjs/db-accordion-item.cjs.entry.js +2 -2
  3. package/dist/cjs/db-accordion.cjs.entry.js +2 -2
  4. package/dist/cjs/db-badge.cjs.entry.js +2 -2
  5. package/dist/cjs/db-brand.cjs.entry.js +2 -2
  6. package/dist/cjs/db-button.cjs.entry.js +2 -2
  7. package/dist/cjs/db-card.cjs.entry.js +2 -2
  8. package/dist/cjs/db-checkbox.cjs.entry.js +2 -2
  9. package/dist/cjs/db-custom-select-dropdown.db-custom-select-list.db-custom-select-list-item.db-input.db-tag.entry.cjs.js.map +1 -1
  10. package/dist/cjs/db-custom-select-dropdown_5.cjs.entry.js +4 -4
  11. package/dist/cjs/db-custom-select-dropdown_5.cjs.entry.js.map +1 -1
  12. package/dist/cjs/db-custom-select-form-field.cjs.entry.js +2 -2
  13. package/dist/cjs/db-custom-select.cjs.entry.js +37 -13
  14. package/dist/cjs/db-custom-select.cjs.entry.js.map +1 -1
  15. package/dist/cjs/db-custom-select.entry.cjs.js.map +1 -1
  16. package/dist/cjs/db-divider.cjs.entry.js +2 -2
  17. package/dist/cjs/db-drawer.cjs.entry.js +2 -2
  18. package/dist/cjs/db-header.cjs.entry.js +4 -3
  19. package/dist/cjs/db-header.cjs.entry.js.map +1 -1
  20. package/dist/cjs/db-header.entry.cjs.js.map +1 -1
  21. package/dist/cjs/db-icon.cjs.entry.js +2 -2
  22. package/dist/cjs/db-infotext.cjs.entry.js +2 -2
  23. package/dist/cjs/db-link.cjs.entry.js +2 -2
  24. package/dist/cjs/db-navigation-item.cjs.entry.js +4 -3
  25. package/dist/cjs/db-navigation-item.cjs.entry.js.map +1 -1
  26. package/dist/cjs/db-navigation-item.entry.cjs.js.map +1 -1
  27. package/dist/cjs/db-navigation.cjs.entry.js +2 -2
  28. package/dist/cjs/db-notification.cjs.entry.js +2 -2
  29. package/dist/cjs/db-page.cjs.entry.js +2 -2
  30. package/dist/cjs/db-popover.cjs.entry.js +65 -11
  31. package/dist/cjs/db-popover.cjs.entry.js.map +1 -1
  32. package/dist/cjs/db-popover.entry.cjs.js.map +1 -1
  33. package/dist/cjs/db-radio.cjs.entry.js +2 -2
  34. package/dist/cjs/db-section.cjs.entry.js +2 -2
  35. package/dist/cjs/db-select.cjs.entry.js +7 -7
  36. package/dist/cjs/db-select.cjs.entry.js.map +1 -1
  37. package/dist/cjs/db-select.entry.cjs.js.map +1 -1
  38. package/dist/cjs/db-stack.cjs.entry.js +2 -2
  39. package/dist/cjs/db-switch.cjs.entry.js +2 -2
  40. package/dist/cjs/db-tab-item_3.cjs.entry.js +2 -2
  41. package/dist/cjs/db-tabs.cjs.entry.js +2 -2
  42. package/dist/cjs/db-textarea.cjs.entry.js +6 -6
  43. package/dist/cjs/db-textarea.cjs.entry.js.map +1 -1
  44. package/dist/cjs/db-textarea.entry.cjs.js.map +1 -1
  45. package/dist/cjs/db-tooltip.cjs.entry.js +66 -14
  46. package/dist/cjs/db-tooltip.cjs.entry.js.map +1 -1
  47. package/dist/cjs/db-tooltip.entry.cjs.js.map +1 -1
  48. package/dist/cjs/db-ux.cjs.js +3 -3
  49. package/dist/cjs/db-ux.cjs.js.map +1 -1
  50. package/dist/cjs/{document-click-listener-Dfd-wUYX.js → document-click-listener-DT5rWFez.js} +3 -3
  51. package/dist/cjs/{document-click-listener-Dfd-wUYX.js.map → document-click-listener-DT5rWFez.js.map} +1 -1
  52. package/dist/cjs/document-scroll-listener-Dr1OKmow.js +46 -0
  53. package/dist/cjs/document-scroll-listener-Dr1OKmow.js.map +1 -0
  54. package/dist/cjs/floating-components-BNCfdqZJ.js +299 -0
  55. package/dist/cjs/floating-components-BNCfdqZJ.js.map +1 -0
  56. package/dist/cjs/{index-7lbP4BU6.js → index-ArRmNC2k.js} +8 -76
  57. package/dist/cjs/index-ArRmNC2k.js.map +1 -0
  58. package/dist/cjs/{index-BzLx0HVU.js → index-DiwURPCd.js} +3 -3
  59. package/dist/cjs/index-DiwURPCd.js.map +1 -0
  60. package/dist/cjs/index.cjs.js +9 -8
  61. package/dist/cjs/index.cjs.js.map +1 -1
  62. package/dist/cjs/loader.cjs.js +2 -2
  63. package/dist/cjs/{navigation-BLjJ1vaO.js → navigation-U4SBgT7D.js} +4 -4
  64. package/dist/cjs/navigation-U4SBgT7D.js.map +1 -0
  65. package/dist/collection/collection-manifest.json +1 -1
  66. package/dist/collection/components/custom-select/custom-select.js +61 -35
  67. package/dist/collection/components/custom-select/custom-select.js.map +1 -1
  68. package/dist/collection/components/custom-select/model.js.map +1 -1
  69. package/dist/collection/components/input/input.js +27 -2
  70. package/dist/collection/components/input/input.js.map +1 -1
  71. package/dist/collection/components/popover/model.js.map +1 -1
  72. package/dist/collection/components/popover/popover.js +92 -36
  73. package/dist/collection/components/popover/popover.js.map +1 -1
  74. package/dist/collection/components/select/select.js +5 -5
  75. package/dist/collection/components/select/select.js.map +1 -1
  76. package/dist/collection/components/textarea/model.js.map +1 -1
  77. package/dist/collection/components/textarea/textarea.js +54 -4
  78. package/dist/collection/components/textarea/textarea.js.map +1 -1
  79. package/dist/collection/components/tooltip/model.js.map +1 -1
  80. package/dist/collection/components/tooltip/tooltip.js +93 -39
  81. package/dist/collection/components/tooltip/tooltip.js.map +1 -1
  82. package/dist/collection/shared/model.js +1 -0
  83. package/dist/collection/shared/model.js.map +1 -1
  84. package/dist/collection/utils/document-scroll-listener.js +39 -0
  85. package/dist/collection/utils/document-scroll-listener.js.map +1 -0
  86. package/dist/collection/utils/floating-components.js +291 -0
  87. package/dist/collection/utils/floating-components.js.map +1 -0
  88. package/dist/collection/utils/index.js +5 -70
  89. package/dist/collection/utils/index.js.map +1 -1
  90. package/dist/collection/utils/navigation.js +1 -1
  91. package/dist/collection/utils/navigation.js.map +1 -1
  92. package/dist/custom-elements.json +313 -97
  93. package/dist/db-ux/db-custom-select-dropdown.db-custom-select-list.db-custom-select-list-item.db-input.db-tag.entry.esm.js.map +1 -1
  94. package/dist/db-ux/db-custom-select.entry.esm.js.map +1 -1
  95. package/dist/db-ux/db-header.entry.esm.js.map +1 -1
  96. package/dist/db-ux/db-navigation-item.entry.esm.js.map +1 -1
  97. package/dist/db-ux/db-popover.entry.esm.js.map +1 -1
  98. package/dist/db-ux/db-select.entry.esm.js.map +1 -1
  99. package/dist/db-ux/db-textarea.entry.esm.js.map +1 -1
  100. package/dist/db-ux/db-tooltip.entry.esm.js.map +1 -1
  101. package/dist/db-ux/db-ux.esm.js +1 -1
  102. package/dist/db-ux/db-ux.esm.js.map +1 -1
  103. package/dist/db-ux/index.esm.js +1 -1
  104. package/dist/db-ux/index.esm.js.map +1 -1
  105. package/dist/db-ux/p-04fb737c.entry.js +2 -0
  106. package/dist/db-ux/p-04fb737c.entry.js.map +1 -0
  107. package/dist/db-ux/{p-b4bc8f26.entry.js → p-0bb2fc14.entry.js} +2 -2
  108. package/dist/db-ux/{p-16a0ae38.entry.js → p-0d8b6ecd.entry.js} +2 -2
  109. package/dist/db-ux/p-0f107c11.entry.js +2 -0
  110. package/dist/db-ux/{p-0740aa7d.entry.js → p-144ebba2.entry.js} +2 -2
  111. package/dist/db-ux/{p-14c44b94.entry.js → p-1face452.entry.js} +2 -2
  112. package/dist/db-ux/{p-8b7d868b.entry.js → p-36b32211.entry.js} +2 -2
  113. package/dist/db-ux/p-3fe511ce.entry.js +2 -0
  114. package/dist/db-ux/{p-5c2eddb6.entry.js.map → p-3fe511ce.entry.js.map} +1 -1
  115. package/dist/db-ux/p-474734cf.entry.js +2 -0
  116. package/dist/db-ux/p-474734cf.entry.js.map +1 -0
  117. package/dist/db-ux/p-4c47f2d7.entry.js +2 -0
  118. package/dist/db-ux/p-4c47f2d7.entry.js.map +1 -0
  119. package/dist/db-ux/{p-55b02c80.entry.js → p-53f83d20.entry.js} +2 -2
  120. package/dist/db-ux/{p-0e4c3fb1.entry.js → p-55f53705.entry.js} +2 -2
  121. package/dist/db-ux/p-5bbfcf9a.entry.js +2 -0
  122. package/dist/db-ux/p-5bbfcf9a.entry.js.map +1 -0
  123. package/dist/db-ux/{p-f83357e2.entry.js → p-5c63036a.entry.js} +2 -2
  124. package/dist/db-ux/p-695bf91e.entry.js +2 -0
  125. package/dist/db-ux/{p-8ad4f80a.entry.js.map → p-695bf91e.entry.js.map} +1 -1
  126. package/dist/db-ux/p-698c2d19.entry.js +2 -0
  127. package/dist/db-ux/p-698c2d19.entry.js.map +1 -0
  128. package/dist/db-ux/p-6f1226da.entry.js +2 -0
  129. package/dist/db-ux/{p-139f5623.entry.js → p-77ce5cb6.entry.js} +2 -2
  130. package/dist/db-ux/{p-c088c8c8.entry.js → p-833f8694.entry.js} +2 -2
  131. package/dist/db-ux/{p-7de004e3.entry.js → p-87a03fc0.entry.js} +2 -2
  132. package/dist/db-ux/{p-6wgV8aKO.js → p-BDA9dlfd.js} +2 -2
  133. package/dist/db-ux/p-BDA9dlfd.js.map +1 -0
  134. package/dist/db-ux/p-BbHrTk7a.js +2 -0
  135. package/dist/db-ux/{p-YMQoOWgh.js.map → p-BbHrTk7a.js.map} +1 -1
  136. package/dist/db-ux/p-BgQRUWMZ.js +2 -0
  137. package/dist/db-ux/p-BgQRUWMZ.js.map +1 -0
  138. package/dist/db-ux/{p-bH2PZLSq.js → p-Ctmm4hMW.js} +1 -1
  139. package/dist/db-ux/p-Ctmm4hMW.js.map +1 -0
  140. package/dist/db-ux/p-DQuL1Twl.js.map +1 -1
  141. package/dist/db-ux/p-DYeQU2bY.js +2 -0
  142. package/dist/db-ux/p-DYeQU2bY.js.map +1 -0
  143. package/dist/db-ux/p-Dgkqk5fN.js +2 -0
  144. package/dist/db-ux/p-Dgkqk5fN.js.map +1 -0
  145. package/dist/db-ux/{p-6b6dbd54.entry.js → p-a107ec7c.entry.js} +2 -2
  146. package/dist/db-ux/p-b0c5f546.entry.js +2 -0
  147. package/dist/db-ux/p-b0c5f546.entry.js.map +1 -0
  148. package/dist/db-ux/{p-9046dcdf.entry.js → p-c40a990b.entry.js} +2 -2
  149. package/dist/db-ux/{p-5c4d25b8.entry.js → p-c673c483.entry.js} +2 -2
  150. package/dist/db-ux/{p-01112955.entry.js → p-ca134c76.entry.js} +2 -2
  151. package/dist/db-ux/{p-c5909b40.entry.js → p-cff88428.entry.js} +2 -2
  152. package/dist/db-ux/{p-9c07a46d.entry.js → p-d5e0c0b5.entry.js} +2 -2
  153. package/dist/db-ux/{p-40713825.entry.js → p-ef6cda9f.entry.js} +2 -2
  154. package/dist/db-ux/{p-e8cabe82.entry.js → p-f60fc221.entry.js} +2 -2
  155. package/dist/db-ux/{p-63f30576.entry.js → p-f71fe126.entry.js} +2 -2
  156. package/dist/esm/app-globals-DQuL1Twl.js.map +1 -1
  157. package/dist/esm/db-accordion-item.entry.js +2 -2
  158. package/dist/esm/db-accordion.entry.js +2 -2
  159. package/dist/esm/db-badge.entry.js +2 -2
  160. package/dist/esm/db-brand.entry.js +2 -2
  161. package/dist/esm/db-button.entry.js +2 -2
  162. package/dist/esm/db-card.entry.js +2 -2
  163. package/dist/esm/db-checkbox.entry.js +2 -2
  164. package/dist/esm/db-custom-select-dropdown.db-custom-select-list.db-custom-select-list-item.db-input.db-tag.entry.js.map +1 -1
  165. package/dist/esm/db-custom-select-dropdown_5.entry.js +4 -4
  166. package/dist/esm/db-custom-select-dropdown_5.entry.js.map +1 -1
  167. package/dist/esm/db-custom-select-form-field.entry.js +2 -2
  168. package/dist/esm/db-custom-select.entry.js +37 -13
  169. package/dist/esm/db-custom-select.entry.js.map +1 -1
  170. package/dist/esm/db-divider.entry.js +2 -2
  171. package/dist/esm/db-drawer.entry.js +2 -2
  172. package/dist/esm/db-header.entry.js +4 -3
  173. package/dist/esm/db-header.entry.js.map +1 -1
  174. package/dist/esm/db-icon.entry.js +2 -2
  175. package/dist/esm/db-infotext.entry.js +2 -2
  176. package/dist/esm/db-link.entry.js +2 -2
  177. package/dist/esm/db-navigation-item.entry.js +4 -3
  178. package/dist/esm/db-navigation-item.entry.js.map +1 -1
  179. package/dist/esm/db-navigation.entry.js +2 -2
  180. package/dist/esm/db-notification.entry.js +2 -2
  181. package/dist/esm/db-page.entry.js +2 -2
  182. package/dist/esm/db-popover.entry.js +65 -11
  183. package/dist/esm/db-popover.entry.js.map +1 -1
  184. package/dist/esm/db-radio.entry.js +2 -2
  185. package/dist/esm/db-section.entry.js +2 -2
  186. package/dist/esm/db-select.entry.js +7 -7
  187. package/dist/esm/db-select.entry.js.map +1 -1
  188. package/dist/esm/db-stack.entry.js +2 -2
  189. package/dist/esm/db-switch.entry.js +2 -2
  190. package/dist/esm/db-tab-item_3.entry.js +2 -2
  191. package/dist/esm/db-tabs.entry.js +2 -2
  192. package/dist/esm/db-textarea.entry.js +6 -6
  193. package/dist/esm/db-textarea.entry.js.map +1 -1
  194. package/dist/esm/db-tooltip.entry.js +66 -14
  195. package/dist/esm/db-tooltip.entry.js.map +1 -1
  196. package/dist/esm/db-ux.js +4 -4
  197. package/dist/esm/db-ux.js.map +1 -1
  198. package/dist/esm/{document-click-listener-Bf90GXqB.js → document-click-listener-CG0rJGJ-.js} +3 -3
  199. package/dist/esm/{document-click-listener-Bf90GXqB.js.map → document-click-listener-CG0rJGJ-.js.map} +1 -1
  200. package/dist/esm/document-scroll-listener-CwWQuwL5.js +44 -0
  201. package/dist/esm/document-scroll-listener-CwWQuwL5.js.map +1 -0
  202. package/dist/esm/floating-components-DYeQU2bY.js +295 -0
  203. package/dist/esm/floating-components-DYeQU2bY.js.map +1 -0
  204. package/dist/esm/{index-pglUTSkG.js → index-BgQRUWMZ.js} +8 -73
  205. package/dist/esm/index-BgQRUWMZ.js.map +1 -0
  206. package/dist/esm/{index-bH2PZLSq.js → index-Ctmm4hMW.js} +3 -3
  207. package/dist/esm/index-Ctmm4hMW.js.map +1 -0
  208. package/dist/esm/index.js +8 -5
  209. package/dist/esm/index.js.map +1 -1
  210. package/dist/esm/loader.js +3 -3
  211. package/dist/esm/{navigation-C1ssnmpm.js → navigation-CE_2IUA4.js} +3 -3
  212. package/dist/esm/navigation-CE_2IUA4.js.map +1 -0
  213. package/dist/types/components/custom-select/custom-select.d.ts +4 -2
  214. package/dist/types/components/custom-select/model.d.ts +3 -3
  215. package/dist/types/components/input/input.d.ts +1 -0
  216. package/dist/types/components/popover/model.d.ts +0 -1
  217. package/dist/types/components/popover/popover.d.ts +7 -2
  218. package/dist/types/components/textarea/model.d.ts +4 -0
  219. package/dist/types/components/textarea/textarea.d.ts +2 -0
  220. package/dist/types/components/tooltip/model.d.ts +5 -3
  221. package/dist/types/components/tooltip/tooltip.d.ts +9 -2
  222. package/dist/types/components.d.ts +24 -0
  223. package/dist/types/shared/model.d.ts +18 -3
  224. package/dist/types/stencil-public-runtime.d.ts +1 -1
  225. package/dist/types/utils/document-scroll-listener.d.ts +9 -0
  226. package/dist/types/utils/floating-components.d.ts +7 -0
  227. package/dist/types/utils/index.d.ts +4 -13
  228. package/dist/types/utils/navigation.d.ts +1 -1
  229. package/dist/vscode.html-custom-data.json +37 -22
  230. package/dist/web-types.json +70 -34
  231. package/package.json +4 -4
  232. package/dist/cjs/index-7lbP4BU6.js.map +0 -1
  233. package/dist/cjs/index-BzLx0HVU.js.map +0 -1
  234. package/dist/cjs/navigation-BLjJ1vaO.js.map +0 -1
  235. package/dist/db-ux/p-39d957bb.entry.js +0 -2
  236. package/dist/db-ux/p-426d06bb.entry.js +0 -2
  237. package/dist/db-ux/p-426d06bb.entry.js.map +0 -1
  238. package/dist/db-ux/p-52e736c3.entry.js +0 -2
  239. package/dist/db-ux/p-5c2eddb6.entry.js +0 -2
  240. package/dist/db-ux/p-6610dd91.entry.js +0 -2
  241. package/dist/db-ux/p-6610dd91.entry.js.map +0 -1
  242. package/dist/db-ux/p-6wgV8aKO.js.map +0 -1
  243. package/dist/db-ux/p-7332ab62.entry.js +0 -2
  244. package/dist/db-ux/p-7332ab62.entry.js.map +0 -1
  245. package/dist/db-ux/p-8ad4f80a.entry.js +0 -2
  246. package/dist/db-ux/p-YMQoOWgh.js +0 -2
  247. package/dist/db-ux/p-a49adbd6.entry.js +0 -2
  248. package/dist/db-ux/p-a49adbd6.entry.js.map +0 -1
  249. package/dist/db-ux/p-a8feda0a.entry.js +0 -2
  250. package/dist/db-ux/p-a8feda0a.entry.js.map +0 -1
  251. package/dist/db-ux/p-bH2PZLSq.js.map +0 -1
  252. package/dist/db-ux/p-e3117b8a.entry.js +0 -2
  253. package/dist/db-ux/p-e3117b8a.entry.js.map +0 -1
  254. package/dist/db-ux/p-pglUTSkG.js +0 -2
  255. package/dist/db-ux/p-pglUTSkG.js.map +0 -1
  256. package/dist/esm/index-bH2PZLSq.js.map +0 -1
  257. package/dist/esm/index-pglUTSkG.js.map +0 -1
  258. package/dist/esm/navigation-C1ssnmpm.js.map +0 -1
  259. /package/dist/db-ux/{p-b4bc8f26.entry.js.map → p-0bb2fc14.entry.js.map} +0 -0
  260. /package/dist/db-ux/{p-16a0ae38.entry.js.map → p-0d8b6ecd.entry.js.map} +0 -0
  261. /package/dist/db-ux/{p-39d957bb.entry.js.map → p-0f107c11.entry.js.map} +0 -0
  262. /package/dist/db-ux/{p-0740aa7d.entry.js.map → p-144ebba2.entry.js.map} +0 -0
  263. /package/dist/db-ux/{p-14c44b94.entry.js.map → p-1face452.entry.js.map} +0 -0
  264. /package/dist/db-ux/{p-8b7d868b.entry.js.map → p-36b32211.entry.js.map} +0 -0
  265. /package/dist/db-ux/{p-55b02c80.entry.js.map → p-53f83d20.entry.js.map} +0 -0
  266. /package/dist/db-ux/{p-0e4c3fb1.entry.js.map → p-55f53705.entry.js.map} +0 -0
  267. /package/dist/db-ux/{p-f83357e2.entry.js.map → p-5c63036a.entry.js.map} +0 -0
  268. /package/dist/db-ux/{p-52e736c3.entry.js.map → p-6f1226da.entry.js.map} +0 -0
  269. /package/dist/db-ux/{p-139f5623.entry.js.map → p-77ce5cb6.entry.js.map} +0 -0
  270. /package/dist/db-ux/{p-c088c8c8.entry.js.map → p-833f8694.entry.js.map} +0 -0
  271. /package/dist/db-ux/{p-7de004e3.entry.js.map → p-87a03fc0.entry.js.map} +0 -0
  272. /package/dist/db-ux/{p-6b6dbd54.entry.js.map → p-a107ec7c.entry.js.map} +0 -0
  273. /package/dist/db-ux/{p-9046dcdf.entry.js.map → p-c40a990b.entry.js.map} +0 -0
  274. /package/dist/db-ux/{p-5c4d25b8.entry.js.map → p-c673c483.entry.js.map} +0 -0
  275. /package/dist/db-ux/{p-01112955.entry.js.map → p-ca134c76.entry.js.map} +0 -0
  276. /package/dist/db-ux/{p-c5909b40.entry.js.map → p-cff88428.entry.js.map} +0 -0
  277. /package/dist/db-ux/{p-9c07a46d.entry.js.map → p-d5e0c0b5.entry.js.map} +0 -0
  278. /package/dist/db-ux/{p-40713825.entry.js.map → p-ef6cda9f.entry.js.map} +0 -0
  279. /package/dist/db-ux/{p-e8cabe82.entry.js.map → p-f60fc221.entry.js.map} +0 -0
  280. /package/dist/db-ux/{p-63f30576.entry.js.map → p-f71fe126.entry.js.map} +0 -0
@@ -0,0 +1,291 @@
1
+ // TODO: We should reevaluate this as soon as CSS Anchor Positioning is supported in all relevant browsers
2
+ const isInView = (el) => {
3
+ var _a;
4
+ const { top, bottom, left, right } = el.getBoundingClientRect();
5
+ const { innerHeight, innerWidth } = window;
6
+ let outTop = top < 0;
7
+ let outBottom = bottom > innerHeight;
8
+ let outLeft = left < 0;
9
+ let outRight = right > innerWidth;
10
+ // We need to check if it was already outside
11
+ const outsideY = el.dataset['outsideVy'];
12
+ const outsideX = el.dataset['outsideVx'];
13
+ const parentRect = (_a = el === null || el === void 0 ? void 0 : el.parentElement) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect();
14
+ if (parentRect) {
15
+ if (outsideY) {
16
+ const position = el.dataset['outsideVy'];
17
+ if (position === 'top') {
18
+ outTop = parentRect.top - (bottom - parentRect.bottom) < 0;
19
+ }
20
+ else {
21
+ outBottom = parentRect.bottom + (parentRect.top - top) > innerHeight;
22
+ }
23
+ }
24
+ if (outsideX) {
25
+ const position = el.dataset['outsideVx'];
26
+ if (position === 'left') {
27
+ outLeft = parentRect.left - (right - parentRect.right) < 0;
28
+ }
29
+ else {
30
+ outRight = parentRect.right + (parentRect.left - left) > innerWidth;
31
+ }
32
+ }
33
+ }
34
+ return {
35
+ outTop,
36
+ outBottom,
37
+ outLeft,
38
+ outRight
39
+ };
40
+ };
41
+ export const handleDataOutside = (el) => {
42
+ const { outTop, outBottom, outLeft, outRight } = isInView(el);
43
+ let dataOutsidePair = {};
44
+ if (outTop || outBottom) {
45
+ dataOutsidePair = {
46
+ vy: outTop ? 'top' : 'bottom'
47
+ };
48
+ el.dataset['outsideVy'] = dataOutsidePair.vy;
49
+ }
50
+ else {
51
+ delete el.dataset['outsideVy'];
52
+ }
53
+ if (outLeft || outRight) {
54
+ dataOutsidePair = Object.assign(Object.assign({}, dataOutsidePair), { vx: outRight ? 'right' : 'left' });
55
+ el.dataset['outsideVx'] = dataOutsidePair.vx;
56
+ }
57
+ else {
58
+ delete el.dataset['outsideVx'];
59
+ }
60
+ return dataOutsidePair;
61
+ };
62
+ export const handleFixedDropdown = (element, parent, placement) => {
63
+ // We skip this if we are in mobile it's already fixed
64
+ if (getComputedStyle(element).zIndex === '9999')
65
+ return;
66
+ const { top, bottom, childHeight, childWidth, width, right, left, correctedPlacement } = getFloatingProps(element, parent, placement);
67
+ const fullWidth = element.dataset['width'] === 'full';
68
+ if (fullWidth) {
69
+ element.style.inlineSize = `${width}px`;
70
+ }
71
+ if (correctedPlacement === 'top' || correctedPlacement === 'bottom' || correctedPlacement === 'top-start' || correctedPlacement === 'bottom-start') {
72
+ element.style.insetInlineStart = `${left}px`;
73
+ }
74
+ else if (correctedPlacement === 'top-end' || correctedPlacement === 'bottom-end') {
75
+ element.style.insetInlineStart = `${right - childWidth}px`;
76
+ }
77
+ if (correctedPlacement === null || correctedPlacement === void 0 ? void 0 : correctedPlacement.startsWith('top')) {
78
+ element.style.insetBlockStart = `${top - childHeight}px`;
79
+ }
80
+ else if (correctedPlacement === null || correctedPlacement === void 0 ? void 0 : correctedPlacement.startsWith('bottom')) {
81
+ element.style.insetBlockStart = `${bottom}px`;
82
+ }
83
+ element.style.position = 'fixed';
84
+ };
85
+ const getFloatingProps = (element, parent, placement) => {
86
+ const childRect = element.getBoundingClientRect();
87
+ const { top, height, bottom, right, left, width } = parent.getBoundingClientRect();
88
+ const { innerHeight, innerWidth } = window;
89
+ let childHeight = childRect.height;
90
+ let childWidth = childRect.width;
91
+ if (placement === 'bottom' || placement === 'top') {
92
+ childWidth = childWidth / 2;
93
+ }
94
+ if (placement === 'left' || placement === 'right') {
95
+ childHeight = childHeight / 2;
96
+ }
97
+ const outsideBottom = bottom + childHeight > innerHeight;
98
+ const outsideTop = top - childHeight < 0;
99
+ const outsideLeft = left - childWidth < 0;
100
+ const outsideRight = right + childWidth > innerWidth;
101
+ let correctedPlacement = placement;
102
+ if (placement.startsWith('bottom')) {
103
+ if (outsideBottom) {
104
+ correctedPlacement = placement === null || placement === void 0 ? void 0 : placement.replace('bottom', 'top');
105
+ if (outsideLeft && outsideRight) {
106
+ correctedPlacement = 'top';
107
+ }
108
+ else if (outsideLeft) {
109
+ correctedPlacement = 'top-start';
110
+ }
111
+ else if (outsideRight) {
112
+ correctedPlacement = 'top-end';
113
+ }
114
+ }
115
+ else {
116
+ if (outsideLeft && outsideRight) {
117
+ correctedPlacement = 'bottom';
118
+ }
119
+ else if (outsideLeft) {
120
+ correctedPlacement = 'bottom-start';
121
+ }
122
+ else if (outsideRight) {
123
+ correctedPlacement = 'bottom-end';
124
+ }
125
+ }
126
+ }
127
+ else if (placement.startsWith('top')) {
128
+ if (outsideTop) {
129
+ correctedPlacement = placement === null || placement === void 0 ? void 0 : placement.replace('top', 'bottom');
130
+ if (outsideLeft && outsideRight) {
131
+ correctedPlacement = 'bottom';
132
+ }
133
+ else if (outsideLeft) {
134
+ correctedPlacement = 'bottom-start';
135
+ }
136
+ else if (outsideRight) {
137
+ correctedPlacement = 'bottom-end';
138
+ }
139
+ }
140
+ else {
141
+ if (outsideLeft && outsideRight) {
142
+ correctedPlacement = 'top';
143
+ }
144
+ else if (outsideLeft) {
145
+ correctedPlacement = 'top-start';
146
+ }
147
+ else if (outsideRight) {
148
+ correctedPlacement = 'top-end';
149
+ }
150
+ }
151
+ }
152
+ else if (placement.startsWith('left')) {
153
+ if (outsideLeft) {
154
+ correctedPlacement = placement === null || placement === void 0 ? void 0 : placement.replace('left', 'right');
155
+ if (outsideBottom && outsideTop) {
156
+ correctedPlacement = 'right';
157
+ }
158
+ else if (outsideBottom) {
159
+ correctedPlacement = 'right-end';
160
+ }
161
+ else if (outsideTop) {
162
+ correctedPlacement = 'right-start';
163
+ }
164
+ }
165
+ else {
166
+ if (outsideBottom && outsideTop) {
167
+ correctedPlacement = 'left';
168
+ }
169
+ else if (outsideBottom) {
170
+ correctedPlacement = 'left-end';
171
+ }
172
+ else if (outsideTop) {
173
+ correctedPlacement = 'left-start';
174
+ }
175
+ }
176
+ }
177
+ else if (correctedPlacement.startsWith('right')) {
178
+ if (outsideRight) {
179
+ correctedPlacement = placement === null || placement === void 0 ? void 0 : placement.replace('right', 'left');
180
+ if (outsideBottom && outsideTop) {
181
+ correctedPlacement = 'left';
182
+ }
183
+ else if (outsideBottom) {
184
+ correctedPlacement = 'left-end';
185
+ }
186
+ else if (outsideTop) {
187
+ correctedPlacement = 'left-start';
188
+ }
189
+ }
190
+ else {
191
+ if (outsideBottom && outsideTop) {
192
+ correctedPlacement = 'right';
193
+ }
194
+ else if (outsideBottom) {
195
+ correctedPlacement = 'right-end';
196
+ }
197
+ else if (outsideTop) {
198
+ correctedPlacement = 'right-start';
199
+ }
200
+ }
201
+ }
202
+ return {
203
+ top,
204
+ bottom,
205
+ right,
206
+ height,
207
+ width,
208
+ left,
209
+ childHeight: childRect.height,
210
+ childWidth: childRect.width,
211
+ correctedPlacement,
212
+ innerWidth,
213
+ innerHeight
214
+ };
215
+ };
216
+ export const handleFixedPopover = (element, parent, placement) => {
217
+ var _a;
218
+ const distance = (_a = getComputedStyle(element).getPropertyValue('--db-popover-distance')) !== null && _a !== void 0 ? _a : '0px';
219
+ const { top, height, width, childHeight, childWidth, right, left, bottom, correctedPlacement, innerWidth, innerHeight } = getFloatingProps(element, parent, placement);
220
+ // Tooltip arrow position
221
+ if (childWidth > width && (correctedPlacement.startsWith('bottom') || correctedPlacement.startsWith('top'))) {
222
+ const diff = width / 2 / childWidth * 100;
223
+ if (correctedPlacement.endsWith('start')) {
224
+ element.style.setProperty('--db-tooltip-arrow-inline-start', `${diff}%`);
225
+ }
226
+ else if (correctedPlacement.endsWith('end')) {
227
+ element.style.setProperty('--db-tooltip-arrow-inline-start', `${100 - diff}%`);
228
+ }
229
+ }
230
+ if (childHeight > height && (correctedPlacement.startsWith('left') || correctedPlacement.startsWith('bottom'))) {
231
+ const diff = height / 2 / childHeight * 100;
232
+ if (correctedPlacement.endsWith('start')) {
233
+ element.style.setProperty('--db-tooltip-arrow-block-start', `${diff}%`);
234
+ }
235
+ else if (correctedPlacement.endsWith('end')) {
236
+ element.style.setProperty('--db-tooltip-arrow-block-start', `${100 - diff}%`);
237
+ }
238
+ }
239
+ // Popover position
240
+ if (correctedPlacement === 'right' || correctedPlacement === 'left') {
241
+ // center horizontally
242
+ element.style.insetBlockStart = `${top + height / 2}px`;
243
+ }
244
+ else if (correctedPlacement === 'right-start' || correctedPlacement === 'left-start') {
245
+ const end = top + childHeight;
246
+ element.style.insetBlockStart = `${top}px`;
247
+ element.style.insetBlockEnd = `${end > innerHeight ? innerHeight : end}px`;
248
+ }
249
+ else if (correctedPlacement === 'right-end' || correctedPlacement === 'left-end') {
250
+ const start = bottom - childHeight;
251
+ element.style.insetBlockStart = `${start < 0 ? 0 : start}px`;
252
+ element.style.insetBlockEnd = `${bottom}px`;
253
+ }
254
+ else if (correctedPlacement === 'top' || correctedPlacement === 'bottom') {
255
+ // center vertically
256
+ element.style.insetInlineStart = `${left + width / 2}px`;
257
+ }
258
+ else if (correctedPlacement === 'top-start' || correctedPlacement === 'bottom-start') {
259
+ const end = left + childWidth;
260
+ element.style.insetInlineStart = `${left}px`;
261
+ element.style.insetInlineEnd = `${end > innerWidth ? innerWidth : end}px`;
262
+ }
263
+ else if (correctedPlacement === 'top-end' || correctedPlacement === 'bottom-end') {
264
+ const start = left - childWidth;
265
+ element.style.insetInlineStart = `${right - childWidth}px`;
266
+ element.style.insetInlineEnd = `${start < 0 ? 0 : start}px`;
267
+ }
268
+ if (correctedPlacement === null || correctedPlacement === void 0 ? void 0 : correctedPlacement.startsWith('right')) {
269
+ const end = right + childWidth;
270
+ element.style.insetInlineStart = `calc(${right}px + ${distance})`;
271
+ element.style.insetInlineEnd = `calc(${end > innerWidth ? innerWidth : end}px + ${distance})`;
272
+ }
273
+ else if (correctedPlacement === null || correctedPlacement === void 0 ? void 0 : correctedPlacement.startsWith('left')) {
274
+ const start = left - childWidth;
275
+ element.style.insetInlineStart = `calc(${start < 0 ? 0 : start}px - ${distance})`;
276
+ element.style.insetInlineEnd = `calc(${right}px - ${distance})`;
277
+ }
278
+ else if (correctedPlacement === null || correctedPlacement === void 0 ? void 0 : correctedPlacement.startsWith('top')) {
279
+ const start = top - childHeight;
280
+ element.style.insetBlockStart = `calc(${start < 0 ? 0 : start}px - ${distance})`;
281
+ element.style.insetBlockEnd = `calc(${bottom}px - ${distance})`;
282
+ }
283
+ else if (correctedPlacement === null || correctedPlacement === void 0 ? void 0 : correctedPlacement.startsWith('bottom')) {
284
+ const end = bottom + childHeight;
285
+ element.style.insetBlockStart = `calc(${bottom}px + ${distance})`;
286
+ element.style.insetBlockEnd = `calc(${end > innerHeight ? innerHeight : end}px + ${distance})`;
287
+ }
288
+ element.style.position = 'fixed';
289
+ element.setAttribute('data-corrected-placement', correctedPlacement);
290
+ };
291
+ //# sourceMappingURL=floating-components.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"floating-components.js","sourceRoot":"","sources":["../../src/utils/floating-components.ts"],"names":[],"mappings":"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","sourcesContent":["// TODO: We should reevaluate this as soon as CSS Anchor Positioning is supported in all relevant browsers\nconst isInView = (el: HTMLElement) => {\n const {\n top,\n bottom,\n left,\n right\n } = el.getBoundingClientRect();\n const {\n innerHeight,\n innerWidth\n } = window;\n let outTop = top < 0;\n let outBottom = bottom > innerHeight;\n let outLeft = left < 0;\n let outRight = right > innerWidth;\n\n // We need to check if it was already outside\n const outsideY = el.dataset['outsideVy'];\n const outsideX = el.dataset['outsideVx'];\n const parentRect = el?.parentElement?.getBoundingClientRect();\n if (parentRect) {\n if (outsideY) {\n const position = el.dataset['outsideVy'];\n if (position === 'top') {\n outTop = parentRect.top - (bottom - parentRect.bottom) < 0;\n } else {\n outBottom = parentRect.bottom + (parentRect.top - top) > innerHeight;\n }\n }\n if (outsideX) {\n const position = el.dataset['outsideVx'];\n if (position === 'left') {\n outLeft = parentRect.left - (right - parentRect.right) < 0;\n } else {\n outRight = parentRect.right + (parentRect.left - left) > innerWidth;\n }\n }\n }\n return {\n outTop,\n outBottom,\n outLeft,\n outRight\n };\n};\nexport interface DBDataOutsidePair {\n vx?: 'left' | 'right';\n vy?: 'top' | 'bottom';\n}\nexport const handleDataOutside = (el: HTMLElement): DBDataOutsidePair => {\n const {\n outTop,\n outBottom,\n outLeft,\n outRight\n } = isInView(el);\n let dataOutsidePair: DBDataOutsidePair = {};\n if (outTop || outBottom) {\n dataOutsidePair = {\n vy: outTop ? 'top' : 'bottom'\n };\n el.dataset['outsideVy'] = dataOutsidePair.vy!;\n } else {\n delete el.dataset['outsideVy'];\n }\n if (outLeft || outRight) {\n dataOutsidePair = {\n ...dataOutsidePair,\n vx: outRight ? 'right' : 'left'\n };\n el.dataset['outsideVx'] = dataOutsidePair.vx!;\n } else {\n delete el.dataset['outsideVx'];\n }\n return dataOutsidePair;\n};\nexport const handleFixedDropdown = (element: HTMLElement, parent: HTMLElement, placement: string) => {\n // We skip this if we are in mobile it's already fixed\n if (getComputedStyle(element).zIndex === '9999') return;\n const {\n top,\n bottom,\n childHeight,\n childWidth,\n width,\n right,\n left,\n correctedPlacement\n } = getFloatingProps(element, parent, placement);\n const fullWidth = element.dataset['width'] === 'full';\n if (fullWidth) {\n element.style.inlineSize = `${width}px`;\n }\n if (correctedPlacement === 'top' || correctedPlacement === 'bottom' || correctedPlacement === 'top-start' || correctedPlacement === 'bottom-start') {\n element.style.insetInlineStart = `${left}px`;\n } else if (correctedPlacement === 'top-end' || correctedPlacement === 'bottom-end') {\n element.style.insetInlineStart = `${right - childWidth}px`;\n }\n if (correctedPlacement?.startsWith('top')) {\n element.style.insetBlockStart = `${top - childHeight}px`;\n } else if (correctedPlacement?.startsWith('bottom')) {\n element.style.insetBlockStart = `${bottom}px`;\n }\n element.style.position = 'fixed';\n};\nconst getFloatingProps = (element: HTMLElement, parent: HTMLElement, placement: string) => {\n const childRect = element.getBoundingClientRect();\n const {\n top,\n height,\n bottom,\n right,\n left,\n width\n } = parent.getBoundingClientRect();\n const {\n innerHeight,\n innerWidth\n } = window;\n let childHeight = childRect.height;\n let childWidth = childRect.width;\n if (placement === 'bottom' || placement === 'top') {\n childWidth = childWidth / 2;\n }\n if (placement === 'left' || placement === 'right') {\n childHeight = childHeight / 2;\n }\n const outsideBottom = bottom + childHeight > innerHeight;\n const outsideTop = top - childHeight < 0;\n const outsideLeft = left - childWidth < 0;\n const outsideRight = right + childWidth > innerWidth;\n let correctedPlacement = placement;\n if (placement.startsWith('bottom')) {\n if (outsideBottom) {\n correctedPlacement = placement?.replace('bottom', 'top');\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'top';\n } else if (outsideLeft) {\n correctedPlacement = 'top-start';\n } else if (outsideRight) {\n correctedPlacement = 'top-end';\n }\n } else {\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'bottom';\n } else if (outsideLeft) {\n correctedPlacement = 'bottom-start';\n } else if (outsideRight) {\n correctedPlacement = 'bottom-end';\n }\n }\n } else if (placement.startsWith('top')) {\n if (outsideTop) {\n correctedPlacement = placement?.replace('top', 'bottom');\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'bottom';\n } else if (outsideLeft) {\n correctedPlacement = 'bottom-start';\n } else if (outsideRight) {\n correctedPlacement = 'bottom-end';\n }\n } else {\n if (outsideLeft && outsideRight) {\n correctedPlacement = 'top';\n } else if (outsideLeft) {\n correctedPlacement = 'top-start';\n } else if (outsideRight) {\n correctedPlacement = 'top-end';\n }\n }\n } else if (placement.startsWith('left')) {\n if (outsideLeft) {\n correctedPlacement = placement?.replace('left', 'right');\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'right';\n } else if (outsideBottom) {\n correctedPlacement = 'right-end';\n } else if (outsideTop) {\n correctedPlacement = 'right-start';\n }\n } else {\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'left';\n } else if (outsideBottom) {\n correctedPlacement = 'left-end';\n } else if (outsideTop) {\n correctedPlacement = 'left-start';\n }\n }\n } else if (correctedPlacement.startsWith('right')) {\n if (outsideRight) {\n correctedPlacement = placement?.replace('right', 'left');\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'left';\n } else if (outsideBottom) {\n correctedPlacement = 'left-end';\n } else if (outsideTop) {\n correctedPlacement = 'left-start';\n }\n } else {\n if (outsideBottom && outsideTop) {\n correctedPlacement = 'right';\n } else if (outsideBottom) {\n correctedPlacement = 'right-end';\n } else if (outsideTop) {\n correctedPlacement = 'right-start';\n }\n }\n }\n return {\n top,\n bottom,\n right,\n height,\n width,\n left,\n childHeight: childRect.height,\n childWidth: childRect.width,\n correctedPlacement,\n innerWidth,\n innerHeight\n };\n};\nexport const handleFixedPopover = (element: HTMLElement, parent: HTMLElement, placement: string) => {\n const distance = getComputedStyle(element).getPropertyValue('--db-popover-distance') ?? '0px';\n const {\n top,\n height,\n width,\n childHeight,\n childWidth,\n right,\n left,\n bottom,\n correctedPlacement,\n innerWidth,\n innerHeight\n } = getFloatingProps(element, parent, placement);\n\n // Tooltip arrow position\n\n if (childWidth > width && (correctedPlacement.startsWith('bottom') || correctedPlacement.startsWith('top'))) {\n const diff = width / 2 / childWidth * 100;\n if (correctedPlacement.endsWith('start')) {\n element.style.setProperty('--db-tooltip-arrow-inline-start', `${diff}%`);\n } else if (correctedPlacement.endsWith('end')) {\n element.style.setProperty('--db-tooltip-arrow-inline-start', `${100 - diff}%`);\n }\n }\n if (childHeight > height && (correctedPlacement.startsWith('left') || correctedPlacement.startsWith('bottom'))) {\n const diff = height / 2 / childHeight * 100;\n if (correctedPlacement.endsWith('start')) {\n element.style.setProperty('--db-tooltip-arrow-block-start', `${diff}%`);\n } else if (correctedPlacement.endsWith('end')) {\n element.style.setProperty('--db-tooltip-arrow-block-start', `${100 - diff}%`);\n }\n }\n\n // Popover position\n\n if (correctedPlacement === 'right' || correctedPlacement === 'left') {\n // center horizontally\n element.style.insetBlockStart = `${top + height / 2}px`;\n } else if (correctedPlacement === 'right-start' || correctedPlacement === 'left-start') {\n const end = top + childHeight;\n element.style.insetBlockStart = `${top}px`;\n element.style.insetBlockEnd = `${end > innerHeight ? innerHeight : end}px`;\n } else if (correctedPlacement === 'right-end' || correctedPlacement === 'left-end') {\n const start = bottom - childHeight;\n element.style.insetBlockStart = `${start < 0 ? 0 : start}px`;\n element.style.insetBlockEnd = `${bottom}px`;\n } else if (correctedPlacement === 'top' || correctedPlacement === 'bottom') {\n // center vertically\n element.style.insetInlineStart = `${left + width / 2}px`;\n } else if (correctedPlacement === 'top-start' || correctedPlacement === 'bottom-start') {\n const end = left + childWidth;\n element.style.insetInlineStart = `${left}px`;\n element.style.insetInlineEnd = `${end > innerWidth ? innerWidth : end}px`;\n } else if (correctedPlacement === 'top-end' || correctedPlacement === 'bottom-end') {\n const start = left - childWidth;\n element.style.insetInlineStart = `${right - childWidth}px`;\n element.style.insetInlineEnd = `${start < 0 ? 0 : start}px`;\n }\n if (correctedPlacement?.startsWith('right')) {\n const end = right + childWidth;\n element.style.insetInlineStart = `calc(${right}px + ${distance})`;\n element.style.insetInlineEnd = `calc(${end > innerWidth ? innerWidth : end}px + ${distance})`;\n } else if (correctedPlacement?.startsWith('left')) {\n const start = left - childWidth;\n element.style.insetInlineStart = `calc(${start < 0 ? 0 : start}px - ${distance})`;\n element.style.insetInlineEnd = `calc(${right}px - ${distance})`;\n } else if (correctedPlacement?.startsWith('top')) {\n const start = top - childHeight;\n element.style.insetBlockStart = `calc(${start < 0 ? 0 : start}px - ${distance})`;\n element.style.insetBlockEnd = `calc(${bottom}px - ${distance})`;\n } else if (correctedPlacement?.startsWith('bottom')) {\n const end = bottom + childHeight;\n element.style.insetBlockStart = `calc(${bottom}px + ${distance})`;\n element.style.insetBlockEnd = `calc(${end > innerHeight ? innerHeight : end}px + ${distance})`;\n }\n element.style.position = 'fixed';\n element.setAttribute('data-corrected-placement', correctedPlacement);\n}"]}
@@ -37,76 +37,6 @@ export const cls = (...args) => {
37
37
  }
38
38
  return result.trim();
39
39
  };
40
- export const visibleInVX = (el) => {
41
- const { left, right } = el.getBoundingClientRect();
42
- const { innerWidth } = window;
43
- return left >= 0 && right <= innerWidth;
44
- };
45
- export const visibleInVY = (el) => {
46
- const { top, bottom } = el.getBoundingClientRect();
47
- const { innerHeight } = window;
48
- return top >= 0 && bottom <= innerHeight;
49
- };
50
- export const isInView = (el) => {
51
- var _a;
52
- const { top, bottom, left, right } = el.getBoundingClientRect();
53
- const { innerHeight, innerWidth } = window;
54
- let outTop = top < 0;
55
- let outBottom = bottom > innerHeight;
56
- let outLeft = left < 0;
57
- let outRight = right > innerWidth;
58
- // We need to check if it was already outside
59
- const outsideY = el.hasAttribute('data-outside-vy');
60
- const outsideX = el.hasAttribute('data-outside-vx');
61
- const parentRect = (_a = el === null || el === void 0 ? void 0 : el.parentElement) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect();
62
- if (parentRect) {
63
- if (outsideY) {
64
- const position = el.getAttribute('data-outside-vy');
65
- if (position === 'top') {
66
- outTop = parentRect.top - (bottom - parentRect.bottom) < 0;
67
- }
68
- else {
69
- outBottom = parentRect.bottom + (parentRect.top - top) > innerHeight;
70
- }
71
- }
72
- if (outsideX) {
73
- const position = el.getAttribute('data-outside-vx');
74
- if (position === 'left') {
75
- outLeft = parentRect.left - (right - parentRect.right) < 0;
76
- }
77
- else {
78
- outRight = parentRect.right + (parentRect.left - left) > innerWidth;
79
- }
80
- }
81
- }
82
- return {
83
- outTop,
84
- outBottom,
85
- outLeft,
86
- outRight
87
- };
88
- };
89
- export const handleDataOutside = (el) => {
90
- const { outTop, outBottom, outLeft, outRight } = isInView(el);
91
- let dataOutsidePair = {};
92
- if (outTop || outBottom) {
93
- dataOutsidePair = {
94
- vy: outTop ? 'top' : 'bottom'
95
- };
96
- el.setAttribute('data-outside-vy', dataOutsidePair.vy);
97
- }
98
- else {
99
- el.removeAttribute('data-outside-vy');
100
- }
101
- if (outLeft || outRight) {
102
- dataOutsidePair = Object.assign(Object.assign({}, dataOutsidePair), { vx: outRight ? 'right' : 'left' });
103
- el.setAttribute('data-outside-vx', dataOutsidePair.vx);
104
- }
105
- else {
106
- el.removeAttribute('data-outside-vx');
107
- }
108
- return dataOutsidePair;
109
- };
110
40
  export const isArrayOfStrings = (value) => Array.isArray(value) && value.every(item => typeof item === 'string');
111
41
  const appleOs = ['Mac', 'iPhone', 'iPad', 'iPod'];
112
42
  export const hasVoiceOver = () => typeof window !== 'undefined' && appleOs.some(os => window.navigator.userAgent.includes(os));
@@ -168,4 +98,9 @@ export const stringPropVisible = (givenString, showString) => {
168
98
  }
169
99
  };
170
100
  export const getSearchInput = (element) => element.querySelector(`input[type="search"]`);
101
+ export const getOptionKey = (option, prefix) => {
102
+ var _a, _b;
103
+ const key = (_b = (_a = option.id) !== null && _a !== void 0 ? _a : option.value) !== null && _b !== void 0 ? _b : uuid();
104
+ return `${prefix}${key}`;
105
+ };
171
106
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"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","sourcesContent":["export const uuid = () => {\n if (typeof window !== 'undefined') {\n if (window.crypto?.randomUUID) {\n return window.crypto.randomUUID();\n } else if (window.crypto?.getRandomValues) {\n return window.crypto.getRandomValues(new Uint32Array(3)).join('-');\n }\n }\n return Math.random().toString().substring(2);\n};\nexport const addAttributeToChildren = (element: Element, attribute: {\n key: string;\n value: string;\n}) => {\n const children = element.children;\n Object.values(children).forEach((child: Element) => {\n child.setAttribute(attribute.key, attribute.value);\n if (child.children.length > 0) {\n addAttributeToChildren(child, attribute);\n }\n });\n};\nexport type ClassNameArg = string | {\n [key: string]: boolean | undefined;\n} | undefined;\nexport const cls = (...args: ClassNameArg[]) => {\n let result = '';\n for (const arg of args) {\n if (arg) {\n if (typeof arg === 'string') {\n result += `${arg} `;\n } else {\n for (const key in arg) {\n if (arg[key]) {\n result += `${key} `;\n }\n }\n }\n }\n }\n return result.trim();\n};\nexport const visibleInVX = (el: Element) => {\n const {\n left,\n right\n } = el.getBoundingClientRect();\n const {\n innerWidth\n } = window;\n return left >= 0 && right <= innerWidth;\n};\nexport const visibleInVY = (el: Element) => {\n const {\n top,\n bottom\n } = el.getBoundingClientRect();\n const {\n innerHeight\n } = window;\n return top >= 0 && bottom <= innerHeight;\n};\nexport const isInView = (el: Element) => {\n const {\n top,\n bottom,\n left,\n right\n } = el.getBoundingClientRect();\n const {\n innerHeight,\n innerWidth\n } = window;\n let outTop = top < 0;\n let outBottom = bottom > innerHeight;\n let outLeft = left < 0;\n let outRight = right > innerWidth;\n\n // We need to check if it was already outside\n const outsideY = el.hasAttribute('data-outside-vy');\n const outsideX = el.hasAttribute('data-outside-vx');\n const parentRect = el?.parentElement?.getBoundingClientRect();\n if (parentRect) {\n if (outsideY) {\n const position = el.getAttribute('data-outside-vy');\n if (position === 'top') {\n outTop = parentRect.top - (bottom - parentRect.bottom) < 0;\n } else {\n outBottom = parentRect.bottom + (parentRect.top - top) > innerHeight;\n }\n }\n if (outsideX) {\n const position = el.getAttribute('data-outside-vx');\n if (position === 'left') {\n outLeft = parentRect.left - (right - parentRect.right) < 0;\n } else {\n outRight = parentRect.right + (parentRect.left - left) > innerWidth;\n }\n }\n }\n return {\n outTop,\n outBottom,\n outLeft,\n outRight\n };\n};\nexport interface DBDataOutsidePair {\n vx?: 'left' | 'right';\n vy?: 'top' | 'bottom';\n}\nexport const handleDataOutside = (el: Element): DBDataOutsidePair => {\n const {\n outTop,\n outBottom,\n outLeft,\n outRight\n } = isInView(el);\n let dataOutsidePair: DBDataOutsidePair = {};\n if (outTop || outBottom) {\n dataOutsidePair = {\n vy: outTop ? 'top' : 'bottom'\n };\n el.setAttribute('data-outside-vy', dataOutsidePair.vy!);\n } else {\n el.removeAttribute('data-outside-vy');\n }\n if (outLeft || outRight) {\n dataOutsidePair = {\n ...dataOutsidePair,\n vx: outRight ? 'right' : 'left'\n };\n el.setAttribute('data-outside-vx', dataOutsidePair.vx!);\n } else {\n el.removeAttribute('data-outside-vx');\n }\n return dataOutsidePair;\n};\nexport const isArrayOfStrings = (value: unknown): value is string[] => Array.isArray(value) && value.every(item => typeof item === 'string');\nconst appleOs = ['Mac', 'iPhone', 'iPad', 'iPod'];\nexport const hasVoiceOver = (): boolean => typeof window !== 'undefined' && appleOs.some(os => window.navigator.userAgent.includes(os));\nexport const delay = (fn: () => void, ms: number) => new Promise(() => setTimeout(fn, ms));\n\n/**\n * Some frameworks like stencil would not add \"true\" as value for a prop\n * if it is used in a framework like angular e.g.: [disabled]=\"myDisabledProp\"\n * @param originBool Some boolean to convert to string\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const getBooleanAsString = (originBool?: boolean | string): any => {\n if (originBool === undefined || originBool === null) return;\n if (typeof originBool === 'string') {\n return String(Boolean(originBool));\n }\n return String(originBool);\n};\nexport const getBoolean = (originBool?: boolean | string, propertyName?: string): boolean | undefined => {\n if (originBool === undefined || originBool === null) return;\n if (typeof originBool === 'string' && propertyName) {\n return Boolean(propertyName === originBool || originBool);\n }\n return Boolean(originBool);\n};\nexport const getNumber = (originNumber?: number | string, alternativeNumber?: number | string): number | undefined => {\n if ((originNumber === undefined || originNumber === null) && (alternativeNumber === undefined || alternativeNumber === null)) {\n return;\n }\n return Number(originNumber ?? alternativeNumber);\n};\n\n/**\n * Retrieves the input value based on the provided value and input type.\n *\n * If the input type is \"number\" or \"range\", the value is processed as a number.\n * Otherwise, the value is returned as-is.\n *\n * @param value - The input value, which can be a number, string, or undefined.\n * @param inputType - The type of the input, such as \"number\", \"range\", or other string types.\n * @returns The processed input value as a string, number, or undefined.\n */\nexport const getInputValue = (value?: number | string, inputType?: string): string | number | undefined => {\n return inputType && ['number', 'range'].includes(inputType) ? getNumber(value) : value;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const getHideProp = (show?: boolean | string): any => {\n if (show === undefined || show === null) {\n return undefined;\n }\n return getBooleanAsString(!Boolean(show));\n};\nexport const stringPropVisible = (givenString?: string, showString?: boolean | string) => {\n if (showString === undefined) {\n return !!givenString;\n } else {\n return Boolean(showString) && Boolean(givenString);\n }\n};\nexport const getSearchInput = (element: HTMLElement): HTMLInputElement | null => element.querySelector<HTMLInputElement>(`input[type=\"search\"]`)"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"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","sourcesContent":["export const uuid = () => {\n if (typeof window !== 'undefined') {\n if (window.crypto?.randomUUID) {\n return window.crypto.randomUUID();\n } else if (window.crypto?.getRandomValues) {\n return window.crypto.getRandomValues(new Uint32Array(3)).join('-');\n }\n }\n return Math.random().toString().substring(2);\n};\nexport const addAttributeToChildren = (element: Element, attribute: {\n key: string;\n value: string;\n}) => {\n const children = element.children;\n Object.values(children).forEach((child: Element) => {\n child.setAttribute(attribute.key, attribute.value);\n if (child.children.length > 0) {\n addAttributeToChildren(child, attribute);\n }\n });\n};\nexport type ClassNameArg = string | {\n [key: string]: boolean | undefined;\n} | undefined;\nexport const cls = (...args: ClassNameArg[]) => {\n let result = '';\n for (const arg of args) {\n if (arg) {\n if (typeof arg === 'string') {\n result += `${arg} `;\n } else {\n for (const key in arg) {\n if (arg[key]) {\n result += `${key} `;\n }\n }\n }\n }\n }\n return result.trim();\n};\nexport const isArrayOfStrings = (value: unknown): value is string[] => Array.isArray(value) && value.every(item => typeof item === 'string');\nconst appleOs = ['Mac', 'iPhone', 'iPad', 'iPod'];\nexport const hasVoiceOver = (): boolean => typeof window !== 'undefined' && appleOs.some(os => window.navigator.userAgent.includes(os));\nexport const delay = (fn: () => void, ms: number) => new Promise(() => setTimeout(fn, ms));\n\n/**\n * Some frameworks like stencil would not add \"true\" as value for a prop\n * if it is used in a framework like angular e.g.: [disabled]=\"myDisabledProp\"\n * @param originBool Some boolean to convert to string\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const getBooleanAsString = (originBool?: boolean | string): any => {\n if (originBool === undefined || originBool === null) return;\n if (typeof originBool === 'string') {\n return String(Boolean(originBool));\n }\n return String(originBool);\n};\nexport const getBoolean = (originBool?: boolean | string, propertyName?: string): boolean | undefined => {\n if (originBool === undefined || originBool === null) return;\n if (typeof originBool === 'string' && propertyName) {\n return Boolean(propertyName === originBool || originBool);\n }\n return Boolean(originBool);\n};\nexport const getNumber = (originNumber?: number | string, alternativeNumber?: number | string): number | undefined => {\n if ((originNumber === undefined || originNumber === null) && (alternativeNumber === undefined || alternativeNumber === null)) {\n return;\n }\n return Number(originNumber ?? alternativeNumber);\n};\n\n/**\n * Retrieves the input value based on the provided value and input type.\n *\n * If the input type is \"number\" or \"range\", the value is processed as a number.\n * Otherwise, the value is returned as-is.\n *\n * @param value - The input value, which can be a number, string, or undefined.\n * @param inputType - The type of the input, such as \"number\", \"range\", or other string types.\n * @returns The processed input value as a string, number, or undefined.\n */\nexport const getInputValue = (value?: number | string, inputType?: string): string | number | undefined => {\n return inputType && ['number', 'range'].includes(inputType) ? getNumber(value) : value;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const getHideProp = (show?: boolean | string): any => {\n if (show === undefined || show === null) {\n return undefined;\n }\n return getBooleanAsString(!Boolean(show));\n};\nexport const stringPropVisible = (givenString?: string, showString?: boolean | string) => {\n if (showString === undefined) {\n return !!givenString;\n } else {\n return Boolean(showString) && Boolean(givenString);\n }\n};\nexport const getSearchInput = (element: HTMLElement): HTMLInputElement | null => element.querySelector<HTMLInputElement>(`input[type=\"search\"]`);\nexport const getOptionKey = (option: {\n id?: string;\n value?: string | number | string[] | undefined;\n}, prefix: string) => {\n const key = option.id ?? option.value ?? uuid();\n return `${prefix}${key}`;\n}"]}
@@ -1,4 +1,4 @@
1
- import { handleDataOutside } from "./index";
1
+ import { handleDataOutside } from "./floating-components";
2
2
  export const isEventTargetNavigationItem = (event) => {
3
3
  var _a, _b;
4
4
  const { target } = event;
@@ -1 +1 @@
1
- {"version":3,"file":"navigation.js","sourceRoot":"","sources":["../../src/utils/navigation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAS5C,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAAC,KAAc,EAAW,EAAE;;IACrE,MAAM,EACJ,MAAM,EACP,GAAG,KAEH,CAAC;IACF,OAAO,OAAO,CAAC,CAAC,CAAA,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,SAAS,0CAAE,QAAQ,CAAC,kCAAkC,CAAC,CAAA,KAAI,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,aAAa,0CAAE,SAAS,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAA,CAAC,CAAC;AACtJ,CAAC,CAAC;AACF,MAAM,OAAO,0BAA0B;IAQrC,YAAY,OAA2B,EAAE,aAA6B;;QALrD,wBAAmB,GAAmB,IAAI,CAAC;QAEpD,gBAAW,GAAY,KAAK,CAAC;QAC7B,WAAM,GAAW,CAAC,CAAC;QACnB,WAAM,GAAW,CAAC,CAAC;QAEzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QACnC,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACzC,OAAO;QACT,CAAC;QACD,IAAI,CAAC,mBAAmB,GAAG,MAAA,IAAI,CAAC,OAAO,0CAAE,OAAO,CAAC,oBAAoB,CAAC,CAAC;QAEvE;;;;WAIG;QACH,IAAI,IAAI,CAAC,mBAAmB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC;YACpE,IAAI,CAAC,IAAI,EAAE,CAAC;QACd,CAAC;IACH,CAAC;IACO,IAAI;;QACV,MAAM,kBAAkB,GAAG,MAAA,MAAA,IAAI,CAAC,mBAAmB,0CAAE,qBAAqB,GAAG,KAAK,mCAAI,CAAC,CAAC;QAExF,mFAAmF;QACnF,6EAA6E;QAC7E,MAAA,IAAI,CAAC,OAAO,0CAAE,KAAK,CAAC,WAAW,CAAC,kCAAkC,EAAE,GAAG,kBAAkB,IAAI,CAAC,CAAC;QAC/F,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IACM,YAAY;;QACjB,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACnF,OAAO;QACT,CAAC;QACD,MAAM,eAAe,GAAG,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC9D,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC;QACtD,MAAM,kBAAkB,GAAG,MAAA,MAAA,IAAI,CAAC,mBAAmB,0CAAE,qBAAqB,GAAG,KAAK,mCAAI,CAAC,CAAC;QACxF,IAAI,CAAC,YAAY,GAAG;YAClB,QAAQ;YACR,kBAAkB;YAClB,mBAAmB,EAAE,IAAI,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,MAAM;YACtE,OAAO,EAAE,CAAC,kBAAkB,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC;YAClD,SAAS,EAAE,eAAe,CAAC,EAAE;YAC7B,SAAS,EAAE,eAAe,CAAC,EAAE;SAC9B,CAAC;IACJ,CAAC;IACM,aAAa;QAClB,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;IAChC,CAAC;IACO,eAAe;QACrB,IAAI,CAAC,IAAI,CAAC,YAAY;YAAE,OAAO,CAAC,CAAC;QACjC,IAAI,IAAI,CAAC,YAAY,CAAC,SAAS,KAAK,OAAO,EAAE,CAAC;YAC5C,oDAAoD;YACpD,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;QACxD,CAAC;QAED,0CAA0C;QAC1C,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;IACxE,CAAC;IACO,eAAe;QACrB,IAAI,CAAC,IAAI,CAAC,YAAY;YAAE,OAAO,CAAC,CAAC;QAEjC,qFAAqF;QACrF,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;QACxH,IAAI,IAAI,CAAC,YAAY,CAAC,SAAS,KAAK,QAAQ,EAAE,CAAC;YAC7C,kEAAkE;YAClE,OAAO,aAAa,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QACrI,CAAC;QACD,OAAO,aAAa,CAAC;IACvB,CAAC;IACO,4BAA4B;QAClC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,OAAO,KAAK,CAAC;QACf,CAAC;QACD,MAAM,yBAAyB,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,KAAK,OAAO,CAAC;QAC1E,IAAI,yBAAyB,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;YAC9E,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,CAAC,yBAAyB,IAAI,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;YACjH,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACO,sBAAsB,CAAC,OAAqC;QAMlE,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,OAAO;QACT,CAAC;QACD,IAAI,OAAO,KAAK,UAAU,EAAE,CAAC;YAC3B,MAAM,UAAU,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,IAAI,CAAC;YAC5F,MAAM,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,IAAI,CAAC;YACvF,OAAO;gBACL,EAAE,EAAE,GAAG,MAAM,IAAI,UAAU,EAAE;gBAC7B,EAAE,EAAE,GAAG,MAAM,IAAI;gBACjB,EAAE,EAAE,QAAQ;gBACZ,EAAE,EAAE,QAAQ,UAAU,EAAE;aACzB,CAAC;QACJ,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACpC,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACpC,MAAM,EAAE,GAAG,GAAG,IAAI,MAAM,IAAI,IAAI,CAAC;QACjC,MAAM,EAAE,GAAG,GAAG,IAAI,MAAM,IAAI,IAAI,CAAC;QACjC,OAAO;YACL,EAAE;YACF,EAAE;YACF,EAAE,EAAE,QAAQ;YACZ,EAAE,EAAE,WAAW;SAChB,CAAC;IACJ,CAAC;IACM,kBAAkB,CAAC,KAAiB;QACzC,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACpF,OAAO;QACT,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC;QAC9D,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC;QAC7D,MAAM,mBAAmB,GAAG,IAAI,CAAC,4BAA4B,EAAE,CAAC;QAChE,MAAM,WAAW,GAAG,IAAI,CAAC,sBAAsB,CAAC,mBAAmB,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QACpG,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,OAAO;QACT,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,gCAAgC,EAAE,WAAW,WAAW,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE,GAAG,CAAC,CAAC;QACxJ,IAAI,mBAAmB,EAAE,CAAC;YACxB,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;QAChC,CAAC;IACH,CAAC;CACF;AACD,eAAe;IACb,2BAA2B;IAC3B,0BAA0B;CAC3B,CAAA","sourcesContent":["import { handleDataOutside } from './index';\nexport type TriangleData = {\n itemRect: DOMRect;\n parentElementWidth: number;\n subNavigationHeight: number;\n padding: number;\n outsideVX: 'left' | 'right' | undefined;\n outsideVY: 'top' | 'bottom' | undefined;\n};\nexport const isEventTargetNavigationItem = (event: unknown): boolean => {\n const {\n target\n } = event as {\n target: HTMLElement;\n };\n return Boolean(!target?.classList?.contains('db-navigation-item-expand-button') && target?.parentElement?.classList.contains('db-navigation-item'));\n};\nexport class NavigationItemSafeTriangle {\n private readonly element: HTMLElement | null;\n private readonly subNavigation: Element | null;\n private readonly parentSubNavigation: Element | null = null;\n private triangleData?: TriangleData;\n private initialized: boolean = false;\n private mouseX: number = 0;\n private mouseY: number = 0;\n constructor(element: HTMLElement | null, subNavigation: Element | null) {\n this.element = element;\n this.subNavigation = subNavigation;\n if (!this.element || !this.subNavigation) {\n return;\n }\n this.parentSubNavigation = this.element?.closest('.db-sub-navigation');\n\n /*\n * only initiate if:\n * 1. item is not at root navigation level\n * 2. item is not in the mobile navigation / within db-drawer\n */\n if (this.parentSubNavigation && !this.element.closest('.db-drawer')) {\n this.init();\n }\n }\n private init() {\n const parentElementWidth = this.parentSubNavigation?.getBoundingClientRect().width ?? 0;\n\n // the triangle has the width of the sub-navigation, current nav-item can be wider.\n // so the width of the triangle must be adapted to a possibly wider nav-item.\n this.element?.style.setProperty('--db-navigation-item-inline-size', `${parentElementWidth}px`);\n this.initialized = true;\n }\n public enableFollow() {\n if (!this.initialized || this.triangleData || !this.element || !this.subNavigation) {\n return;\n }\n const dataOutsidePair = handleDataOutside(this.subNavigation);\n const itemRect = this.element.getBoundingClientRect();\n const parentElementWidth = this.parentSubNavigation?.getBoundingClientRect().width ?? 0;\n this.triangleData = {\n itemRect,\n parentElementWidth,\n subNavigationHeight: this.subNavigation.getBoundingClientRect().height,\n padding: (parentElementWidth - itemRect.width) / 2,\n outsideVX: dataOutsidePair.vx,\n outsideVY: dataOutsidePair.vy\n };\n }\n public disableFollow() {\n this.triangleData = undefined;\n }\n private getTriangleTipX(): number {\n if (!this.triangleData) return 0;\n if (this.triangleData.outsideVX === 'right') {\n // vertical flipped triangle needs an inverted x pos\n return this.triangleData.itemRect.width - this.mouseX;\n }\n\n // triangle stops shrinking from 75% x pos\n return Math.min(this.mouseX, this.triangleData.itemRect.width * 0.75);\n }\n private getTriangleTipY(): number {\n if (!this.triangleData) return 0;\n\n // padding must be added to the y pos of the tip so that the y pos matches the cursor\n const mouseYLimited = Math.max(Math.min(this.mouseY, this.triangleData.itemRect.height), 0) + this.triangleData.padding;\n if (this.triangleData.outsideVY === 'bottom') {\n // add offset to tip y pos to match corrected sub-navigation y pos\n return mouseYLimited + (this.triangleData.subNavigationHeight - this.triangleData.padding * 2 - this.triangleData.itemRect.height);\n }\n return mouseYLimited;\n }\n private hasMouseEnteredSubNavigation(): boolean {\n if (!this.triangleData) {\n return false;\n }\n const isSubNavigationOnLeftSide = this.triangleData.outsideVX === 'right';\n if (isSubNavigationOnLeftSide && this.mouseX < -1 * this.triangleData.padding) {\n return true;\n }\n if (!isSubNavigationOnLeftSide && this.mouseX > this.triangleData.parentElementWidth - this.triangleData.padding) {\n return true;\n }\n return false;\n }\n private getTriangleCoordinates(variant: 'safe-triangle' | 'fill-gap'): undefined | {\n lb: string;\n lt: string;\n rt: string;\n rb: string;\n } {\n if (!this.triangleData) {\n return;\n }\n if (variant === 'fill-gap') {\n const itemHeight = `${this.triangleData.itemRect.height + 2 * this.triangleData.padding}px`;\n const xStart = `${this.triangleData.parentElementWidth - this.triangleData.padding}px`;\n return {\n lb: `${xStart} ${itemHeight}`,\n lt: `${xStart} 0`,\n rt: '100% 0',\n rb: `100% ${itemHeight}`\n };\n }\n const tipX = this.getTriangleTipX();\n const tipY = this.getTriangleTipY();\n const lb = `${tipX}px ${tipY}px`;\n const lt = `${tipX}px ${tipY}px`;\n return {\n lb,\n lt,\n rt: '100% 0',\n rb: '100% 100%'\n };\n }\n public followByMouseEvent(event: MouseEvent) {\n if (!this.initialized || !this.triangleData || !this.element || !this.subNavigation) {\n return;\n }\n this.mouseX = event.clientX - this.triangleData.itemRect.left;\n this.mouseY = event.clientY - this.triangleData.itemRect.top;\n const isOverSubNavigation = this.hasMouseEnteredSubNavigation();\n const coordinates = this.getTriangleCoordinates(isOverSubNavigation ? 'fill-gap' : 'safe-triangle');\n if (!coordinates) {\n return;\n }\n this.element.style.setProperty('--db-navigation-item-clip-path', `polygon(${coordinates.lb}, ${coordinates.lt}, ${coordinates.rt}, ${coordinates.rb})`);\n if (isOverSubNavigation) {\n this.triangleData = undefined;\n }\n }\n}\nexport default {\n isEventTargetNavigationItem,\n NavigationItemSafeTriangle\n}"]}
1
+ {"version":3,"file":"navigation.js","sourceRoot":"","sources":["../../src/utils/navigation.ts"],"names":[],"mappings":"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","sourcesContent":["import { handleDataOutside } from './floating-components';\nexport type TriangleData = {\n itemRect: DOMRect;\n parentElementWidth: number;\n subNavigationHeight: number;\n padding: number;\n outsideVX: 'left' | 'right' | undefined;\n outsideVY: 'top' | 'bottom' | undefined;\n};\nexport const isEventTargetNavigationItem = (event: unknown): boolean => {\n const {\n target\n } = event as {\n target: HTMLElement;\n };\n return Boolean(!target?.classList?.contains('db-navigation-item-expand-button') && target?.parentElement?.classList.contains('db-navigation-item'));\n};\nexport class NavigationItemSafeTriangle {\n private readonly element: HTMLElement | null;\n private readonly subNavigation: HTMLElement | null;\n private readonly parentSubNavigation: HTMLElement | null = null;\n private triangleData?: TriangleData;\n private initialized: boolean = false;\n private mouseX: number = 0;\n private mouseY: number = 0;\n constructor(element: HTMLElement | null, subNavigation: HTMLElement | null) {\n this.element = element;\n this.subNavigation = subNavigation;\n if (!this.element || !this.subNavigation) {\n return;\n }\n this.parentSubNavigation = this.element?.closest('.db-sub-navigation');\n\n /*\n * only initiate if:\n * 1. item is not at root navigation level\n * 2. item is not in the mobile navigation / within db-drawer\n */\n if (this.parentSubNavigation && !this.element.closest('.db-drawer')) {\n this.init();\n }\n }\n private init() {\n const parentElementWidth = this.parentSubNavigation?.getBoundingClientRect().width ?? 0;\n\n // the triangle has the width of the sub-navigation, current nav-item can be wider.\n // so the width of the triangle must be adapted to a possibly wider nav-item.\n this.element?.style.setProperty('--db-navigation-item-inline-size', `${parentElementWidth}px`);\n this.initialized = true;\n }\n public enableFollow() {\n if (!this.initialized || this.triangleData || !this.element || !this.subNavigation) {\n return;\n }\n const dataOutsidePair = handleDataOutside(this.subNavigation);\n const itemRect = this.element.getBoundingClientRect();\n const parentElementWidth = this.parentSubNavigation?.getBoundingClientRect().width ?? 0;\n this.triangleData = {\n itemRect,\n parentElementWidth,\n subNavigationHeight: this.subNavigation.getBoundingClientRect().height,\n padding: (parentElementWidth - itemRect.width) / 2,\n outsideVX: dataOutsidePair.vx,\n outsideVY: dataOutsidePair.vy\n };\n }\n public disableFollow() {\n this.triangleData = undefined;\n }\n private getTriangleTipX(): number {\n if (!this.triangleData) return 0;\n if (this.triangleData.outsideVX === 'right') {\n // vertical flipped triangle needs an inverted x pos\n return this.triangleData.itemRect.width - this.mouseX;\n }\n\n // triangle stops shrinking from 75% x pos\n return Math.min(this.mouseX, this.triangleData.itemRect.width * 0.75);\n }\n private getTriangleTipY(): number {\n if (!this.triangleData) return 0;\n\n // padding must be added to the y pos of the tip so that the y pos matches the cursor\n const mouseYLimited = Math.max(Math.min(this.mouseY, this.triangleData.itemRect.height), 0) + this.triangleData.padding;\n if (this.triangleData.outsideVY === 'bottom') {\n // add offset to tip y pos to match corrected sub-navigation y pos\n return mouseYLimited + (this.triangleData.subNavigationHeight - this.triangleData.padding * 2 - this.triangleData.itemRect.height);\n }\n return mouseYLimited;\n }\n private hasMouseEnteredSubNavigation(): boolean {\n if (!this.triangleData) {\n return false;\n }\n const isSubNavigationOnLeftSide = this.triangleData.outsideVX === 'right';\n if (isSubNavigationOnLeftSide && this.mouseX < -1 * this.triangleData.padding) {\n return true;\n }\n if (!isSubNavigationOnLeftSide && this.mouseX > this.triangleData.parentElementWidth - this.triangleData.padding) {\n return true;\n }\n return false;\n }\n private getTriangleCoordinates(variant: 'safe-triangle' | 'fill-gap'): undefined | {\n lb: string;\n lt: string;\n rt: string;\n rb: string;\n } {\n if (!this.triangleData) {\n return;\n }\n if (variant === 'fill-gap') {\n const itemHeight = `${this.triangleData.itemRect.height + 2 * this.triangleData.padding}px`;\n const xStart = `${this.triangleData.parentElementWidth - this.triangleData.padding}px`;\n return {\n lb: `${xStart} ${itemHeight}`,\n lt: `${xStart} 0`,\n rt: '100% 0',\n rb: `100% ${itemHeight}`\n };\n }\n const tipX = this.getTriangleTipX();\n const tipY = this.getTriangleTipY();\n const lb = `${tipX}px ${tipY}px`;\n const lt = `${tipX}px ${tipY}px`;\n return {\n lb,\n lt,\n rt: '100% 0',\n rb: '100% 100%'\n };\n }\n public followByMouseEvent(event: MouseEvent) {\n if (!this.initialized || !this.triangleData || !this.element || !this.subNavigation) {\n return;\n }\n this.mouseX = event.clientX - this.triangleData.itemRect.left;\n this.mouseY = event.clientY - this.triangleData.itemRect.top;\n const isOverSubNavigation = this.hasMouseEnteredSubNavigation();\n const coordinates = this.getTriangleCoordinates(isOverSubNavigation ? 'fill-gap' : 'safe-triangle');\n if (!coordinates) {\n return;\n }\n this.element.style.setProperty('--db-navigation-item-clip-path', `polygon(${coordinates.lb}, ${coordinates.lt}, ${coordinates.rt}, ${coordinates.rb})`);\n if (isOverSubNavigation) {\n this.triangleData = undefined;\n }\n }\n}\nexport default {\n isEventTargetNavigationItem,\n NavigationItemSafeTriangle\n}"]}