@laerdal/life-react-components 1.4.1-dev.9 → 1.5.1-dev.1.full

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 (367) hide show
  1. package/dist/Accordion/AccordionItem.cjs +77 -0
  2. package/dist/Accordion/AccordionItem.cjs.map +1 -0
  3. package/dist/Accordion/AccordionItem.d.ts +2 -0
  4. package/dist/Accordion/AccordionItem.js +8 -7
  5. package/dist/Accordion/AccordionItem.js.map +1 -1
  6. package/dist/Accordion/AccordionMenu.cjs +105 -0
  7. package/dist/Accordion/AccordionMenu.cjs.map +1 -0
  8. package/dist/Accordion/AccordionMenu.d.ts +2 -0
  9. package/dist/Accordion/AccordionMenu.js +8 -2
  10. package/dist/Accordion/AccordionMenu.js.map +1 -1
  11. package/dist/Accordion/ContentAccordion.cjs +172 -0
  12. package/dist/Accordion/ContentAccordion.cjs.map +1 -0
  13. package/dist/Accordion/index.cjs +38 -0
  14. package/dist/Accordion/index.cjs.map +1 -0
  15. package/dist/Accordion/styles.cjs +45 -0
  16. package/dist/Accordion/styles.cjs.map +1 -0
  17. package/dist/Accordion/styles.d.ts +5 -5
  18. package/dist/Accordion/styles.js +9 -10
  19. package/dist/Accordion/styles.js.map +1 -1
  20. package/dist/AuthPage/AuthPage.cjs +80 -0
  21. package/dist/AuthPage/AuthPage.cjs.map +1 -0
  22. package/dist/AuthPage/Information.cjs +42 -0
  23. package/dist/AuthPage/Information.cjs.map +1 -0
  24. package/dist/AuthPage/ScreenSetsContainer.cjs +25 -0
  25. package/dist/AuthPage/ScreenSetsContainer.cjs.map +1 -0
  26. package/dist/AuthPage/_AuthPageSection.cjs +22 -0
  27. package/dist/AuthPage/_AuthPageSection.cjs.map +1 -0
  28. package/dist/AuthPage/index.cjs +64 -0
  29. package/dist/AuthPage/index.cjs.map +1 -0
  30. package/dist/AuthPage/screenSetsErrorMessages.cjs +13 -0
  31. package/dist/AuthPage/screenSetsErrorMessages.cjs.map +1 -0
  32. package/dist/Banners/Banner.cjs +190 -0
  33. package/dist/Banners/Banner.cjs.map +1 -0
  34. package/dist/Banners/Banner.d.ts +1 -0
  35. package/dist/Banners/Banner.js +84 -189
  36. package/dist/Banners/Banner.js.map +1 -1
  37. package/dist/Banners/OverviewBanner.cjs +55 -0
  38. package/dist/Banners/OverviewBanner.cjs.map +1 -0
  39. package/dist/Banners/index.cjs +24 -0
  40. package/dist/Banners/index.cjs.map +1 -0
  41. package/dist/Banners/styles.cjs +73 -0
  42. package/dist/Banners/styles.cjs.map +1 -0
  43. package/dist/Banners/styles.js +44 -7
  44. package/dist/Banners/styles.js.map +1 -1
  45. package/dist/Breadcrumb/Breadcrumb.cjs +169 -0
  46. package/dist/Breadcrumb/Breadcrumb.cjs.map +1 -0
  47. package/dist/Breadcrumb/BreadcrumbItem.cjs +6 -0
  48. package/dist/Breadcrumb/BreadcrumbItem.cjs.map +1 -0
  49. package/dist/Breadcrumb/index.cjs +16 -0
  50. package/dist/Breadcrumb/index.cjs.map +1 -0
  51. package/dist/Button/BackButton.cjs +75 -0
  52. package/dist/Button/BackButton.cjs.map +1 -0
  53. package/dist/Button/Button.cjs +266 -0
  54. package/dist/Button/Button.cjs.map +1 -0
  55. package/dist/Button/Button.js +27 -101
  56. package/dist/Button/Button.js.map +1 -1
  57. package/dist/Button/DualFunctionButton.cjs +162 -0
  58. package/dist/Button/DualFunctionButton.cjs.map +1 -0
  59. package/dist/Button/Iconbutton.cjs +195 -0
  60. package/dist/Button/Iconbutton.cjs.map +1 -0
  61. package/dist/Button/Iconbutton.d.ts +13 -0
  62. package/dist/Button/Iconbutton.js +2 -2
  63. package/dist/Button/Iconbutton.js.map +1 -1
  64. package/dist/Button/index.cjs +40 -0
  65. package/dist/Button/index.cjs.map +1 -0
  66. package/dist/Chips/ActionChip.cjs +81 -0
  67. package/dist/Chips/ActionChip.cjs.map +1 -0
  68. package/dist/Chips/ChipInput.cjs +199 -0
  69. package/dist/Chips/ChipInput.cjs.map +1 -0
  70. package/dist/Chips/ChipStyles.cjs +43 -0
  71. package/dist/Chips/ChipStyles.cjs.map +1 -0
  72. package/dist/Chips/ChipTypes.cjs +6 -0
  73. package/dist/Chips/ChipTypes.cjs.map +1 -0
  74. package/dist/Chips/ChoiceChips.cjs +94 -0
  75. package/dist/Chips/ChoiceChips.cjs.map +1 -0
  76. package/dist/Chips/FilterChip.cjs +81 -0
  77. package/dist/Chips/FilterChip.cjs.map +1 -0
  78. package/dist/Chips/InputChip.cjs +109 -0
  79. package/dist/Chips/InputChip.cjs.map +1 -0
  80. package/dist/Chips/index.cjs +48 -0
  81. package/dist/Chips/index.cjs.map +1 -0
  82. package/dist/Dropdown/BasicDropdown.cjs +300 -0
  83. package/dist/Dropdown/BasicDropdown.cjs.map +1 -0
  84. package/dist/Dropdown/BasicDropdown.js.map +1 -1
  85. package/dist/Dropdown/ChipDropdownInput.cjs +431 -0
  86. package/dist/Dropdown/ChipDropdownInput.cjs.map +1 -0
  87. package/dist/Dropdown/ChipDropdownInput.js +2 -4
  88. package/dist/Dropdown/ChipDropdownInput.js.map +1 -1
  89. package/dist/Dropdown/CommonStyling.cjs +81 -0
  90. package/dist/Dropdown/CommonStyling.cjs.map +1 -0
  91. package/dist/Dropdown/CommonStyling.d.ts +0 -5
  92. package/dist/Dropdown/CommonStyling.js +3 -10
  93. package/dist/Dropdown/CommonStyling.js.map +1 -1
  94. package/dist/Dropdown/DropdownButton.cjs +161 -0
  95. package/dist/Dropdown/DropdownButton.cjs.map +1 -0
  96. package/dist/Dropdown/DropdownButtonTypes.cjs +6 -0
  97. package/dist/Dropdown/DropdownButtonTypes.cjs.map +1 -0
  98. package/dist/Dropdown/DropdownContent.cjs +566 -0
  99. package/dist/Dropdown/DropdownContent.cjs.map +1 -0
  100. package/dist/Dropdown/DropdownContent.js +19 -54
  101. package/dist/Dropdown/DropdownContent.js.map +1 -1
  102. package/dist/Dropdown/DropdownFilter.cjs +357 -0
  103. package/dist/Dropdown/DropdownFilter.cjs.map +1 -0
  104. package/dist/Dropdown/DropdownFilter.js.map +1 -1
  105. package/dist/Dropdown/index.cjs +40 -0
  106. package/dist/Dropdown/index.cjs.map +1 -0
  107. package/dist/Dropdown/index.d.ts +1 -0
  108. package/dist/Dropdown/index.js.map +1 -1
  109. package/dist/Footer/Components/FooterBottomLinks.cjs +69 -0
  110. package/dist/Footer/Components/FooterBottomLinks.cjs.map +1 -0
  111. package/dist/Footer/Components/FooterDropdownLinks.cjs +91 -0
  112. package/dist/Footer/Components/FooterDropdownLinks.cjs.map +1 -0
  113. package/dist/Footer/Components/FooterNavSection.cjs +90 -0
  114. package/dist/Footer/Components/FooterNavSection.cjs.map +1 -0
  115. package/dist/Footer/Components/FooterNewsletterAndSocialSection.cjs +129 -0
  116. package/dist/Footer/Components/FooterNewsletterAndSocialSection.cjs.map +1 -0
  117. package/dist/Footer/Components/FooterTop.cjs +91 -0
  118. package/dist/Footer/Components/FooterTop.cjs.map +1 -0
  119. package/dist/Footer/Footer.cjs +41 -0
  120. package/dist/Footer/Footer.cjs.map +1 -0
  121. package/dist/Footer/SiteFooter.cjs +89 -0
  122. package/dist/Footer/SiteFooter.cjs.map +1 -0
  123. package/dist/Footer/index.cjs +24 -0
  124. package/dist/Footer/index.cjs.map +1 -0
  125. package/dist/GlobalNavigationBar/Actions.cjs +185 -0
  126. package/dist/GlobalNavigationBar/Actions.cjs.map +1 -0
  127. package/dist/GlobalNavigationBar/Avatar.cjs +106 -0
  128. package/dist/GlobalNavigationBar/Avatar.cjs.map +1 -0
  129. package/dist/GlobalNavigationBar/ExtendedMainMenu.cjs +100 -0
  130. package/dist/GlobalNavigationBar/ExtendedMainMenu.cjs.map +1 -0
  131. package/dist/GlobalNavigationBar/GlobalNavigationBar.cjs +303 -0
  132. package/dist/GlobalNavigationBar/GlobalNavigationBar.cjs.map +1 -0
  133. package/dist/GlobalNavigationBar/Logo.cjs +102 -0
  134. package/dist/GlobalNavigationBar/Logo.cjs.map +1 -0
  135. package/dist/GlobalNavigationBar/MainMenu.cjs +169 -0
  136. package/dist/GlobalNavigationBar/MainMenu.cjs.map +1 -0
  137. package/dist/GlobalNavigationBar/RightSideNav.cjs +89 -0
  138. package/dist/GlobalNavigationBar/RightSideNav.cjs.map +1 -0
  139. package/dist/GlobalNavigationBar/UserMenu/MenuLink.cjs +108 -0
  140. package/dist/GlobalNavigationBar/UserMenu/MenuLink.cjs.map +1 -0
  141. package/dist/GlobalNavigationBar/UserMenu/MobileUserMenu.cjs +176 -0
  142. package/dist/GlobalNavigationBar/UserMenu/MobileUserMenu.cjs.map +1 -0
  143. package/dist/GlobalNavigationBar/UserMenu/UserMenu.cjs +168 -0
  144. package/dist/GlobalNavigationBar/UserMenu/UserMenu.cjs.map +1 -0
  145. package/dist/GlobalNavigationBar/index.cjs +36 -0
  146. package/dist/GlobalNavigationBar/index.cjs.map +1 -0
  147. package/dist/GlobalNavigationBar/mobile/CommonStyles.cjs +71 -0
  148. package/dist/GlobalNavigationBar/mobile/CommonStyles.cjs.map +1 -0
  149. package/dist/GlobalNavigationBar/mobile/ExitMenuButton.cjs +49 -0
  150. package/dist/GlobalNavigationBar/mobile/ExitMenuButton.cjs.map +1 -0
  151. package/dist/GlobalNavigationBar/mobile/MobileActionMenu.cjs +91 -0
  152. package/dist/GlobalNavigationBar/mobile/MobileActionMenu.cjs.map +1 -0
  153. package/dist/GlobalNavigationBar/mobile/MobileMenu.cjs +290 -0
  154. package/dist/GlobalNavigationBar/mobile/MobileMenu.cjs.map +1 -0
  155. package/dist/HyperLink/HyperLink.cjs +72 -0
  156. package/dist/HyperLink/HyperLink.cjs.map +1 -0
  157. package/dist/HyperLink/index.cjs +30 -0
  158. package/dist/HyperLink/index.cjs.map +1 -0
  159. package/dist/HyperLink/styling.cjs +22 -0
  160. package/dist/HyperLink/styling.cjs.map +1 -0
  161. package/dist/InputFields/Checkbox.cjs +126 -0
  162. package/dist/InputFields/Checkbox.cjs.map +1 -0
  163. package/dist/InputFields/DatepickerField.cjs +252 -0
  164. package/dist/InputFields/DatepickerField.cjs.map +1 -0
  165. package/dist/InputFields/DatepickerFieldHeader.cjs +107 -0
  166. package/dist/InputFields/DatepickerFieldHeader.cjs.map +1 -0
  167. package/dist/InputFields/Label.cjs +104 -0
  168. package/dist/InputFields/Label.cjs.map +1 -0
  169. package/dist/InputFields/PasswordField.cjs +150 -0
  170. package/dist/InputFields/PasswordField.cjs.map +1 -0
  171. package/dist/InputFields/QuickSearch.cjs +201 -0
  172. package/dist/InputFields/QuickSearch.cjs.map +1 -0
  173. package/dist/InputFields/RadioButton.cjs +114 -0
  174. package/dist/InputFields/RadioButton.cjs.map +1 -0
  175. package/dist/InputFields/ResponsiveComponentWrapper.cjs +72 -0
  176. package/dist/InputFields/ResponsiveComponentWrapper.cjs.map +1 -0
  177. package/dist/InputFields/SearchBar.cjs +146 -0
  178. package/dist/InputFields/SearchBar.cjs.map +1 -0
  179. package/dist/InputFields/TextField.cjs +126 -0
  180. package/dist/InputFields/TextField.cjs.map +1 -0
  181. package/dist/InputFields/Textarea.cjs +96 -0
  182. package/dist/InputFields/Textarea.cjs.map +1 -0
  183. package/dist/InputFields/components/SearchBarInput.cjs +99 -0
  184. package/dist/InputFields/components/SearchBarInput.cjs.map +1 -0
  185. package/dist/InputFields/components/SearchField.cjs +71 -0
  186. package/dist/InputFields/components/SearchField.cjs.map +1 -0
  187. package/dist/InputFields/index.cjs +80 -0
  188. package/dist/InputFields/index.cjs.map +1 -0
  189. package/dist/InputFields/styling.cjs +76 -0
  190. package/dist/InputFields/styling.cjs.map +1 -0
  191. package/dist/Layouts/index.cjs +56 -0
  192. package/dist/Layouts/index.cjs.map +1 -0
  193. package/dist/List/ListRow.cjs +143 -0
  194. package/dist/List/ListRow.cjs.map +1 -0
  195. package/dist/List/index.cjs +16 -0
  196. package/dist/List/index.cjs.map +1 -0
  197. package/dist/LoadingIndicator/LoadingIndicator.cjs +71 -0
  198. package/dist/LoadingIndicator/LoadingIndicator.cjs.map +1 -0
  199. package/dist/LoadingIndicator/index.cjs +16 -0
  200. package/dist/LoadingIndicator/index.cjs.map +1 -0
  201. package/dist/LoadingPage/GlobalLoadingPage.cjs +66 -0
  202. package/dist/LoadingPage/GlobalLoadingPage.cjs.map +1 -0
  203. package/dist/LoadingPage/index.cjs +16 -0
  204. package/dist/LoadingPage/index.cjs.map +1 -0
  205. package/dist/MenuItem/MenuItem.cjs +104 -0
  206. package/dist/MenuItem/MenuItem.cjs.map +1 -0
  207. package/dist/MenuItem/MenuItem.d.ts +21 -0
  208. package/dist/MenuItem/MenuItem.js +64 -0
  209. package/dist/MenuItem/MenuItem.js.map +1 -0
  210. package/dist/MiniProductCard/MiniProductCard.cjs +80 -0
  211. package/dist/MiniProductCard/MiniProductCard.cjs.map +1 -0
  212. package/dist/MiniProductCard/index.cjs +16 -0
  213. package/dist/MiniProductCard/index.cjs.map +1 -0
  214. package/dist/Modals/Modal.cjs +92 -0
  215. package/dist/Modals/Modal.cjs.map +1 -0
  216. package/dist/Modals/ModalContainer.cjs +176 -0
  217. package/dist/Modals/ModalContainer.cjs.map +1 -0
  218. package/dist/Modals/ModalContainer.js +1 -1
  219. package/dist/Modals/ModalContainer.js.map +1 -1
  220. package/dist/Modals/ModalDialog.cjs +363 -0
  221. package/dist/Modals/ModalDialog.cjs.map +1 -0
  222. package/dist/Modals/ModalDialog.d.ts +1 -0
  223. package/dist/Modals/ModalDialog.js +16 -2
  224. package/dist/Modals/ModalDialog.js.map +1 -1
  225. package/dist/Modals/ModalNote.cjs +93 -0
  226. package/dist/Modals/ModalNote.cjs.map +1 -0
  227. package/dist/Modals/ModalStyles.cjs +154 -0
  228. package/dist/Modals/ModalStyles.cjs.map +1 -0
  229. package/dist/Modals/ModalStyles.js +1 -1
  230. package/dist/Modals/ModalStyles.js.map +1 -1
  231. package/dist/Modals/ModalTypes.cjs +6 -0
  232. package/dist/Modals/ModalTypes.cjs.map +1 -0
  233. package/dist/Modals/index.cjs +70 -0
  234. package/dist/Modals/index.cjs.map +1 -0
  235. package/dist/Modals/index.d.ts +1 -0
  236. package/dist/Modals/index.js.map +1 -1
  237. package/dist/NavItem/NavItem.cjs +26 -0
  238. package/dist/NavItem/NavItem.cjs.map +1 -0
  239. package/dist/NavItem/index.cjs +16 -0
  240. package/dist/NavItem/index.cjs.map +1 -0
  241. package/dist/NotificationDot/NotificationDot.cjs +74 -0
  242. package/dist/NotificationDot/NotificationDot.cjs.map +1 -0
  243. package/dist/NotificationDot/index.cjs +16 -0
  244. package/dist/NotificationDot/index.cjs.map +1 -0
  245. package/dist/Paginator/Paginator.cjs +191 -0
  246. package/dist/Paginator/Paginator.cjs.map +1 -0
  247. package/dist/Paginator/index.cjs +16 -0
  248. package/dist/Paginator/index.cjs.map +1 -0
  249. package/dist/QuizButton/QuizButton.cjs +150 -0
  250. package/dist/QuizButton/QuizButton.cjs.map +1 -0
  251. package/dist/QuizButton/QuizButton.js +6 -6
  252. package/dist/QuizButton/QuizButton.js.map +1 -1
  253. package/dist/QuizButton/index.cjs +16 -0
  254. package/dist/QuizButton/index.cjs.map +1 -0
  255. package/dist/Services/functions.cjs +19 -0
  256. package/dist/Services/functions.cjs.map +1 -0
  257. package/dist/SkipToContent/SkipToContent.cjs +46 -0
  258. package/dist/SkipToContent/SkipToContent.cjs.map +1 -0
  259. package/dist/SkipToContent/index.cjs +16 -0
  260. package/dist/SkipToContent/index.cjs.map +1 -0
  261. package/dist/Switcher/MobileSwitcherMenu.cjs +120 -0
  262. package/dist/Switcher/MobileSwitcherMenu.cjs.map +1 -0
  263. package/dist/Switcher/SwitcherMenuItem.cjs +62 -0
  264. package/dist/Switcher/SwitcherMenuItem.cjs.map +1 -0
  265. package/dist/Switcher/index.cjs +24 -0
  266. package/dist/Switcher/index.cjs.map +1 -0
  267. package/dist/Table/Table.cjs +463 -0
  268. package/dist/Table/Table.cjs.map +1 -0
  269. package/dist/Table/TableBody.cjs +186 -0
  270. package/dist/Table/TableBody.cjs.map +1 -0
  271. package/dist/Table/TableFooter.cjs +119 -0
  272. package/dist/Table/TableFooter.cjs.map +1 -0
  273. package/dist/Table/TableHeaders.cjs +100 -0
  274. package/dist/Table/TableHeaders.cjs.map +1 -0
  275. package/dist/Table/TableStyles.cjs +104 -0
  276. package/dist/Table/TableStyles.cjs.map +1 -0
  277. package/dist/Table/TableTypes.cjs +6 -0
  278. package/dist/Table/TableTypes.cjs.map +1 -0
  279. package/dist/Table/index.cjs +16 -0
  280. package/dist/Table/index.cjs.map +1 -0
  281. package/dist/Table/index.d.ts +1 -0
  282. package/dist/Table/index.js.map +1 -1
  283. package/dist/Tabs/HorizontalTabs.cjs +98 -0
  284. package/dist/Tabs/HorizontalTabs.cjs.map +1 -0
  285. package/dist/Tabs/HorizontalTabs.d.ts +1 -1
  286. package/dist/Tabs/HorizontalTabs.js.map +1 -1
  287. package/dist/Tabs/TabLink.cjs +128 -0
  288. package/dist/Tabs/TabLink.cjs.map +1 -0
  289. package/dist/Tabs/Tabs.cjs +121 -0
  290. package/dist/Tabs/Tabs.cjs.map +1 -0
  291. package/dist/Tabs/VerticalTabs.cjs +68 -0
  292. package/dist/Tabs/VerticalTabs.cjs.map +1 -0
  293. package/dist/Tabs/index.cjs +24 -0
  294. package/dist/Tabs/index.cjs.map +1 -0
  295. package/dist/Tabs/index.d.ts +2 -0
  296. package/dist/Tabs/index.js.map +1 -1
  297. package/dist/Toasters/Toast.cjs +289 -0
  298. package/dist/Toasters/Toast.cjs.map +1 -0
  299. package/dist/Toasters/ToastContext.cjs +179 -0
  300. package/dist/Toasters/ToastContext.cjs.map +1 -0
  301. package/dist/Toasters/index.cjs +36 -0
  302. package/dist/Toasters/index.cjs.map +1 -0
  303. package/dist/Toggles/ToggleSwitch.cjs +73 -0
  304. package/dist/Toggles/ToggleSwitch.cjs.map +1 -0
  305. package/dist/Toggles/TogglerStyles.cjs +39 -0
  306. package/dist/Toggles/TogglerStyles.cjs.map +1 -0
  307. package/dist/Toggles/TogglerTypes.cjs +6 -0
  308. package/dist/Toggles/TogglerTypes.cjs.map +1 -0
  309. package/dist/Toggles/index.cjs +16 -0
  310. package/dist/Toggles/index.cjs.map +1 -0
  311. package/dist/Tooltips/TooltipStyles.cjs +96 -0
  312. package/dist/Tooltips/TooltipStyles.cjs.map +1 -0
  313. package/dist/Tooltips/TooltipTypes.cjs +11 -0
  314. package/dist/Tooltips/TooltipTypes.cjs.map +1 -0
  315. package/dist/Tooltips/TooltipWrapper.cjs +51 -0
  316. package/dist/Tooltips/TooltipWrapper.cjs.map +1 -0
  317. package/dist/Tooltips/index.cjs +36 -0
  318. package/dist/Tooltips/index.cjs.map +1 -0
  319. package/dist/Tooltips/index.d.ts +2 -2
  320. package/dist/Tooltips/index.js +2 -2
  321. package/dist/Tooltips/index.js.map +1 -1
  322. package/dist/assets/index.cjs +173 -0
  323. package/dist/assets/index.cjs.map +1 -0
  324. package/dist/common/EventHandlers.cjs +20 -0
  325. package/dist/common/EventHandlers.cjs.map +1 -0
  326. package/dist/common/FocusVisible.cjs +77 -0
  327. package/dist/common/FocusVisible.cjs.map +1 -0
  328. package/dist/common/InputStyling.cjs +20 -0
  329. package/dist/common/InputStyling.cjs.map +1 -0
  330. package/dist/common/index.cjs +30 -0
  331. package/dist/common/index.cjs.map +1 -0
  332. package/dist/common/index.d.ts +1 -0
  333. package/dist/common/index.js +1 -0
  334. package/dist/common/index.js.map +1 -1
  335. package/dist/hooks/useClickOutside.cjs +35 -0
  336. package/dist/hooks/useClickOutside.cjs.map +1 -0
  337. package/dist/icons/contenticons/ContentIcons.cjs +4530 -0
  338. package/dist/icons/contenticons/ContentIcons.cjs.map +1 -0
  339. package/dist/icons/index.cjs +147 -0
  340. package/dist/icons/index.cjs.map +1 -0
  341. package/dist/icons/systemicons/SystemIcons.cjs +4134 -0
  342. package/dist/icons/systemicons/SystemIcons.cjs.map +1 -0
  343. package/dist/index.cjs +422 -0
  344. package/dist/index.cjs.map +1 -0
  345. package/dist/index.d.ts +1 -0
  346. package/dist/index.js +1 -0
  347. package/dist/index.js.map +1 -1
  348. package/dist/styles/breakpoints.cjs +16 -0
  349. package/dist/styles/breakpoints.cjs.map +1 -0
  350. package/dist/styles/colors.cjs +108 -0
  351. package/dist/styles/colors.cjs.map +1 -0
  352. package/dist/styles/global.cjs +15 -0
  353. package/dist/styles/global.cjs.map +1 -0
  354. package/dist/styles/index.cjs +288 -0
  355. package/dist/styles/index.cjs.map +1 -0
  356. package/dist/styles/index.d.ts +1 -0
  357. package/dist/styles/index.js +1 -0
  358. package/dist/styles/index.js.map +1 -1
  359. package/dist/styles/shadowstyles.cjs +14 -0
  360. package/dist/styles/shadowstyles.cjs.map +1 -0
  361. package/dist/styles/typography.cjs +640 -0
  362. package/dist/styles/typography.cjs.map +1 -0
  363. package/dist/styles/z-indexes.cjs +22 -0
  364. package/dist/styles/z-indexes.cjs.map +1 -0
  365. package/dist/types.cjs +59 -0
  366. package/dist/types.cjs.map +1 -0
  367. package/package.json +13 -5
