@aurodesignsystem/auro-formkit 1.6.0-beta.10

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 (814) hide show
  1. package/.husky/commit-msg +4 -0
  2. package/.husky/pre-commit +3 -0
  3. package/.turbo/cache/013a48308b893dac-meta.json +1 -0
  4. package/.turbo/cache/013a48308b893dac.tar.zst +0 -0
  5. package/.turbo/cache/049b9083252d38be-meta.json +1 -0
  6. package/.turbo/cache/049b9083252d38be.tar.zst +0 -0
  7. package/.turbo/cache/07ca42419b9f050c-meta.json +1 -0
  8. package/.turbo/cache/07ca42419b9f050c.tar.zst +0 -0
  9. package/.turbo/cache/0a1dd4481355cb0b-meta.json +1 -0
  10. package/.turbo/cache/0a1dd4481355cb0b.tar.zst +0 -0
  11. package/.turbo/cache/0cea4c1f34f3683b-meta.json +1 -0
  12. package/.turbo/cache/0cea4c1f34f3683b.tar.zst +0 -0
  13. package/.turbo/cache/13cf37c850bd8cf4-meta.json +1 -0
  14. package/.turbo/cache/13cf37c850bd8cf4.tar.zst +0 -0
  15. package/.turbo/cache/17259cf94d8f8925-meta.json +1 -0
  16. package/.turbo/cache/17259cf94d8f8925.tar.zst +0 -0
  17. package/.turbo/cache/1c99a949ec63ab35-meta.json +1 -0
  18. package/.turbo/cache/1c99a949ec63ab35.tar.zst +0 -0
  19. package/.turbo/cache/257a7a26ea72dbc5-meta.json +1 -0
  20. package/.turbo/cache/257a7a26ea72dbc5.tar.zst +0 -0
  21. package/.turbo/cache/3323eb841acb9c4e-meta.json +1 -0
  22. package/.turbo/cache/3323eb841acb9c4e.tar.zst +0 -0
  23. package/.turbo/cache/34ba23e2e2d652ad-meta.json +1 -0
  24. package/.turbo/cache/34ba23e2e2d652ad.tar.zst +0 -0
  25. package/.turbo/cache/368cd6fed7975ad2-meta.json +1 -0
  26. package/.turbo/cache/368cd6fed7975ad2.tar.zst +0 -0
  27. package/.turbo/cache/3924bce8e51f0ffa-meta.json +1 -0
  28. package/.turbo/cache/3924bce8e51f0ffa.tar.zst +0 -0
  29. package/.turbo/cache/3bf45120d0cc9bd8-meta.json +1 -0
  30. package/.turbo/cache/3bf45120d0cc9bd8.tar.zst +0 -0
  31. package/.turbo/cache/45035bf5c4147ccd-meta.json +1 -0
  32. package/.turbo/cache/45035bf5c4147ccd.tar.zst +0 -0
  33. package/.turbo/cache/4567487084a055b7-meta.json +1 -0
  34. package/.turbo/cache/4567487084a055b7.tar.zst +0 -0
  35. package/.turbo/cache/4763278a7d3dbc16-meta.json +1 -0
  36. package/.turbo/cache/4763278a7d3dbc16.tar.zst +0 -0
  37. package/.turbo/cache/549e6ef9f9ffd9a8-meta.json +1 -0
  38. package/.turbo/cache/549e6ef9f9ffd9a8.tar.zst +0 -0
  39. package/.turbo/cache/59ccd8430174883c-meta.json +1 -0
  40. package/.turbo/cache/59ccd8430174883c.tar.zst +0 -0
  41. package/.turbo/cache/5c16ce3cff5c9dff-meta.json +1 -0
  42. package/.turbo/cache/5c16ce3cff5c9dff.tar.zst +0 -0
  43. package/.turbo/cache/5f304c0f37ef25f3-meta.json +1 -0
  44. package/.turbo/cache/5f304c0f37ef25f3.tar.zst +0 -0
  45. package/.turbo/cache/64de7a53e02db647-meta.json +1 -0
  46. package/.turbo/cache/64de7a53e02db647.tar.zst +0 -0
  47. package/.turbo/cache/683d4c0e20c077a9-meta.json +1 -0
  48. package/.turbo/cache/683d4c0e20c077a9.tar.zst +0 -0
  49. package/.turbo/cache/691a74627ec57993-meta.json +1 -0
  50. package/.turbo/cache/691a74627ec57993.tar.zst +0 -0
  51. package/.turbo/cache/69aae513b7ec6c7d-meta.json +1 -0
  52. package/.turbo/cache/69aae513b7ec6c7d.tar.zst +0 -0
  53. package/.turbo/cache/6dd7058e6703cb35-meta.json +1 -0
  54. package/.turbo/cache/6dd7058e6703cb35.tar.zst +0 -0
  55. package/.turbo/cache/73e9073a5274616d-meta.json +1 -0
  56. package/.turbo/cache/73e9073a5274616d.tar.zst +0 -0
  57. package/.turbo/cache/773edc0f83c8c5a5-meta.json +1 -0
  58. package/.turbo/cache/773edc0f83c8c5a5.tar.zst +0 -0
  59. package/.turbo/cache/786a822763403879-meta.json +1 -0
  60. package/.turbo/cache/786a822763403879.tar.zst +0 -0
  61. package/.turbo/cache/80b5d974184a01df-meta.json +1 -0
  62. package/.turbo/cache/80b5d974184a01df.tar.zst +0 -0
  63. package/.turbo/cache/8954c6073396fadd-meta.json +1 -0
  64. package/.turbo/cache/8954c6073396fadd.tar.zst +0 -0
  65. package/.turbo/cache/8f8ffe35cc79d1a9-meta.json +1 -0
  66. package/.turbo/cache/8f8ffe35cc79d1a9.tar.zst +0 -0
  67. package/.turbo/cache/926d632729ca6536-meta.json +1 -0
  68. package/.turbo/cache/926d632729ca6536.tar.zst +0 -0
  69. package/.turbo/cache/92daa6d7c389d548-meta.json +1 -0
  70. package/.turbo/cache/92daa6d7c389d548.tar.zst +0 -0
  71. package/.turbo/cache/9a097d6576dadd64-meta.json +1 -0
  72. package/.turbo/cache/9a097d6576dadd64.tar.zst +0 -0
  73. package/.turbo/cache/9e7be41cc3a7ef43-meta.json +1 -0
  74. package/.turbo/cache/9e7be41cc3a7ef43.tar.zst +0 -0
  75. package/.turbo/cache/9ee793063ea89126-meta.json +1 -0
  76. package/.turbo/cache/9ee793063ea89126.tar.zst +0 -0
  77. package/.turbo/cache/a1558cef51c034da-meta.json +1 -0
  78. package/.turbo/cache/a1558cef51c034da.tar.zst +0 -0
  79. package/.turbo/cache/a24f2ff8e94e56e8-meta.json +1 -0
  80. package/.turbo/cache/a24f2ff8e94e56e8.tar.zst +0 -0
  81. package/.turbo/cache/a2705cf095a2ceb0-meta.json +1 -0
  82. package/.turbo/cache/a2705cf095a2ceb0.tar.zst +0 -0
  83. package/.turbo/cache/a33c0749886a41b5-meta.json +1 -0
  84. package/.turbo/cache/a33c0749886a41b5.tar.zst +0 -0
  85. package/.turbo/cache/a66b465385a30a2b-meta.json +1 -0
  86. package/.turbo/cache/a66b465385a30a2b.tar.zst +0 -0
  87. package/.turbo/cache/a77bc920ea508bb8-meta.json +1 -0
  88. package/.turbo/cache/a77bc920ea508bb8.tar.zst +0 -0
  89. package/.turbo/cache/b54fc4f664a7a5a0-meta.json +1 -0
  90. package/.turbo/cache/b54fc4f664a7a5a0.tar.zst +0 -0
  91. package/.turbo/cache/ba4418918621fbcd-meta.json +1 -0
  92. package/.turbo/cache/ba4418918621fbcd.tar.zst +0 -0
  93. package/.turbo/cache/be7c23c37b8ec74b-meta.json +1 -0
  94. package/.turbo/cache/be7c23c37b8ec74b.tar.zst +0 -0
  95. package/.turbo/cache/c1b72a92dec4fe37-meta.json +1 -0
  96. package/.turbo/cache/c1b72a92dec4fe37.tar.zst +0 -0
  97. package/.turbo/cache/caa0b4ac8d2a04dd-meta.json +1 -0
  98. package/.turbo/cache/caa0b4ac8d2a04dd.tar.zst +0 -0
  99. package/.turbo/cache/cc81de9c0b452a7c-meta.json +1 -0
  100. package/.turbo/cache/cc81de9c0b452a7c.tar.zst +0 -0
  101. package/.turbo/cache/dad1301ac69bcb85-meta.json +1 -0
  102. package/.turbo/cache/dad1301ac69bcb85.tar.zst +0 -0
  103. package/.turbo/cache/e25ac25a8a0ad126-meta.json +1 -0
  104. package/.turbo/cache/e25ac25a8a0ad126.tar.zst +0 -0
  105. package/.turbo/cache/e671573e4ef02c47-meta.json +1 -0
  106. package/.turbo/cache/e671573e4ef02c47.tar.zst +0 -0
  107. package/.turbo/cache/e86cee22dff5e281-meta.json +1 -0
  108. package/.turbo/cache/e86cee22dff5e281.tar.zst +0 -0
  109. package/.turbo/cache/e992dab20aeefbaf-meta.json +1 -0
  110. package/.turbo/cache/e992dab20aeefbaf.tar.zst +0 -0
  111. package/.turbo/cache/f680556a8e954eac-meta.json +1 -0
  112. package/.turbo/cache/f680556a8e954eac.tar.zst +0 -0
  113. package/.turbo/cache/fa132b5b5f0e75f8-meta.json +1 -0
  114. package/.turbo/cache/fa132b5b5f0e75f8.tar.zst +0 -0
  115. package/.turbo/cache/fbbe2704bf9cb90b-meta.json +1 -0
  116. package/.turbo/cache/fbbe2704bf9cb90b.tar.zst +0 -0
  117. package/.turbo/cache/ffec4500b911b85a-meta.json +1 -0
  118. package/.turbo/cache/ffec4500b911b85a.tar.zst +0 -0
  119. package/CHANGELOG.md +430 -0
  120. package/LICENSE +201 -0
  121. package/README.md +225 -0
  122. package/components/checkbox/.stylelintrc.json +3 -0
  123. package/components/checkbox/.turbo/turbo-build$colon$sass.log +98 -0
  124. package/components/checkbox/.turbo/turbo-build.log +182 -0
  125. package/components/checkbox/.turbo/turbo-bundler.log +13 -0
  126. package/components/checkbox/.turbo/turbo-postCss$colon$component.log +5 -0
  127. package/components/checkbox/.turbo/turbo-sass$colon$render.log +34 -0
  128. package/components/checkbox/.turbo/turbo-types.log +4 -0
  129. package/components/checkbox/README.md +187 -0
  130. package/components/checkbox/demo/api.html +48 -0
  131. package/components/checkbox/demo/api.js +1 -0
  132. package/components/checkbox/demo/api.md +272 -0
  133. package/components/checkbox/demo/api.min.js +845 -0
  134. package/components/checkbox/demo/index.js +8 -0
  135. package/components/checkbox/demo/index.md +306 -0
  136. package/components/checkbox/demo/index.min.js +845 -0
  137. package/components/checkbox/dist/auro-checkbox-group.d.ts +119 -0
  138. package/components/checkbox/dist/auro-checkbox-group.d.ts.map +1 -0
  139. package/components/checkbox/dist/auro-checkbox.d.ts +75 -0
  140. package/components/checkbox/dist/auro-checkbox.d.ts.map +1 -0
  141. package/components/checkbox/dist/index.d.ts +4 -0
  142. package/components/checkbox/dist/index.d.ts.map +1 -0
  143. package/components/checkbox/dist/index.js +844 -0
  144. package/components/checkbox/dist/styles/auro-checkbox-css.d.ts +3 -0
  145. package/components/checkbox/dist/styles/auro-checkbox-css.d.ts.map +1 -0
  146. package/components/checkbox/dist/styles/auro-checkbox-group-css.d.ts +3 -0
  147. package/components/checkbox/dist/styles/auro-checkbox-group-css.d.ts.map +1 -0
  148. package/components/checkbox/dist/styles/color-css.d.ts +3 -0
  149. package/components/checkbox/dist/styles/color-css.d.ts.map +1 -0
  150. package/components/checkbox/dist/styles/colorGroup-css.d.ts +3 -0
  151. package/components/checkbox/dist/styles/colorGroup-css.d.ts.map +1 -0
  152. package/components/checkbox/dist/styles/tokens-css.d.ts +3 -0
  153. package/components/checkbox/dist/styles/tokens-css.d.ts.map +1 -0
  154. package/components/checkbox/node_modules/chalk/package.json +83 -0
  155. package/components/checkbox/node_modules/chalk/readme.md +325 -0
  156. package/components/checkbox/node_modules/chalk/source/index.d.ts +320 -0
  157. package/components/checkbox/node_modules/chalk/source/index.js +225 -0
  158. package/components/checkbox/node_modules/chalk/source/utilities.js +33 -0
  159. package/components/checkbox/node_modules/chalk/source/vendor/ansi-styles/index.d.ts +236 -0
  160. package/components/checkbox/node_modules/chalk/source/vendor/ansi-styles/index.js +223 -0
  161. package/components/checkbox/node_modules/chalk/source/vendor/supports-color/browser.d.ts +1 -0
  162. package/components/checkbox/node_modules/chalk/source/vendor/supports-color/browser.js +30 -0
  163. package/components/checkbox/node_modules/chalk/source/vendor/supports-color/index.d.ts +55 -0
  164. package/components/checkbox/node_modules/chalk/source/vendor/supports-color/index.js +182 -0
  165. package/components/checkbox/package.json +68 -0
  166. package/components/checkbox/src/auro-checkbox-group.js +319 -0
  167. package/components/checkbox/src/auro-checkbox.js +184 -0
  168. package/components/checkbox/src/index.js +8 -0
  169. package/components/checkbox/src/styles/auro-checkbox-css.js +2 -0
  170. package/components/checkbox/src/styles/auro-checkbox-group-css.js +2 -0
  171. package/components/checkbox/src/styles/auro-checkbox-group.css +26 -0
  172. package/components/checkbox/src/styles/auro-checkbox-group.scss +38 -0
  173. package/components/checkbox/src/styles/auro-checkbox.css +123 -0
  174. package/components/checkbox/src/styles/auro-checkbox.scss +100 -0
  175. package/components/checkbox/src/styles/color-css.js +2 -0
  176. package/components/checkbox/src/styles/color.css +84 -0
  177. package/components/checkbox/src/styles/color.scss +118 -0
  178. package/components/checkbox/src/styles/colorGroup-css.js +2 -0
  179. package/components/checkbox/src/styles/colorGroup.css +16 -0
  180. package/components/checkbox/src/styles/colorGroup.scss +24 -0
  181. package/components/checkbox/src/styles/tokens-css.js +2 -0
  182. package/components/checkbox/src/styles/tokens.css +9 -0
  183. package/components/checkbox/src/styles/tokens.scss +11 -0
  184. package/components/combobox/.stylelintrc.json +3 -0
  185. package/components/combobox/.turbo/turbo-build$colon$sass.log +46 -0
  186. package/components/combobox/.turbo/turbo-build.log +160 -0
  187. package/components/combobox/.turbo/turbo-postCss$colon$component.log +5 -0
  188. package/components/combobox/.turbo/turbo-sass$colon$render.log +10 -0
  189. package/components/combobox/README.md +200 -0
  190. package/components/combobox/demo/api.html +55 -0
  191. package/components/combobox/demo/api.js +34 -0
  192. package/components/combobox/demo/api.md +816 -0
  193. package/components/combobox/demo/api.min.js +9165 -0
  194. package/components/combobox/demo/index.js +26 -0
  195. package/components/combobox/demo/index.md +626 -0
  196. package/components/combobox/demo/index.min.js +9028 -0
  197. package/components/combobox/dist/auro-combobox.d.ts +241 -0
  198. package/components/combobox/dist/auro-combobox.d.ts.map +1 -0
  199. package/components/combobox/dist/formkit/auro-dropdownVersion.d.ts +3 -0
  200. package/components/combobox/dist/formkit/auro-dropdownVersion.d.ts.map +1 -0
  201. package/components/combobox/dist/formkit/auro-inputVersion.d.ts +3 -0
  202. package/components/combobox/dist/formkit/auro-inputVersion.d.ts.map +1 -0
  203. package/components/combobox/dist/index.d.ts +3 -0
  204. package/components/combobox/dist/index.d.ts.map +1 -0
  205. package/components/combobox/dist/index.js +7898 -0
  206. package/components/combobox/dist/styles/style-css.d.ts +3 -0
  207. package/components/combobox/dist/styles/style-css.d.ts.map +1 -0
  208. package/components/combobox/node_modules/chalk/package.json +83 -0
  209. package/components/combobox/node_modules/chalk/readme.md +325 -0
  210. package/components/combobox/node_modules/chalk/source/index.d.ts +320 -0
  211. package/components/combobox/node_modules/chalk/source/index.js +225 -0
  212. package/components/combobox/node_modules/chalk/source/utilities.js +33 -0
  213. package/components/combobox/node_modules/chalk/source/vendor/ansi-styles/index.d.ts +236 -0
  214. package/components/combobox/node_modules/chalk/source/vendor/ansi-styles/index.js +223 -0
  215. package/components/combobox/node_modules/chalk/source/vendor/supports-color/browser.d.ts +1 -0
  216. package/components/combobox/node_modules/chalk/source/vendor/supports-color/browser.js +30 -0
  217. package/components/combobox/node_modules/chalk/source/vendor/supports-color/index.d.ts +55 -0
  218. package/components/combobox/node_modules/chalk/source/vendor/supports-color/index.js +182 -0
  219. package/components/combobox/package.json +67 -0
  220. package/components/combobox/src/auro-combobox.js +711 -0
  221. package/components/combobox/src/formkit/auro-dropdownVersion.js +1 -0
  222. package/components/combobox/src/formkit/auro-inputVersion.js +1 -0
  223. package/components/combobox/src/index.js +6 -0
  224. package/components/combobox/src/styles/style-css.js +2 -0
  225. package/components/combobox/src/styles/style.css +60 -0
  226. package/components/combobox/src/styles/style.scss +46 -0
  227. package/components/counter/.stylelintrc.json +3 -0
  228. package/components/counter/.turbo/turbo-build$colon$sass.log +66 -0
  229. package/components/counter/.turbo/turbo-build.log +87 -0
  230. package/components/counter/.turbo/turbo-bundler.log +13 -0
  231. package/components/counter/.turbo/turbo-postCss$colon$component.log +5 -0
  232. package/components/counter/.turbo/turbo-sass$colon$render.log +16 -0
  233. package/components/counter/.turbo/turbo-types.log +4 -0
  234. package/components/counter/demo/api.html +52 -0
  235. package/components/counter/demo/api.js +16 -0
  236. package/components/counter/demo/api.md +1053 -0
  237. package/components/counter/demo/api.min.js +115 -0
  238. package/components/counter/demo/index.js +20 -0
  239. package/components/counter/demo/index.min.js +71 -0
  240. package/components/counter/dist/auro-counter-group.d.ts +20 -0
  241. package/components/counter/dist/auro-counter-group.d.ts.map +1 -0
  242. package/components/counter/dist/auro-counter.d.ts +6 -0
  243. package/components/counter/dist/auro-counter.d.ts.map +1 -0
  244. package/components/counter/dist/index.d.ts +4 -0
  245. package/components/counter/dist/index.d.ts.map +1 -0
  246. package/components/counter/dist/index.js +110 -0
  247. package/components/counter/dist/styles/counter-group-css.d.ts +3 -0
  248. package/components/counter/dist/styles/counter-group-css.d.ts.map +1 -0
  249. package/components/counter/dist/styles/style-css.d.ts +3 -0
  250. package/components/counter/dist/styles/style-css.d.ts.map +1 -0
  251. package/components/counter/node_modules/chalk/package.json +83 -0
  252. package/components/counter/node_modules/chalk/readme.md +325 -0
  253. package/components/counter/node_modules/chalk/source/index.d.ts +320 -0
  254. package/components/counter/node_modules/chalk/source/index.js +225 -0
  255. package/components/counter/node_modules/chalk/source/utilities.js +33 -0
  256. package/components/counter/node_modules/chalk/source/vendor/ansi-styles/index.d.ts +236 -0
  257. package/components/counter/node_modules/chalk/source/vendor/ansi-styles/index.js +223 -0
  258. package/components/counter/node_modules/chalk/source/vendor/supports-color/browser.d.ts +1 -0
  259. package/components/counter/node_modules/chalk/source/vendor/supports-color/browser.js +30 -0
  260. package/components/counter/node_modules/chalk/source/vendor/supports-color/index.d.ts +55 -0
  261. package/components/counter/node_modules/chalk/source/vendor/supports-color/index.js +182 -0
  262. package/components/counter/package.json +50 -0
  263. package/components/counter/src/auro-counter-group.js +48 -0
  264. package/components/counter/src/auro-counter.js +29 -0
  265. package/components/counter/src/index.js +8 -0
  266. package/components/counter/src/styles/counter-group-css.js +2 -0
  267. package/components/counter/src/styles/counter-group.css +4 -0
  268. package/components/counter/src/styles/counter-group.scss +17 -0
  269. package/components/counter/src/styles/style-css.js +2 -0
  270. package/components/counter/src/styles/style.css +4 -0
  271. package/components/counter/src/styles/style.scss +17 -0
  272. package/components/datepicker/.stylelintrc.json +3 -0
  273. package/components/datepicker/.turbo/turbo-build$colon$sass.log +352 -0
  274. package/components/datepicker/.turbo/turbo-build.log +489 -0
  275. package/components/datepicker/.turbo/turbo-postCss$colon$component.log +5 -0
  276. package/components/datepicker/.turbo/turbo-sass$colon$render.log +58 -0
  277. package/components/datepicker/README.md +181 -0
  278. package/components/datepicker/demo/api.html +58 -0
  279. package/components/datepicker/demo/api.js +33 -0
  280. package/components/datepicker/demo/api.md +1172 -0
  281. package/components/datepicker/demo/api.min.js +18466 -0
  282. package/components/datepicker/demo/index.js +19 -0
  283. package/components/datepicker/demo/index.md +107 -0
  284. package/components/datepicker/demo/index.min.js +18195 -0
  285. package/components/datepicker/dist/auro-calendar-cell.d.ts +163 -0
  286. package/components/datepicker/dist/auro-calendar-cell.d.ts.map +1 -0
  287. package/components/datepicker/dist/auro-calendar-month.d.ts +5 -0
  288. package/components/datepicker/dist/auro-calendar-month.d.ts.map +1 -0
  289. package/components/datepicker/dist/auro-calendar.d.ts +105 -0
  290. package/components/datepicker/dist/auro-calendar.d.ts.map +1 -0
  291. package/components/datepicker/dist/auro-datepicker.d.ts +336 -0
  292. package/components/datepicker/dist/auro-datepicker.d.ts.map +1 -0
  293. package/components/datepicker/dist/dropdownVersion.d.ts +1 -0
  294. package/components/datepicker/dist/dropdownVersion.d.ts.map +1 -0
  295. package/components/datepicker/dist/formkit/auro-dropdownVersion.d.ts +3 -0
  296. package/components/datepicker/dist/formkit/auro-dropdownVersion.d.ts.map +1 -0
  297. package/components/datepicker/dist/formkit/auro-inputVersion.d.ts +3 -0
  298. package/components/datepicker/dist/formkit/auro-inputVersion.d.ts.map +1 -0
  299. package/components/datepicker/dist/index.d.ts +3 -0
  300. package/components/datepicker/dist/index.d.ts.map +1 -0
  301. package/components/datepicker/dist/index.js +18191 -0
  302. package/components/datepicker/dist/popoverVersion.d.ts +3 -0
  303. package/components/datepicker/dist/popoverVersion.d.ts.map +1 -0
  304. package/components/datepicker/dist/styles/color-calendar-css.d.ts +3 -0
  305. package/components/datepicker/dist/styles/color-calendar-css.d.ts.map +1 -0
  306. package/components/datepicker/dist/styles/color-cell-css.d.ts +3 -0
  307. package/components/datepicker/dist/styles/color-cell-css.d.ts.map +1 -0
  308. package/components/datepicker/dist/styles/color-css.d.ts +3 -0
  309. package/components/datepicker/dist/styles/color-css.d.ts.map +1 -0
  310. package/components/datepicker/dist/styles/color-month-css.d.ts +3 -0
  311. package/components/datepicker/dist/styles/color-month-css.d.ts.map +1 -0
  312. package/components/datepicker/dist/styles/style-auro-calendar-cell-css.d.ts +3 -0
  313. package/components/datepicker/dist/styles/style-auro-calendar-cell-css.d.ts.map +1 -0
  314. package/components/datepicker/dist/styles/style-auro-calendar-css.d.ts +3 -0
  315. package/components/datepicker/dist/styles/style-auro-calendar-css.d.ts.map +1 -0
  316. package/components/datepicker/dist/styles/style-auro-calendar-month-css.d.ts +3 -0
  317. package/components/datepicker/dist/styles/style-auro-calendar-month-css.d.ts.map +1 -0
  318. package/components/datepicker/dist/styles/style-css.d.ts +3 -0
  319. package/components/datepicker/dist/styles/style-css.d.ts.map +1 -0
  320. package/components/datepicker/dist/styles/tokens-css.d.ts +3 -0
  321. package/components/datepicker/dist/styles/tokens-css.d.ts.map +1 -0
  322. package/components/datepicker/dist/utilities.d.ts +47 -0
  323. package/components/datepicker/dist/utilities.d.ts.map +1 -0
  324. package/components/datepicker/dist/utilitiesCalendar.d.ts +38 -0
  325. package/components/datepicker/dist/utilitiesCalendar.d.ts.map +1 -0
  326. package/components/datepicker/dist/utilitiesCalendarRender.d.ts +51 -0
  327. package/components/datepicker/dist/utilitiesCalendarRender.d.ts.map +1 -0
  328. package/components/datepicker/dist/vendor/wc-range-datepicker/day.d.ts +6 -0
  329. package/components/datepicker/dist/vendor/wc-range-datepicker/day.d.ts.map +1 -0
  330. package/components/datepicker/dist/vendor/wc-range-datepicker/range-datepicker-calendar.d.ts +61 -0
  331. package/components/datepicker/dist/vendor/wc-range-datepicker/range-datepicker-calendar.d.ts.map +1 -0
  332. package/components/datepicker/dist/vendor/wc-range-datepicker/range-datepicker-cell.d.ts +2 -0
  333. package/components/datepicker/dist/vendor/wc-range-datepicker/range-datepicker-cell.d.ts.map +1 -0
  334. package/components/datepicker/dist/vendor/wc-range-datepicker/range-datepicker.d.ts +58 -0
  335. package/components/datepicker/dist/vendor/wc-range-datepicker/range-datepicker.d.ts.map +1 -0
  336. package/components/datepicker/node_modules/chalk/package.json +83 -0
  337. package/components/datepicker/node_modules/chalk/readme.md +325 -0
  338. package/components/datepicker/node_modules/chalk/source/index.d.ts +320 -0
  339. package/components/datepicker/node_modules/chalk/source/index.js +225 -0
  340. package/components/datepicker/node_modules/chalk/source/utilities.js +33 -0
  341. package/components/datepicker/node_modules/chalk/source/vendor/ansi-styles/index.d.ts +236 -0
  342. package/components/datepicker/node_modules/chalk/source/vendor/ansi-styles/index.js +223 -0
  343. package/components/datepicker/node_modules/chalk/source/vendor/supports-color/browser.d.ts +1 -0
  344. package/components/datepicker/node_modules/chalk/source/vendor/supports-color/browser.js +30 -0
  345. package/components/datepicker/node_modules/chalk/source/vendor/supports-color/index.d.ts +55 -0
  346. package/components/datepicker/node_modules/chalk/source/vendor/supports-color/index.js +182 -0
  347. package/components/datepicker/node_modules/rollup-plugin-serve/LICENSE.md +21 -0
  348. package/components/datepicker/node_modules/rollup-plugin-serve/README.md +137 -0
  349. package/components/datepicker/node_modules/rollup-plugin-serve/dist/index.cjs +181 -0
  350. package/components/datepicker/node_modules/rollup-plugin-serve/dist/index.mjs +173 -0
  351. package/components/datepicker/node_modules/rollup-plugin-serve/index.d.ts +75 -0
  352. package/components/datepicker/node_modules/rollup-plugin-serve/package.json +51 -0
  353. package/components/datepicker/package.json +79 -0
  354. package/components/datepicker/src/auro-calendar-cell.js +381 -0
  355. package/components/datepicker/src/auro-calendar-month.js +128 -0
  356. package/components/datepicker/src/auro-calendar.js +329 -0
  357. package/components/datepicker/src/auro-datepicker.js +969 -0
  358. package/components/datepicker/src/dropdownVersion.js +0 -0
  359. package/components/datepicker/src/formkit/auro-dropdownVersion.js +1 -0
  360. package/components/datepicker/src/formkit/auro-inputVersion.js +1 -0
  361. package/components/datepicker/src/index.js +6 -0
  362. package/components/datepicker/src/popoverVersion.js +1 -0
  363. package/components/datepicker/src/styles/color-calendar-css.js +2 -0
  364. package/components/datepicker/src/styles/color-calendar.css +35 -0
  365. package/components/datepicker/src/styles/color-calendar.scss +51 -0
  366. package/components/datepicker/src/styles/color-cell-css.js +2 -0
  367. package/components/datepicker/src/styles/color-cell.css +45 -0
  368. package/components/datepicker/src/styles/color-cell.scss +73 -0
  369. package/components/datepicker/src/styles/color-css.js +2 -0
  370. package/components/datepicker/src/styles/color-month-css.js +2 -0
  371. package/components/datepicker/src/styles/color-month.css +34 -0
  372. package/components/datepicker/src/styles/color-month.scss +27 -0
  373. package/components/datepicker/src/styles/color.css +43 -0
  374. package/components/datepicker/src/styles/color.scss +30 -0
  375. package/components/datepicker/src/styles/style-auro-calendar-cell-css.js +2 -0
  376. package/components/datepicker/src/styles/style-auro-calendar-cell.css +123 -0
  377. package/components/datepicker/src/styles/style-auro-calendar-cell.scss +147 -0
  378. package/components/datepicker/src/styles/style-auro-calendar-css.js +2 -0
  379. package/components/datepicker/src/styles/style-auro-calendar-month-css.js +2 -0
  380. package/components/datepicker/src/styles/style-auro-calendar-month.css +121 -0
  381. package/components/datepicker/src/styles/style-auro-calendar-month.scss +141 -0
  382. package/components/datepicker/src/styles/style-auro-calendar.css +152 -0
  383. package/components/datepicker/src/styles/style-auro-calendar.scss +191 -0
  384. package/components/datepicker/src/styles/style-css.js +2 -0
  385. package/components/datepicker/src/styles/style.css +111 -0
  386. package/components/datepicker/src/styles/style.scss +107 -0
  387. package/components/datepicker/src/styles/tokens-css.js +2 -0
  388. package/components/datepicker/src/styles/tokens.css +22 -0
  389. package/components/datepicker/src/styles/tokens.scss +25 -0
  390. package/components/datepicker/src/utilities.js +87 -0
  391. package/components/datepicker/src/utilitiesCalendar.js +138 -0
  392. package/components/datepicker/src/utilitiesCalendarRender.js +156 -0
  393. package/components/datepicker/src/vendor/wc-range-datepicker/day.js +8 -0
  394. package/components/datepicker/src/vendor/wc-range-datepicker/range-datepicker-calendar.js +521 -0
  395. package/components/datepicker/src/vendor/wc-range-datepicker/range-datepicker-cell.js +211 -0
  396. package/components/datepicker/src/vendor/wc-range-datepicker/range-datepicker.js +254 -0
  397. package/components/dropdown/.stylelintrc.json +3 -0
  398. package/components/dropdown/.turbo/turbo-build$colon$sass.log +75 -0
  399. package/components/dropdown/.turbo/turbo-build$colon$version.log +7 -0
  400. package/components/dropdown/.turbo/turbo-build.log +206 -0
  401. package/components/dropdown/.turbo/turbo-bundler.log +13 -0
  402. package/components/dropdown/.turbo/turbo-postCss$colon$component.log +5 -0
  403. package/components/dropdown/.turbo/turbo-sass$colon$render.log +34 -0
  404. package/components/dropdown/.turbo/turbo-types.log +4 -0
  405. package/components/dropdown/README.md +188 -0
  406. package/components/dropdown/demo/api.html +55 -0
  407. package/components/dropdown/demo/api.js +21 -0
  408. package/components/dropdown/demo/api.md +1179 -0
  409. package/components/dropdown/demo/api.min.js +2885 -0
  410. package/components/dropdown/demo/index.js +22 -0
  411. package/components/dropdown/demo/index.md +404 -0
  412. package/components/dropdown/demo/index.min.js +2851 -0
  413. package/components/dropdown/dist/auro-dropdown.d.ts +194 -0
  414. package/components/dropdown/dist/auro-dropdown.d.ts.map +1 -0
  415. package/components/dropdown/dist/auro-dropdownBib.d.ts +33 -0
  416. package/components/dropdown/dist/auro-dropdownBib.d.ts.map +1 -0
  417. package/components/dropdown/dist/iconVersion.d.ts +3 -0
  418. package/components/dropdown/dist/iconVersion.d.ts.map +1 -0
  419. package/components/dropdown/dist/index.d.ts +3 -0
  420. package/components/dropdown/dist/index.d.ts.map +1 -0
  421. package/components/dropdown/dist/index.js +2842 -0
  422. package/components/dropdown/dist/styles/bibColors-css.d.ts +3 -0
  423. package/components/dropdown/dist/styles/bibColors-css.d.ts.map +1 -0
  424. package/components/dropdown/dist/styles/bibStyles-css.d.ts +3 -0
  425. package/components/dropdown/dist/styles/bibStyles-css.d.ts.map +1 -0
  426. package/components/dropdown/dist/styles/color-css.d.ts +3 -0
  427. package/components/dropdown/dist/styles/color-css.d.ts.map +1 -0
  428. package/components/dropdown/dist/styles/style-css.d.ts +3 -0
  429. package/components/dropdown/dist/styles/style-css.d.ts.map +1 -0
  430. package/components/dropdown/dist/styles/tokens-css.d.ts +3 -0
  431. package/components/dropdown/dist/styles/tokens-css.d.ts.map +1 -0
  432. package/components/dropdown/node_modules/chalk/package.json +83 -0
  433. package/components/dropdown/node_modules/chalk/readme.md +325 -0
  434. package/components/dropdown/node_modules/chalk/source/index.d.ts +320 -0
  435. package/components/dropdown/node_modules/chalk/source/index.js +225 -0
  436. package/components/dropdown/node_modules/chalk/source/utilities.js +33 -0
  437. package/components/dropdown/node_modules/chalk/source/vendor/ansi-styles/index.d.ts +236 -0
  438. package/components/dropdown/node_modules/chalk/source/vendor/ansi-styles/index.js +223 -0
  439. package/components/dropdown/node_modules/chalk/source/vendor/supports-color/browser.d.ts +1 -0
  440. package/components/dropdown/node_modules/chalk/source/vendor/supports-color/browser.js +30 -0
  441. package/components/dropdown/node_modules/chalk/source/vendor/supports-color/index.d.ts +55 -0
  442. package/components/dropdown/node_modules/chalk/source/vendor/supports-color/index.js +182 -0
  443. package/components/dropdown/package.json +57 -0
  444. package/components/dropdown/src/auro-dropdown.js +359 -0
  445. package/components/dropdown/src/auro-dropdownBib.js +97 -0
  446. package/components/dropdown/src/iconVersion.js +1 -0
  447. package/components/dropdown/src/index.js +6 -0
  448. package/components/dropdown/src/styles/bibColors-css.js +2 -0
  449. package/components/dropdown/src/styles/bibColors.css +6 -0
  450. package/components/dropdown/src/styles/bibColors.scss +18 -0
  451. package/components/dropdown/src/styles/bibStyles-css.js +2 -0
  452. package/components/dropdown/src/styles/bibStyles.css +48 -0
  453. package/components/dropdown/src/styles/bibStyles.scss +67 -0
  454. package/components/dropdown/src/styles/color-css.js +2 -0
  455. package/components/dropdown/src/styles/color.css +59 -0
  456. package/components/dropdown/src/styles/color.scss +79 -0
  457. package/components/dropdown/src/styles/style-css.js +2 -0
  458. package/components/dropdown/src/styles/style.css +88 -0
  459. package/components/dropdown/src/styles/style.scss +117 -0
  460. package/components/dropdown/src/styles/tokens-css.js +2 -0
  461. package/components/dropdown/src/styles/tokens.css +13 -0
  462. package/components/dropdown/src/styles/tokens.scss +15 -0
  463. package/components/form/.stylelintrc.json +3 -0
  464. package/components/form/.turbo/turbo-build$colon$sass.log +57 -0
  465. package/components/form/.turbo/turbo-build$colon$version.log +4 -0
  466. package/components/form/.turbo/turbo-build.log +113 -0
  467. package/components/form/.turbo/turbo-bundler.log +13 -0
  468. package/components/form/.turbo/turbo-postCss$colon$component.log +5 -0
  469. package/components/form/.turbo/turbo-sass$colon$render.log +10 -0
  470. package/components/form/.turbo/turbo-types.log +4 -0
  471. package/components/form/README.md +186 -0
  472. package/components/form/demo/api.html +48 -0
  473. package/components/form/demo/api.js +3 -0
  474. package/components/form/demo/api.md +0 -0
  475. package/components/form/demo/api.min.js +160 -0
  476. package/components/form/demo/index.js +4 -0
  477. package/components/form/demo/index.md +40 -0
  478. package/components/form/demo/index.min.js +161 -0
  479. package/components/form/dist/auro-form.d.ts +26 -0
  480. package/components/form/dist/auro-form.d.ts.map +1 -0
  481. package/components/form/dist/index.d.ts +3 -0
  482. package/components/form/dist/index.d.ts.map +1 -0
  483. package/components/form/dist/index.js +162 -0
  484. package/components/form/dist/styles/style-css.d.ts +3 -0
  485. package/components/form/dist/styles/style-css.d.ts.map +1 -0
  486. package/components/form/node_modules/chalk/package.json +83 -0
  487. package/components/form/node_modules/chalk/readme.md +325 -0
  488. package/components/form/node_modules/chalk/source/index.d.ts +320 -0
  489. package/components/form/node_modules/chalk/source/index.js +225 -0
  490. package/components/form/node_modules/chalk/source/utilities.js +33 -0
  491. package/components/form/node_modules/chalk/source/vendor/ansi-styles/index.d.ts +236 -0
  492. package/components/form/node_modules/chalk/source/vendor/ansi-styles/index.js +223 -0
  493. package/components/form/node_modules/chalk/source/vendor/supports-color/browser.d.ts +1 -0
  494. package/components/form/node_modules/chalk/source/vendor/supports-color/browser.js +30 -0
  495. package/components/form/node_modules/chalk/source/vendor/supports-color/index.d.ts +55 -0
  496. package/components/form/node_modules/chalk/source/vendor/supports-color/index.js +182 -0
  497. package/components/form/package.json +72 -0
  498. package/components/form/src/auro-form.js +74 -0
  499. package/components/form/src/index.js +6 -0
  500. package/components/form/src/styles/style-css.js +2 -0
  501. package/components/form/src/styles/style.css +36 -0
  502. package/components/form/src/styles/style.scss +37 -0
  503. package/components/input/.stylelintrc.json +3 -0
  504. package/components/input/.turbo/turbo-build$colon$sass.log +148 -0
  505. package/components/input/.turbo/turbo-build$colon$version.log +10 -0
  506. package/components/input/.turbo/turbo-build.log +300 -0
  507. package/components/input/.turbo/turbo-bundler.log +13 -0
  508. package/components/input/.turbo/turbo-postCss$colon$component.log +5 -0
  509. package/components/input/.turbo/turbo-sass$colon$render.log +52 -0
  510. package/components/input/.turbo/turbo-types.log +4 -0
  511. package/components/input/README.md +176 -0
  512. package/components/input/demo/api.html +40 -0
  513. package/components/input/demo/api.js +25 -0
  514. package/components/input/demo/api.md +1251 -0
  515. package/components/input/demo/api.min.js +4070 -0
  516. package/components/input/demo/index.js +20 -0
  517. package/components/input/demo/index.md +253 -0
  518. package/components/input/demo/index.min.js +4012 -0
  519. package/components/input/dist/auro-input.d.ts +29 -0
  520. package/components/input/dist/auro-input.d.ts.map +1 -0
  521. package/components/input/dist/base-input.d.ts +359 -0
  522. package/components/input/dist/base-input.d.ts.map +1 -0
  523. package/components/input/dist/buttonVersion.d.ts +3 -0
  524. package/components/input/dist/buttonVersion.d.ts.map +1 -0
  525. package/components/input/dist/i18n.d.ts +19 -0
  526. package/components/input/dist/i18n.d.ts.map +1 -0
  527. package/components/input/dist/iconVersion.d.ts +3 -0
  528. package/components/input/dist/iconVersion.d.ts.map +1 -0
  529. package/components/input/dist/index.d.ts +3 -0
  530. package/components/input/dist/index.d.ts.map +1 -0
  531. package/components/input/dist/index.js +3979 -0
  532. package/components/input/dist/styles/borders-css.d.ts +3 -0
  533. package/components/input/dist/styles/borders-css.d.ts.map +1 -0
  534. package/components/input/dist/styles/color-css.d.ts +3 -0
  535. package/components/input/dist/styles/color-css.d.ts.map +1 -0
  536. package/components/input/dist/styles/helpText-css.d.ts +3 -0
  537. package/components/input/dist/styles/helpText-css.d.ts.map +1 -0
  538. package/components/input/dist/styles/input-css.d.ts +3 -0
  539. package/components/input/dist/styles/input-css.d.ts.map +1 -0
  540. package/components/input/dist/styles/label-css.d.ts +3 -0
  541. package/components/input/dist/styles/label-css.d.ts.map +1 -0
  542. package/components/input/dist/styles/notificationIcons-css.d.ts +3 -0
  543. package/components/input/dist/styles/notificationIcons-css.d.ts.map +1 -0
  544. package/components/input/dist/styles/style-css.d.ts +3 -0
  545. package/components/input/dist/styles/style-css.d.ts.map +1 -0
  546. package/components/input/dist/styles/tokens-css.d.ts +3 -0
  547. package/components/input/dist/styles/tokens-css.d.ts.map +1 -0
  548. package/components/input/node_modules/chalk/package.json +83 -0
  549. package/components/input/node_modules/chalk/readme.md +325 -0
  550. package/components/input/node_modules/chalk/source/index.d.ts +320 -0
  551. package/components/input/node_modules/chalk/source/index.js +225 -0
  552. package/components/input/node_modules/chalk/source/utilities.js +33 -0
  553. package/components/input/node_modules/chalk/source/vendor/ansi-styles/index.d.ts +236 -0
  554. package/components/input/node_modules/chalk/source/vendor/ansi-styles/index.js +223 -0
  555. package/components/input/node_modules/chalk/source/vendor/supports-color/browser.d.ts +1 -0
  556. package/components/input/node_modules/chalk/source/vendor/supports-color/browser.js +30 -0
  557. package/components/input/node_modules/chalk/source/vendor/supports-color/index.d.ts +55 -0
  558. package/components/input/node_modules/chalk/source/vendor/supports-color/index.js +182 -0
  559. package/components/input/package.json +75 -0
  560. package/components/input/src/auro-input.js +242 -0
  561. package/components/input/src/base-input.js +942 -0
  562. package/components/input/src/buttonVersion.js +1 -0
  563. package/components/input/src/i18n.js +102 -0
  564. package/components/input/src/iconVersion.js +1 -0
  565. package/components/input/src/index.js +6 -0
  566. package/components/input/src/styles/@aurodesignsystem/webcorestylesheets/src/breakpoints +0 -0
  567. package/components/input/src/styles/borders-css.js +2 -0
  568. package/components/input/src/styles/borders.css +35 -0
  569. package/components/input/src/styles/borders.scss +65 -0
  570. package/components/input/src/styles/color-css.js +2 -0
  571. package/components/input/src/styles/color.css +63 -0
  572. package/components/input/src/styles/color.scss +96 -0
  573. package/components/input/src/styles/helpText-css.js +2 -0
  574. package/components/input/src/styles/helpText.css +6 -0
  575. package/components/input/src/styles/helpText.scss +9 -0
  576. package/components/input/src/styles/input-css.js +2 -0
  577. package/components/input/src/styles/input.css +22 -0
  578. package/components/input/src/styles/input.scss +29 -0
  579. package/components/input/src/styles/label-css.js +2 -0
  580. package/components/input/src/styles/label.css +45 -0
  581. package/components/input/src/styles/label.scss +75 -0
  582. package/components/input/src/styles/notificationIcons-css.js +2 -0
  583. package/components/input/src/styles/notificationIcons.css +76 -0
  584. package/components/input/src/styles/notificationIcons.scss +103 -0
  585. package/components/input/src/styles/style-css.js +2 -0
  586. package/components/input/src/styles/style.css +272 -0
  587. package/components/input/src/styles/style.scss +57 -0
  588. package/components/input/src/styles/tokens-css.js +2 -0
  589. package/components/input/src/styles/tokens.css +9 -0
  590. package/components/input/src/styles/tokens.scss +11 -0
  591. package/components/menu/.stylelintrc.json +3 -0
  592. package/components/menu/.turbo/turbo-build$colon$sass.log +86 -0
  593. package/components/menu/.turbo/turbo-build$colon$version.log +7 -0
  594. package/components/menu/.turbo/turbo-build.log +184 -0
  595. package/components/menu/.turbo/turbo-bundler.log +13 -0
  596. package/components/menu/.turbo/turbo-postCss$colon$component.log +5 -0
  597. package/components/menu/.turbo/turbo-sass$colon$render.log +34 -0
  598. package/components/menu/.turbo/turbo-types.log +4 -0
  599. package/components/menu/README.md +190 -0
  600. package/components/menu/demo/api.html +53 -0
  601. package/components/menu/demo/api.js +27 -0
  602. package/components/menu/demo/api.md +923 -0
  603. package/components/menu/demo/api.min.js +1293 -0
  604. package/components/menu/demo/index.js +28 -0
  605. package/components/menu/demo/index.md +104 -0
  606. package/components/menu/demo/index.min.js +1239 -0
  607. package/components/menu/dist/auro-menu.d.ts +194 -0
  608. package/components/menu/dist/auro-menu.d.ts.map +1 -0
  609. package/components/menu/dist/auro-menuoption.d.ts +65 -0
  610. package/components/menu/dist/auro-menuoption.d.ts.map +1 -0
  611. package/components/menu/dist/iconVersion.d.ts +3 -0
  612. package/components/menu/dist/iconVersion.d.ts.map +1 -0
  613. package/components/menu/dist/index.d.ts +4 -0
  614. package/components/menu/dist/index.d.ts.map +1 -0
  615. package/components/menu/dist/index.js +1231 -0
  616. package/components/menu/dist/styles/color-menu-css.d.ts +3 -0
  617. package/components/menu/dist/styles/color-menu-css.d.ts.map +1 -0
  618. package/components/menu/dist/styles/color-menuoption-css.d.ts +3 -0
  619. package/components/menu/dist/styles/color-menuoption-css.d.ts.map +1 -0
  620. package/components/menu/dist/styles/style-menu-css.d.ts +3 -0
  621. package/components/menu/dist/styles/style-menu-css.d.ts.map +1 -0
  622. package/components/menu/dist/styles/style-menuoption-css.d.ts +3 -0
  623. package/components/menu/dist/styles/style-menuoption-css.d.ts.map +1 -0
  624. package/components/menu/dist/styles/tokens-css.d.ts +3 -0
  625. package/components/menu/dist/styles/tokens-css.d.ts.map +1 -0
  626. package/components/menu/node_modules/chalk/package.json +83 -0
  627. package/components/menu/node_modules/chalk/readme.md +325 -0
  628. package/components/menu/node_modules/chalk/source/index.d.ts +320 -0
  629. package/components/menu/node_modules/chalk/source/index.js +225 -0
  630. package/components/menu/node_modules/chalk/source/utilities.js +33 -0
  631. package/components/menu/node_modules/chalk/source/vendor/ansi-styles/index.d.ts +236 -0
  632. package/components/menu/node_modules/chalk/source/vendor/ansi-styles/index.js +223 -0
  633. package/components/menu/node_modules/chalk/source/vendor/supports-color/browser.d.ts +1 -0
  634. package/components/menu/node_modules/chalk/source/vendor/supports-color/browser.js +30 -0
  635. package/components/menu/node_modules/chalk/source/vendor/supports-color/index.d.ts +55 -0
  636. package/components/menu/node_modules/chalk/source/vendor/supports-color/index.js +182 -0
  637. package/components/menu/node_modules/mime/CHANGELOG.md +296 -0
  638. package/components/menu/node_modules/mime/Mime.js +97 -0
  639. package/components/menu/node_modules/mime/README.md +187 -0
  640. package/components/menu/node_modules/mime/cli.js +46 -0
  641. package/components/menu/node_modules/mime/index.js +4 -0
  642. package/components/menu/node_modules/mime/lite.js +4 -0
  643. package/components/menu/node_modules/mime/package.json +52 -0
  644. package/components/menu/node_modules/mime/types/other.js +1 -0
  645. package/components/menu/node_modules/mime/types/standard.js +1 -0
  646. package/components/menu/node_modules/rollup-plugin-serve/LICENSE.md +21 -0
  647. package/components/menu/node_modules/rollup-plugin-serve/README.md +135 -0
  648. package/components/menu/node_modules/rollup-plugin-serve/dist/index.cjs +181 -0
  649. package/components/menu/node_modules/rollup-plugin-serve/dist/index.cjs.js +197 -0
  650. package/components/menu/node_modules/rollup-plugin-serve/dist/index.es.js +193 -0
  651. package/components/menu/node_modules/rollup-plugin-serve/dist/index.mjs +173 -0
  652. package/components/menu/node_modules/rollup-plugin-serve/package.json +44 -0
  653. package/components/menu/package.json +70 -0
  654. package/components/menu/src/auro-menu.js +571 -0
  655. package/components/menu/src/auro-menuoption.js +148 -0
  656. package/components/menu/src/iconVersion.js +1 -0
  657. package/components/menu/src/index.js +8 -0
  658. package/components/menu/src/styles/color-menu-css.js +2 -0
  659. package/components/menu/src/styles/color-menu.css +4 -0
  660. package/components/menu/src/styles/color-menu.scss +12 -0
  661. package/components/menu/src/styles/color-menuoption-css.js +2 -0
  662. package/components/menu/src/styles/color-menuoption.css +23 -0
  663. package/components/menu/src/styles/color-menuoption.scss +33 -0
  664. package/components/menu/src/styles/style-menu-css.js +2 -0
  665. package/components/menu/src/styles/style-menu.css +2061 -0
  666. package/components/menu/src/styles/style-menu.scss +80 -0
  667. package/components/menu/src/styles/style-menuoption-css.js +2 -0
  668. package/components/menu/src/styles/style-menuoption.css +45 -0
  669. package/components/menu/src/styles/style-menuoption.scss +66 -0
  670. package/components/menu/src/styles/tokens-css.js +2 -0
  671. package/components/menu/src/styles/tokens.css +6 -0
  672. package/components/menu/src/styles/tokens.scss +6 -0
  673. package/components/radio/.stylelintrc.json +3 -0
  674. package/components/radio/.turbo/turbo-build$colon$sass.log +130 -0
  675. package/components/radio/.turbo/turbo-build.log +213 -0
  676. package/components/radio/.turbo/turbo-bundler.log +13 -0
  677. package/components/radio/.turbo/turbo-postCss$colon$component.log +5 -0
  678. package/components/radio/.turbo/turbo-sass$colon$render.log +34 -0
  679. package/components/radio/.turbo/turbo-types.log +4 -0
  680. package/components/radio/README.md +176 -0
  681. package/components/radio/demo/api.html +50 -0
  682. package/components/radio/demo/api.js +17 -0
  683. package/components/radio/demo/api.md +401 -0
  684. package/components/radio/demo/api.min.js +1050 -0
  685. package/components/radio/demo/index.js +8 -0
  686. package/components/radio/demo/index.md +122 -0
  687. package/components/radio/demo/index.min.js +1016 -0
  688. package/components/radio/dist/auro-radio-group.d.ts +171 -0
  689. package/components/radio/dist/auro-radio-group.d.ts.map +1 -0
  690. package/components/radio/dist/auro-radio.d.ts +113 -0
  691. package/components/radio/dist/auro-radio.d.ts.map +1 -0
  692. package/components/radio/dist/index.d.ts +4 -0
  693. package/components/radio/dist/index.d.ts.map +1 -0
  694. package/components/radio/dist/index.js +1015 -0
  695. package/components/radio/dist/styles/auro-radio-group-css.d.ts +3 -0
  696. package/components/radio/dist/styles/auro-radio-group-css.d.ts.map +1 -0
  697. package/components/radio/dist/styles/color-css.d.ts +3 -0
  698. package/components/radio/dist/styles/color-css.d.ts.map +1 -0
  699. package/components/radio/dist/styles/groupColor-css.d.ts +3 -0
  700. package/components/radio/dist/styles/groupColor-css.d.ts.map +1 -0
  701. package/components/radio/dist/styles/style-css.d.ts +3 -0
  702. package/components/radio/dist/styles/style-css.d.ts.map +1 -0
  703. package/components/radio/dist/styles/tokens-css.d.ts +3 -0
  704. package/components/radio/dist/styles/tokens-css.d.ts.map +1 -0
  705. package/components/radio/node_modules/chalk/package.json +83 -0
  706. package/components/radio/node_modules/chalk/readme.md +325 -0
  707. package/components/radio/node_modules/chalk/source/index.d.ts +320 -0
  708. package/components/radio/node_modules/chalk/source/index.js +225 -0
  709. package/components/radio/node_modules/chalk/source/utilities.js +33 -0
  710. package/components/radio/node_modules/chalk/source/vendor/ansi-styles/index.d.ts +236 -0
  711. package/components/radio/node_modules/chalk/source/vendor/ansi-styles/index.js +223 -0
  712. package/components/radio/node_modules/chalk/source/vendor/supports-color/browser.d.ts +1 -0
  713. package/components/radio/node_modules/chalk/source/vendor/supports-color/browser.js +30 -0
  714. package/components/radio/node_modules/chalk/source/vendor/supports-color/index.d.ts +55 -0
  715. package/components/radio/node_modules/chalk/source/vendor/supports-color/index.js +182 -0
  716. package/components/radio/package.json +69 -0
  717. package/components/radio/src/auro-radio-group.js +433 -0
  718. package/components/radio/src/auro-radio.js +247 -0
  719. package/components/radio/src/index.js +8 -0
  720. package/components/radio/src/styles/auro-radio-group-css.js +2 -0
  721. package/components/radio/src/styles/auro-radio-group.css +23 -0
  722. package/components/radio/src/styles/auro-radio-group.scss +36 -0
  723. package/components/radio/src/styles/color-css.js +2 -0
  724. package/components/radio/src/styles/color.css +45 -0
  725. package/components/radio/src/styles/color.scss +56 -0
  726. package/components/radio/src/styles/groupColor-css.js +2 -0
  727. package/components/radio/src/styles/groupColor.css +21 -0
  728. package/components/radio/src/styles/groupColor.scss +33 -0
  729. package/components/radio/src/styles/style-css.js +2 -0
  730. package/components/radio/src/styles/style.css +113 -0
  731. package/components/radio/src/styles/style.scss +99 -0
  732. package/components/radio/src/styles/tokens-css.js +2 -0
  733. package/components/radio/src/styles/tokens.css +9 -0
  734. package/components/radio/src/styles/tokens.scss +12 -0
  735. package/components/select/.stylelintrc.json +3 -0
  736. package/components/select/.turbo/turbo-build$colon$sass.log +122 -0
  737. package/components/select/.turbo/turbo-build.log +240 -0
  738. package/components/select/.turbo/turbo-postCss$colon$component.log +5 -0
  739. package/components/select/.turbo/turbo-sass$colon$render.log +22 -0
  740. package/components/select/README.md +205 -0
  741. package/components/select/demo/alertValue.js +6 -0
  742. package/components/select/demo/api.html +54 -0
  743. package/components/select/demo/api.js +33 -0
  744. package/components/select/demo/api.md +814 -0
  745. package/components/select/demo/api.min.js +4980 -0
  746. package/components/select/demo/index.js +9 -0
  747. package/components/select/demo/index.md +470 -0
  748. package/components/select/demo/index.min.js +4871 -0
  749. package/components/select/dist/auro-select.d.ts +193 -0
  750. package/components/select/dist/auro-select.d.ts.map +1 -0
  751. package/components/select/dist/formkit/auro-dropdownVersion.d.ts +3 -0
  752. package/components/select/dist/formkit/auro-dropdownVersion.d.ts.map +1 -0
  753. package/components/select/dist/index.d.ts +3 -0
  754. package/components/select/dist/index.d.ts.map +1 -0
  755. package/components/select/dist/index.js +3782 -0
  756. package/components/select/dist/styles/color-css.d.ts +3 -0
  757. package/components/select/dist/styles/color-css.d.ts.map +1 -0
  758. package/components/select/dist/styles/style-css.d.ts +3 -0
  759. package/components/select/dist/styles/style-css.d.ts.map +1 -0
  760. package/components/select/dist/styles/tokens-css.d.ts +3 -0
  761. package/components/select/dist/styles/tokens-css.d.ts.map +1 -0
  762. package/components/select/node_modules/chalk/package.json +83 -0
  763. package/components/select/node_modules/chalk/readme.md +325 -0
  764. package/components/select/node_modules/chalk/source/index.d.ts +320 -0
  765. package/components/select/node_modules/chalk/source/index.js +225 -0
  766. package/components/select/node_modules/chalk/source/utilities.js +33 -0
  767. package/components/select/node_modules/chalk/source/vendor/ansi-styles/index.d.ts +236 -0
  768. package/components/select/node_modules/chalk/source/vendor/ansi-styles/index.js +223 -0
  769. package/components/select/node_modules/chalk/source/vendor/supports-color/browser.d.ts +1 -0
  770. package/components/select/node_modules/chalk/source/vendor/supports-color/browser.js +30 -0
  771. package/components/select/node_modules/chalk/source/vendor/supports-color/index.d.ts +55 -0
  772. package/components/select/node_modules/chalk/source/vendor/supports-color/index.js +182 -0
  773. package/components/select/node_modules/mime/CHANGELOG.md +296 -0
  774. package/components/select/node_modules/mime/Mime.js +97 -0
  775. package/components/select/node_modules/mime/README.md +187 -0
  776. package/components/select/node_modules/mime/cli.js +46 -0
  777. package/components/select/node_modules/mime/index.js +4 -0
  778. package/components/select/node_modules/mime/lite.js +4 -0
  779. package/components/select/node_modules/mime/package.json +52 -0
  780. package/components/select/node_modules/mime/types/other.js +1 -0
  781. package/components/select/node_modules/mime/types/standard.js +1 -0
  782. package/components/select/node_modules/rollup-plugin-serve/LICENSE.md +21 -0
  783. package/components/select/node_modules/rollup-plugin-serve/README.md +135 -0
  784. package/components/select/node_modules/rollup-plugin-serve/dist/index.cjs +181 -0
  785. package/components/select/node_modules/rollup-plugin-serve/dist/index.cjs.js +197 -0
  786. package/components/select/node_modules/rollup-plugin-serve/dist/index.es.js +193 -0
  787. package/components/select/node_modules/rollup-plugin-serve/dist/index.mjs +173 -0
  788. package/components/select/node_modules/rollup-plugin-serve/package.json +44 -0
  789. package/components/select/package.json +70 -0
  790. package/components/select/packageScripts/postinstall.mjs +28 -0
  791. package/components/select/src/auro-select.js +570 -0
  792. package/components/select/src/formkit/auro-dropdownVersion.js +1 -0
  793. package/components/select/src/index.js +6 -0
  794. package/components/select/src/styles/color-css.js +2 -0
  795. package/components/select/src/styles/color.css +63 -0
  796. package/components/select/src/styles/color.scss +33 -0
  797. package/components/select/src/styles/style-css.js +2 -0
  798. package/components/select/src/styles/style.css +97 -0
  799. package/components/select/src/styles/style.scss +66 -0
  800. package/components/select/src/styles/tokens-css.js +2 -0
  801. package/components/select/src/styles/tokens.css +3 -0
  802. package/components/select/src/styles/tokens.scss +5 -0
  803. package/package.json +142 -0
  804. package/packages/build-tools/package.json +15 -0
  805. package/packages/build-tools/src/docProcessor.mjs +104 -0
  806. package/packages/build-tools/src/formVersionWriter.mjs +75 -0
  807. package/packages/build-tools/src/index.js +1 -0
  808. package/packages/build-tools/src/kitDocProcessor.mjs +66 -0
  809. package/packages/form-validation/package.json +12 -0
  810. package/packages/form-validation/src/index.js +1 -0
  811. package/packages/form-validation/src/validation.js +239 -0
  812. package/packages/typescript/base.json +19 -0
  813. package/packages/typescript/package.json +20 -0
  814. package/turbo.json +100 -0
