@dnanpm/styleguide 4.0.8 → 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 (427) hide show
  1. package/build/cjs/_virtual/_virtual_inject.js +5 -0
  2. package/build/cjs/assets/fonts/fonts.css.js +3 -1
  3. package/build/cjs/components/Accordion/Accordion.js +66 -54
  4. package/build/cjs/components/AccordionItem/AccordionItem.js +94 -73
  5. package/build/cjs/components/AmountSelector/AmountSelector.js +121 -134
  6. package/build/cjs/components/Box/Box.js +38 -13
  7. package/build/cjs/components/Breadcrumb/Breadcrumb.js +73 -71
  8. package/build/cjs/components/Button/Button.d.ts +1 -1
  9. package/build/cjs/components/Button/Button.js +131 -127
  10. package/build/cjs/components/ButtonArrow/ButtonArrow.js +47 -49
  11. package/build/cjs/components/ButtonCard/ButtonCard.d.ts +2 -2
  12. package/build/cjs/components/ButtonCard/ButtonCard.js +97 -112
  13. package/build/cjs/components/ButtonClose/ButtonClose.d.ts +1 -1
  14. package/build/cjs/components/ButtonClose/ButtonClose.js +25 -14
  15. package/build/cjs/components/ButtonIcon/ButtonIcon.d.ts +44 -3
  16. package/build/cjs/components/ButtonIcon/ButtonIcon.js +105 -67
  17. package/build/cjs/components/ButtonPrimary/ButtonPrimary.d.ts +43 -2
  18. package/build/cjs/components/ButtonPrimary/ButtonPrimary.js +7 -35
  19. package/build/cjs/components/ButtonSecondary/ButtonSecondary.d.ts +43 -2
  20. package/build/cjs/components/ButtonSecondary/ButtonSecondary.js +7 -35
  21. package/build/cjs/components/Carousel/Carousel.d.ts +8 -2
  22. package/build/cjs/components/Carousel/Carousel.js +315 -346
  23. package/build/cjs/components/Checkbox/Checkbox.js +49 -108
  24. package/build/cjs/components/Chip/Chip.js +40 -34
  25. package/build/cjs/components/DateTimePicker/DateTimePicker.js +198 -334
  26. package/build/cjs/components/Divider/Divider.js +29 -15
  27. package/build/cjs/components/DnaLogo/DnaLogo.js +87 -51
  28. package/build/cjs/components/Drawer/Drawer.js +172 -167
  29. package/build/cjs/components/EmptyState/EmptyState.js +24 -12
  30. package/build/cjs/components/EnergyLabel/EnergyLabel.js +77 -73
  31. package/build/cjs/components/Expander/Expander.js +43 -38
  32. package/build/cjs/components/Floater/Floater.js +36 -14
  33. package/build/cjs/components/Footer/Components/FooterComponents.d.ts +4 -2
  34. package/build/cjs/components/Footer/Components/FooterComponents.js +305 -346
  35. package/build/cjs/components/Footer/Footer.js +51 -80
  36. package/build/cjs/components/Footer/context/FooterContext.js +9 -9
  37. package/build/cjs/components/Hero/Hero.js +101 -149
  38. package/build/cjs/components/Icon/Icon.js +41 -22
  39. package/build/cjs/components/Icons/Small/hlArrowBackSmall.js +12 -4
  40. package/build/cjs/components/Icons/Small/hlArrowForwardSmall.js +12 -4
  41. package/build/cjs/components/Icons/Small/hlArrowUnderSmall.js +12 -4
  42. package/build/cjs/components/Icons/Small/hlCalendarSmall.js +12 -4
  43. package/build/cjs/components/Icons/Small/hlChevronDownSmall.js +12 -4
  44. package/build/cjs/components/Icons/Small/hlChevronLeftSmall.js +12 -4
  45. package/build/cjs/components/Icons/Small/hlChevronRightSmall.js +12 -4
  46. package/build/cjs/components/Icons/Small/hlChevronUpSmall.js +12 -4
  47. package/build/cjs/components/Icons/Small/hlClockSmall.js +14 -5
  48. package/build/cjs/components/Icons/Small/hlDownloadSmall.js +18 -6
  49. package/build/cjs/components/Icons/Small/hlExternalSmall.js +12 -4
  50. package/build/cjs/components/Icons/Small/hlUploadSmall.js +18 -6
  51. package/build/cjs/components/Icons/Social/facebook.js +13 -4
  52. package/build/cjs/components/Icons/Social/instagram.js +13 -4
  53. package/build/cjs/components/Icons/Social/linkedin.js +13 -4
  54. package/build/cjs/components/Icons/Social/tiktok.js +12 -4
  55. package/build/cjs/components/Icons/Social/twitter.js +13 -4
  56. package/build/cjs/components/Icons/Social/youtube.js +12 -4
  57. package/build/cjs/components/Icons/hl404.js +12 -4
  58. package/build/cjs/components/Icons/hl4gSim.js +12 -4
  59. package/build/cjs/components/Icons/hl5gSim.js +12 -4
  60. package/build/cjs/components/Icons/hlBattery.js +16 -6
  61. package/build/cjs/components/Icons/hlBell.js +12 -4
  62. package/build/cjs/components/Icons/hlCableTVCard.js +12 -4
  63. package/build/cjs/components/Icons/hlCalendar.js +56 -15
  64. package/build/cjs/components/Icons/hlCall.js +12 -4
  65. package/build/cjs/components/Icons/hlCameraBack.js +18 -6
  66. package/build/cjs/components/Icons/hlCameraFront.js +14 -5
  67. package/build/cjs/components/Icons/hlCart.js +16 -6
  68. package/build/cjs/components/Icons/hlCartEmpty.js +16 -6
  69. package/build/cjs/components/Icons/hlChat.js +24 -7
  70. package/build/cjs/components/Icons/hlCheck.js +12 -4
  71. package/build/cjs/components/Icons/hlChevronDown.js +12 -4
  72. package/build/cjs/components/Icons/hlChevronLeft.js +12 -4
  73. package/build/cjs/components/Icons/hlChevronRight.js +12 -4
  74. package/build/cjs/components/Icons/hlChevronUp.js +12 -4
  75. package/build/cjs/components/Icons/hlCompensation.js +12 -4
  76. package/build/cjs/components/Icons/hlCookie.js +12 -4
  77. package/build/cjs/components/Icons/hlCopy.js +14 -5
  78. package/build/cjs/components/Icons/hlCoupon.js +16 -6
  79. package/build/cjs/components/Icons/hlDelivery.js +14 -4
  80. package/build/cjs/components/Icons/hlDigiturva.js +14 -4
  81. package/build/cjs/components/Icons/hlDisplaySize.js +19 -6
  82. package/build/cjs/components/Icons/hlDocument.js +14 -5
  83. package/build/cjs/components/Icons/hlDownload.js +18 -6
  84. package/build/cjs/components/Icons/hlEnvelope.js +12 -4
  85. package/build/cjs/components/Icons/hlError.js +22 -6
  86. package/build/cjs/components/Icons/hlEuro.js +12 -4
  87. package/build/cjs/components/Icons/hlExclamationMark.js +12 -4
  88. package/build/cjs/components/Icons/hlExpand.js +12 -4
  89. package/build/cjs/components/Icons/hlExternal.js +12 -4
  90. package/build/cjs/components/Icons/hlEyeClosed.js +12 -4
  91. package/build/cjs/components/Icons/hlEyeOpen.js +14 -5
  92. package/build/cjs/components/Icons/hlFaceId.js +12 -4
  93. package/build/cjs/components/Icons/hlFastDelivery.js +12 -4
  94. package/build/cjs/components/Icons/hlFingerprint.js +20 -8
  95. package/build/cjs/components/Icons/hlGlobe.js +12 -4
  96. package/build/cjs/components/Icons/hlHeadphones.js +12 -4
  97. package/build/cjs/components/Icons/hlHeadset.js +18 -6
  98. package/build/cjs/components/Icons/hlHeart.js +12 -4
  99. package/build/cjs/components/Icons/hlHome.js +12 -4
  100. package/build/cjs/components/Icons/hlHub.js +14 -5
  101. package/build/cjs/components/Icons/hlImage.js +12 -4
  102. package/build/cjs/components/Icons/hlInfo.js +18 -6
  103. package/build/cjs/components/Icons/hlInstallment.js +14 -5
  104. package/build/cjs/components/Icons/hlIotSim.js +14 -5
  105. package/build/cjs/components/Icons/hlLaptop.js +13 -4
  106. package/build/cjs/components/Icons/hlLink.js +16 -5
  107. package/build/cjs/components/Icons/hlLiveVideo.js +12 -4
  108. package/build/cjs/components/Icons/hlLock.js +18 -6
  109. package/build/cjs/components/Icons/hlMagnifyingGlass.js +14 -5
  110. package/build/cjs/components/Icons/hlMarker.js +14 -5
  111. package/build/cjs/components/Icons/hlMemory.js +14 -5
  112. package/build/cjs/components/Icons/hlMenu.js +12 -4
  113. package/build/cjs/components/Icons/hlMinimize.js +12 -4
  114. package/build/cjs/components/Icons/hlMinus.js +12 -4
  115. package/build/cjs/components/Icons/hlMobileData.js +12 -4
  116. package/build/cjs/components/Icons/hlMobilePayment.js +19 -6
  117. package/build/cjs/components/Icons/hlModem.js +26 -8
  118. package/build/cjs/components/Icons/hlMore.js +22 -6
  119. package/build/cjs/components/Icons/hlOs.js +14 -5
  120. package/build/cjs/components/Icons/hlPackage.js +12 -4
  121. package/build/cjs/components/Icons/hlPaperclip.js +12 -4
  122. package/build/cjs/components/Icons/hlPaytime.js +12 -4
  123. package/build/cjs/components/Icons/hlPen.js +12 -4
  124. package/build/cjs/components/Icons/hlPerson.js +12 -4
  125. package/build/cjs/components/Icons/hlPhone.js +17 -5
  126. package/build/cjs/components/Icons/hlPlaylist.js +13 -4
  127. package/build/cjs/components/Icons/hlPlus.js +14 -5
  128. package/build/cjs/components/Icons/hlPrepaid.js +12 -4
  129. package/build/cjs/components/Icons/hlProcessor.js +14 -5
  130. package/build/cjs/components/Icons/hlServices.js +12 -4
  131. package/build/cjs/components/Icons/hlSettings.js +12 -4
  132. package/build/cjs/components/Icons/hlShield.js +14 -5
  133. package/build/cjs/components/Icons/hlSim.js +14 -5
  134. package/build/cjs/components/Icons/hlSimSimple.js +18 -6
  135. package/build/cjs/components/Icons/hlSmile.js +22 -7
  136. package/build/cjs/components/Icons/hlSpeechBubble.js +14 -5
  137. package/build/cjs/components/Icons/hlSquaretrade.js +13 -4
  138. package/build/cjs/components/Icons/hlStar.js +12 -4
  139. package/build/cjs/components/Icons/hlStarFilled.js +12 -4
  140. package/build/cjs/components/Icons/hlTrash.js +14 -5
  141. package/build/cjs/components/Icons/hlTv.js +12 -4
  142. package/build/cjs/components/Icons/hlUnlock.js +14 -6
  143. package/build/cjs/components/Icons/hlUpload.js +18 -6
  144. package/build/cjs/components/Icons/hlWarning.js +18 -6
  145. package/build/cjs/components/Icons/hlWifi.js +18 -6
  146. package/build/cjs/components/Icons/hlWrench.js +12 -4
  147. package/build/cjs/components/Icons/hlX.js +12 -4
  148. package/build/cjs/components/InfoDialog/InfoDialog.js +31 -46
  149. package/build/cjs/components/Input/Input.js +143 -159
  150. package/build/cjs/components/Label/Label.js +22 -22
  151. package/build/cjs/components/LabelText/LabelText.js +24 -17
  152. package/build/cjs/components/MainHeaderNavigation/ChildComponents/BusinessMenu.js +29 -44
  153. package/build/cjs/components/MainHeaderNavigation/ChildComponents/DesktopMenu.js +167 -153
  154. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LanguageSelector.js +34 -20
  155. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LinkModifier.js +50 -32
  156. package/build/cjs/components/MainHeaderNavigation/ChildComponents/LoginTooltip.js +17 -5
  157. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.d.ts +5 -2
  158. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.js +100 -95
  159. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.d.ts +6 -2
  160. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.js +4 -58
  161. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MinicartTooltip.js +20 -4
  162. package/build/cjs/components/MainHeaderNavigation/ChildComponents/MobileMenu.js +187 -159
  163. package/build/cjs/components/MainHeaderNavigation/ChildComponents/PageSearch.js +16 -5
  164. package/build/cjs/components/MainHeaderNavigation/MainHeaderNavigation.js +305 -272
  165. package/build/cjs/components/MainHeaderNavigation/context/NavContext.js +61 -49
  166. package/build/cjs/components/MainHeaderNavigation/globalNavStyles.d.ts +31 -16
  167. package/build/cjs/components/MainHeaderNavigation/globalNavStyles.js +39 -172
  168. package/build/cjs/components/Modal/Modal.js +127 -145
  169. package/build/cjs/components/Notification/Notification.js +74 -54
  170. package/build/cjs/components/NotificationBadge/NotificationBadge.js +29 -32
  171. package/build/cjs/components/Overlay/Overlay.js +70 -68
  172. package/build/cjs/components/Pill/Pill.js +91 -82
  173. package/build/cjs/components/PillGroup/PillGroup.js +50 -33
  174. package/build/cjs/components/PixelLoader/PixelLoader.js +37 -34
  175. package/build/cjs/components/PriorityNavigation/PriorityNavigation.js +281 -303
  176. package/build/cjs/components/PriorityNavigationItem/PriorityNavigationItem.js +27 -49
  177. package/build/cjs/components/ProgressIndicator/ProgressIndicator.js +140 -109
  178. package/build/cjs/components/RadioButton/RadioButton.js +91 -114
  179. package/build/cjs/components/ReadMore/ReadMore.js +86 -69
  180. package/build/cjs/components/Search/Search.js +52 -64
  181. package/build/cjs/components/Selectbox/Selectbox.js +279 -94
  182. package/build/cjs/components/Skeleton/Skeleton.js +69 -56
  183. package/build/cjs/components/Switch/Switch.js +62 -76
  184. package/build/cjs/components/Tab/Tab.js +55 -53
  185. package/build/cjs/components/Tabs/Tabs.js +93 -71
  186. package/build/cjs/components/Textarea/Textarea.js +76 -73
  187. package/build/cjs/components/Toaster/Toaster.js +59 -44
  188. package/build/cjs/components/Tooltip/Tooltip.js +74 -87
  189. package/build/cjs/hooks/useCloseOutsideOrElementClicked.js +23 -21
  190. package/build/cjs/hooks/useDebounce.js +9 -9
  191. package/build/cjs/hooks/useDocHeight.js +13 -13
  192. package/build/cjs/hooks/useOutsideClick.js +10 -10
  193. package/build/cjs/hooks/useResizeObserver.js +37 -24
  194. package/build/cjs/hooks/useScrollPosition.js +55 -54
  195. package/build/cjs/hooks/useWindowSize.js +20 -20
  196. package/build/cjs/themes/globalStyles.js +4 -4
  197. package/build/cjs/themes/gridTheme.js +1 -1
  198. package/build/cjs/themes/theme.js +12 -12
  199. package/build/cjs/themes/themeComponents/base.js +9 -8
  200. package/build/cjs/themes/themeComponents/breakpoints.js +6 -6
  201. package/build/cjs/themes/themeComponents/color.js +76 -74
  202. package/build/cjs/themes/themeComponents/fontFamily.js +3 -3
  203. package/build/cjs/themes/themeComponents/fontSize.js +31 -15
  204. package/build/cjs/themes/themeComponents/fontWeight.js +16 -16
  205. package/build/cjs/themes/themeComponents/forms.js +3 -2
  206. package/build/cjs/themes/themeComponents/layout.js +27 -27
  207. package/build/cjs/themes/themeComponents/lineHeight.js +32 -16
  208. package/build/cjs/themes/themeComponents/navigation.js +13 -13
  209. package/build/cjs/themes/themeComponents/radius.js +26 -26
  210. package/build/cjs/utils/common.js +15 -19
  211. package/build/cjs/utils/createStyled.d.ts +154 -134
  212. package/build/cjs/utils/createStyled.js +16 -2
  213. package/build/cjs/utils/styledUtils.js +2 -6
  214. package/build/es/_virtual/_virtual_inject.js +3 -0
  215. package/build/es/assets/fonts/fonts.css.js +3 -1
  216. package/build/es/components/Accordion/Accordion.js +66 -54
  217. package/build/es/components/AccordionItem/AccordionItem.js +94 -73
  218. package/build/es/components/AmountSelector/AmountSelector.js +121 -134
  219. package/build/es/components/Box/Box.js +38 -13
  220. package/build/es/components/Breadcrumb/Breadcrumb.js +73 -71
  221. package/build/es/components/Button/Button.d.ts +1 -1
  222. package/build/es/components/Button/Button.js +131 -127
  223. package/build/es/components/ButtonArrow/ButtonArrow.js +47 -49
  224. package/build/es/components/ButtonCard/ButtonCard.d.ts +2 -2
  225. package/build/es/components/ButtonCard/ButtonCard.js +97 -112
  226. package/build/es/components/ButtonClose/ButtonClose.d.ts +1 -1
  227. package/build/es/components/ButtonClose/ButtonClose.js +25 -14
  228. package/build/es/components/ButtonIcon/ButtonIcon.d.ts +44 -3
  229. package/build/es/components/ButtonIcon/ButtonIcon.js +105 -67
  230. package/build/es/components/ButtonPrimary/ButtonPrimary.d.ts +43 -2
  231. package/build/es/components/ButtonPrimary/ButtonPrimary.js +7 -35
  232. package/build/es/components/ButtonSecondary/ButtonSecondary.d.ts +43 -2
  233. package/build/es/components/ButtonSecondary/ButtonSecondary.js +7 -35
  234. package/build/es/components/Carousel/Carousel.d.ts +8 -2
  235. package/build/es/components/Carousel/Carousel.js +315 -346
  236. package/build/es/components/Checkbox/Checkbox.js +49 -108
  237. package/build/es/components/Chip/Chip.js +40 -34
  238. package/build/es/components/DateTimePicker/DateTimePicker.js +198 -334
  239. package/build/es/components/Divider/Divider.js +29 -15
  240. package/build/es/components/DnaLogo/DnaLogo.js +87 -51
  241. package/build/es/components/Drawer/Drawer.js +172 -167
  242. package/build/es/components/EmptyState/EmptyState.js +24 -12
  243. package/build/es/components/EnergyLabel/EnergyLabel.js +77 -73
  244. package/build/es/components/Expander/Expander.js +43 -38
  245. package/build/es/components/Floater/Floater.js +36 -14
  246. package/build/es/components/Footer/Components/FooterComponents.d.ts +4 -2
  247. package/build/es/components/Footer/Components/FooterComponents.js +305 -346
  248. package/build/es/components/Footer/Footer.js +51 -80
  249. package/build/es/components/Footer/context/FooterContext.js +9 -9
  250. package/build/es/components/Hero/Hero.js +101 -149
  251. package/build/es/components/Icon/Icon.js +41 -22
  252. package/build/es/components/Icons/Small/hlArrowBackSmall.js +12 -4
  253. package/build/es/components/Icons/Small/hlArrowForwardSmall.js +12 -4
  254. package/build/es/components/Icons/Small/hlArrowUnderSmall.js +12 -4
  255. package/build/es/components/Icons/Small/hlCalendarSmall.js +12 -4
  256. package/build/es/components/Icons/Small/hlChevronDownSmall.js +12 -4
  257. package/build/es/components/Icons/Small/hlChevronLeftSmall.js +12 -4
  258. package/build/es/components/Icons/Small/hlChevronRightSmall.js +12 -4
  259. package/build/es/components/Icons/Small/hlChevronUpSmall.js +12 -4
  260. package/build/es/components/Icons/Small/hlClockSmall.js +14 -5
  261. package/build/es/components/Icons/Small/hlDownloadSmall.js +18 -6
  262. package/build/es/components/Icons/Small/hlExternalSmall.js +12 -4
  263. package/build/es/components/Icons/Small/hlUploadSmall.js +18 -6
  264. package/build/es/components/Icons/Social/facebook.js +13 -4
  265. package/build/es/components/Icons/Social/instagram.js +13 -4
  266. package/build/es/components/Icons/Social/linkedin.js +13 -4
  267. package/build/es/components/Icons/Social/tiktok.js +12 -4
  268. package/build/es/components/Icons/Social/twitter.js +13 -4
  269. package/build/es/components/Icons/Social/youtube.js +12 -4
  270. package/build/es/components/Icons/hl404.js +12 -4
  271. package/build/es/components/Icons/hl4gSim.js +12 -4
  272. package/build/es/components/Icons/hl5gSim.js +12 -4
  273. package/build/es/components/Icons/hlBattery.js +16 -6
  274. package/build/es/components/Icons/hlBell.js +12 -4
  275. package/build/es/components/Icons/hlCableTVCard.js +12 -4
  276. package/build/es/components/Icons/hlCalendar.js +56 -15
  277. package/build/es/components/Icons/hlCall.js +12 -4
  278. package/build/es/components/Icons/hlCameraBack.js +18 -6
  279. package/build/es/components/Icons/hlCameraFront.js +14 -5
  280. package/build/es/components/Icons/hlCart.js +16 -6
  281. package/build/es/components/Icons/hlCartEmpty.js +16 -6
  282. package/build/es/components/Icons/hlChat.js +24 -7
  283. package/build/es/components/Icons/hlCheck.js +12 -4
  284. package/build/es/components/Icons/hlChevronDown.js +12 -4
  285. package/build/es/components/Icons/hlChevronLeft.js +12 -4
  286. package/build/es/components/Icons/hlChevronRight.js +12 -4
  287. package/build/es/components/Icons/hlChevronUp.js +12 -4
  288. package/build/es/components/Icons/hlCompensation.js +12 -4
  289. package/build/es/components/Icons/hlCookie.js +12 -4
  290. package/build/es/components/Icons/hlCopy.js +14 -5
  291. package/build/es/components/Icons/hlCoupon.js +16 -6
  292. package/build/es/components/Icons/hlDelivery.js +14 -4
  293. package/build/es/components/Icons/hlDigiturva.js +14 -4
  294. package/build/es/components/Icons/hlDisplaySize.js +19 -6
  295. package/build/es/components/Icons/hlDocument.js +14 -5
  296. package/build/es/components/Icons/hlDownload.js +18 -6
  297. package/build/es/components/Icons/hlEnvelope.js +12 -4
  298. package/build/es/components/Icons/hlError.js +22 -6
  299. package/build/es/components/Icons/hlEuro.js +12 -4
  300. package/build/es/components/Icons/hlExclamationMark.js +12 -4
  301. package/build/es/components/Icons/hlExpand.js +12 -4
  302. package/build/es/components/Icons/hlExternal.js +12 -4
  303. package/build/es/components/Icons/hlEyeClosed.js +12 -4
  304. package/build/es/components/Icons/hlEyeOpen.js +14 -5
  305. package/build/es/components/Icons/hlFaceId.js +12 -4
  306. package/build/es/components/Icons/hlFastDelivery.js +12 -4
  307. package/build/es/components/Icons/hlFingerprint.js +20 -8
  308. package/build/es/components/Icons/hlGlobe.js +12 -4
  309. package/build/es/components/Icons/hlHeadphones.js +12 -4
  310. package/build/es/components/Icons/hlHeadset.js +18 -6
  311. package/build/es/components/Icons/hlHeart.js +12 -4
  312. package/build/es/components/Icons/hlHome.js +12 -4
  313. package/build/es/components/Icons/hlHub.js +14 -5
  314. package/build/es/components/Icons/hlImage.js +12 -4
  315. package/build/es/components/Icons/hlInfo.js +18 -6
  316. package/build/es/components/Icons/hlInstallment.js +14 -5
  317. package/build/es/components/Icons/hlIotSim.js +14 -5
  318. package/build/es/components/Icons/hlLaptop.js +13 -4
  319. package/build/es/components/Icons/hlLink.js +16 -5
  320. package/build/es/components/Icons/hlLiveVideo.js +12 -4
  321. package/build/es/components/Icons/hlLock.js +18 -6
  322. package/build/es/components/Icons/hlMagnifyingGlass.js +14 -5
  323. package/build/es/components/Icons/hlMarker.js +14 -5
  324. package/build/es/components/Icons/hlMemory.js +14 -5
  325. package/build/es/components/Icons/hlMenu.js +12 -4
  326. package/build/es/components/Icons/hlMinimize.js +12 -4
  327. package/build/es/components/Icons/hlMinus.js +12 -4
  328. package/build/es/components/Icons/hlMobileData.js +12 -4
  329. package/build/es/components/Icons/hlMobilePayment.js +19 -6
  330. package/build/es/components/Icons/hlModem.js +26 -8
  331. package/build/es/components/Icons/hlMore.js +22 -6
  332. package/build/es/components/Icons/hlOs.js +14 -5
  333. package/build/es/components/Icons/hlPackage.js +12 -4
  334. package/build/es/components/Icons/hlPaperclip.js +12 -4
  335. package/build/es/components/Icons/hlPaytime.js +12 -4
  336. package/build/es/components/Icons/hlPen.js +12 -4
  337. package/build/es/components/Icons/hlPerson.js +12 -4
  338. package/build/es/components/Icons/hlPhone.js +17 -5
  339. package/build/es/components/Icons/hlPlaylist.js +13 -4
  340. package/build/es/components/Icons/hlPlus.js +14 -5
  341. package/build/es/components/Icons/hlPrepaid.js +12 -4
  342. package/build/es/components/Icons/hlProcessor.js +14 -5
  343. package/build/es/components/Icons/hlServices.js +12 -4
  344. package/build/es/components/Icons/hlSettings.js +12 -4
  345. package/build/es/components/Icons/hlShield.js +14 -5
  346. package/build/es/components/Icons/hlSim.js +14 -5
  347. package/build/es/components/Icons/hlSimSimple.js +18 -6
  348. package/build/es/components/Icons/hlSmile.js +22 -7
  349. package/build/es/components/Icons/hlSpeechBubble.js +14 -5
  350. package/build/es/components/Icons/hlSquaretrade.js +13 -4
  351. package/build/es/components/Icons/hlStar.js +12 -4
  352. package/build/es/components/Icons/hlStarFilled.js +12 -4
  353. package/build/es/components/Icons/hlTrash.js +14 -5
  354. package/build/es/components/Icons/hlTv.js +12 -4
  355. package/build/es/components/Icons/hlUnlock.js +14 -6
  356. package/build/es/components/Icons/hlUpload.js +18 -6
  357. package/build/es/components/Icons/hlWarning.js +18 -6
  358. package/build/es/components/Icons/hlWifi.js +18 -6
  359. package/build/es/components/Icons/hlWrench.js +12 -4
  360. package/build/es/components/Icons/hlX.js +12 -4
  361. package/build/es/components/InfoDialog/InfoDialog.js +31 -46
  362. package/build/es/components/Input/Input.js +143 -159
  363. package/build/es/components/Label/Label.js +22 -22
  364. package/build/es/components/LabelText/LabelText.js +24 -17
  365. package/build/es/components/MainHeaderNavigation/ChildComponents/BusinessMenu.js +29 -44
  366. package/build/es/components/MainHeaderNavigation/ChildComponents/DesktopMenu.js +167 -153
  367. package/build/es/components/MainHeaderNavigation/ChildComponents/LanguageSelector.js +34 -20
  368. package/build/es/components/MainHeaderNavigation/ChildComponents/LinkModifier.js +50 -32
  369. package/build/es/components/MainHeaderNavigation/ChildComponents/LoginTooltip.js +17 -5
  370. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.d.ts +5 -2
  371. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenu.js +100 -95
  372. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.d.ts +6 -2
  373. package/build/es/components/MainHeaderNavigation/ChildComponents/MainNavTooltipMenuExportedStyles.js +4 -58
  374. package/build/es/components/MainHeaderNavigation/ChildComponents/MinicartTooltip.js +20 -4
  375. package/build/es/components/MainHeaderNavigation/ChildComponents/MobileMenu.js +187 -159
  376. package/build/es/components/MainHeaderNavigation/ChildComponents/PageSearch.js +16 -5
  377. package/build/es/components/MainHeaderNavigation/MainHeaderNavigation.js +305 -272
  378. package/build/es/components/MainHeaderNavigation/context/NavContext.js +61 -49
  379. package/build/es/components/MainHeaderNavigation/globalNavStyles.d.ts +31 -16
  380. package/build/es/components/MainHeaderNavigation/globalNavStyles.js +39 -172
  381. package/build/es/components/Modal/Modal.js +127 -145
  382. package/build/es/components/Notification/Notification.js +74 -54
  383. package/build/es/components/NotificationBadge/NotificationBadge.js +29 -32
  384. package/build/es/components/Overlay/Overlay.js +70 -68
  385. package/build/es/components/Pill/Pill.js +91 -82
  386. package/build/es/components/PillGroup/PillGroup.js +50 -33
  387. package/build/es/components/PixelLoader/PixelLoader.js +37 -34
  388. package/build/es/components/PriorityNavigation/PriorityNavigation.js +281 -303
  389. package/build/es/components/PriorityNavigationItem/PriorityNavigationItem.js +27 -49
  390. package/build/es/components/ProgressIndicator/ProgressIndicator.js +140 -109
  391. package/build/es/components/RadioButton/RadioButton.js +91 -114
  392. package/build/es/components/ReadMore/ReadMore.js +86 -69
  393. package/build/es/components/Search/Search.js +52 -64
  394. package/build/es/components/Selectbox/Selectbox.js +279 -94
  395. package/build/es/components/Skeleton/Skeleton.js +69 -56
  396. package/build/es/components/Switch/Switch.js +62 -76
  397. package/build/es/components/Tab/Tab.js +55 -53
  398. package/build/es/components/Tabs/Tabs.js +93 -71
  399. package/build/es/components/Textarea/Textarea.js +76 -73
  400. package/build/es/components/Toaster/Toaster.js +59 -44
  401. package/build/es/components/Tooltip/Tooltip.js +74 -87
  402. package/build/es/hooks/useCloseOutsideOrElementClicked.js +23 -21
  403. package/build/es/hooks/useDebounce.js +9 -9
  404. package/build/es/hooks/useDocHeight.js +13 -13
  405. package/build/es/hooks/useOutsideClick.js +10 -10
  406. package/build/es/hooks/useResizeObserver.js +37 -24
  407. package/build/es/hooks/useScrollPosition.js +55 -54
  408. package/build/es/hooks/useWindowSize.js +20 -20
  409. package/build/es/themes/globalStyles.js +4 -4
  410. package/build/es/themes/gridTheme.js +1 -1
  411. package/build/es/themes/theme.js +12 -12
  412. package/build/es/themes/themeComponents/base.js +9 -8
  413. package/build/es/themes/themeComponents/breakpoints.js +6 -6
  414. package/build/es/themes/themeComponents/color.js +76 -74
  415. package/build/es/themes/themeComponents/fontFamily.js +3 -3
  416. package/build/es/themes/themeComponents/fontSize.js +31 -15
  417. package/build/es/themes/themeComponents/fontWeight.js +16 -16
  418. package/build/es/themes/themeComponents/forms.js +3 -2
  419. package/build/es/themes/themeComponents/layout.js +27 -27
  420. package/build/es/themes/themeComponents/lineHeight.js +32 -16
  421. package/build/es/themes/themeComponents/navigation.js +13 -13
  422. package/build/es/themes/themeComponents/radius.js +26 -26
  423. package/build/es/utils/common.js +15 -19
  424. package/build/es/utils/createStyled.d.ts +154 -134
  425. package/build/es/utils/createStyled.js +16 -2
  426. package/build/es/utils/styledUtils.js +2 -6
  427. package/package.json +19 -17
