@dnanpm/styleguide 4.0.9 → 4.0.10

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 (415) hide show
  1. package/build/cjs/components/Accordion/Accordion.js +66 -54
  2. package/build/cjs/components/AccordionItem/AccordionItem.js +94 -73
  3. package/build/cjs/components/AmountSelector/AmountSelector.js +121 -134
  4. package/build/cjs/components/Box/Box.js +38 -13
  5. package/build/cjs/components/Breadcrumb/Breadcrumb.js +73 -71
  6. package/build/cjs/components/Button/Button.js +131 -127
  7. package/build/cjs/components/ButtonArrow/ButtonArrow.js +47 -49
  8. package/build/cjs/components/ButtonCard/ButtonCard.js +97 -112
  9. package/build/cjs/components/ButtonClose/ButtonClose.js +24 -18
  10. package/build/cjs/components/ButtonIcon/ButtonIcon.js +103 -106
  11. package/build/cjs/components/ButtonPrimary/ButtonPrimary.d.ts +43 -2
  12. package/build/cjs/components/ButtonPrimary/ButtonPrimary.js +7 -35
  13. package/build/cjs/components/ButtonSecondary/ButtonSecondary.d.ts +43 -2
  14. package/build/cjs/components/ButtonSecondary/ButtonSecondary.js +7 -35
  15. package/build/cjs/components/Carousel/Carousel.d.ts +8 -2
  16. package/build/cjs/components/Carousel/Carousel.js +315 -346
  17. package/build/cjs/components/Checkbox/Checkbox.js +49 -108
  18. package/build/cjs/components/Chip/Chip.js +40 -34
  19. package/build/cjs/components/DateTimePicker/DateTimePicker.js +198 -334
  20. package/build/cjs/components/Divider/Divider.js +29 -15
  21. package/build/cjs/components/DnaLogo/DnaLogo.js +87 -51
  22. package/build/cjs/components/Drawer/Drawer.js +172 -167
  23. package/build/cjs/components/EmptyState/EmptyState.js +24 -12
  24. package/build/cjs/components/EnergyLabel/EnergyLabel.js +77 -73
  25. package/build/cjs/components/Expander/Expander.js +43 -38
  26. package/build/cjs/components/Floater/Floater.js +36 -14
  27. package/build/cjs/components/Footer/Components/FooterComponents.d.ts +4 -2
  28. package/build/cjs/components/Footer/Components/FooterComponents.js +305 -346
  29. package/build/cjs/components/Footer/Footer.js +51 -80
  30. package/build/cjs/components/Footer/context/FooterContext.js +9 -9
  31. package/build/cjs/components/Hero/Hero.js +101 -149
  32. package/build/cjs/components/Icon/Icon.js +41 -22
  33. package/build/cjs/components/Icons/Small/hlArrowBackSmall.js +12 -4
  34. package/build/cjs/components/Icons/Small/hlArrowForwardSmall.js +12 -4
  35. package/build/cjs/components/Icons/Small/hlArrowUnderSmall.js +12 -4
  36. package/build/cjs/components/Icons/Small/hlCalendarSmall.js +12 -4
  37. package/build/cjs/components/Icons/Small/hlChevronDownSmall.js +12 -4
  38. package/build/cjs/components/Icons/Small/hlChevronLeftSmall.js +12 -4
  39. package/build/cjs/components/Icons/Small/hlChevronRightSmall.js +12 -4
  40. package/build/cjs/components/Icons/Small/hlChevronUpSmall.js +12 -4
  41. package/build/cjs/components/Icons/Small/hlClockSmall.js +14 -5
  42. package/build/cjs/components/Icons/Small/hlDownloadSmall.js +18 -6
  43. package/build/cjs/components/Icons/Small/hlExternalSmall.js +12 -4
  44. package/build/cjs/components/Icons/Small/hlUploadSmall.js +18 -6
  45. package/build/cjs/components/Icons/Social/facebook.js +13 -4
  46. package/build/cjs/components/Icons/Social/instagram.js +13 -4
  47. package/build/cjs/components/Icons/Social/linkedin.js +13 -4
  48. package/build/cjs/components/Icons/Social/tiktok.js +12 -4
  49. package/build/cjs/components/Icons/Social/twitter.js +13 -4
  50. package/build/cjs/components/Icons/Social/youtube.js +12 -4
  51. package/build/cjs/components/Icons/hl404.js +12 -4
  52. package/build/cjs/components/Icons/hl4gSim.js +12 -4
  53. package/build/cjs/components/Icons/hl5gSim.js +12 -4
  54. package/build/cjs/components/Icons/hlBattery.js +16 -6
  55. package/build/cjs/components/Icons/hlBell.js +12 -4
  56. package/build/cjs/components/Icons/hlCableTVCard.js +12 -4
  57. package/build/cjs/components/Icons/hlCalendar.js +56 -15
  58. package/build/cjs/components/Icons/hlCall.js +12 -4
  59. package/build/cjs/components/Icons/hlCameraBack.js +18 -6
  60. package/build/cjs/components/Icons/hlCameraFront.js +14 -5
  61. package/build/cjs/components/Icons/hlCart.js +16 -6
  62. package/build/cjs/components/Icons/hlCartEmpty.js +16 -6
  63. package/build/cjs/components/Icons/hlChat.js +24 -7
  64. package/build/cjs/components/Icons/hlCheck.js +12 -4
  65. package/build/cjs/components/Icons/hlChevronDown.js +12 -4
  66. package/build/cjs/components/Icons/hlChevronLeft.js +12 -4
  67. package/build/cjs/components/Icons/hlChevronRight.js +12 -4
  68. package/build/cjs/components/Icons/hlChevronUp.js +12 -4
  69. package/build/cjs/components/Icons/hlCompensation.js +12 -4
  70. package/build/cjs/components/Icons/hlCookie.js +12 -4
  71. package/build/cjs/components/Icons/hlCopy.js +14 -5
  72. package/build/cjs/components/Icons/hlCoupon.js +16 -6
  73. package/build/cjs/components/Icons/hlDelivery.js +14 -4
  74. package/build/cjs/components/Icons/hlDigiturva.js +14 -4
  75. package/build/cjs/components/Icons/hlDisplaySize.js +19 -6
  76. package/build/cjs/components/Icons/hlDocument.js +14 -5
  77. package/build/cjs/components/Icons/hlDownload.js +18 -6
  78. package/build/cjs/components/Icons/hlEnvelope.js +12 -4
  79. package/build/cjs/components/Icons/hlError.js +22 -6
  80. package/build/cjs/components/Icons/hlEuro.js +12 -4
  81. package/build/cjs/components/Icons/hlExclamationMark.js +12 -4
  82. package/build/cjs/components/Icons/hlExpand.js +12 -4
  83. package/build/cjs/components/Icons/hlExternal.js +12 -4
  84. package/build/cjs/components/Icons/hlEyeClosed.js +12 -4
  85. package/build/cjs/components/Icons/hlEyeOpen.js +14 -5
  86. package/build/cjs/components/Icons/hlFaceId.js +12 -4
  87. package/build/cjs/components/Icons/hlFastDelivery.js +12 -4
  88. package/build/cjs/components/Icons/hlFingerprint.js +20 -8
  89. package/build/cjs/components/Icons/hlGlobe.js +12 -4
  90. package/build/cjs/components/Icons/hlHeadphones.js +12 -4
  91. package/build/cjs/components/Icons/hlHeadset.js +18 -6
  92. package/build/cjs/components/Icons/hlHeart.js +12 -4
  93. package/build/cjs/components/Icons/hlHome.js +12 -4
  94. package/build/cjs/components/Icons/hlHub.js +14 -5
  95. package/build/cjs/components/Icons/hlImage.js +12 -4
  96. package/build/cjs/components/Icons/hlInfo.js +18 -6
  97. package/build/cjs/components/Icons/hlInstallment.js +14 -5
  98. package/build/cjs/components/Icons/hlIotSim.js +14 -5
  99. package/build/cjs/components/Icons/hlLaptop.js +13 -4
  100. package/build/cjs/components/Icons/hlLink.js +16 -5
  101. package/build/cjs/components/Icons/hlLiveVideo.js +12 -4
  102. package/build/cjs/components/Icons/hlLock.js +18 -6
  103. package/build/cjs/components/Icons/hlMagnifyingGlass.js +14 -5
  104. package/build/cjs/components/Icons/hlMarker.js +14 -5
  105. package/build/cjs/components/Icons/hlMemory.js +14 -5
  106. package/build/cjs/components/Icons/hlMenu.js +12 -4
  107. package/build/cjs/components/Icons/hlMinimize.js +12 -4
  108. package/build/cjs/components/Icons/hlMinus.js +12 -4
  109. package/build/cjs/components/Icons/hlMobileData.js +12 -4
  110. package/build/cjs/components/Icons/hlMobilePayment.js +19 -6
  111. package/build/cjs/components/Icons/hlModem.js +26 -8
  112. package/build/cjs/components/Icons/hlMore.js +22 -6
  113. package/build/cjs/components/Icons/hlOs.js +14 -5
  114. package/build/cjs/components/Icons/hlPackage.js +12 -4
  115. package/build/cjs/components/Icons/hlPaperclip.js +12 -4
  116. package/build/cjs/components/Icons/hlPaytime.js +12 -4
  117. package/build/cjs/components/Icons/hlPen.js +12 -4
  118. package/build/cjs/components/Icons/hlPerson.js +12 -4
  119. package/build/cjs/components/Icons/hlPhone.js +17 -5
  120. package/build/cjs/components/Icons/hlPlaylist.js +13 -4
  121. package/build/cjs/components/Icons/hlPlus.js +14 -5
  122. package/build/cjs/components/Icons/hlPrepaid.js +12 -4
  123. package/build/cjs/components/Icons/hlProcessor.js +14 -5
  124. package/build/cjs/components/Icons/hlServices.js +12 -4
  125. package/build/cjs/components/Icons/hlSettings.js +12 -4
  126. package/build/cjs/components/Icons/hlShield.js +14 -5
  127. package/build/cjs/components/Icons/hlSim.js +14 -5
  128. package/build/cjs/components/Icons/hlSimSimple.js +18 -6
  129. package/build/cjs/components/Icons/hlSmile.js +22 -7
  130. package/build/cjs/components/Icons/hlSpeechBubble.js +14 -5
  131. package/build/cjs/components/Icons/hlSquaretrade.js +13 -4
  132. package/build/cjs/components/Icons/hlStar.js +12 -4
  133. package/build/cjs/components/Icons/hlStarFilled.js +12 -4
  134. package/build/cjs/components/Icons/hlTrash.js +14 -5
  135. package/build/cjs/components/Icons/hlTv.js +12 -4
  136. package/build/cjs/components/Icons/hlUnlock.js +14 -6
  137. package/build/cjs/components/Icons/hlUpload.js +18 -6
  138. package/build/cjs/components/Icons/hlWarning.js +18 -6
  139. package/build/cjs/components/Icons/hlWifi.js +18 -6
  140. package/build/cjs/components/Icons/hlWrench.js +12 -4
  141. package/build/cjs/components/Icons/hlX.js +12 -4
  142. package/build/cjs/components/InfoDialog/InfoDialog.js +31 -46
  143. package/build/cjs/components/Input/Input.js +143 -159
  144. package/build/cjs/components/Label/Label.js +22 -22
  145. package/build/cjs/components/LabelText/LabelText.js +24 -17
  146. package/build/cjs/components/MainHeaderNavigation/ChildComponents/BusinessMenu.js +29 -44
  147. package/build/cjs/components/MainHeaderNavigation/ChildComponents/DesktopMenu.js +167 -153
  148. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LanguageSelector.js +34 -20
  149. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LinkModifier.js +50 -32
  150. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LoginTooltip.js +17 -5
  151. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.d.ts +5 -2
  152. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.js +100 -95
  153. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.d.ts +6 -2
  154. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.js +4 -58
  155. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MinicartTooltip.js +20 -4
  156. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MobileMenu.js +187 -159
  157. package/build/cjs/components/MainHeaderNavigation/ChildComponents/PageSearch.js +16 -5
  158. package/build/cjs/components/MainHeaderNavigation/MainHeaderNavigation.js +305 -272
  159. package/build/cjs/components/MainHeaderNavigation/context/NavContext.js +61 -49
  160. package/build/cjs/components/MainHeaderNavigation/globalNavStyles.d.ts +31 -16
  161. package/build/cjs/components/MainHeaderNavigation/globalNavStyles.js +39 -172
  162. package/build/cjs/components/Modal/Modal.js +127 -145
  163. package/build/cjs/components/Notification/Notification.js +74 -54
  164. package/build/cjs/components/NotificationBadge/NotificationBadge.js +29 -32
  165. package/build/cjs/components/Overlay/Overlay.js +70 -68
  166. package/build/cjs/components/Pill/Pill.js +91 -82
  167. package/build/cjs/components/PillGroup/PillGroup.js +50 -33
  168. package/build/cjs/components/PixelLoader/PixelLoader.js +37 -34
  169. package/build/cjs/components/PriorityNavigation/PriorityNavigation.js +281 -303
  170. package/build/cjs/components/PriorityNavigationItem/PriorityNavigationItem.js +27 -49
  171. package/build/cjs/components/ProgressIndicator/ProgressIndicator.js +140 -109
  172. package/build/cjs/components/RadioButton/RadioButton.js +91 -114
  173. package/build/cjs/components/ReadMore/ReadMore.js +86 -69
  174. package/build/cjs/components/Search/Search.js +52 -64
  175. package/build/cjs/components/Selectbox/Selectbox.js +279 -94
  176. package/build/cjs/components/Skeleton/Skeleton.js +69 -56
  177. package/build/cjs/components/Switch/Switch.js +62 -76
  178. package/build/cjs/components/Tab/Tab.js +55 -53
  179. package/build/cjs/components/Tabs/Tabs.js +93 -71
  180. package/build/cjs/components/Textarea/Textarea.js +76 -73
  181. package/build/cjs/components/Toaster/Toaster.js +59 -44
  182. package/build/cjs/components/Tooltip/Tooltip.js +74 -87
  183. package/build/cjs/hooks/useCloseOutsideOrElementClicked.js +23 -21
  184. package/build/cjs/hooks/useDebounce.js +9 -9
  185. package/build/cjs/hooks/useDocHeight.js +13 -13
  186. package/build/cjs/hooks/useOutsideClick.js +10 -10
  187. package/build/cjs/hooks/useResizeObserver.js +37 -24
  188. package/build/cjs/hooks/useScrollPosition.js +55 -54
  189. package/build/cjs/hooks/useWindowSize.js +20 -20
  190. package/build/cjs/themes/globalStyles.js +4 -4
  191. package/build/cjs/themes/gridTheme.js +1 -1
  192. package/build/cjs/themes/theme.js +12 -12
  193. package/build/cjs/themes/themeComponents/base.js +9 -8
  194. package/build/cjs/themes/themeComponents/breakpoints.js +6 -6
  195. package/build/cjs/themes/themeComponents/color.js +76 -74
  196. package/build/cjs/themes/themeComponents/fontFamily.js +3 -3
  197. package/build/cjs/themes/themeComponents/fontSize.js +31 -15
  198. package/build/cjs/themes/themeComponents/fontWeight.js +16 -16
  199. package/build/cjs/themes/themeComponents/forms.js +3 -2
  200. package/build/cjs/themes/themeComponents/layout.js +27 -27
  201. package/build/cjs/themes/themeComponents/lineHeight.js +32 -16
  202. package/build/cjs/themes/themeComponents/navigation.js +13 -13
  203. package/build/cjs/themes/themeComponents/radius.js +26 -26
  204. package/build/cjs/utils/common.js +15 -19
  205. package/build/cjs/utils/createStyled.d.ts +154 -134
  206. package/build/cjs/utils/createStyled.js +16 -2
  207. package/build/cjs/utils/styledUtils.js +2 -6
  208. package/build/es/components/Accordion/Accordion.js +66 -54
  209. package/build/es/components/AccordionItem/AccordionItem.js +94 -73
  210. package/build/es/components/AmountSelector/AmountSelector.js +121 -134
  211. package/build/es/components/Box/Box.js +38 -13
  212. package/build/es/components/Breadcrumb/Breadcrumb.js +73 -71
  213. package/build/es/components/Button/Button.js +131 -127
  214. package/build/es/components/ButtonArrow/ButtonArrow.js +47 -49
  215. package/build/es/components/ButtonCard/ButtonCard.js +97 -112
  216. package/build/es/components/ButtonClose/ButtonClose.js +24 -18
  217. package/build/es/components/ButtonIcon/ButtonIcon.js +103 -106
  218. package/build/es/components/ButtonPrimary/ButtonPrimary.d.ts +43 -2
  219. package/build/es/components/ButtonPrimary/ButtonPrimary.js +7 -35
  220. package/build/es/components/ButtonSecondary/ButtonSecondary.d.ts +43 -2
  221. package/build/es/components/ButtonSecondary/ButtonSecondary.js +7 -35
  222. package/build/es/components/Carousel/Carousel.d.ts +8 -2
  223. package/build/es/components/Carousel/Carousel.js +315 -346
  224. package/build/es/components/Checkbox/Checkbox.js +49 -108
  225. package/build/es/components/Chip/Chip.js +40 -34
  226. package/build/es/components/DateTimePicker/DateTimePicker.js +198 -334
  227. package/build/es/components/Divider/Divider.js +29 -15
  228. package/build/es/components/DnaLogo/DnaLogo.js +87 -51
  229. package/build/es/components/Drawer/Drawer.js +172 -167
  230. package/build/es/components/EmptyState/EmptyState.js +24 -12
  231. package/build/es/components/EnergyLabel/EnergyLabel.js +77 -73
  232. package/build/es/components/Expander/Expander.js +43 -38
  233. package/build/es/components/Floater/Floater.js +36 -14
  234. package/build/es/components/Footer/Components/FooterComponents.d.ts +4 -2
  235. package/build/es/components/Footer/Components/FooterComponents.js +305 -346
  236. package/build/es/components/Footer/Footer.js +51 -80
  237. package/build/es/components/Footer/context/FooterContext.js +9 -9
  238. package/build/es/components/Hero/Hero.js +101 -149
  239. package/build/es/components/Icon/Icon.js +41 -22
  240. package/build/es/components/Icons/Small/hlArrowBackSmall.js +12 -4
  241. package/build/es/components/Icons/Small/hlArrowForwardSmall.js +12 -4
  242. package/build/es/components/Icons/Small/hlArrowUnderSmall.js +12 -4
  243. package/build/es/components/Icons/Small/hlCalendarSmall.js +12 -4
  244. package/build/es/components/Icons/Small/hlChevronDownSmall.js +12 -4
  245. package/build/es/components/Icons/Small/hlChevronLeftSmall.js +12 -4
  246. package/build/es/components/Icons/Small/hlChevronRightSmall.js +12 -4
  247. package/build/es/components/Icons/Small/hlChevronUpSmall.js +12 -4
  248. package/build/es/components/Icons/Small/hlClockSmall.js +14 -5
  249. package/build/es/components/Icons/Small/hlDownloadSmall.js +18 -6
  250. package/build/es/components/Icons/Small/hlExternalSmall.js +12 -4
  251. package/build/es/components/Icons/Small/hlUploadSmall.js +18 -6
  252. package/build/es/components/Icons/Social/facebook.js +13 -4
  253. package/build/es/components/Icons/Social/instagram.js +13 -4
  254. package/build/es/components/Icons/Social/linkedin.js +13 -4
  255. package/build/es/components/Icons/Social/tiktok.js +12 -4
  256. package/build/es/components/Icons/Social/twitter.js +13 -4
  257. package/build/es/components/Icons/Social/youtube.js +12 -4
  258. package/build/es/components/Icons/hl404.js +12 -4
  259. package/build/es/components/Icons/hl4gSim.js +12 -4
  260. package/build/es/components/Icons/hl5gSim.js +12 -4
  261. package/build/es/components/Icons/hlBattery.js +16 -6
  262. package/build/es/components/Icons/hlBell.js +12 -4
  263. package/build/es/components/Icons/hlCableTVCard.js +12 -4
  264. package/build/es/components/Icons/hlCalendar.js +56 -15
  265. package/build/es/components/Icons/hlCall.js +12 -4
  266. package/build/es/components/Icons/hlCameraBack.js +18 -6
  267. package/build/es/components/Icons/hlCameraFront.js +14 -5
  268. package/build/es/components/Icons/hlCart.js +16 -6
  269. package/build/es/components/Icons/hlCartEmpty.js +16 -6
  270. package/build/es/components/Icons/hlChat.js +24 -7
  271. package/build/es/components/Icons/hlCheck.js +12 -4
  272. package/build/es/components/Icons/hlChevronDown.js +12 -4
  273. package/build/es/components/Icons/hlChevronLeft.js +12 -4
  274. package/build/es/components/Icons/hlChevronRight.js +12 -4
  275. package/build/es/components/Icons/hlChevronUp.js +12 -4
  276. package/build/es/components/Icons/hlCompensation.js +12 -4
  277. package/build/es/components/Icons/hlCookie.js +12 -4
  278. package/build/es/components/Icons/hlCopy.js +14 -5
  279. package/build/es/components/Icons/hlCoupon.js +16 -6
  280. package/build/es/components/Icons/hlDelivery.js +14 -4
  281. package/build/es/components/Icons/hlDigiturva.js +14 -4
  282. package/build/es/components/Icons/hlDisplaySize.js +19 -6
  283. package/build/es/components/Icons/hlDocument.js +14 -5
  284. package/build/es/components/Icons/hlDownload.js +18 -6
  285. package/build/es/components/Icons/hlEnvelope.js +12 -4
  286. package/build/es/components/Icons/hlError.js +22 -6
  287. package/build/es/components/Icons/hlEuro.js +12 -4
  288. package/build/es/components/Icons/hlExclamationMark.js +12 -4
  289. package/build/es/components/Icons/hlExpand.js +12 -4
  290. package/build/es/components/Icons/hlExternal.js +12 -4
  291. package/build/es/components/Icons/hlEyeClosed.js +12 -4
  292. package/build/es/components/Icons/hlEyeOpen.js +14 -5
  293. package/build/es/components/Icons/hlFaceId.js +12 -4
  294. package/build/es/components/Icons/hlFastDelivery.js +12 -4
  295. package/build/es/components/Icons/hlFingerprint.js +20 -8
  296. package/build/es/components/Icons/hlGlobe.js +12 -4
  297. package/build/es/components/Icons/hlHeadphones.js +12 -4
  298. package/build/es/components/Icons/hlHeadset.js +18 -6
  299. package/build/es/components/Icons/hlHeart.js +12 -4
  300. package/build/es/components/Icons/hlHome.js +12 -4
  301. package/build/es/components/Icons/hlHub.js +14 -5
  302. package/build/es/components/Icons/hlImage.js +12 -4
  303. package/build/es/components/Icons/hlInfo.js +18 -6
  304. package/build/es/components/Icons/hlInstallment.js +14 -5
  305. package/build/es/components/Icons/hlIotSim.js +14 -5
  306. package/build/es/components/Icons/hlLaptop.js +13 -4
  307. package/build/es/components/Icons/hlLink.js +16 -5
  308. package/build/es/components/Icons/hlLiveVideo.js +12 -4
  309. package/build/es/components/Icons/hlLock.js +18 -6
  310. package/build/es/components/Icons/hlMagnifyingGlass.js +14 -5
  311. package/build/es/components/Icons/hlMarker.js +14 -5
  312. package/build/es/components/Icons/hlMemory.js +14 -5
  313. package/build/es/components/Icons/hlMenu.js +12 -4
  314. package/build/es/components/Icons/hlMinimize.js +12 -4
  315. package/build/es/components/Icons/hlMinus.js +12 -4
  316. package/build/es/components/Icons/hlMobileData.js +12 -4
  317. package/build/es/components/Icons/hlMobilePayment.js +19 -6
  318. package/build/es/components/Icons/hlModem.js +26 -8
  319. package/build/es/components/Icons/hlMore.js +22 -6
  320. package/build/es/components/Icons/hlOs.js +14 -5
  321. package/build/es/components/Icons/hlPackage.js +12 -4
  322. package/build/es/components/Icons/hlPaperclip.js +12 -4
  323. package/build/es/components/Icons/hlPaytime.js +12 -4
  324. package/build/es/components/Icons/hlPen.js +12 -4
  325. package/build/es/components/Icons/hlPerson.js +12 -4
  326. package/build/es/components/Icons/hlPhone.js +17 -5
  327. package/build/es/components/Icons/hlPlaylist.js +13 -4
  328. package/build/es/components/Icons/hlPlus.js +14 -5
  329. package/build/es/components/Icons/hlPrepaid.js +12 -4
  330. package/build/es/components/Icons/hlProcessor.js +14 -5
  331. package/build/es/components/Icons/hlServices.js +12 -4
  332. package/build/es/components/Icons/hlSettings.js +12 -4
  333. package/build/es/components/Icons/hlShield.js +14 -5
  334. package/build/es/components/Icons/hlSim.js +14 -5
  335. package/build/es/components/Icons/hlSimSimple.js +18 -6
  336. package/build/es/components/Icons/hlSmile.js +22 -7
  337. package/build/es/components/Icons/hlSpeechBubble.js +14 -5
  338. package/build/es/components/Icons/hlSquaretrade.js +13 -4
  339. package/build/es/components/Icons/hlStar.js +12 -4
  340. package/build/es/components/Icons/hlStarFilled.js +12 -4
  341. package/build/es/components/Icons/hlTrash.js +14 -5
  342. package/build/es/components/Icons/hlTv.js +12 -4
  343. package/build/es/components/Icons/hlUnlock.js +14 -6
  344. package/build/es/components/Icons/hlUpload.js +18 -6
  345. package/build/es/components/Icons/hlWarning.js +18 -6
  346. package/build/es/components/Icons/hlWifi.js +18 -6
  347. package/build/es/components/Icons/hlWrench.js +12 -4
  348. package/build/es/components/Icons/hlX.js +12 -4
  349. package/build/es/components/InfoDialog/InfoDialog.js +31 -46
  350. package/build/es/components/Input/Input.js +143 -159
  351. package/build/es/components/Label/Label.js +22 -22
  352. package/build/es/components/LabelText/LabelText.js +24 -17
  353. package/build/es/components/MainHeaderNavigation/ChildComponents/BusinessMenu.js +29 -44
  354. package/build/es/components/MainHeaderNavigation/ChildComponents/DesktopMenu.js +167 -153
  355. package/build/es/components/MainHeaderNavigation/ChildComponents/LanguageSelector.js +34 -20
  356. package/build/es/components/MainHeaderNavigation/ChildComponents/LinkModifier.js +50 -32
  357. package/build/es/components/MainHeaderNavigation/ChildComponents/LoginTooltip.js +17 -5
  358. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.d.ts +5 -2
  359. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.js +100 -95
  360. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.d.ts +6 -2
  361. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.js +4 -58
  362. package/build/es/components/MainHeaderNavigation/ChildComponents/MinicartTooltip.js +20 -4
  363. package/build/es/components/MainHeaderNavigation/ChildComponents/MobileMenu.js +187 -159
  364. package/build/es/components/MainHeaderNavigation/ChildComponents/PageSearch.js +16 -5
  365. package/build/es/components/MainHeaderNavigation/MainHeaderNavigation.js +305 -272
  366. package/build/es/components/MainHeaderNavigation/context/NavContext.js +61 -49
  367. package/build/es/components/MainHeaderNavigation/globalNavStyles.d.ts +31 -16
  368. package/build/es/components/MainHeaderNavigation/globalNavStyles.js +39 -172
  369. package/build/es/components/Modal/Modal.js +127 -145
  370. package/build/es/components/Notification/Notification.js +74 -54
  371. package/build/es/components/NotificationBadge/NotificationBadge.js +29 -32
  372. package/build/es/components/Overlay/Overlay.js +70 -68
  373. package/build/es/components/Pill/Pill.js +91 -82
  374. package/build/es/components/PillGroup/PillGroup.js +50 -33
  375. package/build/es/components/PixelLoader/PixelLoader.js +37 -34
  376. package/build/es/components/PriorityNavigation/PriorityNavigation.js +281 -303
  377. package/build/es/components/PriorityNavigationItem/PriorityNavigationItem.js +27 -49
  378. package/build/es/components/ProgressIndicator/ProgressIndicator.js +140 -109
  379. package/build/es/components/RadioButton/RadioButton.js +91 -114
  380. package/build/es/components/ReadMore/ReadMore.js +86 -69
  381. package/build/es/components/Search/Search.js +52 -64
  382. package/build/es/components/Selectbox/Selectbox.js +279 -94
  383. package/build/es/components/Skeleton/Skeleton.js +69 -56
  384. package/build/es/components/Switch/Switch.js +62 -76
  385. package/build/es/components/Tab/Tab.js +55 -53
  386. package/build/es/components/Tabs/Tabs.js +93 -71
  387. package/build/es/components/Textarea/Textarea.js +76 -73
  388. package/build/es/components/Toaster/Toaster.js +59 -44
  389. package/build/es/components/Tooltip/Tooltip.js +74 -87
  390. package/build/es/hooks/useCloseOutsideOrElementClicked.js +23 -21
  391. package/build/es/hooks/useDebounce.js +9 -9
  392. package/build/es/hooks/useDocHeight.js +13 -13
  393. package/build/es/hooks/useOutsideClick.js +10 -10
  394. package/build/es/hooks/useResizeObserver.js +37 -24
  395. package/build/es/hooks/useScrollPosition.js +55 -54
  396. package/build/es/hooks/useWindowSize.js +20 -20
  397. package/build/es/themes/globalStyles.js +4 -4
  398. package/build/es/themes/gridTheme.js +1 -1
  399. package/build/es/themes/theme.js +12 -12
  400. package/build/es/themes/themeComponents/base.js +9 -8
  401. package/build/es/themes/themeComponents/breakpoints.js +6 -6
  402. package/build/es/themes/themeComponents/color.js +76 -74
  403. package/build/es/themes/themeComponents/fontFamily.js +3 -3
  404. package/build/es/themes/themeComponents/fontSize.js +31 -15
  405. package/build/es/themes/themeComponents/fontWeight.js +16 -16
  406. package/build/es/themes/themeComponents/forms.js +3 -2
  407. package/build/es/themes/themeComponents/layout.js +27 -27
  408. package/build/es/themes/themeComponents/lineHeight.js +32 -16
  409. package/build/es/themes/themeComponents/navigation.js +13 -13
  410. package/build/es/themes/themeComponents/radius.js +26 -26
  411. package/build/es/utils/common.js +15 -19
  412. package/build/es/utils/createStyled.d.ts +154 -134
  413. package/build/es/utils/createStyled.js +16 -2
  414. package/build/es/utils/styledUtils.js +2 -6
  415. package/package.json +15 -13
