@dnanpm/styleguide 3.1.0 → 3.3.0

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 (518) hide show
  1. package/README.md +86 -86
  2. package/build/cjs/{assets/bundle-8de31ca3.css → build/assets/fonts/fonts.css} +129 -129
  3. package/build/cjs/components/Accordion/Accordion.d.ts +2 -1
  4. package/build/cjs/components/Accordion/Accordion.js +4 -4
  5. package/build/cjs/components/AccordionItem/AccordionItem.d.ts +4 -3
  6. package/build/cjs/components/AccordionItem/AccordionItem.js +5 -7
  7. package/build/cjs/components/AmountSelector/AmountSelector.d.ts +1 -1
  8. package/build/cjs/components/AmountSelector/AmountSelector.js +3 -5
  9. package/build/cjs/components/Box/Box.d.ts +2 -1
  10. package/build/cjs/components/Box/Box.js +1 -1
  11. package/build/cjs/components/Button/Button.d.ts +4 -3
  12. package/build/cjs/components/Button/ButtonArrow.d.ts +6 -5
  13. package/build/cjs/components/Button/ButtonArrow.js +6 -11
  14. package/build/cjs/components/Button/ButtonIcon.d.ts +1 -1
  15. package/build/cjs/components/Button/ButtonIcon.js +2 -2
  16. package/build/cjs/components/Checkbox/Checkbox.js +1 -1
  17. package/build/cjs/components/Chip/Chip.d.ts +3 -2
  18. package/build/cjs/components/DateTimePicker/DateTimePicker.d.ts +102 -0
  19. package/build/cjs/components/DateTimePicker/DateTimePicker.js +281 -0
  20. package/build/cjs/components/Divider/Divider.d.ts +2 -1
  21. package/build/cjs/components/DnaLogo/DnaLogo.d.ts +2 -1
  22. package/build/cjs/components/Drawer/Drawer.d.ts +2 -1
  23. package/build/cjs/components/Drawer/Drawer.js +2 -2
  24. package/build/cjs/components/EmptyState/EmptyState.d.ts +3 -2
  25. package/build/cjs/components/EmptyState/EmptyState.js +2 -2
  26. package/build/cjs/components/Floater/Floater.d.ts +2 -1
  27. package/build/cjs/components/Footer/Components/FooterComponents.d.ts +4 -71
  28. package/build/cjs/components/Footer/Components/FooterComponents.js +139 -211
  29. package/build/cjs/components/Footer/Footer.d.ts +4 -13
  30. package/build/cjs/components/Footer/Footer.js +183 -39
  31. package/build/cjs/components/Footer/context/FooterContext.d.ts +5 -4
  32. package/build/cjs/components/Footer/context/FooterContext.js +1 -5
  33. package/build/cjs/components/Icon/Icon.d.ts +8 -8
  34. package/build/cjs/components/Icon/Icon.js +14 -18
  35. package/build/cjs/components/Icons/Small/hlArrowBackSmall.d.ts +3 -0
  36. package/build/cjs/components/Icons/Small/hlArrowForwardSmall.d.ts +3 -0
  37. package/build/cjs/components/Icons/Small/hlArrowUnderSmall.d.ts +3 -0
  38. package/build/cjs/components/Icons/Small/hlCalendarSmall.d.ts +4 -1
  39. package/build/cjs/components/Icons/Small/hlChevronDownSmall.d.ts +4 -1
  40. package/build/cjs/components/Icons/Small/hlChevronLeftSmall.d.ts +4 -1
  41. package/build/cjs/components/Icons/Small/hlChevronRightSmall.d.ts +4 -1
  42. package/build/cjs/components/Icons/Small/hlChevronUpSmall.d.ts +4 -1
  43. package/build/cjs/components/Icons/Small/hlClockSmall.d.ts +4 -1
  44. package/build/cjs/components/Icons/Small/hlDownloadSmall.d.ts +4 -1
  45. package/build/cjs/components/Icons/Small/hlExternalSmall.d.ts +4 -1
  46. package/build/cjs/components/Icons/Small/hlUploadSmall.d.ts +4 -1
  47. package/build/cjs/components/Icons/Social/facebook.d.ts +4 -1
  48. package/build/cjs/components/Icons/Social/instagram.d.ts +4 -1
  49. package/build/cjs/components/Icons/Social/linkedin.d.ts +4 -1
  50. package/build/cjs/components/Icons/Social/tiktok.d.ts +4 -1
  51. package/build/cjs/components/Icons/Social/twitter.d.ts +4 -1
  52. package/build/cjs/components/Icons/Social/youtube.d.ts +4 -1
  53. package/build/cjs/components/Icons/hl404.d.ts +4 -1
  54. package/build/cjs/components/Icons/hl4gSim.d.ts +4 -1
  55. package/build/cjs/components/Icons/hl5gSim.d.ts +4 -1
  56. package/build/cjs/components/Icons/hlBattery.d.ts +4 -1
  57. package/build/cjs/components/Icons/hlBell.d.ts +4 -1
  58. package/build/cjs/components/Icons/hlCableTVCard.d.ts +3 -0
  59. package/build/cjs/components/Icons/hlCalendar.d.ts +4 -1
  60. package/build/cjs/components/Icons/hlCall.d.ts +4 -1
  61. package/build/cjs/components/Icons/hlCameraBack.d.ts +4 -1
  62. package/build/cjs/components/Icons/hlCameraFront.d.ts +4 -1
  63. package/build/cjs/components/Icons/hlCart.d.ts +4 -1
  64. package/build/cjs/components/Icons/hlCartEmpty.d.ts +4 -1
  65. package/build/cjs/components/Icons/hlChat.d.ts +4 -1
  66. package/build/cjs/components/Icons/hlCheck.d.ts +6 -1
  67. package/build/cjs/components/Icons/hlCheck.js +2 -0
  68. package/build/cjs/components/Icons/hlChevronDown.d.ts +4 -1
  69. package/build/cjs/components/Icons/hlChevronLeft.d.ts +4 -1
  70. package/build/cjs/components/Icons/hlChevronRight.d.ts +4 -1
  71. package/build/cjs/components/Icons/hlChevronUp.d.ts +4 -1
  72. package/build/cjs/components/Icons/hlCompensation.d.ts +4 -1
  73. package/build/cjs/components/Icons/hlCookie.d.ts +4 -1
  74. package/build/cjs/components/Icons/hlCopy.d.ts +4 -1
  75. package/build/cjs/components/Icons/hlCoupon.d.ts +4 -1
  76. package/build/cjs/components/Icons/hlDelivery.d.ts +4 -1
  77. package/build/cjs/components/Icons/hlDigiturva.d.ts +4 -1
  78. package/build/cjs/components/Icons/hlDisplaySize.d.ts +4 -1
  79. package/build/cjs/components/Icons/hlDocument.d.ts +4 -1
  80. package/build/cjs/components/Icons/hlDownload.d.ts +4 -1
  81. package/build/cjs/components/Icons/hlEnvelope.d.ts +4 -1
  82. package/build/cjs/components/Icons/hlError.d.ts +4 -1
  83. package/build/cjs/components/Icons/hlEuro.d.ts +4 -1
  84. package/build/cjs/components/Icons/hlExclamationMark.d.ts +4 -1
  85. package/build/cjs/components/Icons/hlExpand.d.ts +4 -1
  86. package/build/cjs/components/Icons/hlExternal.d.ts +4 -1
  87. package/build/cjs/components/Icons/hlEyeClosed.d.ts +4 -1
  88. package/build/cjs/components/Icons/hlEyeOpen.d.ts +4 -1
  89. package/build/cjs/components/Icons/hlFaceId.d.ts +4 -1
  90. package/build/cjs/components/Icons/hlFastDelivery.d.ts +4 -1
  91. package/build/cjs/components/Icons/hlFingerprint.d.ts +4 -1
  92. package/build/cjs/components/Icons/hlGlobe.d.ts +4 -1
  93. package/build/cjs/components/Icons/hlHeadphones.d.ts +4 -1
  94. package/build/cjs/components/Icons/hlHeadset.d.ts +4 -1
  95. package/build/cjs/components/Icons/hlHeart.d.ts +4 -1
  96. package/build/cjs/components/Icons/hlHome.d.ts +4 -1
  97. package/build/cjs/components/Icons/hlHub.d.ts +3 -0
  98. package/build/cjs/components/Icons/hlImage.d.ts +4 -1
  99. package/build/cjs/components/Icons/hlInfo.d.ts +4 -1
  100. package/build/cjs/components/Icons/hlInstallment.d.ts +4 -1
  101. package/build/cjs/components/Icons/hlIotSim.d.ts +4 -1
  102. package/build/cjs/components/Icons/hlLaptop.d.ts +3 -0
  103. package/build/cjs/components/Icons/hlLink.d.ts +7 -0
  104. package/build/cjs/components/Icons/hlLink.js +19 -0
  105. package/build/cjs/components/Icons/hlLiveVideo.d.ts +3 -0
  106. package/build/cjs/components/Icons/hlLock.d.ts +4 -1
  107. package/build/cjs/components/Icons/hlMagnifyingGlass.d.ts +4 -1
  108. package/build/cjs/components/Icons/hlMarker.d.ts +3 -0
  109. package/build/cjs/components/Icons/hlMemory.d.ts +4 -1
  110. package/build/cjs/components/Icons/hlMenu.d.ts +4 -1
  111. package/build/cjs/components/Icons/hlMinimize.d.ts +4 -1
  112. package/build/cjs/components/Icons/hlMinus.d.ts +4 -1
  113. package/build/cjs/components/Icons/hlMobileData.d.ts +4 -1
  114. package/build/cjs/components/Icons/hlMobilePayment.d.ts +4 -1
  115. package/build/cjs/components/Icons/hlModem.d.ts +4 -1
  116. package/build/cjs/components/Icons/hlMore.d.ts +4 -1
  117. package/build/cjs/components/Icons/hlOs.d.ts +4 -1
  118. package/build/cjs/components/Icons/hlPackage.d.ts +4 -1
  119. package/build/cjs/components/Icons/hlPaperclip.d.ts +4 -1
  120. package/build/cjs/components/Icons/hlPaytime.d.ts +4 -1
  121. package/build/cjs/components/Icons/hlPen.d.ts +4 -1
  122. package/build/cjs/components/Icons/hlPerson.d.ts +4 -1
  123. package/build/cjs/components/Icons/hlPhone.d.ts +4 -1
  124. package/build/cjs/components/Icons/hlPlaylist.d.ts +3 -0
  125. package/build/cjs/components/Icons/hlPlus.d.ts +4 -1
  126. package/build/cjs/components/Icons/hlPrepaid.d.ts +4 -1
  127. package/build/cjs/components/Icons/hlProcessor.d.ts +4 -1
  128. package/build/cjs/components/Icons/hlServices.d.ts +4 -1
  129. package/build/cjs/components/Icons/hlSettings.d.ts +4 -1
  130. package/build/cjs/components/Icons/hlShield.d.ts +4 -1
  131. package/build/cjs/components/Icons/hlSim.d.ts +4 -1
  132. package/build/cjs/components/Icons/hlSimSimple.d.ts +4 -1
  133. package/build/cjs/components/Icons/hlSmile.d.ts +4 -1
  134. package/build/cjs/components/Icons/hlSpeechBubble.d.ts +4 -1
  135. package/build/cjs/components/Icons/hlSquaretrade.d.ts +4 -1
  136. package/build/cjs/components/Icons/hlStar.d.ts +4 -1
  137. package/build/cjs/components/Icons/hlStarFilled.d.ts +4 -1
  138. package/build/cjs/components/Icons/hlTrash.d.ts +4 -1
  139. package/build/cjs/components/Icons/hlTv.d.ts +4 -1
  140. package/build/cjs/components/Icons/hlUnlock.d.ts +4 -1
  141. package/build/cjs/components/Icons/hlUpload.d.ts +4 -1
  142. package/build/cjs/components/Icons/hlWarning.d.ts +4 -1
  143. package/build/cjs/components/Icons/hlWifi.d.ts +4 -1
  144. package/build/cjs/components/Icons/hlWrench.d.ts +3 -0
  145. package/build/cjs/components/Icons/hlX.d.ts +4 -1
  146. package/build/cjs/components/Icons/index.d.ts +1 -0
  147. package/build/cjs/components/Icons/index.js +2 -0
  148. package/build/cjs/components/Input/Input.d.ts +28 -11
  149. package/build/cjs/components/Input/Input.js +58 -36
  150. package/build/cjs/components/Label/Label.d.ts +2 -1
  151. package/build/cjs/components/LabelText/LabelText.d.ts +2 -1
  152. package/build/cjs/components/MainHeaderNavigation/ChildComponents/BusinessMenu.d.ts +10 -0
  153. package/build/cjs/components/MainHeaderNavigation/ChildComponents/BusinessMenu.js +62 -0
  154. package/build/cjs/components/MainHeaderNavigation/ChildComponents/DesktopMenu.d.ts +3 -0
  155. package/build/cjs/components/MainHeaderNavigation/ChildComponents/DesktopMenu.js +206 -0
  156. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LanguageSelector.d.ts +4 -0
  157. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LanguageSelector.js +39 -0
  158. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LinkModifier.d.ts +10 -0
  159. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LinkModifier.js +42 -0
  160. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LoginTooltip.d.ts +7 -0
  161. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LoginTooltip.js +23 -0
  162. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.d.ts +193 -0
  163. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.js +121 -0
  164. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.d.ts +169 -0
  165. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.js +68 -0
  166. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MinicartTooltip.d.ts +7 -0
  167. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MinicartTooltip.js +26 -0
  168. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MobileMenu.d.ts +3 -0
  169. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MobileMenu.js +194 -0
  170. package/build/cjs/components/MainHeaderNavigation/ChildComponents/PageSearch.d.ts +6 -0
  171. package/build/cjs/components/MainHeaderNavigation/ChildComponents/PageSearch.js +23 -0
  172. package/build/cjs/components/MainHeaderNavigation/MainHeaderNavigation.d.ts +36 -0
  173. package/build/cjs/components/MainHeaderNavigation/MainHeaderNavigation.js +323 -0
  174. package/build/cjs/components/MainHeaderNavigation/context/MobileMenuContext.d.ts +6 -0
  175. package/build/cjs/components/MainHeaderNavigation/context/MobileMenuContext.js +11 -0
  176. package/build/cjs/components/MainHeaderNavigation/context/NavContext.d.ts +29 -0
  177. package/build/cjs/components/MainHeaderNavigation/context/NavContext.js +56 -0
  178. package/build/cjs/components/MainHeaderNavigation/globalNavStyles.d.ts +1482 -0
  179. package/build/cjs/components/MainHeaderNavigation/globalNavStyles.js +189 -0
  180. package/build/cjs/components/MainNavigation/ChildComponents/DesktopMenu.d.ts +2 -2
  181. package/build/cjs/components/MainNavigation/ChildComponents/DesktopMenu.js +35 -36
  182. package/build/cjs/components/MainNavigation/ChildComponents/HeaderNavigationElements.d.ts +2 -2
  183. package/build/cjs/components/MainNavigation/ChildComponents/HeaderNavigationElements.js +5 -7
  184. package/build/cjs/components/MainNavigation/ChildComponents/LanguageSelector.d.ts +1 -1
  185. package/build/cjs/components/MainNavigation/ChildComponents/LanguageSelector.js +12 -16
  186. package/build/cjs/components/MainNavigation/ChildComponents/LinkModifier.d.ts +1 -1
  187. package/build/cjs/components/MainNavigation/ChildComponents/LinkModifier.js +9 -9
  188. package/build/cjs/components/MainNavigation/ChildComponents/LoginTooltip.js +4 -7
  189. package/build/cjs/components/MainNavigation/ChildComponents/MainNavTooltipMenu.d.ts +5 -4
  190. package/build/cjs/components/MainNavigation/ChildComponents/MainNavTooltipMenu.js +10 -10
  191. package/build/cjs/components/MainNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.d.ts +4 -2
  192. package/build/cjs/components/MainNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.js +2 -2
  193. package/build/cjs/components/MainNavigation/ChildComponents/MinicartTooltip.js +5 -8
  194. package/build/cjs/components/MainNavigation/ChildComponents/MobileMenu.d.ts +1 -1
  195. package/build/cjs/components/MainNavigation/ChildComponents/MobileMenu.js +24 -22
  196. package/build/cjs/components/MainNavigation/ChildComponents/PageSearch.js +4 -7
  197. package/build/cjs/components/MainNavigation/ChildComponents/Ribbon.d.ts +2 -2
  198. package/build/cjs/components/MainNavigation/MainNavigation.d.ts +5 -5
  199. package/build/cjs/components/MainNavigation/MainNavigation.js +100 -74
  200. package/build/cjs/components/MainNavigation/context/MobileMenuContext.d.ts +3 -3
  201. package/build/cjs/components/MainNavigation/context/MobileMenuContext.js +1 -5
  202. package/build/cjs/components/MainNavigation/context/NavContext.d.ts +14 -15
  203. package/build/cjs/components/MainNavigation/context/NavContext.js +6 -5
  204. package/build/cjs/components/MainNavigation/globalNavStyles.d.ts +4 -4
  205. package/build/cjs/components/Modal/Modal.d.ts +2 -1
  206. package/build/cjs/components/Modal/Modal.js +2 -2
  207. package/build/cjs/components/Notification/Notification.d.ts +3 -2
  208. package/build/cjs/components/Notification/Notification.js +6 -10
  209. package/build/cjs/components/NotificationBadge/NotificationBadge.d.ts +2 -1
  210. package/build/cjs/components/Pill/Pill.d.ts +4 -3
  211. package/build/cjs/components/ProgressIndicator/ProgressIndicator.d.ts +2 -1
  212. package/build/cjs/components/ProgressIndicator/ProgressIndicator.js +2 -3
  213. package/build/cjs/components/RadioButton/RadioButton.d.ts +2 -1
  214. package/build/cjs/components/ReadMore/ReadMore.d.ts +4 -4
  215. package/build/cjs/components/ReadMore/ReadMore.js +2 -4
  216. package/build/cjs/components/Search/Search.d.ts +7 -6
  217. package/build/cjs/components/Search/Search.js +3 -4
  218. package/build/cjs/components/SecondaryNavigation/SecondaryNavigation.d.ts +19 -2
  219. package/build/cjs/components/SecondaryNavigation/SecondaryNavigation.js +25 -33
  220. package/build/cjs/components/Selectbox/Selectbox.js +10 -15
  221. package/build/cjs/components/Selectbox/__tests__/Selectbox.spec.d.ts +1 -0
  222. package/build/cjs/components/Tabs/Tab.d.ts +5 -3
  223. package/build/cjs/components/Tabs/Tab.js +1 -1
  224. package/build/cjs/components/Tabs/Tabs.d.ts +18 -19
  225. package/build/cjs/components/Tabs/Tabs.js +3 -3
  226. package/build/cjs/components/Textarea/Textarea.d.ts +6 -5
  227. package/build/cjs/components/Toaster/Toaster.d.ts +3 -2
  228. package/build/cjs/components/Toaster/Toaster.js +7 -11
  229. package/build/cjs/components/Tooltip/Tooltip.d.ts +2 -1
  230. package/build/cjs/components/Tooltip/Tooltip.js +3 -3
  231. package/build/cjs/components/TooltipMenu/ChildComponents/TooltipMenuExportedStyles.d.ts +2 -2
  232. package/build/cjs/components/TooltipMenu/TooltipMenu.d.ts +2 -1
  233. package/build/cjs/components/TooltipMenu/TooltipMenu.js +2 -3
  234. package/build/cjs/components/index.d.ts +3 -1
  235. package/build/cjs/hooks/useCloseOutsideOrElementClicked.js +3 -2
  236. package/build/cjs/hooks/useDebounce.d.ts +2 -0
  237. package/build/cjs/hooks/useDebounce.js +23 -0
  238. package/build/cjs/hooks/useDocHeight.d.ts +2 -1
  239. package/build/cjs/hooks/useDocHeight.js +5 -25
  240. package/build/cjs/hooks/useResizeObserver.d.ts +6 -0
  241. package/build/cjs/hooks/{useElementDimensions.js → useResizeObserver.js} +5 -5
  242. package/build/cjs/hooks/useScrollPosition.d.ts +2 -3
  243. package/build/cjs/hooks/useScrollPosition.js +8 -14
  244. package/build/cjs/index.js +6 -0
  245. package/build/cjs/themes/globalStyles.d.ts +3 -3
  246. package/build/cjs/themes/styled.d.ts +7 -7
  247. package/build/cjs/themes/theme.d.ts +1 -1
  248. package/build/cjs/themes/themeComponents/navigation.d.ts +8 -0
  249. package/build/cjs/themes/themeComponents/navigation.js +14 -1
  250. package/build/cjs/utils/common.d.ts +2 -1
  251. package/build/cjs/utils/common.js +1 -1
  252. package/build/cjs/utils/createStyled.d.ts +163 -2
  253. package/build/cjs/utils/createStyled.js +2 -2
  254. package/build/cjs/utils/styledUtils.d.ts +1 -1
  255. package/build/es/{assets/bundle-8de31ca3.css → build/assets/fonts/fonts.css} +129 -129
  256. package/build/es/components/Accordion/Accordion.d.ts +2 -1
  257. package/build/es/components/Accordion/Accordion.js +5 -5
  258. package/build/es/components/AccordionItem/AccordionItem.d.ts +4 -3
  259. package/build/es/components/AccordionItem/AccordionItem.js +4 -6
  260. package/build/es/components/AmountSelector/AmountSelector.d.ts +1 -1
  261. package/build/es/components/AmountSelector/AmountSelector.js +3 -5
  262. package/build/es/components/Box/Box.d.ts +2 -1
  263. package/build/es/components/Box/Box.js +1 -1
  264. package/build/es/components/Button/Button.d.ts +4 -3
  265. package/build/es/components/Button/ButtonArrow.d.ts +6 -5
  266. package/build/es/components/Button/ButtonArrow.js +7 -12
  267. package/build/es/components/Button/ButtonIcon.d.ts +1 -1
  268. package/build/es/components/Button/ButtonIcon.js +2 -2
  269. package/build/es/components/Checkbox/Checkbox.js +1 -1
  270. package/build/es/components/Chip/Chip.d.ts +3 -2
  271. package/build/es/components/DateTimePicker/DateTimePicker.d.ts +102 -0
  272. package/build/es/components/DateTimePicker/DateTimePicker.js +271 -0
  273. package/build/es/components/Divider/Divider.d.ts +2 -1
  274. package/build/es/components/DnaLogo/DnaLogo.d.ts +2 -1
  275. package/build/es/components/Drawer/Drawer.d.ts +2 -1
  276. package/build/es/components/Drawer/Drawer.js +2 -2
  277. package/build/es/components/EmptyState/EmptyState.d.ts +3 -2
  278. package/build/es/components/EmptyState/EmptyState.js +2 -2
  279. package/build/es/components/Floater/Floater.d.ts +2 -1
  280. package/build/es/components/Footer/Components/FooterComponents.d.ts +4 -71
  281. package/build/es/components/Footer/Components/FooterComponents.js +139 -209
  282. package/build/es/components/Footer/Footer.d.ts +4 -13
  283. package/build/es/components/Footer/Footer.js +185 -41
  284. package/build/es/components/Footer/context/FooterContext.d.ts +5 -4
  285. package/build/es/components/Footer/context/FooterContext.js +2 -2
  286. package/build/es/components/Icon/Icon.d.ts +8 -8
  287. package/build/es/components/Icon/Icon.js +14 -18
  288. package/build/es/components/Icons/Small/hlArrowBackSmall.d.ts +3 -0
  289. package/build/es/components/Icons/Small/hlArrowForwardSmall.d.ts +3 -0
  290. package/build/es/components/Icons/Small/hlArrowUnderSmall.d.ts +3 -0
  291. package/build/es/components/Icons/Small/hlCalendarSmall.d.ts +4 -1
  292. package/build/es/components/Icons/Small/hlChevronDownSmall.d.ts +4 -1
  293. package/build/es/components/Icons/Small/hlChevronLeftSmall.d.ts +4 -1
  294. package/build/es/components/Icons/Small/hlChevronRightSmall.d.ts +4 -1
  295. package/build/es/components/Icons/Small/hlChevronUpSmall.d.ts +4 -1
  296. package/build/es/components/Icons/Small/hlClockSmall.d.ts +4 -1
  297. package/build/es/components/Icons/Small/hlDownloadSmall.d.ts +4 -1
  298. package/build/es/components/Icons/Small/hlExternalSmall.d.ts +4 -1
  299. package/build/es/components/Icons/Small/hlUploadSmall.d.ts +4 -1
  300. package/build/es/components/Icons/Social/facebook.d.ts +4 -1
  301. package/build/es/components/Icons/Social/instagram.d.ts +4 -1
  302. package/build/es/components/Icons/Social/linkedin.d.ts +4 -1
  303. package/build/es/components/Icons/Social/tiktok.d.ts +4 -1
  304. package/build/es/components/Icons/Social/twitter.d.ts +4 -1
  305. package/build/es/components/Icons/Social/youtube.d.ts +4 -1
  306. package/build/es/components/Icons/hl404.d.ts +4 -1
  307. package/build/es/components/Icons/hl4gSim.d.ts +4 -1
  308. package/build/es/components/Icons/hl5gSim.d.ts +4 -1
  309. package/build/es/components/Icons/hlBattery.d.ts +4 -1
  310. package/build/es/components/Icons/hlBell.d.ts +4 -1
  311. package/build/es/components/Icons/hlCableTVCard.d.ts +3 -0
  312. package/build/es/components/Icons/hlCalendar.d.ts +4 -1
  313. package/build/es/components/Icons/hlCall.d.ts +4 -1
  314. package/build/es/components/Icons/hlCameraBack.d.ts +4 -1
  315. package/build/es/components/Icons/hlCameraFront.d.ts +4 -1
  316. package/build/es/components/Icons/hlCart.d.ts +4 -1
  317. package/build/es/components/Icons/hlCartEmpty.d.ts +4 -1
  318. package/build/es/components/Icons/hlChat.d.ts +4 -1
  319. package/build/es/components/Icons/hlCheck.d.ts +6 -1
  320. package/build/es/components/Icons/hlCheck.js +2 -0
  321. package/build/es/components/Icons/hlChevronDown.d.ts +4 -1
  322. package/build/es/components/Icons/hlChevronLeft.d.ts +4 -1
  323. package/build/es/components/Icons/hlChevronRight.d.ts +4 -1
  324. package/build/es/components/Icons/hlChevronUp.d.ts +4 -1
  325. package/build/es/components/Icons/hlCompensation.d.ts +4 -1
  326. package/build/es/components/Icons/hlCookie.d.ts +4 -1
  327. package/build/es/components/Icons/hlCopy.d.ts +4 -1
  328. package/build/es/components/Icons/hlCoupon.d.ts +4 -1
  329. package/build/es/components/Icons/hlDelivery.d.ts +4 -1
  330. package/build/es/components/Icons/hlDigiturva.d.ts +4 -1
  331. package/build/es/components/Icons/hlDisplaySize.d.ts +4 -1
  332. package/build/es/components/Icons/hlDocument.d.ts +4 -1
  333. package/build/es/components/Icons/hlDownload.d.ts +4 -1
  334. package/build/es/components/Icons/hlEnvelope.d.ts +4 -1
  335. package/build/es/components/Icons/hlError.d.ts +4 -1
  336. package/build/es/components/Icons/hlEuro.d.ts +4 -1
  337. package/build/es/components/Icons/hlExclamationMark.d.ts +4 -1
  338. package/build/es/components/Icons/hlExpand.d.ts +4 -1
  339. package/build/es/components/Icons/hlExternal.d.ts +4 -1
  340. package/build/es/components/Icons/hlEyeClosed.d.ts +4 -1
  341. package/build/es/components/Icons/hlEyeOpen.d.ts +4 -1
  342. package/build/es/components/Icons/hlFaceId.d.ts +4 -1
  343. package/build/es/components/Icons/hlFastDelivery.d.ts +4 -1
  344. package/build/es/components/Icons/hlFingerprint.d.ts +4 -1
  345. package/build/es/components/Icons/hlGlobe.d.ts +4 -1
  346. package/build/es/components/Icons/hlHeadphones.d.ts +4 -1
  347. package/build/es/components/Icons/hlHeadset.d.ts +4 -1
  348. package/build/es/components/Icons/hlHeart.d.ts +4 -1
  349. package/build/es/components/Icons/hlHome.d.ts +4 -1
  350. package/build/es/components/Icons/hlHub.d.ts +3 -0
  351. package/build/es/components/Icons/hlImage.d.ts +4 -1
  352. package/build/es/components/Icons/hlInfo.d.ts +4 -1
  353. package/build/es/components/Icons/hlInstallment.d.ts +4 -1
  354. package/build/es/components/Icons/hlIotSim.d.ts +4 -1
  355. package/build/es/components/Icons/hlLaptop.d.ts +3 -0
  356. package/build/es/components/Icons/hlLink.d.ts +7 -0
  357. package/build/es/components/Icons/hlLink.js +11 -0
  358. package/build/es/components/Icons/hlLiveVideo.d.ts +3 -0
  359. package/build/es/components/Icons/hlLock.d.ts +4 -1
  360. package/build/es/components/Icons/hlMagnifyingGlass.d.ts +4 -1
  361. package/build/es/components/Icons/hlMarker.d.ts +3 -0
  362. package/build/es/components/Icons/hlMemory.d.ts +4 -1
  363. package/build/es/components/Icons/hlMenu.d.ts +4 -1
  364. package/build/es/components/Icons/hlMinimize.d.ts +4 -1
  365. package/build/es/components/Icons/hlMinus.d.ts +4 -1
  366. package/build/es/components/Icons/hlMobileData.d.ts +4 -1
  367. package/build/es/components/Icons/hlMobilePayment.d.ts +4 -1
  368. package/build/es/components/Icons/hlModem.d.ts +4 -1
  369. package/build/es/components/Icons/hlMore.d.ts +4 -1
  370. package/build/es/components/Icons/hlOs.d.ts +4 -1
  371. package/build/es/components/Icons/hlPackage.d.ts +4 -1
  372. package/build/es/components/Icons/hlPaperclip.d.ts +4 -1
  373. package/build/es/components/Icons/hlPaytime.d.ts +4 -1
  374. package/build/es/components/Icons/hlPen.d.ts +4 -1
  375. package/build/es/components/Icons/hlPerson.d.ts +4 -1
  376. package/build/es/components/Icons/hlPhone.d.ts +4 -1
  377. package/build/es/components/Icons/hlPlaylist.d.ts +3 -0
  378. package/build/es/components/Icons/hlPlus.d.ts +4 -1
  379. package/build/es/components/Icons/hlPrepaid.d.ts +4 -1
  380. package/build/es/components/Icons/hlProcessor.d.ts +4 -1
  381. package/build/es/components/Icons/hlServices.d.ts +4 -1
  382. package/build/es/components/Icons/hlSettings.d.ts +4 -1
  383. package/build/es/components/Icons/hlShield.d.ts +4 -1
  384. package/build/es/components/Icons/hlSim.d.ts +4 -1
  385. package/build/es/components/Icons/hlSimSimple.d.ts +4 -1
  386. package/build/es/components/Icons/hlSmile.d.ts +4 -1
  387. package/build/es/components/Icons/hlSpeechBubble.d.ts +4 -1
  388. package/build/es/components/Icons/hlSquaretrade.d.ts +4 -1
  389. package/build/es/components/Icons/hlStar.d.ts +4 -1
  390. package/build/es/components/Icons/hlStarFilled.d.ts +4 -1
  391. package/build/es/components/Icons/hlTrash.d.ts +4 -1
  392. package/build/es/components/Icons/hlTv.d.ts +4 -1
  393. package/build/es/components/Icons/hlUnlock.d.ts +4 -1
  394. package/build/es/components/Icons/hlUpload.d.ts +4 -1
  395. package/build/es/components/Icons/hlWarning.d.ts +4 -1
  396. package/build/es/components/Icons/hlWifi.d.ts +4 -1
  397. package/build/es/components/Icons/hlWrench.d.ts +3 -0
  398. package/build/es/components/Icons/hlX.d.ts +4 -1
  399. package/build/es/components/Icons/index.d.ts +1 -0
  400. package/build/es/components/Icons/index.js +1 -0
  401. package/build/es/components/Input/Input.d.ts +28 -11
  402. package/build/es/components/Input/Input.js +58 -36
  403. package/build/es/components/Label/Label.d.ts +2 -1
  404. package/build/es/components/LabelText/LabelText.d.ts +2 -1
  405. package/build/es/components/MainHeaderNavigation/ChildComponents/BusinessMenu.d.ts +10 -0
  406. package/build/es/components/MainHeaderNavigation/ChildComponents/BusinessMenu.js +54 -0
  407. package/build/es/components/MainHeaderNavigation/ChildComponents/DesktopMenu.d.ts +3 -0
  408. package/build/es/components/MainHeaderNavigation/ChildComponents/DesktopMenu.js +198 -0
  409. package/build/es/components/MainHeaderNavigation/ChildComponents/LanguageSelector.d.ts +4 -0
  410. package/build/es/components/MainHeaderNavigation/ChildComponents/LanguageSelector.js +31 -0
  411. package/build/es/components/MainHeaderNavigation/ChildComponents/LinkModifier.d.ts +10 -0
  412. package/build/es/components/MainHeaderNavigation/ChildComponents/LinkModifier.js +33 -0
  413. package/build/es/components/MainHeaderNavigation/ChildComponents/LoginTooltip.d.ts +7 -0
  414. package/build/es/components/MainHeaderNavigation/ChildComponents/LoginTooltip.js +15 -0
  415. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.d.ts +193 -0
  416. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.js +112 -0
  417. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.d.ts +169 -0
  418. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.js +63 -0
  419. package/build/es/components/MainHeaderNavigation/ChildComponents/MinicartTooltip.d.ts +7 -0
  420. package/build/es/components/MainHeaderNavigation/ChildComponents/MinicartTooltip.js +18 -0
  421. package/build/es/components/MainHeaderNavigation/ChildComponents/MobileMenu.d.ts +3 -0
  422. package/build/es/components/MainHeaderNavigation/ChildComponents/MobileMenu.js +186 -0
  423. package/build/es/components/MainHeaderNavigation/ChildComponents/PageSearch.d.ts +6 -0
  424. package/build/es/components/MainHeaderNavigation/ChildComponents/PageSearch.js +15 -0
  425. package/build/es/components/MainHeaderNavigation/MainHeaderNavigation.d.ts +36 -0
  426. package/build/es/components/MainHeaderNavigation/MainHeaderNavigation.js +315 -0
  427. package/build/es/components/MainHeaderNavigation/context/MobileMenuContext.d.ts +6 -0
  428. package/build/es/components/MainHeaderNavigation/context/MobileMenuContext.js +7 -0
  429. package/build/es/components/MainHeaderNavigation/context/NavContext.d.ts +29 -0
  430. package/build/es/components/MainHeaderNavigation/context/NavContext.js +52 -0
  431. package/build/es/components/MainHeaderNavigation/globalNavStyles.d.ts +1482 -0
  432. package/build/es/components/MainHeaderNavigation/globalNavStyles.js +177 -0
  433. package/build/es/components/MainNavigation/ChildComponents/DesktopMenu.d.ts +2 -2
  434. package/build/es/components/MainNavigation/ChildComponents/DesktopMenu.js +35 -36
  435. package/build/es/components/MainNavigation/ChildComponents/HeaderNavigationElements.d.ts +2 -2
  436. package/build/es/components/MainNavigation/ChildComponents/HeaderNavigationElements.js +5 -7
  437. package/build/es/components/MainNavigation/ChildComponents/LanguageSelector.d.ts +1 -1
  438. package/build/es/components/MainNavigation/ChildComponents/LanguageSelector.js +13 -17
  439. package/build/es/components/MainNavigation/ChildComponents/LinkModifier.d.ts +1 -1
  440. package/build/es/components/MainNavigation/ChildComponents/LinkModifier.js +9 -9
  441. package/build/es/components/MainNavigation/ChildComponents/LoginTooltip.js +5 -8
  442. package/build/es/components/MainNavigation/ChildComponents/MainNavTooltipMenu.d.ts +5 -4
  443. package/build/es/components/MainNavigation/ChildComponents/MainNavTooltipMenu.js +11 -11
  444. package/build/es/components/MainNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.d.ts +4 -2
  445. package/build/es/components/MainNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.js +2 -3
  446. package/build/es/components/MainNavigation/ChildComponents/MinicartTooltip.js +6 -9
  447. package/build/es/components/MainNavigation/ChildComponents/MobileMenu.d.ts +1 -1
  448. package/build/es/components/MainNavigation/ChildComponents/MobileMenu.js +25 -23
  449. package/build/es/components/MainNavigation/ChildComponents/PageSearch.js +5 -8
  450. package/build/es/components/MainNavigation/ChildComponents/Ribbon.d.ts +2 -2
  451. package/build/es/components/MainNavigation/MainNavigation.d.ts +5 -5
  452. package/build/es/components/MainNavigation/MainNavigation.js +101 -75
  453. package/build/es/components/MainNavigation/context/MobileMenuContext.d.ts +3 -3
  454. package/build/es/components/MainNavigation/context/MobileMenuContext.js +2 -2
  455. package/build/es/components/MainNavigation/context/NavContext.d.ts +14 -15
  456. package/build/es/components/MainNavigation/context/NavContext.js +7 -2
  457. package/build/es/components/MainNavigation/globalNavStyles.d.ts +4 -4
  458. package/build/es/components/Modal/Modal.d.ts +2 -1
  459. package/build/es/components/Modal/Modal.js +2 -2
  460. package/build/es/components/Notification/Notification.d.ts +3 -2
  461. package/build/es/components/Notification/Notification.js +6 -10
  462. package/build/es/components/NotificationBadge/NotificationBadge.d.ts +2 -1
  463. package/build/es/components/Pill/Pill.d.ts +4 -3
  464. package/build/es/components/ProgressIndicator/ProgressIndicator.d.ts +2 -1
  465. package/build/es/components/ProgressIndicator/ProgressIndicator.js +2 -3
  466. package/build/es/components/RadioButton/RadioButton.d.ts +2 -1
  467. package/build/es/components/ReadMore/ReadMore.d.ts +4 -4
  468. package/build/es/components/ReadMore/ReadMore.js +2 -4
  469. package/build/es/components/Search/Search.d.ts +7 -6
  470. package/build/es/components/Search/Search.js +4 -5
  471. package/build/es/components/SecondaryNavigation/SecondaryNavigation.d.ts +19 -2
  472. package/build/es/components/SecondaryNavigation/SecondaryNavigation.js +25 -33
  473. package/build/es/components/Selectbox/Selectbox.js +10 -15
  474. package/build/es/components/Selectbox/__tests__/Selectbox.spec.d.ts +1 -0
  475. package/build/es/components/Tabs/Tab.d.ts +5 -3
  476. package/build/es/components/Tabs/Tab.js +2 -2
  477. package/build/es/components/Tabs/Tabs.d.ts +18 -19
  478. package/build/es/components/Tabs/Tabs.js +4 -4
  479. package/build/es/components/Textarea/Textarea.d.ts +6 -5
  480. package/build/es/components/Toaster/Toaster.d.ts +3 -2
  481. package/build/es/components/Toaster/Toaster.js +7 -11
  482. package/build/es/components/Tooltip/Tooltip.d.ts +2 -1
  483. package/build/es/components/Tooltip/Tooltip.js +3 -3
  484. package/build/es/components/TooltipMenu/ChildComponents/TooltipMenuExportedStyles.d.ts +2 -2
  485. package/build/es/components/TooltipMenu/TooltipMenu.d.ts +2 -1
  486. package/build/es/components/TooltipMenu/TooltipMenu.js +2 -3
  487. package/build/es/components/index.d.ts +3 -1
  488. package/build/es/hooks/useCloseOutsideOrElementClicked.js +3 -2
  489. package/build/es/hooks/useDebounce.d.ts +2 -0
  490. package/build/es/hooks/useDebounce.js +19 -0
  491. package/build/es/hooks/useDocHeight.d.ts +2 -1
  492. package/build/es/hooks/useDocHeight.js +6 -6
  493. package/build/es/hooks/useResizeObserver.d.ts +6 -0
  494. package/build/es/hooks/{useElementDimensions.js → useResizeObserver.js} +5 -5
  495. package/build/es/hooks/useScrollPosition.d.ts +2 -3
  496. package/build/es/hooks/useScrollPosition.js +9 -11
  497. package/build/es/index.js +3 -0
  498. package/build/es/themes/globalStyles.d.ts +3 -3
  499. package/build/es/themes/styled.d.ts +7 -7
  500. package/build/es/themes/theme.d.ts +1 -1
  501. package/build/es/themes/themeComponents/navigation.d.ts +8 -0
  502. package/build/es/themes/themeComponents/navigation.js +10 -2
  503. package/build/es/utils/common.d.ts +2 -1
  504. package/build/es/utils/common.js +1 -1
  505. package/build/es/utils/createStyled.d.ts +163 -2
  506. package/build/es/utils/createStyled.js +2 -2
  507. package/build/es/utils/styledUtils.d.ts +1 -1
  508. package/package.json +24 -11
  509. package/build/cjs/hooks/modifyBodyClass.d.ts +0 -1
  510. package/build/cjs/hooks/modifyBodyClass.js +0 -20
  511. package/build/cjs/hooks/useDebounceFunc.d.ts +0 -1
  512. package/build/cjs/hooks/useDebounceFunc.js +0 -39
  513. package/build/cjs/hooks/useElementDimensions.d.ts +0 -5
  514. package/build/es/hooks/modifyBodyClass.d.ts +0 -1
  515. package/build/es/hooks/modifyBodyClass.js +0 -16
  516. package/build/es/hooks/useDebounceFunc.d.ts +0 -1
  517. package/build/es/hooks/useDebounceFunc.js +0 -15
  518. package/build/es/hooks/useElementDimensions.d.ts +0 -5
