@laerdal/life-react-components 3.5.1-dev.11 → 3.5.1-dev.13

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 (872) hide show
  1. package/dist/Accordion/AccordionMenu.d.ts +15 -0
  2. package/dist/Accordion/ContentAccordion.d.ts +14 -0
  3. package/dist/AuthPage/AuthPage.d.ts +2 -2
  4. package/dist/Banners/Banner.d.ts +24 -3
  5. package/dist/Banners/OverviewBanner.d.ts +1 -1
  6. package/dist/Breadcrumb/Breadcrumb.d.ts +8 -1
  7. package/dist/Breadcrumb/BreadcrumbItem.d.ts +2 -0
  8. package/dist/Button/BackButton.d.ts +7 -0
  9. package/dist/Button/Button.d.ts +29 -10
  10. package/dist/Button/DualFunctionButton.d.ts +10 -0
  11. package/dist/Button/Iconbutton.d.ts +17 -11
  12. package/dist/Card/HorizontalCard/types.d.ts +13 -3
  13. package/dist/Card/VerticalCard/Card.d.ts +8 -1
  14. package/dist/Card/VerticalCard/CardBottomSection.d.ts +11 -0
  15. package/dist/Card/VerticalCard/CardMiddleSection.d.ts +8 -0
  16. package/dist/Card/VerticalCard/CardTopSection.d.ts +11 -0
  17. package/dist/Chips/ChipTypes.d.ts +35 -1
  18. package/dist/ChipsInput/ChipDropdownInput.d.ts +9 -1
  19. package/dist/ChipsInput/index.d.ts +1 -0
  20. package/dist/Dropdown/BasicDropdown.d.ts +76 -0
  21. package/dist/Dropdown/CommonStyling.d.ts +0 -1
  22. package/dist/Dropdown/DropdownButtonTypes.d.ts +28 -1
  23. package/dist/Dropdown/DropdownContent.d.ts +10 -1
  24. package/dist/Dropdown/DropdownFilter.d.ts +18 -1
  25. package/dist/Footer/Components/FooterBottomLinks.d.ts +2 -2
  26. package/dist/Footer/Components/FooterDropdownLinks.d.ts +2 -2
  27. package/dist/Footer/Components/FooterNavSection.d.ts +2 -2
  28. package/dist/Footer/Components/FooterNewsletterAndSocialSection.d.ts +2 -2
  29. package/dist/Footer/Components/FooterTop.d.ts +2 -2
  30. package/dist/Footer/Footer.d.ts +2 -2
  31. package/dist/Footer/SiteFooter.d.ts +1 -1
  32. package/dist/GlobalNavigationBar/__tests__/GlobalNavigationBar.tests.js +299 -0
  33. package/dist/GlobalNavigationBar/__tests__/Logo.tests.js +26 -0
  34. package/dist/GlobalNavigationBar/desktop/ExtendedMainMenu.d.ts +2 -2
  35. package/dist/GlobalNavigationBar/desktop/UserMenu.d.ts +2 -2
  36. package/dist/GlobalNavigationBar/mobile/MobileMenu.d.ts +2 -2
  37. package/dist/GlobalNavigationBar/types.d.ts +5 -1
  38. package/dist/HyperLink/HyperLink.d.ts +7 -0
  39. package/dist/Image/ImageWithFallbacks.d.ts +1 -1
  40. package/dist/InputFields/DatepickerField.d.ts +39 -1
  41. package/dist/InputFields/DatepickerFieldHeader.d.ts +5 -2
  42. package/dist/InputFields/NumberField.d.ts +46 -17
  43. package/dist/InputFields/PasswordField.d.ts +73 -1
  44. package/dist/InputFields/QuickSearch.d.ts +12 -0
  45. package/dist/InputFields/RadioButton.d.ts +26 -2
  46. package/dist/InputFields/RichTextField.d.ts +57 -0
  47. package/dist/InputFields/SearchBar.d.ts +64 -0
  48. package/dist/InputFields/TextField.d.ts +113 -1
  49. package/dist/InputFields/types.d.ts +39 -1
  50. package/dist/LinearProgress/LinearProgress.d.ts +6 -0
  51. package/dist/List/ListRow.d.ts +17 -4
  52. package/dist/List/__tests__/ListRow.tests.js +51 -0
  53. package/dist/LoadingIndicator/LoadingIndicator.d.ts +6 -3
  54. package/dist/LoadingPage/GlobalLoadingPage.d.ts +1 -1
  55. package/dist/MenuItem/MenuItem.d.ts +7 -1
  56. package/dist/MiniProductCard/MiniProductCard.d.ts +2 -2
  57. package/dist/Modals/Modal.d.ts +4 -4
  58. package/dist/Modals/ModalContainer.d.ts +1 -1
  59. package/dist/Modals/ModalContent.d.ts +1 -1
  60. package/dist/Modals/ModalDialog.d.ts +14 -4
  61. package/dist/NavItem/NavItem.d.ts +1 -1
  62. package/dist/NavItem/NestedNavItem.d.ts +20 -2
  63. package/dist/NotificationDot/NotificationDot.d.ts +10 -0
  64. package/dist/Paginator/Paginator.d.ts +18 -4
  65. package/dist/Panel/Panel.d.ts +24 -6
  66. package/dist/Popover/Popover.d.ts +80 -12
  67. package/dist/ProfileButton/ProfileButton.d.ts +31 -3
  68. package/dist/QuizButton/QuizButton.d.ts +25 -1
  69. package/dist/SegmentControl/SegmentControl.d.ts +25 -2
  70. package/dist/SegmentControl/index.d.ts +2 -2
  71. package/dist/SideMenu/SideMenuBody.d.ts +2 -2
  72. package/dist/SideMenu/SideMenuFooter.d.ts +2 -2
  73. package/dist/SideMenu/SideMenuHeader.d.ts +2 -2
  74. package/dist/Switcher/MobileSwitcherMenu.d.ts +1 -1
  75. package/dist/Switcher/SwitcherMenuItem.d.ts +2 -2
  76. package/dist/Switcher/__tests__/SwitcherMenuItem.js +53 -0
  77. package/dist/Table/TableTypes.d.ts +130 -0
  78. package/dist/Tabs/HorizontalTabs.d.ts +14 -3
  79. package/dist/Tabs/TabLink.d.ts +1 -1
  80. package/dist/Tabs/VerticalTabs.d.ts +30 -2
  81. package/dist/Tabs/__tests__/TabLink.tests.js +83 -0
  82. package/dist/Tabs/__tests__/Tablist.tests.js +78 -0
  83. package/dist/Tabs/index.d.ts +1 -1
  84. package/dist/Tag/Tag.d.ts +3 -0
  85. package/dist/Tile/TileCommonItems.d.ts +2 -2
  86. package/dist/Toasters/Toast.d.ts +9 -1
  87. package/dist/Toggles/ToggleButton.d.ts +5 -0
  88. package/dist/Toggles/TogglerTypes.d.ts +7 -0
  89. package/dist/Tooltips/TooltipOverflow.d.ts +1 -1
  90. package/dist/Tooltips/TooltipStyles.d.ts +2 -1
  91. package/dist/Tooltips/TooltipTypes.d.ts +10 -0
  92. package/dist/Tooltips/TooltipWrapper.d.ts +2 -2
  93. package/dist/index.d.ts +1 -1
  94. package/dist/src/Accordion/AccordionItem.js +47 -0
  95. package/dist/src/Accordion/AccordionMenu.js +66 -0
  96. package/dist/src/Accordion/ContentAccordion.js +107 -0
  97. package/dist/src/Accordion/index.js +7 -0
  98. package/dist/src/Accordion/styles.js +12 -0
  99. package/dist/src/AuthPage/AuthPage.d.ts +1 -1
  100. package/dist/src/AuthPage/AuthPage.js +29 -0
  101. package/dist/src/AuthPage/ScreenSetsContainer.js +9 -0
  102. package/dist/src/AuthPage/index.js +4 -0
  103. package/dist/src/Banners/Banner.d.ts +2 -2
  104. package/dist/src/Banners/Banner.js +112 -0
  105. package/dist/src/Banners/OverviewBanner.d.ts +1 -1
  106. package/dist/src/Banners/OverviewBanner.js +39 -0
  107. package/dist/src/Banners/index.js +4 -0
  108. package/dist/src/Banners/styles.js +55 -0
  109. package/dist/src/Breadcrumb/Breadcrumb.d.ts +1 -1
  110. package/dist/src/Breadcrumb/Breadcrumb.js +67 -0
  111. package/dist/src/Breadcrumb/BreadcrumbItem.js +1 -0
  112. package/dist/src/Breadcrumb/index.js +4 -0
  113. package/dist/src/Breadcrumb/styles.js +24 -0
  114. package/dist/src/Button/BackButton.js +45 -0
  115. package/dist/src/Button/Button.js +87 -0
  116. package/dist/src/Button/DualFunctionButton.js +71 -0
  117. package/dist/src/Button/Iconbutton.js +70 -0
  118. package/dist/src/Button/index.js +8 -0
  119. package/dist/src/Card/HorizontalCard/HorizontalCard.js +55 -0
  120. package/dist/src/Card/HorizontalCard/HorizontalCardActions.d.ts +1 -1
  121. package/dist/src/Card/HorizontalCard/HorizontalCardActions.js +39 -0
  122. package/dist/src/Card/HorizontalCard/HorizontalCardBody.d.ts +1 -1
  123. package/dist/src/Card/HorizontalCard/HorizontalCardBody.js +23 -0
  124. package/dist/src/Card/HorizontalCard/HorizontalCardThumbnail.d.ts +1 -1
  125. package/dist/src/Card/HorizontalCard/HorizontalCardThumbnail.js +21 -0
  126. package/dist/src/Card/HorizontalCard/index.js +4 -0
  127. package/dist/src/Card/HorizontalCard/types.d.ts +5 -5
  128. package/dist/src/Card/HorizontalCard/types.js +1 -0
  129. package/dist/src/Card/VerticalCard/Card.js +61 -0
  130. package/dist/src/Card/VerticalCard/CardBottomSection.js +45 -0
  131. package/dist/src/Card/VerticalCard/CardMiddleSection.js +32 -0
  132. package/dist/src/Card/VerticalCard/CardTopSection.js +33 -0
  133. package/dist/src/Card/VerticalCard/index.js +7 -0
  134. package/dist/src/Card/index.js +2 -0
  135. package/dist/src/Chips/ActionChip.js +45 -0
  136. package/dist/src/Chips/ChipStyles.js +16 -0
  137. package/dist/src/Chips/ChipTypes.d.ts +1 -1
  138. package/dist/src/Chips/ChipTypes.js +1 -0
  139. package/dist/src/Chips/ChoiceChips.js +70 -0
  140. package/dist/src/Chips/FilterChip.js +49 -0
  141. package/dist/src/Chips/InputChip.js +71 -0
  142. package/dist/src/Chips/index.js +6 -0
  143. package/dist/src/ChipsInput/ChipDropdownInput.js +230 -0
  144. package/dist/src/ChipsInput/ChipInput.js +99 -0
  145. package/dist/src/ChipsInput/ChipInputField.js +114 -0
  146. package/dist/src/ChipsInput/ChipInputTypes.js +1 -0
  147. package/dist/src/ChipsInput/index.js +2 -0
  148. package/dist/src/Dropdown/BasicDropdown.d.ts +3 -3
  149. package/dist/src/Dropdown/BasicDropdown.js +153 -0
  150. package/dist/src/Dropdown/CommonStyling.js +24 -0
  151. package/dist/src/Dropdown/DropdownButton.js +107 -0
  152. package/dist/src/Dropdown/DropdownButtonTypes.d.ts +3 -3
  153. package/dist/src/Dropdown/DropdownButtonTypes.js +1 -0
  154. package/dist/src/Dropdown/DropdownContent.js +339 -0
  155. package/dist/src/Dropdown/DropdownFilter.js +161 -0
  156. package/dist/src/Dropdown/index.js +8 -0
  157. package/dist/src/Footer/Components/FooterBottomLinks.js +20 -0
  158. package/dist/src/Footer/Components/FooterDropdownLinks.js +25 -0
  159. package/dist/src/Footer/Components/FooterNavSection.js +32 -0
  160. package/dist/src/Footer/Components/FooterNewsletterAndSocialSection.js +42 -0
  161. package/dist/src/Footer/Components/FooterTop.js +34 -0
  162. package/dist/src/Footer/Footer.js +17 -0
  163. package/dist/src/Footer/SiteFooter.js +57 -0
  164. package/dist/src/Footer/index.js +2 -0
  165. package/dist/src/GlobalNavigationBar/GlobalNavigationBar.d.ts +1 -1
  166. package/dist/src/GlobalNavigationBar/GlobalNavigationBar.js +93 -0
  167. package/dist/src/GlobalNavigationBar/Logo.d.ts +1 -1
  168. package/dist/src/GlobalNavigationBar/Logo.js +33 -0
  169. package/dist/src/GlobalNavigationBar/__tests__/GlobalNavigationBar.tests.js +299 -0
  170. package/dist/src/GlobalNavigationBar/__tests__/Logo.tests.js +26 -0
  171. package/dist/src/GlobalNavigationBar/desktop/DesktopActions.js +88 -0
  172. package/dist/src/GlobalNavigationBar/desktop/ExtendedMainMenu.d.ts +1 -1
  173. package/dist/src/GlobalNavigationBar/desktop/ExtendedMainMenu.js +42 -0
  174. package/dist/src/GlobalNavigationBar/desktop/MainMenu.d.ts +1 -1
  175. package/dist/src/GlobalNavigationBar/desktop/MainMenu.js +175 -0
  176. package/dist/src/GlobalNavigationBar/desktop/RightSideNav.d.ts +1 -1
  177. package/dist/src/GlobalNavigationBar/desktop/RightSideNav.js +46 -0
  178. package/dist/src/GlobalNavigationBar/desktop/SubMenu.d.ts +1 -1
  179. package/dist/src/GlobalNavigationBar/desktop/SubMenu.js +131 -0
  180. package/dist/src/GlobalNavigationBar/desktop/UserMenu.js +90 -0
  181. package/dist/src/GlobalNavigationBar/index.js +3 -0
  182. package/dist/src/GlobalNavigationBar/mobile/CommonStyles.js +28 -0
  183. package/dist/src/GlobalNavigationBar/mobile/MobileActionContainer.js +18 -0
  184. package/dist/src/GlobalNavigationBar/mobile/MobileMenu.d.ts +1 -1
  185. package/dist/src/GlobalNavigationBar/mobile/MobileMenu.js +94 -0
  186. package/dist/src/GlobalNavigationBar/mobile/MobileMenuContent.js +89 -0
  187. package/dist/src/GlobalNavigationBar/mobile/MobileMenuHeader.js +108 -0
  188. package/dist/src/GlobalNavigationBar/types.d.ts +8 -8
  189. package/dist/src/GlobalNavigationBar/types.js +1 -0
  190. package/dist/src/GlobalNavigationBar/utils.js +7 -0
  191. package/dist/src/HyperLink/HyperLink.js +36 -0
  192. package/dist/src/HyperLink/index.js +3 -0
  193. package/dist/src/HyperLink/styling.js +9 -0
  194. package/dist/src/Image/ImageWithFallbacks.d.ts +1 -1
  195. package/dist/src/Image/ImageWithFallbacks.js +87 -0
  196. package/dist/src/Image/index.js +2 -0
  197. package/dist/src/InputFields/Checkbox.js +65 -0
  198. package/dist/src/InputFields/DatepickerField.d.ts +1 -1
  199. package/dist/src/InputFields/DatepickerField.js +237 -0
  200. package/dist/src/InputFields/DatepickerFieldHeader.js +45 -0
  201. package/dist/src/InputFields/Label.d.ts +1 -1
  202. package/dist/src/InputFields/Label.js +83 -0
  203. package/dist/src/InputFields/NumberField.js +194 -0
  204. package/dist/src/InputFields/PasswordField.d.ts +1 -1
  205. package/dist/src/InputFields/PasswordField.js +60 -0
  206. package/dist/src/InputFields/QuickSearch.d.ts +1 -1
  207. package/dist/src/InputFields/QuickSearch.js +92 -0
  208. package/dist/src/InputFields/RadioButton.d.ts +1 -1
  209. package/dist/src/InputFields/RadioButton.js +54 -0
  210. package/dist/src/InputFields/ResponsiveComponentWrapper.d.ts +1 -1
  211. package/dist/src/InputFields/ResponsiveComponentWrapper.js +24 -0
  212. package/dist/src/InputFields/RichTextField.js +83 -0
  213. package/dist/src/InputFields/SearchBar.d.ts +1 -1
  214. package/dist/src/InputFields/SearchBar.js +63 -0
  215. package/dist/src/InputFields/TextField.d.ts +1 -1
  216. package/dist/src/InputFields/TextField.js +51 -0
  217. package/dist/src/InputFields/Textarea.js +65 -0
  218. package/dist/src/InputFields/components/SearchBarInput.d.ts +1 -1
  219. package/dist/src/InputFields/components/SearchBarInput.js +26 -0
  220. package/dist/src/InputFields/components/SearchField.js +44 -0
  221. package/dist/src/InputFields/index.js +13 -0
  222. package/dist/src/InputFields/styling.js +33 -0
  223. package/dist/src/InputFields/types.d.ts +2 -2
  224. package/dist/src/InputFields/types.js +2 -0
  225. package/dist/src/Layouts/index.js +25 -0
  226. package/dist/src/LinearProgress/LinearProgress.js +78 -0
  227. package/dist/src/LinearProgress/index.js +3 -0
  228. package/dist/src/List/ListRow.js +83 -0
  229. package/dist/src/List/__tests__/ListRow.tests.js +51 -0
  230. package/dist/src/List/index.js +2 -0
  231. package/dist/src/LoadingIndicator/LoadingIndicator.d.ts +1 -1
  232. package/dist/src/LoadingIndicator/LoadingIndicator.js +26 -0
  233. package/dist/src/LoadingIndicator/index.js +1 -0
  234. package/dist/src/LoadingPage/GlobalLoadingPage.js +26 -0
  235. package/dist/src/LoadingPage/index.js +1 -0
  236. package/dist/src/MenuItem/MenuItem.d.ts +1 -1
  237. package/dist/src/MenuItem/MenuItem.js +60 -0
  238. package/dist/src/MenuItem/index.js +1 -0
  239. package/dist/src/MiniProductCard/MiniProductCard.d.ts +1 -1
  240. package/dist/src/MiniProductCard/MiniProductCard.js +30 -0
  241. package/dist/src/MiniProductCard/index.js +1 -0
  242. package/dist/src/Modals/Modal.d.ts +1 -1
  243. package/dist/src/Modals/Modal.js +38 -0
  244. package/dist/src/Modals/ModalContainer.d.ts +2 -2
  245. package/dist/src/Modals/ModalContainer.js +130 -0
  246. package/dist/src/Modals/ModalContent.js +159 -0
  247. package/dist/src/Modals/ModalDialog.js +166 -0
  248. package/dist/src/Modals/ModalNote.js +27 -0
  249. package/dist/src/Modals/ModalStyles.js +55 -0
  250. package/dist/src/Modals/ModalTypes.d.ts +2 -2
  251. package/dist/src/Modals/ModalTypes.js +1 -0
  252. package/dist/src/Modals/index.js +6 -0
  253. package/dist/src/NavItem/NavItem.d.ts +1 -1
  254. package/dist/src/NavItem/NavItem.js +26 -0
  255. package/dist/src/NavItem/NestedNavItem.js +18 -0
  256. package/dist/src/NavItem/index.js +1 -0
  257. package/dist/src/NotificationDot/NotificationDot.js +17 -0
  258. package/dist/src/NotificationDot/index.js +1 -0
  259. package/dist/src/Paginator/Paginator.js +77 -0
  260. package/dist/src/Paginator/index.js +2 -0
  261. package/dist/src/Panel/Panel.d.ts +1 -1
  262. package/dist/src/Panel/Panel.js +82 -0
  263. package/dist/src/Panel/index.js +1 -0
  264. package/dist/src/Popover/Popover.js +101 -0
  265. package/dist/src/Popover/index.js +1 -0
  266. package/dist/src/ProfileButton/ProfileButton.d.ts +2 -2
  267. package/dist/src/ProfileButton/ProfileButton.js +52 -0
  268. package/dist/src/ProfileButton/index.js +1 -0
  269. package/dist/src/QuizButton/QuizButton.d.ts +1 -1
  270. package/dist/src/QuizButton/QuizButton.js +53 -0
  271. package/dist/src/QuizButton/index.js +1 -0
  272. package/dist/src/SegmentControl/SegmentControl.js +57 -0
  273. package/dist/src/SegmentControl/index.js +2 -0
  274. package/dist/src/Services/functions.js +11 -0
  275. package/dist/src/SideMenu/SideMenu.js +43 -0
  276. package/dist/src/SideMenu/SideMenuBody.js +24 -0
  277. package/dist/src/SideMenu/SideMenuFooter.js +43 -0
  278. package/dist/src/SideMenu/SideMenuHeader.js +46 -0
  279. package/dist/src/SideMenu/index.js +2 -0
  280. package/dist/src/SideMenu/types.d.ts +3 -3
  281. package/dist/src/SideMenu/types.js +1 -0
  282. package/dist/src/SkipToContent/SkipToContent.d.ts +1 -1
  283. package/dist/src/SkipToContent/SkipToContent.js +17 -0
  284. package/dist/src/SkipToContent/index.js +1 -0
  285. package/dist/src/Switcher/MobileCustomMenuContent.js +26 -0
  286. package/dist/src/Switcher/MobileSwitcherMenu.js +21 -0
  287. package/dist/src/Switcher/SwitcherMenuItem.js +18 -0
  288. package/dist/src/Switcher/__tests__/SwitcherMenuItem.js +53 -0
  289. package/dist/src/Switcher/index.js +3 -0
  290. package/dist/src/Table/Table.js +292 -0
  291. package/dist/src/Table/TableBody.js +116 -0
  292. package/dist/src/Table/TableFooter.js +41 -0
  293. package/dist/src/Table/TableHeaders.js +26 -0
  294. package/dist/src/Table/TableStyles.js +46 -0
  295. package/dist/src/Table/TableTypes.d.ts +4 -4
  296. package/dist/src/Table/TableTypes.js +2 -0
  297. package/dist/src/Table/index.js +3 -0
  298. package/dist/src/Tabs/HorizontalTabs.js +122 -0
  299. package/dist/src/Tabs/TabLink.js +76 -0
  300. package/dist/src/Tabs/Tabs.d.ts +1 -1
  301. package/dist/src/Tabs/Tabs.js +62 -0
  302. package/dist/src/Tabs/VerticalTabs.js +13 -0
  303. package/dist/src/Tabs/__tests__/TabLink.tests.js +83 -0
  304. package/dist/src/Tabs/__tests__/Tablist.tests.js +78 -0
  305. package/dist/src/Tabs/index.js +3 -0
  306. package/dist/src/Tag/Tag.d.ts +2 -2
  307. package/dist/src/Tag/Tag.js +41 -0
  308. package/dist/src/Tag/index.js +1 -0
  309. package/dist/src/Tile/Tile.js +43 -0
  310. package/dist/src/Tile/TileBody.js +15 -0
  311. package/dist/src/Tile/TileCommonItems.js +75 -0
  312. package/dist/src/Tile/TileFooter.js +19 -0
  313. package/dist/src/Tile/TileHeader.js +57 -0
  314. package/dist/src/Tile/TileTypes.d.ts +8 -8
  315. package/dist/src/Tile/TileTypes.js +1 -0
  316. package/dist/src/Tile/index.js +3 -0
  317. package/dist/src/Toasters/Toast.d.ts +2 -2
  318. package/dist/src/Toasters/Toast.js +166 -0
  319. package/dist/src/Toasters/ToastContext.d.ts +2 -2
  320. package/dist/src/Toasters/ToastContext.js +69 -0
  321. package/dist/src/Toasters/index.js +4 -0
  322. package/dist/src/Toggles/ToggleButton.js +48 -0
  323. package/dist/src/Toggles/ToggleSwitch.js +65 -0
  324. package/dist/src/Toggles/TogglerStyles.js +17 -0
  325. package/dist/src/Toggles/TogglerTypes.js +1 -0
  326. package/dist/src/Toggles/index.js +3 -0
  327. package/dist/src/Tooltips/TooltipOverflow.js +71 -0
  328. package/dist/src/Tooltips/TooltipStyles.d.ts +1 -1
  329. package/dist/src/Tooltips/TooltipStyles.js +41 -0
  330. package/dist/src/Tooltips/TooltipTypes.js +1 -0
  331. package/dist/src/Tooltips/TooltipWrapper.js +65 -0
  332. package/dist/src/Tooltips/index.js +3 -0
  333. package/dist/src/assets/index.d.ts +1 -1
  334. package/dist/src/assets/index.js +41 -0
  335. package/dist/src/common/ActionWithin.js +25 -0
  336. package/dist/src/common/ClickOutside.js +20 -0
  337. package/dist/src/common/EventHandlers.js +8 -0
  338. package/dist/src/common/FocusOutside.js +20 -0
  339. package/dist/src/common/FocusVisible.d.ts +1 -1
  340. package/dist/src/common/FocusVisible.js +75 -0
  341. package/dist/src/common/InputStyling.js +8 -0
  342. package/dist/src/common/NavigationHelper.js +18 -0
  343. package/dist/src/common/ScrollableContainer.js +22 -0
  344. package/dist/src/common/StackState.js +10 -0
  345. package/dist/src/common/index.js +6 -0
  346. package/dist/src/icons/contenticons/Adaptive.js +31 -0
  347. package/dist/src/icons/contenticons/Add.js +31 -0
  348. package/dist/src/icons/contenticons/Adult.js +31 -0
  349. package/dist/src/icons/contenticons/AedNoShockAdvised.js +31 -0
  350. package/dist/src/icons/contenticons/AedPads.js +31 -0
  351. package/dist/src/icons/contenticons/AedPadsCorrect.js +31 -0
  352. package/dist/src/icons/contenticons/AedPadsError.js +31 -0
  353. package/dist/src/icons/contenticons/AedShockAdvised.js +31 -0
  354. package/dist/src/icons/contenticons/Ambulance.js +31 -0
  355. package/dist/src/icons/contenticons/Assignments.js +31 -0
  356. package/dist/src/icons/contenticons/Attention.js +31 -0
  357. package/dist/src/icons/contenticons/AutomaticMode.js +31 -0
  358. package/dist/src/icons/contenticons/AwardWinningPerson.js +31 -0
  359. package/dist/src/icons/contenticons/Biohazard.js +31 -0
  360. package/dist/src/icons/contenticons/Bleeding.js +31 -0
  361. package/dist/src/icons/contenticons/Book.js +31 -0
  362. package/dist/src/icons/contenticons/Buildings.js +31 -0
  363. package/dist/src/icons/contenticons/CPRCall.js +31 -0
  364. package/dist/src/icons/contenticons/CPRCycles.js +31 -0
  365. package/dist/src/icons/contenticons/CPRTraining.js +31 -0
  366. package/dist/src/icons/contenticons/Calendar.js +31 -0
  367. package/dist/src/icons/contenticons/Call.js +31 -0
  368. package/dist/src/icons/contenticons/Certificate.js +31 -0
  369. package/dist/src/icons/contenticons/ChestCompressionFraction.js +31 -0
  370. package/dist/src/icons/contenticons/Child.js +31 -0
  371. package/dist/src/icons/contenticons/Cleaning.js +31 -0
  372. package/dist/src/icons/contenticons/ClinicalFindings.js +31 -0
  373. package/dist/src/icons/contenticons/Cloud.js +31 -0
  374. package/dist/src/icons/contenticons/CloudAttension.js +31 -0
  375. package/dist/src/icons/contenticons/CloudChecked.js +31 -0
  376. package/dist/src/icons/contenticons/CloudDownload.js +31 -0
  377. package/dist/src/icons/contenticons/CloudLocked.js +31 -0
  378. package/dist/src/icons/contenticons/CloudNoConnection.js +31 -0
  379. package/dist/src/icons/contenticons/CloudSyncing.js +31 -0
  380. package/dist/src/icons/contenticons/CloudUpload.js +31 -0
  381. package/dist/src/icons/contenticons/Code.js +31 -0
  382. package/dist/src/icons/contenticons/CoffeeBreak.js +31 -0
  383. package/dist/src/icons/contenticons/Contact.js +31 -0
  384. package/dist/src/icons/contenticons/ContactInfo.js +31 -0
  385. package/dist/src/icons/contenticons/Cookie.js +31 -0
  386. package/dist/src/icons/contenticons/CountAloud.js +31 -0
  387. package/dist/src/icons/contenticons/Dashboard.js +31 -0
  388. package/dist/src/icons/contenticons/Data.js +31 -0
  389. package/dist/src/icons/contenticons/DecisionFlow.js +31 -0
  390. package/dist/src/icons/contenticons/Defribilator.js +31 -0
  391. package/dist/src/icons/contenticons/DefribilatorMonitor.js +31 -0
  392. package/dist/src/icons/contenticons/Depth.js +31 -0
  393. package/dist/src/icons/contenticons/Desktop.js +31 -0
  394. package/dist/src/icons/contenticons/DeviceChecked.js +31 -0
  395. package/dist/src/icons/contenticons/Dispatcher.js +31 -0
  396. package/dist/src/icons/contenticons/Doctor.js +31 -0
  397. package/dist/src/icons/contenticons/DocumentChecked.js +31 -0
  398. package/dist/src/icons/contenticons/Download.js +31 -0
  399. package/dist/src/icons/contenticons/ELearning.js +31 -0
  400. package/dist/src/icons/contenticons/EMSRescuer.js +31 -0
  401. package/dist/src/icons/contenticons/ESimulation.js +31 -0
  402. package/dist/src/icons/contenticons/Edit.js +31 -0
  403. package/dist/src/icons/contenticons/Educator.js +31 -0
  404. package/dist/src/icons/contenticons/Elderly.js +31 -0
  405. package/dist/src/icons/contenticons/Embryo.js +31 -0
  406. package/dist/src/icons/contenticons/EventLog.js +31 -0
  407. package/dist/src/icons/contenticons/Faq.js +31 -0
  408. package/dist/src/icons/contenticons/Female.js +31 -0
  409. package/dist/src/icons/contenticons/FirstAid.js +31 -0
  410. package/dist/src/icons/contenticons/Geriatric.js +31 -0
  411. package/dist/src/icons/contenticons/GiftCard.js +31 -0
  412. package/dist/src/icons/contenticons/Goals.js +31 -0
  413. package/dist/src/icons/contenticons/Grid.js +31 -0
  414. package/dist/src/icons/contenticons/GuidedTour.js +31 -0
  415. package/dist/src/icons/contenticons/HandPlacement.js +31 -0
  416. package/dist/src/icons/contenticons/HandPlacementCorrect.js +31 -0
  417. package/dist/src/icons/contenticons/HandPlacementIncorrect.js +31 -0
  418. package/dist/src/icons/contenticons/HeadTilt.js +31 -0
  419. package/dist/src/icons/contenticons/Heart.js +31 -0
  420. package/dist/src/icons/contenticons/HeartPulse.js +31 -0
  421. package/dist/src/icons/contenticons/HeartShock.js +31 -0
  422. package/dist/src/icons/contenticons/Help.js +31 -0
  423. package/dist/src/icons/contenticons/Hierarchy.js +31 -0
  424. package/dist/src/icons/contenticons/Hospital.js +31 -0
  425. package/dist/src/icons/contenticons/Hospitalized.js +31 -0
  426. package/dist/src/icons/contenticons/House.js +31 -0
  427. package/dist/src/icons/contenticons/Infant.js +31 -0
  428. package/dist/src/icons/contenticons/Information.js +31 -0
  429. package/dist/src/icons/contenticons/Injustice.js +31 -0
  430. package/dist/src/icons/contenticons/Institute.js +31 -0
  431. package/dist/src/icons/contenticons/Justice.js +31 -0
  432. package/dist/src/icons/contenticons/Laptop.js +31 -0
  433. package/dist/src/icons/contenticons/Leaflet.js +31 -0
  434. package/dist/src/icons/contenticons/Learner.js +31 -0
  435. package/dist/src/icons/contenticons/Levels.js +31 -0
  436. package/dist/src/icons/contenticons/LevelsDecreasing.js +31 -0
  437. package/dist/src/icons/contenticons/LevelsIncreasing.js +31 -0
  438. package/dist/src/icons/contenticons/LevelsStarred.js +31 -0
  439. package/dist/src/icons/contenticons/Maintenance.js +31 -0
  440. package/dist/src/icons/contenticons/Male.js +31 -0
  441. package/dist/src/icons/contenticons/Manikin.js +31 -0
  442. package/dist/src/icons/contenticons/ManikinCorrect.js +31 -0
  443. package/dist/src/icons/contenticons/ManikinError.js +31 -0
  444. package/dist/src/icons/contenticons/ManualMode.js +31 -0
  445. package/dist/src/icons/contenticons/MapPoint.js +31 -0
  446. package/dist/src/icons/contenticons/MaskLeak.js +31 -0
  447. package/dist/src/icons/contenticons/MedicalHistory.js +31 -0
  448. package/dist/src/icons/contenticons/MedicalRecord.js +31 -0
  449. package/dist/src/icons/contenticons/Medication.js +31 -0
  450. package/dist/src/icons/contenticons/Metronome.js +31 -0
  451. package/dist/src/icons/contenticons/MoodHappy.js +31 -0
  452. package/dist/src/icons/contenticons/MoodIndifferent.js +31 -0
  453. package/dist/src/icons/contenticons/MoodSad.js +31 -0
  454. package/dist/src/icons/contenticons/MoodVeryHappy.js +31 -0
  455. package/dist/src/icons/contenticons/MoodVerySad.js +31 -0
  456. package/dist/src/icons/contenticons/Newborn.js +31 -0
  457. package/dist/src/icons/contenticons/NoInterruption.js +31 -0
  458. package/dist/src/icons/contenticons/Note.js +31 -0
  459. package/dist/src/icons/contenticons/Pain.js +31 -0
  460. package/dist/src/icons/contenticons/Patient.js +31 -0
  461. package/dist/src/icons/contenticons/PatientAssignment.js +31 -0
  462. package/dist/src/icons/contenticons/PatientMonitor.js +31 -0
  463. package/dist/src/icons/contenticons/PatientStretcher.js +31 -0
  464. package/dist/src/icons/contenticons/PatientTransfer.js +31 -0
  465. package/dist/src/icons/contenticons/PatientTreatment.js +31 -0
  466. package/dist/src/icons/contenticons/Person.js +31 -0
  467. package/dist/src/icons/contenticons/PhysiologicalModel.js +31 -0
  468. package/dist/src/icons/contenticons/PieChart.js +31 -0
  469. package/dist/src/icons/contenticons/Pill.js +31 -0
  470. package/dist/src/icons/contenticons/Pregnant.js +31 -0
  471. package/dist/src/icons/contenticons/Print.js +31 -0
  472. package/dist/src/icons/contenticons/ProvidersOrders.js +31 -0
  473. package/dist/src/icons/contenticons/Pulse.js +31 -0
  474. package/dist/src/icons/contenticons/RQICart.js +31 -0
  475. package/dist/src/icons/contenticons/Rate.js +31 -0
  476. package/dist/src/icons/contenticons/RateTooFast.js +31 -0
  477. package/dist/src/icons/contenticons/RateTooSlow.js +31 -0
  478. package/dist/src/icons/contenticons/Recoil.js +31 -0
  479. package/dist/src/icons/contenticons/Ruler.js +31 -0
  480. package/dist/src/icons/contenticons/Screens.js +31 -0
  481. package/dist/src/icons/contenticons/Search.js +31 -0
  482. package/dist/src/icons/contenticons/Sepsis.js +31 -0
  483. package/dist/src/icons/contenticons/Settings.js +31 -0
  484. package/dist/src/icons/contenticons/Shock.js +31 -0
  485. package/dist/src/icons/contenticons/ShockAdvised.js +31 -0
  486. package/dist/src/icons/contenticons/ShockAutomated.js +31 -0
  487. package/dist/src/icons/contenticons/ShockNotAdvised.js +31 -0
  488. package/dist/src/icons/contenticons/Sleep.js +31 -0
  489. package/dist/src/icons/contenticons/Smartphone.js +31 -0
  490. package/dist/src/icons/contenticons/Speech.js +31 -0
  491. package/dist/src/icons/contenticons/SpeechBubble.js +31 -0
  492. package/dist/src/icons/contenticons/SpeechBubbles.js +31 -0
  493. package/dist/src/icons/contenticons/Star.js +31 -0
  494. package/dist/src/icons/contenticons/Stethoscope.js +31 -0
  495. package/dist/src/icons/contenticons/Stock.js +31 -0
  496. package/dist/src/icons/contenticons/Stopwatch.js +31 -0
  497. package/dist/src/icons/contenticons/Suitcase.js +31 -0
  498. package/dist/src/icons/contenticons/SwitchCamera.js +31 -0
  499. package/dist/src/icons/contenticons/SwitchRoles.js +31 -0
  500. package/dist/src/icons/contenticons/Tablet.js +31 -0
  501. package/dist/src/icons/contenticons/Talking.js +31 -0
  502. package/dist/src/icons/contenticons/TargetGroup.js +31 -0
  503. package/dist/src/icons/contenticons/TaskTrainer.js +31 -0
  504. package/dist/src/icons/contenticons/TeamLead.js +31 -0
  505. package/dist/src/icons/contenticons/TeamWork.js +31 -0
  506. package/dist/src/icons/contenticons/Terms.js +31 -0
  507. package/dist/src/icons/contenticons/TimelineReview.js +31 -0
  508. package/dist/src/icons/contenticons/Translation.js +31 -0
  509. package/dist/src/icons/contenticons/Trophy.js +31 -0
  510. package/dist/src/icons/contenticons/Trophy1st.js +31 -0
  511. package/dist/src/icons/contenticons/Trophy2nd.js +31 -0
  512. package/dist/src/icons/contenticons/Trophy3rd.js +31 -0
  513. package/dist/src/icons/contenticons/TrophyStar.js +31 -0
  514. package/dist/src/icons/contenticons/Truck.js +31 -0
  515. package/dist/src/icons/contenticons/TwoRescuerCPR.js +31 -0
  516. package/dist/src/icons/contenticons/USB.js +31 -0
  517. package/dist/src/icons/contenticons/Ultrasound.js +31 -0
  518. package/dist/src/icons/contenticons/VentilationLungs.js +31 -0
  519. package/dist/src/icons/contenticons/VentilationPressure.js +31 -0
  520. package/dist/src/icons/contenticons/VentilationVolume.js +31 -0
  521. package/dist/src/icons/contenticons/Video.js +31 -0
  522. package/dist/src/icons/contenticons/VideoRecording.js +31 -0
  523. package/dist/src/icons/contenticons/Visibility.js +31 -0
  524. package/dist/src/icons/contenticons/VitalSigns.js +31 -0
  525. package/dist/src/icons/contenticons/index.js +179 -0
  526. package/dist/src/icons/index.d.ts +1 -1
  527. package/dist/src/icons/index.js +45 -0
  528. package/dist/src/icons/systemicons/Accessibility.js +31 -0
  529. package/dist/src/icons/systemicons/Add.js +31 -0
  530. package/dist/src/icons/systemicons/AddUser.js +31 -0
  531. package/dist/src/icons/systemicons/Adult.js +31 -0
  532. package/dist/src/icons/systemicons/AedPads.js +31 -0
  533. package/dist/src/icons/systemicons/AedPadsCorrect.js +31 -0
  534. package/dist/src/icons/systemicons/AedPadsError.js +31 -0
  535. package/dist/src/icons/systemicons/Archive.js +31 -0
  536. package/dist/src/icons/systemicons/ArrowCollapse.js +31 -0
  537. package/dist/src/icons/systemicons/ArrowDropDown.js +31 -0
  538. package/dist/src/icons/systemicons/ArrowDropLeft.js +31 -0
  539. package/dist/src/icons/systemicons/ArrowDropRight.js +31 -0
  540. package/dist/src/icons/systemicons/ArrowDropUp.js +31 -0
  541. package/dist/src/icons/systemicons/ArrowExpand.js +31 -0
  542. package/dist/src/icons/systemicons/ArrowLineDown.js +31 -0
  543. package/dist/src/icons/systemicons/ArrowLineLeft.js +31 -0
  544. package/dist/src/icons/systemicons/ArrowLineRight.js +31 -0
  545. package/dist/src/icons/systemicons/ArrowLineUp.js +31 -0
  546. package/dist/src/icons/systemicons/ArrowStopLeft.js +31 -0
  547. package/dist/src/icons/systemicons/ArrowStopRight.js +31 -0
  548. package/dist/src/icons/systemicons/Assignments.js +31 -0
  549. package/dist/src/icons/systemicons/Asterisk.js +31 -0
  550. package/dist/src/icons/systemicons/Attachment.js +31 -0
  551. package/dist/src/icons/systemicons/Attention.js +31 -0
  552. package/dist/src/icons/systemicons/AudioDescriptionOn.js +31 -0
  553. package/dist/src/icons/systemicons/BackwardsFiveSec.js +31 -0
  554. package/dist/src/icons/systemicons/Battery0.js +31 -0
  555. package/dist/src/icons/systemicons/Battery1.js +31 -0
  556. package/dist/src/icons/systemicons/Battery2.js +31 -0
  557. package/dist/src/icons/systemicons/Battery3.js +31 -0
  558. package/dist/src/icons/systemicons/Battery4.js +31 -0
  559. package/dist/src/icons/systemicons/Battery5.js +31 -0
  560. package/dist/src/icons/systemicons/Battery6.js +31 -0
  561. package/dist/src/icons/systemicons/BatteryFull.js +31 -0
  562. package/dist/src/icons/systemicons/Bluetooth.js +31 -0
  563. package/dist/src/icons/systemicons/Book.js +31 -0
  564. package/dist/src/icons/systemicons/BookmarkAdd.js +31 -0
  565. package/dist/src/icons/systemicons/BookmarkCollection.js +31 -0
  566. package/dist/src/icons/systemicons/BookmarkOff.js +31 -0
  567. package/dist/src/icons/systemicons/BookmarkOn.js +31 -0
  568. package/dist/src/icons/systemicons/Bullet.js +31 -0
  569. package/dist/src/icons/systemicons/Calendar.js +31 -0
  570. package/dist/src/icons/systemicons/CheckMark.js +31 -0
  571. package/dist/src/icons/systemicons/CheckboxOff.js +31 -0
  572. package/dist/src/icons/systemicons/CheckboxOn.js +31 -0
  573. package/dist/src/icons/systemicons/CheckboxSemi.js +31 -0
  574. package/dist/src/icons/systemicons/ChevronDown.js +31 -0
  575. package/dist/src/icons/systemicons/ChevronLeft.js +31 -0
  576. package/dist/src/icons/systemicons/ChevronRight.js +31 -0
  577. package/dist/src/icons/systemicons/ChevronUp.js +31 -0
  578. package/dist/src/icons/systemicons/Child.js +31 -0
  579. package/dist/src/icons/systemicons/Clear.js +31 -0
  580. package/dist/src/icons/systemicons/Close.js +31 -0
  581. package/dist/src/icons/systemicons/ClosedCaptionOn.js +31 -0
  582. package/dist/src/icons/systemicons/Cloud.js +31 -0
  583. package/dist/src/icons/systemicons/CloudAttention.js +31 -0
  584. package/dist/src/icons/systemicons/CloudCheck.js +31 -0
  585. package/dist/src/icons/systemicons/CloudDownload.js +31 -0
  586. package/dist/src/icons/systemicons/CloudLocked.js +31 -0
  587. package/dist/src/icons/systemicons/CloudNoConnection.js +31 -0
  588. package/dist/src/icons/systemicons/CloudSyncing.js +31 -0
  589. package/dist/src/icons/systemicons/CloudUpload.js +31 -0
  590. package/dist/src/icons/systemicons/CoffeeBreak.js +31 -0
  591. package/dist/src/icons/systemicons/Copy.js +31 -0
  592. package/dist/src/icons/systemicons/Dashboard.js +31 -0
  593. package/dist/src/icons/systemicons/DecisionFlow.js +31 -0
  594. package/dist/src/icons/systemicons/Delete.js +31 -0
  595. package/dist/src/icons/systemicons/Document.js +31 -0
  596. package/dist/src/icons/systemicons/Download.js +31 -0
  597. package/dist/src/icons/systemicons/DragHandle.js +31 -0
  598. package/dist/src/icons/systemicons/DragIndicator.js +31 -0
  599. package/dist/src/icons/systemicons/Edit.js +31 -0
  600. package/dist/src/icons/systemicons/Educator.js +31 -0
  601. package/dist/src/icons/systemicons/Equals.js +31 -0
  602. package/dist/src/icons/systemicons/EventLog.js +31 -0
  603. package/dist/src/icons/systemicons/Export.js +31 -0
  604. package/dist/src/icons/systemicons/ExportCVS.js +31 -0
  605. package/dist/src/icons/systemicons/ExportDoc.js +31 -0
  606. package/dist/src/icons/systemicons/ExportEXL.js +31 -0
  607. package/dist/src/icons/systemicons/ExportJpg.js +31 -0
  608. package/dist/src/icons/systemicons/ExportPDF.js +31 -0
  609. package/dist/src/icons/systemicons/ExportPNG.js +31 -0
  610. package/dist/src/icons/systemicons/ExtendTextArea.js +31 -0
  611. package/dist/src/icons/systemicons/Facebook.js +31 -0
  612. package/dist/src/icons/systemicons/Filter.js +31 -0
  613. package/dist/src/icons/systemicons/Flickr.js +31 -0
  614. package/dist/src/icons/systemicons/Forward.js +31 -0
  615. package/dist/src/icons/systemicons/ForwardFiveSec.js +31 -0
  616. package/dist/src/icons/systemicons/ForwardSlash.js +31 -0
  617. package/dist/src/icons/systemicons/Fullscreen.js +31 -0
  618. package/dist/src/icons/systemicons/FullscreenExit.js +31 -0
  619. package/dist/src/icons/systemicons/GearSettings.js +31 -0
  620. package/dist/src/icons/systemicons/GridView.js +31 -0
  621. package/dist/src/icons/systemicons/Group.js +31 -0
  622. package/dist/src/icons/systemicons/GuidedTour.js +31 -0
  623. package/dist/src/icons/systemicons/HeartShock.js +31 -0
  624. package/dist/src/icons/systemicons/Help.js +31 -0
  625. package/dist/src/icons/systemicons/Hierarchy.js +31 -0
  626. package/dist/src/icons/systemicons/History.js +31 -0
  627. package/dist/src/icons/systemicons/Home.js +31 -0
  628. package/dist/src/icons/systemicons/Image.js +31 -0
  629. package/dist/src/icons/systemicons/Infant.js +31 -0
  630. package/dist/src/icons/systemicons/Information.js +31 -0
  631. package/dist/src/icons/systemicons/Institute.js +31 -0
  632. package/dist/src/icons/systemicons/Keyboard.js +31 -0
  633. package/dist/src/icons/systemicons/Language.js +31 -0
  634. package/dist/src/icons/systemicons/Learner.js +31 -0
  635. package/dist/src/icons/systemicons/Legend.js +31 -0
  636. package/dist/src/icons/systemicons/Legend1Circle.js +31 -0
  637. package/dist/src/icons/systemicons/Legend2Triangle.js +31 -0
  638. package/dist/src/icons/systemicons/Legend3Star.js +31 -0
  639. package/dist/src/icons/systemicons/Legend4Square.js +31 -0
  640. package/dist/src/icons/systemicons/Legend5Diamond.js +31 -0
  641. package/dist/src/icons/systemicons/Legend6Nabla.js +31 -0
  642. package/dist/src/icons/systemicons/Legend7Pentagon.js +31 -0
  643. package/dist/src/icons/systemicons/Legend8Rectangle.js +31 -0
  644. package/dist/src/icons/systemicons/LegendStrokeDashed.js +31 -0
  645. package/dist/src/icons/systemicons/LegendStrokeSolid.js +31 -0
  646. package/dist/src/icons/systemicons/LikeOff.js +31 -0
  647. package/dist/src/icons/systemicons/LikeOn.js +31 -0
  648. package/dist/src/icons/systemicons/Link.js +31 -0
  649. package/dist/src/icons/systemicons/LinkedIn.js +31 -0
  650. package/dist/src/icons/systemicons/ListView.js +31 -0
  651. package/dist/src/icons/systemicons/LoadingMedium.js +8 -0
  652. package/dist/src/icons/systemicons/LoadingSmall.js +8 -0
  653. package/dist/src/icons/systemicons/LockedOff.js +31 -0
  654. package/dist/src/icons/systemicons/LockedOn.js +31 -0
  655. package/dist/src/icons/systemicons/Login.js +31 -0
  656. package/dist/src/icons/systemicons/Logout.js +31 -0
  657. package/dist/src/icons/systemicons/Loop.js +31 -0
  658. package/dist/src/icons/systemicons/Mail.js +31 -0
  659. package/dist/src/icons/systemicons/Manikin.js +31 -0
  660. package/dist/src/icons/systemicons/MapPoint.js +31 -0
  661. package/dist/src/icons/systemicons/Menu.js +31 -0
  662. package/dist/src/icons/systemicons/Metronome.js +31 -0
  663. package/dist/src/icons/systemicons/Microphone.js +31 -0
  664. package/dist/src/icons/systemicons/Minus.js +31 -0
  665. package/dist/src/icons/systemicons/MoreHorizontal.js +31 -0
  666. package/dist/src/icons/systemicons/MoreVertical.js +31 -0
  667. package/dist/src/icons/systemicons/Notification.js +31 -0
  668. package/dist/src/icons/systemicons/NotificationNew.js +31 -0
  669. package/dist/src/icons/systemicons/OpenFolder.js +31 -0
  670. package/dist/src/icons/systemicons/OpenNewWindow.js +31 -0
  671. package/dist/src/icons/systemicons/OverView.js +31 -0
  672. package/dist/src/icons/systemicons/Pause.js +31 -0
  673. package/dist/src/icons/systemicons/PieChart.js +31 -0
  674. package/dist/src/icons/systemicons/Pin.js +31 -0
  675. package/dist/src/icons/systemicons/Play.js +31 -0
  676. package/dist/src/icons/systemicons/PlayList.js +31 -0
  677. package/dist/src/icons/systemicons/PlayOutline.js +31 -0
  678. package/dist/src/icons/systemicons/PlaybackSpeed.js +31 -0
  679. package/dist/src/icons/systemicons/Plus.js +31 -0
  680. package/dist/src/icons/systemicons/PointDown.js +31 -0
  681. package/dist/src/icons/systemicons/PointLeft.js +31 -0
  682. package/dist/src/icons/systemicons/PointRight.js +31 -0
  683. package/dist/src/icons/systemicons/PointUp.js +31 -0
  684. package/dist/src/icons/systemicons/Print.js +31 -0
  685. package/dist/src/icons/systemicons/RadioButtonOff.js +31 -0
  686. package/dist/src/icons/systemicons/RadioButtonOn.js +31 -0
  687. package/dist/src/icons/systemicons/Record.js +31 -0
  688. package/dist/src/icons/systemicons/Refresh.js +31 -0
  689. package/dist/src/icons/systemicons/Replay.js +31 -0
  690. package/dist/src/icons/systemicons/Rewind.js +31 -0
  691. package/dist/src/icons/systemicons/SUN.js +31 -0
  692. package/dist/src/icons/systemicons/Save.js +31 -0
  693. package/dist/src/icons/systemicons/Search.js +31 -0
  694. package/dist/src/icons/systemicons/SendTo.js +31 -0
  695. package/dist/src/icons/systemicons/Share.js +31 -0
  696. package/dist/src/icons/systemicons/Shock.js +31 -0
  697. package/dist/src/icons/systemicons/ShockAdvised.js +31 -0
  698. package/dist/src/icons/systemicons/ShockAutomated.js +31 -0
  699. package/dist/src/icons/systemicons/ShockNotAdvised.js +31 -0
  700. package/dist/src/icons/systemicons/ShoppingCart.js +31 -0
  701. package/dist/src/icons/systemicons/SkipForward.js +31 -0
  702. package/dist/src/icons/systemicons/Sort.js +31 -0
  703. package/dist/src/icons/systemicons/SpeechBuble.js +31 -0
  704. package/dist/src/icons/systemicons/StarFilled.js +31 -0
  705. package/dist/src/icons/systemicons/StarOutlined.js +31 -0
  706. package/dist/src/icons/systemicons/Stop.js +31 -0
  707. package/dist/src/icons/systemicons/Support.js +31 -0
  708. package/dist/src/icons/systemicons/SwitchApp.js +31 -0
  709. package/dist/src/icons/systemicons/Team.js +31 -0
  710. package/dist/src/icons/systemicons/TechnicalWarning.js +31 -0
  711. package/dist/src/icons/systemicons/ThumbsDown.js +31 -0
  712. package/dist/src/icons/systemicons/ThumbsUp.js +31 -0
  713. package/dist/src/icons/systemicons/Time.js +31 -0
  714. package/dist/src/icons/systemicons/TimeLimited.js +31 -0
  715. package/dist/src/icons/systemicons/Timeline.js +31 -0
  716. package/dist/src/icons/systemicons/Tip.js +31 -0
  717. package/dist/src/icons/systemicons/Transcript.js +31 -0
  718. package/dist/src/icons/systemicons/Translation.js +31 -0
  719. package/dist/src/icons/systemicons/Twitter.js +31 -0
  720. package/dist/src/icons/systemicons/Upload.js +31 -0
  721. package/dist/src/icons/systemicons/Usb.js +31 -0
  722. package/dist/src/icons/systemicons/User.js +31 -0
  723. package/dist/src/icons/systemicons/Video.js +31 -0
  724. package/dist/src/icons/systemicons/VisibleOff.js +31 -0
  725. package/dist/src/icons/systemicons/VisibleOn.js +31 -0
  726. package/dist/src/icons/systemicons/VolumeDown.js +31 -0
  727. package/dist/src/icons/systemicons/VolumeOff.js +31 -0
  728. package/dist/src/icons/systemicons/VolumeUp.js +31 -0
  729. package/dist/src/icons/systemicons/Youtube.js +31 -0
  730. package/dist/src/icons/systemicons/Zoom.js +31 -0
  731. package/dist/src/icons/systemicons/ZoomOut.js +31 -0
  732. package/dist/src/icons/systemicons/index.js +204 -0
  733. package/dist/src/index.js +45 -0
  734. package/dist/src/styles/breakpoints.js +6 -0
  735. package/dist/src/styles/colors.d.ts +0 -1
  736. package/dist/src/styles/colors.js +89 -0
  737. package/dist/src/styles/focus-styles.js +9 -0
  738. package/dist/src/styles/global.js +13 -0
  739. package/dist/src/styles/index.d.ts +2 -1
  740. package/dist/src/styles/index.js +20 -0
  741. package/dist/src/styles/overwritecolors.d.ts +2 -0
  742. package/dist/src/styles/overwritecolors.js +12 -0
  743. package/dist/src/styles/shadowstyles.js +7 -0
  744. package/dist/src/styles/typography.d.ts +1 -1
  745. package/dist/src/styles/typography.js +130 -0
  746. package/dist/src/styles/z-indexes.js +16 -0
  747. package/dist/src/types.js +51 -0
  748. package/dist/src/utils/utils.js +3 -0
  749. package/dist/stories/Accordion/AccordionMenu.stories.d.ts +1 -1
  750. package/dist/stories/Accordion/AccordionMenu.stories.js +153 -0
  751. package/dist/stories/Accordion/ContentAccordion.stories.d.ts +1 -1
  752. package/dist/stories/Accordion/ContentAccordion.stories.js +234 -0
  753. package/dist/stories/AuthPage.stories.js +88 -0
  754. package/dist/stories/Banner.stories.d.ts +1 -1
  755. package/dist/stories/Banner.stories.js +107 -0
  756. package/dist/stories/Breadcrumb.stories.d.ts +1 -1
  757. package/dist/stories/Breadcrumb.stories.js +151 -0
  758. package/dist/stories/Button/BackButton.stories.d.ts +1 -1
  759. package/dist/stories/Button/BackButton.stories.js +32 -0
  760. package/dist/stories/Button/Button.stories.d.ts +1 -1
  761. package/dist/stories/Button/Button.stories.js +499 -0
  762. package/dist/stories/Button/DualFunctionButton.stories.d.ts +1 -1
  763. package/dist/stories/Button/DualFunctionButton.stories.js +374 -0
  764. package/dist/stories/Button/IconButton.stories.d.ts +1 -1
  765. package/dist/stories/Button/IconButton.stories.js +81 -0
  766. package/dist/stories/Card/Card.stories.d.ts +1 -1
  767. package/dist/stories/Card/Card.stories.js +710 -0
  768. package/dist/stories/Card/HorizontalCard.stories.d.ts +1 -1
  769. package/dist/stories/Card/HorizontalCard.stories.js +116 -0
  770. package/dist/stories/Chip/ActionChip.stories.d.ts +1 -1
  771. package/dist/stories/Chip/ActionChip.stories.js +69 -0
  772. package/dist/stories/Chip/ChoiceChip.stories.d.ts +1 -1
  773. package/dist/stories/Chip/ChoiceChip.stories.js +43 -0
  774. package/dist/stories/Chip/FilterChip.stories.d.ts +1 -1
  775. package/dist/stories/Chip/FilterChip.stories.js +68 -0
  776. package/dist/stories/Chip/InputChip.stories.d.ts +1 -1
  777. package/dist/stories/Chip/InputChip.stories.js +94 -0
  778. package/dist/stories/Dropdown/BasicDropdown.stories.d.ts +1 -1
  779. package/dist/stories/Dropdown/BasicDropdown.stories.js +122 -0
  780. package/dist/stories/Dropdown/ButtonDropdown.stories.d.ts +1 -1
  781. package/dist/stories/Dropdown/ButtonDropdown.stories.js +165 -0
  782. package/dist/stories/Dropdown/DropdownFilter.stories.d.ts +1 -1
  783. package/dist/stories/Dropdown/DropdownFilter.stories.js +81 -0
  784. package/dist/stories/Footer.stories.js +95 -0
  785. package/dist/stories/GlobalLoadingPage.stories.js +10 -0
  786. package/dist/stories/GlobalNavigationBar.stories.js +477 -0
  787. package/dist/stories/HorizontalTabs.stories.d.ts +1 -1
  788. package/dist/stories/HorizontalTabs.stories.js +161 -0
  789. package/dist/stories/Icon.stories.js +86 -0
  790. package/dist/stories/InputFields/CheckboxDemo.stories.d.ts +1 -1
  791. package/dist/stories/InputFields/CheckboxDemo.stories.js +63 -0
  792. package/dist/stories/InputFields/ChipInputField.stories.d.ts +1 -1
  793. package/dist/stories/InputFields/ChipInputField.stories.js +195 -0
  794. package/dist/stories/InputFields/DatepickerDemo.stories.d.ts +1 -1
  795. package/dist/stories/InputFields/DatepickerDemo.stories.js +54 -0
  796. package/dist/stories/InputFields/FormDemo.stories.js +47 -0
  797. package/dist/stories/InputFields/NumberFieldDemo.stories.d.ts +1 -1
  798. package/dist/stories/InputFields/NumberFieldDemo.stories.js +147 -0
  799. package/dist/stories/InputFields/PasswordDemo.stories.d.ts +1 -1
  800. package/dist/stories/InputFields/PasswordDemo.stories.js +52 -0
  801. package/dist/stories/InputFields/QuickSearchDemo.stories.d.ts +1 -1
  802. package/dist/stories/InputFields/QuickSearchDemo.stories.js +78 -0
  803. package/dist/stories/InputFields/RadioButtonDemo.stories.d.ts +1 -1
  804. package/dist/stories/InputFields/RadioButtonDemo.stories.js +52 -0
  805. package/dist/stories/InputFields/RichTextFieldDemo.stories.d.ts +1 -1
  806. package/dist/stories/InputFields/RichTextFieldDemo.stories.js +74 -0
  807. package/dist/stories/InputFields/SearchBarDemo.stories.d.ts +1 -1
  808. package/dist/stories/InputFields/SearchBarDemo.stories.js +108 -0
  809. package/dist/stories/InputFields/TextFieldDemo.stories.d.ts +1 -1
  810. package/dist/stories/InputFields/TextFieldDemo.stories.js +113 -0
  811. package/dist/stories/InputFields/TextareaDemo.stories.d.ts +1 -1
  812. package/dist/stories/InputFields/TextareaDemo.stories.js +80 -0
  813. package/dist/stories/Layout.stories.js +15 -0
  814. package/dist/stories/LinearProgress.stories.d.ts +1 -1
  815. package/dist/stories/LinearProgress.stories.js +69 -0
  816. package/dist/stories/List.stories.d.ts +1 -1
  817. package/dist/stories/List.stories.js +290 -0
  818. package/dist/stories/LoadingIndicator.stories.d.ts +1 -1
  819. package/dist/stories/LoadingIndicator.stories.js +24 -0
  820. package/dist/stories/MenuItem.stories.d.ts +1 -1
  821. package/dist/stories/MenuItem.stories.js +101 -0
  822. package/dist/stories/ModalContent.stories.js +468 -0
  823. package/dist/stories/ModalDialog.stories.js +862 -0
  824. package/dist/stories/NavItem.stories.d.ts +1 -1
  825. package/dist/stories/NavItem.stories.js +18 -0
  826. package/dist/stories/Notification.stories.d.ts +1 -1
  827. package/dist/stories/Notification.stories.js +30 -0
  828. package/dist/stories/Paginator.stories.d.ts +1 -1
  829. package/dist/stories/Paginator.stories.js +27 -0
  830. package/dist/stories/Popover.stories.js +836 -0
  831. package/dist/stories/ProfileButton.stories.d.ts +1 -1
  832. package/dist/stories/ProfileButton.stories.js +56 -0
  833. package/dist/stories/QuizButton.stories.d.ts +1 -1
  834. package/dist/stories/QuizButton.stories.js +128 -0
  835. package/dist/stories/Scrollbar.stories.js +70 -0
  836. package/dist/stories/SegmentControl.stories.d.ts +1 -1
  837. package/dist/stories/SegmentControl.stories.js +89 -0
  838. package/dist/stories/ShadowStyles.stories.js +24 -0
  839. package/dist/stories/SideMenu.stories.js +149 -0
  840. package/dist/stories/Switcher.stories.js +17 -0
  841. package/dist/stories/Tables.stories.js +436 -0
  842. package/dist/stories/Tabs.stories.js +92 -0
  843. package/dist/stories/Tag.stories.d.ts +1 -1
  844. package/dist/stories/Tag.stories.js +52 -0
  845. package/dist/stories/Tile.stories.d.ts +1 -1
  846. package/dist/stories/Tile.stories.js +1618 -0
  847. package/dist/stories/Toast.stories.d.ts +1 -1
  848. package/dist/stories/Toast.stories.js +294 -0
  849. package/dist/stories/ToggleButton.stories.d.ts +1 -1
  850. package/dist/stories/ToggleButton.stories.js +74 -0
  851. package/dist/stories/ToggleSwitch.stories.d.ts +1 -1
  852. package/dist/stories/ToggleSwitch.stories.js +94 -0
  853. package/dist/stories/Tooltip.stories.d.ts +1 -1
  854. package/dist/stories/Tooltip.stories.js +88 -0
  855. package/dist/stories/Typography.stories.js +130 -0
  856. package/dist/stories/color.stories.js +272 -0
  857. package/dist/styles/colors.cjs +1 -11
  858. package/dist/styles/colors.cjs.map +1 -1
  859. package/dist/styles/colors.js +0 -9
  860. package/dist/styles/colors.js.map +1 -1
  861. package/dist/styles/global.d.ts +1 -1
  862. package/dist/styles/index.cjs +3 -5
  863. package/dist/styles/index.cjs.map +1 -1
  864. package/dist/styles/index.d.ts +2 -1
  865. package/dist/styles/index.js +2 -1
  866. package/dist/styles/index.js.map +1 -1
  867. package/dist/styles/overwritecolors.cjs +20 -0
  868. package/dist/styles/overwritecolors.cjs.map +1 -0
  869. package/dist/styles/overwritecolors.d.ts +3 -0
  870. package/dist/styles/overwritecolors.js +12 -0
  871. package/dist/styles/overwritecolors.js.map +1 -0
  872. package/package.json +1 -1
