@helsenorge/designsystem-react 15.0.0-beta.0 → 15.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (712) hide show
  1. package/lib/AnchorLink.js.map +1 -1
  2. package/lib/AsChildSlot.js.map +1 -1
  3. package/lib/Avatar.js.map +1 -1
  4. package/lib/Badge.js.map +1 -1
  5. package/lib/Button.js.map +1 -1
  6. package/lib/CHANGELOG.md +61 -0
  7. package/lib/Checkbox.js +25 -48
  8. package/lib/Checkbox.js.map +1 -1
  9. package/lib/Checkbox2.js +69 -0
  10. package/lib/Checkbox2.js.map +1 -0
  11. package/lib/CheckboxMarker.js +64 -0
  12. package/lib/CheckboxMarker.js.map +1 -0
  13. package/lib/Chip.js.map +1 -1
  14. package/lib/Close.js.map +1 -1
  15. package/lib/DictionaryTrigger.js.map +1 -1
  16. package/lib/Drawer.js +2 -2
  17. package/lib/Drawer.js.map +1 -1
  18. package/lib/DrawerNavigation.js.map +1 -1
  19. package/lib/Duolist.js.map +1 -1
  20. package/lib/ElementHeader.js.map +1 -1
  21. package/lib/ElementHeaderText.js.map +1 -1
  22. package/lib/ErrorBoundary.js.map +1 -1
  23. package/lib/ErrorWrapper.js.map +1 -1
  24. package/lib/Expander.js.map +1 -1
  25. package/lib/FilterButton.js.map +1 -1
  26. package/lib/FilterButtonAndChipsWrapper.js.map +1 -1
  27. package/lib/FilterDrawer.js +20 -10
  28. package/lib/FilterDrawer.js.map +1 -1
  29. package/lib/FilterLinkList.js.map +1 -1
  30. package/lib/FilterOverviewLinkList.js.map +1 -1
  31. package/lib/FilterOverviewSearch.js.map +1 -1
  32. package/lib/FilterResultCountAndSortWrapper.js.map +1 -1
  33. package/lib/FilterSearch.js.map +1 -1
  34. package/lib/FilterSort.js.map +1 -1
  35. package/lib/FilterStateWrapper.js.map +1 -1
  36. package/lib/FormFieldTag.js.map +1 -1
  37. package/lib/FormGroup.js +8 -6
  38. package/lib/FormGroup.js.map +1 -1
  39. package/lib/FormLayout.js.map +1 -1
  40. package/lib/HelpDetails.js.map +1 -1
  41. package/lib/HelpTriggerIcon.js.map +1 -1
  42. package/lib/HelpTriggerStandalone.js.map +1 -1
  43. package/lib/HighlightPanel.js.map +1 -1
  44. package/lib/Highlighter.js.map +1 -1
  45. package/lib/HorizontalScroll.js.map +1 -1
  46. package/lib/Icon.js.map +1 -1
  47. package/lib/Illustration.js +1 -1
  48. package/lib/Illustration.js.map +1 -1
  49. package/lib/InfoTeaser.js.map +1 -1
  50. package/lib/Input.js.map +1 -1
  51. package/lib/LazyIcon.js +1 -1
  52. package/lib/LazyIcon.js.map +1 -1
  53. package/lib/LazyIllustration.js +6 -2
  54. package/lib/LazyIllustration.js.map +1 -1
  55. package/lib/LinkList.js.map +1 -1
  56. package/lib/List.js.map +1 -1
  57. package/lib/ListEditMode.js.map +1 -1
  58. package/lib/LoaderSpinner.js +61 -0
  59. package/lib/LoaderSpinner.js.map +1 -0
  60. package/lib/MaxCharacters.js.map +1 -1
  61. package/lib/NotificationBadge.js.map +1 -1
  62. package/lib/PanelTitle.js.map +1 -1
  63. package/lib/PopOver.js.map +1 -1
  64. package/lib/Radio.js +74 -0
  65. package/lib/Radio.js.map +1 -0
  66. package/lib/RadioButton.js +84 -0
  67. package/lib/RadioButton.js.map +1 -0
  68. package/lib/RadioMarker.js +35 -0
  69. package/lib/RadioMarker.js.map +1 -0
  70. package/lib/Select.js.map +1 -1
  71. package/lib/SingleSelectItem.js.map +1 -1
  72. package/lib/Slider.js.map +1 -1
  73. package/lib/Spacer.js.map +1 -1
  74. package/lib/StatusDot.js.map +1 -1
  75. package/lib/StatusDotList.js.map +1 -1
  76. package/lib/StepButtons.js.map +1 -1
  77. package/lib/TabList.js.map +1 -1
  78. package/lib/TabPanel.js.map +1 -1
  79. package/lib/TableBody.js +1 -1
  80. package/lib/TableBody.js.map +1 -1
  81. package/lib/TableCell.js.map +1 -1
  82. package/lib/TableExpandedRow.js.map +1 -1
  83. package/lib/TableExpanderCell.js.map +1 -1
  84. package/lib/TableHead.js +1 -1
  85. package/lib/TableHead.js.map +1 -1
  86. package/lib/TableHeadCell.js.map +1 -1
  87. package/lib/TableRow.js +1 -1
  88. package/lib/TableRow.js.map +1 -1
  89. package/lib/Textarea.js.map +1 -1
  90. package/lib/Title.js.map +1 -1
  91. package/lib/Toast.js.map +1 -1
  92. package/lib/VisualCheckbox.js +79 -0
  93. package/lib/VisualCheckbox.js.map +1 -0
  94. package/lib/VisualRadio.js +64 -0
  95. package/lib/VisualRadio.js.map +1 -0
  96. package/lib/__mocks__/IntersectionObserver.js.map +1 -1
  97. package/lib/__mocks__/MutationObserver.js.map +1 -1
  98. package/lib/__mocks__/ResizeObserver.js.map +1 -1
  99. package/lib/__mocks__/matchMedia.js +3 -2
  100. package/lib/__mocks__/matchMedia.js.map +1 -1
  101. package/lib/__mocks__/useLayoutEvent.js.map +1 -1
  102. package/lib/__mocks__/useOutsideEvent.js.map +1 -1
  103. package/lib/__mocks__/usePseudoClasses.js.map +1 -1
  104. package/lib/__mocks__/useSize.js.map +1 -1
  105. package/lib/__mocks__/uuid.js.map +1 -1
  106. package/lib/components/ArticleTeaser/index.js.map +1 -1
  107. package/lib/components/Checkbox/CheckboxMarker/CheckboxMarker.d.ts +20 -0
  108. package/lib/components/Checkbox/CheckboxMarker/styles.module.scss +309 -0
  109. package/lib/components/Checkbox/CheckboxMarker/styles.module.scss.d.ts +25 -0
  110. package/lib/components/Checkbox/styles.module.scss +9 -269
  111. package/lib/components/Checkbox/styles.module.scss.d.ts +1 -17
  112. package/lib/components/Dropdown/index.js.map +1 -1
  113. package/lib/components/DropdownOld/index.js.map +1 -1
  114. package/lib/components/EmptyState/index.js.map +1 -1
  115. package/lib/components/ExpanderHierarchy/index.js.map +1 -1
  116. package/lib/components/ExpanderList/index.js.map +1 -1
  117. package/lib/components/EyebrowHeader/index.js.map +1 -1
  118. package/lib/components/FavoriteButton/index.js.map +1 -1
  119. package/lib/components/Filter/FilterDrawer/FilterDrawer.d.ts +4 -2
  120. package/lib/components/Filter/FilterDrawer/styles.module.scss +7 -0
  121. package/lib/components/Filter/FilterDrawer/styles.module.scss.d.ts +1 -0
  122. package/lib/components/Filter/FilterSort/styles.module.scss +2 -0
  123. package/lib/components/Filter/LoaderSpinner/LoaderSpinner.d.ts +9 -0
  124. package/lib/components/Filter/LoaderSpinner/index.d.ts +3 -0
  125. package/lib/components/Filter/LoaderSpinner/index.js +7 -0
  126. package/lib/components/Filter/LoaderSpinner/index.js.map +1 -0
  127. package/lib/components/Filter/LoaderSpinner/styles.module.scss +27 -0
  128. package/lib/components/Filter/LoaderSpinner/styles.module.scss.d.ts +11 -0
  129. package/lib/components/Filter/index.d.ts +2 -0
  130. package/lib/components/Filter/index.js +2 -1
  131. package/lib/components/Filter/index.js.map +1 -1
  132. package/lib/components/FormGroup/FormGroup.d.ts +2 -0
  133. package/lib/components/HelpBubble/index.js.map +1 -1
  134. package/lib/components/HelpDrawer/index.js.map +1 -1
  135. package/lib/components/HelpExpanderInline/index.js.map +1 -1
  136. package/lib/components/HelpExpanderStandalone/index.js.map +1 -1
  137. package/lib/components/HelpPanel/index.js.map +1 -1
  138. package/lib/components/HelpTeaser/index.js.map +1 -1
  139. package/lib/components/HelpTooltip/index.js.map +1 -1
  140. package/lib/components/HelpTriggerInline/index.js.map +1 -1
  141. package/lib/components/Icons/ActiveMonitoring.js.map +1 -1
  142. package/lib/components/Icons/AcupunctureBack.js.map +1 -1
  143. package/lib/components/Icons/AdditionalIconInformation.js.map +1 -1
  144. package/lib/components/Icons/AlarmClock.js.map +1 -1
  145. package/lib/components/Icons/AlertSignFill.js.map +1 -1
  146. package/lib/components/Icons/AlertSignStroke.js.map +1 -1
  147. package/lib/components/Icons/Amputation.js.map +1 -1
  148. package/lib/components/Icons/Anxiety.js.map +1 -1
  149. package/lib/components/Icons/Apple.js.map +1 -1
  150. package/lib/components/Icons/Archive.js.map +1 -1
  151. package/lib/components/Icons/ArmFlexing.js.map +1 -1
  152. package/lib/components/Icons/ArrowDown.js.map +1 -1
  153. package/lib/components/Icons/ArrowLeft.js.map +1 -1
  154. package/lib/components/Icons/ArrowRight.js.map +1 -1
  155. package/lib/components/Icons/ArrowUp.js.map +1 -1
  156. package/lib/components/Icons/ArrowUpRight.js.map +1 -1
  157. package/lib/components/Icons/Attachment.js.map +1 -1
  158. package/lib/components/Icons/Atv.js.map +1 -1
  159. package/lib/components/Icons/Avatar.js.map +1 -1
  160. package/lib/components/Icons/AwakePersonOnPillow.js.map +1 -1
  161. package/lib/components/Icons/Baby.js.map +1 -1
  162. package/lib/components/Icons/BandAid.js.map +1 -1
  163. package/lib/components/Icons/BeerAndPills.js.map +1 -1
  164. package/lib/components/Icons/Bell.js.map +1 -1
  165. package/lib/components/Icons/Bike.js.map +1 -1
  166. package/lib/components/Icons/BirthControl.js.map +1 -1
  167. package/lib/components/Icons/BirthdayCake.js.map +1 -1
  168. package/lib/components/Icons/Boat.js.map +1 -1
  169. package/lib/components/Icons/Body.js.map +1 -1
  170. package/lib/components/Icons/Braille.js.map +1 -1
  171. package/lib/components/Icons/Brain.js.map +1 -1
  172. package/lib/components/Icons/BreastReconstruction.js.map +1 -1
  173. package/lib/components/Icons/BreastRemoval.js.map +1 -1
  174. package/lib/components/Icons/Breasts.js.map +1 -1
  175. package/lib/components/Icons/BrokenHeart.js.map +1 -1
  176. package/lib/components/Icons/BrokenPuzzle.js.map +1 -1
  177. package/lib/components/Icons/Bus.js.map +1 -1
  178. package/lib/components/Icons/Calendar.js.map +1 -1
  179. package/lib/components/Icons/CalendarChange.js.map +1 -1
  180. package/lib/components/Icons/CalendarCheck.js.map +1 -1
  181. package/lib/components/Icons/CalendarEvent.js.map +1 -1
  182. package/lib/components/Icons/CalendarSave.js.map +1 -1
  183. package/lib/components/Icons/Cancer.js.map +1 -1
  184. package/lib/components/Icons/Candle.js.map +1 -1
  185. package/lib/components/Icons/Car.js.map +1 -1
  186. package/lib/components/Icons/Carton.js.map +1 -1
  187. package/lib/components/Icons/Change.js.map +1 -1
  188. package/lib/components/Icons/Check.js.map +1 -1
  189. package/lib/components/Icons/CheckFill.js.map +1 -1
  190. package/lib/components/Icons/CheckOutline.js.map +1 -1
  191. package/lib/components/Icons/Chest.js.map +1 -1
  192. package/lib/components/Icons/ChevronDown.js.map +1 -1
  193. package/lib/components/Icons/ChevronLeft.js.map +1 -1
  194. package/lib/components/Icons/ChevronRight.js.map +1 -1
  195. package/lib/components/Icons/ChevronUp.js.map +1 -1
  196. package/lib/components/Icons/ChevronsDown.js.map +1 -1
  197. package/lib/components/Icons/ChevronsUp.js.map +1 -1
  198. package/lib/components/Icons/ChildPlaying.js.map +1 -1
  199. package/lib/components/Icons/Cigarette.js.map +1 -1
  200. package/lib/components/Icons/Coins.js.map +1 -1
  201. package/lib/components/Icons/Contacts.js.map +1 -1
  202. package/lib/components/Icons/Copy.js.map +1 -1
  203. package/lib/components/Icons/CoronaCertificate.js.map +1 -1
  204. package/lib/components/Icons/Coronavirus.js.map +1 -1
  205. package/lib/components/Icons/Cough.js.map +1 -1
  206. package/lib/components/Icons/CreditCard.js.map +1 -1
  207. package/lib/components/Icons/CriticalHealthInfo.js.map +1 -1
  208. package/lib/components/Icons/Cross.js.map +1 -1
  209. package/lib/components/Icons/DataExchange.js.map +1 -1
  210. package/lib/components/Icons/DataReceived.js.map +1 -1
  211. package/lib/components/Icons/DataSent.js.map +1 -1
  212. package/lib/components/Icons/Depression.js.map +1 -1
  213. package/lib/components/Icons/DigestiveSystem.js.map +1 -1
  214. package/lib/components/Icons/Dizzy.js.map +1 -1
  215. package/lib/components/Icons/Documents.js.map +1 -1
  216. package/lib/components/Icons/Dog.js.map +1 -1
  217. package/lib/components/Icons/DonorCard.js.map +1 -1
  218. package/lib/components/Icons/DotAttachment.js.map +1 -1
  219. package/lib/components/Icons/DotCheckmark.js.map +1 -1
  220. package/lib/components/Icons/DotCircleArrows.js.map +1 -1
  221. package/lib/components/Icons/DotDot.js.map +1 -1
  222. package/lib/components/Icons/DotExclamationMark.js.map +1 -1
  223. package/lib/components/Icons/DotFill.js.map +1 -1
  224. package/lib/components/Icons/DotGroup.js.map +1 -1
  225. package/lib/components/Icons/DotHalfDisc.js.map +1 -1
  226. package/lib/components/Icons/DotInfo.js.map +1 -1
  227. package/lib/components/Icons/DotLogin.js.map +1 -1
  228. package/lib/components/Icons/DotLookingGlass.js.map +1 -1
  229. package/lib/components/Icons/DotNoAccess.js.map +1 -1
  230. package/lib/components/Icons/DotNoEye.js.map +1 -1
  231. package/lib/components/Icons/DotOutline.js.map +1 -1
  232. package/lib/components/Icons/DotPencil.js.map +1 -1
  233. package/lib/components/Icons/DotQuestionMark.js.map +1 -1
  234. package/lib/components/Icons/DotTriangle.js.map +1 -1
  235. package/lib/components/Icons/DotX.js.map +1 -1
  236. package/lib/components/Icons/Download.js.map +1 -1
  237. package/lib/components/Icons/Draft.js.map +1 -1
  238. package/lib/components/Icons/Drag.js.map +1 -1
  239. package/lib/components/Icons/EChat.js.map +1 -1
  240. package/lib/components/Icons/Ear.js.map +1 -1
  241. package/lib/components/Icons/EarDeaf.js.map +1 -1
  242. package/lib/components/Icons/EarHearingAid.js.map +1 -1
  243. package/lib/components/Icons/EarNoseThroat.js.map +1 -1
  244. package/lib/components/Icons/EarVolume.js.map +1 -1
  245. package/lib/components/Icons/Edit.js.map +1 -1
  246. package/lib/components/Icons/ElderlyPerson.js.map +1 -1
  247. package/lib/components/Icons/Embolization.js.map +1 -1
  248. package/lib/components/Icons/EmergencyCall.js.map +1 -1
  249. package/lib/components/Icons/EmoticonAnnoyed.js.map +1 -1
  250. package/lib/components/Icons/EmoticonDelighted.js.map +1 -1
  251. package/lib/components/Icons/EmoticonDisappointed.js.map +1 -1
  252. package/lib/components/Icons/EmoticonHappy.js.map +1 -1
  253. package/lib/components/Icons/EmoticonMeh.js.map +1 -1
  254. package/lib/components/Icons/EmptyBox.js.map +1 -1
  255. package/lib/components/Icons/EnterFullScreen.js.map +1 -1
  256. package/lib/components/Icons/Envelope.js.map +1 -1
  257. package/lib/components/Icons/Epilepsy.js.map +1 -1
  258. package/lib/components/Icons/Eraser.js.map +1 -1
  259. package/lib/components/Icons/ErrorSignFill.js.map +1 -1
  260. package/lib/components/Icons/ErrorSignStroke.js.map +1 -1
  261. package/lib/components/Icons/EuropeanHealthCard.js.map +1 -1
  262. package/lib/components/Icons/ExitFullScreen.js.map +1 -1
  263. package/lib/components/Icons/Eye.js.map +1 -1
  264. package/lib/components/Icons/Facebook.js.map +1 -1
  265. package/lib/components/Icons/FallingLeaf.js.map +1 -1
  266. package/lib/components/Icons/Feedback.js.map +1 -1
  267. package/lib/components/Icons/Female.js.map +1 -1
  268. package/lib/components/Icons/FemaleDoctor.js.map +1 -1
  269. package/lib/components/Icons/Ferry.js.map +1 -1
  270. package/lib/components/Icons/File.js.map +1 -1
  271. package/lib/components/Icons/Filter.js +12 -12
  272. package/lib/components/Icons/Filter.js.map +1 -1
  273. package/lib/components/Icons/FingerBleed.js.map +1 -1
  274. package/lib/components/Icons/FirstAidKit.js.map +1 -1
  275. package/lib/components/Icons/Fish.js.map +1 -1
  276. package/lib/components/Icons/FloppyDisk.js.map +1 -1
  277. package/lib/components/Icons/Football.js.map +1 -1
  278. package/lib/components/Icons/Form.js.map +1 -1
  279. package/lib/components/Icons/Forward.js.map +1 -1
  280. package/lib/components/Icons/Gallery.js.map +1 -1
  281. package/lib/components/Icons/Garden.js.map +1 -1
  282. package/lib/components/Icons/GasCan.js.map +1 -1
  283. package/lib/components/Icons/GenderIdentity.js.map +1 -1
  284. package/lib/components/Icons/GlassWater.js.map +1 -1
  285. package/lib/components/Icons/Glasses.js.map +1 -1
  286. package/lib/components/Icons/Globe.js.map +1 -1
  287. package/lib/components/Icons/Grain.js.map +1 -1
  288. package/lib/components/Icons/Graph.js.map +1 -1
  289. package/lib/components/Icons/Group.js.map +1 -1
  290. package/lib/components/Icons/GroupTwins.js.map +1 -1
  291. package/lib/components/Icons/HTMLFile.js.map +1 -1
  292. package/lib/components/Icons/HandWaving.js.map +1 -1
  293. package/lib/components/Icons/HandWithDisease.js.map +1 -1
  294. package/lib/components/Icons/HandsAndHeart.js.map +1 -1
  295. package/lib/components/Icons/HealthClinic.js.map +1 -1
  296. package/lib/components/Icons/HealthMeasurements.js.map +1 -1
  297. package/lib/components/Icons/HealthWarning.js.map +1 -1
  298. package/lib/components/Icons/HealthcarePerson.js.map +1 -1
  299. package/lib/components/Icons/HealthcarePersonell.js.map +1 -1
  300. package/lib/components/Icons/HearingProtection.js.map +1 -1
  301. package/lib/components/Icons/Heart.js.map +1 -1
  302. package/lib/components/Icons/HeartHands.js.map +1 -1
  303. package/lib/components/Icons/HelpSign.js.map +1 -1
  304. package/lib/components/Icons/HelpingHand.js.map +1 -1
  305. package/lib/components/Icons/Hemodialysis.js.map +1 -1
  306. package/lib/components/Icons/Hiker.js.map +1 -1
  307. package/lib/components/Icons/Hipprosthesis.js.map +1 -1
  308. package/lib/components/Icons/History.js.map +1 -1
  309. package/lib/components/Icons/HivAndAids.js.map +1 -1
  310. package/lib/components/Icons/Home.js.map +1 -1
  311. package/lib/components/Icons/HomeFill.js.map +1 -1
  312. package/lib/components/Icons/Hormone.js.map +1 -1
  313. package/lib/components/Icons/Hospital.js.map +1 -1
  314. package/lib/components/Icons/Hourglass.js.map +1 -1
  315. package/lib/components/Icons/IconNames.js.map +1 -1
  316. package/lib/components/Icons/ImgFile.js.map +1 -1
  317. package/lib/components/Icons/Inbox.js.map +1 -1
  318. package/lib/components/Icons/InfoSignFill.js.map +1 -1
  319. package/lib/components/Icons/InfoSignStroke.js.map +1 -1
  320. package/lib/components/Icons/Instagram.js.map +1 -1
  321. package/lib/components/Icons/Intravenous.js.map +1 -1
  322. package/lib/components/Icons/JointPain.js.map +1 -1
  323. package/lib/components/Icons/Journal.js.map +1 -1
  324. package/lib/components/Icons/JpgFile.js.map +1 -1
  325. package/lib/components/Icons/Kidney.js.map +1 -1
  326. package/lib/components/Icons/KitchenScale.js.map +1 -1
  327. package/lib/components/Icons/Kjernejournal.js.map +1 -1
  328. package/lib/components/Icons/Laboratory.js.map +1 -1
  329. package/lib/components/Icons/LaptopBlog.js.map +1 -1
  330. package/lib/components/Icons/LawBook.js.map +1 -1
  331. package/lib/components/Icons/LegalDocument.js.map +1 -1
  332. package/lib/components/Icons/LightBulb.js.map +1 -1
  333. package/lib/components/Icons/List.js.map +1 -1
  334. package/lib/components/Icons/Location.js.map +1 -1
  335. package/lib/components/Icons/LocationFill.js.map +1 -1
  336. package/lib/components/Icons/Lock.js.map +1 -1
  337. package/lib/components/Icons/Login.js.map +1 -1
  338. package/lib/components/Icons/Logout.js.map +1 -1
  339. package/lib/components/Icons/Lungs.js.map +1 -1
  340. package/lib/components/Icons/Makeup.js.map +1 -1
  341. package/lib/components/Icons/MaleDoctor.js.map +1 -1
  342. package/lib/components/Icons/MaleDoctorAndPerson.js.map +1 -1
  343. package/lib/components/Icons/MaleDoctorCompact.js.map +1 -1
  344. package/lib/components/Icons/MaleDoctorCompactFill.js.map +1 -1
  345. package/lib/components/Icons/MaleGenitalia.js.map +1 -1
  346. package/lib/components/Icons/MeasuringTape.js.map +1 -1
  347. package/lib/components/Icons/Medicine.js.map +1 -1
  348. package/lib/components/Icons/MedicineWarning.js.map +1 -1
  349. package/lib/components/Icons/MentalHealthAdult.js.map +1 -1
  350. package/lib/components/Icons/MentalHealthChild.js.map +1 -1
  351. package/lib/components/Icons/Menu.js.map +1 -1
  352. package/lib/components/Icons/Microscope.js.map +1 -1
  353. package/lib/components/Icons/Minus.js.map +1 -1
  354. package/lib/components/Icons/Mirror.js.map +1 -1
  355. package/lib/components/Icons/MobilePhone.js.map +1 -1
  356. package/lib/components/Icons/MotherHoldingBaby.js.map +1 -1
  357. package/lib/components/Icons/MuscleBack.js.map +1 -1
  358. package/lib/components/Icons/MuscleLeg.js.map +1 -1
  359. package/lib/components/Icons/Mushroom.js.map +1 -1
  360. package/lib/components/Icons/Music.js.map +1 -1
  361. package/lib/components/Icons/MusselsAndSalt.js.map +1 -1
  362. package/lib/components/Icons/NoAccess.js.map +1 -1
  363. package/lib/components/Icons/NoEye.js.map +1 -1
  364. package/lib/components/Icons/NoFilter.js.map +1 -1
  365. package/lib/components/Icons/Notepad.js.map +1 -1
  366. package/lib/components/Icons/Osteotomy.js.map +1 -1
  367. package/lib/components/Icons/PaintRoller.js.map +1 -1
  368. package/lib/components/Icons/PaperPlane.js.map +1 -1
  369. package/lib/components/Icons/PatientAndPerson.js.map +1 -1
  370. package/lib/components/Icons/Pause.js.map +1 -1
  371. package/lib/components/Icons/PdfFile.js.map +1 -1
  372. package/lib/components/Icons/Pencil.js.map +1 -1
  373. package/lib/components/Icons/PeopleTalking.js.map +1 -1
  374. package/lib/components/Icons/Peritonealdialysis.js.map +1 -1
  375. package/lib/components/Icons/Person.js.map +1 -1
  376. package/lib/components/Icons/PersonAndPatient.js.map +1 -1
  377. package/lib/components/Icons/PersonCancel.js.map +1 -1
  378. package/lib/components/Icons/PersonInXRayMachine.js.map +1 -1
  379. package/lib/components/Icons/PersonOverweight.js.map +1 -1
  380. package/lib/components/Icons/PersonRelaxing.js.map +1 -1
  381. package/lib/components/Icons/PersonWithBrain.js.map +1 -1
  382. package/lib/components/Icons/PersonWithBrokenArm.js.map +1 -1
  383. package/lib/components/Icons/PersonWithCrutches.js.map +1 -1
  384. package/lib/components/Icons/PersonWithJaw.js.map +1 -1
  385. package/lib/components/Icons/PersonWithMagnifyingGlass.js.map +1 -1
  386. package/lib/components/Icons/PersonWithSenses.js.map +1 -1
  387. package/lib/components/Icons/PersonWorking.js.map +1 -1
  388. package/lib/components/Icons/PersonalPlan.js.map +1 -1
  389. package/lib/components/Icons/PizzaSlice.js.map +1 -1
  390. package/lib/components/Icons/Plane.js.map +1 -1
  391. package/lib/components/Icons/Plant.js.map +1 -1
  392. package/lib/components/Icons/PlateKnifeFork.js.map +1 -1
  393. package/lib/components/Icons/Play.js.map +1 -1
  394. package/lib/components/Icons/PlusLarge.js.map +1 -1
  395. package/lib/components/Icons/PlusSmall.js.map +1 -1
  396. package/lib/components/Icons/PngFile.js.map +1 -1
  397. package/lib/components/Icons/Podcast.js.map +1 -1
  398. package/lib/components/Icons/PoisonInformation.js.map +1 -1
  399. package/lib/components/Icons/Pregnant.js.map +1 -1
  400. package/lib/components/Icons/Printer.js.map +1 -1
  401. package/lib/components/Icons/Psychosis.js.map +1 -1
  402. package/lib/components/Icons/Publication.js.map +1 -1
  403. package/lib/components/Icons/Puzzle.js.map +1 -1
  404. package/lib/components/Icons/QrCode.js.map +1 -1
  405. package/lib/components/Icons/Quarrel.js.map +1 -1
  406. package/lib/components/Icons/RadioTherapy.js.map +1 -1
  407. package/lib/components/Icons/RadioactiveTreatment.js.map +1 -1
  408. package/lib/components/Icons/Radioiodine.js.map +1 -1
  409. package/lib/components/Icons/Receipt.js.map +1 -1
  410. package/lib/components/Icons/Receptionist.js.map +1 -1
  411. package/lib/components/Icons/Recovery.js.map +1 -1
  412. package/lib/components/Icons/Referral.js.map +1 -1
  413. package/lib/components/Icons/Refresh.js.map +1 -1
  414. package/lib/components/Icons/Refund.js.map +1 -1
  415. package/lib/components/Icons/Reminder.js.map +1 -1
  416. package/lib/components/Icons/Reply.js.map +1 -1
  417. package/lib/components/Icons/Rocket.js.map +1 -1
  418. package/lib/components/Icons/RtfFile.js.map +1 -1
  419. package/lib/components/Icons/STDs.js.map +1 -1
  420. package/lib/components/Icons/Save.js.map +1 -1
  421. package/lib/components/Icons/Scale.js.map +1 -1
  422. package/lib/components/Icons/ScreenReader.js.map +1 -1
  423. package/lib/components/Icons/Search.js +4 -4
  424. package/lib/components/Icons/Search.js.map +1 -1
  425. package/lib/components/Icons/SectionSign.js.map +1 -1
  426. package/lib/components/Icons/Settings.js.map +1 -1
  427. package/lib/components/Icons/SettingsFill.js.map +1 -1
  428. package/lib/components/Icons/Sexualorientation.js.map +1 -1
  429. package/lib/components/Icons/ShakingHand.js.map +1 -1
  430. package/lib/components/Icons/Share.js.map +1 -1
  431. package/lib/components/Icons/SharedHealthData.js.map +1 -1
  432. package/lib/components/Icons/SharedHealthMeasurements.js.map +1 -1
  433. package/lib/components/Icons/Shield.js.map +1 -1
  434. package/lib/components/Icons/ShuntOperation.js.map +1 -1
  435. package/lib/components/Icons/Skeleton.js.map +1 -1
  436. package/lib/components/Icons/Skin.js.map +1 -1
  437. package/lib/components/Icons/Snake.js.map +1 -1
  438. package/lib/components/Icons/Snapchat.js.map +1 -1
  439. package/lib/components/Icons/Sort.js +12 -12
  440. package/lib/components/Icons/Sort.js.map +1 -1
  441. package/lib/components/Icons/SortDown.js.map +1 -1
  442. package/lib/components/Icons/SortUp.js.map +1 -1
  443. package/lib/components/Icons/SpeechBubble.js.map +1 -1
  444. package/lib/components/Icons/Spray.js.map +1 -1
  445. package/lib/components/Icons/StarFill.js.map +1 -1
  446. package/lib/components/Icons/StarStroke.js.map +1 -1
  447. package/lib/components/Icons/StickyNote.js.map +1 -1
  448. package/lib/components/Icons/StickyNotes.js.map +1 -1
  449. package/lib/components/Icons/Stopwatch.js.map +1 -1
  450. package/lib/components/Icons/Sun.js.map +1 -1
  451. package/lib/components/Icons/SupportingPerson.js.map +1 -1
  452. package/lib/components/Icons/Surgery.js.map +1 -1
  453. package/lib/components/Icons/Sweets.js.map +1 -1
  454. package/lib/components/Icons/Syringe.js.map +1 -1
  455. package/lib/components/Icons/Taxi.js.map +1 -1
  456. package/lib/components/Icons/TeddyBear.js.map +1 -1
  457. package/lib/components/Icons/Teenagers.js.map +1 -1
  458. package/lib/components/Icons/ThinkingAboutBaby.js.map +1 -1
  459. package/lib/components/Icons/Ticket.js.map +1 -1
  460. package/lib/components/Icons/TimePassing.js.map +1 -1
  461. package/lib/components/Icons/Toddler.js.map +1 -1
  462. package/lib/components/Icons/Tombstone.js.map +1 -1
  463. package/lib/components/Icons/Toolbox.js.map +1 -1
  464. package/lib/components/Icons/Tooth.js.map +1 -1
  465. package/lib/components/Icons/TotalKneeProsthesis.js.map +1 -1
  466. package/lib/components/Icons/Train.js.map +1 -1
  467. package/lib/components/Icons/Transplantation.js.map +1 -1
  468. package/lib/components/Icons/TrashCan.js.map +1 -1
  469. package/lib/components/Icons/TravelRoute.js.map +1 -1
  470. package/lib/components/Icons/TreatmentAids.js.map +1 -1
  471. package/lib/components/Icons/TriangleX.js.map +1 -1
  472. package/lib/components/Icons/Twitter.js.map +1 -1
  473. package/lib/components/Icons/Undo.js.map +1 -1
  474. package/lib/components/Icons/UniProsthesis.js.map +1 -1
  475. package/lib/components/Icons/Upload.js.map +1 -1
  476. package/lib/components/Icons/UserOrganization.js.map +1 -1
  477. package/lib/components/Icons/Vaccine.js.map +1 -1
  478. package/lib/components/Icons/VerticalDots.js.map +1 -1
  479. package/lib/components/Icons/VideoCamera.js.map +1 -1
  480. package/lib/components/Icons/VideoChat.js.map +1 -1
  481. package/lib/components/Icons/Wallet.js.map +1 -1
  482. package/lib/components/Icons/Watch.js.map +1 -1
  483. package/lib/components/Icons/Website.js.map +1 -1
  484. package/lib/components/Icons/Wheelchair.js.map +1 -1
  485. package/lib/components/Icons/WheelchairActive.js.map +1 -1
  486. package/lib/components/Icons/Window.js.map +1 -1
  487. package/lib/components/Icons/WordDocument.js.map +1 -1
  488. package/lib/components/Icons/WorkSuitcase.js.map +1 -1
  489. package/lib/components/Icons/X.js.map +1 -1
  490. package/lib/components/Icons/XOutline.js.map +1 -1
  491. package/lib/components/Icons/XmlFile.js.map +1 -1
  492. package/lib/components/Icons/YouTube.js.map +1 -1
  493. package/lib/components/Icons/Zoom.js.map +1 -1
  494. package/lib/components/Icons/ZoomInLeft.js.map +1 -1
  495. package/lib/components/Icons/ZoomOutLeft.js.map +1 -1
  496. package/lib/components/Illustration/index.js +1 -1
  497. package/lib/components/Illustrations/BabyMobile.js +1 -1
  498. package/lib/components/Illustrations/BabyMobile.js.map +1 -1
  499. package/lib/components/Illustrations/BabyMobileMedium.js +1 -1
  500. package/lib/components/Illustrations/BabyMobileMedium.js.map +1 -1
  501. package/lib/components/Illustrations/Child.js +1 -1
  502. package/lib/components/Illustrations/Child.js.map +1 -1
  503. package/lib/components/Illustrations/ChildMedium.js +1 -1
  504. package/lib/components/Illustrations/ChildMedium.js.map +1 -1
  505. package/lib/components/Illustrations/Doctor.js +1 -1
  506. package/lib/components/Illustrations/Doctor.js.map +1 -1
  507. package/lib/components/Illustrations/DoctorMedium.js.map +1 -1
  508. package/lib/components/Illustrations/DoctorSmall.js.map +1 -1
  509. package/lib/components/Illustrations/EyeContact.d.ts +8 -0
  510. package/lib/components/Illustrations/EyeContact.js +17 -0
  511. package/lib/components/Illustrations/EyeContact.js.map +1 -0
  512. package/lib/components/Illustrations/EyeContactMedium.d.ts +3 -0
  513. package/lib/components/Illustrations/EyeContactMedium.js +80 -0
  514. package/lib/components/Illustrations/EyeContactMedium.js.map +1 -0
  515. package/lib/components/Illustrations/FacialRecognitionFingerprint.js +1 -1
  516. package/lib/components/Illustrations/FacialRecognitionFingerprint.js.map +1 -1
  517. package/lib/components/Illustrations/FacialRecognitionFingerprintMedium.js +1 -1
  518. package/lib/components/Illustrations/FacialRecognitionFingerprintMedium.js.map +1 -1
  519. package/lib/components/Illustrations/GiveBabyFood.js +1 -1
  520. package/lib/components/Illustrations/GiveBabyFood.js.map +1 -1
  521. package/lib/components/Illustrations/GiveBabyFoodMedium.js +1 -1
  522. package/lib/components/Illustrations/GiveBabyFoodMedium.js.map +1 -1
  523. package/lib/components/Illustrations/HealthcarePersonnel.js +1 -1
  524. package/lib/components/Illustrations/HealthcarePersonnel.js.map +1 -1
  525. package/lib/components/Illustrations/HealthcarePersonnelMedium.js.map +1 -1
  526. package/lib/components/Illustrations/HealthcarePersonnelSmall.js.map +1 -1
  527. package/lib/components/Illustrations/IllustrationNames.d.ts +1 -1
  528. package/lib/components/Illustrations/IllustrationNames.js +4 -0
  529. package/lib/components/Illustrations/IllustrationNames.js.map +1 -1
  530. package/lib/components/Illustrations/ReadLetters.js +1 -1
  531. package/lib/components/Illustrations/ReadLetters.js.map +1 -1
  532. package/lib/components/Illustrations/ReadLettersMedium.js +1 -1
  533. package/lib/components/Illustrations/ReadLettersMedium.js.map +1 -1
  534. package/lib/components/Illustrations/SkinToSkin.d.ts +8 -0
  535. package/lib/components/Illustrations/SkinToSkin.js +17 -0
  536. package/lib/components/Illustrations/SkinToSkin.js.map +1 -0
  537. package/lib/components/Illustrations/SkinToSkinMedium.d.ts +3 -0
  538. package/lib/components/Illustrations/SkinToSkinMedium.js +107 -0
  539. package/lib/components/Illustrations/SkinToSkinMedium.js.map +1 -0
  540. package/lib/components/Illustrations/Stork.js +1 -1
  541. package/lib/components/Illustrations/Stork.js.map +1 -1
  542. package/lib/components/Illustrations/StorkMedium.js +1 -1
  543. package/lib/components/Illustrations/StorkMedium.js.map +1 -1
  544. package/lib/components/Illustrations/Stroller.js +1 -1
  545. package/lib/components/Illustrations/Stroller.js.map +1 -1
  546. package/lib/components/Illustrations/StrollerMedium.js +1 -1
  547. package/lib/components/Illustrations/StrollerMedium.js.map +1 -1
  548. package/lib/components/Illustrations/Support2.js +1 -1
  549. package/lib/components/Illustrations/Support2.js.map +1 -1
  550. package/lib/components/Illustrations/Support2Medium.js +1 -1
  551. package/lib/components/Illustrations/Support2Medium.js.map +1 -1
  552. package/lib/components/Illustrations/Thinking.js +1 -1
  553. package/lib/components/Illustrations/Thinking.js.map +1 -1
  554. package/lib/components/Illustrations/ThinkingMedium.js +1 -1
  555. package/lib/components/Illustrations/ThinkingMedium.js.map +1 -1
  556. package/lib/components/Loader/index.js.map +1 -1
  557. package/lib/components/Logo/index.js.map +1 -1
  558. package/lib/components/Modal/index.js.map +1 -1
  559. package/lib/components/NotificationPanel/index.js.map +1 -1
  560. package/lib/components/Panel/index.js +1 -1
  561. package/lib/components/Panel/index.js.map +1 -1
  562. package/lib/components/PanelList/index.js +1 -1
  563. package/lib/components/PanelList/index.js.map +1 -1
  564. package/lib/components/PopMenu/index.js.map +1 -1
  565. package/lib/components/Portal/index.js.map +1 -1
  566. package/lib/components/Progressbar/index.js.map +1 -1
  567. package/lib/components/PromoPanel/index.js.map +1 -1
  568. package/lib/components/RadioButton/RadioMarker/RadioMarker.d.ts +20 -0
  569. package/lib/components/RadioButton/RadioMarker/styles.module.scss +288 -0
  570. package/lib/components/RadioButton/RadioMarker/styles.module.scss.d.ts +20 -0
  571. package/lib/components/RadioButton/index.d.ts +0 -1
  572. package/lib/components/RadioButton/index.js +2 -2
  573. package/lib/components/RadioButton/index.js.map +1 -1
  574. package/lib/components/RadioButton/styles.module.scss +13 -275
  575. package/lib/components/RadioButton/styles.module.scss.d.ts +2 -12
  576. package/lib/components/ServiceMessage/index.js.map +1 -1
  577. package/lib/components/SharingStatus/index.js.map +1 -1
  578. package/lib/components/Step/index.js.map +1 -1
  579. package/lib/components/Stepper/index.js +1 -5
  580. package/lib/components/Stepper/index.js.map +1 -1
  581. package/lib/components/StickyNote/index.js.map +1 -1
  582. package/lib/components/Table/index.js +1 -1
  583. package/lib/components/Table/index.js.map +1 -1
  584. package/lib/components/Tabs/index.js.map +1 -1
  585. package/lib/components/Tag/index.js.map +1 -1
  586. package/lib/components/TagList/index.js.map +1 -1
  587. package/lib/components/Tile/index.js.map +1 -1
  588. package/lib/components/ToastList/index.js.map +1 -1
  589. package/lib/components/Toggle/index.js.map +1 -1
  590. package/lib/components/Validation/index.js.map +1 -1
  591. package/lib/components/VisualCheckboxCloud/Checkbox/Checkbox.d.ts +21 -0
  592. package/lib/components/VisualCheckboxCloud/Checkbox/index.d.ts +3 -0
  593. package/lib/components/VisualCheckboxCloud/Checkbox/index.js +7 -0
  594. package/lib/components/VisualCheckboxCloud/Checkbox/index.js.map +1 -0
  595. package/lib/components/VisualCheckboxCloud/Checkbox/styles.module.scss +10 -0
  596. package/lib/components/VisualCheckboxCloud/Checkbox/styles.module.scss.d.ts +15 -0
  597. package/lib/components/VisualCheckboxCloud/VisualCheckboxCloud.d.ts +29 -0
  598. package/lib/components/VisualCheckboxCloud/index.d.ts +3 -0
  599. package/lib/components/VisualCheckboxCloud/index.js +42 -0
  600. package/lib/components/VisualCheckboxCloud/index.js.map +1 -0
  601. package/lib/components/VisualCheckboxCloud/styles.module.scss +6 -0
  602. package/lib/components/VisualCheckboxCloud/styles.module.scss.d.ts +9 -0
  603. package/lib/components/VisualCheckboxGroup/VisualCheckbox/VisualCheckbox.d.ts +26 -0
  604. package/lib/components/VisualCheckboxGroup/VisualCheckbox/VisualContent.d.ts +10 -0
  605. package/lib/components/VisualCheckboxGroup/VisualCheckbox/index.d.ts +3 -0
  606. package/lib/components/VisualCheckboxGroup/VisualCheckbox/index.js +7 -0
  607. package/lib/components/VisualCheckboxGroup/VisualCheckbox/index.js.map +1 -0
  608. package/lib/components/VisualCheckboxGroup/VisualCheckbox/styles.module.scss +7 -0
  609. package/lib/components/VisualCheckboxGroup/VisualCheckbox/styles.module.scss.d.ts +18 -0
  610. package/lib/components/VisualCheckboxGroup/VisualCheckboxGroup.d.ts +33 -0
  611. package/lib/components/VisualCheckboxGroup/index.d.ts +3 -0
  612. package/lib/components/VisualCheckboxGroup/index.js +47 -0
  613. package/lib/components/VisualCheckboxGroup/index.js.map +1 -0
  614. package/lib/components/VisualCheckboxGroup/styles.module.scss +6 -0
  615. package/lib/components/VisualCheckboxGroup/styles.module.scss.d.ts +10 -0
  616. package/lib/components/VisualRadioCloud/Radio/Radio.d.ts +23 -0
  617. package/lib/components/VisualRadioCloud/Radio/index.d.ts +3 -0
  618. package/lib/components/VisualRadioCloud/Radio/index.js +7 -0
  619. package/lib/components/VisualRadioCloud/Radio/index.js.map +1 -0
  620. package/lib/components/VisualRadioCloud/Radio/styles.module.scss +7 -0
  621. package/lib/components/VisualRadioCloud/Radio/styles.module.scss.d.ts +15 -0
  622. package/lib/components/VisualRadioCloud/VisualRadioCloud.d.ts +39 -0
  623. package/lib/components/VisualRadioCloud/index.d.ts +3 -0
  624. package/lib/components/VisualRadioCloud/index.js +62 -0
  625. package/lib/components/VisualRadioCloud/index.js.map +1 -0
  626. package/lib/components/VisualRadioCloud/styles.module.scss +6 -0
  627. package/lib/components/VisualRadioCloud/styles.module.scss.d.ts +9 -0
  628. package/lib/components/VisualRadioGroup/VisualRadio/VisualContent.d.ts +10 -0
  629. package/lib/components/VisualRadioGroup/VisualRadio/VisualRadio.d.ts +26 -0
  630. package/lib/components/VisualRadioGroup/VisualRadio/index.d.ts +3 -0
  631. package/lib/components/VisualRadioGroup/VisualRadio/index.js +7 -0
  632. package/lib/components/VisualRadioGroup/VisualRadio/index.js.map +1 -0
  633. package/lib/components/VisualRadioGroup/VisualRadio/styles.module.scss +7 -0
  634. package/lib/components/VisualRadioGroup/VisualRadio/styles.module.scss.d.ts +18 -0
  635. package/lib/components/VisualRadioGroup/VisualRadioGroup.d.ts +39 -0
  636. package/lib/components/VisualRadioGroup/index.d.ts +3 -0
  637. package/lib/components/VisualRadioGroup/index.js +67 -0
  638. package/lib/components/VisualRadioGroup/index.js.map +1 -0
  639. package/lib/components/VisualRadioGroup/styles.module.scss +6 -0
  640. package/lib/components/VisualRadioGroup/styles.module.scss.d.ts +10 -0
  641. package/lib/constants.js.map +1 -1
  642. package/lib/constants2.js +6 -6
  643. package/lib/constants2.js.map +1 -1
  644. package/lib/floating-ui.react.js +34 -30
  645. package/lib/floating-ui.react.js.map +1 -1
  646. package/lib/getFilterChips.js.map +1 -1
  647. package/lib/hoc/withBreakpoint/withBreakpoint.js.map +1 -1
  648. package/lib/hooks/useBreakpoint.js.map +1 -1
  649. package/lib/hooks/useElementList.js.map +1 -1
  650. package/lib/hooks/useEventListenerState.js.map +1 -1
  651. package/lib/hooks/useExpand.js.map +1 -1
  652. package/lib/hooks/useFocusToggle.js.map +1 -1
  653. package/lib/hooks/useFocusTrap.js.map +1 -1
  654. package/lib/hooks/useFocusableElements.js.map +1 -1
  655. package/lib/hooks/useIcons.js.map +1 -1
  656. package/lib/hooks/useIdWithFallback.js.map +1 -1
  657. package/lib/hooks/useIntersectionObserver.js.map +1 -1
  658. package/lib/hooks/useInterval.js.map +1 -1
  659. package/lib/hooks/useIsMobileBreakpoint.js.map +1 -1
  660. package/lib/hooks/useIsServerSide.js.map +1 -1
  661. package/lib/hooks/useIsVisible.js.map +1 -1
  662. package/lib/hooks/useKeyboardEvent.js.map +1 -1
  663. package/lib/hooks/useLanguage.js.map +1 -1
  664. package/lib/hooks/useLayoutEvent.js.map +1 -1
  665. package/lib/hooks/useOutsideEvent.js.map +1 -1
  666. package/lib/hooks/usePrevious.js.map +1 -1
  667. package/lib/hooks/usePseudoClasses.js.map +1 -1
  668. package/lib/hooks/useResizeObserver.js.map +1 -1
  669. package/lib/hooks/useReturnFocusOnUnmount.js.map +1 -1
  670. package/lib/hooks/useRovingFocus.js.map +1 -1
  671. package/lib/hooks/useSize.js.map +1 -1
  672. package/lib/hooks/useToggle.js.map +1 -1
  673. package/lib/hooks/usestopPropagation.js.map +1 -1
  674. package/lib/resourceHelper.js +12 -8
  675. package/lib/resourceHelper.js.map +1 -1
  676. package/lib/resources/HN.Designsystem.Drawer.en-GB.json.d.ts +2 -2
  677. package/lib/resources/HN.Designsystem.Filter.en-GB.json.d.ts +6 -4
  678. package/lib/resources/HN.Designsystem.Filter.nb-NO.json.d.ts +6 -4
  679. package/lib/resources/Resources.d.ts +11 -3
  680. package/lib/scss/_visual-form.scss +357 -0
  681. package/lib/theme/currys/color.js.map +1 -1
  682. package/lib/theme/currys/spacing.js.map +1 -1
  683. package/lib/theme/grid.js.map +1 -1
  684. package/lib/theme/index.js.map +1 -1
  685. package/lib/theme/palette.js.map +1 -1
  686. package/lib/theme/spacers.js.map +1 -1
  687. package/lib/utils/accessibility.js.map +1 -1
  688. package/lib/utils/component.js.map +1 -1
  689. package/lib/utils/debounce.js.map +1 -1
  690. package/lib/utils/deepContains.js.map +1 -1
  691. package/lib/utils/device.js.map +1 -1
  692. package/lib/utils/focus.js.map +1 -1
  693. package/lib/utils/language.js.map +1 -1
  694. package/lib/utils/mobile.js.map +1 -1
  695. package/lib/utils/refs.js.map +1 -1
  696. package/lib/utils/resource.js.map +1 -1
  697. package/lib/utils/scroll.js.map +1 -1
  698. package/lib/utils/viewport.js.map +1 -1
  699. package/lib/utils.js.map +1 -1
  700. package/lib/utils2.js.map +1 -1
  701. package/lib/utils3.js +11 -100
  702. package/lib/utils3.js.map +1 -1
  703. package/lib/utils4.js +31 -12
  704. package/lib/utils4.js.map +1 -1
  705. package/lib/utils5.js +112 -31
  706. package/lib/utils5.js.map +1 -1
  707. package/lib/uuid.js.map +1 -1
  708. package/package.json +115 -1
  709. package/scss/_visual-form.scss +357 -0
  710. package/lib/components/RadioButton/utils.d.ts +0 -2
  711. package/lib/utils6.js +0 -115
  712. package/lib/utils6.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":[],"sources":["../../../src/components/PopMenu/constants.ts","../../../src/components/PopMenu/PopMenu.tsx","../../../src/components/PopMenu/index.ts"],"sourcesContent":["export enum PopMenuVariant {\n onWhite = 'on-white',\n onGray = 'on-gray',\n onBlueberry = 'on-blueberry',\n}\n\nexport enum PopMenuLabelPosition {\n right = 'right',\n left = 'left',\n}\n","import React, { useRef, useState } from 'react';\n\nimport classNames from 'classnames';\n\nimport type { SvgIcon } from '../Icon';\nimport type { IconName } from '../Icons/IconNames';\nimport type { LinkListProps, LinkProps } from '../LinkList';\n\nimport { AnalyticsId, IconSize } from '../../constants';\nimport { useIsMobileBreakpoint } from '../../hooks/useIsMobileBreakpoint';\nimport { useOutsideEvent } from '../../hooks/useOutsideEvent';\nimport { usePseudoClasses } from '../../hooks/usePseudoClasses';\nimport { isComponent } from '../../utils/component';\nimport Button from '../Button';\nimport Icon from '../Icon';\nimport VerticalDots from '../Icons/VerticalDots';\nimport X from '../Icons/X';\nimport LazyIcon from '../LazyIcon';\nimport LinkList from '../LinkList';\nimport PopOver from '../PopOver';\nimport { PopMenuLabelPosition, type PopMenuVariant } from './constants';\n\nimport styles from './styles.module.scss';\n\nexport interface PopMenuProps {\n /** Content shown inside PopOver. Can only be a LinkList */\n children: React.ReactElement<LinkListProps>;\n /** Adds custom classes to the popover element. */\n popOverClassName?: string;\n /** Adds custom classes to the element. */\n popMenuClassName?: string;\n /** @deprecated Changes responsive design for the trigger buttons. */\n popMenuVariant?: PopMenuVariant;\n /** Sets the data-testid attribute for the button that opens. */\n openButtonTestId?: string;\n /** Sets the data-testid attribute for the button that closes. */\n closeButtonTestId?: string;\n /** Sets the data-testid attribute for the popover. */\n popOverTestId?: string;\n /** Sets the arial-label attribute for the openButton. */\n openButtonAriaLabel?: string;\n /** Sets the arial-label attribute for the closeButton. */\n closeButtonAriaLabel?: string;\n /** Sets the icon on the trigger button. */\n svgIcon?: SvgIcon | IconName;\n /** Optional text next to the trigger button. */\n labelText?: string;\n /** Placement of the label text relative to the trigger button. */\n labelTextPosition?: PopMenuLabelPosition;\n}\n\nexport const PopMenu: React.FC<PopMenuProps> = (props: PopMenuProps) => {\n const triggerButtonRef = useRef<HTMLButtonElement>(null);\n const iconRef = useRef(null);\n const outerRef = useRef<HTMLDivElement>(null);\n const [isOpen, setIsOpen] = useState(false);\n const {\n children,\n popOverClassName,\n popMenuClassName,\n openButtonTestId,\n closeButtonTestId,\n popOverTestId,\n openButtonAriaLabel,\n closeButtonAriaLabel,\n svgIcon,\n labelText,\n labelTextPosition = PopMenuLabelPosition.right,\n } = props;\n const isMobile = useIsMobileBreakpoint();\n\n useOutsideEvent(outerRef, () => {\n setIsOpen(false);\n });\n\n const { isHovered: triggerButtonIsHovered } = usePseudoClasses(triggerButtonRef);\n const mobileIconSize = isMobile ? IconSize.XSmall : IconSize.Small;\n\n const handleClick = (cb?: () => void): void => {\n setIsOpen(false);\n if (cb) cb();\n };\n\n const renderChildren = (): React.ReactElement | undefined => {\n if (isComponent<LinkListProps>(children, LinkList)) {\n return (\n <PopOver\n testId={popOverTestId}\n className={classNames(styles['pop-menu__pop-over'], popOverClassName)}\n controllerRef={iconRef}\n role=\"dialog\"\n show={isOpen}\n >\n {React.Children.map(children, child =>\n React.cloneElement(child, {\n children: React.Children.map(child.props.children, child =>\n isComponent<LinkProps>(child, LinkList.Link)\n ? React.cloneElement(child, {\n onClick: (event: React.MouseEvent<HTMLAnchorElement | HTMLButtonElement>) =>\n handleClick(() => child.props.onClick && child.props.onClick(event)),\n })\n : child\n ),\n })\n )}\n </PopOver>\n );\n }\n };\n\n const toggleOpenOnClick = (): void => {\n setIsOpen(!isOpen);\n };\n\n const iconComponent =\n svgIcon && typeof svgIcon === 'string' ? (\n <LazyIcon iconName={svgIcon} size={IconSize.XSmall} isHovered={triggerButtonIsHovered} />\n ) : (\n svgIcon && <Icon svgIcon={svgIcon} size={IconSize.XSmall} isHovered={triggerButtonIsHovered} />\n );\n\n const openIcon = svgIcon ? (\n iconComponent\n ) : (\n <Icon ref={iconRef} svgIcon={svgIcon ?? VerticalDots} size={mobileIconSize} isHovered={triggerButtonIsHovered} />\n );\n\n const closeIcon = <Icon svgIcon={X} ref={iconRef} size={mobileIconSize} isHovered={triggerButtonIsHovered} />;\n\n return (\n <div ref={outerRef} className={classNames(popMenuClassName)} data-analyticsid={AnalyticsId.PopMenu}>\n <Button\n variant=\"borderless\"\n aria-expanded={isOpen}\n onClick={toggleOpenOnClick}\n ref={triggerButtonRef}\n ariaLabel={isOpen ? closeButtonAriaLabel : openButtonAriaLabel}\n testId={isOpen ? closeButtonTestId : openButtonTestId}\n >\n {labelText && labelTextPosition == PopMenuLabelPosition.left && <span>{labelText}</span>}\n {isOpen ? closeIcon : openIcon}\n {labelText && labelTextPosition == PopMenuLabelPosition.right && <span>{labelText}</span>}\n </Button>\n {isOpen && renderChildren()}\n </div>\n );\n};\n\nexport default PopMenu;\n","import PopMenu from './PopMenu';\nexport { PopMenuVariant, PopMenuLabelPosition } from './constants';\nexport * from './PopMenu';\nexport default PopMenu;\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA,IAAY,iBAAL,yBAAA,gBAAA;CACL,eAAA,aAAU;CACV,eAAA,YAAS;CACT,eAAA,iBAAc;;KACf;AAED,IAAY,uBAAL,yBAAA,sBAAA;CACL,qBAAA,WAAQ;CACR,qBAAA,UAAO;;KACR;;;AC0CD,IAAa,WAAmC,UAAwB;CACtE,MAAM,mBAAmB,OAA0B,KAAK;CACxD,MAAM,UAAU,OAAO,KAAK;CAC5B,MAAM,WAAW,OAAuB,KAAK;CAC7C,MAAM,CAAC,QAAQ,aAAa,SAAS,MAAM;CAC3C,MAAM,EACJ,UACA,kBACA,kBACA,kBACA,mBACA,eACA,qBACA,sBACA,SACA,WACA,oBAAoB,qBAAqB,UACvC;CACJ,MAAM,WAAW,uBAAuB;CAExC,gBAAgB,gBAAgB;EAC9B,UAAU,MAAM;GAChB;CAEF,MAAM,EAAE,WAAW,2BAA2B,iBAAiB,iBAAiB;CAChF,MAAM,iBAAiB,WAAW,SAAS,SAAS,SAAS;CAE7D,MAAM,eAAe,OAA0B;EAC7C,UAAU,MAAM;EAChB,IAAI,IAAI,IAAI;;CAGd,MAAM,uBAAuD;EAC3D,IAAI,YAA2B,UAAU,iBAAS,EAChD,OACE,oBAAC,iBAAD;GACE,QAAQ;GACR,WAAW,WAAW,OAAO,uBAAuB,iBAAiB;GACrE,eAAe;GACf,MAAK;GACL,MAAM;aAEL,MAAM,SAAS,IAAI,WAAU,UAC5B,MAAM,aAAa,OAAO,EACxB,UAAU,MAAM,SAAS,IAAI,MAAM,MAAM,WAAU,UACjD,YAAuB,OAAO,iBAAS,KAAK,GACxC,MAAM,aAAa,OAAO,EACxB,UAAU,UACR,kBAAkB,MAAM,MAAM,WAAW,MAAM,MAAM,QAAQ,MAAM,CAAC,EACvE,CAAC,GACF,MACL,EACF,CAAC,CACH;GACO,CAAA;;CAKhB,MAAM,0BAAgC;EACpC,UAAU,CAAC,OAAO;;CAGpB,MAAM,gBACJ,WAAW,OAAO,YAAY,WAC5B,oBAAC,kBAAD;EAAU,UAAU;EAAS,MAAM,SAAS;EAAQ,WAAW;EAA0B,CAAA,GAEzF,WAAW,oBAAC,cAAD;EAAe;EAAS,MAAM,SAAS;EAAQ,WAAW;EAA0B,CAAA;CAGnG,MAAM,WAAW,UACf,gBAEA,oBAAC,cAAD;EAAM,KAAK;EAAS,SAAS,WAAW;EAAc,MAAM;EAAgB,WAAW;EAA0B,CAAA;CAGnH,MAAM,YAAY,oBAAC,cAAD;EAAM,SAAS;EAAG,KAAK;EAAS,MAAM;EAAgB,WAAW;EAA0B,CAAA;CAE7G,OACE,qBAAC,OAAD;EAAK,KAAK;EAAU,WAAW,WAAW,iBAAiB;EAAE,oBAAkB,YAAY;YAA3F,CACE,qBAAC,gBAAD;GACE,SAAQ;GACR,iBAAe;GACf,SAAS;GACT,KAAK;GACL,WAAW,SAAS,uBAAuB;GAC3C,QAAQ,SAAS,oBAAoB;aANvC;IAQG,aAAa,qBAAqB,qBAAqB,QAAQ,oBAAC,QAAD,EAAA,UAAO,WAAiB,CAAA;IACvF,SAAS,YAAY;IACrB,aAAa,qBAAqB,qBAAqB,SAAS,oBAAC,QAAD,EAAA,UAAO,WAAiB,CAAA;IAClF;MACR,UAAU,gBAAgB,CACvB;;;;;AC7IV,IAAA,kBAAe"}
1
+ {"version":3,"file":"index.js","names":[],"sources":["../../../src/components/PopMenu/constants.ts","../../../src/components/PopMenu/PopMenu.tsx","../../../src/components/PopMenu/index.ts"],"sourcesContent":["export enum PopMenuVariant {\n onWhite = 'on-white',\n onGray = 'on-gray',\n onBlueberry = 'on-blueberry',\n}\n\nexport enum PopMenuLabelPosition {\n right = 'right',\n left = 'left',\n}\n","import React, { useRef, useState } from 'react';\n\nimport classNames from 'classnames';\n\nimport type { SvgIcon } from '../Icon';\nimport type { IconName } from '../Icons/IconNames';\nimport type { LinkListProps, LinkProps } from '../LinkList';\n\nimport { AnalyticsId, IconSize } from '../../constants';\nimport { useIsMobileBreakpoint } from '../../hooks/useIsMobileBreakpoint';\nimport { useOutsideEvent } from '../../hooks/useOutsideEvent';\nimport { usePseudoClasses } from '../../hooks/usePseudoClasses';\nimport { isComponent } from '../../utils/component';\nimport Button from '../Button';\nimport Icon from '../Icon';\nimport VerticalDots from '../Icons/VerticalDots';\nimport X from '../Icons/X';\nimport LazyIcon from '../LazyIcon';\nimport LinkList from '../LinkList';\nimport PopOver from '../PopOver';\nimport { PopMenuLabelPosition, type PopMenuVariant } from './constants';\n\nimport styles from './styles.module.scss';\n\nexport interface PopMenuProps {\n /** Content shown inside PopOver. Can only be a LinkList */\n children: React.ReactElement<LinkListProps>;\n /** Adds custom classes to the popover element. */\n popOverClassName?: string;\n /** Adds custom classes to the element. */\n popMenuClassName?: string;\n /** @deprecated Changes responsive design for the trigger buttons. */\n popMenuVariant?: PopMenuVariant;\n /** Sets the data-testid attribute for the button that opens. */\n openButtonTestId?: string;\n /** Sets the data-testid attribute for the button that closes. */\n closeButtonTestId?: string;\n /** Sets the data-testid attribute for the popover. */\n popOverTestId?: string;\n /** Sets the arial-label attribute for the openButton. */\n openButtonAriaLabel?: string;\n /** Sets the arial-label attribute for the closeButton. */\n closeButtonAriaLabel?: string;\n /** Sets the icon on the trigger button. */\n svgIcon?: SvgIcon | IconName;\n /** Optional text next to the trigger button. */\n labelText?: string;\n /** Placement of the label text relative to the trigger button. */\n labelTextPosition?: PopMenuLabelPosition;\n}\n\nexport const PopMenu: React.FC<PopMenuProps> = (props: PopMenuProps) => {\n const triggerButtonRef = useRef<HTMLButtonElement>(null);\n const iconRef = useRef(null);\n const outerRef = useRef<HTMLDivElement>(null);\n const [isOpen, setIsOpen] = useState(false);\n const {\n children,\n popOverClassName,\n popMenuClassName,\n openButtonTestId,\n closeButtonTestId,\n popOverTestId,\n openButtonAriaLabel,\n closeButtonAriaLabel,\n svgIcon,\n labelText,\n labelTextPosition = PopMenuLabelPosition.right,\n } = props;\n const isMobile = useIsMobileBreakpoint();\n\n useOutsideEvent(outerRef, () => {\n setIsOpen(false);\n });\n\n const { isHovered: triggerButtonIsHovered } = usePseudoClasses(triggerButtonRef);\n const mobileIconSize = isMobile ? IconSize.XSmall : IconSize.Small;\n\n const handleClick = (cb?: () => void): void => {\n setIsOpen(false);\n if (cb) cb();\n };\n\n const renderChildren = (): React.ReactElement | undefined => {\n if (isComponent<LinkListProps>(children, LinkList)) {\n return (\n <PopOver\n testId={popOverTestId}\n className={classNames(styles['pop-menu__pop-over'], popOverClassName)}\n controllerRef={iconRef}\n role=\"dialog\"\n show={isOpen}\n >\n {React.Children.map(children, child =>\n React.cloneElement(child, {\n children: React.Children.map(child.props.children, child =>\n isComponent<LinkProps>(child, LinkList.Link)\n ? React.cloneElement(child, {\n onClick: (event: React.MouseEvent<HTMLAnchorElement | HTMLButtonElement>) =>\n handleClick(() => child.props.onClick && child.props.onClick(event)),\n })\n : child\n ),\n })\n )}\n </PopOver>\n );\n }\n };\n\n const toggleOpenOnClick = (): void => {\n setIsOpen(!isOpen);\n };\n\n const iconComponent =\n svgIcon && typeof svgIcon === 'string' ? (\n <LazyIcon iconName={svgIcon} size={IconSize.XSmall} isHovered={triggerButtonIsHovered} />\n ) : (\n svgIcon && <Icon svgIcon={svgIcon} size={IconSize.XSmall} isHovered={triggerButtonIsHovered} />\n );\n\n const openIcon = svgIcon ? (\n iconComponent\n ) : (\n <Icon ref={iconRef} svgIcon={svgIcon ?? VerticalDots} size={mobileIconSize} isHovered={triggerButtonIsHovered} />\n );\n\n const closeIcon = <Icon svgIcon={X} ref={iconRef} size={mobileIconSize} isHovered={triggerButtonIsHovered} />;\n\n return (\n <div ref={outerRef} className={classNames(popMenuClassName)} data-analyticsid={AnalyticsId.PopMenu}>\n <Button\n variant=\"borderless\"\n aria-expanded={isOpen}\n onClick={toggleOpenOnClick}\n ref={triggerButtonRef}\n ariaLabel={isOpen ? closeButtonAriaLabel : openButtonAriaLabel}\n testId={isOpen ? closeButtonTestId : openButtonTestId}\n >\n {labelText && labelTextPosition == PopMenuLabelPosition.left && <span>{labelText}</span>}\n {isOpen ? closeIcon : openIcon}\n {labelText && labelTextPosition == PopMenuLabelPosition.right && <span>{labelText}</span>}\n </Button>\n {isOpen && renderChildren()}\n </div>\n );\n};\n\nexport default PopMenu;\n","import PopMenu from './PopMenu';\nexport { PopMenuVariant, PopMenuLabelPosition } from './constants';\nexport * from './PopMenu';\nexport default PopMenu;\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA,IAAY,iBAAL,yBAAA,gBAAA;CACL,eAAA,aAAA;CACA,eAAA,YAAA;CACA,eAAA,iBAAA;;AACF,EAAA,CAAA,CAAA;AAEA,IAAY,uBAAL,yBAAA,sBAAA;CACL,qBAAA,WAAA;CACA,qBAAA,UAAA;;AACF,EAAA,CAAA,CAAA;;;AC0CA,IAAa,WAAmC,UAAwB;CACtE,MAAM,mBAAmB,OAA0B,IAAI;CACvD,MAAM,UAAU,OAAO,IAAI;CAC3B,MAAM,WAAW,OAAuB,IAAI;CAC5C,MAAM,CAAC,QAAQ,aAAa,SAAS,KAAK;CAC1C,MAAM,EACJ,UACA,kBACA,kBACA,kBACA,mBACA,eACA,qBACA,sBACA,SACA,WACA,oBAAoB,qBAAqB,UACvC;CACJ,MAAM,WAAW,sBAAsB;CAEvC,gBAAgB,gBAAgB;EAC9B,UAAU,KAAK;CACjB,CAAC;CAED,MAAM,EAAE,WAAW,2BAA2B,iBAAiB,gBAAgB;CAC/E,MAAM,iBAAiB,WAAW,SAAS,SAAS,SAAS;CAE7D,MAAM,eAAe,OAA0B;EAC7C,UAAU,KAAK;EACf,IAAI,IAAI,GAAG;CACb;CAEA,MAAM,uBAAuD;EAC3D,IAAI,YAA2B,UAAU,gBAAQ,GAC/C,OACE,oBAAC,iBAAD;GACE,QAAQ;GACR,WAAW,WAAW,OAAO,uBAAuB,gBAAgB;GACpE,eAAe;GACf,MAAK;GACL,MAAM;aAEL,MAAM,SAAS,IAAI,WAAU,UAC5B,MAAM,aAAa,OAAO,EACxB,UAAU,MAAM,SAAS,IAAI,MAAM,MAAM,WAAU,UACjD,YAAuB,OAAO,iBAAS,IAAI,IACvC,MAAM,aAAa,OAAO,EACxB,UAAU,UACR,kBAAkB,MAAM,MAAM,WAAW,MAAM,MAAM,QAAQ,KAAK,CAAC,EACvE,CAAC,IACD,KACN,EACF,CAAC,CACH;EACO,CAAA;CAGf;CAEA,MAAM,0BAAgC;EACpC,UAAU,CAAC,MAAM;CACnB;CAEA,MAAM,gBACJ,WAAW,OAAO,YAAY,WAC5B,oBAAC,kBAAD;EAAU,UAAU;EAAS,MAAM,SAAS;EAAQ,WAAW;CAAyB,CAAA,IAExF,WAAW,oBAAC,cAAD;EAAe;EAAS,MAAM,SAAS;EAAQ,WAAW;CAAyB,CAAA;CAGlG,MAAM,WAAW,UACf,gBAEA,oBAAC,cAAD;EAAM,KAAK;EAAS,SAAS,WAAW;EAAc,MAAM;EAAgB,WAAW;CAAyB,CAAA;CAGlH,MAAM,YAAY,oBAAC,cAAD;EAAM,SAAS;EAAG,KAAK;EAAS,MAAM;EAAgB,WAAW;CAAyB,CAAA;CAE5G,OACE,qBAAC,OAAD;EAAK,KAAK;EAAU,WAAW,WAAW,gBAAgB;EAAG,oBAAkB,YAAY;YAA3F,CACE,qBAAC,gBAAD;GACE,SAAQ;GACR,iBAAe;GACf,SAAS;GACT,KAAK;GACL,WAAW,SAAS,uBAAuB;GAC3C,QAAQ,SAAS,oBAAoB;aANvC;IAQG,aAAa,qBAAqB,qBAAqB,QAAQ,oBAAC,QAAD,EAAA,UAAO,UAAgB,CAAA;IACtF,SAAS,YAAY;IACrB,aAAa,qBAAqB,qBAAqB,SAAS,oBAAC,QAAD,EAAA,UAAO,UAAgB,CAAA;GAClF;MACP,UAAU,eAAe,CACvB;;AAET;;;AC/IA,IAAA,kBAAe"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":[],"sources":["../../../src/components/Portal/index.tsx"],"sourcesContent":["import React from 'react';\n\nimport { createPortal } from 'react-dom';\n\nimport { AnalyticsId } from '../../constants';\n\nexport interface PortalProps {\n /** Add custom class to portal, default class is portal-container */\n className?: string;\n /** Content to be displayed in Portal */\n children?: React.ReactNode;\n /** Default is document.body */\n parent?: HTMLElement;\n /** Sets the data-testid attribute. */\n testId?: string;\n}\n\nexport default function Portal({ children, parent, className, testId }: PortalProps): React.ReactPortal {\n // Create div to contain everything\n const el = React.useMemo(() => document.createElement('div'), []);\n el.setAttribute('data-analyticsid', AnalyticsId.Portal);\n if (testId) {\n el.setAttribute('data-testid', testId);\n }\n // On mount function\n React.useEffect(() => {\n // work out target in the DOM based on parent prop\n const target = parent && !!parent.appendChild ? parent : document.body;\n // Default classes\n const classList = ['portal-container'];\n // If className prop is present add each class the classList\n if (className) className.split(' ').forEach(item => classList.push(item));\n classList.forEach(item => el.classList.add(item));\n\n target.appendChild(el);\n // On unmount function\n return (): void => {\n // Remove element from dom\n target.removeChild(el);\n };\n }, [el, parent, className]);\n\n return createPortal(children, el);\n}\n"],"mappings":";;;;AAiBA,SAAwB,OAAO,EAAE,UAAU,QAAQ,WAAW,UAA0C;CAEtG,MAAM,KAAK,MAAM,cAAc,SAAS,cAAc,MAAM,EAAE,EAAE,CAAC;CACjE,GAAG,aAAa,oBAAoB,YAAY,OAAO;CACvD,IAAI,QACF,GAAG,aAAa,eAAe,OAAO;CAGxC,MAAM,gBAAgB;EAEpB,MAAM,SAAS,UAAU,CAAC,CAAC,OAAO,cAAc,SAAS,SAAS;EAElE,MAAM,YAAY,CAAC,mBAAmB;EAEtC,IAAI,WAAW,UAAU,MAAM,IAAI,CAAC,SAAQ,SAAQ,UAAU,KAAK,KAAK,CAAC;EACzE,UAAU,SAAQ,SAAQ,GAAG,UAAU,IAAI,KAAK,CAAC;EAEjD,OAAO,YAAY,GAAG;EAEtB,aAAmB;GAEjB,OAAO,YAAY,GAAG;;IAEvB;EAAC;EAAI;EAAQ;EAAU,CAAC;CAE3B,OAAO,aAAa,UAAU,GAAG"}
1
+ {"version":3,"file":"index.js","names":[],"sources":["../../../src/components/Portal/index.tsx"],"sourcesContent":["import React from 'react';\n\nimport { createPortal } from 'react-dom';\n\nimport { AnalyticsId } from '../../constants';\n\nexport interface PortalProps {\n /** Add custom class to portal, default class is portal-container */\n className?: string;\n /** Content to be displayed in Portal */\n children?: React.ReactNode;\n /** Default is document.body */\n parent?: HTMLElement;\n /** Sets the data-testid attribute. */\n testId?: string;\n}\n\nexport default function Portal({ children, parent, className, testId }: PortalProps): React.ReactPortal {\n // Create div to contain everything\n const el = React.useMemo(() => document.createElement('div'), []);\n el.setAttribute('data-analyticsid', AnalyticsId.Portal);\n if (testId) {\n el.setAttribute('data-testid', testId);\n }\n // On mount function\n React.useEffect(() => {\n // work out target in the DOM based on parent prop\n const target = parent && !!parent.appendChild ? parent : document.body;\n // Default classes\n const classList = ['portal-container'];\n // If className prop is present add each class the classList\n if (className) className.split(' ').forEach(item => classList.push(item));\n classList.forEach(item => el.classList.add(item));\n\n target.appendChild(el);\n // On unmount function\n return (): void => {\n // Remove element from dom\n target.removeChild(el);\n };\n }, [el, parent, className]);\n\n return createPortal(children, el);\n}\n"],"mappings":";;;;AAiBA,SAAwB,OAAO,EAAE,UAAU,QAAQ,WAAW,UAA0C;CAEtG,MAAM,KAAK,MAAM,cAAc,SAAS,cAAc,KAAK,GAAG,CAAC,CAAC;CAChE,GAAG,aAAa,oBAAoB,YAAY,MAAM;CACtD,IAAI,QACF,GAAG,aAAa,eAAe,MAAM;CAGvC,MAAM,gBAAgB;EAEpB,MAAM,SAAS,UAAU,CAAC,CAAC,OAAO,cAAc,SAAS,SAAS;EAElE,MAAM,YAAY,CAAC,kBAAkB;EAErC,IAAI,WAAW,UAAU,MAAM,GAAG,EAAE,SAAQ,SAAQ,UAAU,KAAK,IAAI,CAAC;EACxE,UAAU,SAAQ,SAAQ,GAAG,UAAU,IAAI,IAAI,CAAC;EAEhD,OAAO,YAAY,EAAE;EAErB,aAAmB;GAEjB,OAAO,YAAY,EAAE;EACvB;CACF,GAAG;EAAC;EAAI;EAAQ;CAAS,CAAC;CAE1B,OAAO,aAAa,UAAU,EAAE;AAClC"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":[],"sources":["../../../src/components/Progressbar/constants.ts","../../../src/components/Progressbar/Progressbar.tsx","../../../src/components/Progressbar/index.ts"],"sourcesContent":["export enum ProgressbarSize {\n small = 'small',\n medium = 'medium',\n large = 'large',\n}\n\nexport enum ProgressBarMode {\n ondark = 'ondark',\n onlight = 'onlight',\n}\n\nexport enum Overlay {\n screen = 'screen',\n parent = 'parent',\n}\n","import { useRef, useEffect } from 'react';\n\nimport classNames from 'classnames';\n\nimport { Overlay, ProgressBarMode, ProgressbarSize } from './constants';\nimport { ZIndex } from '../../constants';\nimport { palette } from '../../theme/palette';\n\nimport styles from './styles.module.scss';\n\nexport interface ProgressbarProps {\n /** The value of the progressbar given in percent. Value between 0 and 100 */\n value: number;\n /** Size of the progressbar. Default is large */\n size?: ProgressbarSize;\n /** Changes the visuals of the ProgressBar. Default is onLight */\n mode?: ProgressBarMode;\n /** Loader is displayed with grey background covering the entire screen */\n overlay?: keyof typeof Overlay;\n /** Aria label for the progressbar */\n ariaLabel?: string;\n /** Sets the data-testid attribute */\n testId?: string;\n}\n\nconst Progressbar: React.FC<ProgressbarProps> = ({\n value,\n size = ProgressbarSize.large,\n mode = ProgressBarMode.onlight,\n overlay,\n testId,\n ariaLabel,\n}: ProgressbarProps) => {\n if (overlay) {\n mode = ProgressBarMode.ondark;\n }\n // Restrict value to be between 0 and 100\n value = Math.max(0, Math.min(value, 100));\n\n let width;\n if (size === ProgressbarSize.large) {\n width = 96;\n } else if (size === ProgressbarSize.medium) {\n width = 50;\n } else {\n width = 44;\n }\n\n const totalRadius = width / 2;\n const strokeWidth = 8;\n const radius = totalRadius - strokeWidth / 2;\n const viewBoxSize = totalRadius * 2;\n const viewBoxCenter = totalRadius;\n const circleBackgroundColor = mode === ProgressBarMode.onlight ? palette.blueberry100 : palette.neutral700;\n const mainColor = mode === ProgressBarMode.onlight ? palette.blueberry600 : palette.white;\n const circumference = 2 * Math.PI * radius;\n const strokeDashoffset = circumference - (value / 100) * circumference;\n const valueText = `${value}%`;\n\n const wrapperRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n if (overlay === Overlay.parent && wrapperRef.current?.parentElement?.style) {\n wrapperRef.current.parentElement.style.position = 'relative';\n }\n }, []);\n\n const wrapperClasses = classNames({\n [styles['progressbar--overlay']]: overlay,\n [styles['progressbar--overlay-screen']]: overlay === Overlay.screen,\n [styles['progressbar--overlay-parent']]: overlay === Overlay.parent,\n });\n\n return (\n <>\n <div\n ref={wrapperRef}\n className={wrapperClasses}\n data-testid={testId}\n role=\"progressbar\"\n aria-valuemin={0}\n aria-valuemax={100}\n aria-valuenow={value}\n aria-label={ariaLabel}\n style={overlay === Overlay.screen ? { zIndex: ZIndex.OverlayScreen } : {}}\n >\n <svg\n role=\"presentation\"\n width={viewBoxSize}\n height={viewBoxSize}\n viewBox={`0 0 ${viewBoxSize} ${viewBoxSize}`}\n className={styles['progressbar__svg']}\n >\n <circle cx={viewBoxCenter} cy={viewBoxCenter} r={radius} stroke={circleBackgroundColor} strokeWidth={strokeWidth} fill=\"none\" />\n <circle\n cx={viewBoxCenter}\n cy={viewBoxCenter}\n r={radius}\n stroke={mainColor}\n strokeWidth={strokeWidth}\n fill=\"none\"\n strokeDasharray={circumference}\n strokeDashoffset={strokeDashoffset}\n className={styles['progressbar__progress-circle']}\n transform={`rotate(-90 ${viewBoxCenter} ${viewBoxCenter})`}\n />\n <text\n className=\"progress-wheel__text--large\"\n fontSize={'1.5rem'}\n fill={mainColor}\n x={viewBoxCenter}\n y={viewBoxCenter}\n textAnchor=\"middle\"\n alignmentBaseline=\"middle\"\n >\n {size === ProgressbarSize.large && valueText}\n </text>\n </svg>\n </div>\n <div className={styles['progressbar__sr-only-text']} aria-live=\"assertive\" aria-atomic=\"true\">\n {valueText}\n </div>\n </>\n );\n};\n\nexport default Progressbar;\n","import Progressbar from './Progressbar';\nexport { ProgressbarSize, ProgressBarMode, Overlay } from './constants';\nexport * from './Progressbar';\nexport default Progressbar;\n"],"mappings":";;;;;;;AAAA,IAAY,kBAAL,yBAAA,iBAAA;CACL,gBAAA,WAAQ;CACR,gBAAA,YAAS;CACT,gBAAA,WAAQ;;KACT;AAED,IAAY,kBAAL,yBAAA,iBAAA;CACL,gBAAA,YAAS;CACT,gBAAA,aAAU;;KACX;AAED,IAAY,UAAL,yBAAA,SAAA;CACL,QAAA,YAAS;CACT,QAAA,YAAS;;KACV;;;ACWD,IAAM,eAA2C,EAC/C,OACA,OAAO,gBAAgB,OACvB,OAAO,gBAAgB,SACvB,SACA,QACA,gBACsB;CACtB,IAAI,SACF,OAAO,gBAAgB;CAGzB,QAAQ,KAAK,IAAI,GAAG,KAAK,IAAI,OAAO,IAAI,CAAC;CAEzC,IAAI;CACJ,IAAI,SAAS,gBAAgB,OAC3B,QAAQ;MACH,IAAI,SAAS,gBAAgB,QAClC,QAAQ;MAER,QAAQ;CAGV,MAAM,cAAc,QAAQ;CAC5B,MAAM,cAAc;CACpB,MAAM,SAAS,cAAc,cAAc;CAC3C,MAAM,cAAc,cAAc;CAClC,MAAM,gBAAgB;CACtB,MAAM,wBAAwB,SAAS,gBAAgB,UAAU,QAAQ,eAAe,QAAQ;CAChG,MAAM,YAAY,SAAS,gBAAgB,UAAU,QAAQ,eAAe,QAAQ;CACpF,MAAM,gBAAgB,IAAI,KAAK,KAAK;CACpC,MAAM,mBAAmB,gBAAiB,QAAQ,MAAO;CACzD,MAAM,YAAY,GAAG,MAAM;CAE3B,MAAM,aAAa,OAAuB,KAAK;CAE/C,gBAAgB;EACd,IAAI,YAAY,QAAQ,UAAU,WAAW,SAAS,eAAe,OACnE,WAAW,QAAQ,cAAc,MAAM,WAAW;IAEnD,EAAE,CAAC;CAQN,OACE,qBAAA,UAAA,EAAA,UAAA,CACE,oBAAC,OAAD;EACE,KAAK;EACL,WAViB,WAAW;IAC/B,OAAO,0BAA0B;IACjC,OAAO,iCAAiC,YAAY,QAAQ;IAC5D,OAAO,iCAAiC,YAAY,QAAQ;GAC9D,CAMgB;EACX,eAAa;EACb,MAAK;EACL,iBAAe;EACf,iBAAe;EACf,iBAAe;EACf,cAAY;EACZ,OAAO,YAAY,QAAQ,SAAS,EAAE,QAAQ,OAAO,eAAe,GAAG,EAAE;YAEzE,qBAAC,OAAD;GACE,MAAK;GACL,OAAO;GACP,QAAQ;GACR,SAAS,OAAO,YAAY,GAAG;GAC/B,WAAW,OAAO;aALpB;IAOE,oBAAC,UAAD;KAAQ,IAAI;KAAe,IAAI;KAAe,GAAG;KAAQ,QAAQ;KAAoC;KAAa,MAAK;KAAS,CAAA;IAChI,oBAAC,UAAD;KACE,IAAI;KACJ,IAAI;KACJ,GAAG;KACH,QAAQ;KACK;KACb,MAAK;KACL,iBAAiB;KACC;KAClB,WAAW,OAAO;KAClB,WAAW,cAAc,cAAc,GAAG,cAAc;KACxD,CAAA;IACF,oBAAC,QAAD;KACE,WAAU;KACV,UAAU;KACV,MAAM;KACN,GAAG;KACH,GAAG;KACH,YAAW;KACX,mBAAkB;eAEjB,SAAS,gBAAgB,SAAS;KAC9B,CAAA;IACH;;EACF,CAAA,EACN,oBAAC,OAAD;EAAK,WAAW,OAAO;EAA8B,aAAU;EAAY,eAAY;YACpF;EACG,CAAA,CACL,EAAA,CAAA;;;;ACvHP,IAAA,sBAAe"}
1
+ {"version":3,"file":"index.js","names":[],"sources":["../../../src/components/Progressbar/constants.ts","../../../src/components/Progressbar/Progressbar.tsx","../../../src/components/Progressbar/index.ts"],"sourcesContent":["export enum ProgressbarSize {\n small = 'small',\n medium = 'medium',\n large = 'large',\n}\n\nexport enum ProgressBarMode {\n ondark = 'ondark',\n onlight = 'onlight',\n}\n\nexport enum Overlay {\n screen = 'screen',\n parent = 'parent',\n}\n","import { useRef, useEffect } from 'react';\n\nimport classNames from 'classnames';\n\nimport { Overlay, ProgressBarMode, ProgressbarSize } from './constants';\nimport { ZIndex } from '../../constants';\nimport { palette } from '../../theme/palette';\n\nimport styles from './styles.module.scss';\n\nexport interface ProgressbarProps {\n /** The value of the progressbar given in percent. Value between 0 and 100 */\n value: number;\n /** Size of the progressbar. Default is large */\n size?: ProgressbarSize;\n /** Changes the visuals of the ProgressBar. Default is onLight */\n mode?: ProgressBarMode;\n /** Loader is displayed with grey background covering the entire screen */\n overlay?: keyof typeof Overlay;\n /** Aria label for the progressbar */\n ariaLabel?: string;\n /** Sets the data-testid attribute */\n testId?: string;\n}\n\nconst Progressbar: React.FC<ProgressbarProps> = ({\n value,\n size = ProgressbarSize.large,\n mode = ProgressBarMode.onlight,\n overlay,\n testId,\n ariaLabel,\n}: ProgressbarProps) => {\n if (overlay) {\n mode = ProgressBarMode.ondark;\n }\n // Restrict value to be between 0 and 100\n value = Math.max(0, Math.min(value, 100));\n\n let width;\n if (size === ProgressbarSize.large) {\n width = 96;\n } else if (size === ProgressbarSize.medium) {\n width = 50;\n } else {\n width = 44;\n }\n\n const totalRadius = width / 2;\n const strokeWidth = 8;\n const radius = totalRadius - strokeWidth / 2;\n const viewBoxSize = totalRadius * 2;\n const viewBoxCenter = totalRadius;\n const circleBackgroundColor = mode === ProgressBarMode.onlight ? palette.blueberry100 : palette.neutral700;\n const mainColor = mode === ProgressBarMode.onlight ? palette.blueberry600 : palette.white;\n const circumference = 2 * Math.PI * radius;\n const strokeDashoffset = circumference - (value / 100) * circumference;\n const valueText = `${value}%`;\n\n const wrapperRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n if (overlay === Overlay.parent && wrapperRef.current?.parentElement?.style) {\n wrapperRef.current.parentElement.style.position = 'relative';\n }\n }, []);\n\n const wrapperClasses = classNames({\n [styles['progressbar--overlay']]: overlay,\n [styles['progressbar--overlay-screen']]: overlay === Overlay.screen,\n [styles['progressbar--overlay-parent']]: overlay === Overlay.parent,\n });\n\n return (\n <>\n <div\n ref={wrapperRef}\n className={wrapperClasses}\n data-testid={testId}\n role=\"progressbar\"\n aria-valuemin={0}\n aria-valuemax={100}\n aria-valuenow={value}\n aria-label={ariaLabel}\n style={overlay === Overlay.screen ? { zIndex: ZIndex.OverlayScreen } : {}}\n >\n <svg\n role=\"presentation\"\n width={viewBoxSize}\n height={viewBoxSize}\n viewBox={`0 0 ${viewBoxSize} ${viewBoxSize}`}\n className={styles['progressbar__svg']}\n >\n <circle cx={viewBoxCenter} cy={viewBoxCenter} r={radius} stroke={circleBackgroundColor} strokeWidth={strokeWidth} fill=\"none\" />\n <circle\n cx={viewBoxCenter}\n cy={viewBoxCenter}\n r={radius}\n stroke={mainColor}\n strokeWidth={strokeWidth}\n fill=\"none\"\n strokeDasharray={circumference}\n strokeDashoffset={strokeDashoffset}\n className={styles['progressbar__progress-circle']}\n transform={`rotate(-90 ${viewBoxCenter} ${viewBoxCenter})`}\n />\n <text\n className=\"progress-wheel__text--large\"\n fontSize={'1.5rem'}\n fill={mainColor}\n x={viewBoxCenter}\n y={viewBoxCenter}\n textAnchor=\"middle\"\n alignmentBaseline=\"middle\"\n >\n {size === ProgressbarSize.large && valueText}\n </text>\n </svg>\n </div>\n <div className={styles['progressbar__sr-only-text']} aria-live=\"assertive\" aria-atomic=\"true\">\n {valueText}\n </div>\n </>\n );\n};\n\nexport default Progressbar;\n","import Progressbar from './Progressbar';\nexport { ProgressbarSize, ProgressBarMode, Overlay } from './constants';\nexport * from './Progressbar';\nexport default Progressbar;\n"],"mappings":";;;;;;;AAAA,IAAY,kBAAL,yBAAA,iBAAA;CACL,gBAAA,WAAA;CACA,gBAAA,YAAA;CACA,gBAAA,WAAA;;AACF,EAAA,CAAA,CAAA;AAEA,IAAY,kBAAL,yBAAA,iBAAA;CACL,gBAAA,YAAA;CACA,gBAAA,aAAA;;AACF,EAAA,CAAA,CAAA;AAEA,IAAY,UAAL,yBAAA,SAAA;CACL,QAAA,YAAA;CACA,QAAA,YAAA;;AACF,EAAA,CAAA,CAAA;;;ACWA,IAAM,eAA2C,EAC/C,OACA,OAAO,gBAAgB,OACvB,OAAO,gBAAgB,SACvB,SACA,QACA,gBACsB;CACtB,IAAI,SACF,OAAO,gBAAgB;CAGzB,QAAQ,KAAK,IAAI,GAAG,KAAK,IAAI,OAAO,GAAG,CAAC;CAExC,IAAI;CACJ,IAAI,SAAS,gBAAgB,OAC3B,QAAQ;MACH,IAAI,SAAS,gBAAgB,QAClC,QAAQ;MAER,QAAQ;CAGV,MAAM,cAAc,QAAQ;CAC5B,MAAM,cAAc;CACpB,MAAM,SAAS,cAAc,cAAc;CAC3C,MAAM,cAAc,cAAc;CAClC,MAAM,gBAAgB;CACtB,MAAM,wBAAwB,SAAS,gBAAgB,UAAU,QAAQ,eAAe,QAAQ;CAChG,MAAM,YAAY,SAAS,gBAAgB,UAAU,QAAQ,eAAe,QAAQ;CACpF,MAAM,gBAAgB,IAAI,KAAK,KAAK;CACpC,MAAM,mBAAmB,gBAAiB,QAAQ,MAAO;CACzD,MAAM,YAAY,GAAG,MAAM;CAE3B,MAAM,aAAa,OAAuB,IAAI;CAE9C,gBAAgB;EACd,IAAI,YAAY,QAAQ,UAAU,WAAW,SAAS,eAAe,OACnE,WAAW,QAAQ,cAAc,MAAM,WAAW;CAEtD,GAAG,CAAC,CAAC;CAQL,OACE,qBAAA,UAAA,EAAA,UAAA,CACE,oBAAC,OAAD;EACE,KAAK;EACL,WAViB,WAAW;IAC/B,OAAO,0BAA0B;IACjC,OAAO,iCAAiC,YAAY,QAAQ;IAC5D,OAAO,iCAAiC,YAAY,QAAQ;EAC/D,CAMiB;EACX,eAAa;EACb,MAAK;EACL,iBAAe;EACf,iBAAe;EACf,iBAAe;EACf,cAAY;EACZ,OAAO,YAAY,QAAQ,SAAS,EAAE,QAAQ,OAAO,cAAc,IAAI,CAAC;YAExE,qBAAC,OAAD;GACE,MAAK;GACL,OAAO;GACP,QAAQ;GACR,SAAS,OAAO,YAAY,GAAG;GAC/B,WAAW,OAAO;aALpB;IAOE,oBAAC,UAAD;KAAQ,IAAI;KAAe,IAAI;KAAe,GAAG;KAAQ,QAAQ;KAAoC;KAAa,MAAK;IAAQ,CAAA;IAC/H,oBAAC,UAAD;KACE,IAAI;KACJ,IAAI;KACJ,GAAG;KACH,QAAQ;KACK;KACb,MAAK;KACL,iBAAiB;KACC;KAClB,WAAW,OAAO;KAClB,WAAW,cAAc,cAAc,GAAG,cAAc;IACzD,CAAA;IACD,oBAAC,QAAD;KACE,WAAU;KACV,UAAU;KACV,MAAM;KACN,GAAG;KACH,GAAG;KACH,YAAW;KACX,mBAAkB;eAEjB,SAAS,gBAAgB,SAAS;IAC/B,CAAA;GACH;;CACF,CAAA,GACL,oBAAC,OAAD;EAAK,WAAW,OAAO;EAA8B,aAAU;EAAY,eAAY;YACpF;CACE,CAAA,CACL,EAAA,CAAA;AAEN;;;ACzHA,IAAA,sBAAe"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":[],"sources":["../../../src/components/PromoPanel/PromoPanel.tsx","../../../src/components/PromoPanel/index.ts"],"sourcesContent":["import React from 'react';\n\nimport classNames from 'classnames';\n\nimport type { PaletteNames } from '../../theme/palette';\nimport type { AnchorLinkTags, AnchorLinkTargets } from '../AnchorLink';\nimport type { TitleTags } from '../Title';\n\nimport { AnalyticsId, IconSize } from '../../constants';\nimport { Breakpoint, useBreakpoint } from '../../hooks/useBreakpoint';\nimport { usePseudoClasses } from '../../hooks/usePseudoClasses';\nimport { getColor } from '../../theme/currys/color';\nimport Icon from '../Icon';\nimport ArrowRight from '../Icons/ArrowRight';\nimport ArrowUpRight from '../Icons/ArrowUpRight';\nimport LazyIllustration from '../LazyIllustration';\nimport Title from '../Title';\n\nimport styles from './styles.module.scss';\n\nexport type PromoPanelColors = Extract<PaletteNames, 'neutral' | 'blueberry' | 'cherry'>;\n\nexport interface PromoPanelProps {\n /** Used as the link text if set. title or children must be set for the link to have accessible text. */\n title?: string;\n /** Used as the link text if title is not set. */\n children?: string;\n /** Illustration element */\n illustration?: 'Doctor' | 'HealthcarePersonnel';\n /** Changes the underlying element of the title. */\n titleHtmlMarkup?: TitleTags;\n /** Changes the background color. Default: white */\n color?: PromoPanelColors;\n /** Not used if linkComponent is set */\n href?: string;\n /** Anchor link target. If linkComponent is set, this prop is only used to display the right icon for external links. */\n target?: AnchorLinkTargets;\n /** HTML markup for anchor link. Not used if linkComponent is set. Default: a */\n linkHtmlMarkup?: AnchorLinkTags;\n /** Function that is called when clicked. Not used if linkComponent is set. */\n linkOnClick?: () => void;\n /** Custom link component. Must be \"a\" a or \"button\" element with no styling. */\n linkComponent?: React.ReactElement;\n /** Sets the data-testid attribute. */\n testId?: string;\n}\n\ninterface PromoPanelLinkProps {\n children?: string;\n href?: string;\n target?: AnchorLinkTargets;\n linkComponent?: React.ReactElement;\n linkHtmlMarkup?: AnchorLinkTags;\n linkOnClick?: () => void;\n}\n\nconst PromoPanelLink: React.FC<PromoPanelLinkProps> = props => {\n if (props.linkComponent) {\n return React.cloneElement(props.linkComponent, undefined, props.children);\n }\n\n if (props.linkHtmlMarkup === 'button') {\n return (\n <button type={'button'} onClick={props.linkOnClick}>\n {props.children}\n </button>\n );\n }\n return (\n <a href={props.href} target={props.target} onClick={props.linkOnClick}>\n {props.children}\n </a>\n );\n};\n\nconst PromoPanel: React.FC<PromoPanelProps> = props => {\n const { isHovered, refObject } = usePseudoClasses<HTMLDivElement>();\n\n const { color = 'neutral', titleHtmlMarkup = 'h2', linkHtmlMarkup = 'a' } = props;\n\n const breakpoint = useBreakpoint();\n\n const promoPanelClasses = classNames(\n styles.promopanel,\n styles[`promopanel--${color}`],\n !props.illustration && styles['promopanel--no-illustration']\n );\n\n const promoPanelLink = (\n <PromoPanelLink\n href={props.href}\n target={props.target}\n linkComponent={props.linkComponent}\n linkHtmlMarkup={linkHtmlMarkup}\n linkOnClick={props.linkOnClick}\n >\n {props.title || props.children}\n </PromoPanelLink>\n );\n\n const illustrationSize = ((): number => {\n if (breakpoint >= Breakpoint.md) {\n return 156;\n }\n\n return 110;\n })();\n\n return (\n <div className={promoPanelClasses} data-testid={props.testId} data-analyticsid={AnalyticsId.PromoPanel} ref={refObject}>\n {props.illustration && (\n <LazyIllustration\n illustrationName={props.illustration}\n size={illustrationSize}\n color={color}\n className={styles.promopanel__illustration}\n />\n )}\n <div className={styles.promopanel__content}>\n {props.title && (\n <Title htmlMarkup={titleHtmlMarkup} appearance={'title3'}>\n {promoPanelLink}\n </Title>\n )}\n {!props.title ? promoPanelLink : props.children}\n </div>\n <Icon\n className={styles.promopanel__icon}\n svgIcon={props.target === '_blank' ? ArrowUpRight : ArrowRight}\n size={breakpoint >= Breakpoint.md ? IconSize.Small : IconSize.XSmall}\n isHovered={isHovered}\n color={getColor('blueberry', 500)}\n hoverColor={getColor('blueberry', 600)}\n />\n </div>\n );\n};\n\nexport default PromoPanel;\n","import PromoPanel from './PromoPanel';\nexport * from './PromoPanel';\nexport default PromoPanel;\n"],"mappings":";;;;;;;;;;;;;;AAwDA,IAAM,kBAAgD,UAAS;CAC7D,IAAI,MAAM,eACR,OAAO,MAAM,aAAa,MAAM,eAAe,KAAA,GAAW,MAAM,SAAS;CAG3E,IAAI,MAAM,mBAAmB,UAC3B,OACE,oBAAC,UAAD;EAAQ,MAAM;EAAU,SAAS,MAAM;YACpC,MAAM;EACA,CAAA;CAGb,OACE,oBAAC,KAAD;EAAG,MAAM,MAAM;EAAM,QAAQ,MAAM;EAAQ,SAAS,MAAM;YACvD,MAAM;EACL,CAAA;;AAIR,IAAM,cAAwC,UAAS;CACrD,MAAM,EAAE,WAAW,cAAc,kBAAkC;CAEnE,MAAM,EAAE,QAAQ,WAAW,kBAAkB,MAAM,iBAAiB,QAAQ;CAE5E,MAAM,aAAa,eAAe;CAElC,MAAM,oBAAoB,WACxB,OAAO,YACP,OAAO,eAAe,UACtB,CAAC,MAAM,gBAAgB,OAAO,+BAC/B;CAED,MAAM,iBACJ,oBAAC,gBAAD;EACE,MAAM,MAAM;EACZ,QAAQ,MAAM;EACd,eAAe,MAAM;EACL;EAChB,aAAa,MAAM;YAElB,MAAM,SAAS,MAAM;EACP,CAAA;CAGnB,MAAM,0BAAkC;EACtC,IAAI,cAAc,WAAW,IAC3B,OAAO;EAGT,OAAO;KACL;CAEJ,OACE,qBAAC,OAAD;EAAK,WAAW;EAAmB,eAAa,MAAM;EAAQ,oBAAkB,YAAY;EAAY,KAAK;YAA7G;GACG,MAAM,gBACL,oBAAC,0BAAD;IACE,kBAAkB,MAAM;IACxB,MAAM;IACC;IACP,WAAW,OAAO;IAClB,CAAA;GAEJ,qBAAC,OAAD;IAAK,WAAW,OAAO;cAAvB,CACG,MAAM,SACL,oBAAC,eAAD;KAAO,YAAY;KAAiB,YAAY;eAC7C;KACK,CAAA,EAET,CAAC,MAAM,QAAQ,iBAAiB,MAAM,SACnC;;GACN,oBAAC,cAAD;IACE,WAAW,OAAO;IAClB,SAAS,MAAM,WAAW,WAAW,eAAe;IACpD,MAAM,cAAc,WAAW,KAAK,SAAS,QAAQ,SAAS;IACnD;IACX,OAAO,SAAS,aAAa,IAAI;IACjC,YAAY,SAAS,aAAa,IAAI;IACtC,CAAA;GACE;;;;;ACpIV,IAAA,qBAAe"}
1
+ {"version":3,"file":"index.js","names":[],"sources":["../../../src/components/PromoPanel/PromoPanel.tsx","../../../src/components/PromoPanel/index.ts"],"sourcesContent":["import React from 'react';\n\nimport classNames from 'classnames';\n\nimport type { PaletteNames } from '../../theme/palette';\nimport type { AnchorLinkTags, AnchorLinkTargets } from '../AnchorLink';\nimport type { TitleTags } from '../Title';\n\nimport { AnalyticsId, IconSize } from '../../constants';\nimport { Breakpoint, useBreakpoint } from '../../hooks/useBreakpoint';\nimport { usePseudoClasses } from '../../hooks/usePseudoClasses';\nimport { getColor } from '../../theme/currys/color';\nimport Icon from '../Icon';\nimport ArrowRight from '../Icons/ArrowRight';\nimport ArrowUpRight from '../Icons/ArrowUpRight';\nimport LazyIllustration from '../LazyIllustration';\nimport Title from '../Title';\n\nimport styles from './styles.module.scss';\n\nexport type PromoPanelColors = Extract<PaletteNames, 'neutral' | 'blueberry' | 'cherry'>;\n\nexport interface PromoPanelProps {\n /** Used as the link text if set. title or children must be set for the link to have accessible text. */\n title?: string;\n /** Used as the link text if title is not set. */\n children?: string;\n /** Illustration element */\n illustration?: 'Doctor' | 'HealthcarePersonnel';\n /** Changes the underlying element of the title. */\n titleHtmlMarkup?: TitleTags;\n /** Changes the background color. Default: white */\n color?: PromoPanelColors;\n /** Not used if linkComponent is set */\n href?: string;\n /** Anchor link target. If linkComponent is set, this prop is only used to display the right icon for external links. */\n target?: AnchorLinkTargets;\n /** HTML markup for anchor link. Not used if linkComponent is set. Default: a */\n linkHtmlMarkup?: AnchorLinkTags;\n /** Function that is called when clicked. Not used if linkComponent is set. */\n linkOnClick?: () => void;\n /** Custom link component. Must be \"a\" a or \"button\" element with no styling. */\n linkComponent?: React.ReactElement;\n /** Sets the data-testid attribute. */\n testId?: string;\n}\n\ninterface PromoPanelLinkProps {\n children?: string;\n href?: string;\n target?: AnchorLinkTargets;\n linkComponent?: React.ReactElement;\n linkHtmlMarkup?: AnchorLinkTags;\n linkOnClick?: () => void;\n}\n\nconst PromoPanelLink: React.FC<PromoPanelLinkProps> = props => {\n if (props.linkComponent) {\n return React.cloneElement(props.linkComponent, undefined, props.children);\n }\n\n if (props.linkHtmlMarkup === 'button') {\n return (\n <button type={'button'} onClick={props.linkOnClick}>\n {props.children}\n </button>\n );\n }\n return (\n <a href={props.href} target={props.target} onClick={props.linkOnClick}>\n {props.children}\n </a>\n );\n};\n\nconst PromoPanel: React.FC<PromoPanelProps> = props => {\n const { isHovered, refObject } = usePseudoClasses<HTMLDivElement>();\n\n const { color = 'neutral', titleHtmlMarkup = 'h2', linkHtmlMarkup = 'a' } = props;\n\n const breakpoint = useBreakpoint();\n\n const promoPanelClasses = classNames(\n styles.promopanel,\n styles[`promopanel--${color}`],\n !props.illustration && styles['promopanel--no-illustration']\n );\n\n const promoPanelLink = (\n <PromoPanelLink\n href={props.href}\n target={props.target}\n linkComponent={props.linkComponent}\n linkHtmlMarkup={linkHtmlMarkup}\n linkOnClick={props.linkOnClick}\n >\n {props.title || props.children}\n </PromoPanelLink>\n );\n\n const illustrationSize = ((): number => {\n if (breakpoint >= Breakpoint.md) {\n return 156;\n }\n\n return 110;\n })();\n\n return (\n <div className={promoPanelClasses} data-testid={props.testId} data-analyticsid={AnalyticsId.PromoPanel} ref={refObject}>\n {props.illustration && (\n <LazyIllustration\n illustrationName={props.illustration}\n size={illustrationSize}\n color={color}\n className={styles.promopanel__illustration}\n />\n )}\n <div className={styles.promopanel__content}>\n {props.title && (\n <Title htmlMarkup={titleHtmlMarkup} appearance={'title3'}>\n {promoPanelLink}\n </Title>\n )}\n {!props.title ? promoPanelLink : props.children}\n </div>\n <Icon\n className={styles.promopanel__icon}\n svgIcon={props.target === '_blank' ? ArrowUpRight : ArrowRight}\n size={breakpoint >= Breakpoint.md ? IconSize.Small : IconSize.XSmall}\n isHovered={isHovered}\n color={getColor('blueberry', 500)}\n hoverColor={getColor('blueberry', 600)}\n />\n </div>\n );\n};\n\nexport default PromoPanel;\n","import PromoPanel from './PromoPanel';\nexport * from './PromoPanel';\nexport default PromoPanel;\n"],"mappings":";;;;;;;;;;;;;;AAwDA,IAAM,kBAAgD,UAAS;CAC7D,IAAI,MAAM,eACR,OAAO,MAAM,aAAa,MAAM,eAAe,KAAA,GAAW,MAAM,QAAQ;CAG1E,IAAI,MAAM,mBAAmB,UAC3B,OACE,oBAAC,UAAD;EAAQ,MAAM;EAAU,SAAS,MAAM;YACpC,MAAM;CACD,CAAA;CAGZ,OACE,oBAAC,KAAD;EAAG,MAAM,MAAM;EAAM,QAAQ,MAAM;EAAQ,SAAS,MAAM;YACvD,MAAM;CACN,CAAA;AAEP;AAEA,IAAM,cAAwC,UAAS;CACrD,MAAM,EAAE,WAAW,cAAc,iBAAiC;CAElE,MAAM,EAAE,QAAQ,WAAW,kBAAkB,MAAM,iBAAiB,QAAQ;CAE5E,MAAM,aAAa,cAAc;CAEjC,MAAM,oBAAoB,WACxB,OAAO,YACP,OAAO,eAAe,UACtB,CAAC,MAAM,gBAAgB,OAAO,8BAChC;CAEA,MAAM,iBACJ,oBAAC,gBAAD;EACE,MAAM,MAAM;EACZ,QAAQ,MAAM;EACd,eAAe,MAAM;EACL;EAChB,aAAa,MAAM;YAElB,MAAM,SAAS,MAAM;CACR,CAAA;CAGlB,MAAM,0BAAkC;EACtC,IAAI,cAAc,WAAW,IAC3B,OAAO;EAGT,OAAO;CACT,GAAG;CAEH,OACE,qBAAC,OAAD;EAAK,WAAW;EAAmB,eAAa,MAAM;EAAQ,oBAAkB,YAAY;EAAY,KAAK;YAA7G;GACG,MAAM,gBACL,oBAAC,0BAAD;IACE,kBAAkB,MAAM;IACxB,MAAM;IACC;IACP,WAAW,OAAO;GACnB,CAAA;GAEH,qBAAC,OAAD;IAAK,WAAW,OAAO;cAAvB,CACG,MAAM,SACL,oBAAC,eAAD;KAAO,YAAY;KAAiB,YAAY;eAC7C;IACI,CAAA,GAER,CAAC,MAAM,QAAQ,iBAAiB,MAAM,QACpC;;GACL,oBAAC,cAAD;IACE,WAAW,OAAO;IAClB,SAAS,MAAM,WAAW,WAAW,eAAe;IACpD,MAAM,cAAc,WAAW,KAAK,SAAS,QAAQ,SAAS;IACnD;IACX,OAAO,SAAS,aAAa,GAAG;IAChC,YAAY,SAAS,aAAa,GAAG;GACtC,CAAA;EACE;;AAET;;;ACtIA,IAAA,qBAAe"}
@@ -0,0 +1,20 @@
1
+ import { FormOnColor, FormSize } from '../../../constants';
2
+ export interface RadioMarkerProps {
3
+ /** Whether the radio is checked. Controls the inner dot visibility. */
4
+ checked?: boolean;
5
+ /** Disables the visual state of the marker. */
6
+ disabled?: boolean;
7
+ /** Activates error styling. */
8
+ error?: boolean;
9
+ /** Background context the marker is rendered on. */
10
+ onColor?: keyof typeof FormOnColor;
11
+ /** Size variant of the marker. */
12
+ size?: keyof typeof FormSize;
13
+ /** Adds custom classes to the marker wrapper. */
14
+ className?: string;
15
+ }
16
+ /**
17
+ * Does not render an <input>; consumers render this on their end.
18
+ */
19
+ export declare const RadioMarker: React.FC<RadioMarkerProps>;
20
+ export default RadioMarker;
@@ -0,0 +1,288 @@
1
+ @use '../../../scss/spacers' as spacers;
2
+ @use '../../../scss/palette' as palette;
3
+ @use 'sass:meta';
4
+ @use 'sass:string';
5
+
6
+ @mixin dashed-border() {
7
+ box-shadow: none;
8
+ position: relative;
9
+
10
+ &::after {
11
+ position: absolute;
12
+ content: '';
13
+
14
+ $encoded-color: string.slice(meta.inspect(palette.$neutral600), 2);
15
+
16
+ // Variabler for å lettere styre dashen i background-imaget under
17
+ $stroke: 4;
18
+ $dash: 0.2;
19
+ $gap: 7;
20
+ $scale: 1;
21
+ $stroke-scaled: $stroke * $scale;
22
+ $dash-scaled: $dash * $scale;
23
+ $gap-scaled: $gap * $scale;
24
+
25
+ border-radius: 100px;
26
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25'%3E%3Crect width='100%25' height='100%25' fill='none' rx='100' ry='100' stroke='%23#{$encoded-color}' stroke-width='#{$stroke-scaled}' stroke-dasharray='#{$dash-scaled},#{$gap-scaled}' stroke-linecap='square'/%3E%3C/svg%3E");
27
+ background-repeat: no-repeat;
28
+ width: 28px;
29
+ height: 28px;
30
+ inset: -2px;
31
+ }
32
+ }
33
+
34
+ .radio {
35
+ &__marker {
36
+ display: flex;
37
+ justify-content: center;
38
+ align-items: center;
39
+ border-radius: 10rem;
40
+ height: 1.5rem;
41
+ width: 1.5rem;
42
+ min-height: 1.5rem;
43
+ min-width: 1.5rem;
44
+ color: palette.$neutral700;
45
+ box-shadow: 0 0 0 spacers.getSpacer(4xs);
46
+
47
+ // Vi overstyrer farger satt ved high-contrast mode i nettleser/os
48
+ @media (forced-colors: active) {
49
+ forced-color-adjust: none;
50
+ background-color: transparent !important;
51
+ color: #fff !important;
52
+ }
53
+
54
+ &--on-blueberry {
55
+ color: palette.$blueberry500;
56
+ }
57
+
58
+ &--on-dark {
59
+ color: palette.$neutral200;
60
+ }
61
+
62
+ &--invalid {
63
+ color: palette.$cherry600;
64
+ }
65
+
66
+ &__regular#{&}--checked,
67
+ label:has(input:checked) &__regular {
68
+ color: palette.$blueberry500;
69
+ }
70
+
71
+ &__regular#{&}--checked#{&}--invalid,
72
+ label:has(input:checked) &__regular#{&}--invalid {
73
+ color: palette.$cherry600;
74
+ }
75
+
76
+ &__regular#{&}--checked#{&}--on-dark,
77
+ label:has(input:checked) &__regular#{&}--on-dark {
78
+ color: palette.$blueberry200;
79
+ }
80
+
81
+ &__regular#{&}--checked#{&}--disabled,
82
+ label:has(input:checked) &__regular#{&}--disabled {
83
+ color: palette.$neutral600;
84
+ }
85
+
86
+ &__large {
87
+ // empty stub — checked-state rules live at the &__marker level below
88
+ }
89
+
90
+ // Large size — checked appearance.
91
+ &__large#{&}--checked,
92
+ label:has(input:checked) &__large {
93
+ color: palette.$blueberry100;
94
+ }
95
+
96
+ &__large#{&}--checked#{&}--invalid,
97
+ label:has(input:checked) &__large#{&}--invalid {
98
+ color: palette.$cherry500;
99
+ }
100
+
101
+ &__large#{&}--checked#{&}--disabled,
102
+ label:has(input:checked) &__large#{&}--disabled {
103
+ color: palette.$neutral600;
104
+ }
105
+
106
+ &--disabled,
107
+ &--disabled#{&}--invalid,
108
+ &--disabled#{&}--on-dark {
109
+ @include dashed-border;
110
+
111
+ background-color: transparent;
112
+ }
113
+
114
+ // Focus styles when an input inside the wrapping label is focus-visible
115
+ label:has(:focus-visible) &#{&} {
116
+ box-shadow: 0 0 0 spacers.getSpacer(3xs);
117
+ color: palette.$black;
118
+
119
+ &--on-dark {
120
+ color: palette.$white;
121
+ }
122
+ }
123
+
124
+ label:has(:focus-visible) &__regular#{&}--checked,
125
+ label:has(input:checked:focus-visible) &__regular {
126
+ color: palette.$black;
127
+ }
128
+
129
+ label:has(:focus-visible) &__regular#{&}--checked#{&}--on-dark,
130
+ label:has(input:checked:focus-visible) &__regular#{&}--on-dark {
131
+ color: palette.$white;
132
+ }
133
+
134
+ label:has(:focus-visible) &__large#{&}--checked,
135
+ label:has(input:checked:focus-visible) &__large {
136
+ color: palette.$white;
137
+ }
138
+
139
+ label:has(:focus-visible) &__large#{&}--checked#{&}--invalid,
140
+ label:has(input:checked:focus-visible) &__large#{&}--invalid {
141
+ color: palette.$black;
142
+ }
143
+
144
+ // Hover styles via wrapping label
145
+ label:hover &,
146
+ label:active & {
147
+ box-shadow: 0 0 0 spacers.getSpacer(3xs);
148
+ }
149
+
150
+ label:hover &--on-white,
151
+ label:hover &--on-grey {
152
+ background-color: palette.$neutral100;
153
+ }
154
+
155
+ label:active &--on-white,
156
+ label:active &--on-grey {
157
+ background-color: palette.$blueberry100;
158
+ }
159
+
160
+ label:hover &--on-blueberry {
161
+ background-color: palette.$blueberry100;
162
+ }
163
+
164
+ label:active &--on-blueberry {
165
+ background-color: palette.$blueberry200;
166
+ }
167
+
168
+ label:hover &--on-invalid {
169
+ background-color: palette.$cherry100;
170
+ }
171
+
172
+ label:active &--on-invalid {
173
+ background-color: palette.$cherry200;
174
+ }
175
+
176
+ label:hover &--on-dark {
177
+ background-color: palette.$inverted-hover-old;
178
+ }
179
+
180
+ label:hover &__regular#{&}--checked,
181
+ label:has(input:checked):hover &__regular {
182
+ background-color: palette.$blueberry50;
183
+ }
184
+
185
+ label:active &__regular#{&}--checked,
186
+ label:has(input:checked):active &__regular {
187
+ background-color: palette.$blueberry100;
188
+ }
189
+
190
+ label:hover &__regular#{&}--checked#{&}--invalid,
191
+ label:has(input:checked):hover &__regular#{&}--invalid {
192
+ background-color: palette.$cherry100;
193
+ }
194
+
195
+ label:active &__regular#{&}--checked#{&}--invalid,
196
+ label:has(input:checked):active &__regular#{&}--invalid {
197
+ background-color: palette.$cherry200;
198
+ }
199
+
200
+ label:hover &__regular#{&}--checked#{&}--on-dark,
201
+ label:has(input:checked):hover &__regular#{&}--on-dark {
202
+ background-color: palette.$inverted-hover-old;
203
+ }
204
+
205
+ label:hover &__large#{&}--checked,
206
+ label:has(input:checked):hover &__large {
207
+ background-color: unset;
208
+ }
209
+
210
+ label:hover &__large#{&}--checked#{&}--invalid,
211
+ label:has(input:checked):hover &__large#{&}--invalid {
212
+ background-color: transparent;
213
+ }
214
+
215
+ label:hover &--disabled,
216
+ label:hover &--disabled#{&}--invalid,
217
+ label:hover &--disabled#{&}--on-dark {
218
+ box-shadow: none;
219
+ background-color: transparent;
220
+ }
221
+ }
222
+
223
+ &__marker-dot {
224
+ display: none;
225
+ background-color: palette.$blueberry500;
226
+ width: 0.875rem;
227
+ height: 0.875rem;
228
+ border-radius: 10rem;
229
+
230
+ // Vi overstyrer farger satt ved high-contrast mode i nettleser/os
231
+ @media (forced-colors: active) {
232
+ forced-color-adjust: none;
233
+ background-color: #fff !important;
234
+ }
235
+ }
236
+
237
+ // Show the dot visually
238
+ &__marker#{&}__marker--checked &__marker-dot,
239
+ label:has(input:checked) &__marker &__marker-dot {
240
+ display: block;
241
+ }
242
+
243
+ // Dot color follows the marker state (so the focus ring can turn black
244
+ // without recoloring the dot).
245
+ &__marker--on-dark &__marker-dot {
246
+ background-color: palette.$blueberry200;
247
+ }
248
+
249
+ &__marker--invalid &__marker-dot {
250
+ background-color: palette.$cherry600;
251
+ }
252
+
253
+ &__marker--disabled &__marker-dot {
254
+ background-color: palette.$neutral600;
255
+ }
256
+
257
+ &__marker__large#{&}__marker--checked &__marker-dot,
258
+ label:has(input:checked) &__marker__large &__marker-dot {
259
+ background-color: palette.$blueberry100;
260
+ }
261
+
262
+ &__marker__large#{&}__marker--checked#{&}__marker--invalid &__marker-dot,
263
+ label:has(input:checked) &__marker__large#{&}__marker--invalid &__marker-dot {
264
+ background-color: palette.$cherry500;
265
+ }
266
+
267
+ label:active &__marker-dot {
268
+ background-color: palette.$blueberry800;
269
+ }
270
+
271
+ label:active &__marker--on-dark &__marker-dot {
272
+ background-color: palette.$blueberry300;
273
+ }
274
+
275
+ label:active &__marker--invalid &__marker-dot {
276
+ background-color: palette.$cherry800;
277
+ }
278
+
279
+ label:active &__marker__large#{&}__marker--checked &__marker-dot,
280
+ label:has(input:checked):active &__marker__large &__marker-dot {
281
+ background-color: palette.$blueberry200;
282
+ }
283
+
284
+ label:active &__marker__large#{&}__marker--checked#{&}__marker--invalid &__marker-dot,
285
+ label:has(input:checked):active &__marker__large#{&}__marker--invalid &__marker-dot {
286
+ background-color: palette.$cherry700;
287
+ }
288
+ }
@@ -0,0 +1,20 @@
1
+ export type Styles = {
2
+ radio__marker: string;
3
+ radio__marker__large: string;
4
+ radio__marker__regular: string;
5
+ 'radio__marker--checked': string;
6
+ 'radio__marker--disabled': string;
7
+ 'radio__marker--invalid': string;
8
+ 'radio__marker--on-blueberry': string;
9
+ 'radio__marker--on-dark': string;
10
+ 'radio__marker--on-grey': string;
11
+ 'radio__marker--on-invalid': string;
12
+ 'radio__marker--on-white': string;
13
+ 'radio__marker-dot': string;
14
+ };
15
+
16
+ export type ClassNames = keyof Styles;
17
+
18
+ declare const styles: Styles;
19
+
20
+ export default styles;
@@ -1,4 +1,3 @@
1
1
  import { default as RadioButton } from './RadioButton';
2
2
  export * from './RadioButton';
3
- export * from './utils';
4
3
  export default RadioButton;
@@ -1,7 +1,7 @@
1
- import { n as RadioButton, t as getRadioLabelClasses } from "../../utils3.js";
1
+ import { t as RadioButton } from "../../RadioButton.js";
2
2
  //#region src/components/RadioButton/index.ts
3
3
  var RadioButton_default = RadioButton;
4
4
  //#endregion
5
- export { RadioButton, RadioButton_default as default, getRadioLabelClasses };
5
+ export { RadioButton, RadioButton_default as default };
6
6
 
7
7
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":[],"sources":["../../../src/components/RadioButton/index.ts"],"sourcesContent":["import RadioButton from './RadioButton';\nexport * from './RadioButton';\nexport * from './utils';\nexport default RadioButton;\n"],"mappings":";;AAGA,IAAA,sBAAe"}
1
+ {"version":3,"file":"index.js","names":[],"sources":["../../../src/components/RadioButton/index.ts"],"sourcesContent":["import RadioButton from './RadioButton';\nexport * from './RadioButton';\nexport default RadioButton;\n"],"mappings":";;AAEA,IAAA,sBAAe"}