@haiilo/catalyst 0.5.1 → 0.5.3

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 (469) hide show
  1. package/package.json +5 -6
  2. package/dist/catalyst/app-globals-23d8c4a8.js +0 -948
  3. package/dist/catalyst/app-globals-23d8c4a8.js.map +0 -1
  4. package/dist/catalyst/app-globals-3dd6a26b.js +0 -948
  5. package/dist/catalyst/app-globals-3dd6a26b.js.map +0 -1
  6. package/dist/catalyst/app-globals-42ce39cc.js +0 -948
  7. package/dist/catalyst/app-globals-42ce39cc.js.map +0 -1
  8. package/dist/catalyst/app-globals-5cf43b57.js +0 -949
  9. package/dist/catalyst/app-globals-5cf43b57.js.map +0 -1
  10. package/dist/catalyst/app-globals-8598c768.js +0 -948
  11. package/dist/catalyst/app-globals-8598c768.js.map +0 -1
  12. package/dist/catalyst/app-globals-a41af143.js +0 -948
  13. package/dist/catalyst/app-globals-a41af143.js.map +0 -1
  14. package/dist/catalyst/app-globals-c6a8b994.js +0 -949
  15. package/dist/catalyst/app-globals-c6a8b994.js.map +0 -1
  16. package/dist/catalyst/assets/fonts/AzeretMono-Regular.woff2 +0 -0
  17. package/dist/catalyst/assets/fonts/DMSans-Bold.woff2 +0 -0
  18. package/dist/catalyst/assets/fonts/DMSans-BoldItalic.woff2 +0 -0
  19. package/dist/catalyst/assets/fonts/DMSans-Italic.woff2 +0 -0
  20. package/dist/catalyst/assets/fonts/DMSans-Medium.woff2 +0 -0
  21. package/dist/catalyst/assets/fonts/DMSans-MediumItalic.woff2 +0 -0
  22. package/dist/catalyst/assets/fonts/DMSans-Regular.woff2 +0 -0
  23. package/dist/catalyst/assets/fonts/Lato-Black.woff +0 -0
  24. package/dist/catalyst/assets/fonts/Lato-Black.woff2 +0 -0
  25. package/dist/catalyst/assets/fonts/Lato-BlackItalic.woff +0 -0
  26. package/dist/catalyst/assets/fonts/Lato-BlackItalic.woff2 +0 -0
  27. package/dist/catalyst/assets/fonts/Lato-Bold.woff +0 -0
  28. package/dist/catalyst/assets/fonts/Lato-Bold.woff2 +0 -0
  29. package/dist/catalyst/assets/fonts/Lato-BoldItalic.woff +0 -0
  30. package/dist/catalyst/assets/fonts/Lato-BoldItalic.woff2 +0 -0
  31. package/dist/catalyst/assets/fonts/Lato-Hairline.woff +0 -0
  32. package/dist/catalyst/assets/fonts/Lato-Hairline.woff2 +0 -0
  33. package/dist/catalyst/assets/fonts/Lato-HairlineItalic.woff +0 -0
  34. package/dist/catalyst/assets/fonts/Lato-HairlineItalic.woff2 +0 -0
  35. package/dist/catalyst/assets/fonts/Lato-Heavy.woff +0 -0
  36. package/dist/catalyst/assets/fonts/Lato-Heavy.woff2 +0 -0
  37. package/dist/catalyst/assets/fonts/Lato-HeavyItalic.woff +0 -0
  38. package/dist/catalyst/assets/fonts/Lato-HeavyItalic.woff2 +0 -0
  39. package/dist/catalyst/assets/fonts/Lato-Italic.woff +0 -0
  40. package/dist/catalyst/assets/fonts/Lato-Italic.woff2 +0 -0
  41. package/dist/catalyst/assets/fonts/Lato-Light.woff +0 -0
  42. package/dist/catalyst/assets/fonts/Lato-Light.woff2 +0 -0
  43. package/dist/catalyst/assets/fonts/Lato-LightItalic.woff +0 -0
  44. package/dist/catalyst/assets/fonts/Lato-LightItalic.woff2 +0 -0
  45. package/dist/catalyst/assets/fonts/Lato-Medium.woff +0 -0
  46. package/dist/catalyst/assets/fonts/Lato-Medium.woff2 +0 -0
  47. package/dist/catalyst/assets/fonts/Lato-MediumItalic.woff +0 -0
  48. package/dist/catalyst/assets/fonts/Lato-MediumItalic.woff2 +0 -0
  49. package/dist/catalyst/assets/fonts/Lato-Regular.woff +0 -0
  50. package/dist/catalyst/assets/fonts/Lato-Regular.woff2 +0 -0
  51. package/dist/catalyst/assets/fonts/Lato-Semibold.woff +0 -0
  52. package/dist/catalyst/assets/fonts/Lato-Semibold.woff2 +0 -0
  53. package/dist/catalyst/assets/fonts/Lato-SemiboldItalic.woff +0 -0
  54. package/dist/catalyst/assets/fonts/Lato-SemiboldItalic.woff2 +0 -0
  55. package/dist/catalyst/assets/fonts/Lato-Thin.woff +0 -0
  56. package/dist/catalyst/assets/fonts/Lato-Thin.woff2 +0 -0
  57. package/dist/catalyst/assets/fonts/Lato-ThinItalic.woff +0 -0
  58. package/dist/catalyst/assets/fonts/Lato-ThinItalic.woff2 +0 -0
  59. package/dist/catalyst/cat-alert.entry.js +0 -33
  60. package/dist/catalyst/cat-alert.entry.js.map +0 -1
  61. package/dist/catalyst/cat-badge.entry.js +0 -44
  62. package/dist/catalyst/cat-badge.entry.js.map +0 -1
  63. package/dist/catalyst/cat-button.entry.js +0 -298
  64. package/dist/catalyst/cat-button.entry.js.map +0 -1
  65. package/dist/catalyst/cat-card.entry.js +0 -17
  66. package/dist/catalyst/cat-card.entry.js.map +0 -1
  67. package/dist/catalyst/cat-checkbox.entry.js +0 -75
  68. package/dist/catalyst/cat-checkbox.entry.js.map +0 -1
  69. package/dist/catalyst/cat-i18n-registry-2a6187c9.js +0 -75
  70. package/dist/catalyst/cat-i18n-registry-2a6187c9.js.map +0 -1
  71. package/dist/catalyst/cat-i18n-registry-330db605.js +0 -74
  72. package/dist/catalyst/cat-i18n-registry-330db605.js.map +0 -1
  73. package/dist/catalyst/cat-i18n-registry-83d20604.js +0 -74
  74. package/dist/catalyst/cat-i18n-registry-83d20604.js.map +0 -1
  75. package/dist/catalyst/cat-i18n-registry-dd55821d.js +0 -73
  76. package/dist/catalyst/cat-i18n-registry-dd55821d.js.map +0 -1
  77. package/dist/catalyst/cat-i18n-registry-f6560651.js +0 -75
  78. package/dist/catalyst/cat-i18n-registry-f6560651.js.map +0 -1
  79. package/dist/catalyst/cat-icon-registry-2dcfc9fb.js +0 -59
  80. package/dist/catalyst/cat-icon-registry-2dcfc9fb.js.map +0 -1
  81. package/dist/catalyst/cat-icon.entry.js +0 -31
  82. package/dist/catalyst/cat-icon.entry.js.map +0 -1
  83. package/dist/catalyst/cat-input.entry.js +0 -111
  84. package/dist/catalyst/cat-input.entry.js.map +0 -1
  85. package/dist/catalyst/cat-menu.entry.js +0 -850
  86. package/dist/catalyst/cat-menu.entry.js.map +0 -1
  87. package/dist/catalyst/cat-radio.entry.js +0 -66
  88. package/dist/catalyst/cat-radio.entry.js.map +0 -1
  89. package/dist/catalyst/cat-scrollable.entry.js +0 -4522
  90. package/dist/catalyst/cat-scrollable.entry.js.map +0 -1
  91. package/dist/catalyst/cat-skeleton.entry.js +0 -55
  92. package/dist/catalyst/cat-skeleton.entry.js.map +0 -1
  93. package/dist/catalyst/cat-spinner.entry.js +0 -23
  94. package/dist/catalyst/cat-spinner.entry.js.map +0 -1
  95. package/dist/catalyst/cat-textarea.entry.js +0 -87
  96. package/dist/catalyst/cat-textarea.entry.js.map +0 -1
  97. package/dist/catalyst/cat-toggle.entry.js +0 -66
  98. package/dist/catalyst/cat-toggle.entry.js.map +0 -1
  99. package/dist/catalyst/cat-tooltip.entry.js +0 -129
  100. package/dist/catalyst/cat-tooltip.entry.js.map +0 -1
  101. package/dist/catalyst/catalyst.css +0 -2033
  102. package/dist/catalyst/catalyst.esm.js +0 -134
  103. package/dist/catalyst/catalyst.esm.js.map +0 -1
  104. package/dist/catalyst/css-shim-e6dd2538.js +0 -6
  105. package/dist/catalyst/css-shim-e6dd2538.js.map +0 -1
  106. package/dist/catalyst/dom-7fc649b0.js +0 -75
  107. package/dist/catalyst/dom-7fc649b0.js.map +0 -1
  108. package/dist/catalyst/first-tabbable-2d9f9e9a.js +0 -2123
  109. package/dist/catalyst/first-tabbable-2d9f9e9a.js.map +0 -1
  110. package/dist/catalyst/index-471d4e05.js +0 -3059
  111. package/dist/catalyst/index-471d4e05.js.map +0 -1
  112. package/dist/catalyst/index-bbb694f5.js +0 -3059
  113. package/dist/catalyst/index-bbb694f5.js.map +0 -1
  114. package/dist/catalyst/index.cdn.js +0 -21
  115. package/dist/catalyst/index.esm.js +0 -5
  116. package/dist/catalyst/index.esm.js.map +0 -1
  117. package/dist/catalyst/loglevel-7f0f71af.js +0 -346
  118. package/dist/catalyst/loglevel-7f0f71af.js.map +0 -1
  119. package/dist/catalyst/shadow-css-4d56fa31.js +0 -390
  120. package/dist/catalyst/shadow-css-4d56fa31.js.map +0 -1
  121. package/dist/cjs/app-globals-aaefc070.js +0 -950
  122. package/dist/cjs/app-globals-aaefc070.js.map +0 -1
  123. package/dist/cjs/cat-alert.cjs.entry.js +0 -37
  124. package/dist/cjs/cat-alert.cjs.entry.js.map +0 -1
  125. package/dist/cjs/cat-badge.cjs.entry.js +0 -48
  126. package/dist/cjs/cat-badge.cjs.entry.js.map +0 -1
  127. package/dist/cjs/cat-button.cjs.entry.js +0 -302
  128. package/dist/cjs/cat-button.cjs.entry.js.map +0 -1
  129. package/dist/cjs/cat-card.cjs.entry.js +0 -21
  130. package/dist/cjs/cat-card.cjs.entry.js.map +0 -1
  131. package/dist/cjs/cat-checkbox.cjs.entry.js +0 -79
  132. package/dist/cjs/cat-checkbox.cjs.entry.js.map +0 -1
  133. package/dist/cjs/cat-i18n-registry-a1379d1e.js +0 -76
  134. package/dist/cjs/cat-i18n-registry-a1379d1e.js.map +0 -1
  135. package/dist/cjs/cat-icon-registry-74247389.js +0 -61
  136. package/dist/cjs/cat-icon-registry-74247389.js.map +0 -1
  137. package/dist/cjs/cat-icon.cjs.entry.js +0 -35
  138. package/dist/cjs/cat-icon.cjs.entry.js.map +0 -1
  139. package/dist/cjs/cat-input.cjs.entry.js +0 -115
  140. package/dist/cjs/cat-input.cjs.entry.js.map +0 -1
  141. package/dist/cjs/cat-menu.cjs.entry.js +0 -854
  142. package/dist/cjs/cat-menu.cjs.entry.js.map +0 -1
  143. package/dist/cjs/cat-radio.cjs.entry.js +0 -70
  144. package/dist/cjs/cat-radio.cjs.entry.js.map +0 -1
  145. package/dist/cjs/cat-scrollable.cjs.entry.js +0 -4526
  146. package/dist/cjs/cat-scrollable.cjs.entry.js.map +0 -1
  147. package/dist/cjs/cat-skeleton.cjs.entry.js +0 -59
  148. package/dist/cjs/cat-skeleton.cjs.entry.js.map +0 -1
  149. package/dist/cjs/cat-spinner.cjs.entry.js +0 -27
  150. package/dist/cjs/cat-spinner.cjs.entry.js.map +0 -1
  151. package/dist/cjs/cat-textarea.cjs.entry.js +0 -91
  152. package/dist/cjs/cat-textarea.cjs.entry.js.map +0 -1
  153. package/dist/cjs/cat-toggle.cjs.entry.js +0 -70
  154. package/dist/cjs/cat-toggle.cjs.entry.js.map +0 -1
  155. package/dist/cjs/cat-tooltip.cjs.entry.js +0 -133
  156. package/dist/cjs/cat-tooltip.cjs.entry.js.map +0 -1
  157. package/dist/cjs/catalyst.cjs.js +0 -136
  158. package/dist/cjs/catalyst.cjs.js.map +0 -1
  159. package/dist/cjs/css-shim-6ca600c2.js +0 -8
  160. package/dist/cjs/css-shim-6ca600c2.js.map +0 -1
  161. package/dist/cjs/dom-8d415461.js +0 -77
  162. package/dist/cjs/dom-8d415461.js.map +0 -1
  163. package/dist/cjs/first-tabbable-2068dcc6.js +0 -2133
  164. package/dist/cjs/first-tabbable-2068dcc6.js.map +0 -1
  165. package/dist/cjs/index-abcb3941.js +0 -3094
  166. package/dist/cjs/index-abcb3941.js.map +0 -1
  167. package/dist/cjs/index.cjs.js +0 -14
  168. package/dist/cjs/index.cjs.js.map +0 -1
  169. package/dist/cjs/loader.cjs.js +0 -42
  170. package/dist/cjs/loader.cjs.js.map +0 -1
  171. package/dist/cjs/loglevel-24040e9d.js +0 -348
  172. package/dist/cjs/loglevel-24040e9d.js.map +0 -1
  173. package/dist/cjs/shadow-css-78860e39.js +0 -392
  174. package/dist/cjs/shadow-css-78860e39.js.map +0 -1
  175. package/dist/collection/assets/fonts/AzeretMono-Regular.woff2 +0 -0
  176. package/dist/collection/assets/fonts/DMSans-Bold.woff2 +0 -0
  177. package/dist/collection/assets/fonts/DMSans-BoldItalic.woff2 +0 -0
  178. package/dist/collection/assets/fonts/DMSans-Italic.woff2 +0 -0
  179. package/dist/collection/assets/fonts/DMSans-Medium.woff2 +0 -0
  180. package/dist/collection/assets/fonts/DMSans-MediumItalic.woff2 +0 -0
  181. package/dist/collection/assets/fonts/DMSans-Regular.woff2 +0 -0
  182. package/dist/collection/assets/fonts/Lato-Black.woff +0 -0
  183. package/dist/collection/assets/fonts/Lato-Black.woff2 +0 -0
  184. package/dist/collection/assets/fonts/Lato-BlackItalic.woff +0 -0
  185. package/dist/collection/assets/fonts/Lato-BlackItalic.woff2 +0 -0
  186. package/dist/collection/assets/fonts/Lato-Bold.woff +0 -0
  187. package/dist/collection/assets/fonts/Lato-Bold.woff2 +0 -0
  188. package/dist/collection/assets/fonts/Lato-BoldItalic.woff +0 -0
  189. package/dist/collection/assets/fonts/Lato-BoldItalic.woff2 +0 -0
  190. package/dist/collection/assets/fonts/Lato-Hairline.woff +0 -0
  191. package/dist/collection/assets/fonts/Lato-Hairline.woff2 +0 -0
  192. package/dist/collection/assets/fonts/Lato-HairlineItalic.woff +0 -0
  193. package/dist/collection/assets/fonts/Lato-HairlineItalic.woff2 +0 -0
  194. package/dist/collection/assets/fonts/Lato-Heavy.woff +0 -0
  195. package/dist/collection/assets/fonts/Lato-Heavy.woff2 +0 -0
  196. package/dist/collection/assets/fonts/Lato-HeavyItalic.woff +0 -0
  197. package/dist/collection/assets/fonts/Lato-HeavyItalic.woff2 +0 -0
  198. package/dist/collection/assets/fonts/Lato-Italic.woff +0 -0
  199. package/dist/collection/assets/fonts/Lato-Italic.woff2 +0 -0
  200. package/dist/collection/assets/fonts/Lato-Light.woff +0 -0
  201. package/dist/collection/assets/fonts/Lato-Light.woff2 +0 -0
  202. package/dist/collection/assets/fonts/Lato-LightItalic.woff +0 -0
  203. package/dist/collection/assets/fonts/Lato-LightItalic.woff2 +0 -0
  204. package/dist/collection/assets/fonts/Lato-Medium.woff +0 -0
  205. package/dist/collection/assets/fonts/Lato-Medium.woff2 +0 -0
  206. package/dist/collection/assets/fonts/Lato-MediumItalic.woff +0 -0
  207. package/dist/collection/assets/fonts/Lato-MediumItalic.woff2 +0 -0
  208. package/dist/collection/assets/fonts/Lato-Regular.woff +0 -0
  209. package/dist/collection/assets/fonts/Lato-Regular.woff2 +0 -0
  210. package/dist/collection/assets/fonts/Lato-Semibold.woff +0 -0
  211. package/dist/collection/assets/fonts/Lato-Semibold.woff2 +0 -0
  212. package/dist/collection/assets/fonts/Lato-SemiboldItalic.woff +0 -0
  213. package/dist/collection/assets/fonts/Lato-SemiboldItalic.woff2 +0 -0
  214. package/dist/collection/assets/fonts/Lato-Thin.woff +0 -0
  215. package/dist/collection/assets/fonts/Lato-Thin.woff2 +0 -0
  216. package/dist/collection/assets/fonts/Lato-ThinItalic.woff +0 -0
  217. package/dist/collection/assets/fonts/Lato-ThinItalic.woff2 +0 -0
  218. package/dist/collection/collection-manifest.json +0 -27
  219. package/dist/collection/components/cat-alert/cat-alert.css +0 -62
  220. package/dist/collection/components/cat-alert/cat-alert.js +0 -61
  221. package/dist/collection/components/cat-alert/cat-alert.js.map +0 -1
  222. package/dist/collection/components/cat-badge/cat-badge.css +0 -154
  223. package/dist/collection/components/cat-badge/cat-badge.js +0 -143
  224. package/dist/collection/components/cat-badge/cat-badge.js.map +0 -1
  225. package/dist/collection/components/cat-button/cat-button.css +0 -333
  226. package/dist/collection/components/cat-button/cat-button.js +0 -615
  227. package/dist/collection/components/cat-button/cat-button.js.map +0 -1
  228. package/dist/collection/components/cat-card/cat-card.css +0 -25
  229. package/dist/collection/components/cat-card/cat-card.js +0 -20
  230. package/dist/collection/components/cat-card/cat-card.js.map +0 -1
  231. package/dist/collection/components/cat-checkbox/cat-checkbox.css +0 -105
  232. package/dist/collection/components/cat-checkbox/cat-checkbox.js +0 -314
  233. package/dist/collection/components/cat-checkbox/cat-checkbox.js.map +0 -1
  234. package/dist/collection/components/cat-i18n/cat-i18n-registry.js +0 -70
  235. package/dist/collection/components/cat-i18n/cat-i18n-registry.js.map +0 -1
  236. package/dist/collection/components/cat-icon/cat-icon-registry.js +0 -55
  237. package/dist/collection/components/cat-icon/cat-icon-registry.js.map +0 -1
  238. package/dist/collection/components/cat-icon/cat-icon.css +0 -50
  239. package/dist/collection/components/cat-icon/cat-icon.js +0 -91
  240. package/dist/collection/components/cat-icon/cat-icon.js.map +0 -1
  241. package/dist/collection/components/cat-input/cat-input.css +0 -131
  242. package/dist/collection/components/cat-input/cat-input.js +0 -606
  243. package/dist/collection/components/cat-input/cat-input.js.map +0 -1
  244. package/dist/collection/components/cat-menu/cat-menu.css +0 -34
  245. package/dist/collection/components/cat-menu/cat-menu.js +0 -184
  246. package/dist/collection/components/cat-menu/cat-menu.js.map +0 -1
  247. package/dist/collection/components/cat-radio/cat-radio.css +0 -84
  248. package/dist/collection/components/cat-radio/cat-radio.js +0 -283
  249. package/dist/collection/components/cat-radio/cat-radio.js.map +0 -1
  250. package/dist/collection/components/cat-scrollable/cat-scrollable.css +0 -69
  251. package/dist/collection/components/cat-scrollable/cat-scrollable.js +0 -311
  252. package/dist/collection/components/cat-scrollable/cat-scrollable.js.map +0 -1
  253. package/dist/collection/components/cat-skeleton/cat-skeleton.css +0 -177
  254. package/dist/collection/components/cat-skeleton/cat-skeleton.js +0 -131
  255. package/dist/collection/components/cat-skeleton/cat-skeleton.js.map +0 -1
  256. package/dist/collection/components/cat-spinner/cat-spinner.css +0 -63
  257. package/dist/collection/components/cat-spinner/cat-spinner.js +0 -65
  258. package/dist/collection/components/cat-spinner/cat-spinner.js.map +0 -1
  259. package/dist/collection/components/cat-textarea/cat-textarea.css +0 -74
  260. package/dist/collection/components/cat-textarea/cat-textarea.js +0 -393
  261. package/dist/collection/components/cat-textarea/cat-textarea.js.map +0 -1
  262. package/dist/collection/components/cat-toggle/cat-toggle.css +0 -93
  263. package/dist/collection/components/cat-toggle/cat-toggle.js +0 -283
  264. package/dist/collection/components/cat-toggle/cat-toggle.js.map +0 -1
  265. package/dist/collection/components/cat-tooltip/cat-tooltip.css +0 -41
  266. package/dist/collection/components/cat-tooltip/cat-tooltip.js +0 -254
  267. package/dist/collection/components/cat-tooltip/cat-tooltip.js.map +0 -1
  268. package/dist/collection/index.cdn.js +0 -21
  269. package/dist/collection/index.js +0 -3
  270. package/dist/collection/index.js.map +0 -1
  271. package/dist/collection/init.js +0 -17
  272. package/dist/collection/init.js.map +0 -1
  273. package/dist/collection/utils/breakpoints.js +0 -12
  274. package/dist/collection/utils/breakpoints.js.map +0 -1
  275. package/dist/collection/utils/first-tabbable.js +0 -6
  276. package/dist/collection/utils/first-tabbable.js.map +0 -1
  277. package/dist/collection/utils/is-touch-screen.js +0 -3
  278. package/dist/collection/utils/is-touch-screen.js.map +0 -1
  279. package/dist/collection/utils/media-matcher.js +0 -55
  280. package/dist/collection/utils/media-matcher.js.map +0 -1
  281. package/dist/collection/utils/platform.js +0 -50
  282. package/dist/collection/utils/platform.js.map +0 -1
  283. package/dist/components/cat-alert.d.ts +0 -11
  284. package/dist/components/cat-alert.js +0 -53
  285. package/dist/components/cat-alert.js.map +0 -1
  286. package/dist/components/cat-badge.d.ts +0 -11
  287. package/dist/components/cat-badge.js +0 -68
  288. package/dist/components/cat-badge.js.map +0 -1
  289. package/dist/components/cat-button.d.ts +0 -11
  290. package/dist/components/cat-button.js +0 -8
  291. package/dist/components/cat-button.js.map +0 -1
  292. package/dist/components/cat-button2.js +0 -346
  293. package/dist/components/cat-button2.js.map +0 -1
  294. package/dist/components/cat-card.d.ts +0 -11
  295. package/dist/components/cat-card.js +0 -35
  296. package/dist/components/cat-card.js.map +0 -1
  297. package/dist/components/cat-checkbox.d.ts +0 -11
  298. package/dist/components/cat-checkbox.js +0 -103
  299. package/dist/components/cat-checkbox.js.map +0 -1
  300. package/dist/components/cat-i18n-registry.js +0 -74
  301. package/dist/components/cat-i18n-registry.js.map +0 -1
  302. package/dist/components/cat-icon-registry.js +0 -59
  303. package/dist/components/cat-icon-registry.js.map +0 -1
  304. package/dist/components/cat-icon.d.ts +0 -11
  305. package/dist/components/cat-icon.js +0 -8
  306. package/dist/components/cat-icon.js.map +0 -1
  307. package/dist/components/cat-icon2.js +0 -49
  308. package/dist/components/cat-icon2.js.map +0 -1
  309. package/dist/components/cat-input.d.ts +0 -11
  310. package/dist/components/cat-input.js +0 -172
  311. package/dist/components/cat-input.js.map +0 -1
  312. package/dist/components/cat-menu.d.ts +0 -11
  313. package/dist/components/cat-menu.js +0 -870
  314. package/dist/components/cat-menu.js.map +0 -1
  315. package/dist/components/cat-radio.d.ts +0 -11
  316. package/dist/components/cat-radio.js +0 -93
  317. package/dist/components/cat-radio.js.map +0 -1
  318. package/dist/components/cat-scrollable.d.ts +0 -11
  319. package/dist/components/cat-scrollable.js +0 -4548
  320. package/dist/components/cat-scrollable.js.map +0 -1
  321. package/dist/components/cat-skeleton.d.ts +0 -11
  322. package/dist/components/cat-skeleton.js +0 -78
  323. package/dist/components/cat-skeleton.js.map +0 -1
  324. package/dist/components/cat-spinner.d.ts +0 -11
  325. package/dist/components/cat-spinner.js +0 -8
  326. package/dist/components/cat-spinner.js.map +0 -1
  327. package/dist/components/cat-spinner2.js +0 -41
  328. package/dist/components/cat-spinner2.js.map +0 -1
  329. package/dist/components/cat-textarea.d.ts +0 -11
  330. package/dist/components/cat-textarea.js +0 -119
  331. package/dist/components/cat-textarea.js.map +0 -1
  332. package/dist/components/cat-toggle.d.ts +0 -11
  333. package/dist/components/cat-toggle.js +0 -93
  334. package/dist/components/cat-toggle.js.map +0 -1
  335. package/dist/components/cat-tooltip.d.ts +0 -11
  336. package/dist/components/cat-tooltip.js +0 -154
  337. package/dist/components/cat-tooltip.js.map +0 -1
  338. package/dist/components/first-tabbable.js +0 -2123
  339. package/dist/components/first-tabbable.js.map +0 -1
  340. package/dist/components/index.d.ts +0 -26
  341. package/dist/components/index.js +0 -951
  342. package/dist/components/index.js.map +0 -1
  343. package/dist/components/loglevel.js +0 -346
  344. package/dist/components/loglevel.js.map +0 -1
  345. package/dist/esm/app-globals-3dd6a26b.js +0 -948
  346. package/dist/esm/app-globals-3dd6a26b.js.map +0 -1
  347. package/dist/esm/cat-alert.entry.js +0 -33
  348. package/dist/esm/cat-alert.entry.js.map +0 -1
  349. package/dist/esm/cat-badge.entry.js +0 -44
  350. package/dist/esm/cat-badge.entry.js.map +0 -1
  351. package/dist/esm/cat-button.entry.js +0 -298
  352. package/dist/esm/cat-button.entry.js.map +0 -1
  353. package/dist/esm/cat-card.entry.js +0 -17
  354. package/dist/esm/cat-card.entry.js.map +0 -1
  355. package/dist/esm/cat-checkbox.entry.js +0 -75
  356. package/dist/esm/cat-checkbox.entry.js.map +0 -1
  357. package/dist/esm/cat-i18n-registry-83d20604.js +0 -74
  358. package/dist/esm/cat-i18n-registry-83d20604.js.map +0 -1
  359. package/dist/esm/cat-icon-registry-2dcfc9fb.js +0 -59
  360. package/dist/esm/cat-icon-registry-2dcfc9fb.js.map +0 -1
  361. package/dist/esm/cat-icon.entry.js +0 -31
  362. package/dist/esm/cat-icon.entry.js.map +0 -1
  363. package/dist/esm/cat-input.entry.js +0 -111
  364. package/dist/esm/cat-input.entry.js.map +0 -1
  365. package/dist/esm/cat-menu.entry.js +0 -850
  366. package/dist/esm/cat-menu.entry.js.map +0 -1
  367. package/dist/esm/cat-radio.entry.js +0 -66
  368. package/dist/esm/cat-radio.entry.js.map +0 -1
  369. package/dist/esm/cat-scrollable.entry.js +0 -4522
  370. package/dist/esm/cat-scrollable.entry.js.map +0 -1
  371. package/dist/esm/cat-skeleton.entry.js +0 -55
  372. package/dist/esm/cat-skeleton.entry.js.map +0 -1
  373. package/dist/esm/cat-spinner.entry.js +0 -23
  374. package/dist/esm/cat-spinner.entry.js.map +0 -1
  375. package/dist/esm/cat-textarea.entry.js +0 -87
  376. package/dist/esm/cat-textarea.entry.js.map +0 -1
  377. package/dist/esm/cat-toggle.entry.js +0 -66
  378. package/dist/esm/cat-toggle.entry.js.map +0 -1
  379. package/dist/esm/cat-tooltip.entry.js +0 -129
  380. package/dist/esm/cat-tooltip.entry.js.map +0 -1
  381. package/dist/esm/catalyst.js +0 -134
  382. package/dist/esm/catalyst.js.map +0 -1
  383. package/dist/esm/css-shim-e6dd2538.js +0 -6
  384. package/dist/esm/css-shim-e6dd2538.js.map +0 -1
  385. package/dist/esm/dom-7fc649b0.js +0 -75
  386. package/dist/esm/dom-7fc649b0.js.map +0 -1
  387. package/dist/esm/first-tabbable-2d9f9e9a.js +0 -2123
  388. package/dist/esm/first-tabbable-2d9f9e9a.js.map +0 -1
  389. package/dist/esm/index-471d4e05.js +0 -3059
  390. package/dist/esm/index-471d4e05.js.map +0 -1
  391. package/dist/esm/index.js +0 -5
  392. package/dist/esm/index.js.map +0 -1
  393. package/dist/esm/loader.js +0 -38
  394. package/dist/esm/loader.js.map +0 -1
  395. package/dist/esm/loglevel-7f0f71af.js +0 -346
  396. package/dist/esm/loglevel-7f0f71af.js.map +0 -1
  397. package/dist/esm/polyfills/core-js.js +0 -11
  398. package/dist/esm/polyfills/css-shim.js +0 -1
  399. package/dist/esm/polyfills/dom.js +0 -79
  400. package/dist/esm/polyfills/es5-html-element.js +0 -1
  401. package/dist/esm/polyfills/index.js +0 -34
  402. package/dist/esm/polyfills/system.js +0 -6
  403. package/dist/esm/shadow-css-4d56fa31.js +0 -390
  404. package/dist/esm/shadow-css-4d56fa31.js.map +0 -1
  405. package/dist/index.cjs.js +0 -1
  406. package/dist/index.js +0 -1
  407. package/dist/types/components/cat-alert/cat-alert.d.ts +0 -14
  408. package/dist/types/components/cat-alert/cat-alert.e2e.d.ts +0 -1
  409. package/dist/types/components/cat-alert/cat-alert.spec.d.ts +0 -1
  410. package/dist/types/components/cat-badge/cat-badge.d.ts +0 -29
  411. package/dist/types/components/cat-badge/cat-badge.e2e.d.ts +0 -1
  412. package/dist/types/components/cat-badge/cat-badge.spec.d.ts +0 -1
  413. package/dist/types/components/cat-button/cat-button.d.ts +0 -134
  414. package/dist/types/components/cat-button/cat-button.e2e.d.ts +0 -1
  415. package/dist/types/components/cat-button/cat-button.spec.d.ts +0 -1
  416. package/dist/types/components/cat-card/cat-card.d.ts +0 -7
  417. package/dist/types/components/cat-card/cat-card.e2e.d.ts +0 -1
  418. package/dist/types/components/cat-card/cat-card.spec.d.ts +0 -1
  419. package/dist/types/components/cat-checkbox/cat-checkbox.d.ts +0 -69
  420. package/dist/types/components/cat-checkbox/cat-checkbox.e2e.d.ts +0 -1
  421. package/dist/types/components/cat-checkbox/cat-checkbox.spec.d.ts +0 -1
  422. package/dist/types/components/cat-i18n/cat-i18n-registry.d.ts +0 -18
  423. package/dist/types/components/cat-icon/cat-icon-registry.d.ts +0 -15
  424. package/dist/types/components/cat-icon/cat-icon.d.ts +0 -23
  425. package/dist/types/components/cat-icon/cat-icon.e2e.d.ts +0 -1
  426. package/dist/types/components/cat-icon/cat-icon.spec.d.ts +0 -1
  427. package/dist/types/components/cat-input/cat-input.d.ts +0 -130
  428. package/dist/types/components/cat-input/cat-input.e2e.d.ts +0 -1
  429. package/dist/types/components/cat-input/cat-input.spec.d.ts +0 -1
  430. package/dist/types/components/cat-menu/cat-menu.d.ts +0 -31
  431. package/dist/types/components/cat-menu/cat-menu.e2e.d.ts +0 -1
  432. package/dist/types/components/cat-menu/cat-menu.spec.d.ts +0 -1
  433. package/dist/types/components/cat-radio/cat-radio.d.ts +0 -63
  434. package/dist/types/components/cat-radio/cat-radio.e2e.d.ts +0 -1
  435. package/dist/types/components/cat-radio/cat-radio.spec.d.ts +0 -1
  436. package/dist/types/components/cat-scrollable/cat-scrollable.d.ts +0 -52
  437. package/dist/types/components/cat-scrollable/cat-scrollable.e2e.d.ts +0 -1
  438. package/dist/types/components/cat-scrollable/cat-scrollable.spec.d.ts +0 -1
  439. package/dist/types/components/cat-skeleton/cat-skeleton.d.ts +0 -28
  440. package/dist/types/components/cat-skeleton/cat-skeleton.e2e.d.ts +0 -1
  441. package/dist/types/components/cat-skeleton/cat-skeleton.spec.d.ts +0 -1
  442. package/dist/types/components/cat-spinner/cat-spinner.d.ts +0 -15
  443. package/dist/types/components/cat-spinner/cat-spinner.e2e.d.ts +0 -1
  444. package/dist/types/components/cat-spinner/cat-spinner.spec.d.ts +0 -1
  445. package/dist/types/components/cat-textarea/cat-textarea.d.ts +0 -85
  446. package/dist/types/components/cat-textarea/cat-textarea.e2e.d.ts +0 -1
  447. package/dist/types/components/cat-textarea/cat-textarea.spec.d.ts +0 -1
  448. package/dist/types/components/cat-toggle/cat-toggle.d.ts +0 -64
  449. package/dist/types/components/cat-toggle/cat-toggle.e2e.d.ts +0 -1
  450. package/dist/types/components/cat-toggle/cat-toggle.spec.d.ts +0 -1
  451. package/dist/types/components/cat-tooltip/cat-tooltip.d.ts +0 -46
  452. package/dist/types/components/cat-tooltip/cat-tooltip.e2e.d.ts +0 -1
  453. package/dist/types/components/cat-tooltip/cat-tooltip.spec.d.ts +0 -1
  454. package/dist/types/components.d.ts +0 -1167
  455. package/dist/types/index.d.ts +0 -3
  456. package/dist/types/init.d.ts +0 -1
  457. package/dist/types/stencil-public-runtime.d.ts +0 -1565
  458. package/dist/types/utils/breakpoints.d.ts +0 -7
  459. package/dist/types/utils/first-tabbable.d.ts +0 -4
  460. package/dist/types/utils/is-touch-screen.d.ts +0 -2
  461. package/dist/types/utils/media-matcher.d.ts +0 -13
  462. package/dist/types/utils/media-matcher.spec.d.ts +0 -1
  463. package/dist/types/utils/platform.d.ts +0 -18
  464. package/loader/cdn.js +0 -3
  465. package/loader/index.cjs.js +0 -3
  466. package/loader/index.d.ts +0 -12
  467. package/loader/index.es2017.js +0 -3
  468. package/loader/index.js +0 -4
  469. package/loader/package.json +0 -10
