@jobber/components 4.90.1 → 4.90.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (639) hide show
  1. package/dist/AnimatedPresence/{index.js → index.cjs} +1 -3
  2. package/dist/AnimatedPresence/index.mjs +4 -0
  3. package/dist/{AnimatedPresence-20a02aaa.js → AnimatedPresence-CNNu0y2V.js} +3 -7
  4. package/dist/AnimatedPresence-Cp8tOatE.js +98 -0
  5. package/dist/AnimatedSwitcher/index.cjs +11 -0
  6. package/dist/AnimatedSwitcher/index.mjs +5 -0
  7. package/dist/{AnimatedSwitcher-3d45ec5d.js → AnimatedSwitcher-CXKNa7td.js} +4 -8
  8. package/dist/AnimatedSwitcher-DJqwc2sj.js +90 -0
  9. package/dist/AtlantisContext/{index.js → index.cjs} +1 -3
  10. package/dist/AtlantisContext/index.mjs +2 -0
  11. package/dist/AtlantisContext-B2cWxzkp.js +18 -0
  12. package/dist/Autocomplete/index.cjs +33 -0
  13. package/dist/Autocomplete/index.mjs +27 -0
  14. package/dist/Autocomplete-CHcTq0Do.js +192 -0
  15. package/dist/Autocomplete-CswBpc7U.js +190 -0
  16. package/dist/Avatar/index.cjs +12 -0
  17. package/dist/Avatar/index.mjs +6 -0
  18. package/dist/Avatar-NVE7Yqd4.js +69 -0
  19. package/dist/Avatar-Q8rB73I2.js +67 -0
  20. package/dist/Banner/components/BannerIcon/index.cjs +13 -0
  21. package/dist/Banner/components/BannerIcon/index.mjs +7 -0
  22. package/dist/Banner/index.cjs +23 -0
  23. package/dist/Banner/index.mjs +17 -0
  24. package/dist/Banner-AzSFwco8.js +79 -0
  25. package/dist/Banner-DH176e7P.js +81 -0
  26. package/dist/BannerIcon-BDM1qFzc.js +19 -0
  27. package/dist/BannerIcon-Dg3SkxI7.js +22 -0
  28. package/dist/Body-ChUi3aq5.js +54 -0
  29. package/dist/Body-D1DdNQ7t.js +45 -0
  30. package/dist/Button/index.cjs +13 -0
  31. package/dist/Button/index.mjs +7 -0
  32. package/dist/Button-C6SHw1kI.js +49 -0
  33. package/dist/Button-Cfp4SFrN.js +47 -0
  34. package/dist/ButtonDismiss/index.cjs +14 -0
  35. package/dist/ButtonDismiss/index.mjs +8 -0
  36. package/dist/ButtonDismiss-Cf-2rvG0.js +8 -0
  37. package/dist/ButtonDismiss-DVALYLmq.js +10 -0
  38. package/dist/Card/index.cjs +21 -0
  39. package/dist/Card/index.mjs +15 -0
  40. package/dist/Card-DE7aMoA7.js +83 -0
  41. package/dist/Card-DXsK_SD7.js +81 -0
  42. package/dist/Checkbox/index.cjs +15 -0
  43. package/dist/Checkbox/index.mjs +9 -0
  44. package/dist/Checkbox-BXh_wazi.js +55 -0
  45. package/dist/Checkbox-DxC81YWi.js +53 -0
  46. package/dist/Chip/hooks/index.cjs +8 -0
  47. package/dist/Chip/hooks/index.mjs +2 -0
  48. package/dist/Chip/index.cjs +26 -0
  49. package/dist/Chip/index.mjs +18 -0
  50. package/dist/Chip-DDl2lMHv.js +70 -0
  51. package/dist/Chip-DhTvoOnl.js +67 -0
  52. package/dist/ChipDismissible-S-txJuLF.js +19 -0
  53. package/dist/ChipDismissible-dx2J1n-C.js +22 -0
  54. package/dist/Chips/InternalChipDismissible/hooks/index.cjs +23 -0
  55. package/dist/Chips/InternalChipDismissible/hooks/index.mjs +13 -0
  56. package/dist/Chips/InternalChipDismissible/index.cjs +35 -0
  57. package/dist/Chips/InternalChipDismissible/index.mjs +29 -0
  58. package/dist/Chips/index.cjs +48 -0
  59. package/dist/Chips/index.mjs +44 -0
  60. package/dist/Chips-BBnCrPul.js +93 -0
  61. package/dist/Chips-KPKpzxUx.js +91 -0
  62. package/dist/Combobox/components/ComboboxAction/index.cjs +12 -0
  63. package/dist/Combobox/components/ComboboxAction/index.mjs +6 -0
  64. package/dist/Combobox/components/ComboboxActivator/index.cjs +27 -0
  65. package/dist/Combobox/components/ComboboxActivator/index.mjs +21 -0
  66. package/dist/Combobox/components/ComboboxContent/ComboboxContentHeader/index.cjs +14 -0
  67. package/dist/Combobox/components/ComboboxContent/ComboboxContentHeader/index.mjs +8 -0
  68. package/dist/Combobox/components/ComboboxContent/ComboboxContentList/index.cjs +24 -0
  69. package/dist/Combobox/components/ComboboxContent/ComboboxContentList/index.mjs +18 -0
  70. package/dist/Combobox/components/ComboboxContent/ComboboxContentSearch/index.cjs +10 -0
  71. package/dist/Combobox/components/ComboboxContent/ComboboxContentSearch/index.mjs +4 -0
  72. package/dist/Combobox/components/ComboboxContent/ComboboxLoadMore/index.cjs +9 -0
  73. package/dist/Combobox/components/ComboboxContent/ComboboxLoadMore/index.mjs +3 -0
  74. package/dist/Combobox/components/ComboboxContent/index.cjs +34 -0
  75. package/dist/Combobox/components/ComboboxContent/index.mjs +28 -0
  76. package/dist/Combobox/components/ComboboxOption/index.cjs +14 -0
  77. package/dist/Combobox/components/ComboboxOption/index.mjs +8 -0
  78. package/dist/Combobox/components/ComboboxTrigger/index.cjs +25 -0
  79. package/dist/Combobox/components/ComboboxTrigger/index.mjs +19 -0
  80. package/dist/Combobox/index.cjs +53 -0
  81. package/dist/Combobox/index.mjs +46 -0
  82. package/dist/Combobox-DL8grBGD.js +119 -0
  83. package/dist/Combobox-DkiMKBIq.js +117 -0
  84. package/dist/ComboboxAction-BZcUzPiS.js +22 -0
  85. package/dist/ComboboxAction-BrphUdTc.js +24 -0
  86. package/dist/ComboboxActivator-B-hbPIvc.js +28 -0
  87. package/dist/ComboboxActivator-GbDe5-gd.js +26 -0
  88. package/dist/ComboboxContent-PbGOqYiy.js +145 -0
  89. package/dist/ComboboxContent-Y7XnpDxG.js +143 -0
  90. package/dist/ComboboxContentHeader-CXeTEKPJ.js +29 -0
  91. package/dist/ComboboxContentHeader-R33IqVfI.js +27 -0
  92. package/dist/ComboboxContentList-BcRD6OP7.js +75 -0
  93. package/dist/ComboboxContentList-QdY3v22O.js +77 -0
  94. package/dist/ComboboxContentSearch-BQoi8eST.js +32 -0
  95. package/dist/ComboboxContentSearch-BYHUi0_0.js +34 -0
  96. package/dist/ComboboxLoadMore-CTue6Ccg.js +16 -0
  97. package/dist/ComboboxLoadMore-Dwov5fXg.js +14 -0
  98. package/dist/ComboboxOption-BQAcmD8S.js +20 -0
  99. package/dist/ComboboxOption-CEM44lR4.js +22 -0
  100. package/dist/ComboboxProvider-BfK8pUar.js +13 -0
  101. package/dist/ComboboxProvider-CnooL3he.js +10 -0
  102. package/dist/ComboboxTrigger-BPoUI5Eo.js +24 -0
  103. package/dist/ComboboxTrigger-CUU6Np4P.js +22 -0
  104. package/dist/ConfirmationModal/index.cjs +31 -0
  105. package/dist/ConfirmationModal/index.mjs +25 -0
  106. package/dist/{ConfirmationModal-b44e302f.js → ConfirmationModal-BJRisSRI.js} +8 -12
  107. package/dist/ConfirmationModal-DWSRaZne.js +94 -0
  108. package/dist/Content/index.cjs +9 -0
  109. package/dist/Content/index.mjs +3 -0
  110. package/dist/Content-BfbXarkv.js +15 -0
  111. package/dist/Content-DcpJaJjo.js +13 -0
  112. package/dist/Countdown/index.cjs +11 -0
  113. package/dist/Countdown/index.mjs +5 -0
  114. package/dist/Countdown-B1qWObYf.js +659 -0
  115. package/dist/Countdown-BcPHGeXW.js +657 -0
  116. package/dist/DataDump/index.cjs +24 -0
  117. package/dist/DataDump/index.mjs +18 -0
  118. package/dist/DataDump-CVjjQmzE.js +17 -0
  119. package/dist/DataDump-IdZ5dfe5.js +15 -0
  120. package/dist/DataList/components/DataListAction/index.cjs +13 -0
  121. package/dist/DataList/components/DataListAction/index.mjs +7 -0
  122. package/dist/DataList/components/DataListActions/index.cjs +43 -0
  123. package/dist/DataList/components/DataListActions/index.mjs +37 -0
  124. package/dist/DataList/components/DataListActionsMenu/index.cjs +17 -0
  125. package/dist/DataList/components/DataListActionsMenu/index.mjs +11 -0
  126. package/dist/DataList/components/DataListBulkActions/index.cjs +46 -0
  127. package/dist/DataList/components/DataListBulkActions/index.mjs +39 -0
  128. package/dist/DataList/components/DataListEmptyState/index.cjs +20 -0
  129. package/dist/DataList/components/DataListEmptyState/index.mjs +13 -0
  130. package/dist/DataList/components/DataListFilters/components/DataListSort/index.cjs +54 -0
  131. package/dist/DataList/components/DataListFilters/components/DataListSort/index.mjs +48 -0
  132. package/dist/DataList/components/DataListFilters/index.cjs +68 -0
  133. package/dist/DataList/components/DataListFilters/index.mjs +61 -0
  134. package/dist/DataList/components/DataListHeader/index.cjs +53 -0
  135. package/dist/DataList/components/DataListHeader/index.mjs +47 -0
  136. package/dist/DataList/components/DataListHeaderTile/components/index.cjs +12 -0
  137. package/dist/DataList/components/DataListHeaderTile/components/index.mjs +6 -0
  138. package/dist/DataList/components/DataListHeaderTile/index.cjs +20 -0
  139. package/dist/DataList/components/DataListHeaderTile/index.mjs +14 -0
  140. package/dist/DataList/components/DataListItem/components/DataListItemClickable/index.cjs +14 -0
  141. package/dist/DataList/components/DataListItem/components/DataListItemClickable/index.mjs +8 -0
  142. package/dist/DataList/components/DataListItem/index.cjs +52 -0
  143. package/dist/DataList/components/DataListItem/index.mjs +46 -0
  144. package/dist/DataList/components/DataListItemActions/index.cjs +45 -0
  145. package/dist/DataList/components/DataListItemActions/index.mjs +38 -0
  146. package/dist/DataList/components/DataListItemActionsOverflow/index.cjs +25 -0
  147. package/dist/DataList/components/DataListItemActionsOverflow/index.mjs +19 -0
  148. package/dist/DataList/components/DataListItems/index.cjs +53 -0
  149. package/dist/DataList/components/DataListItems/index.mjs +47 -0
  150. package/dist/DataList/components/DataListLayout/index.cjs +56 -0
  151. package/dist/DataList/components/DataListLayout/index.mjs +50 -0
  152. package/dist/DataList/components/DataListLayoutActions/DataListLayoutContext/index.cjs +9 -0
  153. package/dist/DataList/components/DataListLayoutActions/DataListLayoutContext/index.mjs +2 -0
  154. package/dist/DataList/components/DataListLayoutActions/index.cjs +33 -0
  155. package/dist/DataList/components/DataListLayoutActions/index.mjs +27 -0
  156. package/dist/DataList/components/DataListLoadMore/index.cjs +21 -0
  157. package/dist/DataList/components/DataListLoadMore/index.mjs +14 -0
  158. package/dist/DataList/components/DataListLoadingState/index.cjs +21 -0
  159. package/dist/DataList/components/DataListLoadingState/index.mjs +13 -0
  160. package/dist/DataList/components/DataListOverflowFade/index.cjs +11 -0
  161. package/dist/DataList/components/DataListOverflowFade/index.mjs +4 -0
  162. package/dist/DataList/components/DataListSearch/index.cjs +33 -0
  163. package/dist/DataList/components/DataListSearch/index.mjs +25 -0
  164. package/dist/DataList/components/DataListStatusBar/index.cjs +32 -0
  165. package/dist/DataList/components/DataListStatusBar/index.mjs +25 -0
  166. package/dist/DataList/components/DataListStickyHeader/index.cjs +11 -0
  167. package/dist/DataList/components/DataListStickyHeader/index.mjs +5 -0
  168. package/dist/DataList/components/DataListTags/index.cjs +12 -0
  169. package/dist/DataList/components/DataListTags/index.mjs +6 -0
  170. package/dist/DataList/components/DataListTotalCount/index.cjs +15 -0
  171. package/dist/DataList/components/DataListTotalCount/index.mjs +8 -0
  172. package/dist/DataList/context/DataListContext/index.cjs +12 -0
  173. package/dist/DataList/context/DataListContext/index.mjs +4 -0
  174. package/dist/DataList/context/DataListLayoutContext/index.cjs +12 -0
  175. package/dist/DataList/context/DataListLayoutContext/index.mjs +4 -0
  176. package/dist/DataList/index.cjs +98 -0
  177. package/dist/DataList/index.mjs +92 -0
  178. package/dist/DataList-BNFt3ksk.js +139 -0
  179. package/dist/DataList-Cr9VCHIX.js +5 -0
  180. package/dist/DataList-DHFR_-wI.js +141 -0
  181. package/dist/DataList-Dz5NINSZ.js +3 -0
  182. package/dist/DataList.const-D7NaHwv2.js +25 -0
  183. package/dist/DataList.const-DD8VmZp1.js +38 -0
  184. package/dist/DataList.utils-DhJ6Bzfb.js +161 -0
  185. package/dist/DataList.utils-nlVavDa-.js +168 -0
  186. package/dist/DataListAction-BLmcBkv3.js +39 -0
  187. package/dist/DataListAction-z0r8dyGZ.js +37 -0
  188. package/dist/DataListActions-4k1qQRcL.js +43 -0
  189. package/dist/DataListActions-DNsv1N2R.js +45 -0
  190. package/dist/DataListActionsMenu-4y3C6RwI.js +55 -0
  191. package/dist/DataListActionsMenu-D7LvCqEb.js +57 -0
  192. package/dist/DataListBulkActions-By-GrAPp.js +29 -0
  193. package/dist/DataListBulkActions-Ck89g6ye.js +26 -0
  194. package/dist/DataListContext-54s0cQ2-.js +29 -0
  195. package/dist/DataListContext-BQjPQQPp.js +25 -0
  196. package/dist/DataListEmptyState-5-J-3X4D.js +53 -0
  197. package/dist/DataListEmptyState-BtuGoNX6.js +50 -0
  198. package/dist/DataListFilters-sd7jBhQE.js +46 -0
  199. package/dist/DataListFilters-vylASUtC.js +43 -0
  200. package/dist/DataListHeader-Bkxr7WIZ.js +95 -0
  201. package/dist/DataListHeader-PvjsNn2I.js +93 -0
  202. package/dist/DataListHeaderTile-BybGOG6C.js +81 -0
  203. package/dist/DataListHeaderTile-KJ8Eae63.js +79 -0
  204. package/dist/DataListItem-BqNp3Eqq.js +112 -0
  205. package/dist/DataListItem-CCbOb4ts.js +114 -0
  206. package/dist/DataListItemActions-C25oc6Y-.js +29 -0
  207. package/dist/DataListItemActions-DPiWyGS1.js +32 -0
  208. package/dist/DataListItemActionsOverflow-Dy8lheES.js +33 -0
  209. package/dist/DataListItemActionsOverflow-ul1diZ44.js +35 -0
  210. package/dist/DataListItemClickable-BuMjNn5E.js +47 -0
  211. package/dist/DataListItemClickable-DQ5Sq-4_.js +45 -0
  212. package/dist/DataListItems--_6Rb8Jq.js +19 -0
  213. package/dist/DataListItems-DwAPcNSD.js +21 -0
  214. package/dist/DataListLayout-DWQ3LcOJ.js +21 -0
  215. package/dist/DataListLayout-DYcpl2hP.js +19 -0
  216. package/dist/DataListLayoutActions-B1EVoxK2.js +36 -0
  217. package/dist/DataListLayoutActions-DLj3XiZ5.js +38 -0
  218. package/dist/DataListLayoutContext-Dl1JtgLH.js +11 -0
  219. package/dist/DataListLayoutContext-DwmprXbf.js +18 -0
  220. package/dist/DataListLayoutContext-Il_5jPik.js +14 -0
  221. package/dist/DataListLayoutContext-TpQb0Nj2.js +8 -0
  222. package/dist/DataListLoadMore-FkGD7vHM.js +34 -0
  223. package/dist/DataListLoadMore-ZmJj5-i9.js +31 -0
  224. package/dist/DataListLoadingState-CR1Z1_AR.js +26 -0
  225. package/dist/DataListLoadingState-xQup12W4.js +22 -0
  226. package/dist/DataListOverflowFade-10aOxr8Q.js +25 -0
  227. package/dist/DataListOverflowFade-D0Nqey5v.js +22 -0
  228. package/dist/DataListSearch-DyYTAMCq.js +59 -0
  229. package/dist/DataListSearch-I4HkoS-h.js +63 -0
  230. package/dist/DataListSort-DWwMojZr.js +94 -0
  231. package/dist/DataListSort-GHDVPJ_E.js +92 -0
  232. package/dist/DataListSortingOptions-DpPwd-YR.js +35 -0
  233. package/dist/DataListSortingOptions-nk9dclSJ.js +37 -0
  234. package/dist/DataListStatusBar-Cq2c6T6R.js +22 -0
  235. package/dist/DataListStatusBar-DoDXKGHi.js +25 -0
  236. package/dist/DataListStickyHeader-6xUwJJD7.js +23 -0
  237. package/dist/DataListStickyHeader-xrbxWP2I.js +25 -0
  238. package/dist/DataListTags-69zAArZ2.js +64 -0
  239. package/dist/DataListTags-Ck_VOCzy.js +62 -0
  240. package/dist/DataListTotalCount-CJZ9FD36.js +27 -0
  241. package/dist/DataListTotalCount-Cns_GwAL.js +24 -0
  242. package/dist/DataTable/index.cjs +36 -0
  243. package/dist/DataTable/index.mjs +25 -0
  244. package/dist/DataTable/test-utilities/index.cjs +246 -0
  245. package/dist/DataTable/test-utilities/index.mjs +238 -0
  246. package/dist/DataTable-Bt0NOwH4.js +236 -0
  247. package/dist/DataTable-CNVDhnqd.js +238 -0
  248. package/dist/DatePicker/index.cjs +26 -0
  249. package/dist/DatePicker/index.mjs +20 -0
  250. package/dist/DatePicker-BRUF_5jL.js +8554 -0
  251. package/dist/DatePicker-Ck4FVQQS.js +8551 -0
  252. package/dist/DayOfMonthSelect-BdCBk0Fz.js +130 -0
  253. package/dist/DayOfMonthSelect-CmghghbK.js +137 -0
  254. package/dist/DescriptionList/index.cjs +10 -0
  255. package/dist/DescriptionList/index.mjs +4 -0
  256. package/dist/DescriptionList-BHllIrT9.js +14 -0
  257. package/dist/DescriptionList-BX86_iJ-.js +12 -0
  258. package/dist/Disclosure/index.cjs +17 -0
  259. package/dist/Disclosure/index.mjs +11 -0
  260. package/dist/Disclosure-BOotfD-_.js +33 -0
  261. package/dist/Disclosure-CwDEaUmN.js +35 -0
  262. package/dist/Divider/index.cjs +9 -0
  263. package/dist/Divider/index.mjs +3 -0
  264. package/dist/Divider-CGLchhDF.js +17 -0
  265. package/dist/Divider-yff7rtIo.js +19 -0
  266. package/dist/Drawer/index.cjs +19 -0
  267. package/dist/Drawer/index.mjs +12 -0
  268. package/dist/DrawerGrid-Csj6IRXw.js +28 -0
  269. package/dist/DrawerGrid-Dhe6uh-8.js +31 -0
  270. package/dist/Emphasis/index.cjs +10 -0
  271. package/dist/Emphasis/index.mjs +4 -0
  272. package/dist/Emphasis-RZbI_yDN.js +15 -0
  273. package/dist/Emphasis-ieWWb3pq.js +13 -0
  274. package/dist/FeatureSwitch/index.cjs +26 -0
  275. package/dist/FeatureSwitch/index.mjs +20 -0
  276. package/dist/FeatureSwitch-BcLRihpc.js +52 -0
  277. package/dist/FeatureSwitch-DKsr91OR.js +54 -0
  278. package/dist/Flex/index.cjs +9 -0
  279. package/dist/Flex/index.mjs +3 -0
  280. package/dist/Flex-CloUiW2f.js +28 -0
  281. package/dist/Flex-mRkBGC1G.js +30 -0
  282. package/dist/Form/index.cjs +10 -0
  283. package/dist/Form/index.mjs +4 -0
  284. package/dist/Form-Brm98BxU.js +48 -0
  285. package/dist/{Form/index.js → Form-C1OZbkgH.js} +3 -9
  286. package/dist/FormField/index.cjs +20 -0
  287. package/dist/FormField/index.mjs +14 -0
  288. package/dist/FormField-CevGrDGm.js +261 -0
  289. package/dist/FormField-DgvKr2RR.js +263 -0
  290. package/dist/FormatDate/{index.js → index.cjs} +1 -3
  291. package/dist/FormatDate/index.mjs +2 -0
  292. package/dist/FormatDate-Cuu1uyX_.js +27 -0
  293. package/dist/{FormatDate-70ea5b43.js → FormatDate-F_hdjag1.js} +1 -5
  294. package/dist/FormatEmail/index.cjs +9 -0
  295. package/dist/FormatEmail/index.mjs +3 -0
  296. package/dist/FormatEmail-BL75oJKz.js +11 -0
  297. package/dist/FormatEmail-FWzV4fL2.js +13 -0
  298. package/dist/FormatFile/index.cjs +36 -0
  299. package/dist/FormatFile/index.mjs +30 -0
  300. package/dist/FormatFile-CaULPATZ.js +149 -0
  301. package/dist/FormatFile-Dkkpc4RO.js +147 -0
  302. package/dist/FormatRelativeDateTime/index.cjs +8 -0
  303. package/dist/FormatRelativeDateTime/index.mjs +2 -0
  304. package/dist/{FormatRelativeDateTime/index.js → FormatRelativeDateTime-DJIQHUEo.js} +5 -11
  305. package/dist/FormatRelativeDateTime-SwQGKFKx.js +64 -0
  306. package/dist/FormatTime/index.cjs +8 -0
  307. package/dist/FormatTime/index.mjs +2 -0
  308. package/dist/FormatTime-BUp8wKYB.js +29 -0
  309. package/dist/{FormatTime/index.js → FormatTime-Bf1p46AK.js} +1 -7
  310. package/dist/Gallery/index.cjs +42 -0
  311. package/dist/Gallery/index.mjs +36 -0
  312. package/dist/Gallery-iRUMatk_.js +65 -0
  313. package/dist/Gallery-ondjCKOu.js +63 -0
  314. package/dist/Glimmer/index.cjs +12 -0
  315. package/dist/Glimmer/index.mjs +5 -0
  316. package/dist/Glimmer-CVTrhX52.js +60 -0
  317. package/dist/Glimmer-CnsLTogn.js +63 -0
  318. package/dist/Grid/InternalGridCell/index.cjs +9 -0
  319. package/dist/Grid/InternalGridCell/index.mjs +2 -0
  320. package/dist/Grid/index.cjs +14 -0
  321. package/dist/Grid/index.mjs +7 -0
  322. package/dist/Grid-DC7GAarU.js +29 -0
  323. package/dist/Grid-c8FgrzP7.js +32 -0
  324. package/dist/Heading/index.cjs +12 -0
  325. package/dist/Heading/index.mjs +6 -0
  326. package/dist/{Heading-23d382a1.js → Heading-CCFoOnua.js} +3 -7
  327. package/dist/Heading-Cik7AvDW.js +49 -0
  328. package/dist/Icon/index.cjs +9 -0
  329. package/dist/Icon/index.mjs +3 -0
  330. package/dist/Icon-Cprfa6DH.js +34 -0
  331. package/dist/Icon-DN6zZdoZ.js +36 -0
  332. package/dist/InlineLabel/index.cjs +10 -0
  333. package/dist/InlineLabel/index.mjs +4 -0
  334. package/dist/InlineLabel-DjcM6md2.js +18 -0
  335. package/dist/InlineLabel-DpGHWyZ1.js +20 -0
  336. package/dist/InputAvatar/index.cjs +26 -0
  337. package/dist/InputAvatar/index.mjs +20 -0
  338. package/dist/InputAvatar-0CRsukeF.js +49 -0
  339. package/dist/InputAvatar-BR9CNN8N.js +47 -0
  340. package/dist/InputDate/index.cjs +34 -0
  341. package/dist/InputDate/index.mjs +28 -0
  342. package/dist/InputDate-ChvqCIwy.js +50 -0
  343. package/dist/InputDate-Di1ilUDK.js +48 -0
  344. package/dist/InputEmail/index.cjs +22 -0
  345. package/dist/InputEmail/index.mjs +15 -0
  346. package/dist/InputEmail-2iUVN3lX.js +23 -0
  347. package/dist/InputEmail-DIaAL1Fj.js +20 -0
  348. package/dist/InputFile/index.cjs +23 -0
  349. package/dist/InputFile/index.mjs +16 -0
  350. package/dist/InputFile-CQcJalUx.js +1611 -0
  351. package/dist/InputFile-DrLKxOEw.js +1608 -0
  352. package/dist/InputGroup/index.cjs +9 -0
  353. package/dist/InputGroup/index.mjs +3 -0
  354. package/dist/InputGroup-CDAggb3R.js +25 -0
  355. package/dist/InputGroup-CqwRtrCP.js +23 -0
  356. package/dist/InputNumber/index.cjs +21 -0
  357. package/dist/InputNumber/index.mjs +15 -0
  358. package/dist/{InputNumber-e15cc1a3.js → InputNumber-B1xScmfR.js} +2 -6
  359. package/dist/InputNumber-CJabx_OX.js +56 -0
  360. package/dist/InputPassword/index.cjs +21 -0
  361. package/dist/InputPassword/index.mjs +15 -0
  362. package/dist/InputPassword-558tvE1p.js +21 -0
  363. package/dist/InputPassword-DIzD-pX3.js +19 -0
  364. package/dist/InputPhoneNumber/index.cjs +21 -0
  365. package/dist/InputPhoneNumber/index.mjs +15 -0
  366. package/dist/InputPhoneNumber-DRdIU41q.js +94 -0
  367. package/dist/{InputPhoneNumber/index.js → InputPhoneNumber-DWdXIF84.js} +7 -27
  368. package/dist/InputText/index.cjs +22 -0
  369. package/dist/InputText/index.mjs +16 -0
  370. package/dist/{InputText-130b0440.js → InputText-Br2K1C4M.js} +4 -8
  371. package/dist/InputText-CyGO_Jef.js +96 -0
  372. package/dist/InputTime/index.cjs +26 -0
  373. package/dist/InputTime/index.mjs +20 -0
  374. package/dist/{InputTime/index.js → InputTime-CpoUMFJT.js} +5 -25
  375. package/dist/InputTime-kqDNzoYY.js +190 -0
  376. package/dist/InputValidation/index.cjs +14 -0
  377. package/dist/InputValidation/index.mjs +8 -0
  378. package/dist/InputValidation-CA3D4HMZ.js +22 -0
  379. package/dist/InputValidation-D4MvsPKI.js +20 -0
  380. package/dist/InternalChipDismissible-B7LrCyb7.js +152 -0
  381. package/dist/InternalChipDismissible-C52ZoCE0.js +157 -0
  382. package/dist/InternalGridCell-DqEoIvP9.js +34 -0
  383. package/dist/InternalGridCell-zig0sMW5.js +37 -0
  384. package/dist/LightBox/index.cjs +26 -0
  385. package/dist/LightBox/index.mjs +20 -0
  386. package/dist/LightBox-BMcZ0zUE.js +112 -0
  387. package/dist/LightBox-DdN2Kv2x.js +110 -0
  388. package/dist/Link/index.cjs +8 -0
  389. package/dist/Link/index.mjs +2 -0
  390. package/dist/Link-BXg1N0uc.js +7 -0
  391. package/dist/Link-D4vsUc4Q.js +9 -0
  392. package/dist/List/index.cjs +29 -0
  393. package/dist/List/index.mjs +22 -0
  394. package/dist/List-DEIH9jaA.js +189 -0
  395. package/dist/List-Dh-L_8Vd.js +186 -0
  396. package/dist/Markdown/index.cjs +19 -0
  397. package/dist/Markdown/index.mjs +13 -0
  398. package/dist/Markdown-DIOh2S0u.js +19011 -0
  399. package/dist/Markdown-GR9F9CIO.js +19013 -0
  400. package/dist/Menu/index.cjs +18 -0
  401. package/dist/Menu/index.mjs +12 -0
  402. package/dist/Menu-D4apJOhh.js +131 -0
  403. package/dist/Menu-IjuAzGId.js +129 -0
  404. package/dist/Modal/index.cjs +23 -0
  405. package/dist/Modal/index.mjs +17 -0
  406. package/dist/Modal-Dr-Y4-gf.js +62 -0
  407. package/dist/Modal-aGXkiuSS.js +60 -0
  408. package/dist/MultiSelect/index.cjs +16 -0
  409. package/dist/MultiSelect/index.mjs +10 -0
  410. package/dist/MultiSelect-1LkHc-4a.js +166 -0
  411. package/dist/MultiSelect-CIFWIwY6.js +164 -0
  412. package/dist/Option-DLsUvwdO.js +12 -0
  413. package/dist/Option-c12Y1Noe.js +15 -0
  414. package/dist/Page/index.cjs +32 -0
  415. package/dist/Page/index.mjs +26 -0
  416. package/dist/Page-CakXCvoE.js +58 -0
  417. package/dist/Page-DwQymzZk.js +56 -0
  418. package/dist/Popover/index.cjs +17 -0
  419. package/dist/Popover/index.mjs +11 -0
  420. package/dist/Popover-BY0EW6zV.js +48 -0
  421. package/dist/Popover-ByVk1LqF.js +50 -0
  422. package/dist/ProgressBar/index.cjs +9 -0
  423. package/dist/ProgressBar/index.mjs +3 -0
  424. package/dist/ProgressBar-52i53SJE.js +33 -0
  425. package/dist/ProgressBar-BaSkqP8J.js +31 -0
  426. package/dist/RadioGroup/index.cjs +12 -0
  427. package/dist/RadioGroup/index.mjs +5 -0
  428. package/dist/RadioGroup-CRwAZq63.js +36 -0
  429. package/dist/RadioGroup-TNqC7foh.js +39 -0
  430. package/dist/RecurringSelect/components/index.cjs +15 -0
  431. package/dist/RecurringSelect/components/index.mjs +6 -0
  432. package/dist/RecurringSelect/index.cjs +35 -0
  433. package/dist/RecurringSelect/index.mjs +21 -0
  434. package/dist/RecurringSelect-VBGk4Lt2.js +71 -0
  435. package/dist/RecurringSelect-cwPdAc_S.js +69 -0
  436. package/dist/Select/index.cjs +22 -0
  437. package/dist/Select/index.mjs +15 -0
  438. package/dist/Spinner/index.cjs +9 -0
  439. package/dist/Spinner/index.mjs +3 -0
  440. package/dist/Spinner-L0bWOO6S.js +16 -0
  441. package/dist/Spinner-gZOK7Pbk.js +14 -0
  442. package/dist/StatusIndicator/index.cjs +8 -0
  443. package/dist/StatusIndicator/index.mjs +2 -0
  444. package/dist/StatusIndicator-CQ4BuDSG.js +9 -0
  445. package/dist/StatusIndicator-CQu-mhiP.js +11 -0
  446. package/dist/StatusLabel/index.cjs +11 -0
  447. package/dist/StatusLabel/index.mjs +5 -0
  448. package/dist/StatusLabel-C8xAbAuq.js +18 -0
  449. package/dist/StatusLabel-O-4M1wUA.js +16 -0
  450. package/dist/Switch/index.cjs +10 -0
  451. package/dist/Switch/index.mjs +4 -0
  452. package/dist/Switch-DMYTNJjq.js +48 -0
  453. package/dist/Switch-DqzUCyHn.js +46 -0
  454. package/dist/Table/index.cjs +17 -0
  455. package/dist/Table/index.mjs +4 -0
  456. package/dist/Tabs/index.cjs +11 -0
  457. package/dist/Tabs/index.mjs +4 -0
  458. package/dist/Tabs-C3qMIs1F.js +67 -0
  459. package/dist/Tabs-CRY_vyNW.js +70 -0
  460. package/dist/Text/index.cjs +10 -0
  461. package/dist/Text/index.mjs +4 -0
  462. package/dist/{Text-fbeaaca6.js → Text-Bopx9dUr.js} +2 -6
  463. package/dist/Text-DALHhxHl.js +25 -0
  464. package/dist/Toast/index.cjs +16 -0
  465. package/dist/Toast/index.mjs +10 -0
  466. package/dist/Tooltip/index.cjs +14 -0
  467. package/dist/Tooltip/index.mjs +8 -0
  468. package/dist/Tooltip-B2DBKrJM.js +103 -0
  469. package/dist/Tooltip-VHTRuZ4Y.js +105 -0
  470. package/dist/Typography/index.cjs +9 -0
  471. package/dist/Typography/index.mjs +3 -0
  472. package/dist/Typography-D6YoQOGF.js +36 -0
  473. package/dist/Typography-WLLQxuNl.js +38 -0
  474. package/dist/_baseAssignValue-BthOhxdo.js +29 -0
  475. package/dist/_baseAssignValue-Dt4F7vTV.js +31 -0
  476. package/dist/_baseEach-BECef8ru.js +1069 -0
  477. package/dist/_baseEach-Dze5I6UM.js +1073 -0
  478. package/dist/_commonjsHelpers-COf7qtKz.js +32 -0
  479. package/dist/_commonjsHelpers-vq2WA-uE.js +36 -0
  480. package/dist/_defineProperty-2TBZHj_H.js +1306 -0
  481. package/dist/_defineProperty-DxuhV38S.js +1326 -0
  482. package/dist/_getTag-BhVE5Z9s.js +733 -0
  483. package/dist/_getTag-Z6aLseUE.js +718 -0
  484. package/dist/_polyfill-node.process-e5fcXoUk.js +255 -0
  485. package/dist/_polyfill-node.process-mCRQTL4d.js +258 -0
  486. package/dist/_setToString-CFGrPYbk.js +230 -0
  487. package/dist/_setToString-D9q1MBnP.js +234 -0
  488. package/dist/debounce-DNEaQL1N.js +332 -0
  489. package/dist/debounce-DgeBwtKp.js +329 -0
  490. package/dist/helpers-QJ7YD42d.js +17 -0
  491. package/dist/helpers-cJmOwx3u.js +15 -0
  492. package/dist/index-C4SneFNu.js +1186 -0
  493. package/dist/index-yqmGqwFM.js +1189 -0
  494. package/dist/index.cjs +275 -0
  495. package/dist/index.d.mts +74 -0
  496. package/dist/index.d.ts +74 -0
  497. package/dist/index.mjs +162 -0
  498. package/dist/isObjectLike-BLBufvwS.js +197 -0
  499. package/dist/isObjectLike-CqUyaiWM.js +190 -0
  500. package/dist/isSymbol-MYvz4htB.js +35 -0
  501. package/dist/isSymbol-_Iyy_jRJ.js +33 -0
  502. package/dist/noop-C8qh6oDm.js +26 -0
  503. package/dist/noop-CNfu_5-L.js +24 -0
  504. package/dist/showToast-BB8OsmX0.js +97 -0
  505. package/dist/showToast-DNc6Ghvi.js +99 -0
  506. package/dist/styles.css +8762 -0
  507. package/dist/tslib.es6-CQnq_FvL.js +97 -0
  508. package/dist/tslib.es6-v7P0Y776.js +102 -0
  509. package/dist/useActiveLayout-C0_CiH6w.js +16 -0
  510. package/dist/useActiveLayout-CpgnILog.js +14 -0
  511. package/dist/useAssert--FSFxEub.js +27 -0
  512. package/dist/useAssert-BRTg70rg.js +27 -0
  513. package/dist/{useAtlantisConfig-ed0bee66.js → useAtlantisConfig-BbG41OXr.js} +2 -2
  514. package/dist/useAtlantisConfig-ClMTcI5f.js +14 -0
  515. package/dist/useBatchSelect-CTMzNd5R.js +36 -0
  516. package/dist/useBatchSelect-nB5zKoLG.js +38 -0
  517. package/dist/useChildComponent-2LnkmIw0.js +15 -0
  518. package/dist/useChildComponent-Dv0rjZs2.js +17 -0
  519. package/dist/useFocusTrap-DDVdHPLP.js +74 -0
  520. package/dist/useFocusTrap-J4nqJhkL.js +74 -0
  521. package/dist/useInView-D7JiU6w9.js +25 -0
  522. package/dist/useInView-DRRNAygj.js +25 -0
  523. package/dist/useIsMounted-Ds9qZzhJ.js +47 -0
  524. package/dist/useIsMounted-sw4iFcH2.js +47 -0
  525. package/dist/useOnKeyDown-BBUzTpsM.js +40 -0
  526. package/dist/useOnKeyDown-ClBoAl9o.js +40 -0
  527. package/dist/useRefocusOnActivator-DhXYZbJ2.js +32 -0
  528. package/dist/useRefocusOnActivator-JhjmSWbr.js +32 -0
  529. package/dist/useResizeObserver-Bt-giwIv.js +1192 -0
  530. package/dist/useResizeObserver-D7zJHmH-.js +1189 -0
  531. package/dist/useResponsiveSizing-CaFHa0P8.js +49 -0
  532. package/dist/useResponsiveSizing-X79bu1Sd.js +51 -0
  533. package/dist/useSafeLayoutEffect-87KYIon5.js +14 -0
  534. package/dist/useSafeLayoutEffect-IMNHxeSN.js +12 -0
  535. package/dist/useScrollToActive-AgUIt0XS.js +591 -0
  536. package/dist/useScrollToActive-D4MUBncA.js +597 -0
  537. package/package.json +394 -8
  538. package/{rollup.config.js → rollup.config.mjs} +50 -17
  539. package/dist/AnimatedSwitcher/index.js +0 -13
  540. package/dist/Autocomplete/index.js +0 -214
  541. package/dist/Avatar/index.js +0 -15
  542. package/dist/Avatar-76a799fa.js +0 -78
  543. package/dist/Banner/index.js +0 -111
  544. package/dist/Button/index.js +0 -16
  545. package/dist/Button-6b922fc1.js +0 -57
  546. package/dist/ButtonDismiss/index.js +0 -17
  547. package/dist/ButtonDismiss-a3ba1de2.js +0 -14
  548. package/dist/Card/index.js +0 -24
  549. package/dist/Card-01d6ba19.js +0 -93
  550. package/dist/Checkbox/index.js +0 -18
  551. package/dist/Checkbox-e481a4b1.js +0 -63
  552. package/dist/Chip/index.js +0 -42
  553. package/dist/Chip-76f18555.js +0 -89
  554. package/dist/Chips/index.js +0 -525
  555. package/dist/Combobox/index.js +0 -41
  556. package/dist/Combobox-6d864202.js +0 -481
  557. package/dist/ConfirmationModal/index.js +0 -32
  558. package/dist/Content/index.js +0 -12
  559. package/dist/Content-e3f7b6fc.js +0 -24
  560. package/dist/Countdown/index.js +0 -72
  561. package/dist/DataDump/index.js +0 -37
  562. package/dist/DataList/index.js +0 -1346
  563. package/dist/DataTable/index.js +0 -301
  564. package/dist/DatePicker/index.js +0 -21
  565. package/dist/DatePicker-305a5b82.js +0 -144
  566. package/dist/DescriptionList/index.js +0 -24
  567. package/dist/Disclosure/index.js +0 -46
  568. package/dist/Divider/index.js +0 -29
  569. package/dist/Drawer/index.js +0 -50
  570. package/dist/Emphasis/index.js +0 -13
  571. package/dist/Emphasis-a77d8ee9.js +0 -19
  572. package/dist/FeatureSwitch/index.js +0 -71
  573. package/dist/Flex/index.js +0 -12
  574. package/dist/Flex-d490c4db.js +0 -38
  575. package/dist/FormField/index.js +0 -24
  576. package/dist/FormField-f6fadff2.js +0 -253
  577. package/dist/FormatEmail/index.js +0 -23
  578. package/dist/FormatFile/index.js +0 -37
  579. package/dist/FormatFile-32228107.js +0 -162
  580. package/dist/Gallery/index.js +0 -101
  581. package/dist/Glimmer/index.js +0 -15
  582. package/dist/Glimmer-84dee1ed.js +0 -77
  583. package/dist/Grid/index.js +0 -76
  584. package/dist/Heading/index.js +0 -15
  585. package/dist/Icon/index.js +0 -11
  586. package/dist/Icon-405a216c.js +0 -40
  587. package/dist/InlineLabel/index.js +0 -13
  588. package/dist/InlineLabel-c8fc28f0.js +0 -28
  589. package/dist/InputAvatar/index.js +0 -70
  590. package/dist/InputDate/index.js +0 -74
  591. package/dist/InputEmail/index.js +0 -43
  592. package/dist/InputFile/index.js +0 -25
  593. package/dist/InputFile-20b9074a.js +0 -190
  594. package/dist/InputGroup/index.js +0 -12
  595. package/dist/InputGroup-8d4fd4eb.js +0 -33
  596. package/dist/InputNumber/index.js +0 -25
  597. package/dist/InputPassword/index.js +0 -41
  598. package/dist/InputText/index.js +0 -26
  599. package/dist/InputValidation/index.js +0 -17
  600. package/dist/InputValidation-a92bb519.js +0 -29
  601. package/dist/LightBox/index.js +0 -25
  602. package/dist/LightBox-7efe8932.js +0 -121
  603. package/dist/Link/index.js +0 -15
  604. package/dist/List/index.js +0 -94
  605. package/dist/Markdown/index.js +0 -20
  606. package/dist/Markdown-0f24de70.js +0 -62
  607. package/dist/Menu/index.js +0 -21
  608. package/dist/Menu-d6dd673e.js +0 -139
  609. package/dist/Modal/index.js +0 -26
  610. package/dist/Modal-067becad.js +0 -73
  611. package/dist/MultiSelect/index.js +0 -182
  612. package/dist/Option-a1dbc08a.js +0 -19
  613. package/dist/Page/index.js +0 -78
  614. package/dist/Popover/index.js +0 -65
  615. package/dist/ProgressBar/index.js +0 -12
  616. package/dist/ProgressBar-b68edc8f.js +0 -43
  617. package/dist/RadioGroup/index.js +0 -15
  618. package/dist/RadioGroup-678f4932.js +0 -46
  619. package/dist/RecurringSelect/index.js +0 -227
  620. package/dist/Select/index.js +0 -26
  621. package/dist/Spinner/index.js +0 -12
  622. package/dist/Spinner-9d8fc7ff.js +0 -24
  623. package/dist/StatusIndicator/index.js +0 -11
  624. package/dist/StatusIndicator-7b5258ea.js +0 -18
  625. package/dist/StatusLabel/index.js +0 -28
  626. package/dist/Switch/index.js +0 -13
  627. package/dist/Switch-eac89586.js +0 -56
  628. package/dist/Table/index.js +0 -66
  629. package/dist/Tabs/index.js +0 -80
  630. package/dist/Text/index.js +0 -13
  631. package/dist/Toast/index.js +0 -111
  632. package/dist/Tooltip/index.js +0 -17
  633. package/dist/Tooltip-b9de6e57.js +0 -114
  634. package/dist/Typography/index.js +0 -12
  635. package/dist/Typography-e2a23b7e.js +0 -62
  636. package/dist/style-inject.es-9d2f5f4e.js +0 -30
  637. package/dist/tslib.es6-754e2961.js +0 -46
  638. /package/{.eslintrc.js → .eslintrc.cjs} +0 -0
  639. /package/dist/{AtlantisContext-64608897.js → AtlantisContext-kZu_c9Er.js} +0 -0