@@ -0,0 +1,339 @@
1
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
2
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
3
+ return cooked;
4
+ };
5
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
6
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
7
+ if (ar || !(i in from)) {
8
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
9
+ ar[i] = from[i];
10
+ }
11
+ }
12
+ return to.concat(ar || Array.prototype.slice.call(from));
13
+ };
14
+ import React from 'react';
15
+ import styled from 'styled-components';
16
+ import Button from '../Button/Button';
17
+ import { Size } from '../types';
18
+ import { DropdownContentButtonStyling } from './CommonStyling';
19
+ import { ComponentLStyling, ComponentXLStyling, ComponentMStyling, ComponentSStyling, ComponentTextStyle } from '../styles/typography';
20
+ import { COLORS, scrollBarStyling } from '../styles';
21
+ import { Checkbox, RadioButton } from '../InputFields';
22
+ import { Z_INDEXES } from '../styles/z-indexes';
23
+ import MenuItem from '../MenuItem/MenuItem';
24
+ var MAX_MENU_HEIGHT = 240;
25
+ var AVG_OPTION_HEIGHT = 48;
26
+ var OFFSET_BEFORE_SHOW = 1000000;
27
+ export var DropdownContentContainer = styled.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n display: none;\n pointer-events: auto;\n position: absolute;\n background-color: ", ";\n\n z-index: ", ";\n margin: ", ";\n\n &.show {\n display: flex;\n flex-direction: column;\n justify-content: center;\n &.down,\n &.up {\n ", "\n }\n }\n\n transform: translate(-", "px, -", "px);\n\n &.outline:focus:after {\n content: '';\n pointer-events: none;\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n outline: 4px solid black;\n outline-offset: 2px;\n border-radius: 2px;\n }\n\n &:focus {\n outline: none;\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: 4px 0px;\n\n min-width: ", ";\n border-radius: ", ";\n\n max-height: ", ";\n"], ["\n display: none;\n pointer-events: auto;\n position: absolute;\n background-color: ", ";\n\n z-index: ", ";\n margin: ", ";\n\n &.show {\n display: flex;\n flex-direction: column;\n justify-content: center;\n &.down,\n &.up {\n ", "\n }\n }\n\n transform: translate(-", "px, -", "px);\n\n &.outline:focus:after {\n content: '';\n pointer-events: none;\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n outline: 4px solid black;\n outline-offset: 2px;\n border-radius: 2px;\n }\n\n &:focus {\n outline: none;\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: 4px 0px;\n\n min-width: ", ";\n border-radius: ", ";\n\n max-height: ", ";\n"])), COLORS.white, Z_INDEXES.dropdown, function (props) { return (props.isButton ? '-4px' : '4px 0px'); }, function (props) { return "transform: translate(".concat(props.offsetLeft, ", ").concat(props.offsetTop, ");"); }, OFFSET_BEFORE_SHOW, OFFSET_BEFORE_SHOW, function (props) { return (props.isButton ? DropdownContentButtonStyling : ''); }, COLORS.neutral_100, function (props) { return (props.size == Size.Large ? '320px' : props.size == Size.Medium ? '280px' : '240px'); }, function (props) { return (props.size == Size.Large ? '10px' : props.size == Size.Medium ? '8px' : '6px'); }, function (props) { return (!props.scrollable ? 'auto' : props.maxHeight ? props.maxHeight : props.size == Size.Large ? '320px' : props.size == Size.Medium ? '280px' : '240px'); });
28
+ export var DropdownContentItemsContainer = styled.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n > *:hover {\n z-index: ", ";\n }\n\n > *:active,\n > *.active {\n z-index: ", ";\n }\n\n > *:focus {\n z-index: ", ";\n }\n"], ["\n > *:hover {\n z-index: ", ";\n }\n\n > *:active,\n > *.active {\n z-index: ", ";\n }\n\n > *:focus {\n z-index: ", ";\n }\n"])), Z_INDEXES.hover, Z_INDEXES.active, Z_INDEXES.focus);
29
+ export var DropdownContentListContainer = styled.div(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\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 word-break: break-word;\n }\n\n *:focus {\n outline: none !important;\n }\n\n ", "\n"], ["\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 word-break: break-word;\n }\n\n *:focus {\n outline: none !important;\n }\n\n ", "\n"])), function (props) { return (props.scrollable ? 'overflow-y: scroll;' : ''); }, function (props) { return (props.scrollable ? 'margin-right: 6px;' : ''); }, function (props) { return (props.scrollable ? 'padding-right: 6px;' : ''); }, function (props) { return (props.itemsType != 'normal' ? 'margin-left: 4px;' : ''); }, DropdownContentItemsContainer, function (props) { return (props.size == Size.Large ? '8px' : props.size == Size.Medium ? '4px' : '0px'); }, function (props) { return (props.size == Size.Large ? '8px' : props.size == Size.Medium ? '4px' : '0px'); }, scrollBarStyling(Size.Small));
30
+ var DropdownContentMenuContentContainer = styled.div(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n h1,\n h2,\n 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"], ["\n h1,\n h2,\n 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) { return props.size == Size.Large && ComponentXLStyling(ComponentTextStyle.Bold, COLORS.neutral_500); }, function (props) { return props.size == Size.Medium && ComponentLStyling(ComponentTextStyle.Bold, COLORS.neutral_500); }, function (props) { return (props.size == Size.Small || !props.size) && ComponentMStyling(ComponentTextStyle.Bold, COLORS.neutral_500); }, function (props) { return (props.size == Size.Small || !props.size ? '10px 16px 6px' : props.size == Size.Medium ? '16px 24px 8px' : '16px 32px 8px'); }, function (props) { return props.size == Size.Large && ComponentLStyling(ComponentTextStyle.Regular, COLORS.neutral_500); }, function (props) { return props.size == Size.Medium && ComponentMStyling(ComponentTextStyle.Regular, COLORS.neutral_500); }, function (props) { return (props.size == Size.Small || !props.size) && ComponentSStyling(ComponentTextStyle.Regular, COLORS.neutral_500); }, function (props) { return (props.size == Size.Small || !props.size ? '8px 16px' : props.size == Size.Medium ? '12px 24px' : '16px 32px'); });
31
+ var DividerContainer = styled.div(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n position: relative;\n\n margin-top: ", ";\n\n div.divider {\n width: 100%;\n margin: 0px;\n }\n"], ["\n position: relative;\n\n margin-top: ", ";\n\n div.divider {\n width: 100%;\n margin: 0px;\n }\n"])), function (props) { return (props.size == Size.Large ? '16px' : props.size == Size.Medium ? '12px' : props.size == Size.Small || !props.size ? '8px' : '6px'); });
32
+ var DropdownContentTopItemContainer = styled.div(templateObject_6 || (templateObject_6 = __makeTemplateObject(["\n border-bottom-style: solid;\n border-bottom-color: ", ";\n border-bottom-width: 1px;\n margin-right: 22px;\n"], ["\n border-bottom-style: solid;\n border-bottom-color: ", ";\n border-bottom-width: 1px;\n margin-right: 22px;\n"])), COLORS.neutral_200);
33
+ var DropdownContentActionButtonContainer = styled.div(templateObject_7 || (templateObject_7 = __makeTemplateObject(["\n ", "\n ", "\n\n padding: ", ";\n\n button {\n width: 100%;\n }\n"], ["\n ", "\n ", "\n\n padding: ", ";\n\n button {\n width: 100%;\n }\n"])), function (props) { return (props.scrollable ? "border-top: 1px solid ".concat(COLORS.neutral_200, ";") : ''); }, function (props) { return (props.scrollable ? 'margin-top: 4px;' : ''); }, function (props) { return (props.size === Size.Small || !props.size ? '4px 16px 0px' : props.size === Size.Medium ? '12px 16px 8px' : '16px 16px 12px'); });
34
+ var Overlay = styled.div(templateObject_8 || (templateObject_8 = __makeTemplateObject(["\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n pointer-events: none;\n z-index: ", ";\n"], ["\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n pointer-events: none;\n z-index: ", ";\n"])), Z_INDEXES.modal);
35
+ var DropdownContent = React.forwardRef(function (_a, ref) {
36
+ var _b, _c;
37
+ var id = _a.id, customizationProps = _a.customizationProps, alignLeft = _a.alignLeft, isButton = _a.isButton, size = _a.size, isOpen = _a.isOpen, width = _a.width, setIsOpen = _a.setIsOpen, filter = _a.filter, focused = _a.focused, setFocused = _a.setFocused, selectedValues = _a.selectedValues, setSelectedValues = _a.setSelectedValues, messageOnNoResults = _a.messageOnNoResults, outline = _a.outline, containerRef = _a.containerRef, onActiveDescendantChanged = _a.onActiveDescendantChanged, _d = _a.ariaRolesType, ariaRolesType = _d === void 0 ? 'menu' : _d;
38
+ var _e = React.useState(false), isUp = _e[0], setIsUp = _e[1];
39
+ var _f = React.useState(false), locationDefined = _f[0], setLocationDefined = _f[1];
40
+ var _g = React.useState({ top: '0', left: '0' }), offset = _g[0], setOffset = _g[1];
41
+ var dropdownContentRef = (_b = ref) !== null && _b !== void 0 ? _b : React.useRef(null);
42
+ if (!customizationProps.itemsType)
43
+ customizationProps.itemsType = 'normal';
44
+ if (!size)
45
+ size = Size.Small;
46
+ var itemsListRef = React.useRef(null);
47
+ var actionButtonRef = React.useRef(null);
48
+ var determineDropUp = function () {
49
+ var options = customizationProps.items;
50
+ var rect = containerRef.current.getBoundingClientRect();
51
+ var windowHeight = window.innerHeight;
52
+ var menuHeight = Math.min(MAX_MENU_HEIGHT, options.length * AVG_OPTION_HEIGHT);
53
+ var instOffsetWithMenu = rect.top + rect.height + menuHeight;
54
+ var up = instOffsetWithMenu >= windowHeight;
55
+ setOffset({
56
+ top: up ? "calc(-100% - ".concat(rect.height, "px ").concat(isButton ? '' : '- 8px', ")") : '0',
57
+ left: alignLeft ? "calc(-".concat(rect.width, "px)") : "calc(-100%)",
58
+ });
59
+ setIsUp(up);
60
+ setLocationDefined(true);
61
+ };
62
+ var setNewFocusedElement = function (index) {
63
+ var _a, _b, _c, _d;
64
+ if (outline)
65
+ (_a = dropdownContentRef.current) === null || _a === void 0 ? void 0 : _a.focus();
66
+ var newFocusedElement = elRefs[index];
67
+ if (onActiveDescendantChanged)
68
+ onActiveDescendantChanged(index == 0 ? "".concat(id, "_topitem") : "".concat(id, "_").concat(index));
69
+ var oldFocusedElement = focused || focused === 0 ? elRefs[focused] : null;
70
+ if (newFocusedElement && newFocusedElement !== oldFocusedElement) {
71
+ setFocused(index);
72
+ (_b = oldFocusedElement === null || oldFocusedElement === void 0 ? void 0 : oldFocusedElement.current) === null || _b === void 0 ? void 0 : _b.classList.remove('dropdown-hover');
73
+ (_c = newFocusedElement.current) === null || _c === void 0 ? void 0 : _c.classList.add('dropdown-hover');
74
+ (_d = newFocusedElement.current) === null || _d === void 0 ? void 0 : _d.scrollIntoView({
75
+ block: 'nearest',
76
+ inline: 'nearest',
77
+ });
78
+ }
79
+ };
80
+ var getFilteredItems = function () {
81
+ var filtrationString = (filter !== null && filter !== void 0 ? filter : '').toUpperCase();
82
+ return customizationProps.items.filter(function (x) { var _a, _b; return ((_a = x === null || x === void 0 ? void 0 : x.value) === null || _a === void 0 ? void 0 : _a.toUpperCase().includes(filtrationString)) || ((_b = x === null || x === void 0 ? void 0 : x.displayLabel) === null || _b === void 0 ? void 0 : _b.toUpperCase().includes(filtrationString)); });
83
+ };
84
+ var findNextActiveIndex = function (index, direction, items) {
85
+ var _a;
86
+ for (var i = index + direction; i > 0 && i <= items.length; i += direction) {
87
+ if (!((_a = items[i - 1]) === null || _a === void 0 ? void 0 : _a.disabled)) {
88
+ return i;
89
+ }
90
+ }
91
+ return index;
92
+ };
93
+ var handleKeyDown = function (e) {
94
+ var _a;
95
+ if (isOpen) {
96
+ if (e.key === 'ArrowUp' || e.key === 'Up') {
97
+ e.preventDefault();
98
+ var focusedNow = focused || focused === 0 ? focused : arrLength + 1;
99
+ if (!!focusedNow) {
100
+ focusedNow = focusedNow === 1 && haveTopItem() ? 0 : findNextActiveIndex(focusedNow, -1, getFilteredItems());
101
+ setNewFocusedElement(focusedNow);
102
+ }
103
+ }
104
+ else if (e.key === 'ArrowDown' || e.key === 'Down') {
105
+ e.preventDefault();
106
+ var focusedNow = focused;
107
+ focusedNow = !!focusedNow || focusedNow === 0 ? findNextActiveIndex(focusedNow, 1, getFilteredItems()) : haveTopItem() ? 0 : 1;
108
+ setNewFocusedElement(focusedNow);
109
+ }
110
+ else if (e.key === 'Escape' || e.key === 'Esc') {
111
+ setIsOpen(false);
112
+ setFocused(null);
113
+ if (onActiveDescendantChanged)
114
+ onActiveDescendantChanged(undefined);
115
+ }
116
+ else if ((e.key === 'Enter' || e.key === ' ') && focused !== null && e.target !== (actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.current)) {
117
+ e.preventDefault();
118
+ var focusedElement = elRefs[focused];
119
+ if (focusedElement) {
120
+ (_a = focusedElement.current) === null || _a === void 0 ? void 0 : _a.click();
121
+ }
122
+ if (onActiveDescendantChanged)
123
+ onActiveDescendantChanged(undefined);
124
+ }
125
+ }
126
+ };
127
+ React.useEffect(function () {
128
+ document.addEventListener('keydown', handleKeyDown);
129
+ return function () {
130
+ document.removeEventListener('keydown', handleKeyDown);
131
+ };
132
+ }, []);
133
+ var scrollPosition = React.useRef(0);
134
+ var handleScroll = function () {
135
+ var _a;
136
+ scrollPosition.current = (_a = itemsListRef.current) === null || _a === void 0 ? void 0 : _a.scrollTop;
137
+ };
138
+ React.useLayoutEffect(function () {
139
+ var _a;
140
+ if (itemsListRef.current)
141
+ itemsListRef.current.scrollTop = (_a = scrollPosition.current) !== null && _a !== void 0 ? _a : 0;
142
+ }, [selectedValues]);
143
+ var getCorrectRef = function (ref) {
144
+ switch (customizationProps.itemsType) {
145
+ case 'normal':
146
+ return ref || React.createRef();
147
+ default:
148
+ return ref || React.createRef();
149
+ }
150
+ };
151
+ var arrLength = getFilteredItems().length;
152
+ var _h = React.useState([]), elRefs = _h[0], setElRefs = _h[1];
153
+ React.useEffect(function () {
154
+ if ((elRefs === null || elRefs === void 0 ? void 0 : elRefs.length) !== arrLength) {
155
+ setFocused(null);
156
+ }
157
+ setElRefs(function (elRefs) {
158
+ return Array(arrLength + 1)
159
+ .fill(null)
160
+ .map(function (_, i) { return getCorrectRef(elRefs[i]); });
161
+ });
162
+ }, [isOpen, arrLength]);
163
+ React.useLayoutEffect(function () {
164
+ isOpen && !locationDefined && determineDropUp();
165
+ }, [isOpen, locationDefined]);
166
+ var haveTopItem = function () {
167
+ var _a;
168
+ if (!customizationProps.pinTopItem)
169
+ return false;
170
+ if (customizationProps.itemsType === 'radio' && selectedValues && (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) > 0)
171
+ return true;
172
+ else if (customizationProps.itemsType === 'checkbox' && (customizationProps.multiSelect || (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) > 0))
173
+ return true;
174
+ else if (customizationProps.itemsType === 'normal' && ((_a = getSuggestions()) === null || _a === void 0 ? void 0 : _a.length) > 0)
175
+ return true;
176
+ return false;
177
+ };
178
+ var getSuggestions = function () {
179
+ return getFilteredItems().filter(function (x) { return x.suggestion; });
180
+ };
181
+ /**
182
+ * when dropdown opens set correct position of focused item
183
+ * */
184
+ React.useLayoutEffect(function () {
185
+ if (isOpen && (focused || focused === 0)) {
186
+ setNewFocusedElement(focused === 0 && !haveTopItem() ? 1 : focused);
187
+ }
188
+ }, [isOpen, focused]);
189
+ /**
190
+ * Reset dropdown content state on close
191
+ * */
192
+ React.useEffect(function () {
193
+ var _a, _b, _c, _d, _e;
194
+ if (!isOpen) {
195
+ setLocationDefined(false);
196
+ for (var _i = 0, elRefs_1 = elRefs; _i < elRefs_1.length; _i++) {
197
+ var elRef = elRefs_1[_i];
198
+ (_a = elRef.current) === null || _a === void 0 ? void 0 : _a.classList.remove('dropdown-hover');
199
+ }
200
+ setFocused(null);
201
+ if (onActiveDescendantChanged)
202
+ onActiveDescendantChanged(undefined);
203
+ (_b = dropdownContentRef.current) === null || _b === void 0 ? void 0 : _b.classList.remove('outline');
204
+ (_c = dropdownContentRef.current) === null || _c === void 0 ? void 0 : _c.blur();
205
+ }
206
+ else {
207
+ if (outline) {
208
+ (_d = dropdownContentRef.current) === null || _d === void 0 ? void 0 : _d.classList.add('outline');
209
+ (_e = dropdownContentRef.current) === null || _e === void 0 ? void 0 : _e.focus();
210
+ }
211
+ }
212
+ }, [isOpen, dropdownContentRef, focused, outline]);
213
+ /**
214
+ * Scroll item container to top when dropdown opens
215
+ * */
216
+ React.useEffect(function () {
217
+ if (isOpen && itemsListRef.current) {
218
+ itemsListRef.current.scrollTop = 0;
219
+ }
220
+ }, [isOpen]);
221
+ React.useEffect(function () {
222
+ if (isOpen) {
223
+ var observer_1 = new IntersectionObserver(function (entries) {
224
+ var _a;
225
+ if (!entries[0].isIntersecting) {
226
+ setIsOpen(false);
227
+ //@ts-ignore
228
+ (_a = document === null || document === void 0 ? void 0 : document.activeElement) === null || _a === void 0 ? void 0 : _a.blur();
229
+ }
230
+ }, { threshold: [0], rootMargin: '8px' });
231
+ observer_1.observe(containerRef.current);
232
+ calculateOffset();
233
+ window.addEventListener('scroll', calculateOffset, true);
234
+ window.addEventListener('resize', calculateOffset);
235
+ return function () {
236
+ observer_1.disconnect();
237
+ window.removeEventListener('scroll', calculateOffset, true);
238
+ window.removeEventListener('resize', calculateOffset);
239
+ };
240
+ }
241
+ return function () { };
242
+ }, [isOpen]);
243
+ var handleItemClick = function (selected, item) {
244
+ var newValue = [];
245
+ if (customizationProps.multiSelect) {
246
+ if (selected)
247
+ newValue = __spreadArray(__spreadArray([], selectedValues, true), [item.value], false);
248
+ else
249
+ newValue = selectedValues.filter(function (x) { return x != item.value; });
250
+ }
251
+ else
252
+ newValue = selected ? [item.value] : [];
253
+ setSelectedValues(newValue);
254
+ if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValue)) {
255
+ setIsOpen(false);
256
+ }
257
+ };
258
+ var getTopItem = function () {
259
+ var _a, _b, _c, _d;
260
+ if (!customizationProps.pinTopItem)
261
+ return;
262
+ var visibleItems = getFilteredItems();
263
+ var allSelected = (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.filter(function (x) { return visibleItems.some(function (y) { return y.value == x; }); }).length) == visibleItems.length;
264
+ var showTopItem = false;
265
+ var suggestions = getSuggestions();
266
+ var displayLabel = selectedValues[0] ? (_b = (_a = customizationProps.items) === null || _a === void 0 ? void 0 : _a.find(function (c) { return c.value === selectedValues[0]; })) === null || _b === void 0 ? void 0 : _b.displayLabel : undefined;
267
+ if (customizationProps.itemsType == 'radio' && selectedValues && (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) > 0)
268
+ showTopItem = true;
269
+ else if (customizationProps.itemsType == 'checkbox' && (customizationProps.multiSelect || (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) > 0))
270
+ showTopItem = true;
271
+ else if (customizationProps.itemsType == 'normal' && suggestions.length > 0)
272
+ showTopItem = true;
273
+ if (!showTopItem)
274
+ return;
275
+ var selectedFirst = selectedValues.length > 0 ? visibleItems.find(function (x) { return x.value == selectedValues[0]; }) : null;
276
+ return (React.createElement(DropdownContentTopItemContainer, { size: size },
277
+ customizationProps.itemsType === 'radio' && (React.createElement(RadioButton, { ref: elRefs[0], role: 'menuitemradio', iconPointerEventsTransparent: true, onFocus: function (e) { return onActiveDescendantChanged && onActiveDescendantChanged("".concat(id, "_topitem")); }, tabIndexVal: -1, className: "".concat(focused === 0 ? 'dropdown-hover' : ''), select: function () { }, label: (_c = selectedFirst === null || selectedFirst === void 0 ? void 0 : selectedFirst.displayLabel) !== null && _c !== void 0 ? _c : selectedFirst === null || selectedFirst === void 0 ? void 0 : selectedFirst.value, size: size, id: "".concat(id, "_topitem"), selected: true })),
278
+ customizationProps.itemsType === 'checkbox' && (React.createElement(Checkbox, { ref: elRefs[0], role: 'menuitemcheckbox', tabIndexVal: -1, className: "".concat(focused === 0 ? 'dropdown-hover' : ''), select: function (selected) {
279
+ if (!customizationProps.multiSelect)
280
+ return;
281
+ var newValues = selected ? visibleItems.map(function (x) { return x.value; }) : [];
282
+ setSelectedValues(newValues);
283
+ if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValues))
284
+ setIsOpen(false);
285
+ }, onFocus: function (e) { return onActiveDescendantChanged && onActiveDescendantChanged("".concat(id, "_topitem")); }, iconPointerEventsTransparent: true, semiSelected: customizationProps.multiSelect && !allSelected && (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) > 0, size: size, id: "".concat(id, "_checkbox_selectall"), label: customizationProps.multiSelect ? 'Select all' : (_d = selectedFirst === null || selectedFirst === void 0 ? void 0 : selectedFirst.displayLabel) !== null && _d !== void 0 ? _d : selectedFirst === null || selectedFirst === void 0 ? void 0 : selectedFirst.value, selected: !customizationProps.multiSelect || allSelected })),
286
+ customizationProps.itemsType === 'normal' && (React.createElement(React.Fragment, null, suggestions.map(function (x) { return (React.createElement(MenuItem, { role: ariaRolesType == 'input' ? 'option' : 'menu', key: "".concat(id, "_topitem_").concat(x.value), item: x, size: size, active: false, tabIndex: -1, onFocus: function (e) { return onActiveDescendantChanged && onActiveDescendantChanged("".concat(id, "_topitem")); }, className: "".concat(focused === 0 ? 'dropdown-hover' : ''), ref: elRefs[0], id: "".concat(id, "_topitem"), onClickHandler: function (e) {
287
+ e.stopPropagation();
288
+ customizationProps.onValueUpdate([x.value]);
289
+ setSelectedValues([x.value]);
290
+ setIsOpen(false);
291
+ setFocused(null);
292
+ } })); })))));
293
+ };
294
+ var getElements = function (messageOnNoResults, size) {
295
+ if (getFilteredItems().length === 0) {
296
+ return React.createElement(MenuItem, { item: { value: messageOnNoResults, disabled: true }, size: size, id: "noResultsFound", active: false, onClickHandler: function (e) { } });
297
+ }
298
+ return (React.createElement(DropdownContentItemsContainer, { size: size }, getFilteredItems()
299
+ .filter(function (x) { return x && (customizationProps.itemsType != 'normal' || !x.suggestion); })
300
+ .map(function (item, index) {
301
+ var _a, _b;
302
+ return (React.createElement(React.Fragment, { key: "key_".concat(id, "_").concat(item.value) },
303
+ item.customContent,
304
+ !item.customContent && customizationProps.itemsType == 'radio' && (React.createElement(RadioButton, { role: 'menuitemradio', select: function (selected) { return handleItemClick(selected, item); }, ref: elRefs[index + 1], size: size, tabIndexVal: -1, className: "".concat(index + 1 === focused ? 'dropdown-hover' : ''), iconPointerEventsTransparent: true, disabled: item === null || item === void 0 ? void 0 : item.disabled, key: "key_".concat(id, "_").concat(index + 1), onFocus: function (e) { return onActiveDescendantChanged && onActiveDescendantChanged("".concat(id, "_").concat(index + 1)); }, id: "".concat(id, "_").concat(index + 1), label: (_a = item.displayLabel) !== null && _a !== void 0 ? _a : item.value, selected: selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.includes(item.value) })),
305
+ !item.customContent && customizationProps.itemsType == 'checkbox' && (React.createElement(Checkbox, { role: 'menuitemcheckbox', select: function (selected) { return handleItemClick(selected, item); }, iconPointerEventsTransparent: true, disabled: item === null || item === void 0 ? void 0 : item.disabled, className: "".concat(index + 1 === focused ? 'dropdown-hover' : ''), ref: elRefs[index + 1], size: size, tabIndexVal: -1, key: "key_".concat(id, "_").concat(index + 1), onFocus: function (e) { return onActiveDescendantChanged && onActiveDescendantChanged("".concat(id, "_").concat(index + 1)); }, id: "".concat(id, "_").concat(index + 1), label: (_b = item.displayLabel) !== null && _b !== void 0 ? _b : item.value, selected: selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.includes(item.value) })),
306
+ !item.customContent && (customizationProps.itemsType == 'normal' || !customizationProps.itemsType) && (React.createElement(MenuItem, { role: ariaRolesType == 'input' ? 'option' : 'menu', key: "key_".concat(id, "_").concat(index + 1), id: "".concat(id, "_").concat(index + 1), item: item, tabIndex: -1, className: "".concat(index + 1 === focused ? 'dropdown-hover' : ''), size: size, onFocus: function (e) { return onActiveDescendantChanged && onActiveDescendantChanged("".concat(id, "_").concat(index + 1)); }, active: selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.includes(item.value), ref: elRefs[index + 1], onClickHandler: function (e) {
307
+ e.stopPropagation();
308
+ customizationProps.onValueUpdate([item.value]);
309
+ setSelectedValues([item.value]);
310
+ setIsOpen(false);
311
+ setFocused(null);
312
+ } }))));
313
+ })));
314
+ };
315
+ var calculateOffset = function () {
316
+ var _a;
317
+ var rect = (_a = containerRef === null || containerRef === void 0 ? void 0 : containerRef.current) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect();
318
+ if (rect) {
319
+ dropdownContentRef.current.style.left = "".concat(rect.x + rect.width, "px");
320
+ dropdownContentRef.current.style.top = "".concat(rect.y + rect.height, "px");
321
+ dropdownContentRef.current.style.width = width !== null && width !== void 0 ? width : "".concat(rect.width, "px");
322
+ }
323
+ determineDropUp();
324
+ };
325
+ var cls = "".concat(isOpen ? 'show' : '', " ").concat(isOpen && outline ? 'outline' : '', " ").concat(locationDefined ? (isUp ? 'up' : 'down') : '');
326
+ return (React.createElement(Overlay, null,
327
+ React.createElement(DropdownContentContainer, { role: ariaRolesType == "menu" ? "menu" : "optionlist", ref: dropdownContentRef, size: size, offsetTop: offset.top, id: id, offsetLeft: offset.left, tabIndex: -1, isButton: isButton, alignLeft: alignLeft, scrollable: customizationProps.scrollable, maxHeight: customizationProps.maxHeight, className: cls },
328
+ React.createElement(DropdownContentListContainer, { role: "group", size: size, itemsType: customizationProps.itemsType, onScroll: handleScroll, ref: itemsListRef, outline: outline, scrollable: customizationProps.scrollable },
329
+ customizationProps.menuContent && (React.createElement(DropdownContentMenuContentContainer, { size: size },
330
+ customizationProps.menuContent,
331
+ React.createElement(DividerContainer, { size: size },
332
+ React.createElement("div", { className: "divider" })))),
333
+ customizationProps.pinTopItem && getTopItem(),
334
+ getElements(messageOnNoResults, size)),
335
+ customizationProps.action && customizationProps.actionLabel && (React.createElement(DropdownContentActionButtonContainer, { size: size, scrollable: customizationProps.scrollable },
336
+ React.createElement(Button, { width: "100%", role: "menuitem", icon: customizationProps.actionIcon, ref: actionButtonRef, loading: customizationProps.actionLoading, disabled: customizationProps.actionDisabled, variant: (_c = customizationProps.actionVariant) !== null && _c !== void 0 ? _c : 'primary', size: size, onClick: function () { return customizationProps.action() && setIsOpen(false); } }, customizationProps.actionLabel))))));
337
+ });
338
+ export default DropdownContent;
339
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6, templateObject_7, templateObject_8;
@@ -0,0 +1,161 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __rest = (this && this.__rest) || function (s, e) {
13
+ var t = {};
14
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
15
+ t[p] = s[p];
16
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
17
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
18
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
19
+ t[p[i]] = s[p[i]];
20
+ }
21
+ return t;
22
+ };
23
+ import * as React from 'react';
24
+ import { COLORS } from '../styles';
25
+ import { SystemIcons } from '../icons';
26
+ import { LoadingIndicator } from '../LoadingIndicator';
27
+ import { DropdownInputFieldStyles, DropdownContainer, DropdownInputField } from './CommonStyling';
28
+ import DropdownContent from './DropdownContent';
29
+ import { Size } from '../types';
30
+ import { AutofilledMessage, ErrorMessage } from '../InputFields';
31
+ import TooltipOverflow from '../Tooltips/TooltipOverflow';
32
+ import { defaultOnMouseDownHandler, useActionWithin, useClickOutsideRef, useFocusOutsideRef, useFocusVisibleRef } from '../common';
33
+ import { IconButton } from '../Button';
34
+ var DropdownFilter = React.forwardRef(function (_a, ref) {
35
+ var id = _a.id, list = _a.list, placeholder = _a.placeholder, onSelect = _a.onSelect, onInputChange = _a.onInputChange, value = _a.value, required = _a.required, messageOnNoResults = _a.messageOnNoResults, disabled = _a.disabled, readOnly = _a.readOnly, scrollable = _a.scrollable, activeValidationMessage = _a.activeValidationMessage, autofilledMessage = _a.autofilledMessage, size = _a.size, disableFiltering = _a.disableFiltering, margin = _a.margin, loading = _a.loading, onFocus = _a.onFocus, overflowTooltipPosition = _a.overflowTooltipPosition, onBlur = _a.onBlur, dataTestId = _a.dataTestId, rest = __rest(_a, ["id", "list", "placeholder", "onSelect", "onInputChange", "value", "required", "messageOnNoResults", "disabled", "readOnly", "scrollable", "activeValidationMessage", "autofilledMessage", "size", "disableFiltering", "margin", "loading", "onFocus", "overflowTooltipPosition", "onBlur", "dataTestId"]);
36
+ var _b = React.useState(false), isOpen = _b[0], setIsOpen = _b[1];
37
+ var _c = React.useState(), input = _c[0], setInput = _c[1];
38
+ var _d = React.useState(), activeDescendant = _d[0], setActiveDescendant = _d[1];
39
+ var _e = React.useState(false), restartFilter = _e[0], setRestartFilter = _e[1];
40
+ var _f = React.useState(), selectedItem = _f[0], setSelectedItem = _f[1];
41
+ var _g = React.useState([]), selectedValues = _g[0], setSelectedValues = _g[1];
42
+ var _h = React.useState(null), focused = _h[0], setFocused = _h[1];
43
+ var _j = React.useState(false), inputFocused = _j[0], setInputFocused = _j[1];
44
+ var _k = React.useState(true), init = _k[0], setInit = _k[1];
45
+ var styledFieldRef = useFocusVisibleRef();
46
+ var inputRef = useFocusVisibleRef([styledFieldRef]);
47
+ var clearButtonRef = React.useRef(null);
48
+ useActionWithin(styledFieldRef, input && !readOnly && !disabled ? [clearButtonRef] : []);
49
+ React.useImperativeHandle(ref, function () { return inputRef.current; }, [inputRef]);
50
+ var containerRef = useClickOutsideRef(function () { return setIsOpen(false); }, [], useFocusOutsideRef(function () { return setIsOpen(false); }));
51
+ var handleInputKeyDown = function (e) {
52
+ if (e.key === 'Esc' || e.key === 'Escape') {
53
+ e.preventDefault();
54
+ }
55
+ if (e.key === 'ArrowDown' || e.key === 'Down' || e.key === 'ArrowUp' || e.key === 'Up') {
56
+ e.preventDefault();
57
+ if (!isOpen) {
58
+ setIsOpen(true);
59
+ }
60
+ }
61
+ };
62
+ React.useEffect(function () {
63
+ setInit(true);
64
+ setSelectedValues(!!value ? [value] : []);
65
+ }, [value]);
66
+ React.useEffect(function () {
67
+ var _a, _b;
68
+ if (selectedValues === null || selectedValues === void 0 ? void 0 : selectedValues.length) {
69
+ var val_1 = selectedValues[0];
70
+ var item = list.find(function (a) { return a.value === val_1; });
71
+ setSelectedItem(item);
72
+ setInput((_b = (_a = item === null || item === void 0 ? void 0 : item.displayLabel) !== null && _a !== void 0 ? _a : item === null || item === void 0 ? void 0 : item.value) !== null && _b !== void 0 ? _b : '');
73
+ onSelect && !init && onSelect(val_1);
74
+ }
75
+ else {
76
+ setSelectedItem(undefined);
77
+ onSelect && !init && onSelect('');
78
+ setInput('');
79
+ }
80
+ }, [selectedValues]);
81
+ React.useEffect(function () {
82
+ var _a, _b;
83
+ if (!isOpen) {
84
+ if (!!selectedItem) {
85
+ setInput((_b = (_a = selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.displayLabel) !== null && _a !== void 0 ? _a : selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.value) !== null && _b !== void 0 ? _b : '');
86
+ }
87
+ else {
88
+ setInput('');
89
+ }
90
+ }
91
+ setRestartFilter(true);
92
+ }, [isOpen, selectedItem]);
93
+ var handleInputClear = function (e) {
94
+ var _a;
95
+ setInput('');
96
+ setSelectedValues([]);
97
+ onSelect && onSelect('');
98
+ (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus({ focusVisible: (e === null || e === void 0 ? void 0 : e.detail) !== 1 });
99
+ };
100
+ var renderInput = function () {
101
+ return (React.createElement(DropdownInputFieldStyles, { ref: styledFieldRef, className: size ? size : '', onClick: function (e) {
102
+ var _a, _b;
103
+ if (!readOnly && !disabled) {
104
+ e.stopPropagation();
105
+ setIsOpen(!isOpen);
106
+ if (isOpen) {
107
+ (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.blur();
108
+ }
109
+ else {
110
+ (_b = inputRef.current) === null || _b === void 0 ? void 0 : _b.focus();
111
+ }
112
+ }
113
+ }, disabled: disabled || false, readOnly: readOnly || false, isPlaceholder: !input, showValidationMessage: !!activeValidationMessage, onMouseDown: defaultOnMouseDownHandler, "data-testid": "otherdiv_".concat(id) },
114
+ React.createElement(DropdownInputField, __assign({ id: id, ref: inputRef, autoComplete: 'off-' + Math.floor(Math.random() * 999999999999), type: "search", placeholder: inputFocused ? '' : placeholder, onKeyDown: handleInputKeyDown, ellipsis: true, value: input || '', onChange: function (e) {
115
+ if (!e.target.value) {
116
+ setSelectedValues([]);
117
+ }
118
+ if (!readOnly && !disabled && e.target.value !== input) {
119
+ setRestartFilter(false);
120
+ setIsOpen(true);
121
+ setInput(e.target.value);
122
+ if (onInputChange) {
123
+ onInputChange(e.target.value || '');
124
+ }
125
+ }
126
+ }, onFocus: function (e) {
127
+ setInputFocused(true);
128
+ onFocus && onFocus(e);
129
+ }, onBlur: function (e) {
130
+ setInputFocused(false);
131
+ onBlur && onBlur(e);
132
+ }, required: required, tabIndex: disabled || readOnly ? -1 : 0, disabled: disabled || false, "data-testid": dataTestId }, rest)),
133
+ !isOpen ? React.createElement(TooltipOverflow, { position: overflowTooltipPosition, input: inputRef, withArrow: true, maxWidth: "100%", size: size, align: 'end' }, input) : null,
134
+ input && !readOnly && !disabled && !loading && (React.createElement(IconButton, { action: handleInputClear, ref: clearButtonRef, useTransparentBackground: true, shape: 'circular', style: { marginLeft: '-4px' }, variant: 'secondary' },
135
+ React.createElement(SystemIcons.Clear, null))),
136
+ !disabled && !readOnly && loading && (React.createElement("div", { style: { marginLeft: '-4xp' } },
137
+ React.createElement(LoadingIndicator, { size: Size.Small, color: COLORS.neutral_600 }))),
138
+ React.createElement("div", { className: 'dropdown-arrow' }, isOpen && !readOnly && !disabled ? React.createElement(SystemIcons.ArrowDropUp, { size: "24px", className: size ? size : '' }) : React.createElement(SystemIcons.ArrowDropDown, { size: "24px", className: size ? size : '' }))));
139
+ };
140
+ return (React.createElement(React.Fragment, null,
141
+ React.createElement(DropdownContainer, { ref: containerRef, role: "combobox", "aria-multiselectable": true, "aria-controls": "".concat(id, "_dropdowncontent"), "aria-activedescendant": activeDescendant, "aria-expanded": isOpen, disabled: disabled, isButton: false, readOnly: readOnly, className: size ? size : '', margin: margin },
142
+ renderInput(),
143
+ !readOnly && !disabled && (React.createElement(DropdownContent, { containerRef: containerRef, isOpen: isOpen && !loading, messageOnNoResults: messageOnNoResults !== null && messageOnNoResults !== void 0 ? messageOnNoResults : '', selectedValues: selectedValues, setSelectedValues: setSelectedValues, size: size !== null && size !== void 0 ? size : Size.Small, onActiveDescendantChanged: function (e) { return setActiveDescendant(e); }, focused: focused, ariaRolesType: "input", setFocused: setFocused, outline: false, customizationProps: {
144
+ itemsType: 'normal',
145
+ scrollable: scrollable,
146
+ multiSelect: false,
147
+ action: function () { },
148
+ onValueUpdate: function (values) {
149
+ setRestartFilter(true);
150
+ setInit(false);
151
+ },
152
+ items: list,
153
+ }, filter: !disableFiltering && !restartFilter ? input || '' : '', setIsOpen: setIsOpen, isButton: false, id: "".concat(id, "_dropdowncontent") }))),
154
+ activeValidationMessage && (React.createElement(ErrorMessage, { className: size || '' },
155
+ React.createElement(SystemIcons.TechnicalWarning, { color: COLORS.critical_400 }),
156
+ React.createElement("span", null, activeValidationMessage))),
157
+ autofilledMessage && (React.createElement(AutofilledMessage, { className: size || '' },
158
+ React.createElement(SystemIcons.Information, { color: COLORS.neutral_600 }),
159
+ React.createElement("span", null, autofilledMessage)))));
160
+ });
161
+ export default DropdownFilter;
@@ -0,0 +1,8 @@
1
+ export { default as DropdownContent } from './DropdownContent';
2
+ export * from './DropdownContent';
3
+ export { default as DropdownButton } from './DropdownButton';
4
+ export * from './DropdownButton';
5
+ export { default as DropdownFilter } from './DropdownFilter';
6
+ export * from './DropdownFilter';
7
+ export { default as BasicDropdown } from './BasicDropdown';
8
+ export * from './BasicDropdown';
@@ -0,0 +1,20 @@
1
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
2
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
3
+ return cooked;
4
+ };
5
+ import * as React from 'react';
6
+ import styled from 'styled-components';
7
+ import { HyperLink } from '../../HyperLink';
8
+ import { BREAKPOINTS, COLORS } from '../../styles';
9
+ import { ComponentTextStyle, ComponentXSStyling } from '../../styles/typography';
10
+ var FooterLinkSection = styled.section(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n min-height: 64px;\n color: white;\n display: flex;\n flex-direction: column;\n\n ", " {\n flex-direction: row;\n }\n"], ["\n min-height: 64px;\n color: white;\n display: flex;\n flex-direction: column;\n\n ", " {\n flex-direction: row;\n }\n"])), BREAKPOINTS.MEDIUM);
11
+ var FooterLinks = styled.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n display: flex;\n flex-direction: column;\n margin: 0 auto;\n\n ", " {\n flex-direction: row;\n margin: auto auto auto 0;\n }\n\n a {\n ", "\n &:not(:first-child) {\n margin: 16px 0 0 0;\n ", " {\n margin: 0 0 0 16px;\n }\n }\n }\n"], ["\n display: flex;\n flex-direction: column;\n margin: 0 auto;\n\n ", " {\n flex-direction: row;\n margin: auto auto auto 0;\n }\n\n a {\n ", "\n &:not(:first-child) {\n margin: 16px 0 0 0;\n ", " {\n margin: 0 0 0 16px;\n }\n }\n }\n"])), BREAKPOINTS.MEDIUM, ComponentXSStyling(ComponentTextStyle.Bold, null), BREAKPOINTS.MEDIUM);
12
+ var Copyright = styled.div(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n ", "\n margin: 16px auto 0 auto;\n\n ", " {\n margin: auto 0 auto auto;\n }\n"], ["\n ", "\n margin: 16px auto 0 auto;\n\n ", " {\n margin: auto 0 auto auto;\n }\n"])), ComponentXSStyling(ComponentTextStyle.Regular, COLORS.white), BREAKPOINTS.MEDIUM);
13
+ var FooterBottomLinks = function (_a) {
14
+ var bottomLinks = _a.bottomLinks, copyrightText = _a.copyrightText;
15
+ return (React.createElement(FooterLinkSection, null,
16
+ React.createElement(FooterLinks, null, bottomLinks === null || bottomLinks === void 0 ? void 0 : bottomLinks.map(function (bl, i) { return (React.createElement(HyperLink, { id: "FooterLink_".concat(Math.floor(Math.random() * 999999999999)), key: i, href: bl.to, variant: "inverted" }, bl.label)); })),
17
+ React.createElement(Copyright, null, copyrightText)));
18
+ };
19
+ export default FooterBottomLinks;
20
+ var templateObject_1, templateObject_2, templateObject_3;
@@ -0,0 +1,25 @@
1
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
2
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
3
+ return cooked;
4
+ };
5
+ import * as React from 'react';
6
+ import styled from 'styled-components';
7
+ import { COLORS, ComponentTextStyle, invertedFocusStyles } from '../../styles';
8
+ import { SystemIcons } from '../../icons';
9
+ import { ComponentMStyling, ComponentSStyling } from '../../styles';
10
+ import { HyperLink } from '../../HyperLink';
11
+ import { defaultOnMouseDownHandler } from '../../common';
12
+ var Wrapper = styled.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n width: 100%;\n border-top: 1px solid ", ";\n\n &:last-child {\n border-bottom: 1px solid ", ";\n }\n"], ["\n width: 100%;\n border-top: 1px solid ", ";\n\n &:last-child {\n border-bottom: 1px solid ", ";\n }\n"])), COLORS.neutral_100, COLORS.neutral_100);
13
+ var DropdownLinkBlock = styled.button(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n ", "\n\n display: ", ";\n justify-content: space-between;\n width: 100%;\n height: 48px;\n background-color: transparent;\n border: none;\n padding: 0 16px;\n\n &:hover,\n .open {\n background-color: ", ";\n color: ", ";\n }\n\n &:hover {\n cursor: pointer;\n }\n\n &:active {\n background-color: ", ";\n color: ", ";\n }\n\n &:focus {\n ", "\n }\n\n h3 {\n margin: auto 0;\n ", "\n }\n\n .open {\n h3 {\n background-color: ", ";\n color: ", ";\n }\n }\n\n svg {\n margin: auto 0;\n }\n"], ["\n ", "\n\n display: ", ";\n justify-content: space-between;\n width: 100%;\n height: 48px;\n background-color: transparent;\n border: none;\n padding: 0 16px;\n\n &:hover,\n .open {\n background-color: ", ";\n color: ", ";\n }\n\n &:hover {\n cursor: pointer;\n }\n\n &:active {\n background-color: ", ";\n color: ", ";\n }\n\n &:focus {\n ", "\n }\n\n h3 {\n margin: auto 0;\n ", "\n }\n\n .open {\n h3 {\n background-color: ", ";\n color: ", ";\n }\n }\n\n svg {\n margin: auto 0;\n }\n"])), ComponentSStyling(ComponentTextStyle.Bold, COLORS.white), function (props) { return (props.width > 768 ? 'none' : 'flex'); }, COLORS.neutral_20, COLORS.primary_700, COLORS.primary_100, COLORS.primary_800, invertedFocusStyles, ComponentMStyling(ComponentTextStyle.Regular, 'inherit'), COLORS.neutral_20, COLORS.neutral_800);
14
+ var LinkBlock = styled.div(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n display: none;\n flex-direction: column;\n font-weight: normal;\n width: 100%;\n\n &.show {\n display: flex;\n }\n\n a {\n text-decoration: none;\n\n ", "\n \n display: flex;\n align-items: center;\n \n padding: 0 16px;\n height: 48px;\n\n &:hover {\n background-color: ", ";\n color: ", ";\n cursor: pointer;\n }\n\n &:focus {\n ", "\n }\n\n &:active {\n background-color: ", ";\n color: ", ";\n }\n }\n"], ["\n display: none;\n flex-direction: column;\n font-weight: normal;\n width: 100%;\n\n &.show {\n display: flex;\n }\n\n a {\n text-decoration: none;\n\n ", "\n \n display: flex;\n align-items: center;\n \n padding: 0 16px;\n height: 48px;\n\n &:hover {\n background-color: ", ";\n color: ", ";\n cursor: pointer;\n }\n\n &:focus {\n ", "\n }\n\n &:active {\n background-color: ", ";\n color: ", ";\n }\n }\n"])), ComponentSStyling(ComponentTextStyle.Bold, COLORS.white), COLORS.neutral_20, COLORS.primary_700, invertedFocusStyles, COLORS.primary_100, COLORS.primary_800);
15
+ var FooterDropdownLinks = function (_a) {
16
+ var navSection = _a.navSection, width = _a.width;
17
+ var _b = React.useState(false), dropdownActive = _b[0], setDropdownActive = _b[1];
18
+ return (React.createElement(Wrapper, null,
19
+ React.createElement(DropdownLinkBlock, { width: width, className: dropdownActive ? 'open' : '', onMouseDown: defaultOnMouseDownHandler, onClick: function () { return setDropdownActive(!dropdownActive); } },
20
+ React.createElement("h3", null, navSection.header),
21
+ dropdownActive ? React.createElement(SystemIcons.ChevronUp, { size: "24px" }) : React.createElement(SystemIcons.ChevronDown, { size: "24px" })),
22
+ React.createElement(LinkBlock, { width: width, className: dropdownActive ? 'show' : '' }, navSection.links.map(function (item, index) { return (React.createElement(HyperLink, { key: index, id: "dropdownlink_".concat(Math.floor(Math.random() * 999999999999)), variant: 'inverted', href: item.to, target: item.target || '_blank', rel: "noreferrer noopener" }, item.label)); }))));
23
+ };
24
+ export default FooterDropdownLinks;
25
+ var templateObject_1, templateObject_2, templateObject_3;
@@ -0,0 +1,32 @@
1
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
2
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
3
+ return cooked;
4
+ };
5
+ import * as React from 'react';
6
+ import styled from 'styled-components';
7
+ import { BREAKPOINTS, COLORS, ComponentTextStyle } from '../../styles';
8
+ import FooterDropdownLinks from './FooterDropdownLinks';
9
+ import { ComponentLStyling, ComponentSStyling } from '../../styles/typography';
10
+ import { HyperLink } from '../../HyperLink';
11
+ import { hasWindow } from '../../utils/utils';
12
+ var NavSection = styled.section(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n flex-flow: flex-start;\n color: white;\n margin-bottom: 12px;\n"], ["\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n flex-flow: flex-start;\n color: white;\n margin-bottom: 12px;\n"])));
13
+ var LinkBlock = styled.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n display: ", ";\n flex-direction: column;\n font-weight: normal;\n width: 100%;\n\n ", " {\n padding: 0 24px 24px 0;\n width: calc(50% - 24px);\n }\n\n ", " {\n width: calc(33% - 24px);\n }\n ", " {\n padding: 0 32px 32px 0;\n width: calc(33% - 32px);\n }\n\n h3 {\n ", "\n }\n\n a {\n padding: 8px 0px;\n ", "\n }\n"], ["\n display: ", ";\n flex-direction: column;\n font-weight: normal;\n width: 100%;\n\n ", " {\n padding: 0 24px 24px 0;\n width: calc(50% - 24px);\n }\n\n ", " {\n width: calc(33% - 24px);\n }\n ", " {\n padding: 0 32px 32px 0;\n width: calc(33% - 32px);\n }\n\n h3 {\n ", "\n }\n\n a {\n padding: 8px 0px;\n ", "\n }\n"])), function (props) { return (props.width <= 768 ? 'none' : 'flex'); }, BREAKPOINTS.MEDIUM, BREAKPOINTS.LARGE, BREAKPOINTS.LARGE, ComponentLStyling(ComponentTextStyle.Regular, 'inherit'), ComponentSStyling(ComponentTextStyle.Bold, COLORS.white));
14
+ var FooterNavSection = function (_a) {
15
+ var _b;
16
+ var navOptions = _a.navOptions;
17
+ var _c = React.useState(hasWindow() ? window.innerWidth : -1), width = _c[0], setWidth = _c[1];
18
+ React.useEffect(function () {
19
+ function handleResize() {
20
+ setWidth(window.innerWidth);
21
+ }
22
+ window.addEventListener('resize', handleResize);
23
+ return function () { return window.removeEventListener('resize', handleResize); };
24
+ }, []);
25
+ return (React.createElement(NavSection, null, (_b = navOptions.sections) === null || _b === void 0 ? void 0 : _b.map(function (no, index) {
26
+ return width > 768 ? (React.createElement(LinkBlock, { key: "LinkBlock_".concat(index), width: width },
27
+ React.createElement("h3", null, no.header),
28
+ no.links.map(function (link, index) { return (React.createElement(HyperLink, { key: index, id: "dropdownlink_".concat(Math.floor(Math.random() * 999999999999)), variant: 'inverted', href: link.to, target: link.target || '_blank', rel: "noreferrer noopener" }, link.label)); }))) : (React.createElement(FooterDropdownLinks, { "data-testid": 'footerDropLinks', key: "LinkBlockDropdown_".concat(index), navSection: no, width: width }));
29
+ })));
30
+ };
31
+ export default FooterNavSection;
32
+ var templateObject_1, templateObject_2;