@@ -13,88 +13,53 @@ import ButtonIcon from '../ButtonIcon/ButtonIcon.js';
13
13
  import Icon from '../Icon/Icon.js';
14
14
  import PriorityNavigationItem from '../PriorityNavigationItem/PriorityNavigationItem.js';
15
15
 
16
- const Container = styled.div `
17
- width: 100%;
18
-
19
- ${media.md ` border-bottom: 1px solid ${theme.color.line.L03}; `}
20
- `;
21
- const Category = styled.span `
22
- margin: 0;
23
- color: ${theme.color.text.black};
24
- font-size: ${theme.fontSize.h4};
25
- font-weight: ${theme.fontWeight.bold};
26
- line-height: ${theme.lineHeight.h4};
27
- display: block;
28
-
29
- ${media.md `
16
+ const Container = styled.div.withConfig({
17
+ displayName: "PriorityNavigation__Container",
18
+ componentId: "sc-1fa414d-0"
19
+ })(["width:100%;", ""], media.md` border-bottom: 1px solid ${theme.color.line.L03}; `);
20
+ const Category = styled.span.withConfig({
21
+ displayName: "PriorityNavigation__Category",
22
+ componentId: "sc-1fa414d-1"
23
+ })(["margin:0;color:", ";font-size:", ";font-weight:", ";line-height:", ";display:block;", ""], theme.color.text.black, theme.fontSize.h4, theme.fontWeight.bold, theme.lineHeight.h4, media.md`
30
24
  padding: 1.25rem 0.25rem 0;
31
25
  background: linear-gradient(
32
26
  ${theme.color.default.black}05 0%,
33
27
  ${theme.color.default.black}00 50%,
34
28
  ${theme.color.default.black}00 100%),
35
29
  ${theme.color.background.white.default};
36
- `}
37
- `;
38
- const ListsContainer = styled.div `
39
- display: flex;
40
- flex-direction: column;
41
- position: relative;
42
- background-color: ${theme.color.background.white.default};
43
-
44
- ${media.md `
30
+ `);
31
+ const ListsContainer = styled.div.withConfig({
32
+ displayName: "PriorityNavigation__ListsContainer",
33
+ componentId: "sc-1fa414d-2"
34
+ })(["display:flex;flex-direction:column;position:relative;background-color:", ";", ""], theme.color.background.white.default, media.md`
45
35
  justify-content: space-between;
46
36
  flex-direction: row;
47
37
  height: 100%;
48
38
  align-items: center;
49
39
  margin: 0 auto;
50
- `}
51
- `;
52
- const MobileDropdown = styled.button `
53
- display: flex;
54
- align-items: center;
55
- justify-content: space-between;
56
- cursor: pointer;
57
- background: none;
58
- border: none;
59
- padding: ${({ $isCategoryLabel }) => ($isCategoryLabel ? '0.5rem' : '0.75rem')} 1.25rem;
60
- color: ${theme.color.text.pink};
61
- font-size: ${theme.fontSize.default};
62
- line-height: ${theme.lineHeight.default};
63
- font-weight: ${theme.fontWeight.bold};
64
- border-bottom: 3px solid ${theme.color.default.pink};
65
-
66
- & svg {
67
- pointer-events: none;
68
- }
69
- `;
70
- const MobileDropdownContent = styled.div `
71
- display: flex;
72
- flex-direction: column;
73
- align-items: baseline;
74
- text-align: left;
75
- `;
76
- const CoreULStyles = styled.ul `
77
- list-style: none;
78
- margin: 0;
79
- padding: 0;
80
- overflow: hidden;
81
- `;
82
- const NavigationList = styled(CoreULStyles) `
83
- display: flex;
84
- flex-direction: column;
85
- justify-content: flex-start;
86
- z-index: 1;
87
- width: 100%;
88
- background-color: ${theme.color.background.white.default};
89
- position: absolute;
90
- top: ${getMultipliedSize(theme.base.baseHeight, 5.6)};
91
- visibility: ${({ $isMobileNavigationOpen }) => $isMobileNavigationOpen ? 'visible' : 'hidden'};
92
- clip-path: inset(
93
- 0% 0% ${({ $isMobileNavigationOpen }) => ($isMobileNavigationOpen ? '0%' : '100%')} 0%
94
- );
95
- transition: all 0.2s ease-in-out;
96
-
97
- ${media.md `
40
+ `);
41
+ const MobileDropdown = styled.button.withConfig({
42
+ displayName: "PriorityNavigation__MobileDropdown",
43
+ componentId: "sc-1fa414d-3"
44
+ })(["display:flex;align-items:center;justify-content:space-between;cursor:pointer;background:none;border:none;padding:", " 1.25rem;color:", ";font-size:", ";line-height:", ";font-weight:", ";border-bottom:3px solid ", ";& svg{pointer-events:none;}"], ({
45
+ $isCategoryLabel
46
+ }) => $isCategoryLabel ? '0.5rem' : '0.75rem', theme.color.text.pink, theme.fontSize.default, theme.lineHeight.default, theme.fontWeight.bold, theme.color.default.pink);
47
+ const MobileDropdownContent = styled.div.withConfig({
48
+ displayName: "PriorityNavigation__MobileDropdownContent",
49
+ componentId: "sc-1fa414d-4"
50
+ })(["display:flex;flex-direction:column;align-items:baseline;text-align:left;"]);
51
+ const CoreULStyles = styled.ul.withConfig({
52
+ displayName: "PriorityNavigation__CoreULStyles",
53
+ componentId: "sc-1fa414d-5"
54
+ })(["list-style:none;margin:0;padding:0;overflow:hidden;"]);
55
+ const NavigationList = styled(CoreULStyles).withConfig({
56
+ displayName: "PriorityNavigation__NavigationList",
57
+ componentId: "sc-1fa414d-6"
58
+ })(["display:flex;flex-direction:column;justify-content:flex-start;z-index:1;width:100%;background-color:", ";position:absolute;top:", ";visibility:", ";clip-path:inset( 0% 0% ", " 0% );transition:all 0.2s ease-in-out;", ""], theme.color.background.white.default, getMultipliedSize(theme.base.baseHeight, 5.6), ({
59
+ $isMobileNavigationOpen
60
+ }) => $isMobileNavigationOpen ? 'visible' : 'hidden', ({
61
+ $isMobileNavigationOpen
62
+ }) => $isMobileNavigationOpen ? '0%' : '100%', media.md`
98
63
  position: static;
99
64
  flex-direction: row;
100
65
  visibility: visible;
@@ -106,255 +71,268 @@ const NavigationList = styled(CoreULStyles) `
106
71
  & > li:first-child {
107
72
  margin-left: 0;
108
73
  }
109
- `}
110
- `;
111
- const DropdownList = styled(CoreULStyles) `
112
- position: absolute;
113
- top: ${getMultipliedSize(theme.base.baseHeight, 6)};
114
- right: 0;
115
- z-index: 1;
116
- padding-bottom: 0.5rem;
117
- background-color: ${theme.color.background.white.default};
118
- border: 1px solid ${theme.color.line.L04};
119
- border-radius: 0 0 ${theme.radius.default} ${theme.radius.default};
120
- visibility: ${({ $isDropdownListOpen }) => ($isDropdownListOpen ? 'visible' : 'hidden')};
121
- clip-path: inset(
122
- 0% 0% ${({ $isDropdownListOpen }) => ($isDropdownListOpen ? '0%' : '100%')} 0%
123
- );
124
- transition: all 0.2s ease-in-out;
125
-
126
- ${media.md `
74
+ `);
75
+ const DropdownList = styled(CoreULStyles).withConfig({
76
+ displayName: "PriorityNavigation__DropdownList",
77
+ componentId: "sc-1fa414d-7"
78
+ })(["position:absolute;top:", ";right:0;z-index:1;padding-bottom:0.5rem;background-color:", ";border:1px solid ", ";border-radius:0 0 ", " ", ";visibility:", ";clip-path:inset( 0% 0% ", " 0% );transition:all 0.2s ease-in-out;", " ", ""], getMultipliedSize(theme.base.baseHeight, 6), theme.color.background.white.default, theme.color.line.L04, theme.radius.default, theme.radius.default, ({
79
+ $isDropdownListOpen
80
+ }) => $isDropdownListOpen ? 'visible' : 'hidden', ({
81
+ $isDropdownListOpen
82
+ }) => $isDropdownListOpen ? '0%' : '100%', media.md`
127
83
  & > li {
128
84
  margin: auto 1.25rem;
129
85
  }
130
- `}
131
-
132
- ${getElevationShadow({ elevation: 'low' })}
133
- `;
86
+ `, getElevationShadow({
87
+ elevation: 'low'
88
+ }));
134
89
  /**
135
90
  * TODO: Replace the VisuallyHidden styled component with the global class name.
136
91
  * Ticket: https://jira.dna.fi/browse/STYLE-916
137
92
  */
138
- const VisuallyHidden = styled.span `
139
- position: absolute;
140
- width: 1px;
141
- height: 1px;
142
- padding: 0;
143
- margin: -1px;
144
- overflow: hidden;
145
- clip: rect(0 0 0 0);
146
- clip-path: inset(50%);
147
- white-space: nowrap;
148
- border: 0;
149
- `;
93
+ const VisuallyHidden = styled.span.withConfig({
94
+ displayName: "PriorityNavigation__VisuallyHidden",
95
+ componentId: "sc-1fa414d-8"
96
+ })(["position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0;"]);
150
97
  const reducer = (state, action) => {
151
- var _a, _b;
152
- switch (action.type) {
153
- case 'resetNavigationState': {
154
- const navigationItems = Children.toArray((_a = action === null || action === void 0 ? void 0 : action.payload) === null || _a === void 0 ? void 0 : _a.navigationItems);
155
- return Object.assign(Object.assign({}, state), { navigationItems: navigationItems.slice(0, navigationItems.length - state.lastItemWidth.length), dropdownItems: navigationItems.slice(navigationItems.length - state.lastItemWidth.length) });
156
- }
157
- case 'moveItemToDropdown': {
158
- const lastChild = state.navigationItems[state.navigationItems.length - 1];
159
- return Object.assign(Object.assign(Object.assign({}, state), { navigationItems: state.navigationItems.slice(0, -1), dropdownItems: [lastChild, ...state.dropdownItems] }), (((_b = action === null || action === void 0 ? void 0 : action.payload) === null || _b === void 0 ? void 0 : _b.lastItem) && {
160
- lastItemWidth: [
161
- ...state.lastItemWidth,
162
- action.payload.lastItem.offsetWidth + 40,
163
- ],
164
- }));
98
+ var _a, _b;
99
+ switch (action.type) {
100
+ case 'resetNavigationState':
101
+ {
102
+ const navigationItems = Children.toArray((_a = action === null || action === void 0 ? void 0 : action.payload) === null || _a === void 0 ? void 0 : _a.navigationItems);
103
+ return Object.assign(Object.assign({}, state), {
104
+ navigationItems: navigationItems.slice(0, navigationItems.length - state.lastItemWidth.length),
105
+ dropdownItems: navigationItems.slice(navigationItems.length - state.lastItemWidth.length)
106
+ });
107
+ }
108
+ case 'moveItemToDropdown':
109
+ {
110
+ const lastChild = state.navigationItems[state.navigationItems.length - 1];
111
+ return Object.assign(Object.assign(Object.assign({}, state), {
112
+ navigationItems: state.navigationItems.slice(0, -1),
113
+ dropdownItems: [lastChild, ...state.dropdownItems]
114
+ }), ((_b = action === null || action === void 0 ? void 0 : action.payload) === null || _b === void 0 ? void 0 : _b.lastItem) && {
115
+ lastItemWidth: [...state.lastItemWidth, action.payload.lastItem.offsetWidth + 40]
116
+ });
117
+ }
118
+ case 'moveItemToNavigation':
119
+ {
120
+ const [firstItemFromList, ...dropdownItems] = state.dropdownItems;
121
+ const [, ...lastItemWidth] = state.lastItemWidth;
122
+ return {
123
+ navigationItems: [...state.navigationItems, firstItemFromList],
124
+ dropdownItems,
125
+ lastItemWidth
126
+ };
127
+ }
128
+ default:
129
+ return state;
130
+ }
131
+ };
132
+ const getReactNodeText = reactNode => {
133
+ if (reactNode === null) {
134
+ return '';
135
+ }
136
+ switch (typeof reactNode) {
137
+ case 'string':
138
+ case 'number':
139
+ return reactNode.toString();
140
+ case 'boolean':
141
+ return '';
142
+ case 'object':
143
+ {
144
+ if (reactNode instanceof Array) {
145
+ return reactNode.map(getReactNodeText).join('');
165
146
  }
166
- case 'moveItemToNavigation': {
167
- const [firstItemFromList, ...dropdownItems] = state.dropdownItems;
168
- const [, ...lastItemWidth] = state.lastItemWidth;
169
- return {
170
- navigationItems: [...state.navigationItems, firstItemFromList],
171
- dropdownItems,
172
- lastItemWidth,
173
- };
147
+ if ('props' in reactNode) {
148
+ // Unsafe member access .children on an `any` value (@typescript-eslint/no-unsafe-member-access)
149
+ // eslint-disable-next-line
150
+ return getReactNodeText(reactNode.props.children);
174
151
  }
175
- default:
176
- return state;
177
- }
178
- };
179
- const getReactNodeText = (reactNode) => {
180
- if (reactNode === null) {
181
152
  return '';
182
- }
183
- switch (typeof reactNode) {
184
- case 'string':
185
- case 'number':
186
- return reactNode.toString();
187
- case 'boolean':
188
- return '';
189
- case 'object': {
190
- if (reactNode instanceof Array) {
191
- return reactNode.map(getReactNodeText).join('');
192
- }
193
- if ('props' in reactNode) {
194
- // Unsafe member access .children on an `any` value (@typescript-eslint/no-unsafe-member-access)
195
- // eslint-disable-next-line
196
- return getReactNodeText(reactNode.props.children);
197
- }
198
- return '';
199
- }
200
- default:
201
- return '';
202
- }
153
+ }
154
+ default:
155
+ return '';
156
+ }
203
157
  };
204
158
  /**
205
159
  * @visibleName Priority Navigation
206
160
  */
207
- const PriorityNavigation = (_a) => {
208
- var { dropdownButtonLabel = 'Lisää', 'data-testid': dataTestId, mobileDropdownAriaLabel, currentPageAriaLabel, openMoreSubpagesAriaLabel } = _a, props = __rest(_a, ["dropdownButtonLabel", 'data-testid', "mobileDropdownAriaLabel", "currentPageAriaLabel", "openMoreSubpagesAriaLabel"]);
209
- const listsContainerRef = useRef(null);
210
- const navigationListRef = useRef(null);
211
- const dropdownButtonRef = useRef(null);
212
- const categoryId = useId();
213
- const { isMobile } = useWindowSize(theme.breakpoints.md);
214
- const { width: wrapperContainerWidth } = useResizeObserver(listsContainerRef);
215
- const [isMobileNavigationOpen, setIsMobileNavigationOpen] = useState(false);
216
- const toggleMobileNavigation = () => setIsMobileNavigationOpen(!isMobileNavigationOpen);
217
- const [isDropdownListOpen, setIsDropdownListOpen] = useState(false);
218
- const toggleDropdown = () => {
219
- if (props.onDropdownListToggle) {
220
- props.onDropdownListToggle(!isDropdownListOpen);
221
- }
222
- setIsDropdownListOpen(!isDropdownListOpen);
223
- };
224
- const navigationItems = useRef(new Map()).current;
225
- const initialState = {
226
- navigationItems: Children.toArray(props.children),
227
- dropdownItems: [],
228
- lastItemWidth: [],
229
- };
230
- const [state, dispatch] = useReducer(reducer, initialState);
231
- const checkHorizontalOverflow = useDebounce(() => {
232
- var _a, _b;
233
- if (navigationListRef.current && listsContainerRef.current) {
234
- const navigationListWidth = navigationListRef.current.scrollWidth;
235
- const dropdownButtonWidth = ((_b = (_a = dropdownButtonRef.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) !== null && _b !== void 0 ? _b : 80) + 20;
236
- if (state.navigationItems.length > 0 &&
237
- navigationListWidth + dropdownButtonWidth > wrapperContainerWidth) {
238
- dispatch({
239
- type: 'moveItemToDropdown',
240
- payload: {
241
- lastItem: navigationItems.get(state.navigationItems.length - 1),
242
- },
243
- });
244
- }
245
- else if (state.dropdownItems.length > 0 &&
246
- wrapperContainerWidth >
247
- navigationListWidth +
248
- state.lastItemWidth[state.lastItemWidth.length - 1] +
249
- dropdownButtonWidth +
250
- 20) {
251
- dispatch({
252
- type: 'moveItemToNavigation',
253
- });
254
- }
255
- }
256
- }, 100);
257
- const activeItem = [...state.navigationItems, ...state.dropdownItems].find(child => isValidElement(child) &&
258
- child.type === PriorityNavigationItem &&
259
- child.props.isActive);
260
- const selectedItem = isMobile
261
- ? getReactNodeText(activeItem === null || activeItem === void 0 ? void 0 : activeItem.props.children) ||
262
- ''
263
- : props.categoryLabel;
264
- useOutsideClick(listsContainerRef, () => {
265
- if (isMobileNavigationOpen) {
266
- setIsMobileNavigationOpen(false);
267
- }
268
- if (isDropdownListOpen) {
269
- if (props.onDropdownListToggle) {
270
- props.onDropdownListToggle(false);
271
- }
272
- setIsDropdownListOpen(false);
273
- }
274
- });
275
- useEffect(() => {
276
- if (!isMobile) {
277
- requestAnimationFrame(() => {
278
- dispatch({
279
- type: 'resetNavigationState',
280
- payload: {
281
- navigationItems: props.children,
282
- },
283
- });
284
- setTimeout(() => {
285
- checkHorizontalOverflow();
286
- }, 0);
287
- });
288
- }
289
- setIsMobileNavigationOpen(false);
290
- // eslint-disable-next-line react-hooks/exhaustive-deps
291
- }, [isMobile, props.children]);
292
- useLayoutEffect(() => {
293
- if (!isMobile) {
294
- requestAnimationFrame(() => {
295
- checkHorizontalOverflow();
296
- });
297
- }
298
- }, [
299
- isMobile,
300
- wrapperContainerWidth,
301
- state.navigationItems.length,
302
- state.dropdownItems.length,
303
- checkHorizontalOverflow,
304
- ]);
305
- const handleNavigationListKeyDown = useCallback((e) => {
306
- var _a, _b;
307
- if (isMobile && isMobileNavigationOpen && e.key === 'Tab') {
308
- const focusableElements = (_a = navigationListRef.current) === null || _a === void 0 ? void 0 : _a.querySelectorAll('a, button, input, [tabindex]:not([tabindex="-1"])');
309
- const lastElement = focusableElements === null || focusableElements === void 0 ? void 0 : focusableElements[focusableElements.length - 1];
310
- const goingForward = !e.shiftKey;
311
- if (goingForward && document.activeElement === lastElement) {
312
- e.preventDefault();
313
- setIsMobileNavigationOpen(false);
314
- (_b = dropdownButtonRef.current) === null || _b === void 0 ? void 0 : _b.focus();
315
- }
316
- }
317
- }, [isMobile, isMobileNavigationOpen]);
318
- const handleItemClick = (e) => {
161
+ const PriorityNavigation = _a => {
162
+ var {
163
+ dropdownButtonLabel = 'Lisää',
164
+ 'data-testid': dataTestId,
165
+ mobileDropdownAriaLabel,
166
+ currentPageAriaLabel,
167
+ openMoreSubpagesAriaLabel
168
+ } = _a,
169
+ props = __rest(_a, ["dropdownButtonLabel", 'data-testid', "mobileDropdownAriaLabel", "currentPageAriaLabel", "openMoreSubpagesAriaLabel"]);
170
+ const listsContainerRef = useRef(null);
171
+ const navigationListRef = useRef(null);
172
+ const dropdownButtonRef = useRef(null);
173
+ const categoryId = useId();
174
+ const {
175
+ isMobile
176
+ } = useWindowSize(theme.breakpoints.md);
177
+ const {
178
+ width: wrapperContainerWidth
179
+ } = useResizeObserver(listsContainerRef);
180
+ const [isMobileNavigationOpen, setIsMobileNavigationOpen] = useState(false);
181
+ const toggleMobileNavigation = () => setIsMobileNavigationOpen(!isMobileNavigationOpen);
182
+ const [isDropdownListOpen, setIsDropdownListOpen] = useState(false);
183
+ const toggleDropdown = () => {
184
+ if (props.onDropdownListToggle) {
185
+ props.onDropdownListToggle(!isDropdownListOpen);
186
+ }
187
+ setIsDropdownListOpen(!isDropdownListOpen);
188
+ };
189
+ const navigationItems = useRef(new Map()).current;
190
+ const initialState = {
191
+ navigationItems: Children.toArray(props.children),
192
+ dropdownItems: [],
193
+ lastItemWidth: []
194
+ };
195
+ const [state, dispatch] = useReducer(reducer, initialState);
196
+ const checkHorizontalOverflow = useDebounce(() => {
197
+ var _a, _b;
198
+ if (navigationListRef.current && listsContainerRef.current) {
199
+ const navigationListWidth = navigationListRef.current.scrollWidth;
200
+ const dropdownButtonWidth = ((_b = (_a = dropdownButtonRef.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) !== null && _b !== void 0 ? _b : 80) + 20;
201
+ if (state.navigationItems.length > 0 && navigationListWidth + dropdownButtonWidth > wrapperContainerWidth) {
202
+ dispatch({
203
+ type: 'moveItemToDropdown',
204
+ payload: {
205
+ lastItem: navigationItems.get(state.navigationItems.length - 1)
206
+ }
207
+ });
208
+ } else if (state.dropdownItems.length > 0 && wrapperContainerWidth > navigationListWidth + state.lastItemWidth[state.lastItemWidth.length - 1] + dropdownButtonWidth + 20) {
209
+ dispatch({
210
+ type: 'moveItemToNavigation'
211
+ });
212
+ }
213
+ }
214
+ }, 100);
215
+ const activeItem = [...state.navigationItems, ...state.dropdownItems].find(child => /*#__PURE__*/isValidElement(child) && child.type === PriorityNavigationItem && child.props.isActive);
216
+ const selectedItem = isMobile ? getReactNodeText(activeItem === null || activeItem === void 0 ? void 0 : activeItem.props.children) || '' : props.categoryLabel;
217
+ useOutsideClick(listsContainerRef, () => {
218
+ if (isMobileNavigationOpen) {
219
+ setIsMobileNavigationOpen(false);
220
+ }
221
+ if (isDropdownListOpen) {
222
+ if (props.onDropdownListToggle) {
223
+ props.onDropdownListToggle(false);
224
+ }
225
+ setIsDropdownListOpen(false);
226
+ }
227
+ });
228
+ useEffect(() => {
229
+ if (!isMobile) {
230
+ requestAnimationFrame(() => {
231
+ dispatch({
232
+ type: 'resetNavigationState',
233
+ payload: {
234
+ navigationItems: props.children
235
+ }
236
+ });
237
+ setTimeout(() => {
238
+ checkHorizontalOverflow();
239
+ }, 0);
240
+ });
241
+ }
242
+ setIsMobileNavigationOpen(false);
243
+ // eslint-disable-next-line react-hooks/exhaustive-deps
244
+ }, [isMobile, props.children]);
245
+ useLayoutEffect(() => {
246
+ if (!isMobile) {
247
+ requestAnimationFrame(() => {
248
+ checkHorizontalOverflow();
249
+ });
250
+ }
251
+ }, [isMobile, wrapperContainerWidth, state.navigationItems.length, state.dropdownItems.length, checkHorizontalOverflow]);
252
+ const handleNavigationListKeyDown = useCallback(e => {
253
+ var _a, _b;
254
+ if (isMobile && isMobileNavigationOpen && e.key === 'Tab') {
255
+ const focusableElements = (_a = navigationListRef.current) === null || _a === void 0 ? void 0 : _a.querySelectorAll('a, button, input, [tabindex]:not([tabindex="-1"])');
256
+ const lastElement = focusableElements === null || focusableElements === void 0 ? void 0 : focusableElements[focusableElements.length - 1];
257
+ const goingForward = !e.shiftKey;
258
+ if (goingForward && document.activeElement === lastElement) {
259
+ e.preventDefault();
319
260
  setIsMobileNavigationOpen(false);
320
- if (props.onClick) {
321
- props.onClick(e);
261
+ (_b = dropdownButtonRef.current) === null || _b === void 0 ? void 0 : _b.focus();
262
+ }
263
+ }
264
+ }, [isMobile, isMobileNavigationOpen]);
265
+ const handleItemClick = e => {
266
+ setIsMobileNavigationOpen(false);
267
+ if (props.onClick) {
268
+ props.onClick(e);
269
+ }
270
+ };
271
+ return /*#__PURE__*/React__default.createElement(Container, {
272
+ id: props.id,
273
+ className: props.className,
274
+ "data-testid": dataTestId
275
+ }, !isMobile && props.categoryLabel && (/*#__PURE__*/React__default.createElement(Category, {
276
+ id: categoryId
277
+ }, props.categoryLabel)), /*#__PURE__*/React__default.createElement("nav", {
278
+ "aria-labelledby": categoryId
279
+ }, /*#__PURE__*/React__default.createElement(ListsContainer, {
280
+ ref: listsContainerRef
281
+ }, isMobile && selectedItem && (/*#__PURE__*/React__default.createElement(MobileDropdown, {
282
+ onClick: toggleMobileNavigation,
283
+ "aria-label": mobileDropdownAriaLabel !== null && mobileDropdownAriaLabel !== void 0 ? mobileDropdownAriaLabel : `${props.categoryLabel ? `${props.categoryLabel}, ` : ''}${selectedItem}.`,
284
+ "aria-expanded": isMobileNavigationOpen,
285
+ "$isCategoryLabel": Boolean(props.categoryLabel)
286
+ }, /*#__PURE__*/React__default.createElement(MobileDropdownContent, null, props.categoryLabel && /*#__PURE__*/React__default.createElement(Category, null, props.categoryLabel), selectedItem), /*#__PURE__*/React__default.createElement(Icon, {
287
+ icon: isMobileNavigationOpen ? OvalChevronUp : OvalChevronDown,
288
+ size: "2.5rem"
289
+ }))), /*#__PURE__*/React__default.createElement(NavigationList, {
290
+ ref: navigationListRef,
291
+ "$isMobileNavigationOpen": isMobileNavigationOpen,
292
+ onKeyDown: handleNavigationListKeyDown
293
+ }, Children.map([...state.navigationItems, ...(isMobile ? state.dropdownItems : [])], (navigationItem, index) => {
294
+ if (/*#__PURE__*/isValidElement(navigationItem) && navigationItem.type === PriorityNavigationItem) {
295
+ return /*#__PURE__*/React__default.createElement(PriorityNavigationItem, {
296
+ id: navigationItem.props.id,
297
+ key: navigationItem.key,
298
+ onClick: handleItemClick,
299
+ onKeyDown: navigationItem.props.onKeyDown || props.onKeyDown,
300
+ isActive: navigationItem.props.isActive,
301
+ className: navigationItem.props.className,
302
+ "data-testid": navigationItem.props['data-testid'],
303
+ ref: instance => {
304
+ if (instance) {
305
+ navigationItems.set(index, instance);
306
+ }
322
307
  }
323
- };
324
- return (React__default.createElement(Container, { id: props.id, className: props.className, "data-testid": dataTestId },
325
- !isMobile && props.categoryLabel && (React__default.createElement(Category, { id: categoryId }, props.categoryLabel)),
326
- React__default.createElement("nav", { "aria-labelledby": categoryId },
327
- React__default.createElement(ListsContainer, { ref: listsContainerRef },
328
- isMobile && selectedItem && (React__default.createElement(MobileDropdown, { onClick: toggleMobileNavigation, "aria-label": mobileDropdownAriaLabel !== null && mobileDropdownAriaLabel !== void 0 ? mobileDropdownAriaLabel : `${props.categoryLabel ? `${props.categoryLabel}, ` : ''}${selectedItem}.`, "aria-expanded": isMobileNavigationOpen, "$isCategoryLabel": Boolean(props.categoryLabel) },
329
- React__default.createElement(MobileDropdownContent, null,
330
- props.categoryLabel && React__default.createElement(Category, null, props.categoryLabel),
331
- selectedItem),
332
- React__default.createElement(Icon, { icon: isMobileNavigationOpen ? OvalChevronUp : OvalChevronDown, size: "2.5rem" }))),
333
- React__default.createElement(NavigationList, { ref: navigationListRef, "$isMobileNavigationOpen": isMobileNavigationOpen, onKeyDown: handleNavigationListKeyDown }, Children.map([...state.navigationItems, ...(isMobile ? state.dropdownItems : [])], (navigationItem, index) => {
334
- if (isValidElement(navigationItem) &&
335
- navigationItem.type === PriorityNavigationItem) {
336
- return (React__default.createElement(PriorityNavigationItem, { id: navigationItem.props.id, key: navigationItem.key, onClick: handleItemClick, onKeyDown: navigationItem.props.onKeyDown || props.onKeyDown, isActive: navigationItem.props.isActive, className: navigationItem.props.className, "data-testid": navigationItem.props['data-testid'], ref: instance => {
337
- if (instance) {
338
- navigationItems.set(index, instance);
339
- }
340
- } },
341
- navigationItem.props.isActive
342
- ? cloneElement(navigationItem.props.children, {
343
- 'aria-current': 'page',
344
- })
345
- : navigationItem.props.children,
346
- navigationItem.props.isActive && isMobile && (React__default.createElement(React__default.Fragment, null,
347
- React__default.createElement(Icon, { icon: Check, "aria-hidden": true, color: theme.color.default.pink }),
348
- React__default.createElement(VisuallyHidden, null, currentPageAriaLabel)))));
349
- }
350
- return null;
351
- })),
352
- !isMobile && Boolean(state.dropdownItems.length) && (React__default.createElement(React__default.Fragment, null,
353
- React__default.createElement("div", null,
354
- React__default.createElement(ButtonIcon, { ref: dropdownButtonRef, ariaLabel: openMoreSubpagesAriaLabel, ariaExpanded: isDropdownListOpen, onClick: toggleDropdown, icon: isDropdownListOpen ? ChevronUp : ChevronDown, isReversed: true, "data-testid": "dropdown-button" }, dropdownButtonLabel)),
355
- isDropdownListOpen && (React__default.createElement(DropdownList, { "$isDropdownListOpen": isDropdownListOpen }, state.dropdownItems.map(dropdownItem => isValidElement(dropdownItem) &&
356
- dropdownItem.type === PriorityNavigationItem && (React__default.createElement(PriorityNavigationItem, { id: dropdownItem.props.id, key: dropdownItem.key, onClick: dropdownItem.props.onClick || props.onClick, onKeyDown: dropdownItem.props.onKeyDown ||
357
- props.onKeyDown, isActive: dropdownItem.props.isActive, className: dropdownItem.props.className, "data-testid": dropdownItem.props['data-testid'] }, dropdownItem.props.children)))))))))));
308
+ }, navigationItem.props.isActive ? /*#__PURE__*/cloneElement(navigationItem.props.children, {
309
+ 'aria-current': 'page'
310
+ }) : navigationItem.props.children, navigationItem.props.isActive && isMobile && (/*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement(Icon, {
311
+ icon: Check,
312
+ "aria-hidden": true,
313
+ color: theme.color.default.pink
314
+ }), /*#__PURE__*/React__default.createElement(VisuallyHidden, null, currentPageAriaLabel))));
315
+ }
316
+ return null;
317
+ })), !isMobile && Boolean(state.dropdownItems.length) && (/*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement("div", null, /*#__PURE__*/React__default.createElement(ButtonIcon, {
318
+ ref: dropdownButtonRef,
319
+ ariaLabel: openMoreSubpagesAriaLabel,
320
+ ariaExpanded: isDropdownListOpen,
321
+ onClick: toggleDropdown,
322
+ icon: isDropdownListOpen ? ChevronUp : ChevronDown,
323
+ isReversed: true,
324
+ "data-testid": "dropdown-button"
325
+ }, dropdownButtonLabel)), isDropdownListOpen && (/*#__PURE__*/React__default.createElement(DropdownList, {
326
+ "$isDropdownListOpen": isDropdownListOpen
327
+ }, state.dropdownItems.map(dropdownItem => /*#__PURE__*/isValidElement(dropdownItem) && dropdownItem.type === PriorityNavigationItem && (/*#__PURE__*/React__default.createElement(PriorityNavigationItem, {
328
+ id: dropdownItem.props.id,
329
+ key: dropdownItem.key,
330
+ onClick: dropdownItem.props.onClick || props.onClick,
331
+ onKeyDown: dropdownItem.props.onKeyDown || props.onKeyDown,
332
+ isActive: dropdownItem.props.isActive,
333
+ className: dropdownItem.props.className,
334
+ "data-testid": dropdownItem.props['data-testid']
335
+ }, dropdownItem.props.children))))))))));
358
336
  };
359
337
 
360
338
  export { PriorityNavigation as default };