@@ -0,0 +1,566 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = exports.DDContainer = void 0;
9
+
10
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
11
+
12
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
+
14
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
+
16
+ var _propTypes = _interopRequireDefault(require("prop-types"));
17
+
18
+ var _react = _interopRequireDefault(require("react"));
19
+
20
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
21
+
22
+ var _Button = _interopRequireDefault(require("../Button/Button"));
23
+
24
+ var _types = require("../types");
25
+
26
+ var _CommonStyling = require("./CommonStyling");
27
+
28
+ var _typography = require("../styles/typography");
29
+
30
+ var _styles = require("../styles");
31
+
32
+ var _InputFields = require("../InputFields");
33
+
34
+ var _zIndexes = require("../styles/z-indexes");
35
+
36
+ var _MenuItem = _interopRequireDefault(require("../MenuItem/MenuItem"));
37
+
38
+ var _jsxRuntime = require("react/jsx-runtime");
39
+
40
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
41
+
42
+ var DDContainer = _styledComponents.default.div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n display: none;\n position: absolute;\n background-color: ", ";\n\n width: ", ";\n z-index: ", ";\n margin: ", ";\n\n &.show {\n display: flex;\n flex-direction: column;\n justify-content: center;\n }\n\n &.up {\n top: auto;\n bottom: 100%;\n }\n\n ", "\n\n ", ";\n\n border: 1px solid ", ";\n box-sizing: border-box;\n box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.15);\n padding-top: 4px;\n padding-right: 0px;\n padding-bottom: 4px;\n padding-left: 0px;\n\n min-width: ", ";\n border-radius: ", ";\n\n max-height: ", ";\n"])), _styles.COLORS.white, function (props) {
43
+ return props.width ? props.width : '100%';
44
+ }, _zIndexes.Z_INDEXES.dropdown, function (props) {
45
+ return props.isButton ? '-4px' : '4px 0px';
46
+ }, function (props) {
47
+ return props.alignLeft ? 'left: 0px;' : '';
48
+ }, function (props) {
49
+ return props.isButton ? _CommonStyling.ButtonDropdownContentStyling : '';
50
+ }, _styles.COLORS.neutral_100, function (props) {
51
+ return props.size == _types.Size.Large ? '320px' : props.size == _types.Size.Medium ? '280px' : '240px';
52
+ }, function (props) {
53
+ return props.size == _types.Size.Large ? '10px' : props.size == _types.Size.Medium ? '8px' : '6px';
54
+ }, function (props) {
55
+ return !props.scrollable ? 'auto' : props.maxHeight ? props.maxHeight : props.size == _types.Size.Large ? '320px' : props.size == _types.Size.Medium ? '280px' : '240px';
56
+ });
57
+
58
+ exports.DDContainer = DDContainer;
59
+
60
+ var ItemsContainer = _styledComponents.default.div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2.default)(["\n > *:hover {\n z-index: ", ";\n }\n > *:active,\n > *.active{\n z-index: ", ";\n }\n > *:focus {\n z-index: ", ";\n }\n"])), _zIndexes.Z_INDEXES.hover, _zIndexes.Z_INDEXES.active, _zIndexes.Z_INDEXES.focus);
61
+
62
+ var ListContainer = _styledComponents.default.div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2.default)(["\n ", "\n ", "\n\n\n div.divider {\n display: block;\n width: calc(100% - 40px);\n margin-left: 16px;\n border-top: 1px solid #e5e5e5;\n position: absolute;\n top: 0px;\n }\n\n ", " {\n padding-top: ", ";\n padding-bottom: ", ";\n }\n\n /* width */\n ::-webkit-scrollbar {\n width: 4px;\n margin: 0 6px;\n cursor: pointer;\n }\n\n /* Track */\n ::-webkit-scrollbar-track {\n background: ", ";\n border-radius: 8px;\n }\n\n /* Handle */\n ::-webkit-scrollbar-thumb {\n background: ", ";\n border-radius: 8px;\n }\n\n /* Handle on hover */\n ::-webkit-scrollbar-thumb:hover {\n background: ", ";\n }\n"])), function (props) {
63
+ return props.scrollable ? 'overflow-y: scroll;' : '';
64
+ }, function (props) {
65
+ return props.itemsType != 'normal' ? 'margin-left: 4px;' : '';
66
+ }, ItemsContainer, function (props) {
67
+ return props.size == _types.Size.Large ? '8px' : props.size == _types.Size.Medium ? '4px' : '0px';
68
+ }, function (props) {
69
+ return props.size == _types.Size.Large ? '8px' : props.size == _types.Size.Medium ? '4px' : '0px';
70
+ }, _styles.COLORS.neutral_100, _styles.COLORS.neutral_600, _styles.COLORS.neutral_500);
71
+
72
+ var MenuContentContainer = _styledComponents.default.div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2.default)(["\n h1, h2, h3 {\n margin-block-start: 0px;\n margin-block-end: 0px;\n ", "\n ", "\n ", "\n padding: ", ";\n }\n\n p {\n margin-block-start: 0px;\n margin-block-end: 0px;\n ", "\n ", "\n ", "\n padding: ", ";\n }\n"])), function (props) {
73
+ return props.size == _types.Size.Large && (0, _typography.ComponentXLStyling)(_typography.ComponentTextStyle.Bold, _styles.COLORS.neutral_500);
74
+ }, function (props) {
75
+ return props.size == _types.Size.Medium && (0, _typography.ComponentLStyling)(_typography.ComponentTextStyle.Bold, _styles.COLORS.neutral_500);
76
+ }, function (props) {
77
+ return (props.size == _types.Size.Small || !props.size) && (0, _typography.ComponentMStyling)(_typography.ComponentTextStyle.Bold, _styles.COLORS.neutral_500);
78
+ }, function (props) {
79
+ return props.size == _types.Size.Small || !props.size ? '10px 16px 6px' : props.size == _types.Size.Medium ? '16px 24px 8px' : '16px 32px 8px';
80
+ }, function (props) {
81
+ return props.size == _types.Size.Large && (0, _typography.ComponentLStyling)(_typography.ComponentTextStyle.Regular, _styles.COLORS.neutral_500);
82
+ }, function (props) {
83
+ return props.size == _types.Size.Medium && (0, _typography.ComponentMStyling)(_typography.ComponentTextStyle.Regular, _styles.COLORS.neutral_500);
84
+ }, function (props) {
85
+ return (props.size == _types.Size.Small || !props.size) && (0, _typography.ComponentSStyling)(_typography.ComponentTextStyle.Regular, _styles.COLORS.neutral_500);
86
+ }, function (props) {
87
+ return props.size == _types.Size.Small || !props.size ? '8px 16px' : props.size == _types.Size.Medium ? '12px 24px' : '16px 32px';
88
+ });
89
+
90
+ var DividerContainer = _styledComponents.default.div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2.default)(["\n position: relative;\n\n margin-top: ", ";\n\n div.divider {\n width: 100%;\n margin: 0px;\n }\n"])), function (props) {
91
+ return props.size == _types.Size.Large ? '16px' : props.size == _types.Size.Medium ? '12px' : props.size == _types.Size.Small || !props.size ? '8px' : '6px';
92
+ });
93
+
94
+ var TopItemContainer = _styledComponents.default.div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2.default)(["\n border-bottom-style: solid;\n border-bottom-color: ", ";\n border-bottom-width: 1px;\n margin-right: 22px;\n"])), _styles.COLORS.neutral_200);
95
+
96
+ var ActionButtonContainer = _styledComponents.default.div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2.default)(["\n border-top-style: solid;\n border-top-color: ", ";\n border-top-width: 1px;\n \n padding: ", ";\n\n button {\n width: 100%;\n }\n"])), _styles.COLORS.neutral_200, function (props) {
97
+ return props.size == _types.Size.Small || !props.size ? '0px 16px' : '8px 16px';
98
+ });
99
+
100
+ var MAX_MENU_HEIGHT = 240;
101
+ var AVG_OPTION_HEIGHT = 48;
102
+
103
+ var DropdownContent = function DropdownContent(_ref) {
104
+ var _customizationProps$a;
105
+
106
+ var id = _ref.id,
107
+ customizationProps = _ref.customizationProps,
108
+ alignLeft = _ref.alignLeft,
109
+ isButton = _ref.isButton,
110
+ size = _ref.size,
111
+ isOpen = _ref.isOpen,
112
+ hideOnClickOutside = _ref.hideOnClickOutside,
113
+ width = _ref.width,
114
+ setIsOpen = _ref.setIsOpen,
115
+ filter = _ref.filter,
116
+ focused = _ref.focused,
117
+ setFocused = _ref.setFocused,
118
+ selectedValues = _ref.selectedValues,
119
+ setSelectedValues = _ref.setSelectedValues,
120
+ messageOnNoResults = _ref.messageOnNoResults;
121
+
122
+ var _React$useState = _react.default.useState(false),
123
+ _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
124
+ isUp = _React$useState2[0],
125
+ setIsUp = _React$useState2[1];
126
+
127
+ var dropdownContentRef = _react.default.useRef(null);
128
+
129
+ if (!customizationProps.itemsType) customizationProps.itemsType = 'normal';
130
+ if (!size) size = _types.Size.Small;
131
+
132
+ var itemsListRef = _react.default.useRef(null);
133
+
134
+ var determineDropUp = function determineDropUp() {
135
+ var options = customizationProps.items;
136
+ var node = dropdownContentRef.current;
137
+ if (!node) return;
138
+ var windowHeight = window.innerHeight;
139
+ var menuHeight = Math.min(MAX_MENU_HEIGHT, options.length * AVG_OPTION_HEIGHT);
140
+ var instOffsetWithMenu = node.getBoundingClientRect().top + menuHeight;
141
+ setIsUp(instOffsetWithMenu >= windowHeight);
142
+ };
143
+
144
+ var setNewFocusedElement = function setNewFocusedElement(index) {
145
+ var newFocusedElement = elRefs[index];
146
+
147
+ if (newFocusedElement) {
148
+ var _newFocusedElement$cu;
149
+
150
+ setFocused(index);
151
+ newFocusedElement === null || newFocusedElement === void 0 ? void 0 : (_newFocusedElement$cu = newFocusedElement.current) === null || _newFocusedElement$cu === void 0 ? void 0 : _newFocusedElement$cu.focus();
152
+ }
153
+ };
154
+
155
+ var getFilteredItems = function getFilteredItems() {
156
+ var filtrationString = (filter !== null && filter !== void 0 ? filter : '').toUpperCase();
157
+ return customizationProps.items.filter(function (x) {
158
+ var _x$value, _x$displayLabel;
159
+
160
+ return (x === null || x === void 0 ? void 0 : (_x$value = x.value) === null || _x$value === void 0 ? void 0 : _x$value.toUpperCase().includes(filtrationString)) || (x === null || x === void 0 ? void 0 : (_x$displayLabel = x.displayLabel) === null || _x$displayLabel === void 0 ? void 0 : _x$displayLabel.toUpperCase().includes(filtrationString));
161
+ });
162
+ };
163
+
164
+ var handleKeyDown = function handleKeyDown(e) {
165
+ if (isOpen) {
166
+ if (e.keyCode === 38) {
167
+ e.preventDefault();
168
+ var focusedNow = focused;
169
+
170
+ if (focusedNow !== undefined && focusedNow !== null && focusedNow > 0) {
171
+ var filtered = getFilteredItems();
172
+ if (focusedNow == 1 && haveTopItem()) focusedNow = 0;else {
173
+ for (var i = focusedNow - 1; i > 0; i--) {
174
+ var _filtered;
175
+
176
+ if (!((_filtered = filtered[i - 1]) !== null && _filtered !== void 0 && _filtered.disabled)) {
177
+ focusedNow = i;
178
+ break;
179
+ }
180
+ }
181
+ }
182
+ setNewFocusedElement(focusedNow);
183
+ }
184
+ } else if (e.keyCode === 40) {
185
+ e.preventDefault();
186
+ var focusedNow = focused;
187
+
188
+ if (focusedNow !== undefined && focusedNow !== null) {
189
+ var _filtered2 = getFilteredItems();
190
+
191
+ for (var _i = focusedNow + 1; _i <= _filtered2.length; _i++) {
192
+ var _filtered3;
193
+
194
+ if (!((_filtered3 = _filtered2[_i - 1]) !== null && _filtered3 !== void 0 && _filtered3.disabled)) {
195
+ focusedNow = _i;
196
+ break;
197
+ }
198
+ }
199
+ } else {
200
+ focusedNow = haveTopItem() ? 0 : 1;
201
+ }
202
+
203
+ setNewFocusedElement(focusedNow);
204
+ } else if (e.keyCode === 9) {
205
+ e.preventDefault();
206
+ var focusedNow = focused;
207
+
208
+ if (focusedNow !== undefined && focusedNow !== null) {
209
+ focusedNow++;
210
+ var newFocusedElement = document.getElementById("".concat(id, "_").concat(focusedNow));
211
+
212
+ if (!newFocusedElement) {
213
+ setNewFocusedElement(0);
214
+ } else {
215
+ setNewFocusedElement(focusedNow);
216
+ }
217
+ } else {
218
+ setFocused(null);
219
+ }
220
+ } else if (e.keyCode === 27) {
221
+ setIsOpen(false);
222
+ setFocused(null); //TODO: add onEscapehandler
223
+
224
+ /*
225
+ if (!list.includes(input)) {
226
+ setInput('');
227
+ setPlaceholderSearch(placeholder || '');
228
+ }
229
+ styledFieldRef.current?.focus(); */
230
+ }
231
+ }
232
+ };
233
+
234
+ var handleClickOutside = function handleClickOutside(e) {
235
+ if (hideOnClickOutside && dropdownContentRef !== null && dropdownContentRef !== void 0 && dropdownContentRef.current && !dropdownContentRef.current.contains(e.target) && !elRefs.some(function (x) {
236
+ var _x$current;
237
+
238
+ return x === null || x === void 0 ? void 0 : (_x$current = x.current) === null || _x$current === void 0 ? void 0 : _x$current.contains(e.target);
239
+ })) {
240
+ if (isOpen) {
241
+ setIsOpen(false);
242
+ setFocused(null);
243
+ }
244
+ }
245
+ };
246
+
247
+ _react.default.useEffect(function () {
248
+ document.addEventListener('keydown', handleKeyDown);
249
+ document.addEventListener('click', handleClickOutside);
250
+ return function () {
251
+ document.removeEventListener('keydown', handleKeyDown);
252
+ document.removeEventListener('click', handleClickOutside);
253
+ };
254
+ });
255
+
256
+ var scrollPosition = _react.default.useRef(0);
257
+
258
+ var handleScroll = function handleScroll() {
259
+ var _itemsListRef$current;
260
+
261
+ scrollPosition.current = (_itemsListRef$current = itemsListRef.current) === null || _itemsListRef$current === void 0 ? void 0 : _itemsListRef$current.scrollTop;
262
+ };
263
+
264
+ _react.default.useLayoutEffect(function () {
265
+ var _scrollPosition$curre;
266
+
267
+ if (itemsListRef.current) itemsListRef.current.scrollTop = (_scrollPosition$curre = scrollPosition.current) !== null && _scrollPosition$curre !== void 0 ? _scrollPosition$curre : 0;
268
+ }, [selectedValues]);
269
+
270
+ var getCorrectRef = function getCorrectRef(ref) {
271
+ switch (customizationProps.itemsType) {
272
+ case 'normal':
273
+ return ref || /*#__PURE__*/_react.default.createRef();
274
+
275
+ default:
276
+ return ref || /*#__PURE__*/_react.default.createRef();
277
+ }
278
+ };
279
+
280
+ var arrLength = getFilteredItems().length;
281
+
282
+ var _React$useState3 = _react.default.useState([]),
283
+ _React$useState4 = (0, _slicedToArray2.default)(_React$useState3, 2),
284
+ elRefs = _React$useState4[0],
285
+ setElRefs = _React$useState4[1];
286
+
287
+ _react.default.useEffect(function () {
288
+ setElRefs(function (elRefs) {
289
+ return Array(arrLength + 1).fill(null).map(function (_, i) {
290
+ return getCorrectRef(elRefs[i]);
291
+ });
292
+ });
293
+ }, [isOpen, arrLength, selectedValues]);
294
+
295
+ _react.default.useEffect(function () {
296
+ determineDropUp();
297
+ }, [isOpen]);
298
+
299
+ var haveTopItem = function haveTopItem() {
300
+ var _getSuggestions;
301
+
302
+ if (customizationProps.itemsType === 'radio' && selectedValues && (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) > 0) return true;else if (customizationProps.itemsType === 'checkbox' && (customizationProps.multiSelect || (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) > 0)) return true;else if (customizationProps.itemsType === 'normal' && ((_getSuggestions = getSuggestions()) === null || _getSuggestions === void 0 ? void 0 : _getSuggestions.length) > 0) return true;
303
+ return false;
304
+ };
305
+
306
+ var getSuggestions = function getSuggestions() {
307
+ return getFilteredItems().filter(function (x) {
308
+ return x.suggestion;
309
+ });
310
+ };
311
+
312
+ _react.default.useLayoutEffect(function () {
313
+ if (isOpen && (focused || focused === 0)) {
314
+ var _newFocusedElement$cu2;
315
+
316
+ var focusThis = focused == 0 && !haveTopItem() ? 1 : focused;
317
+ if (focusThis != focused) setFocused(focusThis);
318
+ var newFocusedElement = elRefs[focusThis];
319
+ newFocusedElement === null || newFocusedElement === void 0 ? void 0 : (_newFocusedElement$cu2 = newFocusedElement.current) === null || _newFocusedElement$cu2 === void 0 ? void 0 : _newFocusedElement$cu2.focus();
320
+ } else setFocused(null); //if the dropdown is closed, we don't to keep saved the focused item
321
+
322
+ }, [isOpen]);
323
+
324
+ var handleItemClick = function handleItemClick(selected, item) {
325
+ var newValue = [];
326
+
327
+ if (customizationProps.multiSelect) {
328
+ if (selected) newValue = [].concat((0, _toConsumableArray2.default)(selectedValues), [item.value]);else newValue = selectedValues.filter(function (x) {
329
+ return x != item.value;
330
+ });
331
+ } else newValue = selected ? [item.value] : [];
332
+
333
+ setSelectedValues(newValue);
334
+
335
+ if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValue)) {
336
+ setIsOpen(false);
337
+ }
338
+ };
339
+
340
+ var getTopItem = function getTopItem() {
341
+ var _customizationProps$i, _customizationProps$i2, _selectedFirst$displa, _selectedFirst$displa2;
342
+
343
+ if (!customizationProps.pinTopItem) return;
344
+ var visibleItems = getFilteredItems();
345
+ var allSelected = (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.filter(function (x) {
346
+ return visibleItems.some(function (y) {
347
+ return y.value == x;
348
+ });
349
+ }).length) == visibleItems.length;
350
+ var showTopItem = false;
351
+ var suggestions = getSuggestions();
352
+ var displayLabel = selectedValues[0] ? (_customizationProps$i = customizationProps.items) === null || _customizationProps$i === void 0 ? void 0 : (_customizationProps$i2 = _customizationProps$i.find(function (c) {
353
+ return c.value === selectedValues[0];
354
+ })) === null || _customizationProps$i2 === void 0 ? void 0 : _customizationProps$i2.displayLabel : undefined;
355
+ if (customizationProps.itemsType == 'radio' && selectedValues && (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) > 0) showTopItem = true;else if (customizationProps.itemsType == 'checkbox' && (customizationProps.multiSelect || (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) > 0)) showTopItem = true;else if (customizationProps.itemsType == 'normal' && suggestions.length > 0) showTopItem = true;
356
+ if (!showTopItem) return;
357
+ var selectedFirst = selectedValues.length > 0 ? visibleItems.find(function (x) {
358
+ return x.value == selectedValues[0];
359
+ }) : null;
360
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)(TopItemContainer, {
361
+ size: size,
362
+ children: [customizationProps.itemsType == 'radio' && /*#__PURE__*/(0, _jsxRuntime.jsx)(_InputFields.RadioButton, {
363
+ ref: elRefs[0],
364
+ iconPointerEventsTransparent: true,
365
+ select: function select() {},
366
+ label: (_selectedFirst$displa = selectedFirst === null || selectedFirst === void 0 ? void 0 : selectedFirst.displayLabel) !== null && _selectedFirst$displa !== void 0 ? _selectedFirst$displa : selectedFirst === null || selectedFirst === void 0 ? void 0 : selectedFirst.value,
367
+ size: size,
368
+ id: "".concat(id, "_topitem"),
369
+ selected: true
370
+ }), customizationProps.itemsType == 'checkbox' && /*#__PURE__*/(0, _jsxRuntime.jsx)(_InputFields.Checkbox, {
371
+ ref: elRefs[0],
372
+ select: function select(selected) {
373
+ if (!customizationProps.multiSelect) return;
374
+ var newValues = selected ? visibleItems.map(function (x) {
375
+ return x.value;
376
+ }) : [];
377
+ setSelectedValues(newValues);
378
+ if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValues)) setIsOpen(false);
379
+ },
380
+ iconPointerEventsTransparent: true,
381
+ semiSelected: customizationProps.multiSelect && !allSelected && (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) > 0,
382
+ size: size,
383
+ id: "".concat(id, "_checkbox_selectall"),
384
+ label: customizationProps.multiSelect ? 'Select all' : (_selectedFirst$displa2 = selectedFirst === null || selectedFirst === void 0 ? void 0 : selectedFirst.displayLabel) !== null && _selectedFirst$displa2 !== void 0 ? _selectedFirst$displa2 : selectedFirst === null || selectedFirst === void 0 ? void 0 : selectedFirst.value,
385
+ selected: !customizationProps.multiSelect || allSelected
386
+ }), customizationProps.itemsType == 'normal' && /*#__PURE__*/(0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, {
387
+ children: suggestions.map(function (x) {
388
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_MenuItem.default, {
389
+ item: x,
390
+ size: size,
391
+ active: false,
392
+ ref: elRefs[0],
393
+ id: "".concat(id, "_topitem"),
394
+ onClickHandler: function onClickHandler(e) {
395
+ customizationProps.onValueUpdate([x.value]);
396
+ setSelectedValues([x.value]);
397
+ setIsOpen(false);
398
+ setFocused(null);
399
+ }
400
+ }, "".concat(id, "_topitem_").concat(x.value));
401
+ })
402
+ })]
403
+ });
404
+ };
405
+
406
+ var getElements = function getElements() {
407
+ if (getFilteredItems().length === 0) {
408
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(ItemsContainer, {
409
+ size: size,
410
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("button", {
411
+ className: "dropdownButton",
412
+ disabled: true,
413
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
414
+ children: messageOnNoResults
415
+ })
416
+ })
417
+ });
418
+ }
419
+
420
+ var number = 0;
421
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(ItemsContainer, {
422
+ size: size,
423
+ children: getFilteredItems().filter(function (x) {
424
+ return x && (customizationProps.itemsType != 'normal' || !x.suggestion);
425
+ }).map(function (item) {
426
+ var _item$displayLabel, _item$displayLabel2;
427
+
428
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_react.default.Fragment, {
429
+ children: [item.customContent, !item.customContent && customizationProps.itemsType == 'radio' && /*#__PURE__*/(0, _jsxRuntime.jsx)(_InputFields.RadioButton, {
430
+ select: function select(selected) {
431
+ return handleItemClick(selected, item);
432
+ },
433
+ ref: elRefs[number + 1],
434
+ size: size,
435
+ iconPointerEventsTransparent: true,
436
+ disabled: item === null || item === void 0 ? void 0 : item.disabled,
437
+ id: "".concat(id, "_").concat(number + 1),
438
+ label: (_item$displayLabel = item.displayLabel) !== null && _item$displayLabel !== void 0 ? _item$displayLabel : item.value,
439
+ selected: selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.includes(item.value)
440
+ }, "key_".concat(id, "_").concat(number++)), !item.customContent && customizationProps.itemsType == 'checkbox' && /*#__PURE__*/(0, _jsxRuntime.jsx)(_InputFields.Checkbox, {
441
+ select: function select(selected) {
442
+ return handleItemClick(selected, item);
443
+ },
444
+ iconPointerEventsTransparent: true,
445
+ disabled: item === null || item === void 0 ? void 0 : item.disabled,
446
+ ref: elRefs[number + 1],
447
+ size: size,
448
+ id: "".concat(id, "_").concat(number + 1),
449
+ label: (_item$displayLabel2 = item.displayLabel) !== null && _item$displayLabel2 !== void 0 ? _item$displayLabel2 : item.value,
450
+ selected: selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.includes(item.value)
451
+ }, "key_".concat(id, "_").concat(number++)), !item.customContent && (customizationProps.itemsType == 'normal' || !customizationProps.itemsType) && /*#__PURE__*/(0, _jsxRuntime.jsx)(_MenuItem.default, {
452
+ id: "".concat(id, "_").concat(number + 1),
453
+ item: item,
454
+ size: size,
455
+ active: selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.includes(item.value),
456
+ ref: elRefs[number + 1],
457
+ onClickHandler: function onClickHandler(e) {
458
+ customizationProps.onValueUpdate([item.value]);
459
+ setSelectedValues([item.value]);
460
+ setIsOpen(false);
461
+ setFocused(null);
462
+ }
463
+ }, "key_".concat(id, "_").concat(number++))]
464
+ }, "key_".concat(id, "_").concat(item.value));
465
+ })
466
+ });
467
+ };
468
+
469
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)(DDContainer, {
470
+ ref: dropdownContentRef,
471
+ size: size,
472
+ width: width,
473
+ isButton: isButton,
474
+ alignLeft: alignLeft,
475
+ scrollable: customizationProps.scrollable,
476
+ maxHeight: customizationProps.maxHeight,
477
+ className: [isOpen && 'show', isUp && 'up'].filter(function (e) {
478
+ return !!e;
479
+ }).join(' '),
480
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)(ListContainer, {
481
+ size: size,
482
+ itemsType: customizationProps.itemsType,
483
+ onScroll: handleScroll,
484
+ ref: itemsListRef,
485
+ scrollable: customizationProps.scrollable,
486
+ children: [customizationProps.menuContent && /*#__PURE__*/(0, _jsxRuntime.jsxs)(MenuContentContainer, {
487
+ size: size,
488
+ children: [customizationProps.menuContent, /*#__PURE__*/(0, _jsxRuntime.jsx)(DividerContainer, {
489
+ size: size,
490
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
491
+ className: "divider"
492
+ })
493
+ })]
494
+ }), customizationProps.pinTopItem && getTopItem(), getElements()]
495
+ }), customizationProps.action && customizationProps.actionLabel && /*#__PURE__*/(0, _jsxRuntime.jsx)(ActionButtonContainer, {
496
+ size: size,
497
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_Button.default, {
498
+ width: "100%",
499
+ icon: customizationProps.actionIcon,
500
+ loading: customizationProps.actionLoading,
501
+ disabled: customizationProps.actionDisabled,
502
+ variant: (_customizationProps$a = customizationProps.actionVariant) !== null && _customizationProps$a !== void 0 ? _customizationProps$a : 'primary',
503
+ size: size,
504
+ onClick: function onClick() {
505
+ if (customizationProps.action()) //closing the dropdown if action returns 'true'
506
+ setIsOpen(false);
507
+ },
508
+ children: customizationProps.actionLabel
509
+ })
510
+ })]
511
+ });
512
+ /* ),
513
+ {
514
+ handleClickOutside: () => () => {
515
+ if (isOpen) {
516
+ setIsOpen(false);
517
+ setFocused(null);
518
+ }
519
+ },
520
+ },
521
+ );
522
+ return <Wrapped />; */
523
+ };
524
+
525
+ DropdownContent.propTypes = {
526
+ isButton: _propTypes.default.bool.isRequired,
527
+ customizationProps: _propTypes.default.shape({
528
+ itemsType: _propTypes.default.oneOf(['radio', 'checkbox', 'normal']),
529
+ menuContent: _propTypes.default.node,
530
+ scrollable: _propTypes.default.bool,
531
+ multiSelect: _propTypes.default.bool,
532
+ maxHeight: _propTypes.default.string,
533
+ actionLabel: _propTypes.default.string,
534
+ actionIcon: _propTypes.default.node,
535
+ actionLoading: _propTypes.default.bool,
536
+ actionDisabled: _propTypes.default.bool,
537
+ action: _propTypes.default.func.isRequired,
538
+ pinTopItem: _propTypes.default.bool,
539
+ onValueUpdate: _propTypes.default.func.isRequired,
540
+ items: _propTypes.default.arrayOf(_propTypes.default.shape({
541
+ value: _propTypes.default.string.isRequired,
542
+ displayLabel: _propTypes.default.string,
543
+ noteLabel: _propTypes.default.string,
544
+ suggestion: _propTypes.default.bool,
545
+ showDividerAbove: _propTypes.default.bool,
546
+ disabled: _propTypes.default.bool,
547
+ icon: _propTypes.default.node,
548
+ customContent: _propTypes.default.node
549
+ })).isRequired
550
+ }).isRequired,
551
+ alignLeft: _propTypes.default.bool,
552
+ isOpen: _propTypes.default.bool.isRequired,
553
+ setIsOpen: _propTypes.default.func.isRequired,
554
+ id: _propTypes.default.string.isRequired,
555
+ filter: _propTypes.default.string.isRequired,
556
+ width: _propTypes.default.string,
557
+ hideOnClickOutside: _propTypes.default.bool.isRequired,
558
+ selectedValues: _propTypes.default.arrayOf(_propTypes.default.string).isRequired,
559
+ setSelectedValues: _propTypes.default.func.isRequired,
560
+ messageOnNoResults: _propTypes.default.string.isRequired,
561
+ focused: _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.oneOf([null])]),
562
+ setFocused: _propTypes.default.func.isRequired
563
+ };
564
+ var _default = DropdownContent;
565
+ exports.default = _default;
566
+ //# sourceMappingURL=DropdownContent.cjs.map