@@ -0,0 +1,18 @@
1
+ 'use strict';
2
+
3
+ var Menu = require('../Menu-D4apJOhh.js');
4
+ require('react');
5
+ require('classnames');
6
+ require('framer-motion');
7
+ require('../useOnKeyDown-ClBoAl9o.js');
8
+ require('../useRefocusOnActivator-DhXYZbJ2.js');
9
+ require('../useSafeLayoutEffect-87KYIon5.js');
10
+ require('../Button-C6SHw1kI.js');
11
+ require('react-router-dom');
12
+ require('../Icon-DN6zZdoZ.js');
13
+ require('@jobber/design');
14
+ require('../Typography-WLLQxuNl.js');
15
+
16
+
17
+
18
+ exports.Menu = Menu.Menu;
@@ -0,0 +1,12 @@
1
+ export { M as Menu } from '../Menu-IjuAzGId.js';
2
+ import 'react';
3
+ import 'classnames';
4
+ import 'framer-motion';
5
+ import '../useOnKeyDown-BBUzTpsM.js';
6
+ import '../useRefocusOnActivator-JhjmSWbr.js';
7
+ import '../useSafeLayoutEffect-IMNHxeSN.js';
8
+ import '../Button-Cfp4SFrN.js';
9
+ import 'react-router-dom';
10
+ import '../Icon-Cprfa6DH.js';
11
+ import '@jobber/design';
12
+ import '../Typography-D6YoQOGF.js';
@@ -0,0 +1,131 @@
1
+ 'use strict';
2
+
3
+ var React = require('react');
4
+ var classnames = require('classnames');
5
+ var framerMotion = require('framer-motion');
6
+ var useOnKeyDown = require('./useOnKeyDown-ClBoAl9o.js');
7
+ var useRefocusOnActivator = require('./useRefocusOnActivator-DhXYZbJ2.js');
8
+ var useSafeLayoutEffect = require('./useSafeLayoutEffect-87KYIon5.js');
9
+ var Button = require('./Button-C6SHw1kI.js');
10
+ var Typography = require('./Typography-WLLQxuNl.js');
11
+ var Icon = require('./Icon-DN6zZdoZ.js');
12
+
13
+ var styles = {"wrapper":"dT6M9tp1sZc-","menu":"Qmxlsj0D3qM-","above":"QTisUfiHwL4-","below":"qsch1dlpOHc-","left":"_0xR9-oxWMOU-","right":"gaZwsdyoG0k-","section":"LaKFjYCLHZc-","sectionHeader":"_7HB7dWnqCi0-","action":"ZuceCiefKqw-","icon":"Bz8TONF8kws-","overlay":"eKnUAucwwWU-","fullWidth":"oaxefr58z-E-","screenReaderOnly":"vz9opIdwHFg-"};
14
+
15
+ const variation = {
16
+ overlayStartStop: { opacity: 0 },
17
+ startOrStop: (position) => {
18
+ let y = 10;
19
+ if (position === "below")
20
+ y *= -1;
21
+ if (window.innerWidth < 640)
22
+ y = 150;
23
+ return { opacity: 0, y };
24
+ },
25
+ done: { opacity: 1, y: 0 },
26
+ };
27
+ // eslint-disable-next-line max-statements
28
+ function Menu({ activator, items }) {
29
+ var _a;
30
+ const [visible, setVisible] = React.useState(false);
31
+ const fullWidth = ((_a = activator === null || activator === void 0 ? void 0 : activator.props) === null || _a === void 0 ? void 0 : _a.fullWidth) || false;
32
+ const [position, setPosition] = React.useState({
33
+ vertical: "below",
34
+ horizontal: "right",
35
+ });
36
+ const wrapperRef = React.createRef();
37
+ const buttonID = React.useId();
38
+ const menuID = React.useId();
39
+ useOnKeyDown.useOnKeyDown_2(handleKeyboardShortcut, ["Escape"]);
40
+ useSafeLayoutEffect.useSafeLayoutEffect_1(() => {
41
+ if (wrapperRef.current) {
42
+ const bounds = wrapperRef.current.getBoundingClientRect();
43
+ const newPosition = Object.assign({}, position);
44
+ if (bounds.top <= window.innerHeight / 2) {
45
+ newPosition.vertical = "below";
46
+ }
47
+ else {
48
+ newPosition.vertical = "above";
49
+ }
50
+ if (bounds.left <= window.innerWidth / 2) {
51
+ newPosition.horizontal = "right";
52
+ }
53
+ else {
54
+ newPosition.horizontal = "left";
55
+ }
56
+ setPosition(newPosition);
57
+ }
58
+ }, [visible, fullWidth]);
59
+ useRefocusOnActivator.useRefocusOnActivator_2(visible);
60
+ if (!activator) {
61
+ activator = (React.createElement(Button.Button, { fullWidth: true, label: "More Actions", icon: "more", type: "secondary" }));
62
+ }
63
+ const menuClasses = classnames(styles.menu, position.vertical === "above" && styles.above, position.vertical === "below" && styles.below, position.horizontal === "left" && styles.left, position.horizontal === "right" && styles.right);
64
+ const wrapperClasses = classnames(styles.wrapper, {
65
+ [styles.fullWidth]: fullWidth,
66
+ });
67
+ return (React.createElement("div", { className: wrapperClasses, ref: wrapperRef, onClick: handleParentClick },
68
+ React.cloneElement(activator, {
69
+ onClick: toggle(activator.props.onClick),
70
+ id: buttonID,
71
+ ariaControls: menuID,
72
+ ariaExpanded: visible,
73
+ ariaHaspopup: true,
74
+ }),
75
+ React.createElement(framerMotion.AnimatePresence, null, visible && (React.createElement(React.Fragment, null,
76
+ React.createElement(framerMotion.motion.div, { className: styles.overlay, onClick: toggle(), variants: variation, initial: "overlayStartStop", animate: "done", exit: "overlayStartStop", transition: {
77
+ type: "tween",
78
+ duration: 0.15,
79
+ } }),
80
+ React.createElement(framerMotion.motion.div, { className: menuClasses, role: "menu", "aria-labelledby": buttonID, id: menuID, onClick: hide, variants: variation, initial: "startOrStop", animate: "done", exit: "startOrStop", custom: position, transition: {
81
+ type: "tween",
82
+ duration: 0.25,
83
+ } }, items.map((item, key) => (React.createElement("div", { key: key, className: styles.section },
84
+ item.header && React.createElement(SectionHeader, { text: item.header }),
85
+ item.actions.map((action, index) => (React.createElement(Action, Object.assign({ sectionLabel: item.header, key: action.label, shouldFocus: key === 0 && index === 0 }, action)))))))))))));
86
+ function toggle(callbackPassthrough) {
87
+ return (event) => {
88
+ setVisible(!visible);
89
+ callbackPassthrough && callbackPassthrough(event);
90
+ };
91
+ }
92
+ function hide() {
93
+ setVisible(false);
94
+ }
95
+ function handleKeyboardShortcut(event) {
96
+ const { key } = event;
97
+ if (!visible)
98
+ return;
99
+ event.preventDefault();
100
+ event.stopPropagation();
101
+ key === "Escape" && hide();
102
+ }
103
+ function handleParentClick(event) {
104
+ // Since the menu is being rendered within the same parent as the activator,
105
+ // we need to stop the click event from bubbling up. If the Menu component
106
+ // gets added within a parent that has a click handler, any click on the
107
+ // menu will trigger the parent's click handler.
108
+ event.stopPropagation();
109
+ }
110
+ }
111
+ function SectionHeader({ text }) {
112
+ return (React.createElement("div", { className: styles.sectionHeader, "aria-hidden": true },
113
+ React.createElement(Typography.Typography, { element: "h6", size: "small", textCase: "uppercase", textColor: "textSecondary", fontWeight: "bold" }, text)));
114
+ }
115
+ function Action({ label, sectionLabel, icon, onClick, shouldFocus = false, }) {
116
+ const actionButtonRef = React.useRef();
117
+ React.useEffect(() => {
118
+ if (shouldFocus) {
119
+ // Focus on the next tick to allow useRefocusOnActivator to initialize
120
+ setTimeout(() => { var _a; return (_a = actionButtonRef.current) === null || _a === void 0 ? void 0 : _a.focus(); }, 0);
121
+ }
122
+ }, [shouldFocus]);
123
+ return (React.createElement("button", { role: "menuitem", type: "button", className: styles.action, key: label, onClick: onClick, ref: actionButtonRef },
124
+ icon && (React.createElement("span", { className: styles.icon },
125
+ React.createElement(Icon.Icon, { name: icon }))),
126
+ React.createElement(Typography.Typography, { element: "span", size: "base", textColor: "text" },
127
+ sectionLabel && (React.createElement("span", { className: styles.screenReaderOnly }, sectionLabel)),
128
+ label)));
129
+ }
130
+
131
+ exports.Menu = Menu;
@@ -0,0 +1,129 @@
1
+ import React, { useState, createRef, useId, useRef, useEffect } from 'react';
2
+ import classnames from 'classnames';
3
+ import { AnimatePresence, motion } from 'framer-motion';
4
+ import { u as useOnKeyDown_2 } from './useOnKeyDown-BBUzTpsM.js';
5
+ import { u as useRefocusOnActivator_2 } from './useRefocusOnActivator-JhjmSWbr.js';
6
+ import { u as useSafeLayoutEffect_1 } from './useSafeLayoutEffect-IMNHxeSN.js';
7
+ import { B as Button } from './Button-Cfp4SFrN.js';
8
+ import { T as Typography } from './Typography-D6YoQOGF.js';
9
+ import { I as Icon } from './Icon-Cprfa6DH.js';
10
+
11
+ var styles = {"wrapper":"dT6M9tp1sZc-","menu":"Qmxlsj0D3qM-","above":"QTisUfiHwL4-","below":"qsch1dlpOHc-","left":"_0xR9-oxWMOU-","right":"gaZwsdyoG0k-","section":"LaKFjYCLHZc-","sectionHeader":"_7HB7dWnqCi0-","action":"ZuceCiefKqw-","icon":"Bz8TONF8kws-","overlay":"eKnUAucwwWU-","fullWidth":"oaxefr58z-E-","screenReaderOnly":"vz9opIdwHFg-"};
12
+
13
+ const variation = {
14
+ overlayStartStop: { opacity: 0 },
15
+ startOrStop: (position) => {
16
+ let y = 10;
17
+ if (position === "below")
18
+ y *= -1;
19
+ if (window.innerWidth < 640)
20
+ y = 150;
21
+ return { opacity: 0, y };
22
+ },
23
+ done: { opacity: 1, y: 0 },
24
+ };
25
+ // eslint-disable-next-line max-statements
26
+ function Menu({ activator, items }) {
27
+ var _a;
28
+ const [visible, setVisible] = useState(false);
29
+ const fullWidth = ((_a = activator === null || activator === void 0 ? void 0 : activator.props) === null || _a === void 0 ? void 0 : _a.fullWidth) || false;
30
+ const [position, setPosition] = useState({
31
+ vertical: "below",
32
+ horizontal: "right",
33
+ });
34
+ const wrapperRef = createRef();
35
+ const buttonID = useId();
36
+ const menuID = useId();
37
+ useOnKeyDown_2(handleKeyboardShortcut, ["Escape"]);
38
+ useSafeLayoutEffect_1(() => {
39
+ if (wrapperRef.current) {
40
+ const bounds = wrapperRef.current.getBoundingClientRect();
41
+ const newPosition = Object.assign({}, position);
42
+ if (bounds.top <= window.innerHeight / 2) {
43
+ newPosition.vertical = "below";
44
+ }
45
+ else {
46
+ newPosition.vertical = "above";
47
+ }
48
+ if (bounds.left <= window.innerWidth / 2) {
49
+ newPosition.horizontal = "right";
50
+ }
51
+ else {
52
+ newPosition.horizontal = "left";
53
+ }
54
+ setPosition(newPosition);
55
+ }
56
+ }, [visible, fullWidth]);
57
+ useRefocusOnActivator_2(visible);
58
+ if (!activator) {
59
+ activator = (React.createElement(Button, { fullWidth: true, label: "More Actions", icon: "more", type: "secondary" }));
60
+ }
61
+ const menuClasses = classnames(styles.menu, position.vertical === "above" && styles.above, position.vertical === "below" && styles.below, position.horizontal === "left" && styles.left, position.horizontal === "right" && styles.right);
62
+ const wrapperClasses = classnames(styles.wrapper, {
63
+ [styles.fullWidth]: fullWidth,
64
+ });
65
+ return (React.createElement("div", { className: wrapperClasses, ref: wrapperRef, onClick: handleParentClick },
66
+ React.cloneElement(activator, {
67
+ onClick: toggle(activator.props.onClick),
68
+ id: buttonID,
69
+ ariaControls: menuID,
70
+ ariaExpanded: visible,
71
+ ariaHaspopup: true,
72
+ }),
73
+ React.createElement(AnimatePresence, null, visible && (React.createElement(React.Fragment, null,
74
+ React.createElement(motion.div, { className: styles.overlay, onClick: toggle(), variants: variation, initial: "overlayStartStop", animate: "done", exit: "overlayStartStop", transition: {
75
+ type: "tween",
76
+ duration: 0.15,
77
+ } }),
78
+ React.createElement(motion.div, { className: menuClasses, role: "menu", "aria-labelledby": buttonID, id: menuID, onClick: hide, variants: variation, initial: "startOrStop", animate: "done", exit: "startOrStop", custom: position, transition: {
79
+ type: "tween",
80
+ duration: 0.25,
81
+ } }, items.map((item, key) => (React.createElement("div", { key: key, className: styles.section },
82
+ item.header && React.createElement(SectionHeader, { text: item.header }),
83
+ item.actions.map((action, index) => (React.createElement(Action, Object.assign({ sectionLabel: item.header, key: action.label, shouldFocus: key === 0 && index === 0 }, action)))))))))))));
84
+ function toggle(callbackPassthrough) {
85
+ return (event) => {
86
+ setVisible(!visible);
87
+ callbackPassthrough && callbackPassthrough(event);
88
+ };
89
+ }
90
+ function hide() {
91
+ setVisible(false);
92
+ }
93
+ function handleKeyboardShortcut(event) {
94
+ const { key } = event;
95
+ if (!visible)
96
+ return;
97
+ event.preventDefault();
98
+ event.stopPropagation();
99
+ key === "Escape" && hide();
100
+ }
101
+ function handleParentClick(event) {
102
+ // Since the menu is being rendered within the same parent as the activator,
103
+ // we need to stop the click event from bubbling up. If the Menu component
104
+ // gets added within a parent that has a click handler, any click on the
105
+ // menu will trigger the parent's click handler.
106
+ event.stopPropagation();
107
+ }
108
+ }
109
+ function SectionHeader({ text }) {
110
+ return (React.createElement("div", { className: styles.sectionHeader, "aria-hidden": true },
111
+ React.createElement(Typography, { element: "h6", size: "small", textCase: "uppercase", textColor: "textSecondary", fontWeight: "bold" }, text)));
112
+ }
113
+ function Action({ label, sectionLabel, icon, onClick, shouldFocus = false, }) {
114
+ const actionButtonRef = useRef();
115
+ useEffect(() => {
116
+ if (shouldFocus) {
117
+ // Focus on the next tick to allow useRefocusOnActivator to initialize
118
+ setTimeout(() => { var _a; return (_a = actionButtonRef.current) === null || _a === void 0 ? void 0 : _a.focus(); }, 0);
119
+ }
120
+ }, [shouldFocus]);
121
+ return (React.createElement("button", { role: "menuitem", type: "button", className: styles.action, key: label, onClick: onClick, ref: actionButtonRef },
122
+ icon && (React.createElement("span", { className: styles.icon },
123
+ React.createElement(Icon, { name: icon }))),
124
+ React.createElement(Typography, { element: "span", size: "base", textColor: "text" },
125
+ sectionLabel && (React.createElement("span", { className: styles.screenReaderOnly }, sectionLabel)),
126
+ label)));
127
+ }
128
+
129
+ export { Menu as M };
@@ -0,0 +1,23 @@
1
+ 'use strict';
2
+
3
+ var Modal = require('../Modal-Dr-Y4-gf.js');
4
+ require('react');
5
+ require('react-dom');
6
+ require('classnames');
7
+ require('framer-motion');
8
+ require('../useRefocusOnActivator-DhXYZbJ2.js');
9
+ require('../useOnKeyDown-ClBoAl9o.js');
10
+ require('../useFocusTrap-DDVdHPLP.js');
11
+ require('../Heading-CCFoOnua.js');
12
+ require('../Typography-WLLQxuNl.js');
13
+ require('../useAtlantisConfig-BbG41OXr.js');
14
+ require('../useSafeLayoutEffect-87KYIon5.js');
15
+ require('../Button-C6SHw1kI.js');
16
+ require('react-router-dom');
17
+ require('../Icon-DN6zZdoZ.js');
18
+ require('@jobber/design');
19
+ require('../ButtonDismiss-DVALYLmq.js');
20
+
21
+
22
+
23
+ exports.Modal = Modal.Modal;
@@ -0,0 +1,17 @@
1
+ export { M as Modal } from '../Modal-aGXkiuSS.js';
2
+ import 'react';
3
+ import 'react-dom';
4
+ import 'classnames';
5
+ import 'framer-motion';
6
+ import '../useRefocusOnActivator-JhjmSWbr.js';
7
+ import '../useOnKeyDown-BBUzTpsM.js';
8
+ import '../useFocusTrap-J4nqJhkL.js';
9
+ import '../Heading-Cik7AvDW.js';
10
+ import '../Typography-D6YoQOGF.js';
11
+ import '../useAtlantisConfig-ClMTcI5f.js';
12
+ import '../useSafeLayoutEffect-IMNHxeSN.js';
13
+ import '../Button-Cfp4SFrN.js';
14
+ import 'react-router-dom';
15
+ import '../Icon-Cprfa6DH.js';
16
+ import '@jobber/design';
17
+ import '../ButtonDismiss-Cf-2rvG0.js';
@@ -0,0 +1,62 @@
1
+ 'use strict';
2
+
3
+ var React = require('react');
4
+ var ReactDOM = require('react-dom');
5
+ var classnames = require('classnames');
6
+ var framerMotion = require('framer-motion');
7
+ var useRefocusOnActivator = require('./useRefocusOnActivator-DhXYZbJ2.js');
8
+ var useOnKeyDown = require('./useOnKeyDown-ClBoAl9o.js');
9
+ var useFocusTrap = require('./useFocusTrap-DDVdHPLP.js');
10
+ var Heading = require('./Heading-CCFoOnua.js');
11
+ var Button = require('./Button-C6SHw1kI.js');
12
+ var ButtonDismiss = require('./ButtonDismiss-DVALYLmq.js');
13
+
14
+ var styles = {"container":"QGRLFHPoV5E-","overlay":"_4WzGOMUGj5I-","modal":"WLId2NJBQcQ-","header":"wjrPpIUNNrk-","closeButton":"rKvigUnOyYE-","actionBar":"_62c8HLZFwvs-","leftAction":"Xl1Ptn-P9Ew-","rightAction":"p2s7GtpoZz0-"};
15
+
16
+ var sizes = {"small":"_65IpUjOZiBg-","large":"Cpwnmw65caA-"};
17
+
18
+ function Modal({ open = false, title, size, dismissible = true, children, primaryAction, secondaryAction, tertiaryAction, onRequestClose, }) {
19
+ const modalClassName = classnames(styles.modal, size && sizes[size]);
20
+ useRefocusOnActivator.useRefocusOnActivator_2(open);
21
+ const modalRef = useFocusTrap.useFocusTrap_2(open);
22
+ useOnKeyDown.useOnKeyDown_2(handleRequestClose, "Escape");
23
+ const template = (React.createElement(framerMotion.AnimatePresence, null, open && (React.createElement("div", { ref: modalRef, role: "dialog", className: styles.container, tabIndex: 0 },
24
+ React.createElement(framerMotion.motion.div, { key: styles.overlay, className: styles.overlay, onClick: onRequestClose, initial: { opacity: 0 }, animate: { opacity: 0.8 }, exit: { opacity: 0 }, transition: { duration: 0.2 } }),
25
+ React.createElement(framerMotion.motion.div, { key: styles.modal, className: modalClassName, initial: { scale: 0.9, opacity: 0 }, animate: { scale: 1, opacity: 1 }, exit: { scale: 0.9, opacity: 0 }, transition: {
26
+ duration: 0.2,
27
+ ease: "easeInOut",
28
+ } },
29
+ title != undefined && (React.createElement(Header, { title: title, dismissible: dismissible, onRequestClose: onRequestClose })),
30
+ children,
31
+ React.createElement(Actions, { primary: primaryAction, secondary: secondaryAction, tertiary: tertiaryAction }))))));
32
+ return (globalThis === null || globalThis === void 0 ? void 0 : globalThis.document)
33
+ ? ReactDOM.createPortal(template, document.body)
34
+ : template;
35
+ function handleRequestClose() {
36
+ if (open && onRequestClose) {
37
+ onRequestClose();
38
+ }
39
+ }
40
+ }
41
+ function Header({ title, dismissible, onRequestClose }) {
42
+ return (React.createElement("div", { className: styles.header, "data-testid": "modal-header" },
43
+ React.createElement(Heading.Heading, { level: 3 }, title),
44
+ dismissible && (React.createElement(ButtonDismiss.ButtonDismiss, { onClick: onRequestClose, ariaLabel: "Close modal" }))));
45
+ }
46
+ function Actions({ primary, secondary, tertiary }) {
47
+ const shouldShow = primary != undefined || secondary != undefined || tertiary != undefined;
48
+ if (secondary != undefined) {
49
+ secondary = Object.assign({ type: "primary", variation: "subtle" }, secondary);
50
+ }
51
+ if (tertiary != undefined) {
52
+ tertiary = Object.assign({ type: "secondary", variation: "destructive" }, tertiary);
53
+ }
54
+ return (React.createElement(React.Fragment, null, shouldShow && (React.createElement("div", { className: styles.actionBar },
55
+ React.createElement("div", { className: styles.rightAction },
56
+ primary && React.createElement(Button.Button, Object.assign({}, primary)),
57
+ secondary && React.createElement(Button.Button, Object.assign({}, secondary))),
58
+ tertiary && (React.createElement("div", { className: styles.leftAction },
59
+ React.createElement(Button.Button, Object.assign({}, tertiary))))))));
60
+ }
61
+
62
+ exports.Modal = Modal;
@@ -0,0 +1,60 @@
1
+ import React from 'react';
2
+ import ReactDOM from 'react-dom';
3
+ import classnames from 'classnames';
4
+ import { AnimatePresence, motion } from 'framer-motion';
5
+ import { u as useRefocusOnActivator_2 } from './useRefocusOnActivator-JhjmSWbr.js';
6
+ import { u as useOnKeyDown_2 } from './useOnKeyDown-BBUzTpsM.js';
7
+ import { u as useFocusTrap_2 } from './useFocusTrap-J4nqJhkL.js';
8
+ import { H as Heading } from './Heading-Cik7AvDW.js';
9
+ import { B as Button } from './Button-Cfp4SFrN.js';
10
+ import { B as ButtonDismiss } from './ButtonDismiss-Cf-2rvG0.js';
11
+
12
+ var styles = {"container":"QGRLFHPoV5E-","overlay":"_4WzGOMUGj5I-","modal":"WLId2NJBQcQ-","header":"wjrPpIUNNrk-","closeButton":"rKvigUnOyYE-","actionBar":"_62c8HLZFwvs-","leftAction":"Xl1Ptn-P9Ew-","rightAction":"p2s7GtpoZz0-"};
13
+
14
+ var sizes = {"small":"_65IpUjOZiBg-","large":"Cpwnmw65caA-"};
15
+
16
+ function Modal({ open = false, title, size, dismissible = true, children, primaryAction, secondaryAction, tertiaryAction, onRequestClose, }) {
17
+ const modalClassName = classnames(styles.modal, size && sizes[size]);
18
+ useRefocusOnActivator_2(open);
19
+ const modalRef = useFocusTrap_2(open);
20
+ useOnKeyDown_2(handleRequestClose, "Escape");
21
+ const template = (React.createElement(AnimatePresence, null, open && (React.createElement("div", { ref: modalRef, role: "dialog", className: styles.container, tabIndex: 0 },
22
+ React.createElement(motion.div, { key: styles.overlay, className: styles.overlay, onClick: onRequestClose, initial: { opacity: 0 }, animate: { opacity: 0.8 }, exit: { opacity: 0 }, transition: { duration: 0.2 } }),
23
+ React.createElement(motion.div, { key: styles.modal, className: modalClassName, initial: { scale: 0.9, opacity: 0 }, animate: { scale: 1, opacity: 1 }, exit: { scale: 0.9, opacity: 0 }, transition: {
24
+ duration: 0.2,
25
+ ease: "easeInOut",
26
+ } },
27
+ title != undefined && (React.createElement(Header, { title: title, dismissible: dismissible, onRequestClose: onRequestClose })),
28
+ children,
29
+ React.createElement(Actions, { primary: primaryAction, secondary: secondaryAction, tertiary: tertiaryAction }))))));
30
+ return (globalThis === null || globalThis === void 0 ? void 0 : globalThis.document)
31
+ ? ReactDOM.createPortal(template, document.body)
32
+ : template;
33
+ function handleRequestClose() {
34
+ if (open && onRequestClose) {
35
+ onRequestClose();
36
+ }
37
+ }
38
+ }
39
+ function Header({ title, dismissible, onRequestClose }) {
40
+ return (React.createElement("div", { className: styles.header, "data-testid": "modal-header" },
41
+ React.createElement(Heading, { level: 3 }, title),
42
+ dismissible && (React.createElement(ButtonDismiss, { onClick: onRequestClose, ariaLabel: "Close modal" }))));
43
+ }
44
+ function Actions({ primary, secondary, tertiary }) {
45
+ const shouldShow = primary != undefined || secondary != undefined || tertiary != undefined;
46
+ if (secondary != undefined) {
47
+ secondary = Object.assign({ type: "primary", variation: "subtle" }, secondary);
48
+ }
49
+ if (tertiary != undefined) {
50
+ tertiary = Object.assign({ type: "secondary", variation: "destructive" }, tertiary);
51
+ }
52
+ return (React.createElement(React.Fragment, null, shouldShow && (React.createElement("div", { className: styles.actionBar },
53
+ React.createElement("div", { className: styles.rightAction },
54
+ primary && React.createElement(Button, Object.assign({}, primary)),
55
+ secondary && React.createElement(Button, Object.assign({}, secondary))),
56
+ tertiary && (React.createElement("div", { className: styles.leftAction },
57
+ React.createElement(Button, Object.assign({}, tertiary))))))));
58
+ }
59
+
60
+ export { Modal as M };
@@ -0,0 +1,16 @@
1
+ 'use strict';
2
+
3
+ var MultiSelect = require('../MultiSelect-1LkHc-4a.js');
4
+ require('react');
5
+ require('classnames');
6
+ require('../Checkbox-BXh_wazi.js');
7
+ require('../tslib.es6-v7P0Y776.js');
8
+ require('react-hook-form');
9
+ require('../Icon-DN6zZdoZ.js');
10
+ require('@jobber/design');
11
+ require('../Text-Bopx9dUr.js');
12
+ require('../Typography-WLLQxuNl.js');
13
+
14
+
15
+
16
+ exports.MultiSelect = MultiSelect.MultiSelect;
@@ -0,0 +1,10 @@
1
+ export { M as MultiSelect } from '../MultiSelect-CIFWIwY6.js';
2
+ import 'react';
3
+ import 'classnames';
4
+ import '../Checkbox-DxC81YWi.js';
5
+ import '../tslib.es6-CQnq_FvL.js';
6
+ import 'react-hook-form';
7
+ import '../Icon-Cprfa6DH.js';
8
+ import '@jobber/design';
9
+ import '../Text-DALHhxHl.js';
10
+ import '../Typography-D6YoQOGF.js';
@@ -0,0 +1,166 @@
1
+ 'use strict';
2
+
3
+ var React = require('react');
4
+ var classnames = require('classnames');
5
+ var Checkbox = require('./Checkbox-BXh_wazi.js');
6
+ var Text = require('./Text-Bopx9dUr.js');
7
+ var Icon = require('./Icon-DN6zZdoZ.js');
8
+
9
+ var styles$1 = {"multiSelectContainer":"D-J03az6XL4-","multiSelect":"EzNdHgwsT40-","active":"bu7HWKRu6HI-","small":"eQ6yfQg6zLc-","large":"pM-ts4-QMZY-"};
10
+
11
+ var styles = {"dropDownMenuContainer":"_0SStdD4KRHs-","option":"mFSgwOQZJm0-","active":"SepF4gvOxq8-"};
12
+
13
+ function DropDownMenu({ options, setOptions }) {
14
+ const [highlightedIndex, setHighlightedIndex] = React.useState(0);
15
+ const menuDiv = React.useRef();
16
+ const handleOptionClick = React.useCallback((clickedOption) => {
17
+ setOptions(current => current.map(option => {
18
+ if (option.label == clickedOption.label) {
19
+ return Object.assign(Object.assign({}, option), { checked: !clickedOption.checked });
20
+ }
21
+ return option;
22
+ }));
23
+ }, []);
24
+ function handleOptionHover(event, index) {
25
+ event.preventDefault();
26
+ setHighlightedIndex(index);
27
+ }
28
+ function handleOptionFocus(index) {
29
+ setHighlightedIndex(index);
30
+ if (menuDiv.current) {
31
+ const option = menuDiv.current.children[index].querySelector("input");
32
+ option === null || option === void 0 ? void 0 : option.focus();
33
+ }
34
+ }
35
+ function scrollMenuIfItemNotInView(menuDivElement, direction) {
36
+ const itemDiv = menuDivElement.querySelector(`:nth-child(${highlightedIndex + 1})`);
37
+ if (!itemDiv)
38
+ return;
39
+ const menuTop = menuDivElement.getBoundingClientRect().top;
40
+ const { top: itemTop, height: itemHeight, bottom: itemBottom, } = itemDiv.getBoundingClientRect();
41
+ const itemTrueBottom = itemBottom + itemHeight;
42
+ const menuBottom = menuDivElement.getBoundingClientRect().bottom;
43
+ if (direction == "up" && itemTop - itemHeight < menuTop) {
44
+ menuDivElement.scrollTop -= itemHeight;
45
+ }
46
+ else if (direction == "down" && itemTrueBottom > menuBottom) {
47
+ menuDivElement.scrollTop += itemHeight;
48
+ }
49
+ }
50
+ function handleKeyDown(event) {
51
+ const { key, metaKey, ctrlKey } = event;
52
+ if (metaKey || ctrlKey)
53
+ return;
54
+ switch (key) {
55
+ case "Enter": {
56
+ if (highlightedIndex >= 0) {
57
+ handleOptionClick(options[highlightedIndex]);
58
+ }
59
+ break;
60
+ }
61
+ case "ArrowDown": {
62
+ handlePressDown(event);
63
+ break;
64
+ }
65
+ case "ArrowUp": {
66
+ handlePressUp(event);
67
+ break;
68
+ }
69
+ }
70
+ }
71
+ React.useEffect(() => {
72
+ // focus first option
73
+ handleOptionFocus(0);
74
+ }, [menuDiv]);
75
+ return (React.createElement("ul", { "data-testid": "dropdown-menu", className: styles.dropDownMenuContainer, ref: menuDiv, onKeyDown: handleKeyDown }, options.map((option, index) => {
76
+ const optionClass = classnames(styles.option, {
77
+ [styles.active]: index === highlightedIndex,
78
+ });
79
+ return (React.createElement("li", { key: `${index}-${option.label}`, className: optionClass, onClick: event => {
80
+ event.stopPropagation();
81
+ event.preventDefault();
82
+ handleOptionClick(option);
83
+ }, onMouseOver: e => handleOptionHover(e, index) },
84
+ React.createElement(Checkbox.Checkbox, { label: option.label, checked: option.checked, onFocus: () => setHighlightedIndex(index) })));
85
+ })));
86
+ function handlePressUp(event) {
87
+ event.preventDefault();
88
+ const newIndex = Math.max(0, highlightedIndex - 1);
89
+ handleOptionFocus(newIndex);
90
+ scrollMenuIfItemNotInView(menuDiv.current, "up");
91
+ }
92
+ function handlePressDown(event) {
93
+ event.preventDefault();
94
+ const newIndex = Math.min(options.length - 1, highlightedIndex + 1);
95
+ handleOptionFocus(newIndex);
96
+ scrollMenuIfItemNotInView(menuDiv.current, "down");
97
+ }
98
+ }
99
+
100
+ // eslint-disable-next-line max-statements
101
+ function MultiSelect({ defaultLabel, allSelectedLabel, options, onOptionsChange, size, }) {
102
+ const [label, setLabel] = React.useState(defaultLabel);
103
+ const [menuVisible, setMenuVisible] = React.useState(false);
104
+ const [focused, setFocused] = React.useState(false);
105
+ const multiSelectContainer = React.useRef();
106
+ const multiSelectRef = React.useRef();
107
+ const multiSelectClass = classnames(styles$1.multiSelect, {
108
+ [styles$1.active]: menuVisible,
109
+ [styles$1.large]: size === "large",
110
+ [styles$1.small]: size === "small",
111
+ });
112
+ function handleMenuVisibility() {
113
+ multiSelectRef.current.focus();
114
+ setMenuVisible(!menuVisible);
115
+ }
116
+ const handleClickOutside = (e) => {
117
+ var _a;
118
+ if (!((_a = multiSelectContainer === null || multiSelectContainer === void 0 ? void 0 : multiSelectContainer.current) === null || _a === void 0 ? void 0 : _a.contains(e.target))) {
119
+ setMenuVisible(false);
120
+ }
121
+ };
122
+ function handleKeydown(event) {
123
+ const { key, metaKey, ctrlKey } = event;
124
+ if (metaKey || ctrlKey)
125
+ return;
126
+ switch (key) {
127
+ case "Enter":
128
+ case " ": {
129
+ if (focused) {
130
+ setMenuVisible(!menuVisible);
131
+ }
132
+ break;
133
+ }
134
+ case "Escape": {
135
+ multiSelectRef.current.focus();
136
+ setMenuVisible(false);
137
+ break;
138
+ }
139
+ }
140
+ }
141
+ React.useEffect(() => {
142
+ document.addEventListener("mousedown", handleClickOutside);
143
+ return () => document.removeEventListener("mousedown", handleClickOutside);
144
+ });
145
+ React.useEffect(() => {
146
+ const selected = options.filter(option => option.checked);
147
+ if (selected.length === 0) {
148
+ setLabel(defaultLabel);
149
+ }
150
+ else if (selected.length == options.length) {
151
+ setLabel(allSelectedLabel);
152
+ }
153
+ else {
154
+ const selectedLabels = [];
155
+ selected.forEach(option => selectedLabels.push(option.label));
156
+ setLabel(selectedLabels.join(", "));
157
+ }
158
+ }, [options]);
159
+ return (React.createElement("div", { ref: multiSelectContainer, className: styles$1.multiSelectContainer, onKeyDown: handleKeydown },
160
+ React.createElement("div", { "data-testid": "multi-select", className: multiSelectClass, onClick: handleMenuVisibility, onFocus: () => setFocused(true), onBlur: () => setFocused(false), tabIndex: 0, ref: multiSelectRef, role: "button", "aria-label": `${defaultLabel}: ${label}`, "aria-multiselectable": true, "aria-haspopup": true },
161
+ React.createElement(Text.Text, null, label),
162
+ React.createElement(Icon.Icon, { name: "arrowDown" })),
163
+ menuVisible && (React.createElement(DropDownMenu, { options: options, setOptions: onOptionsChange }))));
164
+ }
165
+
166
+ exports.MultiSelect = MultiSelect;