@@ -1,2123 +0,0 @@
1
- function getSide(placement) {
2
- return placement.split('-')[0];
3
- }
4
-
5
- function getAlignment(placement) {
6
- return placement.split('-')[1];
7
- }
8
-
9
- function getMainAxisFromPlacement(placement) {
10
- return ['top', 'bottom'].includes(getSide(placement)) ? 'x' : 'y';
11
- }
12
-
13
- function getLengthFromAxis(axis) {
14
- return axis === 'y' ? 'height' : 'width';
15
- }
16
-
17
- function computeCoordsFromPlacement(_ref, placement, rtl) {
18
- let {
19
- reference,
20
- floating
21
- } = _ref;
22
- const commonX = reference.x + reference.width / 2 - floating.width / 2;
23
- const commonY = reference.y + reference.height / 2 - floating.height / 2;
24
- const mainAxis = getMainAxisFromPlacement(placement);
25
- const length = getLengthFromAxis(mainAxis);
26
- const commonAlign = reference[length] / 2 - floating[length] / 2;
27
- const side = getSide(placement);
28
- const isVertical = mainAxis === 'x';
29
- let coords;
30
-
31
- switch (side) {
32
- case 'top':
33
- coords = {
34
- x: commonX,
35
- y: reference.y - floating.height
36
- };
37
- break;
38
-
39
- case 'bottom':
40
- coords = {
41
- x: commonX,
42
- y: reference.y + reference.height
43
- };
44
- break;
45
-
46
- case 'right':
47
- coords = {
48
- x: reference.x + reference.width,
49
- y: commonY
50
- };
51
- break;
52
-
53
- case 'left':
54
- coords = {
55
- x: reference.x - floating.width,
56
- y: commonY
57
- };
58
- break;
59
-
60
- default:
61
- coords = {
62
- x: reference.x,
63
- y: reference.y
64
- };
65
- }
66
-
67
- switch (getAlignment(placement)) {
68
- case 'start':
69
- coords[mainAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);
70
- break;
71
-
72
- case 'end':
73
- coords[mainAxis] += commonAlign * (rtl && isVertical ? -1 : 1);
74
- break;
75
- }
76
-
77
- return coords;
78
- }
79
-
80
- /**
81
- * Computes the `x` and `y` coordinates that will place the floating element
82
- * next to a reference element when it is given a certain positioning strategy.
83
- *
84
- * This export does not have any `platform` interface logic. You will need to
85
- * write one for the platform you are using Floating UI with.
86
- */
87
-
88
- const computePosition$1 = async (reference, floating, config) => {
89
- const {
90
- placement = 'bottom',
91
- strategy = 'absolute',
92
- middleware = [],
93
- platform
94
- } = config;
95
- const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));
96
-
97
- if ("development" !== "production") {
98
- if (platform == null) {
99
- console.error(['Floating UI: `platform` property was not passed to config. If you', 'want to use Floating UI on the web, install @floating-ui/dom', 'instead of the /core package. Otherwise, you can create your own', '`platform`: https://floating-ui.com/docs/platform'].join(' '));
100
- }
101
-
102
- if (middleware.filter(_ref => {
103
- let {
104
- name
105
- } = _ref;
106
- return name === 'autoPlacement' || name === 'flip';
107
- }).length > 1) {
108
- throw new Error(['Floating UI: duplicate `flip` and/or `autoPlacement`', 'middleware detected. This will lead to an infinite loop. Ensure only', 'one of either has been passed to the `middleware` array.'].join(' '));
109
- }
110
- }
111
-
112
- let rects = await platform.getElementRects({
113
- reference,
114
- floating,
115
- strategy
116
- });
117
- let {
118
- x,
119
- y
120
- } = computeCoordsFromPlacement(rects, placement, rtl);
121
- let statefulPlacement = placement;
122
- let middlewareData = {};
123
- let _debug_loop_count_ = 0;
124
-
125
- for (let i = 0; i < middleware.length; i++) {
126
- if ("development" !== "production") {
127
- _debug_loop_count_++;
128
-
129
- if (_debug_loop_count_ > 100) {
130
- throw new Error(['Floating UI: The middleware lifecycle appears to be', 'running in an infinite loop. This is usually caused by a `reset`', 'continually being returned without a break condition.'].join(' '));
131
- }
132
- }
133
-
134
- const {
135
- name,
136
- fn
137
- } = middleware[i];
138
- const {
139
- x: nextX,
140
- y: nextY,
141
- data,
142
- reset
143
- } = await fn({
144
- x,
145
- y,
146
- initialPlacement: placement,
147
- placement: statefulPlacement,
148
- strategy,
149
- middlewareData,
150
- rects,
151
- platform,
152
- elements: {
153
- reference,
154
- floating
155
- }
156
- });
157
- x = nextX != null ? nextX : x;
158
- y = nextY != null ? nextY : y;
159
- middlewareData = { ...middlewareData,
160
- [name]: { ...middlewareData[name],
161
- ...data
162
- }
163
- };
164
-
165
- if (reset) {
166
- if (typeof reset === 'object') {
167
- if (reset.placement) {
168
- statefulPlacement = reset.placement;
169
- }
170
-
171
- if (reset.rects) {
172
- rects = reset.rects === true ? await platform.getElementRects({
173
- reference,
174
- floating,
175
- strategy
176
- }) : reset.rects;
177
- }
178
-
179
- ({
180
- x,
181
- y
182
- } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));
183
- }
184
-
185
- i = -1;
186
- continue;
187
- }
188
- }
189
-
190
- return {
191
- x,
192
- y,
193
- placement: statefulPlacement,
194
- strategy,
195
- middlewareData
196
- };
197
- };
198
-
199
- function expandPaddingObject(padding) {
200
- return {
201
- top: 0,
202
- right: 0,
203
- bottom: 0,
204
- left: 0,
205
- ...padding
206
- };
207
- }
208
-
209
- function getSideObjectFromPadding(padding) {
210
- return typeof padding !== 'number' ? expandPaddingObject(padding) : {
211
- top: padding,
212
- right: padding,
213
- bottom: padding,
214
- left: padding
215
- };
216
- }
217
-
218
- function rectToClientRect(rect) {
219
- return { ...rect,
220
- top: rect.y,
221
- left: rect.x,
222
- right: rect.x + rect.width,
223
- bottom: rect.y + rect.height
224
- };
225
- }
226
-
227
- /**
228
- * Resolves with an object of overflow side offsets that determine how much the
229
- * element is overflowing a given clipping boundary.
230
- * - positive = overflowing the boundary by that number of pixels
231
- * - negative = how many pixels left before it will overflow
232
- * - 0 = lies flush with the boundary
233
- * @see https://floating-ui.com/docs/detectOverflow
234
- */
235
- async function detectOverflow(middlewareArguments, options) {
236
- var _await$platform$isEle;
237
-
238
- if (options === void 0) {
239
- options = {};
240
- }
241
-
242
- const {
243
- x,
244
- y,
245
- platform,
246
- rects,
247
- elements,
248
- strategy
249
- } = middlewareArguments;
250
- const {
251
- boundary = 'clippingAncestors',
252
- rootBoundary = 'viewport',
253
- elementContext = 'floating',
254
- altBoundary = false,
255
- padding = 0
256
- } = options;
257
- const paddingObject = getSideObjectFromPadding(padding);
258
- const altContext = elementContext === 'floating' ? 'reference' : 'floating';
259
- const element = elements[altBoundary ? altContext : elementContext];
260
- const clippingClientRect = rectToClientRect(await platform.getClippingRect({
261
- element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || (await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating))),
262
- boundary,
263
- rootBoundary,
264
- strategy
265
- }));
266
- const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({
267
- rect: elementContext === 'floating' ? { ...rects.floating,
268
- x,
269
- y
270
- } : rects.reference,
271
- offsetParent: await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating)),
272
- strategy
273
- }) : rects[elementContext]); // positive = overflowing the clipping rect
274
- // 0 or negative = within the clipping rect
275
-
276
- return {
277
- top: clippingClientRect.top - elementClientRect.top + paddingObject.top,
278
- bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,
279
- left: clippingClientRect.left - elementClientRect.left + paddingObject.left,
280
- right: elementClientRect.right - clippingClientRect.right + paddingObject.right
281
- };
282
- }
283
-
284
- const min$1 = Math.min;
285
- const max$1 = Math.max;
286
-
287
- function within(min$1$1, value, max$1$1) {
288
- return max$1(min$1$1, min$1(value, max$1$1));
289
- }
290
-
291
- /**
292
- * Positions an inner element of the floating element such that it is centered
293
- * to the reference element.
294
- * @see https://floating-ui.com/docs/arrow
295
- */
296
- const arrow = options => ({
297
- name: 'arrow',
298
- options,
299
-
300
- async fn(middlewareArguments) {
301
- // Since `element` is required, we don't Partial<> the type
302
- const {
303
- element,
304
- padding = 0
305
- } = options != null ? options : {};
306
- const {
307
- x,
308
- y,
309
- placement,
310
- rects,
311
- platform
312
- } = middlewareArguments;
313
-
314
- if (element == null) {
315
- if ("development" !== "production") {
316
- console.warn('Floating UI: No `element` was passed to the `arrow` middleware.');
317
- }
318
-
319
- return {};
320
- }
321
-
322
- const paddingObject = getSideObjectFromPadding(padding);
323
- const coords = {
324
- x,
325
- y
326
- };
327
- const axis = getMainAxisFromPlacement(placement);
328
- const length = getLengthFromAxis(axis);
329
- const arrowDimensions = await platform.getDimensions(element);
330
- const minProp = axis === 'y' ? 'top' : 'left';
331
- const maxProp = axis === 'y' ? 'bottom' : 'right';
332
- const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];
333
- const startDiff = coords[axis] - rects.reference[axis];
334
- const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));
335
- const clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;
336
- const centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the floating element if the center
337
- // point is outside of the floating element's bounds
338
-
339
- const min = paddingObject[minProp];
340
- const max = clientSize - arrowDimensions[length] - paddingObject[maxProp];
341
- const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;
342
- const offset = within(min, center, max);
343
- return {
344
- data: {
345
- [axis]: offset,
346
- centerOffset: center - offset
347
- }
348
- };
349
- }
350
-
351
- });
352
-
353
- const hash$1 = {
354
- left: 'right',
355
- right: 'left',
356
- bottom: 'top',
357
- top: 'bottom'
358
- };
359
- function getOppositePlacement(placement) {
360
- return placement.replace(/left|right|bottom|top/g, matched => hash$1[matched]);
361
- }
362
-
363
- function getAlignmentSides(placement, rects, rtl) {
364
- if (rtl === void 0) {
365
- rtl = false;
366
- }
367
-
368
- const alignment = getAlignment(placement);
369
- const mainAxis = getMainAxisFromPlacement(placement);
370
- const length = getLengthFromAxis(mainAxis);
371
- let mainAlignmentSide = mainAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';
372
-
373
- if (rects.reference[length] > rects.floating[length]) {
374
- mainAlignmentSide = getOppositePlacement(mainAlignmentSide);
375
- }
376
-
377
- return {
378
- main: mainAlignmentSide,
379
- cross: getOppositePlacement(mainAlignmentSide)
380
- };
381
- }
382
-
383
- const hash = {
384
- start: 'end',
385
- end: 'start'
386
- };
387
- function getOppositeAlignmentPlacement(placement) {
388
- return placement.replace(/start|end/g, matched => hash[matched]);
389
- }
390
-
391
- const sides = ['top', 'right', 'bottom', 'left'];
392
- const allPlacements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + "-start", side + "-end"), []);
393
-
394
- function getPlacementList(alignment, autoAlignment, allowedPlacements) {
395
- const allowedPlacementsSortedByAlignment = alignment ? [...allowedPlacements.filter(placement => getAlignment(placement) === alignment), ...allowedPlacements.filter(placement => getAlignment(placement) !== alignment)] : allowedPlacements.filter(placement => getSide(placement) === placement);
396
- return allowedPlacementsSortedByAlignment.filter(placement => {
397
- if (alignment) {
398
- return getAlignment(placement) === alignment || (autoAlignment ? getOppositeAlignmentPlacement(placement) !== placement : false);
399
- }
400
-
401
- return true;
402
- });
403
- }
404
-
405
- /**
406
- * Automatically chooses the `placement` which has the most space available.
407
- * @see https://floating-ui.com/docs/autoPlacement
408
- */
409
- const autoPlacement = function (options) {
410
- if (options === void 0) {
411
- options = {};
412
- }
413
-
414
- return {
415
- name: 'autoPlacement',
416
- options,
417
-
418
- async fn(middlewareArguments) {
419
- var _middlewareData$autoP, _middlewareData$autoP2, _middlewareData$autoP3, _middlewareData$autoP4, _placementsSortedByLe;
420
-
421
- const {
422
- x,
423
- y,
424
- rects,
425
- middlewareData,
426
- placement,
427
- platform,
428
- elements
429
- } = middlewareArguments;
430
- const {
431
- alignment = null,
432
- allowedPlacements = allPlacements,
433
- autoAlignment = true,
434
- ...detectOverflowOptions
435
- } = options;
436
- const placements = getPlacementList(alignment, autoAlignment, allowedPlacements);
437
- const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);
438
- const currentIndex = (_middlewareData$autoP = (_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.index) != null ? _middlewareData$autoP : 0;
439
- const currentPlacement = placements[currentIndex];
440
-
441
- if (currentPlacement == null) {
442
- return {};
443
- }
444
-
445
- const {
446
- main,
447
- cross
448
- } = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))); // Make `computeCoords` start from the right place
449
-
450
- if (placement !== currentPlacement) {
451
- return {
452
- x,
453
- y,
454
- reset: {
455
- placement: placements[0]
456
- }
457
- };
458
- }
459
-
460
- const currentOverflows = [overflow[getSide(currentPlacement)], overflow[main], overflow[cross]];
461
- const allOverflows = [...((_middlewareData$autoP3 = (_middlewareData$autoP4 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP4.overflows) != null ? _middlewareData$autoP3 : []), {
462
- placement: currentPlacement,
463
- overflows: currentOverflows
464
- }];
465
- const nextPlacement = placements[currentIndex + 1]; // There are more placements to check
466
-
467
- if (nextPlacement) {
468
- return {
469
- data: {
470
- index: currentIndex + 1,
471
- overflows: allOverflows
472
- },
473
- reset: {
474
- placement: nextPlacement
475
- }
476
- };
477
- }
478
-
479
- const placementsSortedByLeastOverflow = allOverflows.slice().sort((a, b) => a.overflows[0] - b.overflows[0]);
480
- const placementThatFitsOnAllSides = (_placementsSortedByLe = placementsSortedByLeastOverflow.find(_ref => {
481
- let {
482
- overflows
483
- } = _ref;
484
- return overflows.every(overflow => overflow <= 0);
485
- })) == null ? void 0 : _placementsSortedByLe.placement;
486
- const resetPlacement = placementThatFitsOnAllSides != null ? placementThatFitsOnAllSides : placementsSortedByLeastOverflow[0].placement;
487
-
488
- if (resetPlacement !== placement) {
489
- return {
490
- data: {
491
- index: currentIndex + 1,
492
- overflows: allOverflows
493
- },
494
- reset: {
495
- placement: resetPlacement
496
- }
497
- };
498
- }
499
-
500
- return {};
501
- }
502
-
503
- };
504
- };
505
-
506
- function getExpandedPlacements(placement) {
507
- const oppositePlacement = getOppositePlacement(placement);
508
- return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];
509
- }
510
-
511
- /**
512
- * Changes the placement of the floating element to one that will fit if the
513
- * initially specified `placement` does not.
514
- * @see https://floating-ui.com/docs/flip
515
- */
516
- const flip = function (options) {
517
- if (options === void 0) {
518
- options = {};
519
- }
520
-
521
- return {
522
- name: 'flip',
523
- options,
524
-
525
- async fn(middlewareArguments) {
526
- var _middlewareData$flip;
527
-
528
- const {
529
- placement,
530
- middlewareData,
531
- rects,
532
- initialPlacement,
533
- platform,
534
- elements
535
- } = middlewareArguments;
536
- const {
537
- mainAxis: checkMainAxis = true,
538
- crossAxis: checkCrossAxis = true,
539
- fallbackPlacements: specifiedFallbackPlacements,
540
- fallbackStrategy = 'bestFit',
541
- flipAlignment = true,
542
- ...detectOverflowOptions
543
- } = options;
544
- const side = getSide(placement);
545
- const isBasePlacement = side === initialPlacement;
546
- const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));
547
- const placements = [initialPlacement, ...fallbackPlacements];
548
- const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);
549
- const overflows = [];
550
- let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];
551
-
552
- if (checkMainAxis) {
553
- overflows.push(overflow[side]);
554
- }
555
-
556
- if (checkCrossAxis) {
557
- const {
558
- main,
559
- cross
560
- } = getAlignmentSides(placement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));
561
- overflows.push(overflow[main], overflow[cross]);
562
- }
563
-
564
- overflowsData = [...overflowsData, {
565
- placement,
566
- overflows
567
- }]; // One or more sides is overflowing
568
-
569
- if (!overflows.every(side => side <= 0)) {
570
- var _middlewareData$flip$, _middlewareData$flip2;
571
-
572
- const nextIndex = ((_middlewareData$flip$ = (_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) != null ? _middlewareData$flip$ : 0) + 1;
573
- const nextPlacement = placements[nextIndex];
574
-
575
- if (nextPlacement) {
576
- // Try next placement and re-run the lifecycle
577
- return {
578
- data: {
579
- index: nextIndex,
580
- overflows: overflowsData
581
- },
582
- reset: {
583
- placement: nextPlacement
584
- }
585
- };
586
- }
587
-
588
- let resetPlacement = 'bottom';
589
-
590
- switch (fallbackStrategy) {
591
- case 'bestFit':
592
- {
593
- var _overflowsData$slice$;
594
-
595
- const placement = (_overflowsData$slice$ = overflowsData.slice().sort((a, b) => a.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0) - b.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0))[0]) == null ? void 0 : _overflowsData$slice$.placement;
596
-
597
- if (placement) {
598
- resetPlacement = placement;
599
- }
600
-
601
- break;
602
- }
603
-
604
- case 'initialPlacement':
605
- resetPlacement = initialPlacement;
606
- break;
607
- }
608
-
609
- if (placement !== resetPlacement) {
610
- return {
611
- reset: {
612
- placement: resetPlacement
613
- }
614
- };
615
- }
616
- }
617
-
618
- return {};
619
- }
620
-
621
- };
622
- };
623
-
624
- function getSideOffsets(overflow, rect) {
625
- return {
626
- top: overflow.top - rect.height,
627
- right: overflow.right - rect.width,
628
- bottom: overflow.bottom - rect.height,
629
- left: overflow.left - rect.width
630
- };
631
- }
632
-
633
- function isAnySideFullyClipped(overflow) {
634
- return sides.some(side => overflow[side] >= 0);
635
- }
636
-
637
- /**
638
- * Provides data to hide the floating element in applicable situations, such as
639
- * when it is not in the same clipping context as the reference element.
640
- * @see https://floating-ui.com/docs/hide
641
- */
642
- const hide = function (_temp) {
643
- let {
644
- strategy = 'referenceHidden',
645
- ...detectOverflowOptions
646
- } = _temp === void 0 ? {} : _temp;
647
- return {
648
- name: 'hide',
649
-
650
- async fn(middlewareArguments) {
651
- const {
652
- rects
653
- } = middlewareArguments;
654
-
655
- switch (strategy) {
656
- case 'referenceHidden':
657
- {
658
- const overflow = await detectOverflow(middlewareArguments, { ...detectOverflowOptions,
659
- elementContext: 'reference'
660
- });
661
- const offsets = getSideOffsets(overflow, rects.reference);
662
- return {
663
- data: {
664
- referenceHiddenOffsets: offsets,
665
- referenceHidden: isAnySideFullyClipped(offsets)
666
- }
667
- };
668
- }
669
-
670
- case 'escaped':
671
- {
672
- const overflow = await detectOverflow(middlewareArguments, { ...detectOverflowOptions,
673
- altBoundary: true
674
- });
675
- const offsets = getSideOffsets(overflow, rects.floating);
676
- return {
677
- data: {
678
- escapedOffsets: offsets,
679
- escaped: isAnySideFullyClipped(offsets)
680
- }
681
- };
682
- }
683
-
684
- default:
685
- {
686
- return {};
687
- }
688
- }
689
- }
690
-
691
- };
692
- };
693
-
694
- function convertValueToCoords(placement, rects, value, rtl) {
695
- if (rtl === void 0) {
696
- rtl = false;
697
- }
698
-
699
- const side = getSide(placement);
700
- const alignment = getAlignment(placement);
701
- const isVertical = getMainAxisFromPlacement(placement) === 'x';
702
- const mainAxisMulti = ['left', 'top'].includes(side) ? -1 : 1;
703
- const crossAxisMulti = rtl && isVertical ? -1 : 1;
704
- const rawValue = typeof value === 'function' ? value({ ...rects,
705
- placement
706
- }) : value;
707
- const isNumber = typeof rawValue === 'number'; // eslint-disable-next-line prefer-const
708
-
709
- let {
710
- mainAxis,
711
- crossAxis,
712
- alignmentAxis
713
- } = isNumber ? {
714
- mainAxis: rawValue,
715
- crossAxis: 0,
716
- alignmentAxis: null
717
- } : {
718
- mainAxis: 0,
719
- crossAxis: 0,
720
- alignmentAxis: null,
721
- ...rawValue
722
- };
723
-
724
- if (alignment && typeof alignmentAxis === 'number') {
725
- crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;
726
- }
727
-
728
- return isVertical ? {
729
- x: crossAxis * crossAxisMulti,
730
- y: mainAxis * mainAxisMulti
731
- } : {
732
- x: mainAxis * mainAxisMulti,
733
- y: crossAxis * crossAxisMulti
734
- };
735
- }
736
- /**
737
- * Displaces the floating element from its reference element.
738
- * @see https://floating-ui.com/docs/offset
739
- */
740
-
741
- const offset = function (value) {
742
- if (value === void 0) {
743
- value = 0;
744
- }
745
-
746
- return {
747
- name: 'offset',
748
- options: value,
749
-
750
- async fn(middlewareArguments) {
751
- const {
752
- x,
753
- y,
754
- placement,
755
- rects,
756
- platform,
757
- elements
758
- } = middlewareArguments;
759
- const diffCoords = convertValueToCoords(placement, rects, value, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));
760
- return {
761
- x: x + diffCoords.x,
762
- y: y + diffCoords.y,
763
- data: diffCoords
764
- };
765
- }
766
-
767
- };
768
- };
769
-
770
- function getCrossAxis(axis) {
771
- return axis === 'x' ? 'y' : 'x';
772
- }
773
-
774
- /**
775
- * Shifts the floating element in order to keep it in view when it will overflow
776
- * a clipping boundary.
777
- * @see https://floating-ui.com/docs/shift
778
- */
779
- const shift = function (options) {
780
- if (options === void 0) {
781
- options = {};
782
- }
783
-
784
- return {
785
- name: 'shift',
786
- options,
787
-
788
- async fn(middlewareArguments) {
789
- const {
790
- x,
791
- y,
792
- placement
793
- } = middlewareArguments;
794
- const {
795
- mainAxis: checkMainAxis = true,
796
- crossAxis: checkCrossAxis = false,
797
- limiter = {
798
- fn: _ref => {
799
- let {
800
- x,
801
- y
802
- } = _ref;
803
- return {
804
- x,
805
- y
806
- };
807
- }
808
- },
809
- ...detectOverflowOptions
810
- } = options;
811
- const coords = {
812
- x,
813
- y
814
- };
815
- const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);
816
- const mainAxis = getMainAxisFromPlacement(getSide(placement));
817
- const crossAxis = getCrossAxis(mainAxis);
818
- let mainAxisCoord = coords[mainAxis];
819
- let crossAxisCoord = coords[crossAxis];
820
-
821
- if (checkMainAxis) {
822
- const minSide = mainAxis === 'y' ? 'top' : 'left';
823
- const maxSide = mainAxis === 'y' ? 'bottom' : 'right';
824
- const min = mainAxisCoord + overflow[minSide];
825
- const max = mainAxisCoord - overflow[maxSide];
826
- mainAxisCoord = within(min, mainAxisCoord, max);
827
- }
828
-
829
- if (checkCrossAxis) {
830
- const minSide = crossAxis === 'y' ? 'top' : 'left';
831
- const maxSide = crossAxis === 'y' ? 'bottom' : 'right';
832
- const min = crossAxisCoord + overflow[minSide];
833
- const max = crossAxisCoord - overflow[maxSide];
834
- crossAxisCoord = within(min, crossAxisCoord, max);
835
- }
836
-
837
- const limitedCoords = limiter.fn({ ...middlewareArguments,
838
- [mainAxis]: mainAxisCoord,
839
- [crossAxis]: crossAxisCoord
840
- });
841
- return { ...limitedCoords,
842
- data: {
843
- x: limitedCoords.x - x,
844
- y: limitedCoords.y - y
845
- }
846
- };
847
- }
848
-
849
- };
850
- };
851
-
852
- /**
853
- * Built-in `limiter` that will stop `shift()` at a certain point.
854
- */
855
- const limitShift = function (options) {
856
- if (options === void 0) {
857
- options = {};
858
- }
859
-
860
- return {
861
- options,
862
-
863
- fn(middlewareArguments) {
864
- const {
865
- x,
866
- y,
867
- placement,
868
- rects,
869
- middlewareData
870
- } = middlewareArguments;
871
- const {
872
- offset = 0,
873
- mainAxis: checkMainAxis = true,
874
- crossAxis: checkCrossAxis = true
875
- } = options;
876
- const coords = {
877
- x,
878
- y
879
- };
880
- const mainAxis = getMainAxisFromPlacement(placement);
881
- const crossAxis = getCrossAxis(mainAxis);
882
- let mainAxisCoord = coords[mainAxis];
883
- let crossAxisCoord = coords[crossAxis];
884
- const rawOffset = typeof offset === 'function' ? offset({ ...rects,
885
- placement
886
- }) : offset;
887
- const computedOffset = typeof rawOffset === 'number' ? {
888
- mainAxis: rawOffset,
889
- crossAxis: 0
890
- } : {
891
- mainAxis: 0,
892
- crossAxis: 0,
893
- ...rawOffset
894
- };
895
-
896
- if (checkMainAxis) {
897
- const len = mainAxis === 'y' ? 'height' : 'width';
898
- const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;
899
- const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;
900
-
901
- if (mainAxisCoord < limitMin) {
902
- mainAxisCoord = limitMin;
903
- } else if (mainAxisCoord > limitMax) {
904
- mainAxisCoord = limitMax;
905
- }
906
- }
907
-
908
- if (checkCrossAxis) {
909
- var _middlewareData$offse, _middlewareData$offse2, _middlewareData$offse3, _middlewareData$offse4;
910
-
911
- const len = mainAxis === 'y' ? 'width' : 'height';
912
- const isOriginSide = ['top', 'left'].includes(getSide(placement));
913
- const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? (_middlewareData$offse = (_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) != null ? _middlewareData$offse : 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);
914
- const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : (_middlewareData$offse3 = (_middlewareData$offse4 = middlewareData.offset) == null ? void 0 : _middlewareData$offse4[crossAxis]) != null ? _middlewareData$offse3 : 0) - (isOriginSide ? computedOffset.crossAxis : 0);
915
-
916
- if (crossAxisCoord < limitMin) {
917
- crossAxisCoord = limitMin;
918
- } else if (crossAxisCoord > limitMax) {
919
- crossAxisCoord = limitMax;
920
- }
921
- }
922
-
923
- return {
924
- [mainAxis]: mainAxisCoord,
925
- [crossAxis]: crossAxisCoord
926
- };
927
- }
928
-
929
- };
930
- };
931
-
932
- /**
933
- * Provides data to change the size of the floating element. For instance,
934
- * prevent it from overflowing its clipping boundary or match the width of the
935
- * reference element.
936
- * @see https://floating-ui.com/docs/size
937
- */
938
- const size = function (options) {
939
- if (options === void 0) {
940
- options = {};
941
- }
942
-
943
- return {
944
- name: 'size',
945
- options,
946
-
947
- async fn(middlewareArguments) {
948
- const {
949
- placement,
950
- rects,
951
- platform,
952
- elements
953
- } = middlewareArguments;
954
- const {
955
- apply,
956
- ...detectOverflowOptions
957
- } = options;
958
- const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);
959
- const side = getSide(placement);
960
- const alignment = getAlignment(placement);
961
- let heightSide;
962
- let widthSide;
963
-
964
- if (side === 'top' || side === 'bottom') {
965
- heightSide = side;
966
- widthSide = alignment === ((await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))) ? 'start' : 'end') ? 'left' : 'right';
967
- } else {
968
- widthSide = side;
969
- heightSide = alignment === 'end' ? 'top' : 'bottom';
970
- }
971
-
972
- const xMin = max$1(overflow.left, 0);
973
- const xMax = max$1(overflow.right, 0);
974
- const yMin = max$1(overflow.top, 0);
975
- const yMax = max$1(overflow.bottom, 0);
976
- const dimensions = {
977
- height: rects.floating.height - (['left', 'right'].includes(placement) ? 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max$1(overflow.top, overflow.bottom)) : overflow[heightSide]),
978
- width: rects.floating.width - (['top', 'bottom'].includes(placement) ? 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max$1(overflow.left, overflow.right)) : overflow[widthSide])
979
- };
980
- const prevDimensions = await platform.getDimensions(elements.floating);
981
- apply == null ? void 0 : apply({ ...dimensions,
982
- ...rects
983
- });
984
- const nextDimensions = await platform.getDimensions(elements.floating);
985
-
986
- if (prevDimensions.width !== nextDimensions.width || prevDimensions.height !== nextDimensions.height) {
987
- return {
988
- reset: {
989
- rects: true
990
- }
991
- };
992
- }
993
-
994
- return {};
995
- }
996
-
997
- };
998
- };
999
-
1000
- /**
1001
- * Provides improved positioning for inline reference elements that can span
1002
- * over multiple lines, such as hyperlinks or range selections.
1003
- * @see https://floating-ui.com/docs/inline
1004
- */
1005
- const inline = function (options) {
1006
- if (options === void 0) {
1007
- options = {};
1008
- }
1009
-
1010
- return {
1011
- name: 'inline',
1012
- options,
1013
-
1014
- async fn(middlewareArguments) {
1015
- var _await$platform$getCl;
1016
-
1017
- const {
1018
- placement,
1019
- elements,
1020
- rects,
1021
- platform,
1022
- strategy
1023
- } = middlewareArguments; // A MouseEvent's client{X,Y} coords can be up to 2 pixels off a
1024
- // ClientRect's bounds, despite the event listener being triggered. A
1025
- // padding of 2 seems to handle this issue.
1026
-
1027
- const {
1028
- padding = 2,
1029
- x,
1030
- y
1031
- } = options;
1032
- const fallback = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({
1033
- rect: rects.reference,
1034
- offsetParent: await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating)),
1035
- strategy
1036
- }) : rects.reference);
1037
- const clientRects = (_await$platform$getCl = await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference))) != null ? _await$platform$getCl : [];
1038
- const paddingObject = getSideObjectFromPadding(padding);
1039
-
1040
- function getBoundingClientRect() {
1041
- // There are two rects and they are disjoined
1042
- if (clientRects.length === 2 && clientRects[0].left > clientRects[1].right && x != null && y != null) {
1043
- var _clientRects$find;
1044
-
1045
- // Find the first rect in which the point is fully inside
1046
- return (_clientRects$find = clientRects.find(rect => x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom)) != null ? _clientRects$find : fallback;
1047
- } // There are 2 or more connected rects
1048
-
1049
-
1050
- if (clientRects.length >= 2) {
1051
- if (getMainAxisFromPlacement(placement) === 'x') {
1052
- const firstRect = clientRects[0];
1053
- const lastRect = clientRects[clientRects.length - 1];
1054
- const isTop = getSide(placement) === 'top';
1055
- const top = firstRect.top;
1056
- const bottom = lastRect.bottom;
1057
- const left = isTop ? firstRect.left : lastRect.left;
1058
- const right = isTop ? firstRect.right : lastRect.right;
1059
- const width = right - left;
1060
- const height = bottom - top;
1061
- return {
1062
- top,
1063
- bottom,
1064
- left,
1065
- right,
1066
- width,
1067
- height,
1068
- x: left,
1069
- y: top
1070
- };
1071
- }
1072
-
1073
- const isLeftSide = getSide(placement) === 'left';
1074
- const maxRight = max$1(...clientRects.map(rect => rect.right));
1075
- const minLeft = min$1(...clientRects.map(rect => rect.left));
1076
- const measureRects = clientRects.filter(rect => isLeftSide ? rect.left === minLeft : rect.right === maxRight);
1077
- const top = measureRects[0].top;
1078
- const bottom = measureRects[measureRects.length - 1].bottom;
1079
- const left = minLeft;
1080
- const right = maxRight;
1081
- const width = right - left;
1082
- const height = bottom - top;
1083
- return {
1084
- top,
1085
- bottom,
1086
- left,
1087
- right,
1088
- width,
1089
- height,
1090
- x: left,
1091
- y: top
1092
- };
1093
- }
1094
-
1095
- return fallback;
1096
- }
1097
-
1098
- const resetRects = await platform.getElementRects({
1099
- reference: {
1100
- getBoundingClientRect
1101
- },
1102
- floating: elements.floating,
1103
- strategy
1104
- });
1105
-
1106
- if (rects.reference.x !== resetRects.reference.x || rects.reference.y !== resetRects.reference.y || rects.reference.width !== resetRects.reference.width || rects.reference.height !== resetRects.reference.height) {
1107
- return {
1108
- reset: {
1109
- rects: resetRects
1110
- }
1111
- };
1112
- }
1113
-
1114
- return {};
1115
- }
1116
-
1117
- };
1118
- };
1119
-
1120
- function isWindow(value) {
1121
- return (value == null ? void 0 : value.toString()) === '[object Window]';
1122
- }
1123
- function getWindow(node) {
1124
- if (node == null) {
1125
- return window;
1126
- }
1127
-
1128
- if (!isWindow(node)) {
1129
- const ownerDocument = node.ownerDocument;
1130
- return ownerDocument ? ownerDocument.defaultView || window : window;
1131
- }
1132
-
1133
- return node;
1134
- }
1135
-
1136
- function getComputedStyle$1(element) {
1137
- return getWindow(element).getComputedStyle(element);
1138
- }
1139
-
1140
- function getNodeName(node) {
1141
- return isWindow(node) ? '' : node ? (node.nodeName || '').toLowerCase() : '';
1142
- }
1143
-
1144
- function isHTMLElement(value) {
1145
- return value instanceof getWindow(value).HTMLElement;
1146
- }
1147
- function isElement(value) {
1148
- return value instanceof getWindow(value).Element;
1149
- }
1150
- function isNode(value) {
1151
- return value instanceof getWindow(value).Node;
1152
- }
1153
- function isShadowRoot(node) {
1154
- const OwnElement = getWindow(node).ShadowRoot;
1155
- return node instanceof OwnElement || node instanceof ShadowRoot;
1156
- }
1157
- function isOverflowElement(element) {
1158
- // Firefox wants us to check `-x` and `-y` variations as well
1159
- const {
1160
- overflow,
1161
- overflowX,
1162
- overflowY
1163
- } = getComputedStyle$1(element);
1164
- return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);
1165
- }
1166
- function isTableElement(element) {
1167
- return ['table', 'td', 'th'].includes(getNodeName(element));
1168
- }
1169
- function isContainingBlock(element) {
1170
- // TODO: Try and use feature detection here instead
1171
- const isFirefox = navigator.userAgent.toLowerCase().includes('firefox');
1172
- const css = getComputedStyle$1(element); // This is non-exhaustive but covers the most common CSS properties that
1173
- // create a containing block.
1174
- // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block
1175
-
1176
- return css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].includes(css.willChange) || isFirefox && css.willChange === 'filter' || isFirefox && (css.filter ? css.filter !== 'none' : false);
1177
- }
1178
- function isLayoutViewport() {
1179
- // Not Safari
1180
- return !/^((?!chrome|android).)*safari/i.test(navigator.userAgent); // Feature detection for this fails in various ways
1181
- // • Always-visible scrollbar or not
1182
- // • Width of <html>, etc.
1183
- // const vV = win.visualViewport;
1184
- // return vV ? Math.abs(win.innerWidth / vV.scale - vV.width) < 0.5 : true;
1185
- }
1186
-
1187
- const min = Math.min;
1188
- const max = Math.max;
1189
- const round = Math.round;
1190
-
1191
- function getBoundingClientRect(element, includeScale, isFixedStrategy) {
1192
- if (includeScale === void 0) {
1193
- includeScale = false;
1194
- }
1195
-
1196
- if (isFixedStrategy === void 0) {
1197
- isFixedStrategy = false;
1198
- }
1199
-
1200
- const clientRect = element.getBoundingClientRect();
1201
- let scaleX = 1;
1202
- let scaleY = 1;
1203
-
1204
- if (includeScale && isHTMLElement(element)) {
1205
- scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;
1206
- scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;
1207
- }
1208
-
1209
- const win = isElement(element) ? getWindow(element) : window;
1210
- const addVisualOffsets = !isLayoutViewport() && isFixedStrategy;
1211
- const x = (clientRect.left + (addVisualOffsets ? win.visualViewport.offsetLeft : 0)) / scaleX;
1212
- const y = (clientRect.top + (addVisualOffsets ? win.visualViewport.offsetTop : 0)) / scaleY;
1213
- const width = clientRect.width / scaleX;
1214
- const height = clientRect.height / scaleY;
1215
- return {
1216
- width,
1217
- height,
1218
- top: y,
1219
- right: x + width,
1220
- bottom: y + height,
1221
- left: x,
1222
- x,
1223
- y
1224
- };
1225
- }
1226
-
1227
- function getDocumentElement(node) {
1228
- return ((isNode(node) ? node.ownerDocument : node.document) || window.document).documentElement;
1229
- }
1230
-
1231
- function getNodeScroll(element) {
1232
- if (isWindow(element)) {
1233
- return {
1234
- scrollLeft: element.pageXOffset,
1235
- scrollTop: element.pageYOffset
1236
- };
1237
- }
1238
-
1239
- return {
1240
- scrollLeft: element.scrollLeft,
1241
- scrollTop: element.scrollTop
1242
- };
1243
- }
1244
-
1245
- function getWindowScrollBarX(element) {
1246
- // If <html> has a CSS width greater than the viewport, then this will be
1247
- // incorrect for RTL.
1248
- return getBoundingClientRect(getDocumentElement(element)).left + getNodeScroll(element).scrollLeft;
1249
- }
1250
-
1251
- function isScaled(element) {
1252
- const rect = getBoundingClientRect(element);
1253
- return round(rect.width) !== element.offsetWidth || round(rect.height) !== element.offsetHeight;
1254
- }
1255
-
1256
- function getRectRelativeToOffsetParent(element, offsetParent, strategy) {
1257
- const isOffsetParentAnElement = isHTMLElement(offsetParent);
1258
- const documentElement = getDocumentElement(offsetParent);
1259
- const rect = getBoundingClientRect(element, isOffsetParentAnElement && isScaled(offsetParent), strategy === 'fixed');
1260
- let scroll = {
1261
- scrollLeft: 0,
1262
- scrollTop: 0
1263
- };
1264
- const offsets = {
1265
- x: 0,
1266
- y: 0
1267
- };
1268
-
1269
- if (isOffsetParentAnElement || !isOffsetParentAnElement && strategy !== 'fixed') {
1270
- if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {
1271
- scroll = getNodeScroll(offsetParent);
1272
- }
1273
-
1274
- if (isHTMLElement(offsetParent)) {
1275
- const offsetRect = getBoundingClientRect(offsetParent, true);
1276
- offsets.x = offsetRect.x + offsetParent.clientLeft;
1277
- offsets.y = offsetRect.y + offsetParent.clientTop;
1278
- } else if (documentElement) {
1279
- offsets.x = getWindowScrollBarX(documentElement);
1280
- }
1281
- }
1282
-
1283
- return {
1284
- x: rect.left + scroll.scrollLeft - offsets.x,
1285
- y: rect.top + scroll.scrollTop - offsets.y,
1286
- width: rect.width,
1287
- height: rect.height
1288
- };
1289
- }
1290
-
1291
- function getParentNode(node) {
1292
- if (getNodeName(node) === 'html') {
1293
- return node;
1294
- }
1295
-
1296
- return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle
1297
- // @ts-ignore
1298
- node.assignedSlot || // step into the shadow DOM of the parent of a slotted node
1299
- node.parentNode || ( // DOM Element detected
1300
- isShadowRoot(node) ? node.host : null) || // ShadowRoot detected
1301
- getDocumentElement(node) // fallback
1302
-
1303
- );
1304
- }
1305
-
1306
- function getTrueOffsetParent(element) {
1307
- if (!isHTMLElement(element) || getComputedStyle(element).position === 'fixed') {
1308
- return null;
1309
- }
1310
-
1311
- return element.offsetParent;
1312
- }
1313
-
1314
- function getContainingBlock(element) {
1315
- let currentNode = getParentNode(element);
1316
-
1317
- if (isShadowRoot(currentNode)) {
1318
- currentNode = currentNode.host;
1319
- }
1320
-
1321
- while (isHTMLElement(currentNode) && !['html', 'body'].includes(getNodeName(currentNode))) {
1322
- if (isContainingBlock(currentNode)) {
1323
- return currentNode;
1324
- } else {
1325
- currentNode = currentNode.parentNode;
1326
- }
1327
- }
1328
-
1329
- return null;
1330
- } // Gets the closest ancestor positioned element. Handles some edge cases,
1331
- // such as table ancestors and cross browser bugs.
1332
-
1333
-
1334
- function getOffsetParent(element) {
1335
- const window = getWindow(element);
1336
- let offsetParent = getTrueOffsetParent(element);
1337
-
1338
- while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {
1339
- offsetParent = getTrueOffsetParent(offsetParent);
1340
- }
1341
-
1342
- if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static' && !isContainingBlock(offsetParent))) {
1343
- return window;
1344
- }
1345
-
1346
- return offsetParent || getContainingBlock(element) || window;
1347
- }
1348
-
1349
- function getDimensions(element) {
1350
- if (isHTMLElement(element)) {
1351
- return {
1352
- width: element.offsetWidth,
1353
- height: element.offsetHeight
1354
- };
1355
- }
1356
-
1357
- const rect = getBoundingClientRect(element);
1358
- return {
1359
- width: rect.width,
1360
- height: rect.height
1361
- };
1362
- }
1363
-
1364
- function convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {
1365
- let {
1366
- rect,
1367
- offsetParent,
1368
- strategy
1369
- } = _ref;
1370
- const isOffsetParentAnElement = isHTMLElement(offsetParent);
1371
- const documentElement = getDocumentElement(offsetParent);
1372
-
1373
- if (offsetParent === documentElement) {
1374
- return rect;
1375
- }
1376
-
1377
- let scroll = {
1378
- scrollLeft: 0,
1379
- scrollTop: 0
1380
- };
1381
- const offsets = {
1382
- x: 0,
1383
- y: 0
1384
- };
1385
-
1386
- if (isOffsetParentAnElement || !isOffsetParentAnElement && strategy !== 'fixed') {
1387
- if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {
1388
- scroll = getNodeScroll(offsetParent);
1389
- }
1390
-
1391
- if (isHTMLElement(offsetParent)) {
1392
- const offsetRect = getBoundingClientRect(offsetParent, true);
1393
- offsets.x = offsetRect.x + offsetParent.clientLeft;
1394
- offsets.y = offsetRect.y + offsetParent.clientTop;
1395
- } // This doesn't appear to be need to be negated.
1396
- // else if (documentElement) {
1397
- // offsets.x = getWindowScrollBarX(documentElement);
1398
- // }
1399
-
1400
- }
1401
-
1402
- return { ...rect,
1403
- x: rect.x - scroll.scrollLeft + offsets.x,
1404
- y: rect.y - scroll.scrollTop + offsets.y
1405
- };
1406
- }
1407
-
1408
- function getViewportRect(element, strategy) {
1409
- const win = getWindow(element);
1410
- const html = getDocumentElement(element);
1411
- const visualViewport = win.visualViewport;
1412
- let width = html.clientWidth;
1413
- let height = html.clientHeight;
1414
- let x = 0;
1415
- let y = 0;
1416
-
1417
- if (visualViewport) {
1418
- width = visualViewport.width;
1419
- height = visualViewport.height;
1420
- const layoutViewport = isLayoutViewport();
1421
-
1422
- if (layoutViewport || !layoutViewport && strategy === 'fixed') {
1423
- x = visualViewport.offsetLeft;
1424
- y = visualViewport.offsetTop;
1425
- }
1426
- }
1427
-
1428
- return {
1429
- width,
1430
- height,
1431
- x,
1432
- y
1433
- };
1434
- }
1435
-
1436
- // of the `<html>` and `<body>` rect bounds if horizontally scrollable
1437
-
1438
- function getDocumentRect(element) {
1439
- var _element$ownerDocumen;
1440
-
1441
- const html = getDocumentElement(element);
1442
- const scroll = getNodeScroll(element);
1443
- const body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;
1444
- const width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);
1445
- const height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);
1446
- let x = -scroll.scrollLeft + getWindowScrollBarX(element);
1447
- const y = -scroll.scrollTop;
1448
-
1449
- if (getComputedStyle$1(body || html).direction === 'rtl') {
1450
- x += max(html.clientWidth, body ? body.clientWidth : 0) - width;
1451
- }
1452
-
1453
- return {
1454
- width,
1455
- height,
1456
- x,
1457
- y
1458
- };
1459
- }
1460
-
1461
- function getNearestOverflowAncestor(node) {
1462
- const parentNode = getParentNode(node);
1463
-
1464
- if (['html', 'body', '#document'].includes(getNodeName(parentNode))) {
1465
- // @ts-ignore assume body is always available
1466
- return node.ownerDocument.body;
1467
- }
1468
-
1469
- if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {
1470
- return parentNode;
1471
- }
1472
-
1473
- return getNearestOverflowAncestor(parentNode);
1474
- }
1475
-
1476
- function getOverflowAncestors(node, list) {
1477
- var _node$ownerDocument;
1478
-
1479
- if (list === void 0) {
1480
- list = [];
1481
- }
1482
-
1483
- const scrollableAncestor = getNearestOverflowAncestor(node);
1484
- const isBody = scrollableAncestor === ((_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.body);
1485
- const win = getWindow(scrollableAncestor);
1486
- const target = isBody ? [win].concat(win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : []) : scrollableAncestor;
1487
- const updatedList = list.concat(target);
1488
- return isBody ? updatedList : // @ts-ignore: isBody tells us target will be an HTMLElement here
1489
- updatedList.concat(getOverflowAncestors(getParentNode(target)));
1490
- }
1491
-
1492
- function contains(parent, child) {
1493
- const rootNode = child.getRootNode == null ? void 0 : child.getRootNode(); // First, attempt with faster native method
1494
-
1495
- if (parent.contains(child)) {
1496
- return true;
1497
- } // then fallback to custom implementation with Shadow DOM support
1498
- else if (rootNode && isShadowRoot(rootNode)) {
1499
- let next = child;
1500
-
1501
- do {
1502
- // use `===` replace node.isSameNode()
1503
- if (next && parent === next) {
1504
- return true;
1505
- } // @ts-ignore: need a better way to handle this...
1506
-
1507
-
1508
- next = next.parentNode || next.host;
1509
- } while (next);
1510
- }
1511
-
1512
- return false;
1513
- }
1514
-
1515
- function getInnerBoundingClientRect(element, strategy) {
1516
- const clientRect = getBoundingClientRect(element, false, strategy === 'fixed');
1517
- const top = clientRect.top + element.clientTop;
1518
- const left = clientRect.left + element.clientLeft;
1519
- return {
1520
- top,
1521
- left,
1522
- x: left,
1523
- y: top,
1524
- right: left + element.clientWidth,
1525
- bottom: top + element.clientHeight,
1526
- width: element.clientWidth,
1527
- height: element.clientHeight
1528
- };
1529
- }
1530
-
1531
- function getClientRectFromClippingAncestor(element, clippingParent, strategy) {
1532
- if (clippingParent === 'viewport') {
1533
- return rectToClientRect(getViewportRect(element, strategy));
1534
- }
1535
-
1536
- if (isElement(clippingParent)) {
1537
- return getInnerBoundingClientRect(clippingParent, strategy);
1538
- }
1539
-
1540
- return rectToClientRect(getDocumentRect(getDocumentElement(element)));
1541
- } // A "clipping ancestor" is an overflowable container with the characteristic of
1542
- // clipping (or hiding) overflowing elements with a position different from
1543
- // `initial`
1544
-
1545
-
1546
- function getClippingAncestors(element) {
1547
- const clippingAncestors = getOverflowAncestors(element);
1548
- const canEscapeClipping = ['absolute', 'fixed'].includes(getComputedStyle$1(element).position);
1549
- const clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;
1550
-
1551
- if (!isElement(clipperElement)) {
1552
- return [];
1553
- } // @ts-ignore isElement check ensures we return Array<Element>
1554
-
1555
-
1556
- return clippingAncestors.filter(clippingAncestors => isElement(clippingAncestors) && contains(clippingAncestors, clipperElement) && getNodeName(clippingAncestors) !== 'body');
1557
- } // Gets the maximum area that the element is visible in due to any number of
1558
- // clipping ancestors
1559
-
1560
-
1561
- function getClippingRect(_ref) {
1562
- let {
1563
- element,
1564
- boundary,
1565
- rootBoundary,
1566
- strategy
1567
- } = _ref;
1568
- const mainClippingAncestors = boundary === 'clippingAncestors' ? getClippingAncestors(element) : [].concat(boundary);
1569
- const clippingAncestors = [...mainClippingAncestors, rootBoundary];
1570
- const firstClippingAncestor = clippingAncestors[0];
1571
- const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => {
1572
- const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);
1573
- accRect.top = max(rect.top, accRect.top);
1574
- accRect.right = min(rect.right, accRect.right);
1575
- accRect.bottom = min(rect.bottom, accRect.bottom);
1576
- accRect.left = max(rect.left, accRect.left);
1577
- return accRect;
1578
- }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy));
1579
- return {
1580
- width: clippingRect.right - clippingRect.left,
1581
- height: clippingRect.bottom - clippingRect.top,
1582
- x: clippingRect.left,
1583
- y: clippingRect.top
1584
- };
1585
- }
1586
-
1587
- const platform = {
1588
- getClippingRect,
1589
- convertOffsetParentRelativeRectToViewportRelativeRect,
1590
- isElement,
1591
- getDimensions,
1592
- getOffsetParent,
1593
- getDocumentElement,
1594
- getElementRects: _ref => {
1595
- let {
1596
- reference,
1597
- floating,
1598
- strategy
1599
- } = _ref;
1600
- return {
1601
- reference: getRectRelativeToOffsetParent(reference, getOffsetParent(floating), strategy),
1602
- floating: { ...getDimensions(floating),
1603
- x: 0,
1604
- y: 0
1605
- }
1606
- };
1607
- },
1608
- getClientRects: element => Array.from(element.getClientRects()),
1609
- isRTL: element => getComputedStyle$1(element).direction === 'rtl'
1610
- };
1611
-
1612
- /**
1613
- * Automatically updates the position of the floating element when necessary.
1614
- * @see https://floating-ui.com/docs/autoUpdate
1615
- */
1616
- function autoUpdate(reference, floating, update, options) {
1617
- if (options === void 0) {
1618
- options = {};
1619
- }
1620
-
1621
- const {
1622
- ancestorScroll: _ancestorScroll = true,
1623
- ancestorResize: _ancestorResize = true,
1624
- elementResize: _elementResize = true,
1625
- animationFrame = false
1626
- } = options;
1627
- let cleanedUp = false;
1628
- const ancestorScroll = _ancestorScroll && !animationFrame;
1629
- const ancestorResize = _ancestorResize && !animationFrame;
1630
- const elementResize = _elementResize && !animationFrame;
1631
- const ancestors = ancestorScroll || ancestorResize ? [...(isElement(reference) ? getOverflowAncestors(reference) : []), ...getOverflowAncestors(floating)] : [];
1632
- ancestors.forEach(ancestor => {
1633
- ancestorScroll && ancestor.addEventListener('scroll', update, {
1634
- passive: true
1635
- });
1636
- ancestorResize && ancestor.addEventListener('resize', update);
1637
- });
1638
- let observer = null;
1639
-
1640
- if (elementResize) {
1641
- observer = new ResizeObserver(update);
1642
- isElement(reference) && observer.observe(reference);
1643
- observer.observe(floating);
1644
- }
1645
-
1646
- let frameId;
1647
- let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null;
1648
-
1649
- if (animationFrame) {
1650
- frameLoop();
1651
- }
1652
-
1653
- function frameLoop() {
1654
- if (cleanedUp) {
1655
- return;
1656
- }
1657
-
1658
- const nextRefRect = getBoundingClientRect(reference);
1659
-
1660
- if (prevRefRect && (nextRefRect.x !== prevRefRect.x || nextRefRect.y !== prevRefRect.y || nextRefRect.width !== prevRefRect.width || nextRefRect.height !== prevRefRect.height)) {
1661
- update();
1662
- }
1663
-
1664
- prevRefRect = nextRefRect;
1665
- frameId = requestAnimationFrame(frameLoop);
1666
- }
1667
-
1668
- return () => {
1669
- var _observer;
1670
-
1671
- cleanedUp = true;
1672
- ancestors.forEach(ancestor => {
1673
- ancestorScroll && ancestor.removeEventListener('scroll', update);
1674
- ancestorResize && ancestor.removeEventListener('resize', update);
1675
- });
1676
- (_observer = observer) == null ? void 0 : _observer.disconnect();
1677
- observer = null;
1678
-
1679
- if (animationFrame) {
1680
- cancelAnimationFrame(frameId);
1681
- }
1682
- };
1683
- }
1684
-
1685
- /**
1686
- * Computes the `x` and `y` coordinates that will place the floating element
1687
- * next to a reference element when it is given a certain CSS positioning
1688
- * strategy.
1689
- */
1690
-
1691
- const computePosition = (reference, floating, options) => computePosition$1(reference, floating, {
1692
- platform,
1693
- ...options
1694
- });
1695
-
1696
- /*!
1697
- * tabbable 5.3.1
1698
- * @license MIT, https://github.com/focus-trap/tabbable/blob/master/LICENSE
1699
- */
1700
- var candidateSelectors = ['input', 'select', 'textarea', 'a[href]', 'button', '[tabindex]:not(slot)', 'audio[controls]', 'video[controls]', '[contenteditable]:not([contenteditable="false"])', 'details>summary:first-of-type', 'details'];
1701
- var candidateSelector = /* #__PURE__ */candidateSelectors.join(',');
1702
- var NoElement = typeof Element === 'undefined';
1703
- var matches = NoElement ? function () {} : Element.prototype.matches || Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;
1704
- var getRootNode = !NoElement && Element.prototype.getRootNode ? function (element) {
1705
- return element.getRootNode();
1706
- } : function (element) {
1707
- return element.ownerDocument;
1708
- };
1709
- /**
1710
- * @param {Element} el container to check in
1711
- * @param {boolean} includeContainer add container to check
1712
- * @param {(node: Element) => boolean} filter filter candidates
1713
- * @returns {Element[]}
1714
- */
1715
-
1716
- var getCandidates = function getCandidates(el, includeContainer, filter) {
1717
- var candidates = Array.prototype.slice.apply(el.querySelectorAll(candidateSelector));
1718
-
1719
- if (includeContainer && matches.call(el, candidateSelector)) {
1720
- candidates.unshift(el);
1721
- }
1722
-
1723
- candidates = candidates.filter(filter);
1724
- return candidates;
1725
- };
1726
- /**
1727
- * @callback GetShadowRoot
1728
- * @param {Element} element to check for shadow root
1729
- * @returns {ShadowRoot|boolean} ShadowRoot if available or boolean indicating if a shadowRoot is attached but not available.
1730
- */
1731
-
1732
- /**
1733
- * @typedef {Object} CandidatesScope
1734
- * @property {Element} scope contains inner candidates
1735
- * @property {Element[]} candidates
1736
- */
1737
-
1738
- /**
1739
- * @typedef {Object} IterativeOptions
1740
- * @property {GetShadowRoot|boolean} getShadowRoot true if shadow support is enabled; falsy if not;
1741
- * if a function, implies shadow support is enabled and either returns the shadow root of an element
1742
- * or a boolean stating if it has an undisclosed shadow root
1743
- * @property {(node: Element) => boolean} filter filter candidates
1744
- * @property {boolean} flatten if true then result will flatten any CandidatesScope into the returned list
1745
- */
1746
-
1747
- /**
1748
- * @param {Element[]} elements list of element containers to match candidates from
1749
- * @param {boolean} includeContainer add container list to check
1750
- * @param {IterativeOptions} options
1751
- * @returns {Array.<Element|CandidatesScope>}
1752
- */
1753
-
1754
-
1755
- var getCandidatesIteratively = function getCandidatesIteratively(elements, includeContainer, options) {
1756
- var candidates = [];
1757
- var elementsToCheck = Array.from(elements);
1758
-
1759
- while (elementsToCheck.length) {
1760
- var element = elementsToCheck.shift();
1761
-
1762
- if (element.tagName === 'SLOT') {
1763
- // add shadow dom slot scope (slot itself cannot be focusable)
1764
- var assigned = element.assignedElements();
1765
- var content = assigned.length ? assigned : element.children;
1766
- var nestedCandidates = getCandidatesIteratively(content, true, options);
1767
-
1768
- if (options.flatten) {
1769
- candidates.push.apply(candidates, nestedCandidates);
1770
- } else {
1771
- candidates.push({
1772
- scope: element,
1773
- candidates: nestedCandidates
1774
- });
1775
- }
1776
- } else {
1777
- // check candidate element
1778
- var validCandidate = matches.call(element, candidateSelector);
1779
-
1780
- if (validCandidate && options.filter(element) && (includeContainer || !elements.includes(element))) {
1781
- candidates.push(element);
1782
- } // iterate over shadow content if possible
1783
-
1784
-
1785
- var shadowRoot = element.shadowRoot || // check for an undisclosed shadow
1786
- typeof options.getShadowRoot === 'function' && options.getShadowRoot(element);
1787
-
1788
- if (shadowRoot) {
1789
- // add shadow dom scope IIF a shadow root node was given; otherwise, an undisclosed
1790
- // shadow exists, so look at light dom children as fallback BUT create a scope for any
1791
- // child candidates found because they're likely slotted elements (elements that are
1792
- // children of the web component element (which has the shadow), in the light dom, but
1793
- // slotted somewhere _inside_ the undisclosed shadow) -- the scope is created below,
1794
- // _after_ we return from this recursive call
1795
- var _nestedCandidates = getCandidatesIteratively(shadowRoot === true ? element.children : shadowRoot.children, true, options);
1796
-
1797
- if (options.flatten) {
1798
- candidates.push.apply(candidates, _nestedCandidates);
1799
- } else {
1800
- candidates.push({
1801
- scope: element,
1802
- candidates: _nestedCandidates
1803
- });
1804
- }
1805
- } else {
1806
- // there's not shadow so just dig into the element's (light dom) children
1807
- // __without__ giving the element special scope treatment
1808
- elementsToCheck.unshift.apply(elementsToCheck, element.children);
1809
- }
1810
- }
1811
- }
1812
-
1813
- return candidates;
1814
- };
1815
-
1816
- var getTabindex = function getTabindex(node, isScope) {
1817
- if (node.tabIndex < 0) {
1818
- // in Chrome, <details/>, <audio controls/> and <video controls/> elements get a default
1819
- // `tabIndex` of -1 when the 'tabindex' attribute isn't specified in the DOM,
1820
- // yet they are still part of the regular tab order; in FF, they get a default
1821
- // `tabIndex` of 0; since Chrome still puts those elements in the regular tab
1822
- // order, consider their tab index to be 0.
1823
- // Also browsers do not return `tabIndex` correctly for contentEditable nodes;
1824
- // so if they don't have a tabindex attribute specifically set, assume it's 0.
1825
- //
1826
- // isScope is positive for custom element with shadow root or slot that by default
1827
- // have tabIndex -1, but need to be sorted by document order in order for their
1828
- // content to be inserted in the correct position
1829
- if ((isScope || /^(AUDIO|VIDEO|DETAILS)$/.test(node.tagName) || node.isContentEditable) && isNaN(parseInt(node.getAttribute('tabindex'), 10))) {
1830
- return 0;
1831
- }
1832
- }
1833
-
1834
- return node.tabIndex;
1835
- };
1836
-
1837
- var sortOrderedTabbables = function sortOrderedTabbables(a, b) {
1838
- return a.tabIndex === b.tabIndex ? a.documentOrder - b.documentOrder : a.tabIndex - b.tabIndex;
1839
- };
1840
-
1841
- var isInput = function isInput(node) {
1842
- return node.tagName === 'INPUT';
1843
- };
1844
-
1845
- var isHiddenInput = function isHiddenInput(node) {
1846
- return isInput(node) && node.type === 'hidden';
1847
- };
1848
-
1849
- var isDetailsWithSummary = function isDetailsWithSummary(node) {
1850
- var r = node.tagName === 'DETAILS' && Array.prototype.slice.apply(node.children).some(function (child) {
1851
- return child.tagName === 'SUMMARY';
1852
- });
1853
- return r;
1854
- };
1855
-
1856
- var getCheckedRadio = function getCheckedRadio(nodes, form) {
1857
- for (var i = 0; i < nodes.length; i++) {
1858
- if (nodes[i].checked && nodes[i].form === form) {
1859
- return nodes[i];
1860
- }
1861
- }
1862
- };
1863
-
1864
- var isTabbableRadio = function isTabbableRadio(node) {
1865
- if (!node.name) {
1866
- return true;
1867
- }
1868
-
1869
- var radioScope = node.form || getRootNode(node);
1870
-
1871
- var queryRadios = function queryRadios(name) {
1872
- return radioScope.querySelectorAll('input[type="radio"][name="' + name + '"]');
1873
- };
1874
-
1875
- var radioSet;
1876
-
1877
- if (typeof window !== 'undefined' && typeof window.CSS !== 'undefined' && typeof window.CSS.escape === 'function') {
1878
- radioSet = queryRadios(window.CSS.escape(node.name));
1879
- } else {
1880
- try {
1881
- radioSet = queryRadios(node.name);
1882
- } catch (err) {
1883
- // eslint-disable-next-line no-console
1884
- console.error('Looks like you have a radio button with a name attribute containing invalid CSS selector characters and need the CSS.escape polyfill: %s', err.message);
1885
- return false;
1886
- }
1887
- }
1888
-
1889
- var checked = getCheckedRadio(radioSet, node.form);
1890
- return !checked || checked === node;
1891
- };
1892
-
1893
- var isRadio = function isRadio(node) {
1894
- return isInput(node) && node.type === 'radio';
1895
- };
1896
-
1897
- var isNonTabbableRadio = function isNonTabbableRadio(node) {
1898
- return isRadio(node) && !isTabbableRadio(node);
1899
- };
1900
-
1901
- var isZeroArea = function isZeroArea(node) {
1902
- var _node$getBoundingClie = node.getBoundingClientRect(),
1903
- width = _node$getBoundingClie.width,
1904
- height = _node$getBoundingClie.height;
1905
-
1906
- return width === 0 && height === 0;
1907
- };
1908
-
1909
- var isHidden = function isHidden(node, _ref) {
1910
- var displayCheck = _ref.displayCheck,
1911
- getShadowRoot = _ref.getShadowRoot;
1912
-
1913
- if (getComputedStyle(node).visibility === 'hidden') {
1914
- return true;
1915
- }
1916
-
1917
- var isDirectSummary = matches.call(node, 'details>summary:first-of-type');
1918
- var nodeUnderDetails = isDirectSummary ? node.parentElement : node;
1919
-
1920
- if (matches.call(nodeUnderDetails, 'details:not([open]) *')) {
1921
- return true;
1922
- }
1923
-
1924
- if (!displayCheck || displayCheck === 'full') {
1925
- if (typeof getShadowRoot === 'function') {
1926
- // figure out if we should consider the node to be in an undisclosed shadow and use the
1927
- // 'non-zero-area' fallback
1928
- var originalNode = node;
1929
-
1930
- while (node) {
1931
- var parentElement = node.parentElement;
1932
- var rootNode = getRootNode(node);
1933
-
1934
- if (parentElement && !parentElement.shadowRoot && getShadowRoot(parentElement) === true // check if there's an undisclosed shadow
1935
- ) {
1936
- // node has an undisclosed shadow which means we can only treat it as a black box, so we
1937
- // fall back to a non-zero-area test
1938
- return isZeroArea(node);
1939
- } else if (node.assignedSlot) {
1940
- // iterate up slot
1941
- node = node.assignedSlot;
1942
- } else if (!parentElement && rootNode !== node.ownerDocument) {
1943
- // cross shadow boundary
1944
- node = rootNode.host;
1945
- } else {
1946
- // iterate up normal dom
1947
- node = parentElement;
1948
- }
1949
- }
1950
-
1951
- node = originalNode;
1952
- } // else, `getShadowRoot` might be true, but all that does is enable shadow DOM support
1953
- // (i.e. it does not also presume that all nodes might have undisclosed shadows); or
1954
- // it might be a falsy value, which means shadow DOM support is disabled
1955
- // didn't find it sitting in an undisclosed shadow (or shadows are disabled) so now we
1956
- // can just test to see if it would normally be visible or not
1957
- // this works wherever the node is: if there's at least one client rect, it's
1958
- // somehow displayed; it also covers the CSS 'display: contents' case where the
1959
- // node itself is hidden in place of its contents; and there's no need to search
1960
- // up the hierarchy either
1961
-
1962
-
1963
- return !node.getClientRects().length;
1964
- } else if (displayCheck === 'non-zero-area') {
1965
- return isZeroArea(node);
1966
- }
1967
-
1968
- return false;
1969
- }; // form fields (nested) inside a disabled fieldset are not focusable/tabbable
1970
- // unless they are in the _first_ <legend> element of the top-most disabled
1971
- // fieldset
1972
-
1973
-
1974
- var isDisabledFromFieldset = function isDisabledFromFieldset(node) {
1975
- if (/^(INPUT|BUTTON|SELECT|TEXTAREA)$/.test(node.tagName)) {
1976
- var parentNode = node.parentElement; // check if `node` is contained in a disabled <fieldset>
1977
-
1978
- while (parentNode) {
1979
- if (parentNode.tagName === 'FIELDSET' && parentNode.disabled) {
1980
- // look for the first <legend> among the children of the disabled <fieldset>
1981
- for (var i = 0; i < parentNode.children.length; i++) {
1982
- var child = parentNode.children.item(i); // when the first <legend> (in document order) is found
1983
-
1984
- if (child.tagName === 'LEGEND') {
1985
- // if its parent <fieldset> is not nested in another disabled <fieldset>,
1986
- // return whether `node` is a descendant of its first <legend>
1987
- return matches.call(parentNode, 'fieldset[disabled] *') ? true : !child.contains(node);
1988
- }
1989
- } // the disabled <fieldset> containing `node` has no <legend>
1990
-
1991
-
1992
- return true;
1993
- }
1994
-
1995
- parentNode = parentNode.parentElement;
1996
- }
1997
- } // else, node's tabbable/focusable state should not be affected by a fieldset's
1998
- // enabled/disabled state
1999
-
2000
-
2001
- return false;
2002
- };
2003
-
2004
- var isNodeMatchingSelectorFocusable = function isNodeMatchingSelectorFocusable(options, node) {
2005
- if (node.disabled || isHiddenInput(node) || isHidden(node, options) || // For a details element with a summary, the summary element gets the focus
2006
- isDetailsWithSummary(node) || isDisabledFromFieldset(node)) {
2007
- return false;
2008
- }
2009
-
2010
- return true;
2011
- };
2012
-
2013
- var isNodeMatchingSelectorTabbable = function isNodeMatchingSelectorTabbable(options, node) {
2014
- if (isNonTabbableRadio(node) || getTabindex(node) < 0 || !isNodeMatchingSelectorFocusable(options, node)) {
2015
- return false;
2016
- }
2017
-
2018
- return true;
2019
- };
2020
- /**
2021
- * @param {Array.<Element|CandidatesScope>} candidates
2022
- * @returns Element[]
2023
- */
2024
-
2025
-
2026
- var sortByOrder = function sortByOrder(candidates) {
2027
- var regularTabbables = [];
2028
- var orderedTabbables = [];
2029
- candidates.forEach(function (item, i) {
2030
- var isScope = !!item.scope;
2031
- var element = isScope ? item.scope : item;
2032
- var candidateTabindex = getTabindex(element, isScope);
2033
- var elements = isScope ? sortByOrder(item.candidates) : element;
2034
-
2035
- if (candidateTabindex === 0) {
2036
- isScope ? regularTabbables.push.apply(regularTabbables, elements) : regularTabbables.push(element);
2037
- } else {
2038
- orderedTabbables.push({
2039
- documentOrder: i,
2040
- tabIndex: candidateTabindex,
2041
- item: item,
2042
- isScope: isScope,
2043
- content: elements
2044
- });
2045
- }
2046
- });
2047
- return orderedTabbables.sort(sortOrderedTabbables).reduce(function (acc, sortable) {
2048
- sortable.isScope ? acc.push.apply(acc, sortable.content) : acc.push(sortable.content);
2049
- return acc;
2050
- }, []).concat(regularTabbables);
2051
- };
2052
-
2053
- var tabbable = function tabbable(el, options) {
2054
- options = options || {};
2055
- var candidates;
2056
-
2057
- if (options.getShadowRoot) {
2058
- candidates = getCandidatesIteratively([el], options.includeContainer, {
2059
- filter: isNodeMatchingSelectorTabbable.bind(null, options),
2060
- flatten: false,
2061
- getShadowRoot: options.getShadowRoot
2062
- });
2063
- } else {
2064
- candidates = getCandidates(el, options.includeContainer, isNodeMatchingSelectorTabbable.bind(null, options));
2065
- }
2066
-
2067
- return sortByOrder(candidates);
2068
- };
2069
-
2070
- var focusable = function focusable(el, options) {
2071
- options = options || {};
2072
- var candidates;
2073
-
2074
- if (options.getShadowRoot) {
2075
- candidates = getCandidatesIteratively([el], options.includeContainer, {
2076
- filter: isNodeMatchingSelectorFocusable.bind(null, options),
2077
- flatten: true,
2078
- getShadowRoot: options.getShadowRoot
2079
- });
2080
- } else {
2081
- candidates = getCandidates(el, options.includeContainer, isNodeMatchingSelectorFocusable.bind(null, options));
2082
- }
2083
-
2084
- return candidates;
2085
- };
2086
-
2087
- var isTabbable = function isTabbable(node, options) {
2088
- options = options || {};
2089
-
2090
- if (!node) {
2091
- throw new Error('No node provided');
2092
- }
2093
-
2094
- if (matches.call(node, candidateSelector) === false) {
2095
- return false;
2096
- }
2097
-
2098
- return isNodeMatchingSelectorTabbable(options, node);
2099
- };
2100
-
2101
- var focusableCandidateSelector = /* #__PURE__ */candidateSelectors.concat('iframe').join(',');
2102
-
2103
- var isFocusable = function isFocusable(node, options) {
2104
- options = options || {};
2105
-
2106
- if (!node) {
2107
- throw new Error('No node provided');
2108
- }
2109
-
2110
- if (matches.call(node, focusableCandidateSelector) === false) {
2111
- return false;
2112
- }
2113
-
2114
- return isNodeMatchingSelectorFocusable(options, node);
2115
- };
2116
-
2117
- const firstTabbable = (container) => {
2118
- return (container ? tabbable(container, { includeContainer: true, getShadowRoot: true }) : []).shift();
2119
- };
2120
-
2121
- export { isFocusable as a, firstTabbable as b, autoUpdate as c, computePosition as d, flip as e, focusable as f, isTabbable as i, offset as o, tabbable as t };
2122
-
2123
- //# sourceMappingURL=first-tabbable.js.map