@@ -0,0 +1,315 @@
1
+ import { Close, Menu } from '@dnanpm/icons';
2
+ import { prop, indexBy } from 'ramda';
3
+ import React__default, { useRef, useMemo, useState, useEffect } from 'react';
4
+ import useScrollPosition from '../../hooks/useScrollPosition.js';
5
+ import useWindowSize from '../../hooks/useWindowSize.js';
6
+ import styled, { createGlobalStyle, keyframes } from '../../themes/styled.js';
7
+ import theme from '../../themes/theme.js';
8
+ import { navMaxHeight, headerLogoSize, navIconSize } from '../../themes/themeComponents/navigation.js';
9
+ import { getMultipliedSize } from '../../utils/styledUtils.js';
10
+ import DnaLogo from '../DnaLogo/DnaLogo.js';
11
+ import Icon from '../Icon/Icon.js';
12
+ import Notification from '../Notification/Notification.js';
13
+ import BusinessMenu from './ChildComponents/BusinessMenu.js';
14
+ import DesktopMenu from './ChildComponents/DesktopMenu.js';
15
+ import LanguageSelector from './ChildComponents/LanguageSelector.js';
16
+ import LoginTooltip from './ChildComponents/LoginTooltip.js';
17
+ import { IconContainer } from './ChildComponents/MainNavTooltipMenu.js';
18
+ import MinicartTooltip from './ChildComponents/MinicartTooltip.js';
19
+ import RenderMobileMenu from './ChildComponents/MobileMenu.js';
20
+ import PageSearch from './ChildComponents/PageSearch.js';
21
+ import NavContext from './context/NavContext.js';
22
+ import { LogoLink, DesktopMenuContainer, HeaderIconContainer, MobileMenuButton } from './globalNavStyles.js';
23
+
24
+ const GlobalStyle = createGlobalStyle `
25
+ body.overflow-hidden {
26
+ overflow: hidden;
27
+ }
28
+ `;
29
+ // detect common touch screen devices
30
+ const isIosDevice = () => {
31
+ const validate = /iPad|iPhone|iPod|iPad Simulator|iPhone Simulator/i;
32
+ if (typeof navigator !== 'undefined' && typeof window !== 'undefined') {
33
+ return (validate.test(navigator.userAgent) &&
34
+ !window.MSStream);
35
+ }
36
+ return false;
37
+ };
38
+ const iosDevice = isIosDevice();
39
+ const fadeIn = keyframes `
40
+ 0% {
41
+ opacity: 0;
42
+ transform: translateY(-5px);
43
+ }
44
+ 5% {
45
+ opacity: 0;
46
+ transform: translateY(-5px);
47
+ }
48
+ 100% {
49
+ opacity: 1;
50
+ transform: translateY(0px);
51
+ }
52
+ `;
53
+ const preventBodyScroll = () => {
54
+ const { scrollY } = window;
55
+ document.body.style.position = 'fixed';
56
+ document.body.style.top = `-${scrollY}px`;
57
+ };
58
+ const resumeBodyScroll = () => {
59
+ const scrollY = document.body.style.top;
60
+ document.body.style.position = '';
61
+ document.body.style.top = '';
62
+ // if the call to close overlay is done multiple times, scroll only the first time
63
+ if (scrollY) {
64
+ setTimeout(() => {
65
+ window.scrollTo(0, parseInt(scrollY, 10) * -1);
66
+ });
67
+ }
68
+ };
69
+ const PageOverlay = styled.div `
70
+ position: fixed;
71
+ animation: ${fadeIn} 0.2s ease-in-out;
72
+ top: 0;
73
+ left: 0;
74
+ width: 100%;
75
+ height: 100%;
76
+ background: ${theme.color.background.plum.default + theme.color.transparency.T10};
77
+ z-index: ${({ navZIndex }) => navZIndex - 1};
78
+ `;
79
+ const scrollThreshold = 82;
80
+ const checkThreshold = (prevPos, currPos) => {
81
+ if (prevPos >= currPos) {
82
+ return prevPos - currPos > scrollThreshold;
83
+ }
84
+ return currPos - prevPos > scrollThreshold;
85
+ };
86
+ const GlobalNavigationContainer = styled.header `
87
+ z-index: ${({ navZIndex }) => navZIndex};
88
+ position: sticky;
89
+ top: 0;
90
+ left: 0;
91
+ right: 0;
92
+ width: 100%;
93
+ background-color: ${theme.color.background.white.default};
94
+ color: ${theme.color.text.black};
95
+ max-width: 2560px;
96
+ margin: 0 auto;
97
+ > nav {
98
+ background-color: ${theme.color.background.plum.E02};
99
+ }
100
+ `;
101
+ const NavigationWrapper = styled.div `
102
+ display: flex;
103
+ width: 100%;
104
+ max-width: ${getMultipliedSize(theme.base.baseWidth, 256)};
105
+ margin: 0 auto;
106
+ height: ${navMaxHeight};
107
+ position: relative;
108
+ flex-wrap: nowrap;
109
+ gap: 0;
110
+ background-color: ${theme.color.background.white.default};
111
+ border-bottom: 1px solid ${theme.color.line.L04};
112
+ @media (min-width: ${p => p.collapseSize + 1}px) {
113
+ flex-wrap: nowrap;
114
+ gap: 0 ${getMultipliedSize(theme.base.baseWidth, 1.5)};
115
+ }
116
+ `;
117
+ let previousValue = false;
118
+ const isStickySupported = typeof CSS !== 'undefined' &&
119
+ typeof CSS.supports !== 'undefined' &&
120
+ (CSS.supports('position', 'sticky') || CSS.supports('position', '-webkit-sticky'));
121
+ const initiateScrollToHeader = (componentRef) => {
122
+ if ((componentRef === null || componentRef === void 0 ? void 0 : componentRef.current) && isStickySupported && typeof window !== 'undefined') {
123
+ window.scrollTo({ top: componentRef.current.offsetTop, left: 0 });
124
+ }
125
+ };
126
+ /** @visibleName MainHeaderNavigation */
127
+ const MainHeaderNavigation = ({ businessMenuAriaLabel = 'Sivustot', categoryCollectionText = 'Muut kategoriat', className, collapseSize = 767, currentUrl = '', isLoggedIn = false, items = {}, language = 'fi', languageSelector = false, languageSelectorText = 'Vaihda kieltä', login = true, loginComponent, loginText = 'Kirjaudu', mainMenuAriaLabel = 'Päänavigaatio', minicart = true, minicartAmount = 0, minicartComponent = false, minicartText = 'Ostoskori', nextJSLinkComponent = false, notificationText = '', search = true, searchComponent = false, searchText = 'Haku', showLoginTooltip = false, showMinicart = false, zIndex = 1030, }) => {
128
+ var _a, _b, _c;
129
+ const { isMobile } = useWindowSize(collapseSize);
130
+ const navigationEl = useRef(null);
131
+ const key = prop('id');
132
+ // Index & memoize menu levels
133
+ const level1 = useMemo(() => { var _a, _b; return (_b = (_a = items.mainNavigation) === null || _a === void 0 ? void 0 : _a.pages) !== null && _b !== void 0 ? _b : []; }, [items.mainNavigation]);
134
+ const level1Items = useMemo(() => indexBy(key, level1), [level1, key]);
135
+ const level2 = useMemo(() => level1.map(item => indexBy(key, item.pages)), [level1, key]);
136
+ const level2Items = Object.assign({}, ...level2);
137
+ // All states to for handling menus
138
+ const [isMobileMenuOpen, setIsMobileMenuOpen] = useState(false);
139
+ const [menuLevel, setMenuLevel] = useState({
140
+ level1: null,
141
+ animate1: true,
142
+ level2: null,
143
+ animate2: true,
144
+ level1Mobile: null,
145
+ level2Mobile: null,
146
+ scrollPosition: 0,
147
+ hideOnScroll: false,
148
+ });
149
+ const [lang] = useState(language);
150
+ // As scroll position cannot be always retained, close mobile menu when orientation changes
151
+ const initRotation = () => {
152
+ setIsMobileMenuOpen(false);
153
+ };
154
+ useEffect(() => {
155
+ if (iosDevice && isMobileMenuOpen) {
156
+ window.addEventListener('orientationchange', initRotation, false);
157
+ preventBodyScroll();
158
+ }
159
+ if (iosDevice && !isMobileMenuOpen) {
160
+ window.removeEventListener('orientationchange', initRotation, false);
161
+ resumeBodyScroll();
162
+ }
163
+ return () => {
164
+ window.removeEventListener('orientationchange', initRotation, false);
165
+ resumeBodyScroll();
166
+ };
167
+ }, [isMobileMenuOpen]);
168
+ const [tooltipItems, setTooltipItems] = useState(useMemo(() => ({
169
+ minicart: false,
170
+ login: false,
171
+ search: false,
172
+ }), []));
173
+ const tooltipMenuActive = tooltipItems.minicart || tooltipItems.login || tooltipItems.search;
174
+ const freezeOverflow = isMobileMenuOpen || (tooltipMenuActive && isMobile);
175
+ const isPageOverlay = isMobileMenuOpen || tooltipMenuActive || menuLevel.level1 || menuLevel.level2;
176
+ useEffect(() => {
177
+ const bodyClasses = ['overflow-shown', 'overflow-hidden'];
178
+ document.body.classList.remove(...bodyClasses);
179
+ document.body.classList.add(bodyClasses[Number(Boolean(freezeOverflow))]);
180
+ }, [freezeOverflow]);
181
+ const navigationContext = useMemo(() => {
182
+ const handleNavMenuClick = (newValue, updatedLevel) => {
183
+ let clickedItself = false;
184
+ switch (updatedLevel) {
185
+ case 'level1':
186
+ clickedItself = newValue === menuLevel.level1;
187
+ setMenuLevel(Object.assign(Object.assign({}, menuLevel), { level1: !clickedItself ? newValue : null, animate1: !clickedItself, level2: null, animate2: true }));
188
+ break;
189
+ case 'level2':
190
+ clickedItself = newValue === menuLevel.level2;
191
+ setMenuLevel(Object.assign(Object.assign({}, menuLevel), { level2: newValue !== menuLevel.level2 ? newValue : null, animate1: false, animate2: !clickedItself }));
192
+ break;
193
+ case 'level1Mobile':
194
+ setMenuLevel(Object.assign(Object.assign({}, menuLevel), { level1Mobile: newValue || menuLevel.level1Mobile, scrollPosition: newValue ? 1 : 0 }));
195
+ break;
196
+ case 'level2Mobile':
197
+ setMenuLevel(Object.assign(Object.assign({}, menuLevel), { level2Mobile: newValue || menuLevel.level2Mobile, scrollPosition: newValue ? 2 : 1 }));
198
+ break;
199
+ }
200
+ };
201
+ const resetMenuEvents = () => {
202
+ setMenuLevel({
203
+ level2: null,
204
+ animate2: true,
205
+ level1: null,
206
+ animate1: true,
207
+ level1Mobile: null,
208
+ level2Mobile: null,
209
+ scrollPosition: 0,
210
+ hideOnScroll: false,
211
+ });
212
+ if (isMobileMenuOpen) {
213
+ setIsMobileMenuOpen(false);
214
+ }
215
+ setTooltipItems({
216
+ minicart: false,
217
+ login: false,
218
+ search: false,
219
+ });
220
+ };
221
+ const getBackLink = (menuElements, i) => {
222
+ const idValue = menuLevel[`level${i}Mobile`];
223
+ return menuElements[idValue];
224
+ };
225
+ // Resets menu states when menu content alters between mobile and desktop
226
+ const menuChanged = previousValue !== isMobile;
227
+ if (menuChanged) {
228
+ resetMenuEvents();
229
+ previousValue = isMobile;
230
+ }
231
+ return {
232
+ categoryCollectionText,
233
+ collapseSize,
234
+ currentUrl,
235
+ getBackLink,
236
+ handleNavMenuClick,
237
+ isLoggedIn,
238
+ isMobileMenu: isMobile,
239
+ isMobileMenuOpen,
240
+ items,
241
+ lang,
242
+ level1Items,
243
+ level2Items,
244
+ loginComponent,
245
+ menuLevel,
246
+ minicartComponent,
247
+ navZIndex: zIndex,
248
+ nextJSLinkComponent,
249
+ resetMenuEvents,
250
+ searchComponent,
251
+ setTooltipItems,
252
+ showLoginTooltip,
253
+ showMinicart,
254
+ tooltipItems,
255
+ };
256
+ }, [
257
+ categoryCollectionText,
258
+ collapseSize,
259
+ currentUrl,
260
+ isLoggedIn,
261
+ isMobile,
262
+ isMobileMenuOpen,
263
+ items,
264
+ lang,
265
+ level1Items,
266
+ level2Items,
267
+ loginComponent,
268
+ menuLevel,
269
+ minicartComponent,
270
+ nextJSLinkComponent,
271
+ searchComponent,
272
+ showLoginTooltip,
273
+ showMinicart,
274
+ tooltipItems,
275
+ zIndex,
276
+ ]);
277
+ useScrollPosition(({ prevPos, currPos }) => {
278
+ const overThreshold = checkThreshold(prevPos.y, currPos.y);
279
+ const isShow = currPos.y < prevPos.y;
280
+ if (isShow !== menuLevel.hideOnScroll && overThreshold && !menuLevel.level1) {
281
+ setMenuLevel(Object.assign(Object.assign({}, menuLevel), { animate1: false, animate2: false, hideOnScroll: isShow }));
282
+ }
283
+ }, undefined, false, 200);
284
+ const currentBusinessSite = (_a = items === null || items === void 0 ? void 0 : items.businessSelector) === null || _a === void 0 ? void 0 : _a.items.find(item => item.businessId === items.businessId);
285
+ const languagesObject = (_b = items === null || items === void 0 ? void 0 : items.languageSelector) === null || _b === void 0 ? void 0 : _b.urls;
286
+ const { resetMenuEvents } = navigationContext;
287
+ const handleToggleClick = () => {
288
+ resetMenuEvents();
289
+ initiateScrollToHeader(navigationEl);
290
+ setIsMobileMenuOpen(!isMobileMenuOpen);
291
+ };
292
+ return (React__default.createElement(React__default.Fragment, null,
293
+ isPageOverlay && React__default.createElement(PageOverlay, { "data-testid": "navigation-overlay", navZIndex: zIndex }),
294
+ React__default.createElement(GlobalNavigationContainer, { className: className, collapseSize: collapseSize, "data-testid": "dna-main-header", navZIndex: zIndex, ref: navigationEl, role: "banner" },
295
+ React__default.createElement(NavContext.Provider, { value: navigationContext },
296
+ React__default.createElement(GlobalStyle, null),
297
+ !items.mainNavigation && notificationText && (React__default.createElement(Notification, { type: "info" }, notificationText)),
298
+ React__default.createElement(BusinessMenu, { ariaLabel: businessMenuAriaLabel, currentBusinessId: items.businessId, items: (_c = items.businessSelector) === null || _c === void 0 ? void 0 : _c.items, lang: language }),
299
+ React__default.createElement(NavigationWrapper, { collapseSize: collapseSize },
300
+ React__default.createElement(LogoLink, { "data-testid": "dna-logo-link", href: currentBusinessSite === null || currentBusinessSite === void 0 ? void 0 : currentBusinessSite.urls[language], title: "DNA" },
301
+ React__default.createElement(DnaLogo, { size: headerLogoSize })),
302
+ React__default.createElement(DesktopMenuContainer, { "aria-label": mainMenuAriaLabel, collapseSize: collapseSize },
303
+ React__default.createElement(DesktopMenu, null)),
304
+ React__default.createElement(HeaderIconContainer, { collapseSize: collapseSize },
305
+ languagesObject && languageSelector && (React__default.createElement(LanguageSelector, { currentLanguage: language, languagesObject: languagesObject, languageSelectorLabel: languageSelectorText })),
306
+ search && React__default.createElement(PageSearch, { searchLabel: searchText }),
307
+ minicart && (React__default.createElement(MinicartTooltip, { minicartAmount: minicartAmount, minicartLabel: minicartText })),
308
+ login && React__default.createElement(LoginTooltip, { loginLabel: loginText, isLogged: isLoggedIn }),
309
+ React__default.createElement(IconContainer, { collapseSize: collapseSize, "data-testid": "header-mobile-menu-container" },
310
+ React__default.createElement(MobileMenuButton, { "aria-expanded": isMobileMenuOpen, "aria-label": "menu toggle", "data-testid": "header-mobile-menu-toggle", onClick: handleToggleClick },
311
+ React__default.createElement(Icon, { icon: isMobileMenuOpen ? Close : Menu, size: navIconSize })))),
312
+ isMobile && React__default.createElement(RenderMobileMenu, null))))));
313
+ };
314
+
315
+ export { MainHeaderNavigation as default };
@@ -0,0 +1,6 @@
1
+ import type { RefObject } from 'react';
2
+ interface MobileMenuContextProps {
3
+ mobileMenuRef: RefObject<HTMLElement> | null;
4
+ }
5
+ declare const MobileMenuContext: import("react").Context<MobileMenuContextProps>;
6
+ export default MobileMenuContext;
@@ -0,0 +1,7 @@
1
+ import { createContext } from 'react';
2
+
3
+ const MobileMenuContext = createContext({
4
+ mobileMenuRef: null,
5
+ });
6
+
7
+ export { MobileMenuContext as default };
@@ -0,0 +1,29 @@
1
+ import type { Dispatch, ReactNode, SetStateAction } from 'react';
2
+ import type { GlobalNavItems, MenuLevelItem, MenuStates, MenuTooltipItems, MobileMenuLevel } from '../types/globalNavProps';
3
+ export interface NavContextProps {
4
+ categoryCollectionText: string;
5
+ collapseSize: number;
6
+ currentUrl: string;
7
+ getBackLink: (menuElements: MobileMenuLevel, i: number) => MenuLevelItem;
8
+ handleNavMenuClick: (id: string | null, level: string) => void;
9
+ isLoggedIn: boolean;
10
+ isMobileMenu: boolean;
11
+ isMobileMenuOpen: boolean;
12
+ items: GlobalNavItems;
13
+ level1Items: MobileMenuLevel;
14
+ level2Items: MobileMenuLevel;
15
+ lang: string;
16
+ loginComponent?: ReactNode | boolean | undefined;
17
+ menuLevel: MenuStates;
18
+ minicartComponent?: ReactNode | boolean | undefined;
19
+ navZIndex: number;
20
+ nextJSLinkComponent: ReactNode | boolean;
21
+ resetMenuEvents: () => void;
22
+ searchComponent?: ReactNode | boolean | undefined;
23
+ setTooltipItems: Dispatch<SetStateAction<MenuTooltipItems>>;
24
+ showLoginTooltip: boolean;
25
+ showMinicart: boolean;
26
+ tooltipItems: MenuTooltipItems;
27
+ }
28
+ declare const NavContext: import("react").Context<NavContextProps>;
29
+ export default NavContext;
@@ -0,0 +1,52 @@
1
+ import { createContext } from 'react';
2
+
3
+ const NavContext = createContext({
4
+ categoryCollectionText: 'Muut kategoriat',
5
+ collapseSize: 767,
6
+ currentUrl: '',
7
+ getBackLink: () => ({
8
+ id: '',
9
+ pageIsLinkInDesktopNavigation: false,
10
+ pages: [],
11
+ titles: {},
12
+ urls: {},
13
+ }),
14
+ handleNavMenuClick: () => { },
15
+ isLoggedIn: false,
16
+ isMobileMenu: false,
17
+ isMobileMenuOpen: false,
18
+ items: {},
19
+ lang: 'fi',
20
+ level1Items: {
21
+ level1: { id: '', pageIsLinkInDesktopNavigation: false, pages: [], titles: {}, urls: {} },
22
+ },
23
+ level2Items: {
24
+ level2: { id: '', pageIsLinkInDesktopNavigation: false, pages: [], titles: {}, urls: {} },
25
+ },
26
+ loginComponent: false,
27
+ menuLevel: {
28
+ level1: null,
29
+ animate1: true,
30
+ level2: null,
31
+ animate2: true,
32
+ level1Mobile: null,
33
+ level2Mobile: null,
34
+ scrollPosition: 0,
35
+ hideOnScroll: false,
36
+ },
37
+ minicartComponent: undefined,
38
+ navZIndex: 1030,
39
+ nextJSLinkComponent: false,
40
+ resetMenuEvents: () => { },
41
+ searchComponent: false,
42
+ setTooltipItems: () => { },
43
+ showLoginTooltip: false,
44
+ showMinicart: true,
45
+ tooltipItems: {
46
+ minicart: false,
47
+ login: false,
48
+ search: false,
49
+ },
50
+ });
51
+
52
+ export { NavContext as default };