@getmicdrop/svelte-components 5.5.4 → 5.5.5

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 (290) hide show
  1. package/dist/calendar/AboutShow/AboutShow.spec.d.ts +2 -0
  2. package/dist/calendar/AboutShow/AboutShow.spec.d.ts.map +1 -0
  3. package/dist/calendar/AboutShow/AboutShow.spec.js +791 -0
  4. package/dist/calendar/Calendar/MiniMonthCalendar.spec.d.ts +2 -0
  5. package/dist/calendar/Calendar/MiniMonthCalendar.spec.d.ts.map +1 -0
  6. package/dist/calendar/Calendar/MiniMonthCalendar.spec.js +1191 -0
  7. package/dist/calendar/FAQs/FAQs.spec.d.ts +2 -0
  8. package/dist/calendar/FAQs/FAQs.spec.d.ts.map +1 -0
  9. package/dist/calendar/FAQs/FAQs.spec.js +238 -0
  10. package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.d.ts +2 -0
  11. package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.d.ts.map +1 -0
  12. package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.js +420 -0
  13. package/dist/calendar/OrderSummary/OrderSummary.spec.d.ts +2 -0
  14. package/dist/calendar/OrderSummary/OrderSummary.spec.d.ts.map +1 -0
  15. package/dist/calendar/OrderSummary/OrderSummary.spec.js +808 -0
  16. package/dist/calendar/PublicCard/PublicCard.spec.d.ts +2 -0
  17. package/dist/calendar/PublicCard/PublicCard.spec.d.ts.map +1 -0
  18. package/dist/calendar/PublicCard/PublicCard.spec.js +301 -0
  19. package/dist/calendar/ShowCard/ShowCard.spec.d.ts +2 -0
  20. package/dist/calendar/ShowCard/ShowCard.spec.d.ts.map +1 -0
  21. package/dist/calendar/ShowCard/ShowCard.spec.js +714 -0
  22. package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.d.ts +2 -0
  23. package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.d.ts.map +1 -0
  24. package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.js +241 -0
  25. package/dist/components/Layout/Section.spec.d.ts +2 -0
  26. package/dist/components/Layout/Section.spec.d.ts.map +1 -0
  27. package/dist/components/Layout/Section.spec.js +149 -0
  28. package/dist/components/Layout/Sidebar.spec.d.ts +2 -0
  29. package/dist/components/Layout/Sidebar.spec.d.ts.map +1 -0
  30. package/dist/components/Layout/Sidebar.spec.js +186 -0
  31. package/dist/components/Layout/Stack.spec.js +3 -3
  32. package/dist/constants/formOptions.spec.js +9 -5
  33. package/dist/datetime/__tests__/format.test.js +1 -1
  34. package/dist/datetime/__tests__/parse.test.js +1 -1
  35. package/dist/datetime/__tests__/timezone.test.js +124 -2
  36. package/dist/datetime/parse.js +1 -1
  37. package/dist/forms/createFieldTracker.spec.d.ts +2 -0
  38. package/dist/forms/createFieldTracker.spec.d.ts.map +1 -0
  39. package/dist/forms/createFieldTracker.spec.js +343 -0
  40. package/dist/forms/createFormStore.spec.d.ts +2 -0
  41. package/dist/forms/createFormStore.spec.d.ts.map +1 -0
  42. package/dist/forms/createFormStore.spec.js +689 -0
  43. package/dist/forms/createFormStore.svelte.js +0 -1
  44. package/dist/index.d.ts +4 -112
  45. package/dist/index.js +4 -190
  46. package/dist/patterns/data/DataGrid.spec.d.ts +2 -0
  47. package/dist/patterns/data/DataGrid.spec.d.ts.map +1 -0
  48. package/dist/patterns/data/DataGrid.spec.js +159 -0
  49. package/dist/patterns/data/DataList.spec.d.ts +2 -0
  50. package/dist/patterns/data/DataList.spec.d.ts.map +1 -0
  51. package/dist/patterns/data/DataList.spec.js +158 -0
  52. package/dist/patterns/data/DataTable.spec.d.ts +2 -0
  53. package/dist/patterns/data/DataTable.spec.d.ts.map +1 -0
  54. package/dist/patterns/data/DataTable.spec.js +196 -0
  55. package/dist/patterns/forms/FormActions.spec.js +10 -3
  56. package/dist/patterns/forms/FormGrid.spec.d.ts +2 -0
  57. package/dist/patterns/forms/FormGrid.spec.d.ts.map +1 -0
  58. package/dist/patterns/forms/FormGrid.spec.js +125 -0
  59. package/dist/patterns/forms/FormSection.spec.d.ts +2 -0
  60. package/dist/patterns/forms/FormSection.spec.d.ts.map +1 -0
  61. package/dist/patterns/forms/FormSection.spec.js +153 -0
  62. package/dist/patterns/layout/Sidebar.spec.d.ts +2 -0
  63. package/dist/patterns/layout/Sidebar.spec.d.ts.map +1 -0
  64. package/dist/patterns/layout/Sidebar.spec.js +159 -0
  65. package/dist/patterns/navigation/BottomNav.svelte +4 -4
  66. package/dist/patterns/navigation/Header.spec.js +33 -24
  67. package/dist/patterns/page/PageHeader.spec.d.ts +2 -0
  68. package/dist/patterns/page/PageHeader.spec.d.ts.map +1 -0
  69. package/dist/patterns/page/PageHeader.spec.js +167 -0
  70. package/dist/patterns/page/PageLayout.spec.d.ts +2 -0
  71. package/dist/patterns/page/PageLayout.spec.d.ts.map +1 -0
  72. package/dist/patterns/page/PageLayout.spec.js +145 -0
  73. package/dist/patterns/page/PageLoader.spec.js +5 -2
  74. package/dist/patterns/page/SectionHeader.spec.d.ts +2 -0
  75. package/dist/patterns/page/SectionHeader.spec.d.ts.map +1 -0
  76. package/dist/patterns/page/SectionHeader.spec.js +197 -0
  77. package/dist/presets/badges.spec.d.ts +2 -0
  78. package/dist/presets/badges.spec.d.ts.map +1 -0
  79. package/dist/presets/badges.spec.js +172 -0
  80. package/dist/presets/buttons.spec.d.ts +2 -0
  81. package/dist/presets/buttons.spec.d.ts.map +1 -0
  82. package/dist/presets/buttons.spec.js +135 -0
  83. package/dist/primitives/Accordion/Accordion.spec.d.ts +2 -0
  84. package/dist/primitives/Accordion/Accordion.spec.d.ts.map +1 -0
  85. package/dist/primitives/Accordion/Accordion.spec.js +83 -0
  86. package/dist/primitives/Accordion/AccordionItem.spec.d.ts +2 -0
  87. package/dist/primitives/Accordion/AccordionItem.spec.d.ts.map +1 -0
  88. package/dist/primitives/Accordion/AccordionItem.spec.js +661 -0
  89. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -0
  90. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts +35 -0
  91. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts.map +1 -0
  92. package/dist/primitives/Alert/Alert.spec.js +5 -2
  93. package/dist/primitives/Avatar/Avatar.spec.d.ts +2 -0
  94. package/dist/primitives/Avatar/Avatar.spec.d.ts.map +1 -0
  95. package/dist/primitives/Avatar/Avatar.spec.js +211 -0
  96. package/dist/primitives/Badges/Badge.spec.js +109 -68
  97. package/dist/primitives/BottomSheet/BottomSheet.spec.js +36 -27
  98. package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte +13 -0
  99. package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte.d.ts +7 -0
  100. package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte.d.ts.map +1 -0
  101. package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +15 -13
  102. package/dist/primitives/Breadcrumb/Breadcrumb.svelte +5 -5
  103. package/dist/primitives/Button/Button.spec.js +83 -71
  104. package/dist/primitives/Button/ButtonSaveDemo.spec.js +100 -2
  105. package/dist/primitives/Button/ButtonVariantShowcase.spec.d.ts +2 -0
  106. package/dist/primitives/Button/ButtonVariantShowcase.spec.d.ts.map +1 -0
  107. package/dist/primitives/Button/ButtonVariantShowcase.spec.js +202 -0
  108. package/dist/primitives/Card.spec.js +1 -1
  109. package/dist/primitives/Checkbox/Checkbox.spec.d.ts +2 -0
  110. package/dist/primitives/Checkbox/Checkbox.spec.d.ts.map +1 -0
  111. package/dist/primitives/Checkbox/Checkbox.spec.js +252 -0
  112. package/dist/primitives/DarkModeToggle.spec.js +84 -51
  113. package/dist/primitives/Drawer/Drawer.spec.d.ts +2 -0
  114. package/dist/primitives/Drawer/Drawer.spec.d.ts.map +1 -0
  115. package/dist/primitives/Drawer/Drawer.spec.js +212 -0
  116. package/dist/primitives/Dropdown/Dropdown.spec.d.ts +2 -0
  117. package/dist/primitives/Dropdown/Dropdown.spec.d.ts.map +1 -0
  118. package/dist/primitives/Dropdown/Dropdown.spec.js +366 -0
  119. package/dist/primitives/Dropdown/DropdownItem.spec.d.ts +2 -0
  120. package/dist/primitives/Dropdown/DropdownItem.spec.d.ts.map +1 -0
  121. package/dist/primitives/Dropdown/DropdownItem.spec.js +182 -0
  122. package/dist/primitives/Icons/iconTestUtils.spec.d.ts +2 -0
  123. package/dist/primitives/Icons/iconTestUtils.spec.d.ts.map +1 -0
  124. package/dist/primitives/Icons/iconTestUtils.spec.js +235 -0
  125. package/dist/primitives/Input/Input.spec.js +14 -14
  126. package/dist/primitives/Input/Input.svelte +1 -14
  127. package/dist/primitives/Input/Input.svelte.d.ts.map +1 -1
  128. package/dist/primitives/Input/Select.spec.js +11 -17
  129. package/dist/primitives/Input/Textarea.spec.d.ts +2 -0
  130. package/dist/primitives/Input/Textarea.spec.d.ts.map +1 -0
  131. package/dist/primitives/Input/Textarea.spec.js +255 -0
  132. package/dist/primitives/Label/Label.spec.d.ts +2 -0
  133. package/dist/primitives/Label/Label.spec.d.ts.map +1 -0
  134. package/dist/primitives/Label/Label.spec.js +157 -0
  135. package/dist/primitives/Modal/Modal.spec.js +29 -25
  136. package/dist/primitives/Modal/ModalTestWrapper.svelte +65 -0
  137. package/dist/primitives/Modal/ModalTestWrapper.svelte.d.ts +23 -0
  138. package/dist/primitives/Modal/ModalTestWrapper.svelte.d.ts.map +1 -0
  139. package/dist/primitives/NumberInput/NumberInput.spec.d.ts +2 -0
  140. package/dist/primitives/NumberInput/NumberInput.spec.d.ts.map +1 -0
  141. package/dist/primitives/NumberInput/NumberInput.spec.js +235 -0
  142. package/dist/primitives/Pagination/Pagination.spec.d.ts +2 -0
  143. package/dist/primitives/Pagination/Pagination.spec.d.ts.map +1 -0
  144. package/dist/primitives/Pagination/Pagination.spec.js +266 -0
  145. package/dist/primitives/Radio/Radio.spec.d.ts +2 -0
  146. package/dist/primitives/Radio/Radio.spec.d.ts.map +1 -0
  147. package/dist/primitives/Radio/Radio.spec.js +206 -0
  148. package/dist/primitives/Skeleton/CardPlaceholder.spec.d.ts +2 -0
  149. package/dist/primitives/Skeleton/CardPlaceholder.spec.d.ts.map +1 -0
  150. package/dist/primitives/Skeleton/CardPlaceholder.spec.js +156 -0
  151. package/dist/primitives/Skeleton/ImagePlaceholder.spec.d.ts +2 -0
  152. package/dist/primitives/Skeleton/ImagePlaceholder.spec.d.ts.map +1 -0
  153. package/dist/primitives/Skeleton/ImagePlaceholder.spec.js +120 -0
  154. package/dist/primitives/Skeleton/ListPlaceholder.spec.d.ts +2 -0
  155. package/dist/primitives/Skeleton/ListPlaceholder.spec.d.ts.map +1 -0
  156. package/dist/primitives/Skeleton/ListPlaceholder.spec.js +220 -0
  157. package/dist/primitives/Skeleton/Skeleton.spec.d.ts +2 -0
  158. package/dist/primitives/Skeleton/Skeleton.spec.d.ts.map +1 -0
  159. package/dist/primitives/Skeleton/Skeleton.spec.js +173 -0
  160. package/dist/primitives/Spinner/Spinner.spec.js +25 -29
  161. package/dist/primitives/Tabs/TabItem.spec.d.ts +2 -0
  162. package/dist/primitives/Tabs/TabItem.spec.d.ts.map +1 -0
  163. package/dist/primitives/Tabs/TabItem.spec.js +130 -0
  164. package/dist/primitives/Tabs/Tabs.spec.d.ts +2 -0
  165. package/dist/primitives/Tabs/Tabs.spec.d.ts.map +1 -0
  166. package/dist/primitives/Tabs/Tabs.spec.js +295 -0
  167. package/dist/primitives/Tabs/TabsWithItems.test.svelte +18 -0
  168. package/dist/primitives/Tabs/TabsWithItems.test.svelte.d.ts +16 -0
  169. package/dist/primitives/Tabs/TabsWithItems.test.svelte.d.ts.map +1 -0
  170. package/dist/primitives/Toggle.spec.js +93 -77
  171. package/dist/primitives/Typography/Typography.spec.d.ts +2 -0
  172. package/dist/primitives/Typography/Typography.spec.d.ts.map +1 -0
  173. package/dist/primitives/Typography/Typography.spec.js +183 -0
  174. package/dist/primitives/ValidationError.spec.js +1 -1
  175. package/dist/primitives/index.d.ts +1 -0
  176. package/dist/primitives/index.js +3 -0
  177. package/dist/recipes/CropImage/CropImage.spec.js +1 -9
  178. package/dist/recipes/ImageUploader/ImageUploader.spec.d.ts +2 -0
  179. package/dist/recipes/ImageUploader/ImageUploader.spec.d.ts.map +1 -0
  180. package/dist/recipes/ImageUploader/ImageUploader.spec.js +1351 -0
  181. package/dist/recipes/SuperLogin/SuperLogin.spec.d.ts +2 -0
  182. package/dist/recipes/SuperLogin/SuperLogin.spec.d.ts.map +1 -0
  183. package/dist/recipes/SuperLogin/SuperLogin.spec.js +1436 -0
  184. package/dist/recipes/feedback/EmptyState/EmptyState.spec.d.ts +2 -0
  185. package/dist/recipes/feedback/EmptyState/EmptyState.spec.d.ts.map +1 -0
  186. package/dist/recipes/feedback/EmptyState/EmptyState.spec.js +202 -0
  187. package/dist/recipes/feedback/ErrorDisplay.spec.js +6 -6
  188. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +21 -17
  189. package/dist/recipes/fields/CheckboxField.spec.d.ts +2 -0
  190. package/dist/recipes/fields/CheckboxField.spec.d.ts.map +1 -0
  191. package/dist/recipes/fields/CheckboxField.spec.js +135 -0
  192. package/dist/recipes/fields/FormField.spec.d.ts +2 -0
  193. package/dist/recipes/fields/FormField.spec.d.ts.map +1 -0
  194. package/dist/recipes/fields/FormField.spec.js +159 -0
  195. package/dist/recipes/fields/RadioGroup.spec.d.ts +2 -0
  196. package/dist/recipes/fields/RadioGroup.spec.d.ts.map +1 -0
  197. package/dist/recipes/fields/RadioGroup.spec.js +199 -0
  198. package/dist/recipes/fields/SelectField.spec.d.ts +2 -0
  199. package/dist/recipes/fields/SelectField.spec.d.ts.map +1 -0
  200. package/dist/recipes/fields/SelectField.spec.js +188 -0
  201. package/dist/recipes/fields/TextareaField.spec.d.ts +2 -0
  202. package/dist/recipes/fields/TextareaField.spec.d.ts.map +1 -0
  203. package/dist/recipes/fields/TextareaField.spec.js +205 -0
  204. package/dist/recipes/fields/ToggleField.spec.d.ts +2 -0
  205. package/dist/recipes/fields/ToggleField.spec.d.ts.map +1 -0
  206. package/dist/recipes/fields/ToggleField.spec.js +153 -0
  207. package/dist/recipes/inputs/MultiSelect.spec.js +4 -3
  208. package/dist/recipes/inputs/MultiSelect.svelte +10 -3
  209. package/dist/recipes/inputs/MultiSelect.svelte.d.ts +2 -0
  210. package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
  211. package/dist/recipes/inputs/OTPInput.spec.js +52 -39
  212. package/dist/recipes/inputs/PasswordInput.spec.d.ts +2 -0
  213. package/dist/recipes/inputs/PasswordInput.spec.d.ts.map +1 -0
  214. package/dist/recipes/inputs/PasswordInput.spec.js +410 -0
  215. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +253 -173
  216. package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte +71 -0
  217. package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte.d.ts +9 -0
  218. package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte.d.ts.map +1 -0
  219. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +1246 -300
  220. package/dist/recipes/inputs/Search.spec.d.ts +2 -0
  221. package/dist/recipes/inputs/Search.spec.d.ts.map +1 -0
  222. package/dist/recipes/inputs/Search.spec.js +177 -0
  223. package/dist/recipes/inputs/SelectDropdown.spec.d.ts +2 -0
  224. package/dist/recipes/inputs/SelectDropdown.spec.d.ts.map +1 -0
  225. package/dist/recipes/inputs/SelectDropdown.spec.js +512 -0
  226. package/dist/recipes/modals/AlertModal.spec.d.ts +2 -0
  227. package/dist/recipes/modals/AlertModal.spec.d.ts.map +1 -0
  228. package/dist/recipes/modals/AlertModal.spec.js +432 -0
  229. package/dist/recipes/modals/ConfirmationModal.spec.js +36 -21
  230. package/dist/recipes/modals/InputModal.spec.d.ts +2 -0
  231. package/dist/recipes/modals/InputModal.spec.d.ts.map +1 -0
  232. package/dist/recipes/modals/InputModal.spec.js +872 -0
  233. package/dist/recipes/modals/ModalTestWrapper.spec.d.ts +2 -0
  234. package/dist/recipes/modals/ModalTestWrapper.spec.d.ts.map +1 -0
  235. package/dist/recipes/modals/ModalTestWrapper.spec.js +502 -0
  236. package/dist/recipes/modals/StatusModal.spec.d.ts +2 -0
  237. package/dist/recipes/modals/StatusModal.spec.d.ts.map +1 -0
  238. package/dist/recipes/modals/StatusModal.spec.js +599 -0
  239. package/dist/services/ShowService.spec.js +18 -15
  240. package/dist/stories/ButtonAuditDashboard.spec.d.ts +2 -0
  241. package/dist/stories/ButtonAuditDashboard.spec.d.ts.map +1 -0
  242. package/dist/stories/ButtonAuditDashboard.spec.js +913 -0
  243. package/dist/stories/ButtonAuditReview.spec.d.ts +2 -0
  244. package/dist/stories/ButtonAuditReview.spec.d.ts.map +1 -0
  245. package/dist/stories/ButtonAuditReview.spec.js +422 -0
  246. package/dist/stories/ButtonGridView.spec.d.ts +2 -0
  247. package/dist/stories/ButtonGridView.spec.d.ts.map +1 -0
  248. package/dist/stories/ButtonGridView.spec.js +667 -0
  249. package/dist/stories/ButtonShowcase.spec.d.ts +2 -0
  250. package/dist/stories/ButtonShowcase.spec.d.ts.map +1 -0
  251. package/dist/stories/ButtonShowcase.spec.js +499 -0
  252. package/dist/stories/PatternsGallery.spec.d.ts +2 -0
  253. package/dist/stories/PatternsGallery.spec.d.ts.map +1 -0
  254. package/dist/stories/PatternsGallery.spec.js +514 -0
  255. package/dist/stories/PrimitivesGallery.spec.d.ts +2 -0
  256. package/dist/stories/PrimitivesGallery.spec.d.ts.map +1 -0
  257. package/dist/stories/PrimitivesGallery.spec.js +813 -0
  258. package/dist/stories/RecipesGallery.spec.d.ts +2 -0
  259. package/dist/stories/RecipesGallery.spec.d.ts.map +1 -0
  260. package/dist/stories/RecipesGallery.spec.js +299 -0
  261. package/dist/stripe/useStripeTheme.spec.d.ts +2 -0
  262. package/dist/stripe/useStripeTheme.spec.d.ts.map +1 -0
  263. package/dist/stripe/useStripeTheme.spec.js +793 -0
  264. package/dist/telemetry.d.ts.map +1 -1
  265. package/dist/telemetry.js +6 -5
  266. package/dist/telemetry.spec.js +495 -12
  267. package/dist/tokens/__tests__/colors.test.d.ts +2 -0
  268. package/dist/tokens/__tests__/colors.test.d.ts.map +1 -0
  269. package/dist/tokens/__tests__/colors.test.js +152 -0
  270. package/dist/tokens/__tests__/radius.test.d.ts +2 -0
  271. package/dist/tokens/__tests__/radius.test.d.ts.map +1 -0
  272. package/dist/tokens/__tests__/radius.test.js +118 -0
  273. package/dist/tokens/__tests__/shadows.test.d.ts +2 -0
  274. package/dist/tokens/__tests__/shadows.test.d.ts.map +1 -0
  275. package/dist/tokens/__tests__/shadows.test.js +105 -0
  276. package/dist/tokens/__tests__/spacing.test.js +11 -8
  277. package/dist/tokens/__tests__/typography.test.d.ts +2 -0
  278. package/dist/tokens/__tests__/typography.test.d.ts.map +1 -0
  279. package/dist/tokens/__tests__/typography.test.js +156 -0
  280. package/dist/tokens/__tests__/z-index.test.d.ts +2 -0
  281. package/dist/tokens/__tests__/z-index.test.d.ts.map +1 -0
  282. package/dist/tokens/__tests__/z-index.test.js +121 -0
  283. package/dist/utils/apiConfig.spec.js +102 -1
  284. package/dist/utils/formatters.spec.d.ts +2 -0
  285. package/dist/utils/formatters.spec.d.ts.map +1 -0
  286. package/dist/utils/formatters.spec.js +82 -0
  287. package/dist/utils/transitions.spec.d.ts +2 -0
  288. package/dist/utils/transitions.spec.d.ts.map +1 -0
  289. package/dist/utils/transitions.spec.js +130 -0
  290. package/package.json +8 -3
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Search.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Search.spec.d.ts","sourceRoot":"","sources":["../../../src/lib/recipes/inputs/Search.spec.js"],"names":[],"mappings":""}
@@ -0,0 +1,177 @@
1
+ import { render, screen } from '@testing-library/svelte';
2
+ import { expect, describe, test } from 'vitest';
3
+ import Search from './Search.svelte';
4
+
5
+ describe('Search Component', () => {
6
+ test('renders a wrapper div', () => {
7
+ const { container } = render(Search);
8
+ expect(container.querySelector('div')).toBeInTheDocument();
9
+ });
10
+
11
+ test('wrapper has relative class', () => {
12
+ const { container } = render(Search);
13
+ const wrapper = container.firstElementChild;
14
+ expect(wrapper).toHaveClass('relative');
15
+ });
16
+
17
+ test('applies custom className', () => {
18
+ const { container } = render(Search, { props: { class: 'custom-search' } });
19
+ const wrapper = container.firstElementChild;
20
+ expect(wrapper).toHaveClass('custom-search');
21
+ });
22
+
23
+ test('renders a search input', () => {
24
+ const { container } = render(Search);
25
+ const input = container.querySelector('input[type="search"]');
26
+ expect(input).toBeInTheDocument();
27
+ });
28
+
29
+ test('renders a search icon', () => {
30
+ const { container } = render(Search);
31
+ const icon = container.querySelector('svg');
32
+ expect(icon).toBeInTheDocument();
33
+ });
34
+ });
35
+
36
+ describe('Search Placeholder', () => {
37
+ test('default placeholder is "Search"', () => {
38
+ const { container } = render(Search);
39
+ const input = container.querySelector('input');
40
+ expect(input.placeholder).toBe('Search');
41
+ });
42
+
43
+ test('custom placeholder is displayed', () => {
44
+ const { container } = render(Search, { props: { placeholder: 'Search events...' } });
45
+ const input = container.querySelector('input');
46
+ expect(input.placeholder).toBe('Search events...');
47
+ });
48
+ });
49
+
50
+ describe('Search Props', () => {
51
+ test('name prop is passed to input', () => {
52
+ const { container } = render(Search, { props: { name: 'search-query' } });
53
+ const input = container.querySelector('input');
54
+ expect(input).toHaveAttribute('name', 'search-query');
55
+ });
56
+
57
+ test('id prop is passed to input', () => {
58
+ const { container } = render(Search, { props: { id: 'main-search' } });
59
+ const input = container.querySelector('input');
60
+ expect(input).toHaveAttribute('id', 'main-search');
61
+ });
62
+
63
+ test('disabled prop disables input', () => {
64
+ const { container } = render(Search, { props: { disabled: true } });
65
+ const input = container.querySelector('input');
66
+ expect(input).toBeDisabled();
67
+ });
68
+
69
+ test('input is not disabled by default', () => {
70
+ const { container } = render(Search);
71
+ const input = container.querySelector('input');
72
+ expect(input).not.toBeDisabled();
73
+ });
74
+
75
+ test('disabled applies opacity class', () => {
76
+ const { container } = render(Search, { props: { disabled: true } });
77
+ const input = container.querySelector('input');
78
+ expect(input).toHaveClass('opacity-50');
79
+ });
80
+ });
81
+
82
+ describe('Search Size', () => {
83
+ test('default size is lg', () => {
84
+ const { container } = render(Search);
85
+ const wrapper = container.firstElementChild;
86
+ expect(wrapper).toHaveClass('h-11');
87
+ });
88
+
89
+ test('size sm applies h-8', () => {
90
+ const { container } = render(Search, { props: { size: 'sm' } });
91
+ const wrapper = container.firstElementChild;
92
+ expect(wrapper).toHaveClass('h-8');
93
+ });
94
+
95
+ test('size md applies h-10', () => {
96
+ const { container } = render(Search, { props: { size: 'md' } });
97
+ const wrapper = container.firstElementChild;
98
+ expect(wrapper).toHaveClass('h-10');
99
+ });
100
+
101
+ test('size lg applies h-11', () => {
102
+ const { container } = render(Search, { props: { size: 'lg' } });
103
+ const wrapper = container.firstElementChild;
104
+ expect(wrapper).toHaveClass('h-11');
105
+ });
106
+ });
107
+
108
+ describe('Search Input Styling', () => {
109
+ test('has gray background', () => {
110
+ const { container } = render(Search);
111
+ const input = container.querySelector('input');
112
+ expect(input).toHaveClass('bg-gray-50');
113
+ });
114
+
115
+ test('has rounded corners', () => {
116
+ const { container } = render(Search);
117
+ const input = container.querySelector('input');
118
+ expect(input).toHaveClass('rounded-lg');
119
+ });
120
+
121
+ test('has border', () => {
122
+ const { container } = render(Search);
123
+ const input = container.querySelector('input');
124
+ expect(input).toHaveClass('border');
125
+ expect(input).toHaveClass('border-gray-300');
126
+ });
127
+
128
+ test('has focus ring', () => {
129
+ const { container } = render(Search);
130
+ const input = container.querySelector('input');
131
+ expect(input).toHaveClass('focus:ring-4');
132
+ expect(input).toHaveClass('focus:ring-blue-300');
133
+ });
134
+ });
135
+
136
+ describe('Search Icon Positioning', () => {
137
+ test('icon is in absolute positioned container', () => {
138
+ const { container } = render(Search);
139
+ const iconContainer = container.querySelector('.absolute');
140
+ expect(iconContainer).toBeInTheDocument();
141
+ });
142
+
143
+ test('icon container has left positioning', () => {
144
+ const { container } = render(Search);
145
+ const iconContainer = container.querySelector('.absolute.inset-y-0.left-0');
146
+ expect(iconContainer).toBeInTheDocument();
147
+ });
148
+
149
+ test('icon is not clickable', () => {
150
+ const { container } = render(Search);
151
+ const iconContainer = container.querySelector('.pointer-events-none');
152
+ expect(iconContainer).toBeInTheDocument();
153
+ });
154
+ });
155
+
156
+ describe('Search Combinations', () => {
157
+ test('all props together', () => {
158
+ const { container } = render(Search, {
159
+ props: {
160
+ placeholder: 'Find venues...',
161
+ name: 'venue-search',
162
+ id: 'venue-search-input',
163
+ size: 'md',
164
+ disabled: true,
165
+ class: 'custom-search'
166
+ }
167
+ });
168
+ const wrapper = container.firstElementChild;
169
+ expect(wrapper).toHaveClass('custom-search');
170
+ expect(wrapper).toHaveClass('h-10');
171
+ const input = container.querySelector('input');
172
+ expect(input.placeholder).toBe('Find venues...');
173
+ expect(input).toHaveAttribute('name', 'venue-search');
174
+ expect(input).toHaveAttribute('id', 'venue-search-input');
175
+ expect(input).toBeDisabled();
176
+ });
177
+ });
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=SelectDropdown.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectDropdown.spec.d.ts","sourceRoot":"","sources":["../../../src/lib/recipes/inputs/SelectDropdown.spec.js"],"names":[],"mappings":""}
@@ -0,0 +1,512 @@
1
+ import { render, screen, fireEvent, waitFor } from "@testing-library/svelte";
2
+ import userEvent from "@testing-library/user-event";
3
+ import { expect, describe, test, vi, beforeEach } from "vitest";
4
+ import SelectDropdown from "./SelectDropdown.svelte";
5
+
6
+ const sampleOptions = [
7
+ { label: "Option 1", value: "opt1" },
8
+ { label: "Option 2", value: "opt2" },
9
+ { label: "Option 3", value: "opt3" },
10
+ { label: "Option 4", value: "opt4" },
11
+ ];
12
+
13
+ function setupTest(args = {}) {
14
+ const user = userEvent.setup();
15
+ const { component, container } = render(SelectDropdown, {
16
+ props: {
17
+ options: sampleOptions,
18
+ ...args,
19
+ },
20
+ });
21
+ return { user, component, container };
22
+ }
23
+
24
+ describe("SelectDropdown Component Tests", () => {
25
+ beforeEach(() => {
26
+ // Clear any existing event listeners
27
+ document.body.innerHTML = "";
28
+ });
29
+
30
+ test("Renders with default placeholder", () => {
31
+ setupTest();
32
+ expect(screen.getByRole("button", { name: /select/i })).toBeInTheDocument();
33
+ expect(screen.getByText("Select")).toBeInTheDocument();
34
+ });
35
+
36
+ test("Renders with custom placeholder", () => {
37
+ setupTest({ placeholder: "Choose an option" });
38
+ expect(screen.getByText("Choose an option")).toBeInTheDocument();
39
+ });
40
+
41
+ test("Shows selected option label", () => {
42
+ setupTest({ selected: sampleOptions[0] });
43
+ expect(screen.getByText("Option 1")).toBeInTheDocument();
44
+ });
45
+
46
+ test("Opens dropdown on click", async () => {
47
+ const { user } = setupTest();
48
+ const trigger = screen.getByRole("button");
49
+
50
+ await user.click(trigger);
51
+
52
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
53
+ expect(screen.getByText("Option 1")).toBeInTheDocument();
54
+ expect(screen.getByText("Option 2")).toBeInTheDocument();
55
+ expect(screen.getByText("Option 3")).toBeInTheDocument();
56
+ expect(screen.getByText("Option 4")).toBeInTheDocument();
57
+ });
58
+
59
+ test("Displays all options in dropdown", async () => {
60
+ const { user } = setupTest();
61
+ const trigger = screen.getByRole("button");
62
+
63
+ await user.click(trigger);
64
+
65
+ const options = screen.getAllByRole("option");
66
+ expect(options).toHaveLength(4);
67
+ });
68
+
69
+ test("Selects option on click", async () => {
70
+ const { user } = setupTest();
71
+ const trigger = screen.getByRole("button");
72
+
73
+ await user.click(trigger);
74
+ const option2 = screen.getByRole("option", { name: "Option 2" });
75
+ await user.click(option2);
76
+
77
+ // Should show selected option in trigger
78
+ expect(screen.getByText("Option 2")).toBeInTheDocument();
79
+ });
80
+
81
+ test("Closes dropdown after selection", async () => {
82
+ const { user } = setupTest();
83
+ const trigger = screen.getByRole("button");
84
+
85
+ await user.click(trigger);
86
+ const option1 = screen.getByRole("option", { name: "Option 1" });
87
+ await user.click(option1);
88
+
89
+ // Dropdown should be closed
90
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
91
+ });
92
+
93
+ test("Calls onselect callback when option is selected", async () => {
94
+ const onSelectSpy = vi.fn();
95
+ const { user } = setupTest({ onselect: onSelectSpy });
96
+ const trigger = screen.getByRole("button");
97
+
98
+ await user.click(trigger);
99
+ const option2 = screen.getByRole("option", { name: "Option 2" });
100
+ await user.click(option2);
101
+
102
+ expect(onSelectSpy).toHaveBeenCalledWith(sampleOptions[1]);
103
+ });
104
+
105
+ test("Does not open dropdown when disabled", async () => {
106
+ const { user } = setupTest({ disabled: true });
107
+ const trigger = screen.getByRole("button");
108
+
109
+ expect(trigger).toBeDisabled();
110
+ await user.click(trigger);
111
+
112
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
113
+ });
114
+
115
+ test("Applies disabled styles when disabled", () => {
116
+ setupTest({ disabled: true });
117
+ const trigger = screen.getByRole("button");
118
+
119
+ expect(trigger).toHaveClass("opacity-50");
120
+ expect(trigger).toHaveClass("cursor-not-allowed");
121
+ });
122
+
123
+ test("Applies custom className", () => {
124
+ const { container } = setupTest({ class: "custom-class" });
125
+ const dropdown = container.querySelector(".relative");
126
+
127
+ expect(dropdown).toHaveClass("custom-class");
128
+ });
129
+
130
+ test("Closes dropdown on Escape key", async () => {
131
+ const { user } = setupTest();
132
+ const trigger = screen.getByRole("button");
133
+
134
+ await user.click(trigger);
135
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
136
+
137
+ await user.keyboard("{Escape}");
138
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
139
+ });
140
+
141
+ test("Navigates options with ArrowDown key", async () => {
142
+ const { user } = setupTest();
143
+ const trigger = screen.getByRole("button");
144
+
145
+ await user.click(trigger);
146
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
147
+
148
+ const options = screen.getAllByRole("option");
149
+ await user.keyboard("{ArrowDown}");
150
+
151
+ // First option should receive focus
152
+ expect(options[0]).toHaveFocus();
153
+
154
+ await user.keyboard("{ArrowDown}");
155
+ // Second option should receive focus
156
+ expect(options[1]).toHaveFocus();
157
+ });
158
+
159
+ test("Navigates options with ArrowUp key", async () => {
160
+ const { user } = setupTest();
161
+ const trigger = screen.getByRole("button");
162
+
163
+ await user.click(trigger);
164
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
165
+
166
+ const options = screen.getAllByRole("option");
167
+ await user.keyboard("{ArrowUp}");
168
+
169
+ // Should wrap to last option
170
+ expect(options[3]).toHaveFocus();
171
+
172
+ await user.keyboard("{ArrowUp}");
173
+ // Should move to third option
174
+ expect(options[2]).toHaveFocus();
175
+ });
176
+
177
+ test("Navigates to first option with Home key", async () => {
178
+ const { user } = setupTest();
179
+ const trigger = screen.getByRole("button");
180
+
181
+ await user.click(trigger);
182
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
183
+
184
+ const options = screen.getAllByRole("option");
185
+ await user.keyboard("{ArrowDown}");
186
+ await user.keyboard("{ArrowDown}");
187
+ await user.keyboard("{Home}");
188
+
189
+ expect(options[0]).toHaveFocus();
190
+ });
191
+
192
+ test("Navigates to last option with End key", async () => {
193
+ const { user } = setupTest();
194
+ const trigger = screen.getByRole("button");
195
+
196
+ await user.click(trigger);
197
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
198
+
199
+ const options = screen.getAllByRole("option");
200
+ await user.keyboard("{End}");
201
+
202
+ expect(options[3]).toHaveFocus();
203
+ });
204
+
205
+ test("Closes dropdown on Tab key", async () => {
206
+ const { user } = setupTest();
207
+ const trigger = screen.getByRole("button");
208
+
209
+ await user.click(trigger);
210
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
211
+
212
+ await user.keyboard("{Tab}");
213
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
214
+ });
215
+
216
+ test("Returns focus to trigger after Escape", async () => {
217
+ const { user } = setupTest();
218
+ const trigger = screen.getByRole("button");
219
+
220
+ await user.click(trigger);
221
+ await user.keyboard("{Escape}");
222
+
223
+ expect(trigger).toHaveFocus();
224
+ });
225
+
226
+ test("Returns focus to trigger after selection", async () => {
227
+ const { user } = setupTest();
228
+ const trigger = screen.getByRole("button");
229
+
230
+ await user.click(trigger);
231
+ const option1 = screen.getByRole("option", { name: "Option 1" });
232
+ await user.click(option1);
233
+
234
+ await waitFor(() => expect(trigger).toHaveFocus());
235
+ });
236
+
237
+ test("Closes dropdown when clicking outside", async () => {
238
+ const { user } = setupTest();
239
+ const trigger = screen.getByRole("button");
240
+
241
+ await user.click(trigger);
242
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
243
+
244
+ // Click outside the dropdown
245
+ await user.click(document.body);
246
+
247
+ await waitFor(() => {
248
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
249
+ });
250
+ });
251
+
252
+ test("Does not close dropdown when clicking inside container", async () => {
253
+ const { user } = setupTest();
254
+ const trigger = screen.getByRole("button");
255
+
256
+ await user.click(trigger);
257
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
258
+
259
+ // Click on the trigger again
260
+ await user.click(trigger);
261
+
262
+ // Should toggle closed
263
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
264
+ });
265
+
266
+ test("Highlights selected option in dropdown", async () => {
267
+ const { user } = setupTest({ selected: sampleOptions[1] });
268
+ const trigger = screen.getByRole("button");
269
+
270
+ await user.click(trigger);
271
+
272
+ const selectedOption = screen.getByRole("option", { name: "Option 2" });
273
+ expect(selectedOption).toHaveAttribute("aria-selected", "true");
274
+ expect(selectedOption).toHaveClass("bg-blue-50");
275
+ });
276
+
277
+ test("Toggles dropdown on successive clicks", async () => {
278
+ const { user } = setupTest();
279
+ const trigger = screen.getByRole("button");
280
+
281
+ // Open
282
+ await user.click(trigger);
283
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
284
+
285
+ // Close
286
+ await user.click(trigger);
287
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
288
+
289
+ // Open again
290
+ await user.click(trigger);
291
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
292
+ });
293
+
294
+ test("Sets aria-haspopup attribute on trigger", () => {
295
+ setupTest();
296
+ const trigger = screen.getByRole("button");
297
+
298
+ expect(trigger).toHaveAttribute("aria-haspopup", "listbox");
299
+ });
300
+
301
+ test("Sets aria-expanded based on dropdown state", async () => {
302
+ const { user } = setupTest();
303
+ const trigger = screen.getByRole("button");
304
+
305
+ expect(trigger).toHaveAttribute("aria-expanded", "false");
306
+
307
+ await user.click(trigger);
308
+ expect(trigger).toHaveAttribute("aria-expanded", "true");
309
+
310
+ await user.click(trigger);
311
+ expect(trigger).toHaveAttribute("aria-expanded", "false");
312
+ });
313
+
314
+ test("Rotates chevron icon when dropdown is open", async () => {
315
+ const { user, container } = setupTest();
316
+ const trigger = screen.getByRole("button");
317
+
318
+ const chevron = container.querySelector("svg");
319
+ expect(chevron).not.toHaveClass("rotate-180");
320
+
321
+ await user.click(trigger);
322
+ expect(chevron).toHaveClass("rotate-180");
323
+ });
324
+
325
+ test("Handles empty options array", () => {
326
+ setupTest({ options: [] });
327
+ expect(screen.getByRole("button")).toBeInTheDocument();
328
+ });
329
+
330
+ test("Updates displayed value when selected prop changes", async () => {
331
+ const { container } = render(SelectDropdown, {
332
+ props: {
333
+ options: sampleOptions,
334
+ selected: sampleOptions[0],
335
+ },
336
+ });
337
+
338
+ expect(screen.getByText("Option 1")).toBeInTheDocument();
339
+
340
+ // Re-render with new selected prop (Svelte 5 compatible approach)
341
+ container.innerHTML = "";
342
+ render(SelectDropdown, {
343
+ props: {
344
+ options: sampleOptions,
345
+ selected: sampleOptions[2],
346
+ },
347
+ target: container,
348
+ });
349
+
350
+ await waitFor(() => {
351
+ expect(screen.getByText("Option 3")).toBeInTheDocument();
352
+ });
353
+ });
354
+
355
+ test("Shows all options even when one is selected", async () => {
356
+ const { user } = setupTest({ selected: sampleOptions[0] });
357
+ const trigger = screen.getByRole("button");
358
+
359
+ await user.click(trigger);
360
+
361
+ const options = screen.getAllByRole("option");
362
+ expect(options).toHaveLength(4);
363
+ });
364
+
365
+ test("Does not interfere with keyboard events outside dropdown", async () => {
366
+ const { user } = setupTest();
367
+ const trigger = screen.getByRole("button");
368
+
369
+ // Don't open dropdown
370
+ await user.keyboard("{ArrowDown}");
371
+
372
+ // Dropdown should not open
373
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
374
+ });
375
+
376
+ test("Wraps focus correctly with ArrowDown", async () => {
377
+ const { user } = setupTest();
378
+ const trigger = screen.getByRole("button");
379
+
380
+ await user.click(trigger);
381
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
382
+
383
+ const options = screen.getAllByRole("option");
384
+
385
+ // Navigate to last item
386
+ await user.keyboard("{End}");
387
+ expect(options[3]).toHaveFocus();
388
+
389
+ // Press ArrowDown - should wrap to first
390
+ await user.keyboard("{ArrowDown}");
391
+ expect(options[0]).toHaveFocus();
392
+ });
393
+
394
+ test("Wraps focus correctly with ArrowUp", async () => {
395
+ const { user } = setupTest();
396
+ const trigger = screen.getByRole("button");
397
+
398
+ await user.click(trigger);
399
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
400
+
401
+ const options = screen.getAllByRole("option");
402
+
403
+ // First option
404
+ await user.keyboard("{Home}");
405
+ expect(options[0]).toHaveFocus();
406
+
407
+ // Press ArrowUp - should wrap to last
408
+ await user.keyboard("{ArrowUp}");
409
+ expect(options[3]).toHaveFocus();
410
+ });
411
+
412
+ test("Applies correct styling classes to dropdown menu", async () => {
413
+ const { user } = setupTest();
414
+ const trigger = screen.getByRole("button");
415
+
416
+ await user.click(trigger);
417
+
418
+ const menu = screen.getByRole("listbox");
419
+ expect(menu).toHaveClass("absolute");
420
+ expect(menu).toHaveClass("z-10");
421
+ expect(menu).toHaveClass("rounded-lg");
422
+ expect(menu).toHaveClass("shadow-lg");
423
+ });
424
+
425
+ test("Truncates long selected option labels", () => {
426
+ setupTest({
427
+ selected: { label: "Very long option name that should be truncated", value: "long" },
428
+ });
429
+ const span = screen.getByText("Very long option name that should be truncated");
430
+ expect(span).toHaveClass("truncate");
431
+ });
432
+
433
+ test("Allows null selected value", () => {
434
+ setupTest({ selected: null });
435
+ expect(screen.getByText("Select")).toBeInTheDocument();
436
+ });
437
+
438
+ test("Handles option selection with Enter key", async () => {
439
+ const onSelectSpy = vi.fn();
440
+ const { user } = setupTest({ onselect: onSelectSpy });
441
+ const trigger = screen.getByRole("button");
442
+
443
+ await user.click(trigger);
444
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
445
+
446
+ await user.keyboard("{ArrowDown}");
447
+ const options = screen.getAllByRole("option");
448
+
449
+ // Simulate Enter key on focused option
450
+ await fireEvent.click(options[0]);
451
+
452
+ expect(onSelectSpy).toHaveBeenCalledWith(sampleOptions[0]);
453
+ });
454
+
455
+ test("Maintains dropdown position with max-height scroll", async () => {
456
+ const manyOptions = Array.from({ length: 20 }, (_, i) => ({
457
+ label: `Option ${i + 1}`,
458
+ value: `opt${i + 1}`,
459
+ }));
460
+
461
+ const { user } = setupTest({ options: manyOptions });
462
+ const trigger = screen.getByRole("button");
463
+
464
+ await user.click(trigger);
465
+
466
+ const menu = screen.getByRole("listbox");
467
+ expect(menu).toHaveClass("max-h-60");
468
+ expect(menu).toHaveClass("overflow-y-auto");
469
+ });
470
+
471
+ test("Initializes focusedIndex to -1 when opening dropdown", async () => {
472
+ const { user } = setupTest();
473
+ const trigger = screen.getByRole("button");
474
+
475
+ await user.click(trigger);
476
+
477
+ // No option should be focused initially
478
+ const options = screen.getAllByRole("option");
479
+ options.forEach(option => {
480
+ expect(option).not.toHaveFocus();
481
+ });
482
+ });
483
+
484
+ test("Opens and closes dropdown instances independently", async () => {
485
+ const { user: user1 } = setupTest({ placeholder: "Dropdown 1" });
486
+ const { user: user2 } = setupTest({ placeholder: "Dropdown 2" });
487
+
488
+ const trigger1 = screen.getByRole("button", { name: "Dropdown 1" });
489
+ const trigger2 = screen.getByRole("button", { name: "Dropdown 2" });
490
+
491
+ // Open first dropdown
492
+ await user1.click(trigger1);
493
+ expect(screen.getAllByRole("listbox")).toHaveLength(1);
494
+
495
+ // Opening second dropdown closes first (click-outside behavior)
496
+ await user2.click(trigger2);
497
+
498
+ // Should have exactly one listbox open (the second one)
499
+ const listboxes = screen.getAllByRole("listbox");
500
+ expect(listboxes).toHaveLength(1);
501
+ });
502
+
503
+ test("Maintains proper z-index for dropdown overlay", async () => {
504
+ const { user } = setupTest();
505
+ const trigger = screen.getByRole("button");
506
+
507
+ await user.click(trigger);
508
+
509
+ const menu = screen.getByRole("listbox");
510
+ expect(menu).toHaveClass("z-10");
511
+ });
512
+ });