@helsenorge/designsystem-react 15.0.0-beta.1 → 15.1.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 (727) 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 +24 -19
  6. package/lib/Button.js.map +1 -1
  7. package/lib/CHANGELOG.md +46 -0
  8. package/lib/Checkbox.js +25 -48
  9. package/lib/Checkbox.js.map +1 -1
  10. package/lib/Checkbox2.js +69 -0
  11. package/lib/Checkbox2.js.map +1 -0
  12. package/lib/CheckboxMarker.js +64 -0
  13. package/lib/CheckboxMarker.js.map +1 -0
  14. package/lib/Chip.js.map +1 -1
  15. package/lib/Close.js.map +1 -1
  16. package/lib/DictionaryTrigger.js.map +1 -1
  17. package/lib/Drawer.js +46 -18
  18. package/lib/Drawer.js.map +1 -1
  19. package/lib/DrawerNavigation.js.map +1 -1
  20. package/lib/Duolist.js.map +1 -1
  21. package/lib/ElementHeader.js.map +1 -1
  22. package/lib/ElementHeaderText.js.map +1 -1
  23. package/lib/ErrorBoundary.js.map +1 -1
  24. package/lib/ErrorWrapper.js.map +1 -1
  25. package/lib/Expander.js.map +1 -1
  26. package/lib/FilterButton.js.map +1 -1
  27. package/lib/FilterButtonAndChipsWrapper.js.map +1 -1
  28. package/lib/FilterDrawer.js +20 -10
  29. package/lib/FilterDrawer.js.map +1 -1
  30. package/lib/FilterLinkList.js.map +1 -1
  31. package/lib/FilterOverviewLinkList.js.map +1 -1
  32. package/lib/FilterOverviewSearch.js.map +1 -1
  33. package/lib/FilterResultCountAndSortWrapper.js.map +1 -1
  34. package/lib/FilterSearch.js.map +1 -1
  35. package/lib/FilterSort.js.map +1 -1
  36. package/lib/FilterStateWrapper.js.map +1 -1
  37. package/lib/FormFieldTag.js.map +1 -1
  38. package/lib/FormGroup.js +5 -5
  39. package/lib/FormGroup.js.map +1 -1
  40. package/lib/FormLayout.js.map +1 -1
  41. package/lib/HelpDetails.js.map +1 -1
  42. package/lib/HelpTriggerIcon.js.map +1 -1
  43. package/lib/HelpTriggerStandalone.js.map +1 -1
  44. package/lib/HighlightPanel.js.map +1 -1
  45. package/lib/Highlighter.js.map +1 -1
  46. package/lib/HorizontalScroll.js.map +1 -1
  47. package/lib/Icon.js.map +1 -1
  48. package/lib/Illustration.js +1 -1
  49. package/lib/Illustration.js.map +1 -1
  50. package/lib/InfoTeaser.js.map +1 -1
  51. package/lib/Input.js.map +1 -1
  52. package/lib/LazyIcon.js +1 -1
  53. package/lib/LazyIcon.js.map +1 -1
  54. package/lib/LazyIllustration.js +6 -2
  55. package/lib/LazyIllustration.js.map +1 -1
  56. package/lib/LinkList.js.map +1 -1
  57. package/lib/List.js.map +1 -1
  58. package/lib/ListEditMode.js.map +1 -1
  59. package/lib/LoaderSpinner.js +61 -0
  60. package/lib/LoaderSpinner.js.map +1 -0
  61. package/lib/MaxCharacters.js.map +1 -1
  62. package/lib/NotificationBadge.js.map +1 -1
  63. package/lib/PanelTitle.js.map +1 -1
  64. package/lib/PopOver.js.map +1 -1
  65. package/lib/Radio.js +74 -0
  66. package/lib/Radio.js.map +1 -0
  67. package/lib/RadioButton.js +84 -0
  68. package/lib/RadioButton.js.map +1 -0
  69. package/lib/RadioMarker.js +35 -0
  70. package/lib/RadioMarker.js.map +1 -0
  71. package/lib/Select.js.map +1 -1
  72. package/lib/SingleSelectItem.js.map +1 -1
  73. package/lib/Slider.js.map +1 -1
  74. package/lib/Spacer.js.map +1 -1
  75. package/lib/StatusDot.js.map +1 -1
  76. package/lib/StatusDotList.js.map +1 -1
  77. package/lib/StepButtons.js.map +1 -1
  78. package/lib/TabList.js.map +1 -1
  79. package/lib/TabPanel.js.map +1 -1
  80. package/lib/TableBody.js +3 -3
  81. package/lib/TableBody.js.map +1 -1
  82. package/lib/TableCell.js +2 -2
  83. package/lib/TableCell.js.map +1 -1
  84. package/lib/TableExpandedRow.js +4 -4
  85. package/lib/TableExpandedRow.js.map +1 -1
  86. package/lib/TableExpanderCell.js +2 -2
  87. package/lib/TableExpanderCell.js.map +1 -1
  88. package/lib/TableHead.js +7 -7
  89. package/lib/TableHead.js.map +1 -1
  90. package/lib/TableHeadCell.js +5 -5
  91. package/lib/TableHeadCell.js.map +1 -1
  92. package/lib/TableRow.js +6 -6
  93. package/lib/TableRow.js.map +1 -1
  94. package/lib/Textarea.js.map +1 -1
  95. package/lib/Title.js.map +1 -1
  96. package/lib/Toast.js.map +1 -1
  97. package/lib/VisualCheckbox.js +79 -0
  98. package/lib/VisualCheckbox.js.map +1 -0
  99. package/lib/VisualRadio.js +64 -0
  100. package/lib/VisualRadio.js.map +1 -0
  101. package/lib/__mocks__/IntersectionObserver.js.map +1 -1
  102. package/lib/__mocks__/MutationObserver.js.map +1 -1
  103. package/lib/__mocks__/ResizeObserver.js.map +1 -1
  104. package/lib/__mocks__/matchMedia.js +3 -2
  105. package/lib/__mocks__/matchMedia.js.map +1 -1
  106. package/lib/__mocks__/useLayoutEvent.js.map +1 -1
  107. package/lib/__mocks__/useOutsideEvent.js.map +1 -1
  108. package/lib/__mocks__/usePseudoClasses.js.map +1 -1
  109. package/lib/__mocks__/useSize.js.map +1 -1
  110. package/lib/__mocks__/uuid.js.map +1 -1
  111. package/lib/components/ArticleTeaser/index.js.map +1 -1
  112. package/lib/components/Button/styles.module.scss +39 -16
  113. package/lib/components/Button/styles.module.scss.d.ts +3 -2
  114. package/lib/components/Checkbox/CheckboxMarker/CheckboxMarker.d.ts +20 -0
  115. package/lib/components/Checkbox/CheckboxMarker/styles.module.scss +309 -0
  116. package/lib/components/Checkbox/CheckboxMarker/styles.module.scss.d.ts +25 -0
  117. package/lib/components/Checkbox/styles.module.scss +9 -269
  118. package/lib/components/Checkbox/styles.module.scss.d.ts +1 -17
  119. package/lib/components/Drawer/DrawerBackButton.d.ts +10 -0
  120. package/lib/components/Drawer/DrawerBackButton.module.scss +52 -0
  121. package/lib/components/Drawer/DrawerBackButton.module.scss.d.ts +10 -0
  122. package/lib/components/Drawer/styles.module.scss +0 -9
  123. package/lib/components/Dropdown/index.js.map +1 -1
  124. package/lib/components/DropdownOld/index.js.map +1 -1
  125. package/lib/components/EmptyState/index.js.map +1 -1
  126. package/lib/components/Expander/styles.module.scss.d.ts +3 -2
  127. package/lib/components/ExpanderHierarchy/index.js.map +1 -1
  128. package/lib/components/ExpanderList/index.js.map +1 -1
  129. package/lib/components/EyebrowHeader/index.js.map +1 -1
  130. package/lib/components/FavoriteButton/index.js.map +1 -1
  131. package/lib/components/Filter/FilterDrawer/FilterDrawer.d.ts +4 -2
  132. package/lib/components/Filter/FilterDrawer/styles.module.scss +7 -0
  133. package/lib/components/Filter/FilterDrawer/styles.module.scss.d.ts +1 -0
  134. package/lib/components/Filter/LoaderSpinner/LoaderSpinner.d.ts +9 -0
  135. package/lib/components/Filter/LoaderSpinner/index.d.ts +3 -0
  136. package/lib/components/Filter/LoaderSpinner/index.js +7 -0
  137. package/lib/components/Filter/LoaderSpinner/index.js.map +1 -0
  138. package/lib/components/Filter/LoaderSpinner/styles.module.scss +27 -0
  139. package/lib/components/Filter/LoaderSpinner/styles.module.scss.d.ts +11 -0
  140. package/lib/components/Filter/index.d.ts +2 -0
  141. package/lib/components/Filter/index.js +2 -1
  142. package/lib/components/Filter/index.js.map +1 -1
  143. package/lib/components/HelpBubble/index.js.map +1 -1
  144. package/lib/components/HelpDrawer/index.js.map +1 -1
  145. package/lib/components/HelpExpanderInline/index.js.map +1 -1
  146. package/lib/components/HelpExpanderStandalone/index.js.map +1 -1
  147. package/lib/components/HelpPanel/index.js.map +1 -1
  148. package/lib/components/HelpTeaser/index.js.map +1 -1
  149. package/lib/components/HelpTooltip/index.js.map +1 -1
  150. package/lib/components/HelpTriggerInline/index.js.map +1 -1
  151. package/lib/components/Icons/ActiveMonitoring.js.map +1 -1
  152. package/lib/components/Icons/AcupunctureBack.js.map +1 -1
  153. package/lib/components/Icons/AdditionalIconInformation.js.map +1 -1
  154. package/lib/components/Icons/AlarmClock.js.map +1 -1
  155. package/lib/components/Icons/AlertSignFill.js.map +1 -1
  156. package/lib/components/Icons/AlertSignStroke.js.map +1 -1
  157. package/lib/components/Icons/Amputation.js.map +1 -1
  158. package/lib/components/Icons/Anxiety.js.map +1 -1
  159. package/lib/components/Icons/Apple.js.map +1 -1
  160. package/lib/components/Icons/Archive.js.map +1 -1
  161. package/lib/components/Icons/ArmFlexing.js.map +1 -1
  162. package/lib/components/Icons/ArrowDown.js.map +1 -1
  163. package/lib/components/Icons/ArrowLeft.js.map +1 -1
  164. package/lib/components/Icons/ArrowRight.js.map +1 -1
  165. package/lib/components/Icons/ArrowUp.js.map +1 -1
  166. package/lib/components/Icons/ArrowUpRight.js.map +1 -1
  167. package/lib/components/Icons/Attachment.js.map +1 -1
  168. package/lib/components/Icons/Atv.js.map +1 -1
  169. package/lib/components/Icons/Avatar.js.map +1 -1
  170. package/lib/components/Icons/AwakePersonOnPillow.js.map +1 -1
  171. package/lib/components/Icons/Baby.js.map +1 -1
  172. package/lib/components/Icons/BandAid.js.map +1 -1
  173. package/lib/components/Icons/BeerAndPills.js.map +1 -1
  174. package/lib/components/Icons/Bell.js.map +1 -1
  175. package/lib/components/Icons/Bike.js.map +1 -1
  176. package/lib/components/Icons/BirthControl.js.map +1 -1
  177. package/lib/components/Icons/BirthdayCake.js.map +1 -1
  178. package/lib/components/Icons/Boat.js.map +1 -1
  179. package/lib/components/Icons/Body.js.map +1 -1
  180. package/lib/components/Icons/Braille.js.map +1 -1
  181. package/lib/components/Icons/Brain.js.map +1 -1
  182. package/lib/components/Icons/BreastReconstruction.js.map +1 -1
  183. package/lib/components/Icons/BreastRemoval.js.map +1 -1
  184. package/lib/components/Icons/Breasts.js.map +1 -1
  185. package/lib/components/Icons/BrokenHeart.js.map +1 -1
  186. package/lib/components/Icons/BrokenPuzzle.js.map +1 -1
  187. package/lib/components/Icons/Bus.js.map +1 -1
  188. package/lib/components/Icons/Calendar.js.map +1 -1
  189. package/lib/components/Icons/CalendarChange.js.map +1 -1
  190. package/lib/components/Icons/CalendarCheck.js.map +1 -1
  191. package/lib/components/Icons/CalendarEvent.js.map +1 -1
  192. package/lib/components/Icons/CalendarSave.js.map +1 -1
  193. package/lib/components/Icons/Cancer.js.map +1 -1
  194. package/lib/components/Icons/Candle.js.map +1 -1
  195. package/lib/components/Icons/Car.js.map +1 -1
  196. package/lib/components/Icons/Carton.js.map +1 -1
  197. package/lib/components/Icons/Change.js.map +1 -1
  198. package/lib/components/Icons/Check.js.map +1 -1
  199. package/lib/components/Icons/CheckFill.js.map +1 -1
  200. package/lib/components/Icons/CheckOutline.js.map +1 -1
  201. package/lib/components/Icons/Chest.js.map +1 -1
  202. package/lib/components/Icons/ChevronDown.js.map +1 -1
  203. package/lib/components/Icons/ChevronLeft.js.map +1 -1
  204. package/lib/components/Icons/ChevronRight.js.map +1 -1
  205. package/lib/components/Icons/ChevronUp.js.map +1 -1
  206. package/lib/components/Icons/ChevronsDown.js.map +1 -1
  207. package/lib/components/Icons/ChevronsUp.js.map +1 -1
  208. package/lib/components/Icons/ChildPlaying.js.map +1 -1
  209. package/lib/components/Icons/Cigarette.js.map +1 -1
  210. package/lib/components/Icons/Coins.js.map +1 -1
  211. package/lib/components/Icons/Contacts.js.map +1 -1
  212. package/lib/components/Icons/Copy.js.map +1 -1
  213. package/lib/components/Icons/CoronaCertificate.js.map +1 -1
  214. package/lib/components/Icons/Coronavirus.js.map +1 -1
  215. package/lib/components/Icons/Cough.js.map +1 -1
  216. package/lib/components/Icons/CreditCard.js.map +1 -1
  217. package/lib/components/Icons/CriticalHealthInfo.js.map +1 -1
  218. package/lib/components/Icons/Cross.js.map +1 -1
  219. package/lib/components/Icons/DataExchange.js.map +1 -1
  220. package/lib/components/Icons/DataReceived.js.map +1 -1
  221. package/lib/components/Icons/DataSent.js.map +1 -1
  222. package/lib/components/Icons/Depression.js.map +1 -1
  223. package/lib/components/Icons/DigestiveSystem.js.map +1 -1
  224. package/lib/components/Icons/Dizzy.js.map +1 -1
  225. package/lib/components/Icons/Documents.js.map +1 -1
  226. package/lib/components/Icons/Dog.js.map +1 -1
  227. package/lib/components/Icons/DonorCard.js.map +1 -1
  228. package/lib/components/Icons/DotAttachment.js.map +1 -1
  229. package/lib/components/Icons/DotCheckmark.js.map +1 -1
  230. package/lib/components/Icons/DotCircleArrows.js.map +1 -1
  231. package/lib/components/Icons/DotDot.js.map +1 -1
  232. package/lib/components/Icons/DotExclamationMark.js.map +1 -1
  233. package/lib/components/Icons/DotFill.js.map +1 -1
  234. package/lib/components/Icons/DotGroup.js.map +1 -1
  235. package/lib/components/Icons/DotHalfDisc.js.map +1 -1
  236. package/lib/components/Icons/DotInfo.js.map +1 -1
  237. package/lib/components/Icons/DotLogin.js.map +1 -1
  238. package/lib/components/Icons/DotLookingGlass.js.map +1 -1
  239. package/lib/components/Icons/DotNoAccess.js.map +1 -1
  240. package/lib/components/Icons/DotNoEye.js.map +1 -1
  241. package/lib/components/Icons/DotOutline.js.map +1 -1
  242. package/lib/components/Icons/DotPencil.js.map +1 -1
  243. package/lib/components/Icons/DotQuestionMark.js.map +1 -1
  244. package/lib/components/Icons/DotTriangle.js.map +1 -1
  245. package/lib/components/Icons/DotX.js.map +1 -1
  246. package/lib/components/Icons/Download.js.map +1 -1
  247. package/lib/components/Icons/Draft.js.map +1 -1
  248. package/lib/components/Icons/Drag.js.map +1 -1
  249. package/lib/components/Icons/EChat.js.map +1 -1
  250. package/lib/components/Icons/Ear.js.map +1 -1
  251. package/lib/components/Icons/EarDeaf.js.map +1 -1
  252. package/lib/components/Icons/EarHearingAid.js.map +1 -1
  253. package/lib/components/Icons/EarNoseThroat.js.map +1 -1
  254. package/lib/components/Icons/EarVolume.js.map +1 -1
  255. package/lib/components/Icons/Edit.js.map +1 -1
  256. package/lib/components/Icons/ElderlyPerson.js.map +1 -1
  257. package/lib/components/Icons/Embolization.js.map +1 -1
  258. package/lib/components/Icons/EmergencyCall.js.map +1 -1
  259. package/lib/components/Icons/EmoticonAnnoyed.js.map +1 -1
  260. package/lib/components/Icons/EmoticonDelighted.js.map +1 -1
  261. package/lib/components/Icons/EmoticonDisappointed.js.map +1 -1
  262. package/lib/components/Icons/EmoticonHappy.js.map +1 -1
  263. package/lib/components/Icons/EmoticonMeh.js.map +1 -1
  264. package/lib/components/Icons/EmptyBox.js.map +1 -1
  265. package/lib/components/Icons/EnterFullScreen.js.map +1 -1
  266. package/lib/components/Icons/Envelope.js.map +1 -1
  267. package/lib/components/Icons/Epilepsy.js.map +1 -1
  268. package/lib/components/Icons/Eraser.js.map +1 -1
  269. package/lib/components/Icons/ErrorSignFill.js.map +1 -1
  270. package/lib/components/Icons/ErrorSignStroke.js.map +1 -1
  271. package/lib/components/Icons/EuropeanHealthCard.js.map +1 -1
  272. package/lib/components/Icons/ExitFullScreen.js.map +1 -1
  273. package/lib/components/Icons/Eye.js.map +1 -1
  274. package/lib/components/Icons/Facebook.js.map +1 -1
  275. package/lib/components/Icons/FallingLeaf.js.map +1 -1
  276. package/lib/components/Icons/Feedback.js.map +1 -1
  277. package/lib/components/Icons/Female.js.map +1 -1
  278. package/lib/components/Icons/FemaleDoctor.js.map +1 -1
  279. package/lib/components/Icons/Ferry.js.map +1 -1
  280. package/lib/components/Icons/File.js.map +1 -1
  281. package/lib/components/Icons/Filter.js +12 -12
  282. package/lib/components/Icons/Filter.js.map +1 -1
  283. package/lib/components/Icons/FingerBleed.js.map +1 -1
  284. package/lib/components/Icons/FirstAidKit.js.map +1 -1
  285. package/lib/components/Icons/Fish.js.map +1 -1
  286. package/lib/components/Icons/FloppyDisk.js.map +1 -1
  287. package/lib/components/Icons/Football.js.map +1 -1
  288. package/lib/components/Icons/Form.js.map +1 -1
  289. package/lib/components/Icons/Forward.js.map +1 -1
  290. package/lib/components/Icons/Gallery.js.map +1 -1
  291. package/lib/components/Icons/Garden.js.map +1 -1
  292. package/lib/components/Icons/GasCan.js.map +1 -1
  293. package/lib/components/Icons/GenderIdentity.js.map +1 -1
  294. package/lib/components/Icons/GlassWater.js.map +1 -1
  295. package/lib/components/Icons/Glasses.js.map +1 -1
  296. package/lib/components/Icons/Globe.js.map +1 -1
  297. package/lib/components/Icons/Grain.js.map +1 -1
  298. package/lib/components/Icons/Graph.js.map +1 -1
  299. package/lib/components/Icons/Group.js.map +1 -1
  300. package/lib/components/Icons/GroupTwins.js.map +1 -1
  301. package/lib/components/Icons/HTMLFile.js.map +1 -1
  302. package/lib/components/Icons/HandWaving.js.map +1 -1
  303. package/lib/components/Icons/HandWithDisease.js.map +1 -1
  304. package/lib/components/Icons/HandsAndHeart.js.map +1 -1
  305. package/lib/components/Icons/HealthClinic.js.map +1 -1
  306. package/lib/components/Icons/HealthMeasurements.js.map +1 -1
  307. package/lib/components/Icons/HealthWarning.js.map +1 -1
  308. package/lib/components/Icons/HealthcarePerson.js.map +1 -1
  309. package/lib/components/Icons/HealthcarePersonell.js.map +1 -1
  310. package/lib/components/Icons/HearingProtection.js.map +1 -1
  311. package/lib/components/Icons/Heart.js.map +1 -1
  312. package/lib/components/Icons/HeartHands.js.map +1 -1
  313. package/lib/components/Icons/HelpSign.js.map +1 -1
  314. package/lib/components/Icons/HelpingHand.js.map +1 -1
  315. package/lib/components/Icons/Hemodialysis.js.map +1 -1
  316. package/lib/components/Icons/Hiker.js.map +1 -1
  317. package/lib/components/Icons/Hipprosthesis.js.map +1 -1
  318. package/lib/components/Icons/History.js.map +1 -1
  319. package/lib/components/Icons/HivAndAids.js.map +1 -1
  320. package/lib/components/Icons/Home.js.map +1 -1
  321. package/lib/components/Icons/HomeFill.js.map +1 -1
  322. package/lib/components/Icons/Hormone.js.map +1 -1
  323. package/lib/components/Icons/Hospital.js.map +1 -1
  324. package/lib/components/Icons/Hourglass.js.map +1 -1
  325. package/lib/components/Icons/IconNames.js.map +1 -1
  326. package/lib/components/Icons/ImgFile.js.map +1 -1
  327. package/lib/components/Icons/Inbox.js.map +1 -1
  328. package/lib/components/Icons/InfoSignFill.js.map +1 -1
  329. package/lib/components/Icons/InfoSignStroke.js.map +1 -1
  330. package/lib/components/Icons/Instagram.js.map +1 -1
  331. package/lib/components/Icons/Intravenous.js.map +1 -1
  332. package/lib/components/Icons/JointPain.js.map +1 -1
  333. package/lib/components/Icons/Journal.js.map +1 -1
  334. package/lib/components/Icons/JpgFile.js.map +1 -1
  335. package/lib/components/Icons/Kidney.js.map +1 -1
  336. package/lib/components/Icons/KitchenScale.js.map +1 -1
  337. package/lib/components/Icons/Kjernejournal.js.map +1 -1
  338. package/lib/components/Icons/Laboratory.js.map +1 -1
  339. package/lib/components/Icons/LaptopBlog.js.map +1 -1
  340. package/lib/components/Icons/LawBook.js.map +1 -1
  341. package/lib/components/Icons/LegalDocument.js.map +1 -1
  342. package/lib/components/Icons/LightBulb.js.map +1 -1
  343. package/lib/components/Icons/List.js.map +1 -1
  344. package/lib/components/Icons/Location.js.map +1 -1
  345. package/lib/components/Icons/LocationFill.js.map +1 -1
  346. package/lib/components/Icons/Lock.js.map +1 -1
  347. package/lib/components/Icons/Login.js.map +1 -1
  348. package/lib/components/Icons/Logout.js.map +1 -1
  349. package/lib/components/Icons/Lungs.js.map +1 -1
  350. package/lib/components/Icons/Makeup.js.map +1 -1
  351. package/lib/components/Icons/MaleDoctor.js.map +1 -1
  352. package/lib/components/Icons/MaleDoctorAndPerson.js.map +1 -1
  353. package/lib/components/Icons/MaleDoctorCompact.js.map +1 -1
  354. package/lib/components/Icons/MaleDoctorCompactFill.js.map +1 -1
  355. package/lib/components/Icons/MaleGenitalia.js.map +1 -1
  356. package/lib/components/Icons/MeasuringTape.js.map +1 -1
  357. package/lib/components/Icons/Medicine.js.map +1 -1
  358. package/lib/components/Icons/MedicineWarning.js.map +1 -1
  359. package/lib/components/Icons/MentalHealthAdult.js.map +1 -1
  360. package/lib/components/Icons/MentalHealthChild.js.map +1 -1
  361. package/lib/components/Icons/Menu.js.map +1 -1
  362. package/lib/components/Icons/Microscope.js.map +1 -1
  363. package/lib/components/Icons/Minus.js.map +1 -1
  364. package/lib/components/Icons/Mirror.js.map +1 -1
  365. package/lib/components/Icons/MobilePhone.js.map +1 -1
  366. package/lib/components/Icons/MotherHoldingBaby.js.map +1 -1
  367. package/lib/components/Icons/MuscleBack.js.map +1 -1
  368. package/lib/components/Icons/MuscleLeg.js.map +1 -1
  369. package/lib/components/Icons/Mushroom.js.map +1 -1
  370. package/lib/components/Icons/Music.js.map +1 -1
  371. package/lib/components/Icons/MusselsAndSalt.js.map +1 -1
  372. package/lib/components/Icons/NoAccess.js.map +1 -1
  373. package/lib/components/Icons/NoEye.js.map +1 -1
  374. package/lib/components/Icons/NoFilter.js.map +1 -1
  375. package/lib/components/Icons/Notepad.js.map +1 -1
  376. package/lib/components/Icons/Osteotomy.js.map +1 -1
  377. package/lib/components/Icons/PaintRoller.js.map +1 -1
  378. package/lib/components/Icons/PaperPlane.js.map +1 -1
  379. package/lib/components/Icons/PatientAndPerson.js.map +1 -1
  380. package/lib/components/Icons/Pause.js.map +1 -1
  381. package/lib/components/Icons/PdfFile.js.map +1 -1
  382. package/lib/components/Icons/Pencil.js.map +1 -1
  383. package/lib/components/Icons/PeopleTalking.js.map +1 -1
  384. package/lib/components/Icons/Peritonealdialysis.js.map +1 -1
  385. package/lib/components/Icons/Person.js.map +1 -1
  386. package/lib/components/Icons/PersonAndPatient.js.map +1 -1
  387. package/lib/components/Icons/PersonCancel.js.map +1 -1
  388. package/lib/components/Icons/PersonInXRayMachine.js.map +1 -1
  389. package/lib/components/Icons/PersonOverweight.js.map +1 -1
  390. package/lib/components/Icons/PersonRelaxing.js.map +1 -1
  391. package/lib/components/Icons/PersonWithBrain.js.map +1 -1
  392. package/lib/components/Icons/PersonWithBrokenArm.js.map +1 -1
  393. package/lib/components/Icons/PersonWithCrutches.js.map +1 -1
  394. package/lib/components/Icons/PersonWithJaw.js.map +1 -1
  395. package/lib/components/Icons/PersonWithMagnifyingGlass.js.map +1 -1
  396. package/lib/components/Icons/PersonWithSenses.js.map +1 -1
  397. package/lib/components/Icons/PersonWorking.js.map +1 -1
  398. package/lib/components/Icons/PersonalPlan.js.map +1 -1
  399. package/lib/components/Icons/PizzaSlice.js.map +1 -1
  400. package/lib/components/Icons/Plane.js.map +1 -1
  401. package/lib/components/Icons/Plant.js.map +1 -1
  402. package/lib/components/Icons/PlateKnifeFork.js.map +1 -1
  403. package/lib/components/Icons/Play.js.map +1 -1
  404. package/lib/components/Icons/PlusLarge.js.map +1 -1
  405. package/lib/components/Icons/PlusSmall.js.map +1 -1
  406. package/lib/components/Icons/PngFile.js.map +1 -1
  407. package/lib/components/Icons/Podcast.js.map +1 -1
  408. package/lib/components/Icons/PoisonInformation.js.map +1 -1
  409. package/lib/components/Icons/Pregnant.js.map +1 -1
  410. package/lib/components/Icons/Printer.js.map +1 -1
  411. package/lib/components/Icons/Psychosis.js.map +1 -1
  412. package/lib/components/Icons/Publication.js.map +1 -1
  413. package/lib/components/Icons/Puzzle.js.map +1 -1
  414. package/lib/components/Icons/QrCode.js.map +1 -1
  415. package/lib/components/Icons/Quarrel.js.map +1 -1
  416. package/lib/components/Icons/RadioTherapy.js.map +1 -1
  417. package/lib/components/Icons/RadioactiveTreatment.js.map +1 -1
  418. package/lib/components/Icons/Radioiodine.js.map +1 -1
  419. package/lib/components/Icons/Receipt.js.map +1 -1
  420. package/lib/components/Icons/Receptionist.js.map +1 -1
  421. package/lib/components/Icons/Recovery.js.map +1 -1
  422. package/lib/components/Icons/Referral.js.map +1 -1
  423. package/lib/components/Icons/Refresh.js.map +1 -1
  424. package/lib/components/Icons/Refund.js.map +1 -1
  425. package/lib/components/Icons/Reminder.js.map +1 -1
  426. package/lib/components/Icons/Reply.js.map +1 -1
  427. package/lib/components/Icons/Rocket.js.map +1 -1
  428. package/lib/components/Icons/RtfFile.js.map +1 -1
  429. package/lib/components/Icons/STDs.js.map +1 -1
  430. package/lib/components/Icons/Save.js.map +1 -1
  431. package/lib/components/Icons/Scale.js.map +1 -1
  432. package/lib/components/Icons/ScreenReader.js.map +1 -1
  433. package/lib/components/Icons/Search.js +4 -4
  434. package/lib/components/Icons/Search.js.map +1 -1
  435. package/lib/components/Icons/SectionSign.js.map +1 -1
  436. package/lib/components/Icons/Settings.js.map +1 -1
  437. package/lib/components/Icons/SettingsFill.js.map +1 -1
  438. package/lib/components/Icons/Sexualorientation.js.map +1 -1
  439. package/lib/components/Icons/ShakingHand.js.map +1 -1
  440. package/lib/components/Icons/Share.js.map +1 -1
  441. package/lib/components/Icons/SharedHealthData.js.map +1 -1
  442. package/lib/components/Icons/SharedHealthMeasurements.js.map +1 -1
  443. package/lib/components/Icons/Shield.js.map +1 -1
  444. package/lib/components/Icons/ShuntOperation.js.map +1 -1
  445. package/lib/components/Icons/Skeleton.js.map +1 -1
  446. package/lib/components/Icons/Skin.js.map +1 -1
  447. package/lib/components/Icons/Snake.js.map +1 -1
  448. package/lib/components/Icons/Snapchat.js.map +1 -1
  449. package/lib/components/Icons/Sort.js +12 -12
  450. package/lib/components/Icons/Sort.js.map +1 -1
  451. package/lib/components/Icons/SortDown.js.map +1 -1
  452. package/lib/components/Icons/SortUp.js.map +1 -1
  453. package/lib/components/Icons/SpeechBubble.js.map +1 -1
  454. package/lib/components/Icons/Spray.js.map +1 -1
  455. package/lib/components/Icons/StarFill.js.map +1 -1
  456. package/lib/components/Icons/StarStroke.js.map +1 -1
  457. package/lib/components/Icons/StickyNote.js.map +1 -1
  458. package/lib/components/Icons/StickyNotes.js.map +1 -1
  459. package/lib/components/Icons/Stopwatch.js.map +1 -1
  460. package/lib/components/Icons/Sun.js.map +1 -1
  461. package/lib/components/Icons/SupportingPerson.js.map +1 -1
  462. package/lib/components/Icons/Surgery.js.map +1 -1
  463. package/lib/components/Icons/Sweets.js.map +1 -1
  464. package/lib/components/Icons/Syringe.js.map +1 -1
  465. package/lib/components/Icons/Taxi.js.map +1 -1
  466. package/lib/components/Icons/TeddyBear.js.map +1 -1
  467. package/lib/components/Icons/Teenagers.js.map +1 -1
  468. package/lib/components/Icons/ThinkingAboutBaby.js.map +1 -1
  469. package/lib/components/Icons/Ticket.js.map +1 -1
  470. package/lib/components/Icons/TimePassing.js.map +1 -1
  471. package/lib/components/Icons/Toddler.js.map +1 -1
  472. package/lib/components/Icons/Tombstone.js.map +1 -1
  473. package/lib/components/Icons/Toolbox.js.map +1 -1
  474. package/lib/components/Icons/Tooth.js.map +1 -1
  475. package/lib/components/Icons/TotalKneeProsthesis.js.map +1 -1
  476. package/lib/components/Icons/Train.js.map +1 -1
  477. package/lib/components/Icons/Transplantation.js.map +1 -1
  478. package/lib/components/Icons/TrashCan.js.map +1 -1
  479. package/lib/components/Icons/TravelRoute.js.map +1 -1
  480. package/lib/components/Icons/TreatmentAids.js.map +1 -1
  481. package/lib/components/Icons/TriangleX.js.map +1 -1
  482. package/lib/components/Icons/Twitter.js.map +1 -1
  483. package/lib/components/Icons/Undo.js.map +1 -1
  484. package/lib/components/Icons/UniProsthesis.js.map +1 -1
  485. package/lib/components/Icons/Upload.js.map +1 -1
  486. package/lib/components/Icons/UserOrganization.js.map +1 -1
  487. package/lib/components/Icons/Vaccine.js.map +1 -1
  488. package/lib/components/Icons/VerticalDots.js.map +1 -1
  489. package/lib/components/Icons/VideoCamera.js.map +1 -1
  490. package/lib/components/Icons/VideoChat.js.map +1 -1
  491. package/lib/components/Icons/Wallet.js.map +1 -1
  492. package/lib/components/Icons/Watch.js.map +1 -1
  493. package/lib/components/Icons/Website.js.map +1 -1
  494. package/lib/components/Icons/Wheelchair.js.map +1 -1
  495. package/lib/components/Icons/WheelchairActive.js.map +1 -1
  496. package/lib/components/Icons/Window.js.map +1 -1
  497. package/lib/components/Icons/WordDocument.js.map +1 -1
  498. package/lib/components/Icons/WorkSuitcase.js.map +1 -1
  499. package/lib/components/Icons/X.js.map +1 -1
  500. package/lib/components/Icons/XOutline.js.map +1 -1
  501. package/lib/components/Icons/XmlFile.js.map +1 -1
  502. package/lib/components/Icons/YouTube.js.map +1 -1
  503. package/lib/components/Icons/Zoom.js.map +1 -1
  504. package/lib/components/Icons/ZoomInLeft.js.map +1 -1
  505. package/lib/components/Icons/ZoomOutLeft.js.map +1 -1
  506. package/lib/components/Illustration/index.js +1 -1
  507. package/lib/components/Illustrations/BabyMobile.js +1 -1
  508. package/lib/components/Illustrations/BabyMobile.js.map +1 -1
  509. package/lib/components/Illustrations/BabyMobileMedium.js +1 -1
  510. package/lib/components/Illustrations/BabyMobileMedium.js.map +1 -1
  511. package/lib/components/Illustrations/Child.js +1 -1
  512. package/lib/components/Illustrations/Child.js.map +1 -1
  513. package/lib/components/Illustrations/ChildMedium.js +1 -1
  514. package/lib/components/Illustrations/ChildMedium.js.map +1 -1
  515. package/lib/components/Illustrations/Doctor.js +1 -1
  516. package/lib/components/Illustrations/Doctor.js.map +1 -1
  517. package/lib/components/Illustrations/DoctorMedium.js.map +1 -1
  518. package/lib/components/Illustrations/DoctorSmall.js.map +1 -1
  519. package/lib/components/Illustrations/EyeContact.d.ts +8 -0
  520. package/lib/components/Illustrations/EyeContact.js +17 -0
  521. package/lib/components/Illustrations/EyeContact.js.map +1 -0
  522. package/lib/components/Illustrations/EyeContactMedium.d.ts +3 -0
  523. package/lib/components/Illustrations/EyeContactMedium.js +80 -0
  524. package/lib/components/Illustrations/EyeContactMedium.js.map +1 -0
  525. package/lib/components/Illustrations/FacialRecognitionFingerprint.js +1 -1
  526. package/lib/components/Illustrations/FacialRecognitionFingerprint.js.map +1 -1
  527. package/lib/components/Illustrations/FacialRecognitionFingerprintMedium.js +1 -1
  528. package/lib/components/Illustrations/FacialRecognitionFingerprintMedium.js.map +1 -1
  529. package/lib/components/Illustrations/GiveBabyFood.js +1 -1
  530. package/lib/components/Illustrations/GiveBabyFood.js.map +1 -1
  531. package/lib/components/Illustrations/GiveBabyFoodMedium.js +1 -1
  532. package/lib/components/Illustrations/GiveBabyFoodMedium.js.map +1 -1
  533. package/lib/components/Illustrations/HealthcarePersonnel.js +1 -1
  534. package/lib/components/Illustrations/HealthcarePersonnel.js.map +1 -1
  535. package/lib/components/Illustrations/HealthcarePersonnelMedium.js.map +1 -1
  536. package/lib/components/Illustrations/HealthcarePersonnelSmall.js.map +1 -1
  537. package/lib/components/Illustrations/IllustrationNames.d.ts +1 -1
  538. package/lib/components/Illustrations/IllustrationNames.js +4 -0
  539. package/lib/components/Illustrations/IllustrationNames.js.map +1 -1
  540. package/lib/components/Illustrations/ReadLetters.js +1 -1
  541. package/lib/components/Illustrations/ReadLetters.js.map +1 -1
  542. package/lib/components/Illustrations/ReadLettersMedium.js +1 -1
  543. package/lib/components/Illustrations/ReadLettersMedium.js.map +1 -1
  544. package/lib/components/Illustrations/SkinToSkin.d.ts +8 -0
  545. package/lib/components/Illustrations/SkinToSkin.js +17 -0
  546. package/lib/components/Illustrations/SkinToSkin.js.map +1 -0
  547. package/lib/components/Illustrations/SkinToSkinMedium.d.ts +3 -0
  548. package/lib/components/Illustrations/SkinToSkinMedium.js +107 -0
  549. package/lib/components/Illustrations/SkinToSkinMedium.js.map +1 -0
  550. package/lib/components/Illustrations/Stork.js +1 -1
  551. package/lib/components/Illustrations/Stork.js.map +1 -1
  552. package/lib/components/Illustrations/StorkMedium.js +1 -1
  553. package/lib/components/Illustrations/StorkMedium.js.map +1 -1
  554. package/lib/components/Illustrations/Stroller.js +1 -1
  555. package/lib/components/Illustrations/Stroller.js.map +1 -1
  556. package/lib/components/Illustrations/StrollerMedium.js +1 -1
  557. package/lib/components/Illustrations/StrollerMedium.js.map +1 -1
  558. package/lib/components/Illustrations/Support2.js +1 -1
  559. package/lib/components/Illustrations/Support2.js.map +1 -1
  560. package/lib/components/Illustrations/Support2Medium.js +1 -1
  561. package/lib/components/Illustrations/Support2Medium.js.map +1 -1
  562. package/lib/components/Illustrations/Thinking.js +1 -1
  563. package/lib/components/Illustrations/Thinking.js.map +1 -1
  564. package/lib/components/Illustrations/ThinkingMedium.js +1 -1
  565. package/lib/components/Illustrations/ThinkingMedium.js.map +1 -1
  566. package/lib/components/Loader/index.js.map +1 -1
  567. package/lib/components/Logo/index.js.map +1 -1
  568. package/lib/components/Modal/index.js.map +1 -1
  569. package/lib/components/NotificationPanel/index.js.map +1 -1
  570. package/lib/components/Panel/index.js +1 -1
  571. package/lib/components/Panel/index.js.map +1 -1
  572. package/lib/components/Panel/styles.module.scss.d.ts +3 -2
  573. package/lib/components/PanelList/index.js +1 -1
  574. package/lib/components/PanelList/index.js.map +1 -1
  575. package/lib/components/PopMenu/index.js.map +1 -1
  576. package/lib/components/Portal/index.js.map +1 -1
  577. package/lib/components/Progressbar/index.js.map +1 -1
  578. package/lib/components/PromoPanel/index.js.map +1 -1
  579. package/lib/components/RadioButton/RadioMarker/RadioMarker.d.ts +20 -0
  580. package/lib/components/RadioButton/RadioMarker/styles.module.scss +288 -0
  581. package/lib/components/RadioButton/RadioMarker/styles.module.scss.d.ts +20 -0
  582. package/lib/components/RadioButton/index.d.ts +0 -1
  583. package/lib/components/RadioButton/index.js +2 -2
  584. package/lib/components/RadioButton/index.js.map +1 -1
  585. package/lib/components/RadioButton/styles.module.scss +13 -275
  586. package/lib/components/RadioButton/styles.module.scss.d.ts +2 -12
  587. package/lib/components/ServiceMessage/index.js.map +1 -1
  588. package/lib/components/SharingStatus/index.js.map +1 -1
  589. package/lib/components/Step/index.js.map +1 -1
  590. package/lib/components/Stepper/index.js +1 -5
  591. package/lib/components/Stepper/index.js.map +1 -1
  592. package/lib/components/StickyNote/index.js.map +1 -1
  593. package/lib/components/Table/index.js +3 -3
  594. package/lib/components/Table/index.js.map +1 -1
  595. package/lib/components/Tabs/index.js +5 -0
  596. package/lib/components/Tabs/index.js.map +1 -1
  597. package/lib/components/Tag/index.js.map +1 -1
  598. package/lib/components/TagList/index.js.map +1 -1
  599. package/lib/components/Tile/index.js.map +1 -1
  600. package/lib/components/ToastList/index.js.map +1 -1
  601. package/lib/components/Toggle/index.js.map +1 -1
  602. package/lib/components/Validation/index.js.map +1 -1
  603. package/lib/components/VisualCheckboxCloud/Checkbox/Checkbox.d.ts +21 -0
  604. package/lib/components/VisualCheckboxCloud/Checkbox/index.d.ts +3 -0
  605. package/lib/components/VisualCheckboxCloud/Checkbox/index.js +7 -0
  606. package/lib/components/VisualCheckboxCloud/Checkbox/index.js.map +1 -0
  607. package/lib/components/VisualCheckboxCloud/Checkbox/styles.module.scss +10 -0
  608. package/lib/components/VisualCheckboxCloud/Checkbox/styles.module.scss.d.ts +15 -0
  609. package/lib/components/VisualCheckboxCloud/VisualCheckboxCloud.d.ts +29 -0
  610. package/lib/components/VisualCheckboxCloud/index.d.ts +3 -0
  611. package/lib/components/VisualCheckboxCloud/index.js +42 -0
  612. package/lib/components/VisualCheckboxCloud/index.js.map +1 -0
  613. package/lib/components/VisualCheckboxCloud/styles.module.scss +6 -0
  614. package/lib/components/VisualCheckboxCloud/styles.module.scss.d.ts +9 -0
  615. package/lib/components/VisualCheckboxGroup/VisualCheckbox/VisualCheckbox.d.ts +26 -0
  616. package/lib/components/VisualCheckboxGroup/VisualCheckbox/VisualContent.d.ts +10 -0
  617. package/lib/components/VisualCheckboxGroup/VisualCheckbox/index.d.ts +3 -0
  618. package/lib/components/VisualCheckboxGroup/VisualCheckbox/index.js +7 -0
  619. package/lib/components/VisualCheckboxGroup/VisualCheckbox/index.js.map +1 -0
  620. package/lib/components/VisualCheckboxGroup/VisualCheckbox/styles.module.scss +7 -0
  621. package/lib/components/VisualCheckboxGroup/VisualCheckbox/styles.module.scss.d.ts +18 -0
  622. package/lib/components/VisualCheckboxGroup/VisualCheckboxGroup.d.ts +33 -0
  623. package/lib/components/VisualCheckboxGroup/index.d.ts +3 -0
  624. package/lib/components/VisualCheckboxGroup/index.js +47 -0
  625. package/lib/components/VisualCheckboxGroup/index.js.map +1 -0
  626. package/lib/components/VisualCheckboxGroup/styles.module.scss +6 -0
  627. package/lib/components/VisualCheckboxGroup/styles.module.scss.d.ts +10 -0
  628. package/lib/components/VisualRadioCloud/Radio/Radio.d.ts +23 -0
  629. package/lib/components/VisualRadioCloud/Radio/index.d.ts +3 -0
  630. package/lib/components/VisualRadioCloud/Radio/index.js +7 -0
  631. package/lib/components/VisualRadioCloud/Radio/index.js.map +1 -0
  632. package/lib/components/VisualRadioCloud/Radio/styles.module.scss +7 -0
  633. package/lib/components/VisualRadioCloud/Radio/styles.module.scss.d.ts +15 -0
  634. package/lib/components/VisualRadioCloud/VisualRadioCloud.d.ts +39 -0
  635. package/lib/components/VisualRadioCloud/index.d.ts +3 -0
  636. package/lib/components/VisualRadioCloud/index.js +62 -0
  637. package/lib/components/VisualRadioCloud/index.js.map +1 -0
  638. package/lib/components/VisualRadioCloud/styles.module.scss +6 -0
  639. package/lib/components/VisualRadioCloud/styles.module.scss.d.ts +9 -0
  640. package/lib/components/VisualRadioGroup/VisualRadio/VisualContent.d.ts +10 -0
  641. package/lib/components/VisualRadioGroup/VisualRadio/VisualRadio.d.ts +26 -0
  642. package/lib/components/VisualRadioGroup/VisualRadio/index.d.ts +3 -0
  643. package/lib/components/VisualRadioGroup/VisualRadio/index.js +7 -0
  644. package/lib/components/VisualRadioGroup/VisualRadio/index.js.map +1 -0
  645. package/lib/components/VisualRadioGroup/VisualRadio/styles.module.scss +7 -0
  646. package/lib/components/VisualRadioGroup/VisualRadio/styles.module.scss.d.ts +18 -0
  647. package/lib/components/VisualRadioGroup/VisualRadioGroup.d.ts +39 -0
  648. package/lib/components/VisualRadioGroup/index.d.ts +3 -0
  649. package/lib/components/VisualRadioGroup/index.js +67 -0
  650. package/lib/components/VisualRadioGroup/index.js.map +1 -0
  651. package/lib/components/VisualRadioGroup/styles.module.scss +6 -0
  652. package/lib/components/VisualRadioGroup/styles.module.scss.d.ts +10 -0
  653. package/lib/constants.js.map +1 -1
  654. package/lib/constants2.js +6 -6
  655. package/lib/constants2.js.map +1 -1
  656. package/lib/floating-ui.react.js +30 -30
  657. package/lib/floating-ui.react.js.map +1 -1
  658. package/lib/getFilterChips.js.map +1 -1
  659. package/lib/hoc/withBreakpoint/withBreakpoint.js.map +1 -1
  660. package/lib/hooks/useBreakpoint.js.map +1 -1
  661. package/lib/hooks/useElementList.js.map +1 -1
  662. package/lib/hooks/useEventListenerState.js.map +1 -1
  663. package/lib/hooks/useExpand.js.map +1 -1
  664. package/lib/hooks/useFocusToggle.js.map +1 -1
  665. package/lib/hooks/useFocusTrap.js.map +1 -1
  666. package/lib/hooks/useFocusableElements.js.map +1 -1
  667. package/lib/hooks/useIcons.js.map +1 -1
  668. package/lib/hooks/useIdWithFallback.js.map +1 -1
  669. package/lib/hooks/useIntersectionObserver.js.map +1 -1
  670. package/lib/hooks/useInterval.js.map +1 -1
  671. package/lib/hooks/useIsMobileBreakpoint.js.map +1 -1
  672. package/lib/hooks/useIsServerSide.js.map +1 -1
  673. package/lib/hooks/useIsVisible.js.map +1 -1
  674. package/lib/hooks/useKeyboardEvent.js.map +1 -1
  675. package/lib/hooks/useLanguage.js.map +1 -1
  676. package/lib/hooks/useLayoutEvent.js.map +1 -1
  677. package/lib/hooks/useOutsideEvent.js.map +1 -1
  678. package/lib/hooks/usePrevious.js.map +1 -1
  679. package/lib/hooks/usePseudoClasses.js.map +1 -1
  680. package/lib/hooks/useResizeObserver.js.map +1 -1
  681. package/lib/hooks/useReturnFocusOnUnmount.js.map +1 -1
  682. package/lib/hooks/useRovingFocus.js.map +1 -1
  683. package/lib/hooks/useSize.js.map +1 -1
  684. package/lib/hooks/useToggle.js.map +1 -1
  685. package/lib/hooks/usestopPropagation.js.map +1 -1
  686. package/lib/resourceHelper.js +42 -8
  687. package/lib/resourceHelper.js.map +1 -1
  688. package/lib/resources/HN.Designsystem.Drawer.se-NO.json.d.ts +7 -0
  689. package/lib/resources/HN.Designsystem.Filter.en-GB.json.d.ts +7 -4
  690. package/lib/resources/HN.Designsystem.Filter.nb-NO.json.d.ts +7 -4
  691. package/lib/resources/HN.Designsystem.Filter.nn-NO.json.d.ts +16 -0
  692. package/lib/resources/HN.Designsystem.Filter.se-NO.json.d.ts +16 -0
  693. package/lib/resources/HN.Designsystem.Tabs.se-NO.json.d.ts +7 -0
  694. package/lib/resources/Resources.d.ts +15 -3
  695. package/lib/scss/_visual-form.scss +357 -0
  696. package/lib/theme/currys/color.js.map +1 -1
  697. package/lib/theme/currys/spacing.js.map +1 -1
  698. package/lib/theme/grid.js.map +1 -1
  699. package/lib/theme/index.js.map +1 -1
  700. package/lib/theme/palette.js.map +1 -1
  701. package/lib/theme/spacers.js.map +1 -1
  702. package/lib/utils/accessibility.js.map +1 -1
  703. package/lib/utils/component.js.map +1 -1
  704. package/lib/utils/debounce.js.map +1 -1
  705. package/lib/utils/deepContains.js.map +1 -1
  706. package/lib/utils/device.js.map +1 -1
  707. package/lib/utils/focus.js.map +1 -1
  708. package/lib/utils/language.js.map +1 -1
  709. package/lib/utils/mobile.js.map +1 -1
  710. package/lib/utils/refs.js.map +1 -1
  711. package/lib/utils/resource.js.map +1 -1
  712. package/lib/utils/scroll.js.map +1 -1
  713. package/lib/utils/viewport.js.map +1 -1
  714. package/lib/utils.js.map +1 -1
  715. package/lib/utils2.js.map +1 -1
  716. package/lib/utils3.js +11 -100
  717. package/lib/utils3.js.map +1 -1
  718. package/lib/utils4.js +31 -12
  719. package/lib/utils4.js.map +1 -1
  720. package/lib/utils5.js +112 -31
  721. package/lib/utils5.js.map +1 -1
  722. package/lib/uuid.js.map +1 -1
  723. package/package.json +133 -3
  724. package/scss/_visual-form.scss +357 -0
  725. package/lib/components/RadioButton/utils.d.ts +0 -2
  726. package/lib/utils6.js +0 -115
  727. package/lib/utils6.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"ListEditMode.js","names":[],"sources":["../src/components/ListEditMode/ListEditMode.tsx","../src/components/ListEditMode/constants.ts","../src/components/ListEditMode/index.ts"],"sourcesContent":["import classNames from 'classnames';\n\nimport type { ExpanderListColors, ExpanderListVariant } from '../ExpanderList';\nimport type { SvgIcon } from '../Icon';\nimport type { LinkListColors, LinkListVariant } from '../LinkList';\n\nimport { IconSize } from '../../constants';\nimport { usePseudoClasses } from '../../hooks/usePseudoClasses';\nimport Icon from '../Icon';\nimport X from '../Icons/X';\n\nimport styles from './styles.module.scss';\n\nexport interface ListEditModeProps extends ListEditModeItemProps {\n /** Items in the ListEditMode */\n children: React.ReactNode;\n /** Sets visual priority */\n variant?: LinkListVariant | ExpanderListVariant;\n /** Sets color */\n color?: LinkListColors | ExpanderListColors;\n /** Aria label for delete button */\n deleteButtonAriaLabel?: string;\n}\n\nexport interface ListEditModeItemProps {\n /** Enables ListEditMode */\n editMode?: boolean;\n /** Callback for delete button */\n onDelete?: (e?: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n contentId?: string;\n}\n\nexport const IconButton = ({\n icon,\n color,\n onClick,\n ariaLabel,\n ariaDescribedby,\n}: {\n icon: SvgIcon;\n color: 'red' | 'blue';\n onClick?: (e?: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n ariaLabel?: string;\n ariaDescribedby?: string;\n}): React.JSX.Element => {\n const { refObject, isHovered } = usePseudoClasses<HTMLButtonElement>();\n\n return (\n <button\n ref={refObject}\n onClick={onClick}\n type=\"button\"\n className={classNames(styles['list-edit-mode__icon-button'])}\n aria-label={ariaLabel}\n aria-describedby={ariaDescribedby}\n >\n <Icon\n isHovered={isHovered}\n svgIcon={icon}\n size={IconSize.Small}\n color={color === 'blue' ? 'var(--color-action-graphics-onlight)' : 'var(--color-destructive-graphics-normal'}\n />\n </button>\n );\n};\n\nexport const ListEditModeItem = (props: ListEditModeProps): React.JSX.Element => {\n const { children, variant = 'line', color = 'neutral', onDelete, deleteButtonAriaLabel, contentId } = props;\n\n const listClassNames = classNames(styles['list-edit-mode__item'], color && styles[`list-edit-mode__item--${color}`], {\n [styles['list-edit-mode__item--line']]: variant === 'line',\n [styles['list-edit-mode__item--fill']]: variant === 'fill' || variant === 'fill-negative',\n });\n\n return (\n <li className={listClassNames}>\n {children}\n {onDelete && <IconButton icon={X} onClick={onDelete} color=\"red\" ariaLabel={deleteButtonAriaLabel} ariaDescribedby={contentId} />}\n </li>\n );\n};\n\nListEditModeItem.displayName = 'ListEditModeItem';\n\nexport default ListEditModeItem;\n","import classNames from 'classnames';\n\nimport styles from './styles.module.scss';\n\nexport const listEditModeWrapperClassnames = classNames([styles[`list-edit-mode`]]);\n","import ListEditModeItem from './ListEditMode';\nexport * from './ListEditMode';\nexport * from './constants';\nexport default ListEditModeItem;\n"],"mappings":";;;;;;;;AAgCA,IAAa,cAAc,EACzB,MACA,OACA,SACA,WACA,sBAOuB;CACvB,MAAM,EAAE,WAAW,cAAc,kBAAqC;CAEtE,OACE,oBAAC,UAAD;EACE,KAAK;EACI;EACT,MAAK;EACL,WAAW,WAAW,OAAO,+BAA+B;EAC5D,cAAY;EACZ,oBAAkB;YAElB,oBAAC,cAAD;GACa;GACX,SAAS;GACT,MAAM,SAAS;GACf,OAAO,UAAU,SAAS,yCAAyC;GACnE,CAAA;EACK,CAAA;;AAIb,IAAa,oBAAoB,UAAgD;CAC/E,MAAM,EAAE,UAAU,UAAU,QAAQ,QAAQ,WAAW,UAAU,uBAAuB,cAAc;CAOtG,OACE,qBAAC,MAAD;EAAI,WANiB,WAAW,OAAO,yBAAyB,SAAS,OAAO,yBAAyB,UAAU;IAClH,OAAO,gCAAgC,YAAY;IACnD,OAAO,gCAAgC,YAAY,UAAU,YAAY;GAC3E,CAGgB;YAAf,CACG,UACA,YAAY,oBAAC,YAAD;GAAY,MAAM;GAAG,SAAS;GAAU,OAAM;GAAM,WAAW;GAAuB,iBAAiB;GAAa,CAAA,CAC9H;;;AAIT,iBAAiB,cAAc;;;AC9E/B,IAAa,gCAAgC,WAAW,CAAC,OAAO,kBAAkB,CAAC;;;ACDnF,IAAA,uBAAe"}