@@ -14,127 +14,112 @@ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'defau
14
14
 
15
15
  var React__default = /*#__PURE__*/_interopDefaultCompat(React);
16
16
 
17
- const ButtonCardWrapper = styledComponents.styled.button `
18
- display: block;
19
- padding: 0;
20
- border: 0;
21
- width: 100%;
22
- background-color: transparent;
23
- cursor: pointer;
24
- font-family: ${theme.default.fontFamily.default};
25
- font-size: ${theme.default.fontSize.default};
26
- line-height: ${theme.default.lineHeight.default};
27
- color: ${theme.default.color.text.black};
28
- text-decoration: none;
29
-
30
- &:focus-visible {
31
- border: 1px solid ${theme.default.color.focus.light};
32
- box-shadow: 0px 0px 0px 2px ${theme.default.color.focus.dark};
33
- border-radius: ${theme.default.radius.default};
34
- outline: none;
35
-
36
- & > div {
37
- border: 0;
38
- }
39
- }
40
-
41
- &:hover {
42
- color: ${theme.default.color.text.black};
43
- }
44
- `;
45
- const StyledBox = styledComponents.styled(Box.default) `
46
- display: flex;
47
- text-align: left;
48
- gap: ${({ size }) => (size === 'small' ? '0.313rem' : '1rem')};
49
- border: 1px solid ${theme.default.color.line.L03};
50
- padding: ${({ size }) => (size === 'small' ? '0.625rem' : '1rem')};
51
- ${({ size }) => size === 'small' && 'flex-direction: column'};
52
- ${({ size }) => size !== 'small' && 'align-items: center'};
53
- `;
54
- const VisualContent = styledComponents.styled.div `
55
- display: flex;
56
- align-items: center;
57
- width: ${({ size }) => (size === 'small' ? '2.5rem' : '3.75rem')};
58
- height: ${({ size }) => (size === 'small' ? '2.5rem' : '3.75rem')};
59
- `;
60
- const TextContentWrapper = styledComponents.styled.div `
61
- display: flex;
62
- flex-grow: 1;
63
- align-items: center;
64
- justify-content: space-between;
65
- gap: ${({ size }) => (size === 'small' ? '0.625rem' : '1rem')};
66
- min-width: 0;
67
- `;
68
- const TextContent = styledComponents.styled.div `
69
- flex: 1 1 auto;
70
- `;
71
- const Title = styledComponents.styled.div `
72
- font-size: ${theme.default.fontSize.default};
73
- line-height: ${theme.default.lineHeight.default};
74
- font-weight: ${theme.default.fontWeight.bold};
75
- display: -webkit-box;
76
- -webkit-box-orient: vertical;
77
- -webkit-line-clamp: 2;
78
- overflow: hidden;
79
- word-break: break-word;
80
- max-width: 100%;
81
-
82
- ${({ size }) => size === 'small' &&
83
- `
17
+ const ButtonCardWrapper = styledComponents.styled.button.withConfig({
18
+ displayName: "ButtonCard__ButtonCardWrapper",
19
+ componentId: "sc-oqmhtr-0"
20
+ })(["display:block;padding:0;border:0;width:100%;background-color:transparent;cursor:pointer;font-family:", ";font-size:", ";line-height:", ";color:", ";text-decoration:none;&:focus-visible{border:1px solid ", ";box-shadow:0px 0px 0px 2px ", ";border-radius:", ";outline:none;& > div{border:0;}}&:hover{color:", ";}"], theme.default.fontFamily.default, theme.default.fontSize.default, theme.default.lineHeight.default, theme.default.color.text.black, theme.default.color.focus.light, theme.default.color.focus.dark, theme.default.radius.default, theme.default.color.text.black);
21
+ const StyledBox = styledComponents.styled(Box.default).withConfig({
22
+ displayName: "ButtonCard__StyledBox",
23
+ componentId: "sc-oqmhtr-1"
24
+ })(["display:flex;text-align:left;gap:", ";border:1px solid ", ";padding:", ";", ";", ";"], ({
25
+ size
26
+ }) => size === 'small' ? '0.313rem' : '1rem', theme.default.color.line.L03, ({
27
+ size
28
+ }) => size === 'small' ? '0.625rem' : '1rem', ({
29
+ size
30
+ }) => size === 'small' && 'flex-direction: column', ({
31
+ size
32
+ }) => size !== 'small' && 'align-items: center');
33
+ const VisualContent = styledComponents.styled.div.withConfig({
34
+ displayName: "ButtonCard__VisualContent",
35
+ componentId: "sc-oqmhtr-2"
36
+ })(["display:flex;align-items:center;width:", ";height:", ";"], ({
37
+ size
38
+ }) => size === 'small' ? '2.5rem' : '3.75rem', ({
39
+ size
40
+ }) => size === 'small' ? '2.5rem' : '3.75rem');
41
+ const TextContentWrapper = styledComponents.styled.div.withConfig({
42
+ displayName: "ButtonCard__TextContentWrapper",
43
+ componentId: "sc-oqmhtr-3"
44
+ })(["display:flex;flex-grow:1;align-items:center;justify-content:space-between;gap:", ";min-width:0;"], ({
45
+ size
46
+ }) => size === 'small' ? '0.625rem' : '1rem');
47
+ const TextContent = styledComponents.styled.div.withConfig({
48
+ displayName: "ButtonCard__TextContent",
49
+ componentId: "sc-oqmhtr-4"
50
+ })(["flex:1 1 auto;"]);
51
+ const Title = styledComponents.styled.div.withConfig({
52
+ displayName: "ButtonCard__Title",
53
+ componentId: "sc-oqmhtr-5"
54
+ })(["font-size:", ";line-height:", ";font-weight:", ";display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;word-break:break-word;max-width:100%;", " ", ";"], theme.default.fontSize.default, theme.default.lineHeight.default, theme.default.fontWeight.bold, ({
55
+ size
56
+ }) => size === 'small' && `
84
57
  font-size: ${theme.default.fontSize.s};
85
58
  line-height: ${theme.default.lineHeight.s};
86
59
  font-weight: ${theme.default.fontWeight.medium};
87
60
  -webkit-line-clamp: 1;
88
- `}
89
-
90
- ${({ size }) => size === 'large' &&
91
- `
61
+ `, ({
62
+ size
63
+ }) => size === 'large' && `
92
64
  font-size: ${theme.default.fontSize.xl};
93
- `};
94
- `;
95
- const Subtitle = styledComponents.styled.div `
96
- color: ${theme.default.color.text.gray};
97
- font-size: ${theme.default.fontSize.s};
98
- line-height: ${theme.default.lineHeight.s};
99
- font-weight: ${theme.default.fontWeight.medium};
100
- display: -webkit-box;
101
- -webkit-box-orient: vertical;
102
- -webkit-line-clamp: 2;
103
- overflow: hidden;
104
- word-break: break-word;
105
- max-width: 100%;
106
-
107
- ${({ size }) => size === 'small' &&
108
- `
65
+ `);
66
+ const Subtitle = styledComponents.styled.div.withConfig({
67
+ displayName: "ButtonCard__Subtitle",
68
+ componentId: "sc-oqmhtr-6"
69
+ })(["color:", ";font-size:", ";line-height:", ";font-weight:", ";display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;word-break:break-word;max-width:100%;", " ", ";"], theme.default.color.text.gray, theme.default.fontSize.s, theme.default.lineHeight.s, theme.default.fontWeight.medium, ({
70
+ size
71
+ }) => size === 'small' && `
109
72
  font-size: ${theme.default.fontSize.xs};
110
73
  line-height: ${theme.default.lineHeight.xxs};
111
- `}
112
-
113
- ${({ size }) => size === 'large' &&
114
- `
74
+ `, ({
75
+ size
76
+ }) => size === 'large' && `
115
77
  font-size: ${theme.default.fontSize.default};
116
- `};
117
- `;
118
- const CtaIcon = styledComponents.styled(Icon.default) `
119
- color: ${theme.default.color.text.pink};
120
-
121
- ${ButtonCardWrapper}:hover & {
122
- color: ${theme.default.color.hover.pink};
123
- }
124
- `;
78
+ `);
79
+ const CtaIcon = styledComponents.styled(Icon.default).withConfig({
80
+ displayName: "ButtonCard__CtaIcon",
81
+ componentId: "sc-oqmhtr-7"
82
+ })(["color:", ";", ":hover &{color:", ";}"], theme.default.color.text.pink, ButtonCardWrapper, theme.default.color.hover.pink);
125
83
  /** @visibleName Button Card */