@@ -0,0 +1,2885 @@
1
+ function showExample() {
2
+ const triggerInput = document.querySelector('#showExampleTriggerInput');
3
+ const dropdownElem = document.querySelector('#showMethodExample');
4
+
5
+ triggerInput.addEventListener('keydown', () => {
6
+ dropdownElem.show();
7
+ });
8
+ }
9
+
10
+ function hideExample() {
11
+ const btn = document.querySelector('#hideExampleBtn');
12
+ const dropdown = document.querySelector('#hideExample');
13
+
14
+ btn.addEventListener('click', () => {
15
+ dropdown.hide();
16
+ });
17
+ }
18
+
19
+ function inDialogExample() {
20
+ document.querySelector("#dropdown-dialog-opener").addEventListener("click", () => {
21
+ const dialog = document.querySelector("#dropdown-dialog");
22
+ dialog.open = true;
23
+ });
24
+ }
25
+
26
+ /**
27
+ * @license
28
+ * Copyright 2017 Google LLC
29
+ * SPDX-License-Identifier: BSD-3-Clause
30
+ */
31
+ const t$2=globalThis,i$5=t$2.trustedTypes,s$2=i$5?i$5.createPolicy("lit-html",{createHTML:t=>t}):void 0,e$4="$lit$",h$1=`lit$${Math.random().toFixed(9).slice(2)}$`,o$4="?"+h$1,n$3=`<${o$4}>`,r$3=document,l$2=()=>r$3.createComment(""),c$2=t=>null===t||"object"!=typeof t&&"function"!=typeof t,a$2=Array.isArray,u$2=t=>a$2(t)||"function"==typeof t?.[Symbol.iterator],d$1="[ \t\n\f\r]",f$1=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,v=/-->/g,_=/>/g,m=RegExp(`>|${d$1}(?:([^\\s"'>=/]+)(${d$1}*=${d$1}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`,"g"),p$1=/'/g,g=/"/g,$=/^(?:script|style|textarea|title)$/i,y$1=t=>(i,...s)=>({_$litType$:t,strings:i,values:s}),x=y$1(1),T=Symbol.for("lit-noChange"),E=Symbol.for("lit-nothing"),A=new WeakMap,C=r$3.createTreeWalker(r$3,129);function P(t,i){if(!a$2(t)||!t.hasOwnProperty("raw"))throw Error("invalid template strings array");return void 0!==s$2?s$2.createHTML(i):i}const V=(t,i)=>{const s=t.length-1,o=[];let r,l=2===i?"<svg>":3===i?"<math>":"",c=f$1;for(let i=0;i<s;i++){const s=t[i];let a,u,d=-1,y=0;for(;y<s.length&&(c.lastIndex=y,u=c.exec(s),null!==u);)y=c.lastIndex,c===f$1?"!--"===u[1]?c=v:void 0!==u[1]?c=_:void 0!==u[2]?($.test(u[2])&&(r=RegExp("</"+u[2],"g")),c=m):void 0!==u[3]&&(c=m):c===m?">"===u[0]?(c=r??f$1,d=-1):void 0===u[1]?d=-2:(d=c.lastIndex-u[2].length,a=u[1],c=void 0===u[3]?m:'"'===u[3]?g:p$1):c===g||c===p$1?c=m:c===v||c===_?c=f$1:(c=m,r=void 0);const x=c===m&&t[i+1].startsWith("/>")?" ":"";l+=c===f$1?s+n$3:d>=0?(o.push(a),s.slice(0,d)+e$4+s.slice(d)+h$1+x):s+h$1+(-2===d?i:x);}return [P(t,l+(t[s]||"<?>")+(2===i?"</svg>":3===i?"</math>":"")),o]};class N{constructor({strings:t,_$litType$:s},n){let r;this.parts=[];let c=0,a=0;const u=t.length-1,d=this.parts,[f,v]=V(t,s);if(this.el=N.createElement(f,n),C.currentNode=this.el.content,2===s||3===s){const t=this.el.content.firstChild;t.replaceWith(...t.childNodes);}for(;null!==(r=C.nextNode())&&d.length<u;){if(1===r.nodeType){if(r.hasAttributes())for(const t of r.getAttributeNames())if(t.endsWith(e$4)){const i=v[a++],s=r.getAttribute(t).split(h$1),e=/([.?@])?(.*)/.exec(i);d.push({type:1,index:c,name:e[2],strings:s,ctor:"."===e[1]?H:"?"===e[1]?I:"@"===e[1]?L:k}),r.removeAttribute(t);}else t.startsWith(h$1)&&(d.push({type:6,index:c}),r.removeAttribute(t));if($.test(r.tagName)){const t=r.textContent.split(h$1),s=t.length-1;if(s>0){r.textContent=i$5?i$5.emptyScript:"";for(let i=0;i<s;i++)r.append(t[i],l$2()),C.nextNode(),d.push({type:2,index:++c});r.append(t[s],l$2());}}}else if(8===r.nodeType)if(r.data===o$4)d.push({type:2,index:c});else {let t=-1;for(;-1!==(t=r.data.indexOf(h$1,t+1));)d.push({type:7,index:c}),t+=h$1.length-1;}c++;}}static createElement(t,i){const s=r$3.createElement("template");return s.innerHTML=t,s}}function S$1(t,i,s=t,e){if(i===T)return i;let h=void 0!==e?s._$Co?.[e]:s._$Cl;const o=c$2(i)?void 0:i._$litDirective$;return h?.constructor!==o&&(h?._$AO?.(!1),void 0===o?h=void 0:(h=new o(t),h._$AT(t,s,e)),void 0!==e?(s._$Co??=[])[e]=h:s._$Cl=h),void 0!==h&&(i=S$1(t,h._$AS(t,i.values),h,e)),i}class M{constructor(t,i){this._$AV=[],this._$AN=void 0,this._$AD=t,this._$AM=i;}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}u(t){const{el:{content:i},parts:s}=this._$AD,e=(t?.creationScope??r$3).importNode(i,!0);C.currentNode=e;let h=C.nextNode(),o=0,n=0,l=s[0];for(;void 0!==l;){if(o===l.index){let i;2===l.type?i=new R(h,h.nextSibling,this,t):1===l.type?i=new l.ctor(h,l.name,l.strings,this,t):6===l.type&&(i=new z(h,this,t)),this._$AV.push(i),l=s[++n];}o!==l?.index&&(h=C.nextNode(),o++);}return C.currentNode=r$3,e}p(t){let i=0;for(const s of this._$AV)void 0!==s&&(void 0!==s.strings?(s._$AI(t,s,i),i+=s.strings.length-2):s._$AI(t[i])),i++;}}class R{get _$AU(){return this._$AM?._$AU??this._$Cv}constructor(t,i,s,e){this.type=2,this._$AH=E,this._$AN=void 0,this._$AA=t,this._$AB=i,this._$AM=s,this.options=e,this._$Cv=e?.isConnected??!0;}get parentNode(){let t=this._$AA.parentNode;const i=this._$AM;return void 0!==i&&11===t?.nodeType&&(t=i.parentNode),t}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(t,i=this){t=S$1(this,t,i),c$2(t)?t===E||null==t||""===t?(this._$AH!==E&&this._$AR(),this._$AH=E):t!==this._$AH&&t!==T&&this._(t):void 0!==t._$litType$?this.$(t):void 0!==t.nodeType?this.T(t):u$2(t)?this.k(t):this._(t);}O(t){return this._$AA.parentNode.insertBefore(t,this._$AB)}T(t){this._$AH!==t&&(this._$AR(),this._$AH=this.O(t));}_(t){this._$AH!==E&&c$2(this._$AH)?this._$AA.nextSibling.data=t:this.T(r$3.createTextNode(t)),this._$AH=t;}$(t){const{values:i,_$litType$:s}=t,e="number"==typeof s?this._$AC(t):(void 0===s.el&&(s.el=N.createElement(P(s.h,s.h[0]),this.options)),s);if(this._$AH?._$AD===e)this._$AH.p(i);else {const t=new M(e,this),s=t.u(this.options);t.p(i),this.T(s),this._$AH=t;}}_$AC(t){let i=A.get(t.strings);return void 0===i&&A.set(t.strings,i=new N(t)),i}k(t){a$2(this._$AH)||(this._$AH=[],this._$AR());const i=this._$AH;let s,e=0;for(const h of t)e===i.length?i.push(s=new R(this.O(l$2()),this.O(l$2()),this,this.options)):s=i[e],s._$AI(h),e++;e<i.length&&(this._$AR(s&&s._$AB.nextSibling,e),i.length=e);}_$AR(t=this._$AA.nextSibling,i){for(this._$AP?.(!1,!0,i);t&&t!==this._$AB;){const i=t.nextSibling;t.remove(),t=i;}}setConnected(t){void 0===this._$AM&&(this._$Cv=t,this._$AP?.(t));}}class k{get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}constructor(t,i,s,e,h){this.type=1,this._$AH=E,this._$AN=void 0,this.element=t,this.name=i,this._$AM=e,this.options=h,s.length>2||""!==s[0]||""!==s[1]?(this._$AH=Array(s.length-1).fill(new String),this.strings=s):this._$AH=E;}_$AI(t,i=this,s,e){const h=this.strings;let o=!1;if(void 0===h)t=S$1(this,t,i,0),o=!c$2(t)||t!==this._$AH&&t!==T,o&&(this._$AH=t);else {const e=t;let n,r;for(t=h[0],n=0;n<h.length-1;n++)r=S$1(this,e[s+n],i,n),r===T&&(r=this._$AH[n]),o||=!c$2(r)||r!==this._$AH[n],r===E?t=E:t!==E&&(t+=(r??"")+h[n+1]),this._$AH[n]=r;}o&&!e&&this.j(t);}j(t){t===E?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,t??"");}}class H extends k{constructor(){super(...arguments),this.type=3;}j(t){this.element[this.name]=t===E?void 0:t;}}class I extends k{constructor(){super(...arguments),this.type=4;}j(t){this.element.toggleAttribute(this.name,!!t&&t!==E);}}class L extends k{constructor(t,i,s,e,h){super(t,i,s,e,h),this.type=5;}_$AI(t,i=this){if((t=S$1(this,t,i,0)??E)===T)return;const s=this._$AH,e=t===E&&s!==E||t.capture!==s.capture||t.once!==s.once||t.passive!==s.passive,h=t!==E&&(s===E||e);e&&this.element.removeEventListener(this.name,this,s),h&&this.element.addEventListener(this.name,this,t),this._$AH=t;}handleEvent(t){"function"==typeof this._$AH?this._$AH.call(this.options?.host??this.element,t):this._$AH.handleEvent(t);}}class z{constructor(t,i,s){this.element=t,this.type=6,this._$AN=void 0,this._$AM=i,this.options=s;}get _$AU(){return this._$AM._$AU}_$AI(t){S$1(this,t);}}const j=t$2.litHtmlPolyfillSupport;j?.(N,R),(t$2.litHtmlVersions??=[]).push("3.2.1");const B=(t,i,s)=>{const e=s?.renderBefore??i;let h=e._$litPart$;if(void 0===h){const t=s?.renderBefore??null;e._$litPart$=h=new R(i.insertBefore(l$2(),t),t,void 0,s??{});}return h._$AI(t),h};
32
+
33
+ /**
34
+ * @license
35
+ * Copyright 2020 Google LLC
36
+ * SPDX-License-Identifier: BSD-3-Clause
37
+ */
38
+ const a$1=Symbol.for(""),o$3=t=>{if(t?.r===a$1)return t?._$litStatic$},s$1=t=>({_$litStatic$:t,r:a$1}),i$4=(t,...r)=>({_$litStatic$:r.reduce(((r,e,a)=>r+(t=>{if(void 0!==t._$litStatic$)return t._$litStatic$;throw Error(`Value passed to 'literal' function must be a 'literal' result: ${t}. Use 'unsafeStatic' to pass non-literal values, but\n take care to ensure page security.`)})(e)+t[a+1]),t[0]),r:a$1}),l$1=new Map,n$2=t=>(r,...e)=>{const a=e.length;let s,i;const n=[],u=[];let c,$=0,f=!1;for(;$<a;){for(c=r[$];$<a&&void 0!==(i=e[$],s=o$3(i));)c+=s+r[++$],f=!0;$!==a&&u.push(i),n.push(c),$++;}if($===a&&n.push(r[a]),f){const t=n.join("$$lit$$");void 0===(r=l$1.get(t))&&(n.raw=n,l$1.set(t,r=n)),e=u;}return t(r,...e)},u$1=n$2(x);
39
+
40
+ /**
41
+ * @license
42
+ * Copyright 2019 Google LLC
43
+ * SPDX-License-Identifier: BSD-3-Clause
44
+ */
45
+ const t$1=globalThis,e$3=t$1.ShadowRoot&&(void 0===t$1.ShadyCSS||t$1.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,s=Symbol(),o$2=new WeakMap;let n$1 = class n{constructor(t,e,o){if(this._$cssResult$=!0,o!==s)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=t,this.t=e;}get styleSheet(){let t=this.o;const s=this.t;if(e$3&&void 0===t){const e=void 0!==s&&1===s.length;e&&(t=o$2.get(s)),void 0===t&&((this.o=t=new CSSStyleSheet).replaceSync(this.cssText),e&&o$2.set(s,t));}return t}toString(){return this.cssText}};const r$2=t=>new n$1("string"==typeof t?t:t+"",void 0,s),i$3=(t,...e)=>{const o=1===t.length?t[0]:e.reduce(((e,s,o)=>e+(t=>{if(!0===t._$cssResult$)return t.cssText;if("number"==typeof t)return t;throw Error("Value passed to 'css' function must be a 'css' function result: "+t+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(s)+t[o+1]),t[0]);return new n$1(o,t,s)},S=(s,o)=>{if(e$3)s.adoptedStyleSheets=o.map((t=>t instanceof CSSStyleSheet?t:t.styleSheet));else for(const e of o){const o=document.createElement("style"),n=t$1.litNonce;void 0!==n&&o.setAttribute("nonce",n),o.textContent=e.cssText,s.appendChild(o);}},c$1=e$3?t=>t:t=>t instanceof CSSStyleSheet?(t=>{let e="";for(const s of t.cssRules)e+=s.cssText;return r$2(e)})(t):t;
46
+
47
+ /**
48
+ * @license
49
+ * Copyright 2017 Google LLC
50
+ * SPDX-License-Identifier: BSD-3-Clause
51
+ */const{is:i$2,defineProperty:e$2,getOwnPropertyDescriptor:r$1,getOwnPropertyNames:h,getOwnPropertySymbols:o$1,getPrototypeOf:n}=Object,a=globalThis,c=a.trustedTypes,l=c?c.emptyScript:"",p=a.reactiveElementPolyfillSupport,d=(t,s)=>t,u={toAttribute(t,s){switch(s){case Boolean:t=t?l:null;break;case Object:case Array:t=null==t?t:JSON.stringify(t);}return t},fromAttribute(t,s){let i=t;switch(s){case Boolean:i=null!==t;break;case Number:i=null===t?null:Number(t);break;case Object:case Array:try{i=JSON.parse(t);}catch(t){i=null;}}return i}},f=(t,s)=>!i$2(t,s),y={attribute:!0,type:String,converter:u,reflect:!1,hasChanged:f};Symbol.metadata??=Symbol("metadata"),a.litPropertyMetadata??=new WeakMap;class b extends HTMLElement{static addInitializer(t){this._$Ei(),(this.l??=[]).push(t);}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(t,s=y){if(s.state&&(s.attribute=!1),this._$Ei(),this.elementProperties.set(t,s),!s.noAccessor){const i=Symbol(),r=this.getPropertyDescriptor(t,i,s);void 0!==r&&e$2(this.prototype,t,r);}}static getPropertyDescriptor(t,s,i){const{get:e,set:h}=r$1(this.prototype,t)??{get(){return this[s]},set(t){this[s]=t;}};return {get(){return e?.call(this)},set(s){const r=e?.call(this);h.call(this,s),this.requestUpdate(t,r,i);},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)??y}static _$Ei(){if(this.hasOwnProperty(d("elementProperties")))return;const t=n(this);t.finalize(),void 0!==t.l&&(this.l=[...t.l]),this.elementProperties=new Map(t.elementProperties);}static finalize(){if(this.hasOwnProperty(d("finalized")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(d("properties"))){const t=this.properties,s=[...h(t),...o$1(t)];for(const i of s)this.createProperty(i,t[i]);}const t=this[Symbol.metadata];if(null!==t){const s=litPropertyMetadata.get(t);if(void 0!==s)for(const[t,i]of s)this.elementProperties.set(t,i);}this._$Eh=new Map;for(const[t,s]of this.elementProperties){const i=this._$Eu(t,s);void 0!==i&&this._$Eh.set(i,t);}this.elementStyles=this.finalizeStyles(this.styles);}static finalizeStyles(s){const i=[];if(Array.isArray(s)){const e=new Set(s.flat(1/0).reverse());for(const s of e)i.unshift(c$1(s));}else void 0!==s&&i.push(c$1(s));return i}static _$Eu(t,s){const i=s.attribute;return !1===i?void 0:"string"==typeof i?i:"string"==typeof t?t.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev();}_$Ev(){this._$ES=new Promise((t=>this.enableUpdating=t)),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach((t=>t(this)));}addController(t){(this._$EO??=new Set).add(t),void 0!==this.renderRoot&&this.isConnected&&t.hostConnected?.();}removeController(t){this._$EO?.delete(t);}_$E_(){const t=new Map,s=this.constructor.elementProperties;for(const i of s.keys())this.hasOwnProperty(i)&&(t.set(i,this[i]),delete this[i]);t.size>0&&(this._$Ep=t);}createRenderRoot(){const t=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return S(t,this.constructor.elementStyles),t}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach((t=>t.hostConnected?.()));}enableUpdating(t){}disconnectedCallback(){this._$EO?.forEach((t=>t.hostDisconnected?.()));}attributeChangedCallback(t,s,i){this._$AK(t,i);}_$EC(t,s){const i=this.constructor.elementProperties.get(t),e=this.constructor._$Eu(t,i);if(void 0!==e&&!0===i.reflect){const r=(void 0!==i.converter?.toAttribute?i.converter:u).toAttribute(s,i.type);this._$Em=t,null==r?this.removeAttribute(e):this.setAttribute(e,r),this._$Em=null;}}_$AK(t,s){const i=this.constructor,e=i._$Eh.get(t);if(void 0!==e&&this._$Em!==e){const t=i.getPropertyOptions(e),r="function"==typeof t.converter?{fromAttribute:t.converter}:void 0!==t.converter?.fromAttribute?t.converter:u;this._$Em=e,this[e]=r.fromAttribute(s,t.type),this._$Em=null;}}requestUpdate(t,s,i){if(void 0!==t){if(i??=this.constructor.getPropertyOptions(t),!(i.hasChanged??f)(this[t],s))return;this.P(t,s,i);}!1===this.isUpdatePending&&(this._$ES=this._$ET());}P(t,s,i){this._$AL.has(t)||this._$AL.set(t,s),!0===i.reflect&&this._$Em!==t&&(this._$Ej??=new Set).add(t);}async _$ET(){this.isUpdatePending=!0;try{await this._$ES;}catch(t){Promise.reject(t);}const t=this.scheduleUpdate();return null!=t&&await t,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(const[t,s]of this._$Ep)this[t]=s;this._$Ep=void 0;}const t=this.constructor.elementProperties;if(t.size>0)for(const[s,i]of t)!0!==i.wrapped||this._$AL.has(s)||void 0===this[s]||this.P(s,this[s],i);}let t=!1;const s=this._$AL;try{t=this.shouldUpdate(s),t?(this.willUpdate(s),this._$EO?.forEach((t=>t.hostUpdate?.())),this.update(s)):this._$EU();}catch(s){throw t=!1,this._$EU(),s}t&&this._$AE(s);}willUpdate(t){}_$AE(t){this._$EO?.forEach((t=>t.hostUpdated?.())),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(t)),this.updated(t);}_$EU(){this._$AL=new Map,this.isUpdatePending=!1;}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(t){return !0}update(t){this._$Ej&&=this._$Ej.forEach((t=>this._$EC(t,this[t]))),this._$EU();}updated(t){}firstUpdated(t){}}b.elementStyles=[],b.shadowRootOptions={mode:"open"},b[d("elementProperties")]=new Map,b[d("finalized")]=new Map,p?.({ReactiveElement:b}),(a.reactiveElementVersions??=[]).push("2.0.4");
52
+
53
+ /**
54
+ * @license
55
+ * Copyright 2017 Google LLC
56
+ * SPDX-License-Identifier: BSD-3-Clause
57
+ */class r extends b{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0;}createRenderRoot(){const t=super.createRenderRoot();return this.renderOptions.renderBefore??=t.firstChild,t}update(t){const s=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(t),this._$Do=B(s,this.renderRoot,this.renderOptions);}connectedCallback(){super.connectedCallback(),this._$Do?.setConnected(!0);}disconnectedCallback(){super.disconnectedCallback(),this._$Do?.setConnected(!1);}render(){return T}}r._$litElement$=!0,r["finalized"]=!0,globalThis.litElementHydrateSupport?.({LitElement:r});const i$1=globalThis.litElementPolyfillSupport;i$1?.({LitElement:r});(globalThis.litElementVersions??=[]).push("4.1.1");
58
+
59
+ // Copyright (c) Alaska Air. All right reserved. Licensed under the Apache-2.0 license
60
+ // See LICENSE in the project root for license information.
61
+
62
+ // ---------------------------------------------------------------------
63
+
64
+ /* eslint-disable line-comment-position, no-inline-comments, no-confusing-arrow, no-nested-ternary, implicit-arrow-linebreak */
65
+
66
+ class AuroLibraryRuntimeUtils {
67
+
68
+ /* eslint-disable jsdoc/require-param */
69
+
70
+ /**
71
+ * This will register a new custom element with the browser.
72
+ * @param {String} name - The name of the custom element.
73
+ * @param {Object} componentClass - The class to register as a custom element.
74
+ * @returns {void}
75
+ */
76
+ registerComponent(name, componentClass) {
77
+ if (!customElements.get(name)) {
78
+ customElements.define(name, class extends componentClass {});
79
+ }
80
+ }
81
+
82
+ /**
83
+ * Finds and returns the closest HTML Element based on a selector.
84
+ * @returns {void}
85
+ */
86
+ closestElement(
87
+ selector, // selector like in .closest()
88
+ base = this, // extra functionality to skip a parent
89
+ __Closest = (el, found = el && el.closest(selector)) =>
90
+ !el || el === document || el === window
91
+ ? null // standard .closest() returns null for non-found selectors also
92
+ : found
93
+ ? found // found a selector INside this element
94
+ : __Closest(el.getRootNode().host) // recursion!! break out to parent DOM
95
+ ) {
96
+ return __Closest(base);
97
+ }
98
+ /* eslint-enable jsdoc/require-param */
99
+
100
+ /**
101
+ * If the element passed is registered with a different tag name than what is passed in, the tag name is added as an attribute to the element.
102
+ * @param {Object} elem - The element to check.
103
+ * @param {String} tagName - The name of the Auro component to check for or add as an attribute.
104
+ * @returns {void}
105
+ */
106
+ handleComponentTagRename(elem, tagName) {
107
+ const tag = tagName.toLowerCase();
108
+ const elemTag = elem.tagName.toLowerCase();
109
+
110
+ if (elemTag !== tag) {
111
+ elem.setAttribute(tag, true);
112
+ }
113
+ }
114
+
115
+ /**
116
+ * Validates if an element is a specific Auro component.
117
+ * @param {Object} elem - The element to validate.
118
+ * @param {String} tagName - The name of the Auro component to check against.
119
+ * @returns {Boolean} - Returns true if the element is the specified Auro component.
120
+ */
121
+ elementMatch(elem, tagName) {
122
+ const tag = tagName.toLowerCase();
123
+ const elemTag = elem.tagName.toLowerCase();
124
+
125
+ return elemTag === tag || elem.hasAttribute(tag);
126
+ }
127
+ }
128
+
129
+ /**
130
+ * Custom positioning reference element.
131
+ * @see https://floating-ui.com/docs/virtual-elements
132
+ */
133
+
134
+ const sides = ['top', 'right', 'bottom', 'left'];
135
+ const alignments = ['start', 'end'];
136
+ const placements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + "-" + alignments[0], side + "-" + alignments[1]), []);
137
+ const min = Math.min;
138
+ const max = Math.max;
139
+ const round = Math.round;
140
+ const floor = Math.floor;
141
+ const createCoords = v => ({
142
+ x: v,
143
+ y: v
144
+ });
145
+ const oppositeSideMap = {
146
+ left: 'right',
147
+ right: 'left',
148
+ bottom: 'top',
149
+ top: 'bottom'
150
+ };
151
+ const oppositeAlignmentMap = {
152
+ start: 'end',
153
+ end: 'start'
154
+ };
155
+ function evaluate(value, param) {
156
+ return typeof value === 'function' ? value(param) : value;
157
+ }
158
+ function getSide(placement) {
159
+ return placement.split('-')[0];
160
+ }
161
+ function getAlignment(placement) {
162
+ return placement.split('-')[1];
163
+ }
164
+ function getOppositeAxis(axis) {
165
+ return axis === 'x' ? 'y' : 'x';
166
+ }
167
+ function getAxisLength(axis) {
168
+ return axis === 'y' ? 'height' : 'width';
169
+ }
170
+ function getSideAxis(placement) {
171
+ return ['top', 'bottom'].includes(getSide(placement)) ? 'y' : 'x';
172
+ }
173
+ function getAlignmentAxis(placement) {
174
+ return getOppositeAxis(getSideAxis(placement));
175
+ }
176
+ function getAlignmentSides(placement, rects, rtl) {
177
+ if (rtl === void 0) {
178
+ rtl = false;
179
+ }
180
+ const alignment = getAlignment(placement);
181
+ const alignmentAxis = getAlignmentAxis(placement);
182
+ const length = getAxisLength(alignmentAxis);
183
+ let mainAlignmentSide = alignmentAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';
184
+ if (rects.reference[length] > rects.floating[length]) {
185
+ mainAlignmentSide = getOppositePlacement(mainAlignmentSide);
186
+ }
187
+ return [mainAlignmentSide, getOppositePlacement(mainAlignmentSide)];
188
+ }
189
+ function getExpandedPlacements(placement) {
190
+ const oppositePlacement = getOppositePlacement(placement);
191
+ return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];
192
+ }
193
+ function getOppositeAlignmentPlacement(placement) {
194
+ return placement.replace(/start|end/g, alignment => oppositeAlignmentMap[alignment]);
195
+ }
196
+ function getSideList(side, isStart, rtl) {
197
+ const lr = ['left', 'right'];
198
+ const rl = ['right', 'left'];
199
+ const tb = ['top', 'bottom'];
200
+ const bt = ['bottom', 'top'];
201
+ switch (side) {
202
+ case 'top':
203
+ case 'bottom':
204
+ if (rtl) return isStart ? rl : lr;
205
+ return isStart ? lr : rl;
206
+ case 'left':
207
+ case 'right':
208
+ return isStart ? tb : bt;
209
+ default:
210
+ return [];
211
+ }
212
+ }
213
+ function getOppositeAxisPlacements(placement, flipAlignment, direction, rtl) {
214
+ const alignment = getAlignment(placement);
215
+ let list = getSideList(getSide(placement), direction === 'start', rtl);
216
+ if (alignment) {
217
+ list = list.map(side => side + "-" + alignment);
218
+ if (flipAlignment) {
219
+ list = list.concat(list.map(getOppositeAlignmentPlacement));
220
+ }
221
+ }
222
+ return list;
223
+ }
224
+ function getOppositePlacement(placement) {
225
+ return placement.replace(/left|right|bottom|top/g, side => oppositeSideMap[side]);
226
+ }
227
+ function expandPaddingObject(padding) {
228
+ return {
229
+ top: 0,
230
+ right: 0,
231
+ bottom: 0,
232
+ left: 0,
233
+ ...padding
234
+ };
235
+ }
236
+ function getPaddingObject(padding) {
237
+ return typeof padding !== 'number' ? expandPaddingObject(padding) : {
238
+ top: padding,
239
+ right: padding,
240
+ bottom: padding,
241
+ left: padding
242
+ };
243
+ }
244
+ function rectToClientRect(rect) {
245
+ const {
246
+ x,
247
+ y,
248
+ width,
249
+ height
250
+ } = rect;
251
+ return {
252
+ width,
253
+ height,
254
+ top: y,
255
+ left: x,
256
+ right: x + width,
257
+ bottom: y + height,
258
+ x,
259
+ y
260
+ };
261
+ }
262
+
263
+ function computeCoordsFromPlacement(_ref, placement, rtl) {
264
+ let {
265
+ reference,
266
+ floating
267
+ } = _ref;
268
+ const sideAxis = getSideAxis(placement);
269
+ const alignmentAxis = getAlignmentAxis(placement);
270
+ const alignLength = getAxisLength(alignmentAxis);
271
+ const side = getSide(placement);
272
+ const isVertical = sideAxis === 'y';
273
+ const commonX = reference.x + reference.width / 2 - floating.width / 2;
274
+ const commonY = reference.y + reference.height / 2 - floating.height / 2;
275
+ const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;
276
+ let coords;
277
+ switch (side) {
278
+ case 'top':
279
+ coords = {
280
+ x: commonX,
281
+ y: reference.y - floating.height
282
+ };
283
+ break;
284
+ case 'bottom':
285
+ coords = {
286
+ x: commonX,
287
+ y: reference.y + reference.height
288
+ };
289
+ break;
290
+ case 'right':
291
+ coords = {
292
+ x: reference.x + reference.width,
293
+ y: commonY
294
+ };
295
+ break;
296
+ case 'left':
297
+ coords = {
298
+ x: reference.x - floating.width,
299
+ y: commonY
300
+ };
301
+ break;
302
+ default:
303
+ coords = {
304
+ x: reference.x,
305
+ y: reference.y
306
+ };
307
+ }
308
+ switch (getAlignment(placement)) {
309
+ case 'start':
310
+ coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);
311
+ break;
312
+ case 'end':
313
+ coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);
314
+ break;
315
+ }
316
+ return coords;
317
+ }
318
+
319
+ /**
320
+ * Computes the `x` and `y` coordinates that will place the floating element
321
+ * next to a given reference element.
322
+ *
323
+ * This export does not have any `platform` interface logic. You will need to
324
+ * write one for the platform you are using Floating UI with.
325
+ */
326
+ const computePosition$1 = async (reference, floating, config) => {
327
+ const {
328
+ placement = 'bottom',
329
+ strategy = 'absolute',
330
+ middleware = [],
331
+ platform
332
+ } = config;
333
+ const validMiddleware = middleware.filter(Boolean);
334
+ const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));
335
+ let rects = await platform.getElementRects({
336
+ reference,
337
+ floating,
338
+ strategy
339
+ });
340
+ let {
341
+ x,
342
+ y
343
+ } = computeCoordsFromPlacement(rects, placement, rtl);
344
+ let statefulPlacement = placement;
345
+ let middlewareData = {};
346
+ let resetCount = 0;
347
+ for (let i = 0; i < validMiddleware.length; i++) {
348
+ const {
349
+ name,
350
+ fn
351
+ } = validMiddleware[i];
352
+ const {
353
+ x: nextX,
354
+ y: nextY,
355
+ data,
356
+ reset
357
+ } = await fn({
358
+ x,
359
+ y,
360
+ initialPlacement: placement,
361
+ placement: statefulPlacement,
362
+ strategy,
363
+ middlewareData,
364
+ rects,
365
+ platform,
366
+ elements: {
367
+ reference,
368
+ floating
369
+ }
370
+ });
371
+ x = nextX != null ? nextX : x;
372
+ y = nextY != null ? nextY : y;
373
+ middlewareData = {
374
+ ...middlewareData,
375
+ [name]: {
376
+ ...middlewareData[name],
377
+ ...data
378
+ }
379
+ };
380
+ if (reset && resetCount <= 50) {
381
+ resetCount++;
382
+ if (typeof reset === 'object') {
383
+ if (reset.placement) {
384
+ statefulPlacement = reset.placement;
385
+ }
386
+ if (reset.rects) {
387
+ rects = reset.rects === true ? await platform.getElementRects({
388
+ reference,
389
+ floating,
390
+ strategy
391
+ }) : reset.rects;
392
+ }
393
+ ({
394
+ x,
395
+ y
396
+ } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));
397
+ }
398
+ i = -1;
399
+ }
400
+ }
401
+ return {
402
+ x,
403
+ y,
404
+ placement: statefulPlacement,
405
+ strategy,
406
+ middlewareData
407
+ };
408
+ };
409
+
410
+ /**
411
+ * Resolves with an object of overflow side offsets that determine how much the
412
+ * element is overflowing a given clipping boundary on each side.
413
+ * - positive = overflowing the boundary by that number of pixels
414
+ * - negative = how many pixels left before it will overflow
415
+ * - 0 = lies flush with the boundary
416
+ * @see https://floating-ui.com/docs/detectOverflow
417
+ */
418
+ async function detectOverflow(state, options) {
419
+ var _await$platform$isEle;
420
+ if (options === void 0) {
421
+ options = {};
422
+ }
423
+ const {
424
+ x,
425
+ y,
426
+ platform,
427
+ rects,
428
+ elements,
429
+ strategy
430
+ } = state;
431
+ const {
432
+ boundary = 'clippingAncestors',
433
+ rootBoundary = 'viewport',
434
+ elementContext = 'floating',
435
+ altBoundary = false,
436
+ padding = 0
437
+ } = evaluate(options, state);
438
+ const paddingObject = getPaddingObject(padding);
439
+ const altContext = elementContext === 'floating' ? 'reference' : 'floating';
440
+ const element = elements[altBoundary ? altContext : elementContext];
441
+ const clippingClientRect = rectToClientRect(await platform.getClippingRect({
442
+ 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))),
443
+ boundary,
444
+ rootBoundary,
445
+ strategy
446
+ }));
447
+ const rect = elementContext === 'floating' ? {
448
+ x,
449
+ y,
450
+ width: rects.floating.width,
451
+ height: rects.floating.height
452
+ } : rects.reference;
453
+ const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));
454
+ const offsetScale = (await (platform.isElement == null ? void 0 : platform.isElement(offsetParent))) ? (await (platform.getScale == null ? void 0 : platform.getScale(offsetParent))) || {
455
+ x: 1,
456
+ y: 1
457
+ } : {
458
+ x: 1,
459
+ y: 1
460
+ };
461
+ const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({
462
+ elements,
463
+ rect,
464
+ offsetParent,
465
+ strategy
466
+ }) : rect);
467
+ return {
468
+ top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,
469
+ bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,
470
+ left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,
471
+ right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x
472
+ };
473
+ }
474
+
475
+ function getPlacementList(alignment, autoAlignment, allowedPlacements) {
476
+ const allowedPlacementsSortedByAlignment = alignment ? [...allowedPlacements.filter(placement => getAlignment(placement) === alignment), ...allowedPlacements.filter(placement => getAlignment(placement) !== alignment)] : allowedPlacements.filter(placement => getSide(placement) === placement);
477
+ return allowedPlacementsSortedByAlignment.filter(placement => {
478
+ if (alignment) {
479
+ return getAlignment(placement) === alignment || (autoAlignment ? getOppositeAlignmentPlacement(placement) !== placement : false);
480
+ }
481
+ return true;
482
+ });
483
+ }
484
+ /**
485
+ * Optimizes the visibility of the floating element by choosing the placement
486
+ * that has the most space available automatically, without needing to specify a
487
+ * preferred placement. Alternative to `flip`.
488
+ * @see https://floating-ui.com/docs/autoPlacement
489
+ */
490
+ const autoPlacement$1 = function (options) {
491
+ if (options === void 0) {
492
+ options = {};
493
+ }
494
+ return {
495
+ name: 'autoPlacement',
496
+ options,
497
+ async fn(state) {
498
+ var _middlewareData$autoP, _middlewareData$autoP2, _placementsThatFitOnE;
499
+ const {
500
+ rects,
501
+ middlewareData,
502
+ placement,
503
+ platform,
504
+ elements
505
+ } = state;
506
+ const {
507
+ crossAxis = false,
508
+ alignment,
509
+ allowedPlacements = placements,
510
+ autoAlignment = true,
511
+ ...detectOverflowOptions
512
+ } = evaluate(options, state);
513
+ const placements$1 = alignment !== undefined || allowedPlacements === placements ? getPlacementList(alignment || null, autoAlignment, allowedPlacements) : allowedPlacements;
514
+ const overflow = await detectOverflow(state, detectOverflowOptions);
515
+ const currentIndex = ((_middlewareData$autoP = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP.index) || 0;
516
+ const currentPlacement = placements$1[currentIndex];
517
+ if (currentPlacement == null) {
518
+ return {};
519
+ }
520
+ const alignmentSides = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));
521
+
522
+ // Make `computeCoords` start from the right place.
523
+ if (placement !== currentPlacement) {
524
+ return {
525
+ reset: {
526
+ placement: placements$1[0]
527
+ }
528
+ };
529
+ }
530
+ const currentOverflows = [overflow[getSide(currentPlacement)], overflow[alignmentSides[0]], overflow[alignmentSides[1]]];
531
+ const allOverflows = [...(((_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.overflows) || []), {
532
+ placement: currentPlacement,
533
+ overflows: currentOverflows
534
+ }];
535
+ const nextPlacement = placements$1[currentIndex + 1];
536
+
537
+ // There are more placements to check.
538
+ if (nextPlacement) {
539
+ return {
540
+ data: {
541
+ index: currentIndex + 1,
542
+ overflows: allOverflows
543
+ },
544
+ reset: {
545
+ placement: nextPlacement
546
+ }
547
+ };
548
+ }
549
+ const placementsSortedByMostSpace = allOverflows.map(d => {
550
+ const alignment = getAlignment(d.placement);
551
+ return [d.placement, alignment && crossAxis ?
552
+ // Check along the mainAxis and main crossAxis side.
553
+ d.overflows.slice(0, 2).reduce((acc, v) => acc + v, 0) :
554
+ // Check only the mainAxis.
555
+ d.overflows[0], d.overflows];
556
+ }).sort((a, b) => a[1] - b[1]);
557
+ const placementsThatFitOnEachSide = placementsSortedByMostSpace.filter(d => d[2].slice(0,
558
+ // Aligned placements should not check their opposite crossAxis
559
+ // side.
560
+ getAlignment(d[0]) ? 2 : 3).every(v => v <= 0));
561
+ const resetPlacement = ((_placementsThatFitOnE = placementsThatFitOnEachSide[0]) == null ? void 0 : _placementsThatFitOnE[0]) || placementsSortedByMostSpace[0][0];
562
+ if (resetPlacement !== placement) {
563
+ return {
564
+ data: {
565
+ index: currentIndex + 1,
566
+ overflows: allOverflows
567
+ },
568
+ reset: {
569
+ placement: resetPlacement
570
+ }
571
+ };
572
+ }
573
+ return {};
574
+ }
575
+ };
576
+ };
577
+
578
+ /**
579
+ * Optimizes the visibility of the floating element by flipping the `placement`
580
+ * in order to keep it in view when the preferred placement(s) will overflow the
581
+ * clipping boundary. Alternative to `autoPlacement`.
582
+ * @see https://floating-ui.com/docs/flip
583
+ */
584
+ const flip$1 = function (options) {
585
+ if (options === void 0) {
586
+ options = {};
587
+ }
588
+ return {
589
+ name: 'flip',
590
+ options,
591
+ async fn(state) {
592
+ var _middlewareData$arrow, _middlewareData$flip;
593
+ const {
594
+ placement,
595
+ middlewareData,
596
+ rects,
597
+ initialPlacement,
598
+ platform,
599
+ elements
600
+ } = state;
601
+ const {
602
+ mainAxis: checkMainAxis = true,
603
+ crossAxis: checkCrossAxis = true,
604
+ fallbackPlacements: specifiedFallbackPlacements,
605
+ fallbackStrategy = 'bestFit',
606
+ fallbackAxisSideDirection = 'none',
607
+ flipAlignment = true,
608
+ ...detectOverflowOptions
609
+ } = evaluate(options, state);
610
+
611
+ // If a reset by the arrow was caused due to an alignment offset being
612
+ // added, we should skip any logic now since `flip()` has already done its
613
+ // work.
614
+ // https://github.com/floating-ui/floating-ui/issues/2549#issuecomment-1719601643
615
+ if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {
616
+ return {};
617
+ }
618
+ const side = getSide(placement);
619
+ const initialSideAxis = getSideAxis(initialPlacement);
620
+ const isBasePlacement = getSide(initialPlacement) === initialPlacement;
621
+ const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));
622
+ const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));
623
+ const hasFallbackAxisSideDirection = fallbackAxisSideDirection !== 'none';
624
+ if (!specifiedFallbackPlacements && hasFallbackAxisSideDirection) {
625
+ fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));
626
+ }
627
+ const placements = [initialPlacement, ...fallbackPlacements];
628
+ const overflow = await detectOverflow(state, detectOverflowOptions);
629
+ const overflows = [];
630
+ let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];
631
+ if (checkMainAxis) {
632
+ overflows.push(overflow[side]);
633
+ }
634
+ if (checkCrossAxis) {
635
+ const sides = getAlignmentSides(placement, rects, rtl);
636
+ overflows.push(overflow[sides[0]], overflow[sides[1]]);
637
+ }
638
+ overflowsData = [...overflowsData, {
639
+ placement,
640
+ overflows
641
+ }];
642
+
643
+ // One or more sides is overflowing.
644
+ if (!overflows.every(side => side <= 0)) {
645
+ var _middlewareData$flip2, _overflowsData$filter;
646
+ const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;
647
+ const nextPlacement = placements[nextIndex];
648
+ if (nextPlacement) {
649
+ // Try next placement and re-run the lifecycle.
650
+ return {
651
+ data: {
652
+ index: nextIndex,
653
+ overflows: overflowsData
654
+ },
655
+ reset: {
656
+ placement: nextPlacement
657
+ }
658
+ };
659
+ }
660
+
661
+ // First, find the candidates that fit on the mainAxis side of overflow,
662
+ // then find the placement that fits the best on the main crossAxis side.
663
+ let resetPlacement = (_overflowsData$filter = overflowsData.filter(d => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;
664
+
665
+ // Otherwise fallback.
666
+ if (!resetPlacement) {
667
+ switch (fallbackStrategy) {
668
+ case 'bestFit':
669
+ {
670
+ var _overflowsData$filter2;
671
+ const placement = (_overflowsData$filter2 = overflowsData.filter(d => {
672
+ if (hasFallbackAxisSideDirection) {
673
+ const currentSideAxis = getSideAxis(d.placement);
674
+ return currentSideAxis === initialSideAxis ||
675
+ // Create a bias to the `y` side axis due to horizontal
676
+ // reading directions favoring greater width.
677
+ currentSideAxis === 'y';
678
+ }
679
+ return true;
680
+ }).map(d => [d.placement, d.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$filter2[0];
681
+ if (placement) {
682
+ resetPlacement = placement;
683
+ }
684
+ break;
685
+ }
686
+ case 'initialPlacement':
687
+ resetPlacement = initialPlacement;
688
+ break;
689
+ }
690
+ }
691
+ if (placement !== resetPlacement) {
692
+ return {
693
+ reset: {
694
+ placement: resetPlacement
695
+ }
696
+ };
697
+ }
698
+ }
699
+ return {};
700
+ }
701
+ };
702
+ };
703
+
704
+ // For type backwards-compatibility, the `OffsetOptions` type was also
705
+ // Derivable.
706
+
707
+ async function convertValueToCoords(state, options) {
708
+ const {
709
+ placement,
710
+ platform,
711
+ elements
712
+ } = state;
713
+ const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));
714
+ const side = getSide(placement);
715
+ const alignment = getAlignment(placement);
716
+ const isVertical = getSideAxis(placement) === 'y';
717
+ const mainAxisMulti = ['left', 'top'].includes(side) ? -1 : 1;
718
+ const crossAxisMulti = rtl && isVertical ? -1 : 1;
719
+ const rawValue = evaluate(options, state);
720
+
721
+ // eslint-disable-next-line prefer-const
722
+ let {
723
+ mainAxis,
724
+ crossAxis,
725
+ alignmentAxis
726
+ } = typeof rawValue === 'number' ? {
727
+ mainAxis: rawValue,
728
+ crossAxis: 0,
729
+ alignmentAxis: null
730
+ } : {
731
+ mainAxis: rawValue.mainAxis || 0,
732
+ crossAxis: rawValue.crossAxis || 0,
733
+ alignmentAxis: rawValue.alignmentAxis
734
+ };
735
+ if (alignment && typeof alignmentAxis === 'number') {
736
+ crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;
737
+ }
738
+ return isVertical ? {
739
+ x: crossAxis * crossAxisMulti,
740
+ y: mainAxis * mainAxisMulti
741
+ } : {
742
+ x: mainAxis * mainAxisMulti,
743
+ y: crossAxis * crossAxisMulti
744
+ };
745
+ }
746
+
747
+ /**
748
+ * Modifies the placement by translating the floating element along the
749
+ * specified axes.
750
+ * A number (shorthand for `mainAxis` or distance), or an axes configuration
751
+ * object may be passed.
752
+ * @see https://floating-ui.com/docs/offset
753
+ */
754
+ const offset$1 = function (options) {
755
+ if (options === void 0) {
756
+ options = 0;
757
+ }
758
+ return {
759
+ name: 'offset',
760
+ options,
761
+ async fn(state) {
762
+ var _middlewareData$offse, _middlewareData$arrow;
763
+ const {
764
+ x,
765
+ y,
766
+ placement,
767
+ middlewareData
768
+ } = state;
769
+ const diffCoords = await convertValueToCoords(state, options);
770
+
771
+ // If the placement is the same and the arrow caused an alignment offset
772
+ // then we don't need to change the positioning coordinates.
773
+ if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {
774
+ return {};
775
+ }
776
+ return {
777
+ x: x + diffCoords.x,
778
+ y: y + diffCoords.y,
779
+ data: {
780
+ ...diffCoords,
781
+ placement
782
+ }
783
+ };
784
+ }
785
+ };
786
+ };
787
+
788
+ function hasWindow() {
789
+ return typeof window !== 'undefined';
790
+ }
791
+ function getNodeName(node) {
792
+ if (isNode(node)) {
793
+ return (node.nodeName || '').toLowerCase();
794
+ }
795
+ // Mocked nodes in testing environments may not be instances of Node. By
796
+ // returning `#document` an infinite loop won't occur.
797
+ // https://github.com/floating-ui/floating-ui/issues/2317
798
+ return '#document';
799
+ }
800
+ function getWindow(node) {
801
+ var _node$ownerDocument;
802
+ return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;
803
+ }
804
+ function getDocumentElement(node) {
805
+ var _ref;
806
+ return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;
807
+ }
808
+ function isNode(value) {
809
+ if (!hasWindow()) {
810
+ return false;
811
+ }
812
+ return value instanceof Node || value instanceof getWindow(value).Node;
813
+ }
814
+ function isElement(value) {
815
+ if (!hasWindow()) {
816
+ return false;
817
+ }
818
+ return value instanceof Element || value instanceof getWindow(value).Element;
819
+ }
820
+ function isHTMLElement(value) {
821
+ if (!hasWindow()) {
822
+ return false;
823
+ }
824
+ return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;
825
+ }
826
+ function isShadowRoot(value) {
827
+ if (!hasWindow() || typeof ShadowRoot === 'undefined') {
828
+ return false;
829
+ }
830
+ return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;
831
+ }
832
+ function isOverflowElement(element) {
833
+ const {
834
+ overflow,
835
+ overflowX,
836
+ overflowY,
837
+ display
838
+ } = getComputedStyle$1(element);
839
+ return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !['inline', 'contents'].includes(display);
840
+ }
841
+ function isTableElement(element) {
842
+ return ['table', 'td', 'th'].includes(getNodeName(element));
843
+ }
844
+ function isTopLayer(element) {
845
+ return [':popover-open', ':modal'].some(selector => {
846
+ try {
847
+ return element.matches(selector);
848
+ } catch (e) {
849
+ return false;
850
+ }
851
+ });
852
+ }
853
+ function isContainingBlock(elementOrCss) {
854
+ const webkit = isWebKit();
855
+ const css = isElement(elementOrCss) ? getComputedStyle$1(elementOrCss) : elementOrCss;
856
+
857
+ // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block
858
+ return css.transform !== 'none' || css.perspective !== 'none' || (css.containerType ? css.containerType !== 'normal' : false) || !webkit && (css.backdropFilter ? css.backdropFilter !== 'none' : false) || !webkit && (css.filter ? css.filter !== 'none' : false) || ['transform', 'perspective', 'filter'].some(value => (css.willChange || '').includes(value)) || ['paint', 'layout', 'strict', 'content'].some(value => (css.contain || '').includes(value));
859
+ }
860
+ function getContainingBlock(element) {
861
+ let currentNode = getParentNode(element);
862
+ while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {
863
+ if (isContainingBlock(currentNode)) {
864
+ return currentNode;
865
+ } else if (isTopLayer(currentNode)) {
866
+ return null;
867
+ }
868
+ currentNode = getParentNode(currentNode);
869
+ }
870
+ return null;
871
+ }
872
+ function isWebKit() {
873
+ if (typeof CSS === 'undefined' || !CSS.supports) return false;
874
+ return CSS.supports('-webkit-backdrop-filter', 'none');
875
+ }
876
+ function isLastTraversableNode(node) {
877
+ return ['html', 'body', '#document'].includes(getNodeName(node));
878
+ }
879
+ function getComputedStyle$1(element) {
880
+ return getWindow(element).getComputedStyle(element);
881
+ }
882
+ function getNodeScroll(element) {
883
+ if (isElement(element)) {
884
+ return {
885
+ scrollLeft: element.scrollLeft,
886
+ scrollTop: element.scrollTop
887
+ };
888
+ }
889
+ return {
890
+ scrollLeft: element.scrollX,
891
+ scrollTop: element.scrollY
892
+ };
893
+ }
894
+ function getParentNode(node) {
895
+ if (getNodeName(node) === 'html') {
896
+ return node;
897
+ }
898
+ const result =
899
+ // Step into the shadow DOM of the parent of a slotted node.
900
+ node.assignedSlot ||
901
+ // DOM Element detected.
902
+ node.parentNode ||
903
+ // ShadowRoot detected.
904
+ isShadowRoot(node) && node.host ||
905
+ // Fallback.
906
+ getDocumentElement(node);
907
+ return isShadowRoot(result) ? result.host : result;
908
+ }
909
+ function getNearestOverflowAncestor(node) {
910
+ const parentNode = getParentNode(node);
911
+ if (isLastTraversableNode(parentNode)) {
912
+ return node.ownerDocument ? node.ownerDocument.body : node.body;
913
+ }
914
+ if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {
915
+ return parentNode;
916
+ }
917
+ return getNearestOverflowAncestor(parentNode);
918
+ }
919
+ function getOverflowAncestors(node, list, traverseIframes) {
920
+ var _node$ownerDocument2;
921
+ if (list === void 0) {
922
+ list = [];
923
+ }
924
+ if (traverseIframes === void 0) {
925
+ traverseIframes = true;
926
+ }
927
+ const scrollableAncestor = getNearestOverflowAncestor(node);
928
+ const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);
929
+ const win = getWindow(scrollableAncestor);
930
+ if (isBody) {
931
+ const frameElement = getFrameElement(win);
932
+ return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []);
933
+ }
934
+ return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));
935
+ }
936
+ function getFrameElement(win) {
937
+ return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null;
938
+ }
939
+
940
+ function getCssDimensions(element) {
941
+ const css = getComputedStyle$1(element);
942
+ // In testing environments, the `width` and `height` properties are empty
943
+ // strings for SVG elements, returning NaN. Fallback to `0` in this case.
944
+ let width = parseFloat(css.width) || 0;
945
+ let height = parseFloat(css.height) || 0;
946
+ const hasOffset = isHTMLElement(element);
947
+ const offsetWidth = hasOffset ? element.offsetWidth : width;
948
+ const offsetHeight = hasOffset ? element.offsetHeight : height;
949
+ const shouldFallback = round(width) !== offsetWidth || round(height) !== offsetHeight;
950
+ if (shouldFallback) {
951
+ width = offsetWidth;
952
+ height = offsetHeight;
953
+ }
954
+ return {
955
+ width,
956
+ height,
957
+ $: shouldFallback
958
+ };
959
+ }
960
+
961
+ function unwrapElement(element) {
962
+ return !isElement(element) ? element.contextElement : element;
963
+ }
964
+
965
+ function getScale(element) {
966
+ const domElement = unwrapElement(element);
967
+ if (!isHTMLElement(domElement)) {
968
+ return createCoords(1);
969
+ }
970
+ const rect = domElement.getBoundingClientRect();
971
+ const {
972
+ width,
973
+ height,
974
+ $
975
+ } = getCssDimensions(domElement);
976
+ let x = ($ ? round(rect.width) : rect.width) / width;
977
+ let y = ($ ? round(rect.height) : rect.height) / height;
978
+
979
+ // 0, NaN, or Infinity should always fallback to 1.
980
+
981
+ if (!x || !Number.isFinite(x)) {
982
+ x = 1;
983
+ }
984
+ if (!y || !Number.isFinite(y)) {
985
+ y = 1;
986
+ }
987
+ return {
988
+ x,
989
+ y
990
+ };
991
+ }
992
+
993
+ const noOffsets = /*#__PURE__*/createCoords(0);
994
+ function getVisualOffsets(element) {
995
+ const win = getWindow(element);
996
+ if (!isWebKit() || !win.visualViewport) {
997
+ return noOffsets;
998
+ }
999
+ return {
1000
+ x: win.visualViewport.offsetLeft,
1001
+ y: win.visualViewport.offsetTop
1002
+ };
1003
+ }
1004
+ function shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) {
1005
+ if (isFixed === void 0) {
1006
+ isFixed = false;
1007
+ }
1008
+ if (!floatingOffsetParent || isFixed && floatingOffsetParent !== getWindow(element)) {
1009
+ return false;
1010
+ }
1011
+ return isFixed;
1012
+ }
1013
+
1014
+ function getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) {
1015
+ if (includeScale === void 0) {
1016
+ includeScale = false;
1017
+ }
1018
+ if (isFixedStrategy === void 0) {
1019
+ isFixedStrategy = false;
1020
+ }
1021
+ const clientRect = element.getBoundingClientRect();
1022
+ const domElement = unwrapElement(element);
1023
+ let scale = createCoords(1);
1024
+ if (includeScale) {
1025
+ if (offsetParent) {
1026
+ if (isElement(offsetParent)) {
1027
+ scale = getScale(offsetParent);
1028
+ }
1029
+ } else {
1030
+ scale = getScale(element);
1031
+ }
1032
+ }
1033
+ const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : createCoords(0);
1034
+ let x = (clientRect.left + visualOffsets.x) / scale.x;
1035
+ let y = (clientRect.top + visualOffsets.y) / scale.y;
1036
+ let width = clientRect.width / scale.x;
1037
+ let height = clientRect.height / scale.y;
1038
+ if (domElement) {
1039
+ const win = getWindow(domElement);
1040
+ const offsetWin = offsetParent && isElement(offsetParent) ? getWindow(offsetParent) : offsetParent;
1041
+ let currentWin = win;
1042
+ let currentIFrame = getFrameElement(currentWin);
1043
+ while (currentIFrame && offsetParent && offsetWin !== currentWin) {
1044
+ const iframeScale = getScale(currentIFrame);
1045
+ const iframeRect = currentIFrame.getBoundingClientRect();
1046
+ const css = getComputedStyle$1(currentIFrame);
1047
+ const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css.paddingLeft)) * iframeScale.x;
1048
+ const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css.paddingTop)) * iframeScale.y;
1049
+ x *= iframeScale.x;
1050
+ y *= iframeScale.y;
1051
+ width *= iframeScale.x;
1052
+ height *= iframeScale.y;
1053
+ x += left;
1054
+ y += top;
1055
+ currentWin = getWindow(currentIFrame);
1056
+ currentIFrame = getFrameElement(currentWin);
1057
+ }
1058
+ }
1059
+ return rectToClientRect({
1060
+ width,
1061
+ height,
1062
+ x,
1063
+ y
1064
+ });
1065
+ }
1066
+
1067
+ // If <html> has a CSS width greater than the viewport, then this will be
1068
+ // incorrect for RTL.
1069
+ function getWindowScrollBarX(element, rect) {
1070
+ const leftScroll = getNodeScroll(element).scrollLeft;
1071
+ if (!rect) {
1072
+ return getBoundingClientRect(getDocumentElement(element)).left + leftScroll;
1073
+ }
1074
+ return rect.left + leftScroll;
1075
+ }
1076
+
1077
+ function getHTMLOffset(documentElement, scroll, ignoreScrollbarX) {
1078
+ if (ignoreScrollbarX === void 0) {
1079
+ ignoreScrollbarX = false;
1080
+ }
1081
+ const htmlRect = documentElement.getBoundingClientRect();
1082
+ const x = htmlRect.left + scroll.scrollLeft - (ignoreScrollbarX ? 0 :
1083
+ // RTL <body> scrollbar.
1084
+ getWindowScrollBarX(documentElement, htmlRect));
1085
+ const y = htmlRect.top + scroll.scrollTop;
1086
+ return {
1087
+ x,
1088
+ y
1089
+ };
1090
+ }
1091
+
1092
+ function convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {
1093
+ let {
1094
+ elements,
1095
+ rect,
1096
+ offsetParent,
1097
+ strategy
1098
+ } = _ref;
1099
+ const isFixed = strategy === 'fixed';
1100
+ const documentElement = getDocumentElement(offsetParent);
1101
+ const topLayer = elements ? isTopLayer(elements.floating) : false;
1102
+ if (offsetParent === documentElement || topLayer && isFixed) {
1103
+ return rect;
1104
+ }
1105
+ let scroll = {
1106
+ scrollLeft: 0,
1107
+ scrollTop: 0
1108
+ };
1109
+ let scale = createCoords(1);
1110
+ const offsets = createCoords(0);
1111
+ const isOffsetParentAnElement = isHTMLElement(offsetParent);
1112
+ if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {
1113
+ if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {
1114
+ scroll = getNodeScroll(offsetParent);
1115
+ }
1116
+ if (isHTMLElement(offsetParent)) {
1117
+ const offsetRect = getBoundingClientRect(offsetParent);
1118
+ scale = getScale(offsetParent);
1119
+ offsets.x = offsetRect.x + offsetParent.clientLeft;
1120
+ offsets.y = offsetRect.y + offsetParent.clientTop;
1121
+ }
1122
+ }
1123
+ const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll, true) : createCoords(0);
1124
+ return {
1125
+ width: rect.width * scale.x,
1126
+ height: rect.height * scale.y,
1127
+ x: rect.x * scale.x - scroll.scrollLeft * scale.x + offsets.x + htmlOffset.x,
1128
+ y: rect.y * scale.y - scroll.scrollTop * scale.y + offsets.y + htmlOffset.y
1129
+ };
1130
+ }
1131
+
1132
+ function getClientRects(element) {
1133
+ return Array.from(element.getClientRects());
1134
+ }
1135
+
1136
+ // Gets the entire size of the scrollable document area, even extending outside
1137
+ // of the `<html>` and `<body>` rect bounds if horizontally scrollable.
1138
+ function getDocumentRect(element) {
1139
+ const html = getDocumentElement(element);
1140
+ const scroll = getNodeScroll(element);
1141
+ const body = element.ownerDocument.body;
1142
+ const width = max(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth);
1143
+ const height = max(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight);
1144
+ let x = -scroll.scrollLeft + getWindowScrollBarX(element);
1145
+ const y = -scroll.scrollTop;
1146
+ if (getComputedStyle$1(body).direction === 'rtl') {
1147
+ x += max(html.clientWidth, body.clientWidth) - width;
1148
+ }
1149
+ return {
1150
+ width,
1151
+ height,
1152
+ x,
1153
+ y
1154
+ };
1155
+ }
1156
+
1157
+ function getViewportRect(element, strategy) {
1158
+ const win = getWindow(element);
1159
+ const html = getDocumentElement(element);
1160
+ const visualViewport = win.visualViewport;
1161
+ let width = html.clientWidth;
1162
+ let height = html.clientHeight;
1163
+ let x = 0;
1164
+ let y = 0;
1165
+ if (visualViewport) {
1166
+ width = visualViewport.width;
1167
+ height = visualViewport.height;
1168
+ const visualViewportBased = isWebKit();
1169
+ if (!visualViewportBased || visualViewportBased && strategy === 'fixed') {
1170
+ x = visualViewport.offsetLeft;
1171
+ y = visualViewport.offsetTop;
1172
+ }
1173
+ }
1174
+ return {
1175
+ width,
1176
+ height,
1177
+ x,
1178
+ y
1179
+ };
1180
+ }
1181
+
1182
+ // Returns the inner client rect, subtracting scrollbars if present.
1183
+ function getInnerBoundingClientRect(element, strategy) {
1184
+ const clientRect = getBoundingClientRect(element, true, strategy === 'fixed');
1185
+ const top = clientRect.top + element.clientTop;
1186
+ const left = clientRect.left + element.clientLeft;
1187
+ const scale = isHTMLElement(element) ? getScale(element) : createCoords(1);
1188
+ const width = element.clientWidth * scale.x;
1189
+ const height = element.clientHeight * scale.y;
1190
+ const x = left * scale.x;
1191
+ const y = top * scale.y;
1192
+ return {
1193
+ width,
1194
+ height,
1195
+ x,
1196
+ y
1197
+ };
1198
+ }
1199
+ function getClientRectFromClippingAncestor(element, clippingAncestor, strategy) {
1200
+ let rect;
1201
+ if (clippingAncestor === 'viewport') {
1202
+ rect = getViewportRect(element, strategy);
1203
+ } else if (clippingAncestor === 'document') {
1204
+ rect = getDocumentRect(getDocumentElement(element));
1205
+ } else if (isElement(clippingAncestor)) {
1206
+ rect = getInnerBoundingClientRect(clippingAncestor, strategy);
1207
+ } else {
1208
+ const visualOffsets = getVisualOffsets(element);
1209
+ rect = {
1210
+ x: clippingAncestor.x - visualOffsets.x,
1211
+ y: clippingAncestor.y - visualOffsets.y,
1212
+ width: clippingAncestor.width,
1213
+ height: clippingAncestor.height
1214
+ };
1215
+ }
1216
+ return rectToClientRect(rect);
1217
+ }
1218
+ function hasFixedPositionAncestor(element, stopNode) {
1219
+ const parentNode = getParentNode(element);
1220
+ if (parentNode === stopNode || !isElement(parentNode) || isLastTraversableNode(parentNode)) {
1221
+ return false;
1222
+ }
1223
+ return getComputedStyle$1(parentNode).position === 'fixed' || hasFixedPositionAncestor(parentNode, stopNode);
1224
+ }
1225
+
1226
+ // A "clipping ancestor" is an `overflow` element with the characteristic of
1227
+ // clipping (or hiding) child elements. This returns all clipping ancestors
1228
+ // of the given element up the tree.
1229
+ function getClippingElementAncestors(element, cache) {
1230
+ const cachedResult = cache.get(element);
1231
+ if (cachedResult) {
1232
+ return cachedResult;
1233
+ }
1234
+ let result = getOverflowAncestors(element, [], false).filter(el => isElement(el) && getNodeName(el) !== 'body');
1235
+ let currentContainingBlockComputedStyle = null;
1236
+ const elementIsFixed = getComputedStyle$1(element).position === 'fixed';
1237
+ let currentNode = elementIsFixed ? getParentNode(element) : element;
1238
+
1239
+ // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block
1240
+ while (isElement(currentNode) && !isLastTraversableNode(currentNode)) {
1241
+ const computedStyle = getComputedStyle$1(currentNode);
1242
+ const currentNodeIsContaining = isContainingBlock(currentNode);
1243
+ if (!currentNodeIsContaining && computedStyle.position === 'fixed') {
1244
+ currentContainingBlockComputedStyle = null;
1245
+ }
1246
+ const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === 'static' && !!currentContainingBlockComputedStyle && ['absolute', 'fixed'].includes(currentContainingBlockComputedStyle.position) || isOverflowElement(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode);
1247
+ if (shouldDropCurrentNode) {
1248
+ // Drop non-containing blocks.
1249
+ result = result.filter(ancestor => ancestor !== currentNode);
1250
+ } else {
1251
+ // Record last containing block for next iteration.
1252
+ currentContainingBlockComputedStyle = computedStyle;
1253
+ }
1254
+ currentNode = getParentNode(currentNode);
1255
+ }
1256
+ cache.set(element, result);
1257
+ return result;
1258
+ }
1259
+
1260
+ // Gets the maximum area that the element is visible in due to any number of
1261
+ // clipping ancestors.
1262
+ function getClippingRect(_ref) {
1263
+ let {
1264
+ element,
1265
+ boundary,
1266
+ rootBoundary,
1267
+ strategy
1268
+ } = _ref;
1269
+ const elementClippingAncestors = boundary === 'clippingAncestors' ? isTopLayer(element) ? [] : getClippingElementAncestors(element, this._c) : [].concat(boundary);
1270
+ const clippingAncestors = [...elementClippingAncestors, rootBoundary];
1271
+ const firstClippingAncestor = clippingAncestors[0];
1272
+ const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => {
1273
+ const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);
1274
+ accRect.top = max(rect.top, accRect.top);
1275
+ accRect.right = min(rect.right, accRect.right);
1276
+ accRect.bottom = min(rect.bottom, accRect.bottom);
1277
+ accRect.left = max(rect.left, accRect.left);
1278
+ return accRect;
1279
+ }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy));
1280
+ return {
1281
+ width: clippingRect.right - clippingRect.left,
1282
+ height: clippingRect.bottom - clippingRect.top,
1283
+ x: clippingRect.left,
1284
+ y: clippingRect.top
1285
+ };
1286
+ }
1287
+
1288
+ function getDimensions(element) {
1289
+ const {
1290
+ width,
1291
+ height
1292
+ } = getCssDimensions(element);
1293
+ return {
1294
+ width,
1295
+ height
1296
+ };
1297
+ }
1298
+
1299
+ function getRectRelativeToOffsetParent(element, offsetParent, strategy) {
1300
+ const isOffsetParentAnElement = isHTMLElement(offsetParent);
1301
+ const documentElement = getDocumentElement(offsetParent);
1302
+ const isFixed = strategy === 'fixed';
1303
+ const rect = getBoundingClientRect(element, true, isFixed, offsetParent);
1304
+ let scroll = {
1305
+ scrollLeft: 0,
1306
+ scrollTop: 0
1307
+ };
1308
+ const offsets = createCoords(0);
1309
+ if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {
1310
+ if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {
1311
+ scroll = getNodeScroll(offsetParent);
1312
+ }
1313
+ if (isOffsetParentAnElement) {
1314
+ const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent);
1315
+ offsets.x = offsetRect.x + offsetParent.clientLeft;
1316
+ offsets.y = offsetRect.y + offsetParent.clientTop;
1317
+ } else if (documentElement) {
1318
+ // If the <body> scrollbar appears on the left (e.g. RTL systems). Use
1319
+ // Firefox with layout.scrollbar.side = 3 in about:config to test this.
1320
+ offsets.x = getWindowScrollBarX(documentElement);
1321
+ }
1322
+ }
1323
+ const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll) : createCoords(0);
1324
+ const x = rect.left + scroll.scrollLeft - offsets.x - htmlOffset.x;
1325
+ const y = rect.top + scroll.scrollTop - offsets.y - htmlOffset.y;
1326
+ return {
1327
+ x,
1328
+ y,
1329
+ width: rect.width,
1330
+ height: rect.height
1331
+ };
1332
+ }
1333
+
1334
+ function isStaticPositioned(element) {
1335
+ return getComputedStyle$1(element).position === 'static';
1336
+ }
1337
+
1338
+ function getTrueOffsetParent(element, polyfill) {
1339
+ if (!isHTMLElement(element) || getComputedStyle$1(element).position === 'fixed') {
1340
+ return null;
1341
+ }
1342
+ if (polyfill) {
1343
+ return polyfill(element);
1344
+ }
1345
+ let rawOffsetParent = element.offsetParent;
1346
+
1347
+ // Firefox returns the <html> element as the offsetParent if it's non-static,
1348
+ // while Chrome and Safari return the <body> element. The <body> element must
1349
+ // be used to perform the correct calculations even if the <html> element is
1350
+ // non-static.
1351
+ if (getDocumentElement(element) === rawOffsetParent) {
1352
+ rawOffsetParent = rawOffsetParent.ownerDocument.body;
1353
+ }
1354
+ return rawOffsetParent;
1355
+ }
1356
+
1357
+ // Gets the closest ancestor positioned element. Handles some edge cases,
1358
+ // such as table ancestors and cross browser bugs.
1359
+ function getOffsetParent(element, polyfill) {
1360
+ const win = getWindow(element);
1361
+ if (isTopLayer(element)) {
1362
+ return win;
1363
+ }
1364
+ if (!isHTMLElement(element)) {
1365
+ let svgOffsetParent = getParentNode(element);
1366
+ while (svgOffsetParent && !isLastTraversableNode(svgOffsetParent)) {
1367
+ if (isElement(svgOffsetParent) && !isStaticPositioned(svgOffsetParent)) {
1368
+ return svgOffsetParent;
1369
+ }
1370
+ svgOffsetParent = getParentNode(svgOffsetParent);
1371
+ }
1372
+ return win;
1373
+ }
1374
+ let offsetParent = getTrueOffsetParent(element, polyfill);
1375
+ while (offsetParent && isTableElement(offsetParent) && isStaticPositioned(offsetParent)) {
1376
+ offsetParent = getTrueOffsetParent(offsetParent, polyfill);
1377
+ }
1378
+ if (offsetParent && isLastTraversableNode(offsetParent) && isStaticPositioned(offsetParent) && !isContainingBlock(offsetParent)) {
1379
+ return win;
1380
+ }
1381
+ return offsetParent || getContainingBlock(element) || win;
1382
+ }
1383
+
1384
+ const getElementRects = async function (data) {
1385
+ const getOffsetParentFn = this.getOffsetParent || getOffsetParent;
1386
+ const getDimensionsFn = this.getDimensions;
1387
+ const floatingDimensions = await getDimensionsFn(data.floating);
1388
+ return {
1389
+ reference: getRectRelativeToOffsetParent(data.reference, await getOffsetParentFn(data.floating), data.strategy),
1390
+ floating: {
1391
+ x: 0,
1392
+ y: 0,
1393
+ width: floatingDimensions.width,
1394
+ height: floatingDimensions.height
1395
+ }
1396
+ };
1397
+ };
1398
+
1399
+ function isRTL(element) {
1400
+ return getComputedStyle$1(element).direction === 'rtl';
1401
+ }
1402
+
1403
+ const platform = {
1404
+ convertOffsetParentRelativeRectToViewportRelativeRect,
1405
+ getDocumentElement,
1406
+ getClippingRect,
1407
+ getOffsetParent,
1408
+ getElementRects,
1409
+ getClientRects,
1410
+ getDimensions,
1411
+ getScale,
1412
+ isElement,
1413
+ isRTL
1414
+ };
1415
+
1416
+ // https://samthor.au/2021/observing-dom/
1417
+ function observeMove(element, onMove) {
1418
+ let io = null;
1419
+ let timeoutId;
1420
+ const root = getDocumentElement(element);
1421
+ function cleanup() {
1422
+ var _io;
1423
+ clearTimeout(timeoutId);
1424
+ (_io = io) == null || _io.disconnect();
1425
+ io = null;
1426
+ }
1427
+ function refresh(skip, threshold) {
1428
+ if (skip === void 0) {
1429
+ skip = false;
1430
+ }
1431
+ if (threshold === void 0) {
1432
+ threshold = 1;
1433
+ }
1434
+ cleanup();
1435
+ const {
1436
+ left,
1437
+ top,
1438
+ width,
1439
+ height
1440
+ } = element.getBoundingClientRect();
1441
+ if (!skip) {
1442
+ onMove();
1443
+ }
1444
+ if (!width || !height) {
1445
+ return;
1446
+ }
1447
+ const insetTop = floor(top);
1448
+ const insetRight = floor(root.clientWidth - (left + width));
1449
+ const insetBottom = floor(root.clientHeight - (top + height));
1450
+ const insetLeft = floor(left);
1451
+ const rootMargin = -insetTop + "px " + -insetRight + "px " + -insetBottom + "px " + -insetLeft + "px";
1452
+ const options = {
1453
+ rootMargin,
1454
+ threshold: max(0, min(1, threshold)) || 1
1455
+ };
1456
+ let isFirstUpdate = true;
1457
+ function handleObserve(entries) {
1458
+ const ratio = entries[0].intersectionRatio;
1459
+ if (ratio !== threshold) {
1460
+ if (!isFirstUpdate) {
1461
+ return refresh();
1462
+ }
1463
+ if (!ratio) {
1464
+ // If the reference is clipped, the ratio is 0. Throttle the refresh
1465
+ // to prevent an infinite loop of updates.
1466
+ timeoutId = setTimeout(() => {
1467
+ refresh(false, 1e-7);
1468
+ }, 1000);
1469
+ } else {
1470
+ refresh(false, ratio);
1471
+ }
1472
+ }
1473
+ isFirstUpdate = false;
1474
+ }
1475
+
1476
+ // Older browsers don't support a `document` as the root and will throw an
1477
+ // error.
1478
+ try {
1479
+ io = new IntersectionObserver(handleObserve, {
1480
+ ...options,
1481
+ // Handle <iframe>s
1482
+ root: root.ownerDocument
1483
+ });
1484
+ } catch (e) {
1485
+ io = new IntersectionObserver(handleObserve, options);
1486
+ }
1487
+ io.observe(element);
1488
+ }
1489
+ refresh(true);
1490
+ return cleanup;
1491
+ }
1492
+
1493
+ /**
1494
+ * Automatically updates the position of the floating element when necessary.
1495
+ * Should only be called when the floating element is mounted on the DOM or
1496
+ * visible on the screen.
1497
+ * @returns cleanup function that should be invoked when the floating element is
1498
+ * removed from the DOM or hidden from the screen.
1499
+ * @see https://floating-ui.com/docs/autoUpdate
1500
+ */
1501
+ function autoUpdate(reference, floating, update, options) {
1502
+ if (options === void 0) {
1503
+ options = {};
1504
+ }
1505
+ const {
1506
+ ancestorScroll = true,
1507
+ ancestorResize = true,
1508
+ elementResize = typeof ResizeObserver === 'function',
1509
+ layoutShift = typeof IntersectionObserver === 'function',
1510
+ animationFrame = false
1511
+ } = options;
1512
+ const referenceEl = unwrapElement(reference);
1513
+ const ancestors = ancestorScroll || ancestorResize ? [...(referenceEl ? getOverflowAncestors(referenceEl) : []), ...getOverflowAncestors(floating)] : [];
1514
+ ancestors.forEach(ancestor => {
1515
+ ancestorScroll && ancestor.addEventListener('scroll', update, {
1516
+ passive: true
1517
+ });
1518
+ ancestorResize && ancestor.addEventListener('resize', update);
1519
+ });
1520
+ const cleanupIo = referenceEl && layoutShift ? observeMove(referenceEl, update) : null;
1521
+ let reobserveFrame = -1;
1522
+ let resizeObserver = null;
1523
+ if (elementResize) {
1524
+ resizeObserver = new ResizeObserver(_ref => {
1525
+ let [firstEntry] = _ref;
1526
+ if (firstEntry && firstEntry.target === referenceEl && resizeObserver) {
1527
+ // Prevent update loops when using the `size` middleware.
1528
+ // https://github.com/floating-ui/floating-ui/issues/1740
1529
+ resizeObserver.unobserve(floating);
1530
+ cancelAnimationFrame(reobserveFrame);
1531
+ reobserveFrame = requestAnimationFrame(() => {
1532
+ var _resizeObserver;
1533
+ (_resizeObserver = resizeObserver) == null || _resizeObserver.observe(floating);
1534
+ });
1535
+ }
1536
+ update();
1537
+ });
1538
+ if (referenceEl && !animationFrame) {
1539
+ resizeObserver.observe(referenceEl);
1540
+ }
1541
+ resizeObserver.observe(floating);
1542
+ }
1543
+ let frameId;
1544
+ let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null;
1545
+ if (animationFrame) {
1546
+ frameLoop();
1547
+ }
1548
+ function frameLoop() {
1549
+ const nextRefRect = getBoundingClientRect(reference);
1550
+ if (prevRefRect && (nextRefRect.x !== prevRefRect.x || nextRefRect.y !== prevRefRect.y || nextRefRect.width !== prevRefRect.width || nextRefRect.height !== prevRefRect.height)) {
1551
+ update();
1552
+ }
1553
+ prevRefRect = nextRefRect;
1554
+ frameId = requestAnimationFrame(frameLoop);
1555
+ }
1556
+ update();
1557
+ return () => {
1558
+ var _resizeObserver2;
1559
+ ancestors.forEach(ancestor => {
1560
+ ancestorScroll && ancestor.removeEventListener('scroll', update);
1561
+ ancestorResize && ancestor.removeEventListener('resize', update);
1562
+ });
1563
+ cleanupIo == null || cleanupIo();
1564
+ (_resizeObserver2 = resizeObserver) == null || _resizeObserver2.disconnect();
1565
+ resizeObserver = null;
1566
+ if (animationFrame) {
1567
+ cancelAnimationFrame(frameId);
1568
+ }
1569
+ };
1570
+ }
1571
+
1572
+ /**
1573
+ * Modifies the placement by translating the floating element along the
1574
+ * specified axes.
1575
+ * A number (shorthand for `mainAxis` or distance), or an axes configuration
1576
+ * object may be passed.
1577
+ * @see https://floating-ui.com/docs/offset
1578
+ */
1579
+ const offset = offset$1;
1580
+
1581
+ /**
1582
+ * Optimizes the visibility of the floating element by choosing the placement
1583
+ * that has the most space available automatically, without needing to specify a
1584
+ * preferred placement. Alternative to `flip`.
1585
+ * @see https://floating-ui.com/docs/autoPlacement
1586
+ */
1587
+ const autoPlacement = autoPlacement$1;
1588
+
1589
+ /**
1590
+ * Optimizes the visibility of the floating element by flipping the `placement`
1591
+ * in order to keep it in view when the preferred placement(s) will overflow the
1592
+ * clipping boundary. Alternative to `autoPlacement`.
1593
+ * @see https://floating-ui.com/docs/flip
1594
+ */
1595
+ const flip = flip$1;
1596
+
1597
+ /**
1598
+ * Computes the `x` and `y` coordinates that will place the floating element
1599
+ * next to a given reference element.
1600
+ */
1601
+ const computePosition = (reference, floating, options) => {
1602
+ // This caches the expensive `getClippingElementAncestors` function so that
1603
+ // multiple lifecycle resets re-use the same result. It only lives for a
1604
+ // single call. If other functions become expensive, we can add them as well.
1605
+ const cache = new Map();
1606
+ const mergedOptions = {
1607
+ platform,
1608
+ ...options
1609
+ };
1610
+ const platformWithCache = {
1611
+ ...mergedOptions.platform,
1612
+ _c: cache
1613
+ };
1614
+ return computePosition$1(reference, floating, {
1615
+ ...mergedOptions,
1616
+ platform: platformWithCache
1617
+ });
1618
+ };
1619
+
1620
+ /* eslint-disable line-comment-position, no-inline-comments */
1621
+
1622
+
1623
+ class AuroFloatingUI {
1624
+ constructor() {
1625
+ // Store event listener references for cleanup
1626
+ this.focusHandler = null;
1627
+ this.clickHandler = null;
1628
+ this.keyDownHandler = null;
1629
+
1630
+ /**
1631
+ * @private
1632
+ */
1633
+ this.eventPrefix = undefined;
1634
+ }
1635
+
1636
+ /**
1637
+ * @private
1638
+ * Adjusts the size of the bib content based on the bibSizer dimensions.
1639
+ *
1640
+ * This method retrieves the computed styles of the bibSizer element and applies them to the bib content.
1641
+ * If the fullscreen parameter is true, it resets the dimensions to their default values. Otherwise, it
1642
+ * mirrors the width and height from the bibSizer, ensuring that they are not set to zero.
1643
+ *
1644
+ * @param {boolean} fullscreen - A flag indicating whether to reset the dimensions for fullscreen mode.
1645
+ * If true, the bib content dimensions are cleared; if false, they are set
1646
+ * based on the bibSizer's computed styles.
1647
+ */
1648
+ mirrorSize(fullscreen) {
1649
+ // mirror the boxsize from bibSizer
1650
+ if (this.element.bibSizer) {
1651
+ const sizerStyle = window.getComputedStyle(this.element.bibSizer);
1652
+ const bibContent = this.element.bib.shadowRoot.querySelector(".container");
1653
+ if (fullscreen) {
1654
+ bibContent.style.width = '';
1655
+ bibContent.style.height = '';
1656
+ bibContent.style.maxWidth = '';
1657
+ bibContent.style.maxHeight = '';
1658
+ } else {
1659
+ if (sizerStyle.width !== '0px') {
1660
+ bibContent.style.width = sizerStyle.width;
1661
+ }
1662
+ if (sizerStyle.height !== '0px') {
1663
+ bibContent.style.height = sizerStyle.height;
1664
+ }
1665
+ bibContent.style.maxWidth = sizerStyle.maxWidth;
1666
+ bibContent.style.maxHeight = sizerStyle.maxHeight;
1667
+ }
1668
+ }
1669
+ }
1670
+
1671
+ /**
1672
+ * @private
1673
+ * Determines the positioning strategy based on the current viewport size and mobile breakpoint.
1674
+ *
1675
+ * This method checks if the current viewport width is less than or equal to the specified mobile fullscreen breakpoint
1676
+ * defined in the bib element. If it is, the strategy is set to 'fullscreen'; otherwise, it defaults to 'floating'.
1677
+ *
1678
+ * @returns {String} The positioning strategy, either 'fullscreen' or 'floating'.
1679
+ */
1680
+ getPositioningStrategy() {
1681
+ let strategy = 'floating';
1682
+ if (this.element.bib.mobileFullscreenBreakpoint) {
1683
+ const isMobile = window.matchMedia(`(max-width: ${this.element.bib.mobileFullscreenBreakpoint})`).matches;
1684
+ if (isMobile) {
1685
+ strategy = 'fullscreen';
1686
+ }
1687
+ }
1688
+ return strategy;
1689
+ }
1690
+
1691
+ /**
1692
+ * @private
1693
+ * Positions the bib element based on the current configuration and positioning strategy.
1694
+ *
1695
+ * This method determines the appropriate positioning strategy (fullscreen or not) and configures the bib accordingly.
1696
+ * It also sets up middleware for the floater configuration, computes the position of the bib relative to the trigger element,
1697
+ * and applies the calculated position to the bib's style.
1698
+ */
1699
+ position() {
1700
+ const strategy = this.getPositioningStrategy();
1701
+ if (strategy === 'fullscreen') {
1702
+ this.configureBibFullscreen(true);
1703
+ this.mirrorSize(true);
1704
+ } else {
1705
+ this.configureBibFullscreen(false);
1706
+ this.mirrorSize(false);
1707
+
1708
+ // Define the middlware for the floater configuration
1709
+ const middleware = [
1710
+ offset(this.element.floaterConfig.offset || 0),
1711
+ ...(this.element.floaterConfig.flip ? [flip()] : []), // Add flip middleware if flip is enabled
1712
+ ...(this.element.floaterConfig.autoPlacement ? [autoPlacement()] : []), // Add autoPlacement middleware if autoPlacement is enabled
1713
+ ];
1714
+
1715
+ // Compute the position of the bib
1716
+ computePosition(this.element.trigger, this.element.bib, {
1717
+ placement: this.element.floaterConfig.placement || 'bottom',
1718
+ middleware: middleware || []
1719
+ }).then(({x, y}) => { // eslint-disable-line id-length
1720
+ Object.assign(this.element.bib.style, {
1721
+ left: `${x}px`,
1722
+ top: `${y}px`,
1723
+ });
1724
+ });
1725
+ }
1726
+ }
1727
+
1728
+ /**
1729
+ * @private
1730
+ * Configures the bib element for fullscreen mode based on the mobile status.
1731
+ *
1732
+ * This method sets the 'isFullscreen' attribute on the bib element to "true" if the `isMobile` parameter is true,
1733
+ * and resets its position to the top-left corner of the viewport. If `isMobile` is false, it removes the
1734
+ * 'isFullscreen' attribute, indicating that the bib is not in fullscreen mode.
1735
+ *
1736
+ * @param {boolean} isMobile - A flag indicating whether the current device is mobile.
1737
+ */
1738
+ configureBibFullscreen(isMobile) {
1739
+ if (isMobile) {
1740
+ this.element.bib.setAttribute('isFullscreen', "true");
1741
+ // reset the prev position
1742
+ this.element.bib.style.top = "0px";
1743
+ this.element.bib.style.left = "0px";
1744
+ } else {
1745
+ this.element.bib.removeAttribute('isFullscreen');
1746
+ }
1747
+ }
1748
+
1749
+ updateState() {
1750
+ const isVisible = this.element.isPopoverVisible;
1751
+ this.element.trigger.setAttribute('aria-expanded', isVisible);
1752
+
1753
+ if (isVisible) {
1754
+ this.element.bib.setAttribute('data-show', true);
1755
+ } else {
1756
+ this.element.bib.removeAttribute('data-show');
1757
+ }
1758
+
1759
+ if (!isVisible) {
1760
+ this.cleanupHideHandlers();
1761
+ try {
1762
+ this.element.cleanup?.();
1763
+ } catch (error) {
1764
+ // Do nothing
1765
+ }
1766
+ }
1767
+ }
1768
+
1769
+ handleFocusLoss() {
1770
+ if (this.element.noHideOnThisFocusLoss ||
1771
+ this.element.hasAttribute('noHideOnThisFocusLoss')) {
1772
+ return;
1773
+ }
1774
+
1775
+ const {activeElement} = document;
1776
+ if (activeElement === document.querySelector('body') ||
1777
+ this.element.contains(activeElement) ||
1778
+ this.element.bibContent?.contains(activeElement)) {
1779
+ return;
1780
+ }
1781
+
1782
+ this.hideBib();
1783
+ }
1784
+
1785
+ setupHideHandlers() {
1786
+ // Define handlers & store references
1787
+ this.focusHandler = () => this.handleFocusLoss();
1788
+
1789
+ this.clickHandler = (evt) => {
1790
+ if (!evt.composedPath().includes(this.element.trigger) &&
1791
+ !evt.composedPath().includes(this.element.bibContent)) {
1792
+ this.hideBib();
1793
+ }
1794
+ };
1795
+
1796
+ // ESC key handler
1797
+ this.keyDownHandler = (evt) => {
1798
+ if (evt.key === 'Escape' && this.element.isPopoverVisible) {
1799
+ this.hideBib();
1800
+ }
1801
+ };
1802
+
1803
+ // Add event listeners using the stored references
1804
+ document.addEventListener('focusin', this.focusHandler);
1805
+ window.addEventListener('click', this.clickHandler);
1806
+ document.addEventListener('keydown', this.keyDownHandler);
1807
+ }
1808
+
1809
+ cleanupHideHandlers() {
1810
+ // Remove event listeners if they exist
1811
+ if (this.focusHandler) {
1812
+ document.removeEventListener('focusin', this.focusHandler);
1813
+ this.focusHandler = null;
1814
+ }
1815
+
1816
+ if (this.clickHandler) {
1817
+ window.removeEventListener('click', this.clickHandler);
1818
+ this.clickHandler = null;
1819
+ }
1820
+
1821
+ if (this.keyDownHandler) {
1822
+ document.removeEventListener('keydown', this.keyDownHandler);
1823
+ this.keyDownHandler = null;
1824
+ }
1825
+ }
1826
+
1827
+ handleUpdate(changedProperties) {
1828
+ if (changedProperties.has('isPopoverVisible')) {
1829
+ this.updateState();
1830
+ }
1831
+ }
1832
+
1833
+ updateCurrentExpandedDropdown() {
1834
+ // Close any other dropdown that is already open
1835
+ if (document.expandedAuroDropdown) {
1836
+ this.hideBib(document.expandedAuroDropdown);
1837
+ }
1838
+
1839
+ document.expandedAuroDropdown = this;
1840
+ }
1841
+
1842
+ showBib() {
1843
+ if (!this.element.disabled && !this.element.isPopoverVisible) {
1844
+ this.updateCurrentExpandedDropdown();
1845
+ this.element.isPopoverVisible = true;
1846
+ this.element.triggerChevron?.setAttribute('data-expanded', true);
1847
+ this.dispatchEventDropdownToggle();
1848
+ this.position();
1849
+
1850
+ // Clean up any existing handlers before setting up new ones
1851
+ this.cleanupHideHandlers();
1852
+ this.setupHideHandlers();
1853
+
1854
+ // Setup auto update to handle resize and scroll
1855
+ this.element.cleanup = autoUpdate(this.element.trigger, this.element.bib, () => {
1856
+ this.position();
1857
+ });
1858
+ }
1859
+ }
1860
+
1861
+ hideBib() {
1862
+ if (this.element.isPopoverVisible && !this.element.disabled && !this.element.noToggle) {
1863
+ this.element.isPopoverVisible = false;
1864
+ this.element.triggerChevron?.removeAttribute('data-expanded');
1865
+ this.dispatchEventDropdownToggle();
1866
+ }
1867
+ }
1868
+
1869
+ /**
1870
+ * @private
1871
+ * @returns {void} Dispatches event with an object showing the state of the dropdown.
1872
+ */
1873
+ dispatchEventDropdownToggle() {
1874
+ const event = new CustomEvent(this.eventPrefix ? `${this.eventPrefix}-toggled` : 'toggled', {
1875
+ detail: {
1876
+ expanded: this.isPopoverVisible,
1877
+ },
1878
+ composed: true
1879
+ });
1880
+
1881
+ this.element.dispatchEvent(event);
1882
+ }
1883
+
1884
+ handleClick() {
1885
+ if (this.element.isPopoverVisible) {
1886
+ this.hideBib();
1887
+ } else {
1888
+ this.showBib();
1889
+ }
1890
+
1891
+ const event = new CustomEvent(this.eventPrefix ? `${this.eventPrefix}-triggerClick` : "triggerClick", {
1892
+ composed: true,
1893
+ details: {
1894
+ expanded: this.element.isPopoverVisible
1895
+ }
1896
+ });
1897
+
1898
+ this.element.dispatchEvent(event);
1899
+ }
1900
+
1901
+ handleEvent(event) {
1902
+ if (!this.element.disableEventShow) {
1903
+ switch (event.type) {
1904
+ case 'keydown':
1905
+ // Support both Enter and Space keys for accessibility
1906
+ // Space is included as it's expected behavior for interactive elements
1907
+ if (event.key === 'Enter' || event.key === ' ') {
1908
+ event.preventDefault(); // Prevent page scroll on space
1909
+ this.handleClick();
1910
+ }
1911
+ break;
1912
+ case 'mouseenter':
1913
+ if (this.element.hoverToggle) {
1914
+ this.showBib();
1915
+ }
1916
+ break;
1917
+ case 'mouseleave':
1918
+ if (this.element.hoverToggle) {
1919
+ this.hideBib();
1920
+ }
1921
+ break;
1922
+ case 'focus':
1923
+ if (this.element.focusShow) {
1924
+ /*
1925
+ This needs to better handle clicking that gives focus -
1926
+ currently it shows and then immediately hides the bib
1927
+ */
1928
+ this.showBib();
1929
+ }
1930
+ break;
1931
+ case 'blur':
1932
+ this.handleFocusLoss();
1933
+ break;
1934
+ case 'click':
1935
+ if (document.activeElement === document.body) {
1936
+ event.currentTarget.focus();
1937
+ }
1938
+ this.handleClick();
1939
+ break;
1940
+ // Do nothing
1941
+ }
1942
+ }
1943
+ }
1944
+
1945
+ handleTriggerTabIndex() {
1946
+ const focusableElementSelectors = [
1947
+ 'a',
1948
+ 'button',
1949
+ 'input:not([type="hidden"])',
1950
+ 'select',
1951
+ 'textarea',
1952
+ '[tabindex]:not([tabindex="-1"])',
1953
+ 'auro-button',
1954
+ 'auro-input',
1955
+ 'auro-hyperlink'
1956
+ ];
1957
+
1958
+ const triggerNode = this.element.querySelectorAll('[slot="trigger"]')[0];
1959
+ const triggerNodeTagName = triggerNode.tagName.toLowerCase();
1960
+
1961
+ focusableElementSelectors.forEach((selector) => {
1962
+ // Check if the trigger node element is focusable
1963
+ if (triggerNodeTagName === selector) {
1964
+ this.element.tabIndex = -1;
1965
+ return;
1966
+ }
1967
+
1968
+ // Check if any child is focusable
1969
+ if (triggerNode.querySelector(selector)) {
1970
+ this.element.tabIndex = -1;
1971
+ }
1972
+ });
1973
+ }
1974
+
1975
+ configure(elem, eventPrefix) {
1976
+ this.eventPrefix = eventPrefix;
1977
+ this.element = elem;
1978
+ this.element.trigger = this.element.shadowRoot.querySelector('#trigger');
1979
+ this.element.bib = this.element.shadowRoot.querySelector('#bib');
1980
+ this.element.bibSizer = this.element.shadowRoot.querySelector('#bibSizer');
1981
+ this.element.triggerChevron = this.element.shadowRoot.querySelector('#showStateIcon');
1982
+
1983
+ document.body.append(this.element.bib);
1984
+
1985
+ this.handleTriggerTabIndex();
1986
+
1987
+ this.element.trigger.addEventListener('keydown', (event) => this.handleEvent(event));
1988
+ this.element.trigger.addEventListener('click', (event) => this.handleEvent(event));
1989
+ this.element.trigger.addEventListener('mouseenter', (event) => this.handleEvent(event));
1990
+ this.element.trigger.addEventListener('mouseleave', (event) => this.handleEvent(event));
1991
+ this.element.trigger.addEventListener('focus', (event) => this.handleEvent(event));
1992
+ this.element.trigger.addEventListener('blur', (event) => this.handleEvent(event));
1993
+ }
1994
+
1995
+ disconnect() {
1996
+ this.cleanupHideHandlers();
1997
+ this.element.cleanup?.();
1998
+
1999
+ // Remove event & keyboard listeners
2000
+ if (this.element?.trigger) {
2001
+ this.element.trigger.removeEventListener('keydown', (event) => this.handleEvent(event));
2002
+ this.element.trigger.removeEventListener('click', (event) => this.handleEvent(event));
2003
+ this.element.trigger.removeEventListener('mouseenter', (event) => this.handleEvent(event));
2004
+ this.element.trigger.removeEventListener('mouseleave', (event) => this.handleEvent(event));
2005
+ this.element.trigger.removeEventListener('focus', (event) => this.handleEvent(event));
2006
+ this.element.trigger.removeEventListener('blur', (event) => this.handleEvent(event));
2007
+ }
2008
+ }
2009
+ }
2010
+
2011
+ // Copyright (c) Alaska Air. All right reserved. Licensed under the Apache-2.0 license
2012
+ // See LICENSE in the project root for license information.
2013
+
2014
+
2015
+ class AuroDependencyVersioning {
2016
+
2017
+ /**
2018
+ * Generates a unique string to be used for child auro element naming.
2019
+ * @private
2020
+ * @param {string} baseName - Defines the first part of the unique element name.
2021
+ * @param {string} version - Version of the component that will be appended to the baseName.
2022
+ * @returns {string} - Unique string to be used for naming.
2023
+ */
2024
+ generateElementName(baseName, version) {
2025
+ let result = baseName;
2026
+
2027
+ result += '-';
2028
+ result += version.replace(/[.]/g, '_');
2029
+
2030
+ return result;
2031
+ }
2032
+
2033
+ /**
2034
+ * Generates a unique string to be used for child auro element naming.
2035
+ * @param {string} baseName - Defines the first part of the unique element name.
2036
+ * @param {string} version - Version of the component that will be appended to the baseName.
2037
+ * @returns {string} - Unique string to be used for naming.
2038
+ */
2039
+ generateTag(baseName, version, tagClass) {
2040
+ const elementName = this.generateElementName(baseName, version);
2041
+ const tag = i$4`${s$1(elementName)}`;
2042
+
2043
+ if (!customElements.get(elementName)) {
2044
+ customElements.define(elementName, class extends tagClass {});
2045
+ }
2046
+
2047
+ return tag;
2048
+ }
2049
+ }
2050
+
2051
+ /**
2052
+ * @license
2053
+ * Copyright 2017 Google LLC
2054
+ * SPDX-License-Identifier: BSD-3-Clause
2055
+ */
2056
+ const t={ATTRIBUTE:1,CHILD:2,PROPERTY:3,BOOLEAN_ATTRIBUTE:4,EVENT:5,ELEMENT:6},e$1=t=>(...e)=>({_$litDirective$:t,values:e});class i{constructor(t){}get _$AU(){return this._$AM._$AU}_$AT(t,e,i){this._$Ct=t,this._$AM=e,this._$Ci=i;}_$AS(t,e){return this.update(t,e)}update(t,e){return this.render(...e)}}
2057
+
2058
+ /**
2059
+ * @license
2060
+ * Copyright 2018 Google LLC
2061
+ * SPDX-License-Identifier: BSD-3-Clause
2062
+ */const e=e$1(class extends i{constructor(t$1){if(super(t$1),t$1.type!==t.ATTRIBUTE||"class"!==t$1.name||t$1.strings?.length>2)throw Error("`classMap()` can only be used in the `class` attribute and must be the only part in the attribute.")}render(t){return " "+Object.keys(t).filter((s=>t[s])).join(" ")+" "}update(s,[i]){if(void 0===this.st){this.st=new Set,void 0!==s.strings&&(this.nt=new Set(s.strings.join(" ").split(/\s/).filter((t=>""!==t))));for(const t in i)i[t]&&!this.nt?.has(t)&&this.st.add(t);return this.render(i)}const r=s.element.classList;for(const t of this.st)t in i||(r.remove(t),this.st.delete(t));for(const t in i){const s=!!i[t];s===this.st.has(t)||this.nt?.has(t)||(s?(r.add(t),this.st.add(t)):(r.remove(t),this.st.delete(t)));}return T}});
2063
+
2064
+ /**
2065
+ * @license
2066
+ * Copyright 2018 Google LLC
2067
+ * SPDX-License-Identifier: BSD-3-Clause
2068
+ */const o=o=>o??E;
2069
+
2070
+ // Copyright (c) 2020 Alaska Airlines. All right reserved. Licensed under the Apache-2.0 license
2071
+ // See LICENSE in the project root for license information.
2072
+
2073
+
2074
+ /**
2075
+ * @attr {Boolean} hidden - If present, the component will be hidden both visually and from screen readers
2076
+ * @attr {Boolean} hiddenVisually - If present, the component will be hidden visually, but still read by screen readers
2077
+ * @attr {Boolean} hiddenAudible - If present, the component will be hidden from screen readers, but seen visually
2078
+ */
2079
+
2080
+ class AuroElement extends r {
2081
+
2082
+ // function to define props used within the scope of this component
2083
+ static get properties() {
2084
+ return {
2085
+ hidden: { type: Boolean,
2086
+ reflect: true },
2087
+ hiddenVisually: { type: Boolean,
2088
+ reflect: true },
2089
+ hiddenAudible: { type: Boolean,
2090
+ reflect: true },
2091
+ };
2092
+ }
2093
+
2094
+ /**
2095
+ * @private Function that determines state of aria-hidden
2096
+ */
2097
+ hideAudible(value) {
2098
+ if (value) {
2099
+ return 'true'
2100
+ }
2101
+
2102
+ return 'false'
2103
+ }
2104
+ }
2105
+
2106
+ var error = {"role":"img","color":"currentColor","title":"","desc":"Error alert indicator.","width":"var(--auro-size-lg, var(--ds-size-300, 1.5rem))","height":"var(--auro-size-lg, var(--ds-size-300, 1.5rem))","xmlns":"http://www.w3.org/2000/svg","xmlns_xlink":"http://www.w3.org/1999/xlink","viewBox":"0 0 24 24","path":"/icons","style":"ico_squareLarge","type":"icon","name":"error","category":"alert","deprecated":true,"svg":"<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" aria-labelledby=\"error__desc\" class=\"ico_squareLarge\" data-deprecated=\"true\" role=\"img\" style=\"min-width:var(--auro-size-lg, var(--ds-size-300, 1.5rem));height:var(--auro-size-lg, var(--ds-size-300, 1.5rem));fill:currentColor\" viewBox=\"0 0 24 24\" part=\"svg\"><title/><desc id=\"error__desc\">Error alert indicator.</desc><path d=\"m13.047 5.599 6.786 11.586A1.207 1.207 0 0 1 18.786 19H5.214a1.207 1.207 0 0 1-1.047-1.815l6.786-11.586a1.214 1.214 0 0 1 2.094 0m-1.165.87a.23.23 0 0 0-.085.085L5.419 17.442a.232.232 0 0 0 .203.35h12.756a.234.234 0 0 0 .203-.35L12.203 6.554a.236.236 0 0 0-.321-.084M12 15.5a.75.75 0 1 1 0 1.5.75.75 0 0 1 0-1.5m-.024-6.22c.325 0 .589.261.589.583v4.434a.586.586 0 0 1-.589.583.586.586 0 0 1-.588-.583V9.863c0-.322.264-.583.588-.583\"/></svg>"};
2107
+
2108
+ /* eslint-disable no-underscore-dangle, jsdoc/no-undefined-types, jsdoc/require-param-description */
2109
+
2110
+ const _fetchMap = new Map();
2111
+
2112
+ /**
2113
+ * A callback to parse Response body.
2114
+ *
2115
+ * @callback ResponseParser
2116
+ * @param {Fetch.Response} response
2117
+ * @returns {Promise}
2118
+ */
2119
+
2120
+ /**
2121
+ * A minimal in-memory map to de-duplicate Fetch API media requests.
2122
+ *
2123
+ * @param {String} uri
2124
+ * @param {Object} [options={}]
2125
+ * @param {ResponseParser} [options.responseParser=(response) => response.text()]
2126
+ * @returns {Promise}
2127
+ */
2128
+ const cacheFetch = (uri, options = {}) => {
2129
+ const responseParser = options.responseParser || ((response) => response.text());
2130
+ if (!_fetchMap.has(uri)) {
2131
+ _fetchMap.set(uri, fetch(uri).then(responseParser));
2132
+ }
2133
+ return _fetchMap.get(uri);
2134
+ };
2135
+
2136
+ var styleCss$2 = i$3`*,*:before,*:after{box-sizing:border-box}@media(prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}}*:focus-visible{outline:0}*:focus-visible{outline:0}:focus:not(:focus-visible){outline:3px solid transparent}.util_displayInline{display:inline}.util_displayInlineBlock{display:inline-block}.util_displayBlock,:host{display:block}.util_displayFlex{display:flex}.util_displayHidden,:host([hidden]:not(:focus):not(:active)){display:none}.util_displayHiddenVisually,:host([hiddenVisually]:not(:focus):not(:active)){position:absolute;overflow:hidden;clip:rect(1px, 1px, 1px, 1px);width:1px;height:1px;padding:0;border:0}.ico_squareLarge{fill:currentColor;height:var(--auro-size-lg, var(--ds-size-300, 1.5rem))}.ico_squareSmall{fill:currentColor;height:.6rem}.ico_squareMed{fill:currentColor;height:var(--auro-size-md, var(--ds-size-200, 1rem))}.ico_squareSml{fill:currentColor;height:var(--auro-size-sm, var(--ds-size-150, 0.75rem))}:host{color:currentColor;vertical-align:middle;line-height:1;display:inline-block}:host .logo{color:var(--ds-color-brand-midnight-400, #01426a)}svg{min-width:var(--ds-auro-icon-size, 1.5rem) !important;width:var(--ds-auro-icon-size, 1.5rem) !important;height:var(--ds-auro-icon-size, 1.5rem) !important}.label{display:flex;align-items:flex-start}.label svg{margin:0 var(--ds-size-50, 0.25rem)}.wrapper{height:var(--ds-auro-icon-size);width:var(--ds-auro-icon-size)}.labelContainer{line-height:1.8}`;
2137
+
2138
+ // Copyright (c) 2020 Alaska Airlines. All right reserved. Licensed under the Apache-2.0 license
2139
+ // See LICENSE in the project root for license information.
2140
+
2141
+
2142
+ // See https://git.io/JJ6SJ for "How to document your components using JSDoc"
2143
+ /**
2144
+ * @attr {Boolean} onDark - Set value for on-dark version of auro-icon
2145
+ * @slot - Hidden from visibility, used for a11y if icon description is needed
2146
+ */
2147
+
2148
+ // build the component class
2149
+ class BaseIcon extends AuroElement {
2150
+ constructor() {
2151
+ super();
2152
+ this.onDark = false;
2153
+ }
2154
+
2155
+ // function to define props used within the scope of this component
2156
+ static get properties() {
2157
+ return {
2158
+ ...super.properties,
2159
+ onDark: {
2160
+ type: Boolean,
2161
+ reflect: true
2162
+ },
2163
+
2164
+ /**
2165
+ * @private
2166
+ */
2167
+ svg: {
2168
+ attribute: false,
2169
+ reflect: true
2170
+ }
2171
+ };
2172
+ }
2173
+
2174
+ static get styles() {
2175
+ return i$3`
2176
+ ${styleCss$2}
2177
+ `;
2178
+ }
2179
+
2180
+ /**
2181
+ * Async function to fetch requested icon from npm CDN.
2182
+ * @private
2183
+ * @param {string} category - Icon category.
2184
+ * @param {string} name - Icon name.
2185
+ * @returns {SVGElement} DOM - Ready HTML to be appended.
2186
+ */
2187
+ async fetchIcon(category, name) {
2188
+ let iconHTML = '';
2189
+
2190
+ if (category === 'logos') {
2191
+ iconHTML = await cacheFetch(`${this.uri}/${category}/${name}.svg`);
2192
+ } else {
2193
+ iconHTML = await cacheFetch(`${this.uri}/icons/${category}/${name}.svg`);
2194
+ }
2195
+
2196
+ const dom = new DOMParser().parseFromString(iconHTML, 'text/html');
2197
+
2198
+ return dom.body.querySelector('svg');
2199
+ }
2200
+
2201
+ // lifecycle function
2202
+ async firstUpdated() {
2203
+ if (!this.customSvg) {
2204
+ const svg = await this.fetchIcon(this.category, this.name);
2205
+
2206
+ if (svg) {
2207
+ this.svg = svg;
2208
+ } else if (!svg) {
2209
+ const penDOM = new DOMParser().parseFromString(error.svg, 'text/html');
2210
+
2211
+ this.svg = penDOM.body.firstChild;
2212
+ }
2213
+ }
2214
+ }
2215
+ }
2216
+
2217
+ var tokensCss$1 = i$3`:host{--ds-auro-icon-color: var(--ds-color-icon-primary-default, $ds-color-icon-primary-default);--ds-auro-icon-size: var(--ds-size-300, $ds-size-300)}`;
2218
+
2219
+ var colorCss$2 = i$3`:host{color:var(--ds-auro-icon-color)}:host([customColor]){color:inherit}:host(:not([onDark])[accent]){--ds-auro-icon-color: var(--ds-color-icon-accent-default, #a2c270)}:host(:not([onDark])[disabled]){--ds-auro-icon-color: var(--ds-color-icon-ui-primary-disabled-default, #adadad)}:host(:not([onDark])[emphasis]){--ds-auro-icon-color: var(--ds-color-icon-emphasis-default, #2a2a2a)}:host(:not([onDark])[error]){--ds-auro-icon-color: var(--ds-color-icon-error-default, #cc1816)}:host(:not([onDark])[info]){--ds-auro-icon-color: var(--ds-color-icon-info-default, #326aa5)}:host(:not([onDark])[secondary]){--ds-auro-icon-color: var(--ds-color-icon-secondary-default, #7e8894)}:host(:not([onDark])[subtle]){--ds-auro-icon-color: var(--ds-color-icon-subtle-default, #a0c9f1)}:host(:not([onDark])[success]){--ds-auro-icon-color: var(--ds-color-icon-success-default, #40a080)}:host(:not([onDark])[tertiary]){--ds-auro-icon-color: var(--ds-color-icon-tertiary-default, #afb9c6)}:host(:not([onDark])[warning]){--ds-auro-icon-color: var(--ds-color-icon-warning-default, #c49432)}:host([onDark]){--ds-auro-icon-color: var(--ds-color-icon-primary-inverse, #f7f7f7)}:host([onDark][accent]){--ds-auro-icon-color: var(--ds-color-icon-accent-inverse, #badd81)}:host([onDark][disabled]){--ds-auro-icon-color: var(--ds-color-icon-ui-primary-disabled-inverse, #7e7e7e)}:host([onDark][emphasis]){--ds-auro-icon-color: var(--ds-color-icon-emphasis-inverse, #ffffff)}:host([onDark][error]){--ds-auro-icon-color: var(--ds-color-icon-error-inverse, #f9aca6)}:host([onDark][info]){--ds-auro-icon-color: var(--ds-color-icon-info-inverse, #89b2d4)}:host([onDark][secondary]){--ds-auro-icon-color: var(--ds-color-icon-secondary-inverse, #ccd2db)}:host([onDark][subtle]){--ds-auro-icon-color: var(--ds-color-icon-subtle-inverse, #326aa5)}:host([onDark][success]){--ds-auro-icon-color: var(--ds-color-icon-success-inverse, #8eceb9)}:host([onDark][tertiary]){--ds-auro-icon-color: var(--ds-color-icon-tertiary-inverse, #939fad)}:host([onDark][warning]){--ds-auro-icon-color: var(--ds-color-icon-warning-inverse, #f2c153)}`;
2220
+
2221
+ // Copyright (c) 2020 Alaska Airlines. All right reserved. Licensed under the Apache-2.0 license
2222
+ // See LICENSE in the project root for license information.
2223
+
2224
+
2225
+ // See https://git.io/JJ6SJ for "How to document your components using JSDoc"
2226
+ /**
2227
+ * auro-icon provides users a way to use the Auro Icons by simply passing in the category and name.
2228
+ *
2229
+ * @attr {String} category - The category of the icon you are looking for. See https://auro.alaskaair.com/icons/usage.
2230
+ * @attr {String} name - The name of the icon you are looking for without the file extension. See https://auro.alaskaair.com/icons/usage
2231
+ * @attr {Boolean} customColor - Removes primary selector.
2232
+ * @attr {Boolean} customSvg - When true, auro-icon will render a custom SVG inside the default slot.
2233
+ * @attr {Boolean} label - Exposes content in slot as icon label.
2234
+ * @attr {Boolean} primary - DEPRECATED: Sets the icon to use the baseline primary icon style.
2235
+ * @attr {Boolean} accent - Sets the icon to use the accent style.
2236
+ * @attr {Boolean} emphasis - Sets the icon to use the emphasis style.
2237
+ * @attr {Boolean} disabled - Sets the icon to use the disabled style.
2238
+ * @attr {Boolean} error - Sets the icon to use the error style.
2239
+ * @attr {Boolean} info - Sets the icon to use the info style.
2240
+ * @attr {Boolean} secondary - Sets the icon to use the secondary style.
2241
+ * @attr {Boolean} tertiary - Sets the icon to use the tertiary style.
2242
+ * @attr {Boolean} subtle - Sets the icon to use the subtle style.
2243
+ * @attr {Boolean} success - Sets the icon to use the success style.
2244
+ * @attr {Boolean} warning - Sets the icon to use the warning style.
2245
+ * @attr {String} ariaHidden - Set aria-hidden value. Default is `true`. Option is `false`.
2246
+ * @attr {String} uri - Set the uri for CDN used when fetching icons
2247
+ * @slot - Hidden from visibility, used for a11y if icon description is needed.
2248
+ * @slot svg - Used for custom SVG content.
2249
+ */
2250
+
2251
+ // build the component class
2252
+ class AuroIcon extends BaseIcon {
2253
+ constructor() {
2254
+ super();
2255
+
2256
+ this.uri = 'https://cdn.jsdelivr.net/npm/@alaskaairux/icons@latest/dist';
2257
+
2258
+ this.privateDefaults();
2259
+ }
2260
+
2261
+ /**
2262
+ * Internal Defaults.
2263
+ * @private
2264
+ * @returns {void}
2265
+ */
2266
+ privateDefaults() {
2267
+ this.accent = false;
2268
+ this.customColor = false;
2269
+ this.customSvg = false;
2270
+ this.disabled = false;
2271
+ this.emphasis = false;
2272
+ this.error = false;
2273
+ this.info = false;
2274
+ this.label = false;
2275
+ this.primary = false;
2276
+ this.secondary = false;
2277
+ this.subtle = false;
2278
+ this.success = false;
2279
+ this.tertiary = false;
2280
+ this.warning = false;
2281
+ this.runtimeUtils = new AuroLibraryRuntimeUtils();
2282
+ }
2283
+
2284
+ // function to define props used within the scope of this component
2285
+ static get properties() {
2286
+ return {
2287
+ ...super.properties,
2288
+ accent: {
2289
+ type: Boolean,
2290
+ reflect: true
2291
+ },
2292
+ ariaHidden: {
2293
+ type: String,
2294
+ reflect: true
2295
+ },
2296
+ category: {
2297
+ type: String,
2298
+ reflect: true
2299
+ },
2300
+ customColor: {
2301
+ type: Boolean
2302
+ },
2303
+ customSvg: {
2304
+ type: Boolean
2305
+ },
2306
+ disabled: {
2307
+ type: Boolean,
2308
+ reflect: true
2309
+ },
2310
+ emphasis: {
2311
+ type: Boolean,
2312
+ reflect: true
2313
+ },
2314
+ error: {
2315
+ type: Boolean,
2316
+ reflect: true
2317
+ },
2318
+ info: {
2319
+ type: Boolean,
2320
+ reflect: true
2321
+ },
2322
+ label: {
2323
+ type: Boolean,
2324
+ reflect: true
2325
+ },
2326
+ name: {
2327
+ type: String,
2328
+ reflect: true
2329
+ },
2330
+ primary: {
2331
+ type: Boolean,
2332
+ reflect: true
2333
+ },
2334
+ secondary: {
2335
+ type: Boolean,
2336
+ reflect: true
2337
+ },
2338
+ subtle: {
2339
+ type: Boolean,
2340
+ reflect: true
2341
+ },
2342
+ success: {
2343
+ type: Boolean,
2344
+ reflect: true
2345
+ },
2346
+ tertiary: {
2347
+ type: Boolean,
2348
+ reflect: true
2349
+ },
2350
+ uri: {
2351
+ type: String
2352
+ },
2353
+ warning: {
2354
+ type: Boolean,
2355
+ reflect: true
2356
+ }
2357
+ };
2358
+ }
2359
+
2360
+ static get styles() {
2361
+ return [
2362
+ super.styles,
2363
+ i$3`${tokensCss$1}`,
2364
+ i$3`${styleCss$2}`,
2365
+ i$3`${colorCss$2}`
2366
+ ];
2367
+ }
2368
+
2369
+ /**
2370
+ * This will register this element with the browser.
2371
+ * @param {string} [name="auro-icon"] - The name of element that you want to register to.
2372
+ *
2373
+ * @example
2374
+ * AuroIcon.register("custom-icon") // this will register this element to <custom-icon/>
2375
+ *
2376
+ */
2377
+ static register(name = "auro-icon") {
2378
+ AuroLibraryRuntimeUtils.prototype.registerComponent(name, AuroIcon);
2379
+ }
2380
+
2381
+ connectedCallback() {
2382
+ super.connectedCallback();
2383
+
2384
+ // Add the tag name as an attribute if it is different than the component name
2385
+ this.runtimeUtils.handleComponentTagRename(this, 'auro-icon');
2386
+ }
2387
+
2388
+ /**
2389
+ * @returns {void} Exposes CSS parts for styling from parent components.
2390
+ */
2391
+ exposeCssParts() {
2392
+ this.setAttribute('exportparts', 'svg:iconSvg');
2393
+ }
2394
+
2395
+ // function that renders the HTML and CSS into the scope of the component
2396
+ render() {
2397
+ const a11y = {
2398
+ 'labelContainer': true,
2399
+ 'util_displayHiddenVisually': !this.label
2400
+ };
2401
+
2402
+ const classes = {
2403
+ 'label': this.label,
2404
+ 'wrapper': true,
2405
+ };
2406
+
2407
+ return x`
2408
+ <div
2409
+ class="${e(classes)}"
2410
+ title="${o(this.title || undefined)}">
2411
+ <span aria-hidden="${o(this.ariaHidden ? this.ariaHidden : true)}" part="svg">
2412
+ ${this.customSvg ? x`
2413
+ <slot name="svg"></slot>
2414
+ ` : x`
2415
+ ${this.svg}
2416
+ `
2417
+ }
2418
+ </span>
2419
+
2420
+ <div class="${e(a11y)}">
2421
+ <slot></slot>
2422
+ </div>
2423
+ </div>
2424
+ `;
2425
+ }
2426
+ }
2427
+
2428
+ var iconVersion = '6.1.2';
2429
+
2430
+ var styleCss$1 = i$3`:host{position:relative;display:inline-block;max-width:100%}:host([fluid]){display:block}#bibSizer{position:absolute;z-index:-1;opacity:0;pointer-events:none}.label{font-size:var(--ds-text-body-size-xs, 0.75rem);line-height:var(--ds-text-body-size-default, 1rem);white-space:normal}.trigger{position:relative;display:flex;align-items:center;border-width:1px;border-style:solid}@media(hover: hover){.trigger:hover{cursor:pointer}}.triggerContentWrapper{overflow:hidden;flex:1;text-overflow:ellipsis;white-space:nowrap}#showStateIcon{display:flex;overflow:hidden;height:100%;align-items:center;margin-left:var(--ds-size-100, 0.5rem)}#showStateIcon [auro-icon]{height:var(--ds-size-300, 1.5rem);line-height:var(--ds-size-300, 1.5rem)}#showStateIcon[data-expanded=true] [auro-icon]{transform:rotate(-180deg)}.helpText{margin-top:var(--ds-size-50, 0.25rem);font-size:var(--ds-text-body-size-xs, 0.75rem);line-height:var(--ds-text-body-size-default, 1rem)}:host([matchwidth]) #bibSizer{width:100%}:host([disabled]){pointer-events:none}:host([inset]) .trigger{padding:var(--ds-size-150, 0.75rem) var(--ds-size-200, 1rem)}:host([common]) .trigger,:host([inset][bordered]) .trigger{padding:var(--ds-size-200, 1rem) var(--ds-size-150, 0.75rem)}:host([common]) .trigger,:host([rounded]) .trigger{border-radius:var(--ds-border-radius, 0.375rem)}`;
2431
+
2432
+ var colorCss$1 = i$3`.label{color:var(--ds-auro-dropdown-label-text-color)}.trigger{border-color:var(--ds-auro-dropdown-trigger-border-color);background-color:var(--ds-auro-dropdown-trigger-container-color);color:var(--ds-auro-dropdown-trigger-text-color)}.trigger:focus-within,.trigger:active{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-active-default, #0074c8)}.trigger:focus-within:not(:active){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-focus-default, #2c67b5);outline:1px solid var(--ds-color-border-ui-focus-default, #2c67b5)}.trigger:hover{--ds-auro-dropdown-trigger-container-color: var(--ds-color-container-ui-secondary-hover-default, rgba(0, 0, 0, 0.03))}.helpText{color:var(--ds-auro-dropdown-help-text-color)}:host([disabled]){--ds-auro-dropdown-trigger-text-color: var(--ds-color-text-ui-disabled-default, #adadad);--ds-auro-dropdown-label-text-color: var(--ds-color-text-ui-disabled-default, #adadad)}:host([common]),:host([bordered]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-primary-default, #585e67)}:host([common]) .trigger:active,:host([common]) .trigger:focus-within,:host([bordered]) .trigger:active,:host([bordered]) .trigger:focus-within{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-focus-default, #2c67b5)}:host([error]){--ds-auro-dropdown-help-text-color: var(--ds-color-text-error-default, #cc1816);--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-error-default, #cc1816)}:host([error]) .trigger{outline:solid 1px var(--ds-auro-dropdown-trigger-border-color)}:host([error]) .trigger:focus-within,:host([error]) .trigger:active{--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-active-default, #0074c8)}:host([error]) .trigger:active{box-shadow:none;outline:none}:host([disabled][common]),:host([disabled][bordered]){--ds-auro-dropdown-trigger-border-color: var(--ds-color-border-ui-disabled-default, #adadad)}`;
2433
+
2434
+ var tokensCss = i$3`:host{--ds-auro-dropdown-help-text-color: var(--ds-color-text-secondary-default, #525252);--ds-auro-dropdown-label-text-color: var(--ds-color-text-secondary-default, #525252);--ds-auro-dropdown-popover-container-color: var(--ds-color-container-primary-default, #ffffff);--ds-auro-dropdown-popover-border-color: transparent;--ds-auro-dropdown-popover-text-color: var(--ds-color-text-primary-default, #2a2a2a);--ds-auro-dropdown-trigger-container-color: var(--ds-color-container-primary-default, #ffffff);--ds-auro-dropdown-trigger-border-color: transparent;--ds-auro-dropdown-trigger-text-color: var(--ds-color-text-primary-default, #2a2a2a);--ds-auro-dropdownbib-boxshadow-color: var(--ds-elevation-200, 0px 0px 10px rgba(0, 0, 0, 0.15));--ds-auro-dropdownbib-container-color: var(--ds-color-container-primary-default, #ffffff);--ds-auro-dropdownbib-text-color: var(--ds-color-text-primary-default, #2a2a2a)}`;
2435
+
2436
+ var styleCss = i$3`:host{position:absolute;z-index:var(--depth-tooltip, 400);display:none}.container{display:inline-block;overflow:auto;box-sizing:border-box;margin:var(--ds-size-50, 0.25rem) 0}:host([isfullscreen]){position:fixed;top:0;left:0}:host([isfullscreen]) .container{width:100dvw;max-width:none;height:100dvh;max-height:none;border-radius:unset;margin-top:0;box-shadow:unset}:host([data-show]){display:flex}:host([common]:not([isfullscreen])) .container,:host([rounded]:not([isfullscreen])) .container{border-radius:var(--ds-border-radius, 0.375rem)}:host([common]) .container,:host([inset]) .container{padding:var(--ds-size-50, 0.25rem) var(--ds-size-100, 0.5rem)}:host([common][isfullscreen]) .container,:host([rounded][isfullscreen]) .container{border-radius:unset;box-shadow:unset}`;
2437
+
2438
+ var colorCss = i$3`.container{background-color:var(--ds-auro-dropdownbib-container-color);box-shadow:var(--ds-auro-dropdownbib-boxshadow-color);color:var(--ds-auro-dropdownbib-text-color)}`;
2439
+
2440
+ // Copyright (c) 2020 Alaska Airlines. All right reserved. Licensed under the Apache-2.0 license
2441
+ // See LICENSE in the project root for license information.
2442
+
2443
+
2444
+
2445
+ const DESIGN_TOKEN_BREAKPOINT_PREFIX = '--ds-grid-breakpoint-';
2446
+ const DESIGN_TOKEN_BREAKPOINT_OPTIONS = [
2447
+ 'lg',
2448
+ 'md',
2449
+ 'sm',
2450
+ 'xs',
2451
+ ];
2452
+
2453
+ /**
2454
+ * @attr { Boolean } common - If declared, will apply all styles for the common theme.
2455
+ * @attr { Boolean } rounded - If declared, will apply border-radius to the bib.
2456
+ * @attr { Boolean } inset - If declared, will apply extra padding to bib content.
2457
+ * @prop { String } mobileFullscreenBreakpoint - Defines the screen size breakpoint (`lg`, `md`, `sm`, or `xs`) at which the dropdown switches to fullscreen mode on mobile. When expanded, the dropdown will automatically display in fullscreen mode if the screen size is equal to or smaller than the selected breakpoint.
2458
+ * @csspart bibContainer - Apply css to the bib container.
2459
+ */
2460
+
2461
+ class AuroDropdownBib extends r {
2462
+
2463
+ constructor() {
2464
+ super();
2465
+
2466
+ /**
2467
+ * @private
2468
+ */
2469
+ this._mobileBreakpointValue = undefined;
2470
+ }
2471
+
2472
+ static get styles() {
2473
+ return [
2474
+ styleCss,
2475
+ colorCss,
2476
+ tokensCss
2477
+ ];
2478
+ }
2479
+
2480
+ static get properties() {
2481
+ return {
2482
+ common: {
2483
+ type: Boolean,
2484
+ reflect: true
2485
+ },
2486
+ inset: {
2487
+ type: Boolean,
2488
+ reflect: true
2489
+ },
2490
+ rounded: {
2491
+ type: Boolean,
2492
+ reflect: true
2493
+ },
2494
+ };
2495
+ }
2496
+
2497
+ set mobileFullscreenBreakpoint(value) {
2498
+ // verify the defined breakpoint is valid and exit out if not
2499
+ const validatedValue = DESIGN_TOKEN_BREAKPOINT_OPTIONS.includes(value) ? value : undefined;
2500
+ if (!validatedValue) {
2501
+ this._mobileBreakpointValue = undefined;
2502
+ } else {
2503
+ // get the pixel value for the defined breakpoint
2504
+ const docStyle = getComputedStyle(document.documentElement);
2505
+ this._mobileBreakpointValue = docStyle.getPropertyValue(DESIGN_TOKEN_BREAKPOINT_PREFIX + value);
2506
+ }
2507
+ }
2508
+
2509
+ get mobileFullscreenBreakpoint() {
2510
+ return this._mobileBreakpointValue;
2511
+ }
2512
+
2513
+ // function that renders the HTML and CSS into the scope of the component
2514
+ render() {
2515
+ return u$1`
2516
+ <div class="container" part="bibContainer">
2517
+ <slot></slot>
2518
+ </div>
2519
+ `;
2520
+ }
2521
+ }
2522
+
2523
+ // default internal definition
2524
+ if (!customElements.get("auro-dropdownbib")) {
2525
+ customElements.define("auro-dropdownbib", AuroDropdownBib);
2526
+ }
2527
+
2528
+ // Copyright (c) 2020 Alaska Airlines. All right reserved. Licensed under the Apache-2.0 license
2529
+ // See LICENSE in the project root for license information.
2530
+
2531
+
2532
+ /**
2533
+ * @attr { Boolean } bordered - If declared, applies a border around the trigger slot.
2534
+ * @attr { Boolean } common - If declared, the dropdown will be styled with the common theme.
2535
+ * @attr { Boolean } chevron - If declared, the dropdown displays an display state chevron on the right.
2536
+ * @attr { Boolean } disabled - If declared, the dropdown is not interactive.
2537
+ * @attr { Boolean } disableEventShow - If declared, the dropdown will only show by calling the API .show() public method.
2538
+ * @attr { Boolean } error - If declared in combination with `bordered` property or `helpText` slot content, will apply red color to both.
2539
+ * @attr {Boolean} fluid - Makes the trigger to be full width of its parent container
2540
+ * @attr { Boolean } matchWidth - If declared, the popover and trigger will be set to the same width.
2541
+ * @attr { Boolean } inset - If declared, will apply padding around trigger slot content.
2542
+ * @attr { Boolean } rounded - If declared, will apply border-radius to trigger and default slots.
2543
+ * @attr { Boolean } hoverToggle - if declared, the trigger will toggle the big on mouseover/mouseout.
2544
+ * @attr { Boolean } noToggle - If declared, the trigger will only show the dropdown bib.
2545
+ * @attr { Boolean } focusShow - if declared, the bib will display when focus is applied to the trigger.
2546
+ * @attr { Boolean } noHideOnThisFocusLoss - If declared, the dropdown will not hide when moving focus outside the element.
2547
+ * @attr { String } mobileFullscreenBreakpoint - Defines the screen size breakpoint (`lg`, `md`, `sm`, or `xs`) at which the dropdown switches to fullscreen mode on mobile. When expanded, the dropdown will automatically display in fullscreen mode if the screen size is equal to or smaller than the selected breakpoint.
2548
+ * @prop { Boolean } isPopoverVisible - If true, the dropdown bib is displayed.
2549
+ * @slot - Default slot for the popover content.
2550
+ * @slot label - Defines the content of the label.
2551
+ * @slot helpText - Defines the content of the helpText.
2552
+ * @slot trigger - Defines the content of the trigger.
2553
+ * @csspart trigger - The trigger content container.
2554
+ * @csspart chevron - The collapsed/expanded state icon container.
2555
+ * @csspart helpText - The helpText content container.
2556
+ * @csspart popover - The bib content container.
2557
+ * @event auroDropdown-triggerClick - Notifies that the trigger has been clicked.
2558
+ * @event auroDropdown-toggled - Notifies that the visibility of the dropdown bib has changed.
2559
+ */
2560
+ class AuroDropdown extends r {
2561
+ constructor() {
2562
+ super();
2563
+
2564
+ this.isPopoverVisible = false;
2565
+ this.matchWidth = false;
2566
+ this.noHideOnThisFocusLoss = false;
2567
+
2568
+ this.privateDefaults();
2569
+ }
2570
+
2571
+ /**
2572
+ * @private
2573
+ * @returns {void} Internal defaults.
2574
+ */
2575
+ privateDefaults() {
2576
+ this.bordered = false;
2577
+ this.chevron = false;
2578
+ this.disabled = false;
2579
+ this.error = false;
2580
+ this.inset = false;
2581
+ this.placement = 'bottom-start';
2582
+ this.rounded = false;
2583
+ this.tabIndex = 0;
2584
+ this.noToggle = false;
2585
+
2586
+ /**
2587
+ * @private
2588
+ */
2589
+ this.runtimeUtils = new AuroLibraryRuntimeUtils();
2590
+
2591
+ /**
2592
+ * @private
2593
+ */
2594
+ this.floater = new AuroFloatingUI();
2595
+
2596
+ /**
2597
+ * @private
2598
+ */
2599
+ this.floaterConfig = {
2600
+ placement: 'bottom-start',
2601
+ flip: true,
2602
+ autoPlacement: false,
2603
+ offset: 0,
2604
+ };
2605
+
2606
+ /**
2607
+ * Generate unique names for dependency components.
2608
+ */
2609
+ const versioning = new AuroDependencyVersioning();
2610
+ this.iconTag = versioning.generateTag('auro-icon', iconVersion, AuroIcon);
2611
+ }
2612
+
2613
+ /**
2614
+ * Public method to hide the dropdown.
2615
+ * @returns {void}
2616
+ */
2617
+ hide() {
2618
+ this.floater.hideBib();
2619
+ }
2620
+
2621
+ /**
2622
+ * Public method to show the dropdown.
2623
+ * @returns {void}
2624
+ */
2625
+ show() {
2626
+ this.floater.showBib();
2627
+ }
2628
+
2629
+ // function to define props used within the scope of this component
2630
+ static get properties() {
2631
+ return {
2632
+ bordered: {
2633
+ type: Boolean,
2634
+ reflect: true
2635
+ },
2636
+ chevron: {
2637
+ type: Boolean,
2638
+ reflect: true
2639
+ },
2640
+ disabled: {
2641
+ type: Boolean,
2642
+ reflect: true
2643
+ },
2644
+ error: {
2645
+ type: Boolean,
2646
+ reflect: true
2647
+ },
2648
+ fluid: {
2649
+ type: Boolean,
2650
+ reflect: true,
2651
+ },
2652
+ focusShow: {
2653
+ type: Boolean,
2654
+ reflect: true
2655
+ },
2656
+ hoverToggle: {
2657
+ type: Boolean,
2658
+ reflect: true
2659
+ },
2660
+ inset: {
2661
+ type: Boolean,
2662
+ reflect: true
2663
+ },
2664
+ matchWidth: {
2665
+ type: Boolean,
2666
+ reflect: true
2667
+ },
2668
+ rounded: {
2669
+ type: Boolean,
2670
+ reflect: true
2671
+ },
2672
+ common: {
2673
+ type: Boolean,
2674
+ reflect: true
2675
+ },
2676
+ noToggle: {
2677
+ type: Boolean,
2678
+ reflect: true
2679
+ },
2680
+ noHideOnThisFocusLoss: {
2681
+ type: Boolean,
2682
+ reflect: true
2683
+ },
2684
+ isPopoverVisible: { type: Boolean },
2685
+ onSlotChange: {
2686
+ type: Function,
2687
+ reflect: false
2688
+ },
2689
+ mobileFullscreenBreakpoint: {
2690
+ type: String,
2691
+ reflect: true,
2692
+ },
2693
+
2694
+ /**
2695
+ * @private
2696
+ */
2697
+ dropdownWidth: { type: Number },
2698
+
2699
+ /**
2700
+ * @private
2701
+ */
2702
+ placement: { type: String },
2703
+
2704
+ /**
2705
+ * @private
2706
+ */
2707
+ tabIndex: { type: Number }
2708
+ };
2709
+ }
2710
+
2711
+ static get styles() {
2712
+ return [
2713
+ styleCss$1,
2714
+ colorCss$1,
2715
+ tokensCss
2716
+ ];
2717
+ }
2718
+
2719
+ /**
2720
+ * This will register this element with the browser.
2721
+ * @param {string} [name="auro-dropdown"] - The name of element that you want to register to.
2722
+ *
2723
+ * @example
2724
+ * AuroDropdown.register("custom-dropdown") // this will register this element to <custom-dropdown/>
2725
+ *
2726
+ */
2727
+ static register(name = "auro-dropdown") {
2728
+ AuroLibraryRuntimeUtils.prototype.registerComponent(name, AuroDropdown);
2729
+ }
2730
+
2731
+ connectedCallback() {
2732
+ super.connectedCallback();
2733
+ }
2734
+
2735
+ disconnectedCallback() {
2736
+ super.disconnectedCallback();
2737
+ }
2738
+
2739
+ updated(changedProperties) {
2740
+ this.floater.handleUpdate(changedProperties);
2741
+
2742
+ if (changedProperties.has('mobileFullscreenBreakpoint')) {
2743
+ this.bibContent.mobileFullscreenBreakpoint = this.mobileFullscreenBreakpoint;
2744
+ }
2745
+ }
2746
+
2747
+ firstUpdated() {
2748
+ this.floater.configure(this, 'auroDropdown');
2749
+ this.bibContent = this.floater.element.bib;
2750
+
2751
+ // Add the tag name as an attribute if it is different than the component name
2752
+ this.runtimeUtils.handleComponentTagRename(this, 'auro-dropdown');
2753
+ }
2754
+
2755
+ /**
2756
+ * Exposes CSS parts for styling from parent components.
2757
+ * @private
2758
+ * @returns {void}
2759
+ */
2760
+ exposeCssParts() {
2761
+ this.setAttribute('exportparts', 'trigger:dropdownTrigger, chevron:dropdownChevron, helpText:dropdownHelpText, size:dropdownSize');
2762
+ }
2763
+
2764
+ /**
2765
+ * Determines if content is within a custom slot.
2766
+ * @private
2767
+ * @param {HTMLElement} element - The element to check.
2768
+ * @returns {Boolean}
2769
+ */
2770
+ isCustomSlotContent(element) {
2771
+ let currentElement = element;
2772
+
2773
+ let inCustomSlot = false;
2774
+
2775
+ while (currentElement) {
2776
+ currentElement = currentElement.parentElement;
2777
+
2778
+ if (currentElement && currentElement.hasAttribute('slot')) {
2779
+ inCustomSlot = true;
2780
+ break;
2781
+ }
2782
+ }
2783
+
2784
+ return inCustomSlot;
2785
+ }
2786
+
2787
+ /**
2788
+ * Handles the default slot change event and updates the content.
2789
+ *
2790
+ * This method retrieves all nodes assigned to the default slot of the event target and appends them
2791
+ * to the `bibContent` element. If a callback function `onSlotChange` is defined, it is invoked to
2792
+ * notify about the slot change.
2793
+ *
2794
+ * @private
2795
+ * @method handleDefaultSlot
2796
+ * @param {Event} event - The event object representing the slot change.
2797
+ * @fires Function#onSlotChange - Optional callback invoked when the slot content changes.
2798
+ */
2799
+ handleDefaultSlot(event) {
2800
+ [...event.target.assignedNodes()].forEach((node) => this.bibContent.append(node));
2801
+
2802
+ if (this.onSlotChange) {
2803
+ this.onSlotChange();
2804
+ }
2805
+ }
2806
+
2807
+ // function that renders the HTML and CSS into the scope of the component
2808
+ render() {
2809
+ return u$1`
2810
+ <div>
2811
+ <div
2812
+ id="trigger"
2813
+ class="trigger"
2814
+ part="trigger"
2815
+ role="button"
2816
+ aria-labelledby="triggerLabel"
2817
+ aria-controls="popover"
2818
+ tabindex="${this.tabIndex}"
2819
+ >
2820
+ <div class="triggerContentWrapper">
2821
+ <label class="label" id="triggerLabel">
2822
+ <slot name="label"></slot>
2823
+ </label>
2824
+ <div class="triggerContent">
2825
+ <slot
2826
+ name="trigger"
2827
+ @slotchange="${() => {this.floater.handleTriggerTabIndex(); }}"></slot>
2828
+ </div>
2829
+ </div>
2830
+ ${this.chevron || this.common ? u$1`
2831
+ <div
2832
+ id="showStateIcon"
2833
+ part="chevron">
2834
+ <${this.iconTag}
2835
+ category="interface"
2836
+ name="chevron-down"
2837
+ customColor
2838
+ ?disabled=${this.disabled}
2839
+ >
2840
+ </${this.iconTag}>
2841
+ </div>
2842
+ ` : undefined }
2843
+ </div>
2844
+ <div
2845
+ class="helpText"
2846
+ part="helpText">
2847
+ <slot name="helpText"></slot>
2848
+ </div>
2849
+ <div class="slotContent">
2850
+ <slot @slotchange="${this.handleDefaultSlot}"></slot>
2851
+ </div>
2852
+ <div id="bibSizer" part="size"></div>
2853
+ <auro-dropdownbib
2854
+ id="bib"
2855
+ role="tooltip"
2856
+ ?common="${this.common}"
2857
+ ?rounded="${this.common || this.rounded}"
2858
+ ?inset="${this.common || this.inset}">
2859
+ </auro-dropdownbib>
2860
+ </div>
2861
+ `;
2862
+ }
2863
+ }
2864
+
2865
+ AuroDropdown.register();
2866
+
2867
+ /* eslint-disable jsdoc/require-jsdoc, no-magic-numbers */
2868
+
2869
+ function initExamples(initialCount = 0) {
2870
+ try {
2871
+ // javascript example function calls to be added here upon creation to test examples
2872
+ showExample();
2873
+ hideExample();
2874
+ inDialogExample();
2875
+ } catch (err) {
2876
+ if (initialCount <= 20) {
2877
+ // setTimeout handles issue where content is sometimes loaded after the functions get called
2878
+ setTimeout(() => {
2879
+ initExamples(initialCount + 1);
2880
+ }, 100);
2881
+ }
2882
+ }
2883
+ }
2884
+
2885
+ export { initExamples };