1
+ {"version":3,"file":"ListEditMode.js","names":[],"sources":["../src/components/ListEditMode/ListEditMode.tsx","../src/components/ListEditMode/constants.ts","../src/components/ListEditMode/index.ts"],"sourcesContent":["import classNames from 'classnames';\n\nimport type { ExpanderListColors, ExpanderListVariant } from '../ExpanderList';\nimport type { SvgIcon } from '../Icon';\nimport type { LinkListColors, LinkListVariant } from '../LinkList';\n\nimport { IconSize } from '../../constants';\nimport { usePseudoClasses } from '../../hooks/usePseudoClasses';\nimport Icon from '../Icon';\nimport X from '../Icons/X';\n\nimport styles from './styles.module.scss';\n\nexport interface ListEditModeProps extends ListEditModeItemProps {\n /** Items in the ListEditMode */\n children: React.ReactNode;\n /** Sets visual priority */\n variant?: LinkListVariant | ExpanderListVariant;\n /** Sets color */\n color?: LinkListColors | ExpanderListColors;\n /** Aria label for delete button */\n deleteButtonAriaLabel?: string;\n}\n\nexport interface ListEditModeItemProps {\n /** Enables ListEditMode */\n editMode?: boolean;\n /** Callback for delete button */\n onDelete?: (e?: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n contentId?: string;\n}\n\nexport const IconButton = ({\n icon,\n color,\n onClick,\n ariaLabel,\n ariaDescribedby,\n}: {\n icon: SvgIcon;\n color: 'red' | 'blue';\n onClick?: (e?: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n ariaLabel?: string;\n ariaDescribedby?: string;\n}): React.JSX.Element => {\n const { refObject, isHovered } = usePseudoClasses<HTMLButtonElement>();\n\n return (\n <button\n ref={refObject}\n onClick={onClick}\n type=\"button\"\n className={classNames(styles['list-edit-mode__icon-button'])}\n aria-label={ariaLabel}\n aria-describedby={ariaDescribedby}\n >\n <Icon\n isHovered={isHovered}\n svgIcon={icon}\n size={IconSize.Small}\n color={color === 'blue' ? 'var(--color-action-graphics-onlight)' : 'var(--color-destructive-graphics-normal'}\n />\n </button>\n );\n};\n\nexport const ListEditModeItem = (props: ListEditModeProps): React.JSX.Element => {\n const { children, variant = 'line', color = 'neutral', onDelete, deleteButtonAriaLabel, contentId } = props;\n\n const listClassNames = classNames(styles['list-edit-mode__item'], color && styles[`list-edit-mode__item--${color}`], {\n [styles['list-edit-mode__item--line']]: variant === 'line',\n [styles['list-edit-mode__item--fill']]: variant === 'fill' || variant === 'fill-negative',\n });\n\n return (\n <li className={listClassNames}>\n {children}\n {onDelete && <IconButton icon={X} onClick={onDelete} color=\"red\" ariaLabel={deleteButtonAriaLabel} ariaDescribedby={contentId} />}\n </li>\n );\n};\n\nListEditModeItem.displayName = 'ListEditModeItem';\n\nexport default ListEditModeItem;\n","import classNames from 'classnames';\n\nimport styles from './styles.module.scss';\n\nexport const listEditModeWrapperClassnames = classNames([styles[`list-edit-mode`]]);\n","import ListEditModeItem from './ListEditMode';\nexport * from './ListEditMode';\nexport * from './constants';\nexport default ListEditModeItem;\n"],"mappings":";;;;;;;;AAgCA,IAAa,cAAc,EACzB,MACA,OACA,SACA,WACA,sBAOuB;CACvB,MAAM,EAAE,WAAW,cAAc,iBAAoC;CAErE,OACE,oBAAC,UAAD;EACE,KAAK;EACI;EACT,MAAK;EACL,WAAW,WAAW,OAAO,8BAA8B;EAC3D,cAAY;EACZ,oBAAkB;YAElB,oBAAC,cAAD;GACa;GACX,SAAS;GACT,MAAM,SAAS;GACf,OAAO,UAAU,SAAS,yCAAyC;EACpE,CAAA;CACK,CAAA;AAEZ;AAEA,IAAa,oBAAoB,UAAgD;CAC/E,MAAM,EAAE,UAAU,UAAU,QAAQ,QAAQ,WAAW,UAAU,uBAAuB,cAAc;CAOtG,OACE,qBAAC,MAAD;EAAI,WANiB,WAAW,OAAO,yBAAyB,SAAS,OAAO,yBAAyB,UAAU;IAClH,OAAO,gCAAgC,YAAY;IACnD,OAAO,gCAAgC,YAAY,UAAU,YAAY;EAC5E,CAGiB;YAAf,CACG,UACA,YAAY,oBAAC,YAAD;GAAY,MAAM;GAAG,SAAS;GAAU,OAAM;GAAM,WAAW;GAAuB,iBAAiB;EAAY,CAAA,CAC9H;;AAER;AAEA,iBAAiB,cAAc;;;AC9E/B,IAAa,gCAAgC,WAAW,CAAC,OAAO,iBAAiB,CAAC;;;ACDlF,IAAA,uBAAe"}
@@ -0,0 +1,61 @@
1
+ import { AnalyticsId, LanguageLocales } from "./constants.js";
2
+ import { useLanguage } from "./hooks/useLanguage.js";
3
+ import { useIsMobileBreakpoint } from "./hooks/useIsMobileBreakpoint.js";
4
+ import { t as getResources } from "./resourceHelper.js";
5
+ import { useEffect, useId } from "react";
6
+ import { jsx, jsxs } from "react/jsx-runtime";
7
+ import { useAnimate } from "motion/react";
8
+ import styles from "./components/Filter/LoaderSpinner/styles.module.scss";
9
+ //#region src/components/Filter/LoaderSpinner/LoaderSpinner.tsx
10
+ var LoaderSpinner = (props) => {
11
+ const { resources, testId } = props;
12
+ const textId = useId();
13
+ const isMobile = useIsMobileBreakpoint();
14
+ const svgSize = isMobile ? 14 : 19;
15
+ const { language } = useLanguage(LanguageLocales.NORWEGIAN);
16
+ const mergedResources = {
17
+ ...getResources(language),
18
+ ...resources
19
+ };
20
+ const [scope, animate] = useAnimate();
21
+ useEffect(() => {
22
+ if (!scope.current) return;
23
+ animate(scope.current, { rotate: 360 }, {
24
+ duration: 1.3,
25
+ ease: "linear",
26
+ repeat: Infinity
27
+ });
28
+ }, []);
29
+ return /* @__PURE__ */ jsxs("div", {
30
+ "data-testid": testId,
31
+ "data-analyticsid": AnalyticsId.Loader,
32
+ role: "progressbar",
33
+ "aria-labelledby": textId,
34
+ className: styles["loader-spinner"],
35
+ children: [/* @__PURE__ */ jsx("svg", {
36
+ ref: scope,
37
+ className: styles["loader-spinner__svg"],
38
+ width: svgSize,
39
+ height: svgSize,
40
+ fill: "none",
41
+ xmlns: "http://www.w3.org/2000/svg",
42
+ children: isMobile ? /* @__PURE__ */ jsx("path", {
43
+ d: "M1 7a6 6 0 1 1 6 6",
44
+ strokeWidth: "2",
45
+ strokeLinecap: "round"
46
+ }) : /* @__PURE__ */ jsx("path", {
47
+ d: "M1.5 9.5a8 8 0 1 1 8 8",
48
+ strokeWidth: "2.3",
49
+ strokeLinecap: "round"
50
+ })
51
+ }), /* @__PURE__ */ jsx("span", {
52
+ id: textId,
53
+ className: styles["loader-spinner__text"],
54
+ children: mergedResources.loadingText
55
+ })]
56
+ });
57
+ };
58
+ //#endregion
59
+ export { LoaderSpinner as t };
60
+
61
+ //# sourceMappingURL=LoaderSpinner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LoaderSpinner.js","names":[],"sources":["../src/components/Filter/LoaderSpinner/LoaderSpinner.tsx"],"sourcesContent":["import { useEffect, useId } from 'react';\n\nimport { useAnimate } from 'motion/react';\n\nimport type { HNDesignsystemFilter } from '../../../resources/Resources';\n\nimport { AnalyticsId, LanguageLocales } from '../../../constants';\nimport { useIsMobileBreakpoint } from '../../../hooks/useIsMobileBreakpoint';\nimport { useLanguage } from '../../../hooks/useLanguage';\nimport { getResources } from '../resourceHelper';\n\nimport styles from './styles.module.scss';\n\nexport interface LoaderSpinnerProps {\n /** Resources for the component */\n resources?: Partial<HNDesignsystemFilter>;\n /** Sets the data-testid attribute. */\n testId?: string;\n}\n\nconst LoaderSpinner: React.FC<LoaderSpinnerProps> = props => {\n const { resources, testId } = props;\n const textId = useId();\n const isMobile = useIsMobileBreakpoint();\n const svgSize = isMobile ? 14 : 19;\n const { language } = useLanguage<LanguageLocales>(LanguageLocales.NORWEGIAN);\n const defaultResources = getResources(language);\n const mergedResources = {\n ...defaultResources,\n ...resources,\n };\n const [scope, animate] = useAnimate();\n\n useEffect(() => {\n if (!scope.current) {\n return;\n }\n\n animate(scope.current, { rotate: 360 }, { duration: 1.3, ease: 'linear', repeat: Infinity });\n }, []);\n\n return (\n <div\n data-testid={testId}\n data-analyticsid={AnalyticsId.Loader}\n role=\"progressbar\"\n aria-labelledby={textId}\n className={styles['loader-spinner']}\n >\n <svg\n ref={scope}\n className={styles['loader-spinner__svg']}\n width={svgSize}\n height={svgSize}\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n {isMobile ? (\n <path d=\"M1 7a6 6 0 1 1 6 6\" strokeWidth=\"2\" strokeLinecap=\"round\" />\n ) : (\n <path d=\"M1.5 9.5a8 8 0 1 1 8 8\" strokeWidth=\"2.3\" strokeLinecap=\"round\" />\n )}\n </svg>\n <span id={textId} className={styles['loader-spinner__text']}>\n {mergedResources.loadingText}\n </span>\n </div>\n );\n};\n\nexport default LoaderSpinner;\n"],"mappings":";;;;;;;;;AAoBA,IAAM,iBAA8C,UAAS;CAC3D,MAAM,EAAE,WAAW,WAAW;CAC9B,MAAM,SAAS,MAAM;CACrB,MAAM,WAAW,sBAAsB;CACvC,MAAM,UAAU,WAAW,KAAK;CAChC,MAAM,EAAE,aAAa,YAA6B,gBAAgB,SAAS;CAE3E,MAAM,kBAAkB;EACtB,GAFuB,aAAa,QAEjC;EACH,GAAG;CACL;CACA,MAAM,CAAC,OAAO,WAAW,WAAW;CAEpC,gBAAgB;EACd,IAAI,CAAC,MAAM,SACT;EAGF,QAAQ,MAAM,SAAS,EAAE,QAAQ,IAAI,GAAG;GAAE,UAAU;GAAK,MAAM;GAAU,QAAQ;EAAS,CAAC;CAC7F,GAAG,CAAC,CAAC;CAEL,OACE,qBAAC,OAAD;EACE,eAAa;EACb,oBAAkB,YAAY;EAC9B,MAAK;EACL,mBAAiB;EACjB,WAAW,OAAO;YALpB,CAOE,oBAAC,OAAD;GACE,KAAK;GACL,WAAW,OAAO;GAClB,OAAO;GACP,QAAQ;GACR,MAAK;GACL,OAAM;aAEL,WACC,oBAAC,QAAD;IAAM,GAAE;IAAqB,aAAY;IAAI,eAAc;GAAS,CAAA,IAEpE,oBAAC,QAAD;IAAM,GAAE;IAAyB,aAAY;IAAM,eAAc;GAAS,CAAA;EAEzE,CAAA,GACL,oBAAC,QAAD;GAAM,IAAI;GAAQ,WAAW,OAAO;aACjC,gBAAgB;EACb,CAAA,CACH;;AAET"}
@@ -1 +1 @@
1
- {"version":3,"file":"MaxCharacters.js","names":[],"sources":["../src/components/MaxCharacters/MaxCharacters.tsx"],"sourcesContent":["import classNames from 'classnames';\n\nimport { FormOnColor } from '../../constants';\n\nimport styles from './styles.module.scss';\n\ninterface MaxCharactersProps {\n /** Current input length */\n length: number;\n /** max character limit in textarea */\n maxCharacters: number;\n /** The text is displayed in the end of the text-counter */\n maxText: string;\n /** Changes the visuals of the textarea */\n onColor?: keyof typeof FormOnColor;\n /** Max width of the component */\n maxWidth?: string;\n}\n\nconst MaxCharacters: React.FC<MaxCharactersProps> = ({ maxCharacters, maxText, length, onColor, maxWidth }) => {\n const progress = length / maxCharacters;\n\n const counterTextClass = classNames(styles['max-characters'], {\n [styles[`max-characters--on-dark`]]: onColor === FormOnColor.ondark,\n [styles[`max-characters--invalid`]]: progress > 1,\n });\n\n const ariaLevel = progress > 0.95 ? 'polite' : 'off';\n\n return (\n <div aria-live={ariaLevel} aria-atomic={'true'} className={counterTextClass} style={{ maxWidth }}>\n {`${length}/${maxCharacters} ${maxText}`}\n </div>\n );\n};\n\nexport default MaxCharacters;\n"],"mappings":";;;;;AAmBA,IAAM,iBAA+C,EAAE,eAAe,SAAS,QAAQ,SAAS,eAAe;CAC7G,MAAM,WAAW,SAAS;CAE1B,MAAM,mBAAmB,WAAW,OAAO,mBAAmB;GAC3D,OAAO,6BAA6B,YAAY,YAAY;GAC5D,OAAO,6BAA6B,WAAW;EACjD,CAAC;CAIF,OACE,oBAAC,OAAD;EAAK,aAHW,WAAW,MAAO,WAAW;EAGlB,eAAa;EAAQ,WAAW;EAAkB,OAAO,EAAE,UAAU;YAC7F,GAAG,OAAO,GAAG,cAAc,GAAG;EAC3B,CAAA"}
1
+ {"version":3,"file":"MaxCharacters.js","names":[],"sources":["../src/components/MaxCharacters/MaxCharacters.tsx"],"sourcesContent":["import classNames from 'classnames';\n\nimport { FormOnColor } from '../../constants';\n\nimport styles from './styles.module.scss';\n\ninterface MaxCharactersProps {\n /** Current input length */\n length: number;\n /** max character limit in textarea */\n maxCharacters: number;\n /** The text is displayed in the end of the text-counter */\n maxText: string;\n /** Changes the visuals of the textarea */\n onColor?: keyof typeof FormOnColor;\n /** Max width of the component */\n maxWidth?: string;\n}\n\nconst MaxCharacters: React.FC<MaxCharactersProps> = ({ maxCharacters, maxText, length, onColor, maxWidth }) => {\n const progress = length / maxCharacters;\n\n const counterTextClass = classNames(styles['max-characters'], {\n [styles[`max-characters--on-dark`]]: onColor === FormOnColor.ondark,\n [styles[`max-characters--invalid`]]: progress > 1,\n });\n\n const ariaLevel = progress > 0.95 ? 'polite' : 'off';\n\n return (\n <div aria-live={ariaLevel} aria-atomic={'true'} className={counterTextClass} style={{ maxWidth }}>\n {`${length}/${maxCharacters} ${maxText}`}\n </div>\n );\n};\n\nexport default MaxCharacters;\n"],"mappings":";;;;;AAmBA,IAAM,iBAA+C,EAAE,eAAe,SAAS,QAAQ,SAAS,eAAe;CAC7G,MAAM,WAAW,SAAS;CAE1B,MAAM,mBAAmB,WAAW,OAAO,mBAAmB;GAC3D,OAAO,6BAA6B,YAAY,YAAY;GAC5D,OAAO,6BAA6B,WAAW;CAClD,CAAC;CAID,OACE,oBAAC,OAAD;EAAK,aAHW,WAAW,MAAO,WAAW;EAGlB,eAAa;EAAQ,WAAW;EAAkB,OAAO,EAAE,SAAS;YAC5F,GAAG,OAAO,GAAG,cAAc,GAAG;CAC5B,CAAA;AAET"}
@@ -1 +1 @@
1
- {"version":3,"file":"NotificationBadge.js","names":[],"sources":["../src/components/Badge/NotificationBadge.tsx"],"sourcesContent":["import type { IconSize } from '../../constants';\n\nimport { palette } from '../../theme/palette';\nimport Icon from '../Icon';\nimport CheckFill from '../Icons/CheckFill';\nimport ErrorSignFill from '../Icons/ErrorSignFill';\nimport InfoSignFill from '../Icons/InfoSignFill';\nimport TriangleX from '../Icons/TriangleX';\n\nexport type BadgeNotificationVariant = 'info' | 'warn' | 'error' | 'success';\n\nexport interface NotificationBadgeProps {\n /** Changes the type of the badge */\n variant: BadgeNotificationVariant;\n /** Sets the size of the badge */\n size: IconSize;\n /** Adds custom classes to the element */\n className?: string;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** Sets hover state */\n isHovered?: boolean;\n}\n\nconst NotificationBadge = (props: NotificationBadgeProps): React.JSX.Element => {\n const { variant, size, className = '', testId, isHovered = false } = props;\n switch (variant) {\n case 'info':\n return (\n <Icon\n svgIcon={InfoSignFill}\n color={palette.blueberry700}\n hoverColor={palette.blueberry700}\n size={size}\n className={className}\n testId={testId}\n isHovered={isHovered}\n />\n );\n case 'warn':\n return (\n <Icon\n svgIcon={ErrorSignFill}\n color={palette.banana800}\n hoverColor={palette.banana700}\n size={size}\n className={className}\n testId={testId}\n isHovered={isHovered}\n />\n );\n case 'error':\n return (\n <Icon\n svgIcon={TriangleX}\n color={palette.cherry700}\n hoverColor={palette.cherry700}\n size={size}\n className={className}\n testId={testId}\n isHovered={isHovered}\n />\n );\n case 'success':\n return (\n <Icon\n svgIcon={CheckFill}\n color={palette.kiwi900}\n hoverColor={palette.kiwi900}\n size={size}\n className={className}\n testId={testId}\n isHovered={isHovered}\n />\n );\n }\n};\n\nexport default NotificationBadge;\n"],"mappings":";;;;;;;;AAwBA,IAAM,qBAAqB,UAAqD;CAC9E,MAAM,EAAE,SAAS,MAAM,YAAY,IAAI,QAAQ,YAAY,UAAU;CACrE,QAAQ,SAAR;EACE,KAAK,QACH,OACE,oBAAC,cAAD;GACE,SAAS;GACT,OAAO,QAAQ;GACf,YAAY,QAAQ;GACd;GACK;GACH;GACG;GACX,CAAA;EAEN,KAAK,QACH,OACE,oBAAC,cAAD;GACE,SAAS;GACT,OAAO,QAAQ;GACf,YAAY,QAAQ;GACd;GACK;GACH;GACG;GACX,CAAA;EAEN,KAAK,SACH,OACE,oBAAC,cAAD;GACE,SAAS;GACT,OAAO,QAAQ;GACf,YAAY,QAAQ;GACd;GACK;GACH;GACG;GACX,CAAA;EAEN,KAAK,WACH,OACE,oBAAC,cAAD;GACE,SAAS;GACT,OAAO,QAAQ;GACf,YAAY,QAAQ;GACd;GACK;GACH;GACG;GACX,CAAA"}
1
+ {"version":3,"file":"NotificationBadge.js","names":[],"sources":["../src/components/Badge/NotificationBadge.tsx"],"sourcesContent":["import type { IconSize } from '../../constants';\n\nimport { palette } from '../../theme/palette';\nimport Icon from '../Icon';\nimport CheckFill from '../Icons/CheckFill';\nimport ErrorSignFill from '../Icons/ErrorSignFill';\nimport InfoSignFill from '../Icons/InfoSignFill';\nimport TriangleX from '../Icons/TriangleX';\n\nexport type BadgeNotificationVariant = 'info' | 'warn' | 'error' | 'success';\n\nexport interface NotificationBadgeProps {\n /** Changes the type of the badge */\n variant: BadgeNotificationVariant;\n /** Sets the size of the badge */\n size: IconSize;\n /** Adds custom classes to the element */\n className?: string;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** Sets hover state */\n isHovered?: boolean;\n}\n\nconst NotificationBadge = (props: NotificationBadgeProps): React.JSX.Element => {\n const { variant, size, className = '', testId, isHovered = false } = props;\n switch (variant) {\n case 'info':\n return (\n <Icon\n svgIcon={InfoSignFill}\n color={palette.blueberry700}\n hoverColor={palette.blueberry700}\n size={size}\n className={className}\n testId={testId}\n isHovered={isHovered}\n />\n );\n case 'warn':\n return (\n <Icon\n svgIcon={ErrorSignFill}\n color={palette.banana800}\n hoverColor={palette.banana700}\n size={size}\n className={className}\n testId={testId}\n isHovered={isHovered}\n />\n );\n case 'error':\n return (\n <Icon\n svgIcon={TriangleX}\n color={palette.cherry700}\n hoverColor={palette.cherry700}\n size={size}\n className={className}\n testId={testId}\n isHovered={isHovered}\n />\n );\n case 'success':\n return (\n <Icon\n svgIcon={CheckFill}\n color={palette.kiwi900}\n hoverColor={palette.kiwi900}\n size={size}\n className={className}\n testId={testId}\n isHovered={isHovered}\n />\n );\n }\n};\n\nexport default NotificationBadge;\n"],"mappings":";;;;;;;;AAwBA,IAAM,qBAAqB,UAAqD;CAC9E,MAAM,EAAE,SAAS,MAAM,YAAY,IAAI,QAAQ,YAAY,UAAU;CACrE,QAAQ,SAAR;EACE,KAAK,QACH,OACE,oBAAC,cAAD;GACE,SAAS;GACT,OAAO,QAAQ;GACf,YAAY,QAAQ;GACd;GACK;GACH;GACG;EACZ,CAAA;EAEL,KAAK,QACH,OACE,oBAAC,cAAD;GACE,SAAS;GACT,OAAO,QAAQ;GACf,YAAY,QAAQ;GACd;GACK;GACH;GACG;EACZ,CAAA;EAEL,KAAK,SACH,OACE,oBAAC,cAAD;GACE,SAAS;GACT,OAAO,QAAQ;GACf,YAAY,QAAQ;GACd;GACK;GACH;GACG;EACZ,CAAA;EAEL,KAAK,WACH,OACE,oBAAC,cAAD;GACE,SAAS;GACT,OAAO,QAAQ;GACf,YAAY,QAAQ;GACd;GACK;GACH;GACG;EACZ,CAAA;CAEP;AACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"PanelTitle.js","names":[],"sources":["../src/components/Panel/PanelTitle/PanelTitle.tsx","../src/components/Panel/PanelTitle/index.ts"],"sourcesContent":["import classNames from 'classnames';\n\nimport Highlighter from '../../Highlighter';\nimport Title from '../../Title';\n\nimport styles from './styles.module.scss';\n\nexport interface PanelTitleProps {\n /** Badge displayed in title */\n badge?: React.ReactNode;\n /** Icon displayed in title. Only IconSize Small is supported */\n icon?: React.ReactNode;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** Title text */\n title: string | React.ReactNode;\n /** Title HTML markup */\n titleMarkup?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n /** Highlights text in title and content. Used for search results */\n highlightText?: string;\n}\n\nconst PanelTitle: React.FC<PanelTitleProps> = (props: PanelTitleProps) => {\n const { testId, icon, badge, title, titleMarkup = 'h3', highlightText } = props;\n return (\n <div className={classNames(styles['paneltitle'], { [styles['paneltitle--has-icon']]: icon })} data-testid={testId}>\n {icon && <div className={styles['paneltitle__icon']}>{icon}</div>}\n {title && (\n <div className={styles['paneltitle__title']}>\n <Title appearance=\"title3\" htmlMarkup={titleMarkup}>\n <Highlighter searchText={highlightText}>{title}</Highlighter>\n </Title>\n {badge && <div className={styles['paneltitle__badge']}>{badge}</div>}\n </div>\n )}\n </div>\n );\n};\n\nexport default PanelTitle;\n","import PanelTitle from './PanelTitle';\nexport * from './PanelTitle';\nexport default PanelTitle;\n"],"mappings":";;;;;;AAsBA,IAAM,cAAyC,UAA2B;CACxE,MAAM,EAAE,QAAQ,MAAM,OAAO,OAAO,cAAc,MAAM,kBAAkB;CAC1E,OACE,qBAAC,OAAD;EAAK,WAAW,WAAW,OAAO,eAAe,GAAG,OAAO,0BAA0B,MAAM,CAAC;EAAE,eAAa;YAA3G,CACG,QAAQ,oBAAC,OAAD;GAAK,WAAW,OAAO;aAAsB;GAAW,CAAA,EAChE,SACC,qBAAC,OAAD;GAAK,WAAW,OAAO;aAAvB,CACE,oBAAC,eAAD;IAAO,YAAW;IAAS,YAAY;cACrC,oBAAC,qBAAD;KAAa,YAAY;eAAgB;KAAoB,CAAA;IACvD,CAAA,EACP,SAAS,oBAAC,OAAD;IAAK,WAAW,OAAO;cAAuB;IAAY,CAAA,CAChE;KAEJ;;;;;ACjCV,IAAA,qBAAe"}
1
+ {"version":3,"file":"PanelTitle.js","names":[],"sources":["../src/components/Panel/PanelTitle/PanelTitle.tsx","../src/components/Panel/PanelTitle/index.ts"],"sourcesContent":["import classNames from 'classnames';\n\nimport Highlighter from '../../Highlighter';\nimport Title from '../../Title';\n\nimport styles from './styles.module.scss';\n\nexport interface PanelTitleProps {\n /** Badge displayed in title */\n badge?: React.ReactNode;\n /** Icon displayed in title. Only IconSize Small is supported */\n icon?: React.ReactNode;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** Title text */\n title: string | React.ReactNode;\n /** Title HTML markup */\n titleMarkup?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n /** Highlights text in title and content. Used for search results */\n highlightText?: string;\n}\n\nconst PanelTitle: React.FC<PanelTitleProps> = (props: PanelTitleProps) => {\n const { testId, icon, badge, title, titleMarkup = 'h3', highlightText } = props;\n return (\n <div className={classNames(styles['paneltitle'], { [styles['paneltitle--has-icon']]: icon })} data-testid={testId}>\n {icon && <div className={styles['paneltitle__icon']}>{icon}</div>}\n {title && (\n <div className={styles['paneltitle__title']}>\n <Title appearance=\"title3\" htmlMarkup={titleMarkup}>\n <Highlighter searchText={highlightText}>{title}</Highlighter>\n </Title>\n {badge && <div className={styles['paneltitle__badge']}>{badge}</div>}\n </div>\n )}\n </div>\n );\n};\n\nexport default PanelTitle;\n","import PanelTitle from './PanelTitle';\nexport * from './PanelTitle';\nexport default PanelTitle;\n"],"mappings":";;;;;;AAsBA,IAAM,cAAyC,UAA2B;CACxE,MAAM,EAAE,QAAQ,MAAM,OAAO,OAAO,cAAc,MAAM,kBAAkB;CAC1E,OACE,qBAAC,OAAD;EAAK,WAAW,WAAW,OAAO,eAAe,GAAG,OAAO,0BAA0B,KAAK,CAAC;EAAG,eAAa;YAA3G,CACG,QAAQ,oBAAC,OAAD;GAAK,WAAW,OAAO;aAAsB;EAAU,CAAA,GAC/D,SACC,qBAAC,OAAD;GAAK,WAAW,OAAO;aAAvB,CACE,oBAAC,eAAD;IAAO,YAAW;IAAS,YAAY;cACrC,oBAAC,qBAAD;KAAa,YAAY;eAAgB;IAAmB,CAAA;GACvD,CAAA,GACN,SAAS,oBAAC,OAAD;IAAK,WAAW,OAAO;cAAuB;GAAW,CAAA,CAChE;IAEJ;;AAET;;;ACnCA,IAAA,qBAAe"}
@@ -1 +1 @@
1
- {"version":3,"file":"PopOver.js","names":[],"sources":["../src/components/PopOver/utils.ts","../src/components/PopOver/PopOver.tsx","../src/components/PopOver/index.ts"],"sourcesContent":["import type { CSSProperties } from 'react';\n\nexport enum PopOverVariant {\n positionautomatic = 'positionautomatic',\n positionbelow = 'positionbelow',\n positionabove = 'positionabove',\n}\n\ntype HorizontalPosition = 'left' | 'right' | 'floating';\ntype BubblePosition = 'leftabove' | 'leftbelow' | 'rightabove' | 'rightbelow' | 'floatingabove' | 'floatingbelow';\n\n/** Bredde på hjelpeboble */\nconst BUBBLE_WIDTH_PX = 373;\n/** Hjelpeboblen skal holde avstand til venstre/høyre kant på vinduet */\nconst WINDOW_MARGIN_PX = 12;\n/** Vertikal avstand fra hjelpeboble til kontroller */\nconst BUBBLE_VERTICAL_OFFSET_PX = 16;\n/** Høyde/bredde på pil */\nconst ARROW_WIDTH_PX = 20;\n/** Avstand fra pil til hjelpeboble */\nconst ARROW_VERTICAL_OFFSET_PX = 4;\n/** Pilen skal holde avstand til venstre/høyre kant av hjelpeboblen */\nconst ARROW_HORIZONTAL_MARGIN_PX = 12;\n\n/**\n * Beregn om hjelpeboblen skal vises over eller under kontrolleren\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @param variant Ønsket plassering av hjelpeboblen (over/under/automatisk)\n * @returns Om hjelpeboblen skal vises over eller under\n */\nexport const getVerticalPosition = (\n controllerSize: DOMRect,\n bubbleSize: DOMRect,\n variant: keyof typeof PopOverVariant\n): keyof typeof PopOverVariant => {\n if (variant !== PopOverVariant.positionautomatic) {\n return variant;\n }\n if (controllerSize.top > bubbleSize.height + BUBBLE_VERTICAL_OFFSET_PX) {\n return PopOverVariant.positionabove;\n } else {\n return PopOverVariant.positionbelow;\n }\n};\n\n/**\n * Finn horisontalt midtpunkt på kontrolleren i forhold til venstre kant av vinduet\n * @param controllerSize DOMRect for controlleren\n * @returns Horisontalt senter av controlleren i px\n */\nconst getControllerLeftCenterPx = (controllerSize: DOMRect): number => controllerSize.left + controllerSize.width / 2;\n\n/**\n * Finn horisontalt midtpunkt på kontrolleren i forhold til høyre kant av vinduet\n * @param controllerSize DOMRect for controlleren\n * @returns Horisontalt senter av controlleren i px\n */\nconst getControllerRightCenterPx = (controllerSize: DOMRect): number =>\n document.documentElement.clientWidth - controllerSize.right + controllerSize.width / 2;\n\n/**\n * Finn venstre kant av hjelpeboblen i forhold til kontrolleren\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns Venstre kant av hjelpeboblen i px\n */\nconst getBubbleLeftPx = (controllerSize: DOMRect, bubbleSize: DOMRect): number => {\n const controllerHorizontalCenterPx = getControllerLeftCenterPx(controllerSize);\n\n return controllerHorizontalCenterPx - bubbleSize.width / 2;\n};\n\n/**\n * Finn høyre kant av hjelpeboblen i forhold til kontrolleren\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns Høyre kant av hjelpeboblen i px\n */\nconst getBubbleRightPx = (controllerSize: DOMRect, bubbleSize: DOMRect): number => {\n const bubbleLeftPx = getBubbleLeftPx(controllerSize, bubbleSize);\n\n return bubbleLeftPx + bubbleSize.width;\n};\n\n/**\n * Sjekk om venstre kant av hjelpeboblen er innenfor vinduet\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns true dersom venstre kant er innenfor vinduet\n */\nconst getBubbleLeftVisible = (controllerSize: DOMRect, bubbleSize: DOMRect): boolean => {\n const bubbleLeftPx = getBubbleLeftPx(controllerSize, bubbleSize);\n\n return bubbleLeftPx > WINDOW_MARGIN_PX;\n};\n\n/**\n * Sjekk om høyre kant av hjelpeboblen er innenfor vinduet\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns true dersom høyre kant er innenfor vinduet\n */\nconst getBubbleRightIsVisible = (controllerSize: DOMRect, bubbleSize: DOMRect): boolean => {\n const bubbleRightPx = getBubbleRightPx(controllerSize, bubbleSize);\n\n return bubbleRightPx < document.documentElement.clientWidth - WINDOW_MARGIN_PX;\n};\n\n/**\n * Finn riktig horisontal plassering til hjelpeboblen\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns left, right eller floating\n */\nconst getHorizontalPosition = (controllerSize: DOMRect, bubbleSize: DOMRect): HorizontalPosition => {\n if (!getBubbleRightIsVisible(controllerSize, bubbleSize)) {\n return 'right';\n }\n if (!getBubbleLeftVisible(controllerSize, bubbleSize)) {\n return 'left';\n }\n\n return 'floating';\n};\n\n/**\n * Finn vertikal plassering av hjelpeboblen når den skal vises over\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns \"Top\" for hjelpeboblen i px\n */\nconst getBubbleAbovePx = (controllerSize: DOMRect, bubbleSize: DOMRect): number =>\n controllerSize.top - BUBBLE_VERTICAL_OFFSET_PX - bubbleSize.height;\n\n/**\n * Finn vertikal plassering av hjelpeboblen når den skal vises under\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns \"Top\" for hjelpeboblen i px\n */\nconst getBubbleBelowPx = (controllerSize: DOMRect): number => controllerSize.bottom + BUBBLE_VERTICAL_OFFSET_PX;\n\n/**\n * Finn maks bredde på hjelpeboblen i forhold til vinduet\n * @returns Bredde på hjelpeboblen i px\n */\nconst getBubbleWidth = (): number => document.documentElement.clientWidth - WINDOW_MARGIN_PX * 2;\n\n/**\n * Sjekk om hjelpeboblen har plass i vinduet\n * @returns true dersom det er plass til hjelpeboblen i vinduet\n */\nconst getBubbleFitsInWindow = (): boolean => {\n return document.documentElement.clientWidth > BUBBLE_WIDTH_PX + WINDOW_MARGIN_PX * 2;\n};\n\n/**\n * Finn vertikal plassering av pilen når den skal vises over\n * @param controllerSize DOMRect for controlleren\n * @returns \"Top\" for pilen i px\n */\nconst getArrowTopxPx = (controllerSize: DOMRect): number => controllerSize.top - BUBBLE_VERTICAL_OFFSET_PX - ARROW_VERTICAL_OFFSET_PX;\n\n/**\n * Finn horisontal plassering av pilen i forhold til venstre kant av vinduet\n * @param controllerSize DOMRect for controlleren\n * @returns Venstre kant av pilen i px\n */\nconst getArrowLeftPx = (controllerSize: DOMRect): number => getControllerLeftCenterPx(controllerSize) - ARROW_WIDTH_PX / 2;\n\n/**\n * Finn horisontal plassering av pilen\n * @param controllerSize DOMRect for controlleren\n * @returns Venstre kant av pilen i px\n */\nconst getArrowRightPx = (controllerSize: DOMRect): number => getControllerRightCenterPx(controllerSize) - ARROW_WIDTH_PX / 2;\n\n/**\n * Finn riktig plassering av hjelpeboblen\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @param variant Ønsket plassering av hjelpeboblen (over/under)\n * @returns Beste mulige plassering av hjelpeboblen\n */\nconst getBubblePosition = (controllerSize: DOMRect, bubbleSize: DOMRect, variant: keyof typeof PopOverVariant): BubblePosition => {\n const horizontalPosition = getHorizontalPosition(controllerSize, bubbleSize);\n const verticalPosition = getVerticalPosition(controllerSize, bubbleSize, variant);\n\n if (horizontalPosition === 'left') {\n if (verticalPosition === PopOverVariant.positionabove) {\n return 'leftabove';\n }\n return 'leftbelow';\n }\n\n if (horizontalPosition === 'right') {\n if (verticalPosition === PopOverVariant.positionabove) {\n return 'rightabove';\n }\n return 'rightbelow';\n }\n\n if (verticalPosition === PopOverVariant.positionabove) {\n return 'floatingabove';\n }\n\n return 'floatingbelow';\n};\n\n/**\n * Finn riktig plassering av hjelpeboblen\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @param variant Ønsket plassering av hjelpeboblen (over/under)\n * @returns CSSProperties som plasserer hjelpeboblen riktig\n */\nexport const getBubbleStyle = (controllerSize: DOMRect, bubbleSize: DOMRect, variant: keyof typeof PopOverVariant): CSSProperties => {\n const bubblePosition = getBubblePosition(controllerSize, bubbleSize, variant);\n const bubbleWidth = !getBubbleFitsInWindow() ? getBubbleWidth() : undefined;\n\n if (bubblePosition === 'leftabove') {\n return {\n left: WINDOW_MARGIN_PX,\n top: getBubbleAbovePx(controllerSize, bubbleSize),\n width: bubbleWidth,\n };\n }\n if (bubblePosition === 'leftbelow') {\n return { left: WINDOW_MARGIN_PX, top: getBubbleBelowPx(controllerSize), width: bubbleWidth };\n }\n if (bubblePosition === 'rightabove') {\n return { right: WINDOW_MARGIN_PX, top: getBubbleAbovePx(controllerSize, bubbleSize), width: bubbleWidth };\n }\n if (bubblePosition === 'rightbelow') {\n return { right: WINDOW_MARGIN_PX, top: getBubbleBelowPx(controllerSize), width: bubbleWidth };\n }\n\n if (bubblePosition === 'floatingbelow') {\n return { left: getBubbleLeftPx(controllerSize, bubbleSize), top: getBubbleBelowPx(controllerSize), width: bubbleWidth };\n }\n\n return { left: getBubbleLeftPx(controllerSize, bubbleSize), top: getBubbleAbovePx(controllerSize, bubbleSize), width: bubbleWidth };\n};\n\n/**\n * Finn riktig plassering av pilen\n * @param bubbleStyle CSSProperties for hjelpeboblen\n * @param controllerSize DOMRect for kontrolleren\n * @param verticalPosition Ønsket plassering av hjelpeboblen (over/under)\n * @returns CSSProperties som plasserer pilen riktig\n */\nexport const getArrowStyle = (\n bubbleStyle: CSSProperties,\n controllerSize: DOMRect,\n verticalPosition: keyof typeof PopOverVariant\n): CSSProperties => {\n const leftPx = getArrowLeftPx(controllerSize);\n const rightPx = getArrowRightPx(controllerSize);\n const minLeftPx = (bubbleStyle.left as number) + ARROW_HORIZONTAL_MARGIN_PX;\n const minRightPx = (bubbleStyle.right as number) + ARROW_HORIZONTAL_MARGIN_PX;\n\n if (bubbleStyle.right) {\n if (verticalPosition === PopOverVariant.positionabove) {\n return {\n right: rightPx > minRightPx ? rightPx : minRightPx,\n top: getArrowTopxPx(controllerSize),\n };\n }\n\n return {\n right: rightPx > minRightPx ? rightPx : minRightPx,\n top: controllerSize.bottom,\n };\n }\n\n if (verticalPosition === PopOverVariant.positionabove) {\n return {\n left: leftPx > minLeftPx ? leftPx : minLeftPx,\n top: getArrowTopxPx(controllerSize),\n };\n }\n\n return {\n left: leftPx > minLeftPx ? leftPx : minLeftPx,\n top: controllerSize.bottom,\n };\n};\n","import { useRef } from 'react';\n\nimport {\n autoUpdate,\n flip,\n offset,\n shift,\n useClick,\n useDismiss,\n useFloating,\n useInteractions,\n FloatingArrow,\n arrow,\n hide,\n FloatingFocusManager,\n useMergeRefs,\n} from '@floating-ui/react';\nimport classNames from 'classnames';\n\nimport { PopOverVariant } from './utils';\nimport { AnalyticsId, ZIndex } from '../../constants';\nimport { getAriaLabelAttributes } from '../../utils/accessibility';\n\nimport styles from './styles.module.scss';\n\nexport type PopOverRole = 'tooltip' | 'dialog' | 'group';\n\nexport type PopOverPlacement = 'top' | 'bottom';\n\nexport interface PopOverProps {\n /** Sets aria-label of the bubble. If role is set to dialog ariaLabel or ariaLabelledById MUST be set! */\n ariaLabel?: string;\n /** Sets aria-labelledby of the bubble. If role is set to dialog ariaLabel or ariaLabelledById MUST be set! */\n ariaLabelledById?: string;\n /** Id of the PopOver */\n id?: string;\n /** Content shown inside PopOver. Note that if role=\"tooltip\", you must not include interactive/focusable elements. */\n children: React.ReactNode;\n /** Ref for the element the PopOver is placed upon */\n controllerRef: React.RefObject<HTMLElement | SVGSVGElement | null>;\n /** Show the popover. Only applies when role=tooltip. Default: false. */\n show?: boolean;\n /** Adds custom classes to the element. */\n className?: string;\n /** @deprecated Adds custom classes to the arrow element. */\n arrowClassName?: string;\n /** @deprecated use placement instead. Determines the placement of the popover. Default: automatic positioning. */\n variant?: keyof typeof PopOverVariant;\n /** Sets the placement of the popover relative to the trigger if there is space, otherwise automatic. */\n placement?: PopOverPlacement;\n /** Sets role of the PopOver element */\n role?: PopOverRole;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** Overrides the default z-index of PopOver */\n zIndex?: number;\n /** Ref that is passed to the component */\n ref?: React.Ref<HTMLDivElement | SVGSVGElement | HTMLElement | null>;\n}\n\nconst PopOver: React.FC<PopOverProps> = props => {\n const {\n ariaLabel,\n ariaLabelledById,\n id,\n children,\n controllerRef,\n show = false,\n className = '',\n variant = PopOverVariant.positionautomatic,\n role = 'dialog',\n testId,\n zIndex = ZIndex.PopOver,\n placement,\n ref,\n } = props;\n\n const ariaLabelAttributes = getAriaLabelAttributes({ label: ariaLabel, id: ariaLabelledById });\n\n const placementProp = placement ?? (variant === PopOverVariant.positionabove ? 'top' : 'bottom');\n\n const arrowRef = useRef(null);\n const { refs, floatingStyles, context, middlewareData } = useFloating({\n middleware: [offset(10), flip(), shift({ padding: 8 }), hide(), arrow({ element: arrowRef })],\n placement: placementProp,\n whileElementsMounted: autoUpdate,\n elements: {\n reference: controllerRef.current,\n },\n });\n\n const click = useClick(context);\n const dismiss = useDismiss(context);\n\n const { getFloatingProps } = useInteractions([click, dismiss]);\n\n const isVisible = show && !middlewareData.hide?.referenceHidden;\n\n const mergedRef = useMergeRefs<HTMLElement | SVGSVGElement>([refs.setFloating, ref]);\n\n return (\n <FloatingFocusManager context={context} modal={false}>\n <div\n id={id}\n ref={mergedRef}\n style={{ ...floatingStyles, visibility: isVisible ? 'visible' : 'hidden', zIndex: zIndex }}\n className={classNames(styles.popover, className)}\n {...getFloatingProps()}\n role={role}\n data-testid={testId}\n data-analyticsid={AnalyticsId.PopOver}\n {...ariaLabelAttributes}\n >\n {children}\n <FloatingArrow\n ref={arrowRef}\n className={styles['popover__arrow']}\n context={context}\n fill={'var(--core-color-white)'}\n stroke={'var(--color-base-border-onlight)'}\n strokeWidth={1}\n />\n </div>\n </FloatingFocusManager>\n );\n};\n\nPopOver.displayName = 'PopOver';\n\nexport default PopOver;\n","import PopOver from './PopOver';\nexport { PopOverVariant } from './utils';\nexport * from './PopOver';\nexport default PopOver;\n"],"mappings":";;;;;;;;AAEA,IAAY,iBAAL,yBAAA,gBAAA;CACL,eAAA,uBAAoB;CACpB,eAAA,mBAAgB;CAChB,eAAA,mBAAgB;;KACjB;;;ACsDD,IAAM,WAAkC,UAAS;CAC/C,MAAM,EACJ,WACA,kBACA,IACA,UACA,eACA,OAAO,OACP,YAAY,IACZ,UAAU,eAAe,mBACzB,OAAO,UACP,QACA,SAAS,OAAO,SAChB,WACA,QACE;CAEJ,MAAM,sBAAsB,uBAAuB;EAAE,OAAO;EAAW,IAAI;EAAkB,CAAC;CAE9F,MAAM,gBAAgB,cAAc,YAAY,eAAe,gBAAgB,QAAQ;CAEvF,MAAM,WAAW,OAAO,KAAK;CAC7B,MAAM,EAAE,MAAM,gBAAgB,SAAS,mBAAmB,YAAY;EACpE,YAAY;GAAC,OAAO,GAAG;GAAE,MAAM;GAAE,MAAM,EAAE,SAAS,GAAG,CAAC;GAAE,MAAM;GAAE,MAAM,EAAE,SAAS,UAAU,CAAC;GAAC;EAC7F,WAAW;EACX,sBAAsB;EACtB,UAAU,EACR,WAAW,cAAc,SAC1B;EACF,CAAC;CAKF,MAAM,EAAE,qBAAqB,gBAAgB,CAH/B,SAAS,QAGuB,EAF9B,WAAW,QAE0B,CAAQ,CAAC;CAE9D,MAAM,YAAY,QAAQ,CAAC,eAAe,MAAM;CAIhD,OACE,oBAAC,sBAAD;EAA+B;EAAS,OAAO;YAC7C,qBAAC,OAAD;GACM;GACJ,KANY,aAA0C,CAAC,KAAK,aAAa,IAAI,CAMxE;GACL,OAAO;IAAE,GAAG;IAAgB,YAAY,YAAY,YAAY;IAAkB;IAAQ;GAC1F,WAAW,WAAW,OAAO,SAAS,UAAU;GAChD,GAAI,kBAAkB;GAChB;GACN,eAAa;GACb,oBAAkB,YAAY;GAC9B,GAAI;aATN,CAWG,UACD,oBAAC,eAAD;IACE,KAAK;IACL,WAAW,OAAO;IACT;IACT,MAAM;IACN,QAAQ;IACR,aAAa;IACb,CAAA,CACE;;EACe,CAAA;;AAI3B,QAAQ,cAAc;;;AC5HtB,IAAA,kBAAe"}
1
+ {"version":3,"file":"PopOver.js","names":[],"sources":["../src/components/PopOver/utils.ts","../src/components/PopOver/PopOver.tsx","../src/components/PopOver/index.ts"],"sourcesContent":["import type { CSSProperties } from 'react';\n\nexport enum PopOverVariant {\n positionautomatic = 'positionautomatic',\n positionbelow = 'positionbelow',\n positionabove = 'positionabove',\n}\n\ntype HorizontalPosition = 'left' | 'right' | 'floating';\ntype BubblePosition = 'leftabove' | 'leftbelow' | 'rightabove' | 'rightbelow' | 'floatingabove' | 'floatingbelow';\n\n/** Bredde på hjelpeboble */\nconst BUBBLE_WIDTH_PX = 373;\n/** Hjelpeboblen skal holde avstand til venstre/høyre kant på vinduet */\nconst WINDOW_MARGIN_PX = 12;\n/** Vertikal avstand fra hjelpeboble til kontroller */\nconst BUBBLE_VERTICAL_OFFSET_PX = 16;\n/** Høyde/bredde på pil */\nconst ARROW_WIDTH_PX = 20;\n/** Avstand fra pil til hjelpeboble */\nconst ARROW_VERTICAL_OFFSET_PX = 4;\n/** Pilen skal holde avstand til venstre/høyre kant av hjelpeboblen */\nconst ARROW_HORIZONTAL_MARGIN_PX = 12;\n\n/**\n * Beregn om hjelpeboblen skal vises over eller under kontrolleren\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @param variant Ønsket plassering av hjelpeboblen (over/under/automatisk)\n * @returns Om hjelpeboblen skal vises over eller under\n */\nexport const getVerticalPosition = (\n controllerSize: DOMRect,\n bubbleSize: DOMRect,\n variant: keyof typeof PopOverVariant\n): keyof typeof PopOverVariant => {\n if (variant !== PopOverVariant.positionautomatic) {\n return variant;\n }\n if (controllerSize.top > bubbleSize.height + BUBBLE_VERTICAL_OFFSET_PX) {\n return PopOverVariant.positionabove;\n } else {\n return PopOverVariant.positionbelow;\n }\n};\n\n/**\n * Finn horisontalt midtpunkt på kontrolleren i forhold til venstre kant av vinduet\n * @param controllerSize DOMRect for controlleren\n * @returns Horisontalt senter av controlleren i px\n */\nconst getControllerLeftCenterPx = (controllerSize: DOMRect): number => controllerSize.left + controllerSize.width / 2;\n\n/**\n * Finn horisontalt midtpunkt på kontrolleren i forhold til høyre kant av vinduet\n * @param controllerSize DOMRect for controlleren\n * @returns Horisontalt senter av controlleren i px\n */\nconst getControllerRightCenterPx = (controllerSize: DOMRect): number =>\n document.documentElement.clientWidth - controllerSize.right + controllerSize.width / 2;\n\n/**\n * Finn venstre kant av hjelpeboblen i forhold til kontrolleren\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns Venstre kant av hjelpeboblen i px\n */\nconst getBubbleLeftPx = (controllerSize: DOMRect, bubbleSize: DOMRect): number => {\n const controllerHorizontalCenterPx = getControllerLeftCenterPx(controllerSize);\n\n return controllerHorizontalCenterPx - bubbleSize.width / 2;\n};\n\n/**\n * Finn høyre kant av hjelpeboblen i forhold til kontrolleren\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns Høyre kant av hjelpeboblen i px\n */\nconst getBubbleRightPx = (controllerSize: DOMRect, bubbleSize: DOMRect): number => {\n const bubbleLeftPx = getBubbleLeftPx(controllerSize, bubbleSize);\n\n return bubbleLeftPx + bubbleSize.width;\n};\n\n/**\n * Sjekk om venstre kant av hjelpeboblen er innenfor vinduet\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns true dersom venstre kant er innenfor vinduet\n */\nconst getBubbleLeftVisible = (controllerSize: DOMRect, bubbleSize: DOMRect): boolean => {\n const bubbleLeftPx = getBubbleLeftPx(controllerSize, bubbleSize);\n\n return bubbleLeftPx > WINDOW_MARGIN_PX;\n};\n\n/**\n * Sjekk om høyre kant av hjelpeboblen er innenfor vinduet\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns true dersom høyre kant er innenfor vinduet\n */\nconst getBubbleRightIsVisible = (controllerSize: DOMRect, bubbleSize: DOMRect): boolean => {\n const bubbleRightPx = getBubbleRightPx(controllerSize, bubbleSize);\n\n return bubbleRightPx < document.documentElement.clientWidth - WINDOW_MARGIN_PX;\n};\n\n/**\n * Finn riktig horisontal plassering til hjelpeboblen\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns left, right eller floating\n */\nconst getHorizontalPosition = (controllerSize: DOMRect, bubbleSize: DOMRect): HorizontalPosition => {\n if (!getBubbleRightIsVisible(controllerSize, bubbleSize)) {\n return 'right';\n }\n if (!getBubbleLeftVisible(controllerSize, bubbleSize)) {\n return 'left';\n }\n\n return 'floating';\n};\n\n/**\n * Finn vertikal plassering av hjelpeboblen når den skal vises over\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns \"Top\" for hjelpeboblen i px\n */\nconst getBubbleAbovePx = (controllerSize: DOMRect, bubbleSize: DOMRect): number =>\n controllerSize.top - BUBBLE_VERTICAL_OFFSET_PX - bubbleSize.height;\n\n/**\n * Finn vertikal plassering av hjelpeboblen når den skal vises under\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @returns \"Top\" for hjelpeboblen i px\n */\nconst getBubbleBelowPx = (controllerSize: DOMRect): number => controllerSize.bottom + BUBBLE_VERTICAL_OFFSET_PX;\n\n/**\n * Finn maks bredde på hjelpeboblen i forhold til vinduet\n * @returns Bredde på hjelpeboblen i px\n */\nconst getBubbleWidth = (): number => document.documentElement.clientWidth - WINDOW_MARGIN_PX * 2;\n\n/**\n * Sjekk om hjelpeboblen har plass i vinduet\n * @returns true dersom det er plass til hjelpeboblen i vinduet\n */\nconst getBubbleFitsInWindow = (): boolean => {\n return document.documentElement.clientWidth > BUBBLE_WIDTH_PX + WINDOW_MARGIN_PX * 2;\n};\n\n/**\n * Finn vertikal plassering av pilen når den skal vises over\n * @param controllerSize DOMRect for controlleren\n * @returns \"Top\" for pilen i px\n */\nconst getArrowTopxPx = (controllerSize: DOMRect): number => controllerSize.top - BUBBLE_VERTICAL_OFFSET_PX - ARROW_VERTICAL_OFFSET_PX;\n\n/**\n * Finn horisontal plassering av pilen i forhold til venstre kant av vinduet\n * @param controllerSize DOMRect for controlleren\n * @returns Venstre kant av pilen i px\n */\nconst getArrowLeftPx = (controllerSize: DOMRect): number => getControllerLeftCenterPx(controllerSize) - ARROW_WIDTH_PX / 2;\n\n/**\n * Finn horisontal plassering av pilen\n * @param controllerSize DOMRect for controlleren\n * @returns Venstre kant av pilen i px\n */\nconst getArrowRightPx = (controllerSize: DOMRect): number => getControllerRightCenterPx(controllerSize) - ARROW_WIDTH_PX / 2;\n\n/**\n * Finn riktig plassering av hjelpeboblen\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @param variant Ønsket plassering av hjelpeboblen (over/under)\n * @returns Beste mulige plassering av hjelpeboblen\n */\nconst getBubblePosition = (controllerSize: DOMRect, bubbleSize: DOMRect, variant: keyof typeof PopOverVariant): BubblePosition => {\n const horizontalPosition = getHorizontalPosition(controllerSize, bubbleSize);\n const verticalPosition = getVerticalPosition(controllerSize, bubbleSize, variant);\n\n if (horizontalPosition === 'left') {\n if (verticalPosition === PopOverVariant.positionabove) {\n return 'leftabove';\n }\n return 'leftbelow';\n }\n\n if (horizontalPosition === 'right') {\n if (verticalPosition === PopOverVariant.positionabove) {\n return 'rightabove';\n }\n return 'rightbelow';\n }\n\n if (verticalPosition === PopOverVariant.positionabove) {\n return 'floatingabove';\n }\n\n return 'floatingbelow';\n};\n\n/**\n * Finn riktig plassering av hjelpeboblen\n * @param controllerSize DOMRect for controlleren\n * @param bubbleSize DOMRect for hjelpeboblen\n * @param variant Ønsket plassering av hjelpeboblen (over/under)\n * @returns CSSProperties som plasserer hjelpeboblen riktig\n */\nexport const getBubbleStyle = (controllerSize: DOMRect, bubbleSize: DOMRect, variant: keyof typeof PopOverVariant): CSSProperties => {\n const bubblePosition = getBubblePosition(controllerSize, bubbleSize, variant);\n const bubbleWidth = !getBubbleFitsInWindow() ? getBubbleWidth() : undefined;\n\n if (bubblePosition === 'leftabove') {\n return {\n left: WINDOW_MARGIN_PX,\n top: getBubbleAbovePx(controllerSize, bubbleSize),\n width: bubbleWidth,\n };\n }\n if (bubblePosition === 'leftbelow') {\n return { left: WINDOW_MARGIN_PX, top: getBubbleBelowPx(controllerSize), width: bubbleWidth };\n }\n if (bubblePosition === 'rightabove') {\n return { right: WINDOW_MARGIN_PX, top: getBubbleAbovePx(controllerSize, bubbleSize), width: bubbleWidth };\n }\n if (bubblePosition === 'rightbelow') {\n return { right: WINDOW_MARGIN_PX, top: getBubbleBelowPx(controllerSize), width: bubbleWidth };\n }\n\n if (bubblePosition === 'floatingbelow') {\n return { left: getBubbleLeftPx(controllerSize, bubbleSize), top: getBubbleBelowPx(controllerSize), width: bubbleWidth };\n }\n\n return { left: getBubbleLeftPx(controllerSize, bubbleSize), top: getBubbleAbovePx(controllerSize, bubbleSize), width: bubbleWidth };\n};\n\n/**\n * Finn riktig plassering av pilen\n * @param bubbleStyle CSSProperties for hjelpeboblen\n * @param controllerSize DOMRect for kontrolleren\n * @param verticalPosition Ønsket plassering av hjelpeboblen (over/under)\n * @returns CSSProperties som plasserer pilen riktig\n */\nexport const getArrowStyle = (\n bubbleStyle: CSSProperties,\n controllerSize: DOMRect,\n verticalPosition: keyof typeof PopOverVariant\n): CSSProperties => {\n const leftPx = getArrowLeftPx(controllerSize);\n const rightPx = getArrowRightPx(controllerSize);\n const minLeftPx = (bubbleStyle.left as number) + ARROW_HORIZONTAL_MARGIN_PX;\n const minRightPx = (bubbleStyle.right as number) + ARROW_HORIZONTAL_MARGIN_PX;\n\n if (bubbleStyle.right) {\n if (verticalPosition === PopOverVariant.positionabove) {\n return {\n right: rightPx > minRightPx ? rightPx : minRightPx,\n top: getArrowTopxPx(controllerSize),\n };\n }\n\n return {\n right: rightPx > minRightPx ? rightPx : minRightPx,\n top: controllerSize.bottom,\n };\n }\n\n if (verticalPosition === PopOverVariant.positionabove) {\n return {\n left: leftPx > minLeftPx ? leftPx : minLeftPx,\n top: getArrowTopxPx(controllerSize),\n };\n }\n\n return {\n left: leftPx > minLeftPx ? leftPx : minLeftPx,\n top: controllerSize.bottom,\n };\n};\n","import { useRef } from 'react';\n\nimport {\n autoUpdate,\n flip,\n offset,\n shift,\n useClick,\n useDismiss,\n useFloating,\n useInteractions,\n FloatingArrow,\n arrow,\n hide,\n FloatingFocusManager,\n useMergeRefs,\n} from '@floating-ui/react';\nimport classNames from 'classnames';\n\nimport { PopOverVariant } from './utils';\nimport { AnalyticsId, ZIndex } from '../../constants';\nimport { getAriaLabelAttributes } from '../../utils/accessibility';\n\nimport styles from './styles.module.scss';\n\nexport type PopOverRole = 'tooltip' | 'dialog' | 'group';\n\nexport type PopOverPlacement = 'top' | 'bottom';\n\nexport interface PopOverProps {\n /** Sets aria-label of the bubble. If role is set to dialog ariaLabel or ariaLabelledById MUST be set! */\n ariaLabel?: string;\n /** Sets aria-labelledby of the bubble. If role is set to dialog ariaLabel or ariaLabelledById MUST be set! */\n ariaLabelledById?: string;\n /** Id of the PopOver */\n id?: string;\n /** Content shown inside PopOver. Note that if role=\"tooltip\", you must not include interactive/focusable elements. */\n children: React.ReactNode;\n /** Ref for the element the PopOver is placed upon */\n controllerRef: React.RefObject<HTMLElement | SVGSVGElement | null>;\n /** Show the popover. Only applies when role=tooltip. Default: false. */\n show?: boolean;\n /** Adds custom classes to the element. */\n className?: string;\n /** @deprecated Adds custom classes to the arrow element. */\n arrowClassName?: string;\n /** @deprecated use placement instead. Determines the placement of the popover. Default: automatic positioning. */\n variant?: keyof typeof PopOverVariant;\n /** Sets the placement of the popover relative to the trigger if there is space, otherwise automatic. */\n placement?: PopOverPlacement;\n /** Sets role of the PopOver element */\n role?: PopOverRole;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** Overrides the default z-index of PopOver */\n zIndex?: number;\n /** Ref that is passed to the component */\n ref?: React.Ref<HTMLDivElement | SVGSVGElement | HTMLElement | null>;\n}\n\nconst PopOver: React.FC<PopOverProps> = props => {\n const {\n ariaLabel,\n ariaLabelledById,\n id,\n children,\n controllerRef,\n show = false,\n className = '',\n variant = PopOverVariant.positionautomatic,\n role = 'dialog',\n testId,\n zIndex = ZIndex.PopOver,\n placement,\n ref,\n } = props;\n\n const ariaLabelAttributes = getAriaLabelAttributes({ label: ariaLabel, id: ariaLabelledById });\n\n const placementProp = placement ?? (variant === PopOverVariant.positionabove ? 'top' : 'bottom');\n\n const arrowRef = useRef(null);\n const { refs, floatingStyles, context, middlewareData } = useFloating({\n middleware: [offset(10), flip(), shift({ padding: 8 }), hide(), arrow({ element: arrowRef })],\n placement: placementProp,\n whileElementsMounted: autoUpdate,\n elements: {\n reference: controllerRef.current,\n },\n });\n\n const click = useClick(context);\n const dismiss = useDismiss(context);\n\n const { getFloatingProps } = useInteractions([click, dismiss]);\n\n const isVisible = show && !middlewareData.hide?.referenceHidden;\n\n const mergedRef = useMergeRefs<HTMLElement | SVGSVGElement>([refs.setFloating, ref]);\n\n return (\n <FloatingFocusManager context={context} modal={false}>\n <div\n id={id}\n ref={mergedRef}\n style={{ ...floatingStyles, visibility: isVisible ? 'visible' : 'hidden', zIndex: zIndex }}\n className={classNames(styles.popover, className)}\n {...getFloatingProps()}\n role={role}\n data-testid={testId}\n data-analyticsid={AnalyticsId.PopOver}\n {...ariaLabelAttributes}\n >\n {children}\n <FloatingArrow\n ref={arrowRef}\n className={styles['popover__arrow']}\n context={context}\n fill={'var(--core-color-white)'}\n stroke={'var(--color-base-border-onlight)'}\n strokeWidth={1}\n />\n </div>\n </FloatingFocusManager>\n );\n};\n\nPopOver.displayName = 'PopOver';\n\nexport default PopOver;\n","import PopOver from './PopOver';\nexport { PopOverVariant } from './utils';\nexport * from './PopOver';\nexport default PopOver;\n"],"mappings":";;;;;;;;AAEA,IAAY,iBAAL,yBAAA,gBAAA;CACL,eAAA,uBAAA;CACA,eAAA,mBAAA;CACA,eAAA,mBAAA;;AACF,EAAA,CAAA,CAAA;;;ACsDA,IAAM,WAAkC,UAAS;CAC/C,MAAM,EACJ,WACA,kBACA,IACA,UACA,eACA,OAAO,OACP,YAAY,IACZ,UAAU,eAAe,mBACzB,OAAO,UACP,QACA,SAAS,OAAO,SAChB,WACA,QACE;CAEJ,MAAM,sBAAsB,uBAAuB;EAAE,OAAO;EAAW,IAAI;CAAiB,CAAC;CAE7F,MAAM,gBAAgB,cAAc,YAAY,eAAe,gBAAgB,QAAQ;CAEvF,MAAM,WAAW,OAAO,IAAI;CAC5B,MAAM,EAAE,MAAM,gBAAgB,SAAS,mBAAmB,YAAY;EACpE,YAAY;GAAC,OAAO,EAAE;GAAG,KAAK;GAAG,MAAM,EAAE,SAAS,EAAE,CAAC;GAAG,KAAK;GAAG,MAAM,EAAE,SAAS,SAAS,CAAC;EAAC;EAC5F,WAAW;EACX,sBAAsB;EACtB,UAAU,EACR,WAAW,cAAc,QAC3B;CACF,CAAC;CAKD,MAAM,EAAE,qBAAqB,gBAAgB,CAH/B,SAAS,OAGuB,GAF9B,WAAW,OAE0B,CAAO,CAAC;CAE7D,MAAM,YAAY,QAAQ,CAAC,eAAe,MAAM;CAIhD,OACE,oBAAC,sBAAD;EAA+B;EAAS,OAAO;YAC7C,qBAAC,OAAD;GACM;GACJ,KANY,aAA0C,CAAC,KAAK,aAAa,GAAG,CAMvE;GACL,OAAO;IAAE,GAAG;IAAgB,YAAY,YAAY,YAAY;IAAkB;GAAO;GACzF,WAAW,WAAW,OAAO,SAAS,SAAS;GAC/C,GAAI,iBAAiB;GACf;GACN,eAAa;GACb,oBAAkB,YAAY;GAC9B,GAAI;aATN,CAWG,UACD,oBAAC,eAAD;IACE,KAAK;IACL,WAAW,OAAO;IACT;IACT,MAAM;IACN,QAAQ;IACR,aAAa;GACd,CAAA,CACE;;CACe,CAAA;AAE1B;AAEA,QAAQ,cAAc;;;AC5HtB,IAAA,kBAAe"}
package/lib/Radio.js ADDED
@@ -0,0 +1,74 @@
1
+ import { useIsMobileBreakpoint } from "./hooks/useIsMobileBreakpoint.js";
2
+ import { useIdWithFallback } from "./hooks/useIdWithFallback.js";
3
+ import { getAriaDescribedBy } from "./utils/accessibility.js";
4
+ import { t as ErrorWrapper_default } from "./ErrorWrapper.js";
5
+ import classNames from "classnames";
6
+ import { useState } from "react";
7
+ import { jsx, jsxs } from "react/jsx-runtime";
8
+ import styles from "./components/VisualRadioCloud/Radio/styles.module.scss";
9
+ //#region src/components/VisualRadioCloud/Radio/Radio.tsx
10
+ var Radio = (props) => {
11
+ const { className, checked, defaultChecked, children, inputId: inputIdProp, errorText, error = !!errorText, errorTextId: errorTextIdProp, errorWrapperClassName, testId, onChange, ref, ...rest } = props;
12
+ const inputId = useIdWithFallback(inputIdProp);
13
+ const errorTextId = useIdWithFallback(errorTextIdProp);
14
+ const isMobile = useIsMobileBreakpoint();
15
+ const [isChecked, setIsChecked] = useState(!!(checked ?? defaultChecked));
16
+ const [prevChecked, setPrevChecked] = useState(checked);
17
+ if (prevChecked !== checked) {
18
+ setPrevChecked(checked);
19
+ if (checked !== void 0 && checked !== isChecked) setIsChecked(checked);
20
+ }
21
+ const handleChange = (e) => {
22
+ setIsChecked(e.target.checked);
23
+ onChange?.(e);
24
+ };
25
+ return /* @__PURE__ */ jsx(ErrorWrapper_default, {
26
+ className: errorWrapperClassName,
27
+ errorText,
28
+ errorTextId,
29
+ children: /* @__PURE__ */ jsxs("label", {
30
+ className: classNames(styles["visual-radio"], {
31
+ [styles["visual-radio--checked"]]: isChecked,
32
+ [styles["visual-radio--invalid"]]: error
33
+ }, className),
34
+ htmlFor: inputId,
35
+ "data-testid": testId,
36
+ children: [/* @__PURE__ */ jsx("input", {
37
+ ...rest,
38
+ id: inputId,
39
+ ref,
40
+ className: styles["visual-radio__input"],
41
+ type: "radio",
42
+ checked: isChecked,
43
+ "aria-describedby": getAriaDescribedBy(props, errorTextId),
44
+ onChange: handleChange
45
+ }), /* @__PURE__ */ jsxs("span", {
46
+ className: styles["visual-radio__pill"],
47
+ children: [isChecked && /* @__PURE__ */ jsx("span", {
48
+ className: styles["visual-radio__icon"],
49
+ "aria-hidden": "true",
50
+ children: isMobile ? /* @__PURE__ */ jsx("svg", {
51
+ width: "8",
52
+ height: "8",
53
+ fill: "none",
54
+ xmlns: "http://www.w3.org/2000/svg",
55
+ children: /* @__PURE__ */ jsx("path", { d: "M4 8a4 4 0 1 0 0-8 4 4 0 0 0 0 8Z" })
56
+ }) : /* @__PURE__ */ jsx("svg", {
57
+ width: "12",
58
+ height: "12",
59
+ fill: "none",
60
+ xmlns: "http://www.w3.org/2000/svg",
61
+ children: /* @__PURE__ */ jsx("path", { d: "M6 12A6 6 0 1 0 6 0a6 6 0 0 0 0 12Z" })
62
+ })
63
+ }), /* @__PURE__ */ jsx("span", {
64
+ className: styles["visual-radio__label"],
65
+ children
66
+ })]
67
+ })]
68
+ })
69
+ });
70
+ };
71
+ //#endregion
72
+ export { Radio as t };
73
+
74
+ //# sourceMappingURL=Radio.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Radio.js","names":[],"sources":["../src/components/VisualRadioCloud/Radio/Radio.tsx"],"sourcesContent":["import { useState } from 'react';\n\nimport classNames from 'classnames';\n\nimport type { ErrorWrapperClassNameProps } from '../../ErrorWrapper';\n\nimport { useIdWithFallback } from '../../../hooks/useIdWithFallback';\nimport { useIsMobileBreakpoint } from '../../../hooks/useIsMobileBreakpoint';\nimport { getAriaDescribedBy } from '../../../utils/accessibility';\nimport ErrorWrapper from '../../ErrorWrapper';\n\nimport styles from './styles.module.scss';\n\nexport interface RadioProps\n extends\n ErrorWrapperClassNameProps,\n Omit<React.InputHTMLAttributes<HTMLInputElement>, 'type' | 'id' | 'className' | 'children' | 'size' | 'value'> {\n /** Adds custom classes to the root element. */\n className?: string;\n /** Label text shown inside the pill. */\n children: React.ReactNode;\n /** Value identifying this radio inside its group. Required. */\n value: string;\n /** input id of the underlying radio */\n inputId?: string;\n /** Activates error styling. Can be true while errorText is empty (e.g. when used in a cloud). */\n error?: boolean;\n /** Error text to show above the component. */\n errorText?: string;\n /** Error text id */\n errorTextId?: string;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** Ref forwarded to the underlying input element. */\n ref?: React.Ref<HTMLInputElement | null>;\n}\n\nconst Radio: React.FC<RadioProps> = props => {\n const {\n className,\n checked,\n defaultChecked,\n children,\n inputId: inputIdProp,\n errorText,\n error = !!errorText,\n errorTextId: errorTextIdProp,\n errorWrapperClassName,\n testId,\n onChange,\n ref,\n ...rest\n } = props;\n\n const inputId = useIdWithFallback(inputIdProp);\n const errorTextId = useIdWithFallback(errorTextIdProp);\n const isMobile = useIsMobileBreakpoint();\n const [isChecked, setIsChecked] = useState<boolean>(!!(checked ?? defaultChecked));\n const [prevChecked, setPrevChecked] = useState<boolean | undefined>(checked);\n if (prevChecked !== checked) {\n setPrevChecked(checked);\n if (checked !== undefined && checked !== isChecked) {\n setIsChecked(checked);\n }\n }\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>): void => {\n setIsChecked(e.target.checked);\n onChange?.(e);\n };\n\n return (\n <ErrorWrapper className={errorWrapperClassName} errorText={errorText} errorTextId={errorTextId}>\n <label\n className={classNames(\n styles['visual-radio'],\n {\n [styles['visual-radio--checked']]: isChecked,\n [styles['visual-radio--invalid']]: error,\n },\n className\n )}\n htmlFor={inputId}\n data-testid={testId}\n >\n <input\n {...rest}\n id={inputId}\n ref={ref}\n className={styles['visual-radio__input']}\n type=\"radio\"\n checked={isChecked}\n aria-describedby={getAriaDescribedBy(props, errorTextId)}\n onChange={handleChange}\n />\n <span className={styles['visual-radio__pill']}>\n {isChecked && (\n <span className={styles['visual-radio__icon']} aria-hidden=\"true\">\n {isMobile ? (\n <svg width=\"8\" height=\"8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M4 8a4 4 0 1 0 0-8 4 4 0 0 0 0 8Z\" />\n </svg>\n ) : (\n <svg width=\"12\" height=\"12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M6 12A6 6 0 1 0 6 0a6 6 0 0 0 0 12Z\" />\n </svg>\n )}\n </span>\n )}\n <span className={styles['visual-radio__label']}>{children}</span>\n </span>\n </label>\n </ErrorWrapper>\n );\n};\n\nexport default Radio;\n"],"mappings":";;;;;;;;;AAqCA,IAAM,SAA8B,UAAS;CAC3C,MAAM,EACJ,WACA,SACA,gBACA,UACA,SAAS,aACT,WACA,QAAQ,CAAC,CAAC,WACV,aAAa,iBACb,uBACA,QACA,UACA,KACA,GAAG,SACD;CAEJ,MAAM,UAAU,kBAAkB,WAAW;CAC7C,MAAM,cAAc,kBAAkB,eAAe;CACrD,MAAM,WAAW,sBAAsB;CACvC,MAAM,CAAC,WAAW,gBAAgB,SAAkB,CAAC,EAAE,WAAW,eAAe;CACjF,MAAM,CAAC,aAAa,kBAAkB,SAA8B,OAAO;CAC3E,IAAI,gBAAgB,SAAS;EAC3B,eAAe,OAAO;EACtB,IAAI,YAAY,KAAA,KAAa,YAAY,WACvC,aAAa,OAAO;CAExB;CAEA,MAAM,gBAAgB,MAAiD;EACrE,aAAa,EAAE,OAAO,OAAO;EAC7B,WAAW,CAAC;CACd;CAEA,OACE,oBAAC,sBAAD;EAAc,WAAW;EAAkC;EAAwB;YACjF,qBAAC,SAAD;GACE,WAAW,WACT,OAAO,iBACP;KACG,OAAO,2BAA2B;KAClC,OAAO,2BAA2B;GACrC,GACA,SACF;GACA,SAAS;GACT,eAAa;aAVf,CAYE,oBAAC,SAAD;IACE,GAAI;IACJ,IAAI;IACC;IACL,WAAW,OAAO;IAClB,MAAK;IACL,SAAS;IACT,oBAAkB,mBAAmB,OAAO,WAAW;IACvD,UAAU;GACX,CAAA,GACD,qBAAC,QAAD;IAAM,WAAW,OAAO;cAAxB,CACG,aACC,oBAAC,QAAD;KAAM,WAAW,OAAO;KAAuB,eAAY;eACxD,WACC,oBAAC,OAAD;MAAK,OAAM;MAAI,QAAO;MAAI,MAAK;MAAO,OAAM;gBAC1C,oBAAC,QAAD,EAAM,GAAE,oCAAqC,CAAA;KAC1C,CAAA,IAEL,oBAAC,OAAD;MAAK,OAAM;MAAK,QAAO;MAAK,MAAK;MAAO,OAAM;gBAC5C,oBAAC,QAAD,EAAM,GAAE,sCAAuC,CAAA;KAC5C,CAAA;IAEH,CAAA,GAER,oBAAC,QAAD;KAAM,WAAW,OAAO;KAAyB;IAAe,CAAA,CAC5D;KACD;;CACK,CAAA;AAElB"}
@@ -0,0 +1,84 @@
1
+ import { t as uuid } from "./uuid.js";
2
+ import { AnalyticsId, FormOnColor, FormSize } from "./constants.js";
3
+ import { useIdWithFallback } from "./hooks/useIdWithFallback.js";
4
+ import { getAriaDescribedBy } from "./utils/accessibility.js";
5
+ import { t as ErrorWrapper_default } from "./ErrorWrapper.js";
6
+ import { r as renderLabelAsParent, t as getLabelText } from "./utils2.js";
7
+ import { t as RadioMarker } from "./RadioMarker.js";
8
+ import classNames from "classnames";
9
+ import { jsx, jsxs } from "react/jsx-runtime";
10
+ import radioButtonStyles from "./components/RadioButton/styles.module.scss";
11
+ //#region src/components/RadioButton/RadioButton.tsx
12
+ var RadioButton = (props) => {
13
+ const { className, defaultChecked, onChange, disabled, label, inputId = uuid(), onColor = FormOnColor.onwhite, name = inputId, size, errorText, errorTextId: errorTextIdProp, error = !!errorText, errorWrapperClassName, value = getLabelText(label), testId, required, labelClassNames, ref, ...rest } = props;
14
+ const invalid = error || onColor === FormOnColor.oninvalid;
15
+ const onDark = onColor === FormOnColor.ondark;
16
+ const onGrey = onColor === FormOnColor.ongrey;
17
+ const onBlueberry = onColor === FormOnColor.onblueberry;
18
+ const onCherry = onColor === FormOnColor.oninvalid;
19
+ const isLarge = size === FormSize.large;
20
+ const errorTextId = useIdWithFallback(errorTextIdProp);
21
+ const radioButtonWrapperClasses = classNames(radioButtonStyles["radio-button-wrapper"], {
22
+ [radioButtonStyles["radio-button-wrapper__large"]]: isLarge,
23
+ [radioButtonStyles["radio-button-wrapper__large--invalid"]]: isLarge && onCherry,
24
+ [radioButtonStyles["radio-button-wrapper__large--on-blueberry"]]: isLarge && onBlueberry
25
+ });
26
+ const radioButtonLabelClasses = classNames(radioButtonStyles["radio-button-label"], {
27
+ [radioButtonStyles["radio-button-label--disabled"]]: disabled,
28
+ [radioButtonStyles["radio-button-label--on-dark"]]: onDark,
29
+ [radioButtonStyles["radio-button-label--invalid"]]: invalid,
30
+ [radioButtonStyles["radio-button-label__large"]]: isLarge,
31
+ [radioButtonStyles["radio-button-label__large--disabled"]]: isLarge && disabled,
32
+ [radioButtonStyles["radio-button-label__large--on-grey"]]: isLarge && onGrey,
33
+ [radioButtonStyles["radio-button-label__large--on-blueberry"]]: isLarge && onBlueberry,
34
+ [radioButtonStyles["radio-button-label__large--invalid"]]: isLarge && onCherry
35
+ }, labelClassNames);
36
+ const radioButtonClasses = classNames(radioButtonStyles["radio-button"], className);
37
+ const getLabelContent = () => /* @__PURE__ */ jsxs("span", {
38
+ className: radioButtonStyles["radio-button__marker-wrapper"],
39
+ children: [/* @__PURE__ */ jsx("input", {
40
+ ...rest,
41
+ id: inputId,
42
+ name,
43
+ className: radioButtonClasses,
44
+ type: "radio",
45
+ disabled,
46
+ value,
47
+ ref,
48
+ defaultChecked,
49
+ "aria-describedby": getAriaDescribedBy(props, errorTextId),
50
+ required,
51
+ onChange
52
+ }), /* @__PURE__ */ jsx(RadioMarker, {
53
+ disabled,
54
+ error: invalid,
55
+ onColor,
56
+ size
57
+ })]
58
+ });
59
+ return /* @__PURE__ */ jsx(ErrorWrapper_default, {
60
+ className: errorWrapperClassName,
61
+ errorText,
62
+ errorTextId,
63
+ children: /* @__PURE__ */ jsx("div", {
64
+ "data-testid": testId,
65
+ "data-analyticsid": AnalyticsId.RadioButton,
66
+ className: radioButtonWrapperClasses,
67
+ children: renderLabelAsParent({
68
+ label,
69
+ children: getLabelContent(),
70
+ inputId,
71
+ onColor,
72
+ labelClassName: radioButtonLabelClasses,
73
+ sublabelWrapperClassName: radioButtonStyles["radiobutton-sublabel-wrapper"],
74
+ large: isLarge,
75
+ afterLabelChildrenClassName: radioButtonStyles["radiobutton-afterlabelchildren-wrapper"]
76
+ })
77
+ })
78
+ });
79
+ };
80
+ RadioButton.displayName = "RadioButton";
81
+ //#endregion
82
+ export { RadioButton as t };
83
+
84
+ //# sourceMappingURL=RadioButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadioButton.js","names":[],"sources":["../src/components/RadioButton/RadioButton.tsx"],"sourcesContent":["import classNames from 'classnames';\n\nimport type { ErrorWrapperClassNameProps } from '../ErrorWrapper';\n\nimport RadioMarker from './RadioMarker/RadioMarker';\nimport { AnalyticsId, FormOnColor, FormSize } from '../../constants';\nimport { useIdWithFallback } from '../../hooks/useIdWithFallback';\nimport { getAriaDescribedBy } from '../../utils/accessibility';\nimport { uuid } from '../../utils/uuid';\nimport ErrorWrapper from '../ErrorWrapper';\nimport { getLabelText, renderLabelAsParent } from '../Label/utils';\n\nimport radioButtonStyles from './styles.module.scss';\n\nexport interface RadioButtonProps\n extends\n ErrorWrapperClassNameProps,\n Pick<\n React.InputHTMLAttributes<HTMLInputElement>,\n 'aria-describedby' | 'name' | 'value' | 'disabled' | 'checked' | 'defaultChecked' | 'required' | 'onChange'\n > {\n /** Adds custom classes to the element. */\n className?: string;\n /** The <Label/> next to the radioButton - sublabels kan ikke kombineres med large variant */\n label: React.ReactNode;\n /** Adds custom classes to the label element. */\n labelClassNames?: string;\n /** input id of the radioButton */\n inputId?: string;\n /** Changes the visuals of the radioButton */\n onColor?: keyof typeof FormOnColor;\n /** Changes the visuals of the radioButton. Large version only works when used inside a FormGroup wrapper. */\n size?: keyof typeof FormSize;\n /** Activates Error style for the radioButton - This is can be true while errorText is empty, when in a FormGroup */\n error?: boolean;\n /** Error text to show above the component */\n errorText?: string;\n /** Error text id */\n errorTextId?: string;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** Ref passed to the input element */\n ref?: React.Ref<HTMLInputElement | null>;\n}\n\nexport const RadioButton: React.FC<RadioButtonProps> = props => {\n const {\n className,\n defaultChecked,\n onChange,\n disabled,\n label,\n inputId = uuid(),\n onColor = FormOnColor.onwhite,\n name = inputId,\n size,\n errorText,\n errorTextId: errorTextIdProp,\n error = !!errorText,\n errorWrapperClassName,\n value = getLabelText(label),\n testId,\n required,\n labelClassNames,\n ref,\n ...rest\n } = props;\n const invalid = error || onColor === FormOnColor.oninvalid;\n const onDark = onColor === FormOnColor.ondark;\n const onGrey = onColor === FormOnColor.ongrey;\n const onBlueberry = onColor === FormOnColor.onblueberry;\n const onCherry = onColor === FormOnColor.oninvalid;\n const isLarge = size === FormSize.large;\n\n const errorTextId = useIdWithFallback(errorTextIdProp);\n\n const radioButtonWrapperClasses = classNames(radioButtonStyles['radio-button-wrapper'], {\n [radioButtonStyles['radio-button-wrapper__large']]: isLarge,\n [radioButtonStyles['radio-button-wrapper__large--invalid']]: isLarge && onCherry,\n [radioButtonStyles['radio-button-wrapper__large--on-blueberry']]: isLarge && onBlueberry,\n });\n const radioButtonLabelClasses = classNames(\n radioButtonStyles['radio-button-label'],\n {\n [radioButtonStyles['radio-button-label--disabled']]: disabled,\n [radioButtonStyles['radio-button-label--on-dark']]: onDark,\n [radioButtonStyles['radio-button-label--invalid']]: invalid,\n [radioButtonStyles['radio-button-label__large']]: isLarge,\n [radioButtonStyles['radio-button-label__large--disabled']]: isLarge && disabled,\n [radioButtonStyles['radio-button-label__large--on-grey']]: isLarge && onGrey,\n [radioButtonStyles['radio-button-label__large--on-blueberry']]: isLarge && onBlueberry,\n [radioButtonStyles['radio-button-label__large--invalid']]: isLarge && onCherry,\n },\n labelClassNames\n );\n const radioButtonClasses = classNames(radioButtonStyles['radio-button'], className);\n\n const getLabelContent = (): React.ReactNode => (\n <span className={radioButtonStyles['radio-button__marker-wrapper']}>\n <input\n {...rest}\n id={inputId}\n name={name}\n className={radioButtonClasses}\n type=\"radio\"\n disabled={disabled}\n value={value}\n ref={ref}\n defaultChecked={defaultChecked}\n aria-describedby={getAriaDescribedBy(props, errorTextId)}\n required={required}\n onChange={onChange}\n />\n <RadioMarker disabled={disabled} error={invalid} onColor={onColor} size={size} />\n </span>\n );\n\n return (\n <ErrorWrapper className={errorWrapperClassName} errorText={errorText} errorTextId={errorTextId}>\n <div data-testid={testId} data-analyticsid={AnalyticsId.RadioButton} className={radioButtonWrapperClasses}>\n {renderLabelAsParent({\n label: label,\n children: getLabelContent(),\n inputId: inputId,\n onColor: onColor as FormOnColor,\n labelClassName: radioButtonLabelClasses,\n sublabelWrapperClassName: radioButtonStyles['radiobutton-sublabel-wrapper'],\n large: isLarge,\n afterLabelChildrenClassName: radioButtonStyles['radiobutton-afterlabelchildren-wrapper'],\n })}\n </div>\n </ErrorWrapper>\n );\n};\n\nRadioButton.displayName = 'RadioButton';\n\nexport default RadioButton;\n"],"mappings":";;;;;;;;;;;AA6CA,IAAa,eAA0C,UAAS;CAC9D,MAAM,EACJ,WACA,gBACA,UACA,UACA,OACA,UAAU,KAAK,GACf,UAAU,YAAY,SACtB,OAAO,SACP,MACA,WACA,aAAa,iBACb,QAAQ,CAAC,CAAC,WACV,uBACA,QAAQ,aAAa,KAAK,GAC1B,QACA,UACA,iBACA,KACA,GAAG,SACD;CACJ,MAAM,UAAU,SAAS,YAAY,YAAY;CACjD,MAAM,SAAS,YAAY,YAAY;CACvC,MAAM,SAAS,YAAY,YAAY;CACvC,MAAM,cAAc,YAAY,YAAY;CAC5C,MAAM,WAAW,YAAY,YAAY;CACzC,MAAM,UAAU,SAAS,SAAS;CAElC,MAAM,cAAc,kBAAkB,eAAe;CAErD,MAAM,4BAA4B,WAAW,kBAAkB,yBAAyB;GACrF,kBAAkB,iCAAiC;GACnD,kBAAkB,0CAA0C,WAAW;GACvE,kBAAkB,+CAA+C,WAAW;CAC/E,CAAC;CACD,MAAM,0BAA0B,WAC9B,kBAAkB,uBAClB;GACG,kBAAkB,kCAAkC;GACpD,kBAAkB,iCAAiC;GACnD,kBAAkB,iCAAiC;GACnD,kBAAkB,+BAA+B;GACjD,kBAAkB,yCAAyC,WAAW;GACtE,kBAAkB,wCAAwC,WAAW;GACrE,kBAAkB,6CAA6C,WAAW;GAC1E,kBAAkB,wCAAwC,WAAW;CACxE,GACA,eACF;CACA,MAAM,qBAAqB,WAAW,kBAAkB,iBAAiB,SAAS;CAElF,MAAM,wBACJ,qBAAC,QAAD;EAAM,WAAW,kBAAkB;YAAnC,CACE,oBAAC,SAAD;GACE,GAAI;GACJ,IAAI;GACE;GACN,WAAW;GACX,MAAK;GACK;GACH;GACF;GACW;GAChB,oBAAkB,mBAAmB,OAAO,WAAW;GAC7C;GACA;EACX,CAAA,GACD,oBAAC,aAAD;GAAuB;GAAU,OAAO;GAAkB;GAAe;EAAO,CAAA,CAC5E;;CAGR,OACE,oBAAC,sBAAD;EAAc,WAAW;EAAkC;EAAwB;YACjF,oBAAC,OAAD;GAAK,eAAa;GAAQ,oBAAkB,YAAY;GAAa,WAAW;aAC7E,oBAAoB;IACZ;IACP,UAAU,gBAAgB;IACjB;IACA;IACT,gBAAgB;IAChB,0BAA0B,kBAAkB;IAC5C,OAAO;IACP,6BAA6B,kBAAkB;GACjD,CAAC;EACE,CAAA;CACO,CAAA;AAElB;AAEA,YAAY,cAAc"}
@@ -0,0 +1,35 @@
1
+ import { FormOnColor, FormSize } from "./constants.js";
2
+ import classNames from "classnames";
3
+ import { jsx } from "react/jsx-runtime";
4
+ import styles from "./components/RadioButton/RadioMarker/styles.module.scss";
5
+ //#region src/components/RadioButton/RadioMarker/RadioMarker.tsx
6
+ /**
7
+ * Does not render an <input>; consumers render this on their end.
8
+ */
9
+ var RadioMarker = (props) => {
10
+ const { checked = false, disabled = false, error = false, onColor = FormOnColor.onwhite, size, className } = props;
11
+ const onWhite = onColor === FormOnColor.onwhite;
12
+ const onGrey = onColor === FormOnColor.ongrey;
13
+ const onBlueberry = onColor === FormOnColor.onblueberry;
14
+ const onInvalid = error || onColor === FormOnColor.oninvalid;
15
+ const onDark = onColor === FormOnColor.ondark;
16
+ const large = size === FormSize.large;
17
+ return /* @__PURE__ */ jsx("span", {
18
+ className: classNames(styles["radio__marker"], large ? styles["radio__marker__large"] : styles["radio__marker__regular"], {
19
+ [styles["radio__marker--on-white"]]: onWhite,
20
+ [styles["radio__marker--on-grey"]]: onGrey,
21
+ [styles["radio__marker--on-blueberry"]]: onBlueberry,
22
+ [styles["radio__marker--on-dark"]]: onDark,
23
+ [styles["radio__marker--on-invalid"]]: onInvalid,
24
+ [styles["radio__marker--invalid"]]: onInvalid,
25
+ [styles["radio__marker--disabled"]]: disabled,
26
+ [styles["radio__marker--checked"]]: checked
27
+ }, className),
28
+ "aria-hidden": "true",
29
+ children: /* @__PURE__ */ jsx("span", { className: styles["radio__marker-dot"] })
30
+ });
31
+ };
32
+ //#endregion
33
+ export { RadioMarker as t };
34
+
35
+ //# sourceMappingURL=RadioMarker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadioMarker.js","names":[],"sources":["../src/components/RadioButton/RadioMarker/RadioMarker.tsx"],"sourcesContent":["import classNames from 'classnames';\n\nimport { FormOnColor, FormSize } from '../../../constants';\n\nimport styles from './styles.module.scss';\n\nexport interface RadioMarkerProps {\n /** Whether the radio is checked. Controls the inner dot visibility. */\n checked?: boolean;\n /** Disables the visual state of the marker. */\n disabled?: boolean;\n /** Activates error styling. */\n error?: boolean;\n /** Background context the marker is rendered on. */\n onColor?: keyof typeof FormOnColor;\n /** Size variant of the marker. */\n size?: keyof typeof FormSize;\n /** Adds custom classes to the marker wrapper. */\n className?: string;\n}\n\n/**\n * Does not render an <input>; consumers render this on their end.\n */\nexport const RadioMarker: React.FC<RadioMarkerProps> = props => {\n const { checked = false, disabled = false, error = false, onColor = FormOnColor.onwhite, size, className } = props;\n\n const onWhite = onColor === FormOnColor.onwhite;\n const onGrey = onColor === FormOnColor.ongrey;\n const onBlueberry = onColor === FormOnColor.onblueberry;\n const onInvalid = error || onColor === FormOnColor.oninvalid;\n const onDark = onColor === FormOnColor.ondark;\n const large = size === FormSize.large;\n\n const markerClasses = classNames(\n styles['radio__marker'],\n large ? styles['radio__marker__large'] : styles['radio__marker__regular'],\n {\n [styles['radio__marker--on-white']]: onWhite,\n [styles['radio__marker--on-grey']]: onGrey,\n [styles['radio__marker--on-blueberry']]: onBlueberry,\n [styles['radio__marker--on-dark']]: onDark,\n [styles['radio__marker--on-invalid']]: onInvalid,\n [styles['radio__marker--invalid']]: onInvalid,\n [styles['radio__marker--disabled']]: disabled,\n [styles['radio__marker--checked']]: checked,\n },\n className\n );\n\n return (\n <span className={markerClasses} aria-hidden=\"true\">\n <span className={styles['radio__marker-dot']} />\n </span>\n );\n};\n\nexport default RadioMarker;\n"],"mappings":";;;;;;;;AAwBA,IAAa,eAA0C,UAAS;CAC9D,MAAM,EAAE,UAAU,OAAO,WAAW,OAAO,QAAQ,OAAO,UAAU,YAAY,SAAS,MAAM,cAAc;CAE7G,MAAM,UAAU,YAAY,YAAY;CACxC,MAAM,SAAS,YAAY,YAAY;CACvC,MAAM,cAAc,YAAY,YAAY;CAC5C,MAAM,YAAY,SAAS,YAAY,YAAY;CACnD,MAAM,SAAS,YAAY,YAAY;CACvC,MAAM,QAAQ,SAAS,SAAS;CAkBhC,OACE,oBAAC,QAAD;EAAM,WAjBc,WACpB,OAAO,kBACP,QAAQ,OAAO,0BAA0B,OAAO,2BAChD;IACG,OAAO,6BAA6B;IACpC,OAAO,4BAA4B;IACnC,OAAO,iCAAiC;IACxC,OAAO,4BAA4B;IACnC,OAAO,+BAA+B;IACtC,OAAO,4BAA4B;IACnC,OAAO,6BAA6B;IACpC,OAAO,4BAA4B;EACtC,GACA,SAIiB;EAAe,eAAY;YAC1C,oBAAC,QAAD,EAAM,WAAW,OAAO,qBAAuB,CAAA;CAC3C,CAAA;AAEV"}
package/lib/Select.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"Select.js","names":[],"sources":["../src/components/Select/Select.tsx","../src/components/Select/index.ts"],"sourcesContent":["import classNames from 'classnames';\n\nimport type { ErrorWrapperClassNameProps } from '../ErrorWrapper';\n\nimport { AnalyticsId, AVERAGE_CHARACTER_WIDTH_PX, FormOnColor, IconSize } from '../../constants';\nimport { useIdWithFallback } from '../../hooks/useIdWithFallback';\nimport { getColor } from '../../theme/currys';\nimport { getAriaDescribedBy } from '../../utils/accessibility';\nimport ErrorWrapper from '../ErrorWrapper';\nimport Icon from '../Icon';\nimport ChevronDown from '../Icons/ChevronDown';\nimport { renderLabel } from '../Label/utils';\n\nimport selectStyles from './styles.module.scss';\n\ntype SelectConcept = 'normal' | 'transparent';\n\nexport interface SelectProps\n extends\n ErrorWrapperClassNameProps,\n Pick<\n React.SelectHTMLAttributes<HTMLSelectElement>,\n 'aria-describedby' | 'name' | 'disabled' | 'required' | 'value' | 'onChange' | 'autoComplete'\n > {\n /** Sets the content of the select element. */\n children: React.ReactNode;\n /** Adds custom classes to the element. */\n className?: string;\n /** Changes the visuals of the component */\n concept?: SelectConcept;\n /** The label text above the select */\n label?: React.ReactNode;\n /** Adds custom classes to the label wrapper */\n labelClassName?: string;\n /** Changes the visuals of the component */\n onColor?: keyof typeof FormOnColor;\n /** Activates Error style for the select component - This is can be true while errorText is empty, when in a FormGroup */\n error?: boolean;\n /** Error text to show above the component */\n errorText?: string;\n /** Error text id */\n errorTextId?: string;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** select id of the select element */\n selectId?: string;\n /** Width of select in characters (approximate) */\n width?: number;\n /** Gives defaultvalue to the comp. Preferred over selected prop on option by react */\n defaultValue?: string | number;\n /** Adds custom classes to the wrapper tag */\n wrapperClassName?: string;\n /** Ref passed to the select element */\n ref?: React.Ref<HTMLSelectElement | null>;\n}\n\nconst getSelectMaxWidth = (characters: number): string => {\n const paddingWidth = '2rem';\n\n return `calc(${characters * AVERAGE_CHARACTER_WIDTH_PX}px + ${paddingWidth})`;\n};\n\nconst getIconColor = (invalid: boolean, disabled: boolean): string => {\n const iconColor = invalid ? 'cherry' : 'blueberry';\n return disabled ? getColor('neutral', 500) : getColor(iconColor, 600);\n};\n\nexport const Select: React.FC<SelectProps> = props => {\n const {\n className,\n children,\n concept = 'normal',\n disabled,\n error,\n errorText,\n errorTextId: errorTextIdProp,\n selectId: selectIdProp,\n errorWrapperClassName,\n label,\n name = props.selectId,\n onColor = FormOnColor.onwhite,\n testId,\n width,\n required,\n value,\n defaultValue,\n autoComplete = 'off',\n wrapperClassName,\n ref,\n labelClassName,\n ...rest\n } = props;\n\n const selectId = useIdWithFallback(selectIdProp);\n const errorTextId = useIdWithFallback(errorTextIdProp);\n const onBlueberry = onColor === 'onblueberry';\n const invalid = onColor === 'oninvalid' || !!errorText || !!error;\n const iconColor = getIconColor(invalid, !!disabled);\n const maxWidth = width ? getSelectMaxWidth(width) : undefined;\n\n const selectInnerWrapperClasses = classNames(\n selectStyles['select-inner-wrapper'],\n {\n [selectStyles['select-inner-wrapper--transparent']]: concept === 'transparent',\n [selectStyles['select-inner-wrapper--on-blueberry']]: onBlueberry,\n [selectStyles['select-inner-wrapper--invalid']]: invalid,\n [selectStyles['select-inner-wrapper--disabled']]: disabled,\n },\n className\n );\n\n const selectClasses = classNames(selectStyles.select, {\n [selectStyles['select--on-blueberry']]: onBlueberry,\n [selectStyles['select--invalid']]: invalid,\n });\n\n const selectWrapperClasses = classNames(selectStyles['select-wrapper'], wrapperClassName);\n\n return (\n <ErrorWrapper className={errorWrapperClassName} errorText={errorText} errorTextId={errorTextId}>\n <div data-testid={testId} data-analyticsid={AnalyticsId.Select} className={selectWrapperClasses} style={{ maxWidth }}>\n {renderLabel({ label: label, inputId: selectId, onColor: onColor as FormOnColor, className: labelClassName })}\n <div className={selectInnerWrapperClasses} data-testid={testId + '-inner-wrapper'}>\n <Icon\n className={selectStyles['select-arrow']}\n svgIcon={ChevronDown}\n color={iconColor}\n size={IconSize.XSmall}\n testId={testId + '-icon'}\n />\n <select\n {...rest}\n aria-invalid={!!invalid}\n id={selectId}\n name={name}\n className={selectClasses}\n disabled={disabled}\n ref={ref}\n required={required}\n aria-describedby={getAriaDescribedBy(props, errorTextId)}\n aria-required={!!required}\n value={value}\n defaultValue={defaultValue}\n autoComplete={autoComplete ? autoComplete : undefined}\n >\n {children}\n </select>\n </div>\n </div>\n </ErrorWrapper>\n );\n};\n\nexport default Select;\n","import Select from './Select';\nexport * from './Select';\nexport default Select;\n"],"mappings":";;;;;;;;;;;;AAwDA,IAAM,qBAAqB,eAA+B;CAGxD,OAAO,QAAQ,aAAA,GAAwC;;AAGzD,IAAM,gBAAgB,SAAkB,aAA8B;CAEpE,OAAO,WAAW,SAAS,WAAW,IAAI,GAAG,SAD3B,UAAU,WAAW,aAC0B,IAAI;;AAGvE,IAAa,UAAgC,UAAS;CACpD,MAAM,EACJ,WACA,UACA,UAAU,UACV,UACA,OACA,WACA,aAAa,iBACb,UAAU,cACV,uBACA,OACA,OAAO,MAAM,UACb,UAAU,YAAY,SACtB,QACA,OACA,UACA,OACA,cACA,eAAe,OACf,kBACA,KACA,gBACA,GAAG,SACD;CAEJ,MAAM,WAAW,kBAAkB,aAAa;CAChD,MAAM,cAAc,kBAAkB,gBAAgB;CACtD,MAAM,cAAc,YAAY;CAChC,MAAM,UAAU,YAAY,eAAe,CAAC,CAAC,aAAa,CAAC,CAAC;CAC5D,MAAM,YAAY,aAAa,SAAS,CAAC,CAAC,SAAS;CACnD,MAAM,WAAW,QAAQ,kBAAkB,MAAM,GAAG,KAAA;CAEpD,MAAM,4BAA4B,WAChC,aAAa,yBACb;GACG,aAAa,uCAAuC,YAAY;GAChE,aAAa,wCAAwC;GACrD,aAAa,mCAAmC;GAChD,aAAa,oCAAoC;EACnD,EACD,UACD;CAED,MAAM,gBAAgB,WAAW,aAAa,QAAQ;GACnD,aAAa,0BAA0B;GACvC,aAAa,qBAAqB;EACpC,CAAC;CAEF,MAAM,uBAAuB,WAAW,aAAa,mBAAmB,iBAAiB;CAEzF,OACE,oBAAC,sBAAD;EAAc,WAAW;EAAkC;EAAwB;YACjF,qBAAC,OAAD;GAAK,eAAa;GAAQ,oBAAkB,YAAY;GAAQ,WAAW;GAAsB,OAAO,EAAE,UAAU;aAApH,CACG,YAAY;IAAS;IAAO,SAAS;IAAmB;IAAwB,WAAW;IAAgB,CAAC,EAC7G,qBAAC,OAAD;IAAK,WAAW;IAA2B,eAAa,SAAS;cAAjE,CACE,oBAAC,cAAD;KACE,WAAW,aAAa;KACxB,SAAS;KACT,OAAO;KACP,MAAM,SAAS;KACf,QAAQ,SAAS;KACjB,CAAA,EACF,oBAAC,UAAD;KACE,GAAI;KACJ,gBAAc,CAAC,CAAC;KAChB,IAAI;KACE;KACN,WAAW;KACD;KACL;KACK;KACV,oBAAkB,mBAAmB,OAAO,YAAY;KACxD,iBAAe,CAAC,CAAC;KACV;KACO;KACd,cAAc,eAAe,eAAe,KAAA;KAE3C;KACM,CAAA,CACL;MACF;;EACO,CAAA;;;;ACnJnB,IAAA,iBAAe"}
1
+ {"version":3,"file":"Select.js","names":[],"sources":["../src/components/Select/Select.tsx","../src/components/Select/index.ts"],"sourcesContent":["import classNames from 'classnames';\n\nimport type { ErrorWrapperClassNameProps } from '../ErrorWrapper';\n\nimport { AnalyticsId, AVERAGE_CHARACTER_WIDTH_PX, FormOnColor, IconSize } from '../../constants';\nimport { useIdWithFallback } from '../../hooks/useIdWithFallback';\nimport { getColor } from '../../theme/currys';\nimport { getAriaDescribedBy } from '../../utils/accessibility';\nimport ErrorWrapper from '../ErrorWrapper';\nimport Icon from '../Icon';\nimport ChevronDown from '../Icons/ChevronDown';\nimport { renderLabel } from '../Label/utils';\n\nimport selectStyles from './styles.module.scss';\n\ntype SelectConcept = 'normal' | 'transparent';\n\nexport interface SelectProps\n extends\n ErrorWrapperClassNameProps,\n Pick<\n React.SelectHTMLAttributes<HTMLSelectElement>,\n 'aria-describedby' | 'name' | 'disabled' | 'required' | 'value' | 'onChange' | 'autoComplete'\n > {\n /** Sets the content of the select element. */\n children: React.ReactNode;\n /** Adds custom classes to the element. */\n className?: string;\n /** Changes the visuals of the component */\n concept?: SelectConcept;\n /** The label text above the select */\n label?: React.ReactNode;\n /** Adds custom classes to the label wrapper */\n labelClassName?: string;\n /** Changes the visuals of the component */\n onColor?: keyof typeof FormOnColor;\n /** Activates Error style for the select component - This is can be true while errorText is empty, when in a FormGroup */\n error?: boolean;\n /** Error text to show above the component */\n errorText?: string;\n /** Error text id */\n errorTextId?: string;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** select id of the select element */\n selectId?: string;\n /** Width of select in characters (approximate) */\n width?: number;\n /** Gives defaultvalue to the comp. Preferred over selected prop on option by react */\n defaultValue?: string | number;\n /** Adds custom classes to the wrapper tag */\n wrapperClassName?: string;\n /** Ref passed to the select element */\n ref?: React.Ref<HTMLSelectElement | null>;\n}\n\nconst getSelectMaxWidth = (characters: number): string => {\n const paddingWidth = '2rem';\n\n return `calc(${characters * AVERAGE_CHARACTER_WIDTH_PX}px + ${paddingWidth})`;\n};\n\nconst getIconColor = (invalid: boolean, disabled: boolean): string => {\n const iconColor = invalid ? 'cherry' : 'blueberry';\n return disabled ? getColor('neutral', 500) : getColor(iconColor, 600);\n};\n\nexport const Select: React.FC<SelectProps> = props => {\n const {\n className,\n children,\n concept = 'normal',\n disabled,\n error,\n errorText,\n errorTextId: errorTextIdProp,\n selectId: selectIdProp,\n errorWrapperClassName,\n label,\n name = props.selectId,\n onColor = FormOnColor.onwhite,\n testId,\n width,\n required,\n value,\n defaultValue,\n autoComplete = 'off',\n wrapperClassName,\n ref,\n labelClassName,\n ...rest\n } = props;\n\n const selectId = useIdWithFallback(selectIdProp);\n const errorTextId = useIdWithFallback(errorTextIdProp);\n const onBlueberry = onColor === 'onblueberry';\n const invalid = onColor === 'oninvalid' || !!errorText || !!error;\n const iconColor = getIconColor(invalid, !!disabled);\n const maxWidth = width ? getSelectMaxWidth(width) : undefined;\n\n const selectInnerWrapperClasses = classNames(\n selectStyles['select-inner-wrapper'],\n {\n [selectStyles['select-inner-wrapper--transparent']]: concept === 'transparent',\n [selectStyles['select-inner-wrapper--on-blueberry']]: onBlueberry,\n [selectStyles['select-inner-wrapper--invalid']]: invalid,\n [selectStyles['select-inner-wrapper--disabled']]: disabled,\n },\n className\n );\n\n const selectClasses = classNames(selectStyles.select, {\n [selectStyles['select--on-blueberry']]: onBlueberry,\n [selectStyles['select--invalid']]: invalid,\n });\n\n const selectWrapperClasses = classNames(selectStyles['select-wrapper'], wrapperClassName);\n\n return (\n <ErrorWrapper className={errorWrapperClassName} errorText={errorText} errorTextId={errorTextId}>\n <div data-testid={testId} data-analyticsid={AnalyticsId.Select} className={selectWrapperClasses} style={{ maxWidth }}>\n {renderLabel({ label: label, inputId: selectId, onColor: onColor as FormOnColor, className: labelClassName })}\n <div className={selectInnerWrapperClasses} data-testid={testId + '-inner-wrapper'}>\n <Icon\n className={selectStyles['select-arrow']}\n svgIcon={ChevronDown}\n color={iconColor}\n size={IconSize.XSmall}\n testId={testId + '-icon'}\n />\n <select\n {...rest}\n aria-invalid={!!invalid}\n id={selectId}\n name={name}\n className={selectClasses}\n disabled={disabled}\n ref={ref}\n required={required}\n aria-describedby={getAriaDescribedBy(props, errorTextId)}\n aria-required={!!required}\n value={value}\n defaultValue={defaultValue}\n autoComplete={autoComplete ? autoComplete : undefined}\n >\n {children}\n </select>\n </div>\n </div>\n </ErrorWrapper>\n );\n};\n\nexport default Select;\n","import Select from './Select';\nexport * from './Select';\nexport default Select;\n"],"mappings":";;;;;;;;;;;;AAwDA,IAAM,qBAAqB,eAA+B;CAGxD,OAAO,QAAQ,aAAA,GAAwC;AACzD;AAEA,IAAM,gBAAgB,SAAkB,aAA8B;CAEpE,OAAO,WAAW,SAAS,WAAW,GAAG,IAAI,SAD3B,UAAU,WAAW,aAC0B,GAAG;AACtE;AAEA,IAAa,UAAgC,UAAS;CACpD,MAAM,EACJ,WACA,UACA,UAAU,UACV,UACA,OACA,WACA,aAAa,iBACb,UAAU,cACV,uBACA,OACA,OAAO,MAAM,UACb,UAAU,YAAY,SACtB,QACA,OACA,UACA,OACA,cACA,eAAe,OACf,kBACA,KACA,gBACA,GAAG,SACD;CAEJ,MAAM,WAAW,kBAAkB,YAAY;CAC/C,MAAM,cAAc,kBAAkB,eAAe;CACrD,MAAM,cAAc,YAAY;CAChC,MAAM,UAAU,YAAY,eAAe,CAAC,CAAC,aAAa,CAAC,CAAC;CAC5D,MAAM,YAAY,aAAa,SAAS,CAAC,CAAC,QAAQ;CAClD,MAAM,WAAW,QAAQ,kBAAkB,KAAK,IAAI,KAAA;CAEpD,MAAM,4BAA4B,WAChC,aAAa,yBACb;GACG,aAAa,uCAAuC,YAAY;GAChE,aAAa,wCAAwC;GACrD,aAAa,mCAAmC;GAChD,aAAa,oCAAoC;CACpD,GACA,SACF;CAEA,MAAM,gBAAgB,WAAW,aAAa,QAAQ;GACnD,aAAa,0BAA0B;GACvC,aAAa,qBAAqB;CACrC,CAAC;CAED,MAAM,uBAAuB,WAAW,aAAa,mBAAmB,gBAAgB;CAExF,OACE,oBAAC,sBAAD;EAAc,WAAW;EAAkC;EAAwB;YACjF,qBAAC,OAAD;GAAK,eAAa;GAAQ,oBAAkB,YAAY;GAAQ,WAAW;GAAsB,OAAO,EAAE,SAAS;aAAnH,CACG,YAAY;IAAS;IAAO,SAAS;IAAmB;IAAwB,WAAW;GAAe,CAAC,GAC5G,qBAAC,OAAD;IAAK,WAAW;IAA2B,eAAa,SAAS;cAAjE,CACE,oBAAC,cAAD;KACE,WAAW,aAAa;KACxB,SAAS;KACT,OAAO;KACP,MAAM,SAAS;KACf,QAAQ,SAAS;IAClB,CAAA,GACD,oBAAC,UAAD;KACE,GAAI;KACJ,gBAAc,CAAC,CAAC;KAChB,IAAI;KACE;KACN,WAAW;KACD;KACL;KACK;KACV,oBAAkB,mBAAmB,OAAO,WAAW;KACvD,iBAAe,CAAC,CAAC;KACV;KACO;KACd,cAAc,eAAe,eAAe,KAAA;KAE3C;IACK,CAAA,CACL;KACF;;CACO,CAAA;AAElB;;;ACrJA,IAAA,iBAAe"}
@@ -1 +1 @@
1
- {"version":3,"file":"SingleSelectItem.js","names":[],"sources":["../src/components/Dropdown/SingleSelect/utils.tsx","../src/components/Dropdown/SingleSelect/SingleSelectItem.tsx"],"sourcesContent":["import React from 'react';\n\nimport type { SingleSelectContextType } from './SingleSelect';\n\nexport const SingleSelectContext = React.createContext<SingleSelectContextType | null>(null);\n\nexport const useSingleSelect = (): SingleSelectContextType | null => React.useContext(SingleSelectContext);\n","import React, { useId } from 'react';\n\nimport classNames from 'classnames';\n\nimport type { AsChildSlotHandle } from '../../AsChildSlot';\n\nimport { useSingleSelect } from './utils';\nimport AsChildSlot from '../../AsChildSlot';\n\nimport styles from './styles.module.scss';\n\nexport interface SingleSelectItemProps extends Pick<React.ButtonHTMLAttributes<HTMLButtonElement>, 'disabled'> {\n /** The text to the singleSelectItem */\n text?: string;\n /** input id of the singleSelectItem */\n inputId?: string;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** When true, onclick and keyboard events will be passed to the child Button or AnchorLink. */\n asChild?: boolean;\n /** Only use when asChild is set to true and only pass one child */\n children?: React.ReactNode;\n /** Value for this singleSelectItem option - used by the parent wrapper to keep track of the context */\n value?: string;\n /** aria-describedby passthrough if needed */\n ['aria-describedby']?: string;\n /** Marks this option as initially selected */\n defaultSelected?: boolean;\n /** Ref that is passed to the component */\n ref?: React.Ref<HTMLElement | null>;\n}\n\nexport const SingleSelectItem: React.FC<SingleSelectItemProps> = props => {\n const { text, value, testId, asChild = false, children, disabled, defaultSelected, ref, ...rest } = props;\n\n const generatedId = useId();\n const inputId = props.inputId ?? generatedId;\n const group = useSingleSelect();\n const optionValue = typeof value === 'string' && value.length > 0 ? value : inputId;\n const isSelected = group ? group.value === optionValue : false;\n const isDisabled = !!disabled || !!group?.disabled;\n const asChildSlotRef = React.useRef<AsChildSlotHandle | null>(null);\n\n React.useEffect(() => {\n if (defaultSelected && group && typeof group.value === 'undefined') {\n group.onValueChange?.(optionValue);\n }\n }, [defaultSelected, group, optionValue]);\n\n const contentClasses = classNames(styles['single-select-item__content'], {\n [styles['single-select-item__content--disabled']]: isDisabled,\n });\n const dotClasses = classNames(styles['single-select-item__dot'], {\n [styles['single-select-item__dot--disabled']]: isDisabled,\n [styles['single-select-item__dot--checked']]: isSelected,\n });\n\n const childArray = React.Children.toArray(children).filter(React.isValidElement) as React.ReactElement[];\n const childElement = childArray[0] ?? null;\n\n const selectThis = (e?: React.SyntheticEvent): void => {\n if (isDisabled) return;\n if (group && group.value !== optionValue) {\n group.onValueChange?.(optionValue, e);\n }\n };\n\n const content = (\n <>\n <span className={dotClasses} aria-hidden />\n <span>{text}</span>\n </>\n );\n\n const Component = (asChild ? AsChildSlot : 'button') as React.ElementType;\n const childWithInjectedContent = childElement ? React.cloneElement(childElement, undefined, content) : null;\n\n const componentProps = asChild\n ? {\n ref: asChildSlotRef,\n elementRef: ref,\n className: contentClasses,\n disabled: isDisabled,\n onSelect: (e: React.SyntheticEvent): void => selectThis(e),\n ariaCurrent: isSelected ? 'true' : undefined,\n children: childWithInjectedContent,\n }\n : {\n ...rest,\n type: 'button' as const,\n className: contentClasses,\n disabled: isDisabled,\n onClick: (e: React.MouseEvent<HTMLButtonElement>): void => {\n e.preventDefault();\n selectThis(e);\n },\n onKeyDown: (e: React.KeyboardEvent<HTMLButtonElement>): void => {\n if (e.key === 'Enter') {\n e.preventDefault();\n selectThis(e);\n }\n },\n ref: ref,\n 'aria-disabled': isDisabled || undefined,\n 'aria-current': isSelected ? 'true' : undefined,\n children: content,\n };\n\n return (\n <div data-testid={testId} className={styles['single-select-item']}>\n <Component {...componentProps} />\n </div>\n );\n};\n\nSingleSelectItem.displayName = 'Dropdown.SingleSelectItem';\n\nexport default SingleSelectItem;\n"],"mappings":";;;;;;AAIA,IAAa,sBAAsB,MAAM,cAA8C,KAAK;AAE5F,IAAa,wBAAwD,MAAM,WAAW,oBAAoB;;;AC0B1G,IAAa,oBAAoD,UAAS;CACxE,MAAM,EAAE,MAAM,OAAO,QAAQ,UAAU,OAAO,UAAU,UAAU,iBAAiB,KAAK,GAAG,SAAS;CAEpG,MAAM,cAAc,OAAO;CAC3B,MAAM,UAAU,MAAM,WAAW;CACjC,MAAM,QAAQ,iBAAiB;CAC/B,MAAM,cAAc,OAAO,UAAU,YAAY,MAAM,SAAS,IAAI,QAAQ;CAC5E,MAAM,aAAa,QAAQ,MAAM,UAAU,cAAc;CACzD,MAAM,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO;CAC1C,MAAM,iBAAiB,MAAM,OAAiC,KAAK;CAEnE,MAAM,gBAAgB;EACpB,IAAI,mBAAmB,SAAS,OAAO,MAAM,UAAU,aACrD,MAAM,gBAAgB,YAAY;IAEnC;EAAC;EAAiB;EAAO;EAAY,CAAC;CAEzC,MAAM,iBAAiB,WAAW,OAAO,gCAAgC,GACtE,OAAO,2CAA2C,YACpD,CAAC;CACF,MAAM,aAAa,WAAW,OAAO,4BAA4B;GAC9D,OAAO,uCAAuC;GAC9C,OAAO,sCAAsC;EAC/C,CAAC;CAGF,MAAM,eADa,MAAM,SAAS,QAAQ,SAAS,CAAC,OAAO,MAAM,eAC5C,CAAW,MAAM;CAEtC,MAAM,cAAc,MAAmC;EACrD,IAAI,YAAY;EAChB,IAAI,SAAS,MAAM,UAAU,aAC3B,MAAM,gBAAgB,aAAa,EAAE;;CAIzC,MAAM,UACJ,qBAAA,UAAA,EAAA,UAAA,CACE,oBAAC,QAAD;EAAM,WAAW;EAAY,eAAA;EAAc,CAAA,EAC3C,oBAAC,QAAD,EAAA,UAAO,MAAY,CAAA,CAClB,EAAA,CAAA;CAGL,MAAM,YAAa,UAAU,sBAAc;CAC3C,MAAM,2BAA2B,eAAe,MAAM,aAAa,cAAc,KAAA,GAAW,QAAQ,GAAG;CAEvG,MAAM,iBAAiB,UACnB;EACE,KAAK;EACL,YAAY;EACZ,WAAW;EACX,UAAU;EACV,WAAW,MAAkC,WAAW,EAAE;EAC1D,aAAa,aAAa,SAAS,KAAA;EACnC,UAAU;EACX,GACD;EACE,GAAG;EACH,MAAM;EACN,WAAW;EACX,UAAU;EACV,UAAU,MAAiD;GACzD,EAAE,gBAAgB;GAClB,WAAW,EAAE;;EAEf,YAAY,MAAoD;GAC9D,IAAI,EAAE,QAAQ,SAAS;IACrB,EAAE,gBAAgB;IAClB,WAAW,EAAE;;;EAGZ;EACL,iBAAiB,cAAc,KAAA;EAC/B,gBAAgB,aAAa,SAAS,KAAA;EACtC,UAAU;EACX;CAEL,OACE,oBAAC,OAAD;EAAK,eAAa;EAAQ,WAAW,OAAO;YAC1C,oBAAC,WAAD,EAAW,GAAI,gBAAkB,CAAA;EAC7B,CAAA;;AAIV,iBAAiB,cAAc"}
1
+ {"version":3,"file":"SingleSelectItem.js","names":[],"sources":["../src/components/Dropdown/SingleSelect/utils.tsx","../src/components/Dropdown/SingleSelect/SingleSelectItem.tsx"],"sourcesContent":["import React from 'react';\n\nimport type { SingleSelectContextType } from './SingleSelect';\n\nexport const SingleSelectContext = React.createContext<SingleSelectContextType | null>(null);\n\nexport const useSingleSelect = (): SingleSelectContextType | null => React.useContext(SingleSelectContext);\n","import React, { useId } from 'react';\n\nimport classNames from 'classnames';\n\nimport type { AsChildSlotHandle } from '../../AsChildSlot';\n\nimport { useSingleSelect } from './utils';\nimport AsChildSlot from '../../AsChildSlot';\n\nimport styles from './styles.module.scss';\n\nexport interface SingleSelectItemProps extends Pick<React.ButtonHTMLAttributes<HTMLButtonElement>, 'disabled'> {\n /** The text to the singleSelectItem */\n text?: string;\n /** input id of the singleSelectItem */\n inputId?: string;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** When true, onclick and keyboard events will be passed to the child Button or AnchorLink. */\n asChild?: boolean;\n /** Only use when asChild is set to true and only pass one child */\n children?: React.ReactNode;\n /** Value for this singleSelectItem option - used by the parent wrapper to keep track of the context */\n value?: string;\n /** aria-describedby passthrough if needed */\n ['aria-describedby']?: string;\n /** Marks this option as initially selected */\n defaultSelected?: boolean;\n /** Ref that is passed to the component */\n ref?: React.Ref<HTMLElement | null>;\n}\n\nexport const SingleSelectItem: React.FC<SingleSelectItemProps> = props => {\n const { text, value, testId, asChild = false, children, disabled, defaultSelected, ref, ...rest } = props;\n\n const generatedId = useId();\n const inputId = props.inputId ?? generatedId;\n const group = useSingleSelect();\n const optionValue = typeof value === 'string' && value.length > 0 ? value : inputId;\n const isSelected = group ? group.value === optionValue : false;\n const isDisabled = !!disabled || !!group?.disabled;\n const asChildSlotRef = React.useRef<AsChildSlotHandle | null>(null);\n\n React.useEffect(() => {\n if (defaultSelected && group && typeof group.value === 'undefined') {\n group.onValueChange?.(optionValue);\n }\n }, [defaultSelected, group, optionValue]);\n\n const contentClasses = classNames(styles['single-select-item__content'], {\n [styles['single-select-item__content--disabled']]: isDisabled,\n });\n const dotClasses = classNames(styles['single-select-item__dot'], {\n [styles['single-select-item__dot--disabled']]: isDisabled,\n [styles['single-select-item__dot--checked']]: isSelected,\n });\n\n const childArray = React.Children.toArray(children).filter(React.isValidElement) as React.ReactElement[];\n const childElement = childArray[0] ?? null;\n\n const selectThis = (e?: React.SyntheticEvent): void => {\n if (isDisabled) return;\n if (group && group.value !== optionValue) {\n group.onValueChange?.(optionValue, e);\n }\n };\n\n const content = (\n <>\n <span className={dotClasses} aria-hidden />\n <span>{text}</span>\n </>\n );\n\n const Component = (asChild ? AsChildSlot : 'button') as React.ElementType;\n const childWithInjectedContent = childElement ? React.cloneElement(childElement, undefined, content) : null;\n\n const componentProps = asChild\n ? {\n ref: asChildSlotRef,\n elementRef: ref,\n className: contentClasses,\n disabled: isDisabled,\n onSelect: (e: React.SyntheticEvent): void => selectThis(e),\n ariaCurrent: isSelected ? 'true' : undefined,\n children: childWithInjectedContent,\n }\n : {\n ...rest,\n type: 'button' as const,\n className: contentClasses,\n disabled: isDisabled,\n onClick: (e: React.MouseEvent<HTMLButtonElement>): void => {\n e.preventDefault();\n selectThis(e);\n },\n onKeyDown: (e: React.KeyboardEvent<HTMLButtonElement>): void => {\n if (e.key === 'Enter') {\n e.preventDefault();\n selectThis(e);\n }\n },\n ref: ref,\n 'aria-disabled': isDisabled || undefined,\n 'aria-current': isSelected ? 'true' : undefined,\n children: content,\n };\n\n return (\n <div data-testid={testId} className={styles['single-select-item']}>\n <Component {...componentProps} />\n </div>\n );\n};\n\nSingleSelectItem.displayName = 'Dropdown.SingleSelectItem';\n\nexport default SingleSelectItem;\n"],"mappings":";;;;;;AAIA,IAAa,sBAAsB,MAAM,cAA8C,IAAI;AAE3F,IAAa,wBAAwD,MAAM,WAAW,mBAAmB;;;AC0BzG,IAAa,oBAAoD,UAAS;CACxE,MAAM,EAAE,MAAM,OAAO,QAAQ,UAAU,OAAO,UAAU,UAAU,iBAAiB,KAAK,GAAG,SAAS;CAEpG,MAAM,cAAc,MAAM;CAC1B,MAAM,UAAU,MAAM,WAAW;CACjC,MAAM,QAAQ,gBAAgB;CAC9B,MAAM,cAAc,OAAO,UAAU,YAAY,MAAM,SAAS,IAAI,QAAQ;CAC5E,MAAM,aAAa,QAAQ,MAAM,UAAU,cAAc;CACzD,MAAM,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO;CAC1C,MAAM,iBAAiB,MAAM,OAAiC,IAAI;CAElE,MAAM,gBAAgB;EACpB,IAAI,mBAAmB,SAAS,OAAO,MAAM,UAAU,aACrD,MAAM,gBAAgB,WAAW;CAErC,GAAG;EAAC;EAAiB;EAAO;CAAW,CAAC;CAExC,MAAM,iBAAiB,WAAW,OAAO,gCAAgC,GACtE,OAAO,2CAA2C,WACrD,CAAC;CACD,MAAM,aAAa,WAAW,OAAO,4BAA4B;GAC9D,OAAO,uCAAuC;GAC9C,OAAO,sCAAsC;CAChD,CAAC;CAGD,MAAM,eADa,MAAM,SAAS,QAAQ,QAAQ,EAAE,OAAO,MAAM,cAC5C,EAAW,MAAM;CAEtC,MAAM,cAAc,MAAmC;EACrD,IAAI,YAAY;EAChB,IAAI,SAAS,MAAM,UAAU,aAC3B,MAAM,gBAAgB,aAAa,CAAC;CAExC;CAEA,MAAM,UACJ,qBAAA,UAAA,EAAA,UAAA,CACE,oBAAC,QAAD;EAAM,WAAW;EAAY,eAAA;CAAa,CAAA,GAC1C,oBAAC,QAAD,EAAA,UAAO,KAAW,CAAA,CAClB,EAAA,CAAA;CAGJ,MAAM,YAAa,UAAU,sBAAc;CAC3C,MAAM,2BAA2B,eAAe,MAAM,aAAa,cAAc,KAAA,GAAW,OAAO,IAAI;CAEvG,MAAM,iBAAiB,UACnB;EACE,KAAK;EACL,YAAY;EACZ,WAAW;EACX,UAAU;EACV,WAAW,MAAkC,WAAW,CAAC;EACzD,aAAa,aAAa,SAAS,KAAA;EACnC,UAAU;CACZ,IACA;EACE,GAAG;EACH,MAAM;EACN,WAAW;EACX,UAAU;EACV,UAAU,MAAiD;GACzD,EAAE,eAAe;GACjB,WAAW,CAAC;EACd;EACA,YAAY,MAAoD;GAC9D,IAAI,EAAE,QAAQ,SAAS;IACrB,EAAE,eAAe;IACjB,WAAW,CAAC;GACd;EACF;EACK;EACL,iBAAiB,cAAc,KAAA;EAC/B,gBAAgB,aAAa,SAAS,KAAA;EACtC,UAAU;CACZ;CAEJ,OACE,oBAAC,OAAD;EAAK,eAAa;EAAQ,WAAW,OAAO;YAC1C,oBAAC,WAAD,EAAW,GAAI,eAAiB,CAAA;CAC7B,CAAA;AAET;AAEA,iBAAiB,cAAc"}