126
- const ButtonCard = (_a) => {
127
- var { type = 'submit', size = 'medium', 'data-testid': dataTestId } = _a, props = tslib.__rest(_a, ["type", "size", 'data-testid']);
128
- return (React__default.default.createElement(ButtonCardWrapper, Object.assign({ id: props.id, as: props.href ? 'a' : undefined, type: props.href ? undefined : type, href: props.href, onClick: props.onClick, className: props.className, "data-testid": dataTestId }, props.dataAttributes, (!props.href && {
129
- name: props.name,
130
- })),
131
- React__default.default.createElement(StyledBox, { elevation: "low", size: size },
132
- React__default.default.createElement(VisualContent, { size: size, "data-testid": dataTestId && `${dataTestId}-content` }, props.children),
133
- React__default.default.createElement(TextContentWrapper, { size: size },
134
- React__default.default.createElement(TextContent, null,
135
- React__default.default.createElement(Title, { size: size, "data-testid": dataTestId && `${dataTestId}-title` }, props.title),
136
- props.subtitle && (React__default.default.createElement(Subtitle, { size: size, "data-testid": dataTestId && `${dataTestId}-subtitle` }, props.subtitle))),
137
- React__default.default.createElement(CtaIcon, { icon: props.isExternal && props.href ? icons.Open : icons.ChevronRight, size: size === 'small' ? '1rem' : '1.5rem', "data-testid": dataTestId && `${dataTestId}-cta`, "aria-label": props.ariaLabelIcon, "aria-hidden": !props.ariaLabelIcon && true })))));
84
+ const ButtonCard = _a => {
85
+ var {
86
+ type = 'button',
87
+ size = 'medium',
88
+ 'data-testid': dataTestId
89
+ } = _a,
90
+ props = tslib.__rest(_a, ["type", "size", 'data-testid']);
91
+ return /*#__PURE__*/React__default.default.createElement(ButtonCardWrapper, Object.assign({
92
+ id: props.id,
93
+ as: props.href ? 'a' : undefined,
94
+ type: props.href ? undefined : type,
95
+ onClick: props.onClick,
96
+ className: props.className,
97
+ "data-testid": dataTestId
98
+ }, props.dataAttributes, props.href ? {
99
+ href: props.href
100
+ } : {}, !props.href && {
101
+ name: props.name
102
+ }), /*#__PURE__*/React__default.default.createElement(StyledBox, {
103
+ elevation: "low",
104
+ size: size
105
+ }, /*#__PURE__*/React__default.default.createElement(VisualContent, {
106
+ size: size,
107
+ "data-testid": dataTestId && `${dataTestId}-content`
108
+ }, props.children), /*#__PURE__*/React__default.default.createElement(TextContentWrapper, {
109
+ size: size
110
+ }, /*#__PURE__*/React__default.default.createElement(TextContent, null, /*#__PURE__*/React__default.default.createElement(Title, {
111
+ size: size,
112
+ "data-testid": dataTestId && `${dataTestId}-title`
113
+ }, props.title), props.subtitle && (/*#__PURE__*/React__default.default.createElement(Subtitle, {
114
+ size: size,
115
+ "data-testid": dataTestId && `${dataTestId}-subtitle`
116
+ }, props.subtitle))), /*#__PURE__*/React__default.default.createElement(CtaIcon, {
117
+ icon: props.isExternal && props.href ? icons.Open : icons.ChevronRight,
118
+ size: size === 'small' ? '1rem' : '1.5rem',
119
+ "data-testid": dataTestId && `${dataTestId}-cta`,
120
+ "aria-label": props.ariaLabelIcon,
121
+ "aria-hidden": !props.ariaLabelIcon && true
122
+ }))));
138
123
  };
139
124
 
140
125
  exports.default = ButtonCard;
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import type { Props as ButtonProps } from '../Button/Button';
3
- interface Props extends Pick<ButtonProps, 'id' | 'name' | 'children' | 'onClick' | 'onMouseDown' | 'className' | 'data-testid'> {
3
+ interface Props extends Pick<ButtonProps, 'id' | 'name' | 'children' | 'onClick' | 'onMouseDown' | 'className' | 'data-testid' | 'type' | 'darkBg'> {
4
4
  /**
5
5
  * Allows to pass aria label for screen readers
6
6
  */
@@ -12,21 +12,32 @@ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'defau
12
12
 
13
13
  var React__default = /*#__PURE__*/_interopDefaultCompat(React);
14
14
 
15
- const ButtonElement = styledComponents.styled.button `
16
- position: absolute;
17
- top: 0;
18
- right: 0;
19
- margin: ${styledUtils.getMultipliedSize(theme.default.base.baseHeight, 1)};
20
- display: inline-flex;
21
- cursor: pointer;
22
- background: none;
23
- border: none;
24
- padding: 0;
25
- `;
15
+ const ButtonElement = styledComponents.styled.button.withConfig({
16
+ displayName: "ButtonClose__ButtonElement",
17
+ componentId: "sc-1wb6vgp-0"
18
+ })(["position:absolute;top:0;right:0;margin:", ";display:inline-flex;cursor:pointer;background:none;border:none;padding:0;", ""], styledUtils.getMultipliedSize(theme.default.base.baseHeight, 1), ({
19
+ $darkBg
20
+ }) => $darkBg && `
21
+ color: ${theme.default.color.text.white};
22
+ `);
26
23
  /** @visibleName Button Close */
27
- const ButtonClose = (_a) => {
28
- var { 'data-testid': dataTestId, 'aria-label': ariaLabel } = _a, props = tslib.__rest(_a, ['data-testid', 'aria-label']);
29
- return (React__default.default.createElement(ButtonElement, { id: props.id, name: props.name, onClick: props.onClick, onMouseDown: props.onMouseDown, className: props.className, "data-testid": dataTestId, "aria-label": ariaLabel }, props.children));
24
+ const ButtonClose = _a => {
25
+ var {
26
+ 'data-testid': dataTestId,
27
+ 'aria-label': ariaLabel
28
+ } = _a,
29
+ props = tslib.__rest(_a, ['data-testid', 'aria-label']);
30
+ return /*#__PURE__*/React__default.default.createElement(ButtonElement, {
31
+ id: props.id,
32
+ name: props.name,
33
+ onClick: props.onClick,
34
+ onMouseDown: props.onMouseDown,
35
+ type: props.type || 'button',
36
+ className: props.className,
37
+ "data-testid": dataTestId,
38
+ "aria-label": ariaLabel,
39
+ "$darkBg": props.darkBg || false
40
+ }, props.children);
30
41
  };
31
42
 
32
43
  exports.default = ButtonClose;
@@ -1,7 +1,8 @@
1
+ import type { AnchorHTMLAttributes, ButtonHTMLAttributes, ComponentType, ReactNode } from 'react';
1
2
  import React from 'react';
2
- import type { Props as ButtonProps } from '../Button/Button';
3
+ import type { ButtonType, CommonProps } from '../Button/Button';
3
4
  import type { Props as IconProps } from '../Icon/Icon';
4
- interface Props extends Omit<ButtonProps, 'fullWidth'> {
5
+ interface Props extends Omit<CommonProps, 'fullWidth'> {
5
6
  /**
6
7
  * Icon shown in icon button component
7
8
  *
@@ -35,7 +36,47 @@ interface Props extends Omit<ButtonProps, 'fullWidth'> {
35
36
  */
36
37
  isLinkStyle?: boolean;
37
38
  }
39
+ export type ButtonProps = Props & Omit<ButtonHTMLAttributes<HTMLButtonElement>, keyof Props | 'href' | 'nextLink' | 'target'> & {
40
+ /**
41
+ * Name of the button element
42
+ */
43
+ name?: string;
44
+ /**
45
+ * Allows to change the HTML type of button element. Ignored when `href` is defined
46
+ *
47
+ * @param {ButtonType} submit Button submits the form data
48
+ * @param {ButtonType} button No functionality when pressed
49
+ * @param {ButtonType} reset Button resets all the controls to their initial values
50
+ *
51
+ * @default 'button'
52
+ */
53
+ type?: ButtonType;
54
+ /**
55
+ * Allows disabling the component functionality.
56
+ * When `href` is defined, disables the link functionality.
57
+ *
58
+ * @default false
59
+ */
60
+ disabled?: boolean;
61
+ };
62
+ export type AnchorProps = Props & Omit<AnchorHTMLAttributes<HTMLAnchorElement>, keyof Props | 'name' | 'disabled' | 'type'> & {
63
+ /**
64
+ * Allows to change the type of resulting HTML element from button (`<button></button>`) to anchor (`<a href="..."></a>`)
65
+ */
66
+ href?: string;
67
+ /**
68
+ * Allows to use a custom link component instead of anchor element when `href` is defined
69
+ */
70
+ nextLink?: ComponentType<{
71
+ href: string;
72
+ children: ReactNode;
73
+ }>;
74
+ /**
75
+ * Allows to set the target attribute for the link
76
+ */
77
+ target?: '_self' | '_blank' | '_parent' | '_top';
78
+ };
38
79
  /** @visibleName Button Icon */
39
- declare const ButtonIcon: React.ForwardRefExoticComponent<Props & React.RefAttributes<HTMLButtonElement>>;
80
+ declare const ButtonIcon: React.ForwardRefExoticComponent<(ButtonProps | AnchorProps) & React.RefAttributes<HTMLButtonElement | HTMLAnchorElement>>;
40
81
  /** @component */
41
82
  export default ButtonIcon;
@@ -15,10 +15,12 @@ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'defau
15
15
 
16
16
  var React__default = /*#__PURE__*/_interopDefaultCompat(React);
17
17
 
18
- const getStandardStyle = ({ isLinkStyle }) => {
19
- const colorValue = isLinkStyle ? theme.default.color.default.pink : theme.default.color.text.black;
20
- const colorHoverValue = isLinkStyle ? theme.default.color.hover.pink : theme.default.color.text.black;
21
- return `
18
+ const getStandardStyle = ({
19
+ isLinkStyle
20
+ }) => {
21
+ const colorValue = isLinkStyle ? theme.default.color.default.pink : theme.default.color.text.black;
22
+ const colorHoverValue = isLinkStyle ? theme.default.color.hover.pink : theme.default.color.text.black;
23
+ return `
22
24
  color: ${colorValue};
23
25
  &:focus-visible {
24
26
  border: 2px solid ${theme.default.color.focus.light};
@@ -37,8 +39,8 @@ const getStandardStyle = ({ isLinkStyle }) => {
37
39
  `;
38
40
  };
39
41
  const getDarkBgStyle = () => {
40
- const colorValue = theme.default.color.text.white;
41
- return `
42
+ const colorValue = theme.default.color.text.white;
43
+ return `
42
44
  color: ${colorValue};
43
45
  &:focus-visible {
44
46
  border: 2px solid ${theme.default.color.focus.dark};
@@ -56,49 +58,23 @@ const getDarkBgStyle = () => {
56
58
  }
57
59
  `;
58
60
  };
59
- const ButtonElement = styledComponents.styled.button `
60
- display: inline-flex;
61
- align-items: center;
62
- font-family: ${theme.default.fontFamily.default};
63
- font-weight: ${theme.default.fontWeight.bold};
64
- font-size: ${({ $small }) => ($small ? theme.default.fontSize.s : theme.default.fontSize.default)};
65
- line-height: ${({ $small }) => ($small ? theme.default.lineHeight.xs : theme.default.lineHeight.default)};
66
- cursor: pointer;
67
- background-color: transparent;
68
- border: 2px solid transparent;
69
- padding: ${styledUtils.getDividedSize(theme.default.base.baseWidth, 5)} 0;
70
- text-align: left;
71
- transition: all 0.2s ease-in-out;
72
-
73
- & svg {
74
- pointer-events: none;
75
- }
76
-
77
- ${({ $isReversed }) => $isReversed && `flex-direction: row-reverse;`}
78
-
79
- ${({ $darkBg, $isLinkStyle }) => $darkBg ? getDarkBgStyle() : getStandardStyle({ isLinkStyle: $isLinkStyle })}
80
-
81
- &:focus-visible {
82
- border-radius: ${theme.default.radius.s};
83
- text-decoration: underline;
84
- outline: none;
85
- }
86
-
87
- &:hover {
88
- text-decoration: underline;
89
- text-underline-offset: 0.2em;
90
- text-decoration-skip-ink: auto;
91
- text-decoration-thickness: from-font;
92
- }
93
-
94
- &:disabled,
95
- &[disabled] {
96
- cursor: not-allowed;
97
- text-decoration: none;
98
- }
99
-
100
- ${({ $loading }) => $loading &&
101
- `
61
+ const ButtonElement = styledComponents.styled.button.withConfig({
62
+ displayName: "ButtonIcon__ButtonElement",
63
+ componentId: "sc-y46ygq-0"
64
+ })(["display:inline-flex;align-items:center;font-family:", ";font-weight:", ";font-size:", ";line-height:", ";cursor:pointer;background-color:transparent;border:2px solid transparent;padding:", " 0;text-align:left;transition:all 0.2s ease-in-out;text-decoration:none;& svg{pointer-events:none;}", " ", " &:focus-visible{border-radius:", ";text-decoration:underline;outline:none;}&:hover{text-decoration:underline;text-underline-offset:0.2em;text-decoration-skip-ink:auto;text-decoration-thickness:from-font;}&:disabled,&[disabled],&[aria-disabled='true']{cursor:not-allowed;text-decoration:none;}", " ", ""], theme.default.fontFamily.default, theme.default.fontWeight.bold, ({
65
+ $small
66
+ }) => $small ? theme.default.fontSize.s : theme.default.fontSize.default, ({
67
+ $small
68
+ }) => $small ? theme.default.lineHeight.xs : theme.default.lineHeight.default, styledUtils.getDividedSize(theme.default.base.baseWidth, 5), ({
69
+ $isReversed
70
+ }) => $isReversed && `flex-direction: row-reverse;`, ({
71
+ $darkBg,
72
+ $isLinkStyle
73
+ }) => $darkBg ? getDarkBgStyle() : getStandardStyle({
74
+ isLinkStyle: $isLinkStyle
75
+ }), theme.default.radius.s, ({
76
+ $loading
77
+ }) => $loading && `
102
78
  pointer-events: none;
103
79
 
104
80
  &:focus {
@@ -109,28 +85,90 @@ const ButtonElement = styledComponents.styled.button `
109
85
  > * {
110
86
  display: inline-flex;
111
87
  }
112
- `}
113
-
114
- ${({ $hideChildrenMobile }) => $hideChildrenMobile &&
115
- styledComponents.css `
116
- span.dnasg-icon + span {
117
- display: none;
118
- }
119
-
120
- ${styledUtils.media.sm `
88
+ `, ({
89
+ $hideChildrenMobile
90
+ }) => $hideChildrenMobile && styledComponents.css(["span.dnasg-icon + span{display:none;}", ""], styledUtils.media.sm`
121
91
  span.dnasg-icon + span {
122
92
  display: initial;
123
93
  }
124
- `}
125
- `}
126
- `;
94
+ `));
127
95
  /** @visibleName Button Icon */
128
- const ButtonIcon = React.forwardRef((_a, ref) => {
129
- var { icon = icons.EditUnderline, 'data-testid': dataTestId, 'data-track-value': dataTrackValue } = _a, props = tslib.__rest(_a, ["icon", 'data-testid', 'data-track-value']);
130
- const position = props.isReversed ? 'right' : 'left';
131
- return (React__default.default.createElement(ButtonElement, Object.assign({ ref: ref, id: props.id, name: props.name, type: props.type, onClick: props.onClick, onMouseDown: props.onMouseDown, "$small": props.small, "$darkBg": props.darkBg, "$loading": props.loading, tabIndex: props.loading ? -1 : 0, "data-loading": props.loading, disabled: props.disabled, "$hideChildrenMobile": props.hideChildrenMobile, "$isReversed": props.isReversed, className: props.className, "data-testid": dataTestId, "data-track-value": dataTrackValue, "aria-expanded": props.ariaExpanded, "aria-label": props.ariaLabel, "$isLinkStyle": props.isLinkStyle }, props.dataAttributes), props.loading ? (React__default.default.createElement(PixelLoader.default, { color: props.darkBg ? theme.default.color.default.white : theme.default.color.default.black, label: props.loadingLabel })) : (React__default.default.createElement(React__default.default.Fragment, null,
132
- React__default.default.createElement(Icon.default, { icon: icon, color: props.darkBg ? theme.default.color.default.white : theme.default.color.default.pink, size: props.small ? '1.25rem' : '1.5rem', position: props.children ? position : undefined, "aria-hidden": true }),
133
- props.children && (React__default.default.createElement("span", { "data-testid": dataTestId && `${dataTestId}-text` }, props.children))))));
96
+ const ButtonIcon = /*#__PURE__*/React.forwardRef((_a, ref) => {
97
+ var _b;
98
+ var {
99
+ icon = icons.EditUnderline,
100
+ 'data-testid': dataTestId,
101
+ 'data-track-value': dataTrackValue
102
+ } = _a,
103
+ props = tslib.__rest(_a, ["icon", 'data-testid', 'data-track-value']);
104
+ const position = props.isReversed ? 'right' : 'left';
105
+ const propHref = props.href;
106
+ const propNextLink = props.nextLink;
107
+ const propTarget = props.target;
108
+ const isDisabledAnchor = props.disabled && propHref;
109
+ const handleClick = event => {
110
+ if (isDisabledAnchor) {
111
+ event.preventDefault();
112
+ event.stopPropagation();
113
+ return;
114
+ }
115
+ if (props.onClick) {
116
+ props.onClick(event);
117
+ }
118
+ };
119
+ const content = props.loading ? (/*#__PURE__*/React__default.default.createElement(PixelLoader.default, {
120
+ color: props.darkBg ? theme.default.color.default.white : theme.default.color.default.black,
121
+ label: props.loadingLabel
122
+ })) : (/*#__PURE__*/React__default.default.createElement(React__default.default.Fragment, null, /*#__PURE__*/React__default.default.createElement(Icon.default, {
123
+ icon: icon,
124
+ color: props.darkBg ? theme.default.color.default.white : theme.default.color.default.pink,
125
+ size: props.small ? '1.25rem' : '1.5rem',
126
+ position: props.children ? position : undefined,
127
+ "aria-hidden": true
128
+ }), props.children && (/*#__PURE__*/React__default.default.createElement("span", {
129
+ "data-testid": dataTestId && `${dataTestId}-text`
130
+ }, props.children))));
131
+ const commonButtonElementProps = {
132
+ id: props.id,
133
+ onClick: handleClick,
134
+ onMouseDown: props.onMouseDown,
135
+ $small: props.small,
136
+ $darkBg: props.darkBg,
137
+ $loading: props.loading,
138
+ 'data-loading': props.loading,
139
+ className: props.className,
140
+ 'data-testid': dataTestId,
141
+ 'data-track-value': dataTrackValue,
142
+ 'aria-label': props.ariaLabel,
143
+ $hideChildrenMobile: props.hideChildrenMobile,
144
+ $isReversed: props.isReversed,
145
+ 'aria-expanded': props.ariaExpanded
146
+ };
147
+ if (propHref) {
148
+ const anchorProps = {
149
+ href: isDisabledAnchor ? undefined : propHref,
150
+ target: propTarget,
151
+ rel: propHref && propTarget === '_blank' ? 'noopener noreferrer' : undefined
152
+ };
153
+ return /*#__PURE__*/React__default.default.createElement(ButtonElement, Object.assign({
154
+ as: propNextLink !== null && propNextLink !== void 0 ? propNextLink : propHref ? 'a' : undefined,
155
+ "aria-disabled": isDisabledAnchor ? 'true' : undefined,
156
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-explicit-any
157
+ ref: propNextLink ? ref : ref,
158
+ tabIndex: props.loading || isDisabledAnchor ? -1 : 0,
159
+ "$isLinkStyle": (_b = props.isLinkStyle) !== null && _b !== void 0 ? _b : true
160
+ }, commonButtonElementProps, anchorProps, props.dataAttributes), content);
161
+ } else {
162
+ return /*#__PURE__*/React__default.default.createElement(ButtonElement, Object.assign({
163
+ as: "button",
164
+ ref: ref,
165
+ name: props.name,
166
+ type: props.type || 'button',
167
+ tabIndex: props.loading ? -1 : 0,
168
+ disabled: props.disabled,
169
+ "$isLinkStyle": props.isLinkStyle
170
+ }, commonButtonElementProps, props.dataAttributes), content);
171
+ }
134
172
  });
135
173
 
136
174
  exports.default = ButtonIcon;
@@ -1,5 +1,46 @@
1
- import Button from '../Button/Button';
1
+ import type { Props } from '../Button/Button';
2
2
  /** @visibleName Button Primary */
3
- declare const ButtonPrimary: typeof Button;
3
+ declare const ButtonPrimary: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("styled-components").FastOmit<(Omit<import("../Button/Button").CommonProps & Omit<import("react").ButtonHTMLAttributes<HTMLButtonElement>, "target" | "href" | keyof import("../Button/Button").CommonProps | "nextLink"> & {
4
+ name?: string;
5
+ type?: import("../Button/Button").ButtonType;
6
+ disabled?: boolean;
7
+ } & import("react").RefAttributes<HTMLButtonElement | HTMLAnchorElement>, "ref"> & {
8
+ ref?: ((instance: HTMLButtonElement | HTMLAnchorElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLButtonElement | HTMLAnchorElement> | null | undefined;
9
+ }) | (Omit<import("../Button/Button").CommonProps & Omit<import("react").AnchorHTMLAttributes<HTMLAnchorElement>, "name" | "type" | "disabled" | keyof import("../Button/Button").CommonProps> & {
10
+ href?: string;
11
+ nextLink?: import("react").ComponentType<{
12
+ href: string;
13
+ children: import("react").ReactNode;
14
+ }>;
15
+ target?: "_self" | "_blank" | "_parent" | "_top";
16
+ } & import("react").RefAttributes<HTMLButtonElement | HTMLAnchorElement>, "ref"> & {
17
+ ref?: ((instance: HTMLButtonElement | HTMLAnchorElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLButtonElement | HTMLAnchorElement> | null | undefined;
18
+ }), "loading"> & Pick<Props, "loading">, never> & Partial<Pick<import("styled-components").FastOmit<(Omit<import("../Button/Button").CommonProps & Omit<import("react").ButtonHTMLAttributes<HTMLButtonElement>, "target" | "href" | keyof import("../Button/Button").CommonProps | "nextLink"> & {
19
+ name?: string;
20
+ type?: import("../Button/Button").ButtonType;
21
+ disabled?: boolean;
22
+ } & import("react").RefAttributes<HTMLButtonElement | HTMLAnchorElement>, "ref"> & {
23
+ ref?: ((instance: HTMLButtonElement | HTMLAnchorElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLButtonElement | HTMLAnchorElement> | null | undefined;
24
+ }) | (Omit<import("../Button/Button").CommonProps & Omit<import("react").AnchorHTMLAttributes<HTMLAnchorElement>, "name" | "type" | "disabled" | keyof import("../Button/Button").CommonProps> & {
25
+ href?: string;
26
+ nextLink?: import("react").ComponentType<{
27
+ href: string;
28
+ children: import("react").ReactNode;
29
+ }>;
30
+ target?: "_self" | "_blank" | "_parent" | "_top";
31
+ } & import("react").RefAttributes<HTMLButtonElement | HTMLAnchorElement>, "ref"> & {
32
+ ref?: ((instance: HTMLButtonElement | HTMLAnchorElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLButtonElement | HTMLAnchorElement> | null | undefined;
33
+ }), "loading"> & Pick<Props, "loading">, never>>> & string & Omit<import("react").ForwardRefExoticComponent<((import("../Button/Button").CommonProps & Omit<import("react").ButtonHTMLAttributes<HTMLButtonElement>, "target" | "href" | keyof import("../Button/Button").CommonProps | "nextLink"> & {
34
+ name?: string;
35
+ type?: import("../Button/Button").ButtonType;
36
+ disabled?: boolean;
37
+ }) | (import("../Button/Button").CommonProps & Omit<import("react").AnchorHTMLAttributes<HTMLAnchorElement>, "name" | "type" | "disabled" | keyof import("../Button/Button").CommonProps> & {
38
+ href?: string;
39
+ nextLink?: import("react").ComponentType<{
40
+ href: string;
41
+ children: import("react").ReactNode;
42
+ }>;
43
+ target?: "_self" | "_blank" | "_parent" | "_top";
44
+ })) & import("react").RefAttributes<HTMLButtonElement | HTMLAnchorElement>>, keyof import("react").Component<any, {}, any>>;
4
45
  /** @component */
5
46
  export default ButtonPrimary;