@nordhealth/components 4.11.0 → 4.12.1

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 (358) hide show
  1. package/README.md +8 -8
  2. package/custom-elements.json +4145 -3918
  3. package/lib/AutocompleteMixin-D8eiOxvO.js.map +1 -1
  4. package/lib/Avatar.js +1 -1
  5. package/lib/Avatar.js.map +1 -1
  6. package/lib/Badge.js.map +1 -1
  7. package/lib/Banner.js +1 -1
  8. package/lib/Banner.js.map +1 -1
  9. package/lib/Button.js +12 -1
  10. package/lib/Button.js.map +1 -1
  11. package/lib/ButtonGroup.js +1 -1
  12. package/lib/ButtonGroup.js.map +1 -1
  13. package/lib/Calendar-CL_eqbiT.js +2 -0
  14. package/lib/Calendar-CL_eqbiT.js.map +1 -0
  15. package/lib/Calendar.js +1 -1
  16. package/lib/Card.js +1 -1
  17. package/lib/Card.js.map +1 -1
  18. package/lib/Checkbox.js +1 -1
  19. package/lib/Checkbox.js.map +1 -1
  20. package/lib/CommandMenu.js +1 -1
  21. package/lib/CommandMenu.js.map +1 -1
  22. package/lib/CommandMenuAction.js +1 -1
  23. package/lib/CommandMenuAction.js.map +1 -1
  24. package/lib/DatePicker.js +1 -1
  25. package/lib/DatePicker.js.map +1 -1
  26. package/lib/DateSelectEvent.js +1 -1
  27. package/lib/DateSelectEvent.js.map +1 -1
  28. package/lib/DirectionController-ChvNGESZ.js.map +1 -1
  29. package/lib/Divider.js.map +1 -1
  30. package/lib/Drawer.js +1 -1
  31. package/lib/Drawer.js.map +1 -1
  32. package/lib/Dropdown.js +1 -1
  33. package/lib/Dropdown.js.map +1 -1
  34. package/lib/DropdownGroup.js.map +1 -1
  35. package/lib/DropdownItem-Cy6lHtoG.js +2 -0
  36. package/lib/DropdownItem-Cy6lHtoG.js.map +1 -0
  37. package/lib/DropdownItem.js +1 -1
  38. package/lib/DropdownItem.js.map +1 -1
  39. package/lib/EmptyState.js.map +1 -1
  40. package/lib/EventController-BBOmvfLa.js.map +1 -1
  41. package/lib/Fieldset.js +1 -1
  42. package/lib/Fieldset.js.map +1 -1
  43. package/lib/FocusableMixin-BlQLNPdJ.js.map +1 -1
  44. package/lib/Footer.js +1 -1
  45. package/lib/Footer.js.map +1 -1
  46. package/lib/FormAssociatedMixin-DFL7yabe.js.map +1 -1
  47. package/lib/FormDataController-OUt5L5uC.js.map +1 -1
  48. package/lib/{FormField-CUC_H-0e.js → FormField--eLuhPue.js} +2 -2
  49. package/lib/FormField--eLuhPue.js.map +1 -0
  50. package/lib/Header.js +1 -1
  51. package/lib/Header.js.map +1 -1
  52. package/lib/Icon.js +1 -1
  53. package/lib/Icon.js.map +1 -1
  54. package/lib/IconManager.js +1 -1
  55. package/lib/IconManager.js.map +1 -1
  56. package/lib/Input.js +1 -1
  57. package/lib/Input.js.map +1 -1
  58. package/lib/InputMixin-LetXsCyv.js.map +1 -1
  59. package/lib/KeyboardController.js +1 -1
  60. package/lib/KeyboardController.js.map +1 -1
  61. package/lib/Layout.js +1 -1
  62. package/lib/Layout.js.map +1 -1
  63. package/lib/LightDismissController-4pH8cdko.js.map +1 -1
  64. package/lib/LightDomController-DIwtVelV.js.map +1 -1
  65. package/lib/LightSlotController-Coyy4nqS.js.map +1 -1
  66. package/lib/LocalizeController.js +1 -1
  67. package/lib/LocalizeController.js.map +1 -1
  68. package/lib/Message.js +1 -1
  69. package/lib/Message.js.map +1 -1
  70. package/lib/Modal.js +1 -1
  71. package/lib/Modal.js.map +1 -1
  72. package/lib/ModalController.js +1 -1
  73. package/lib/ModalController.js.map +1 -1
  74. package/lib/NavGroup.js +1 -1
  75. package/lib/NavGroup.js.map +1 -1
  76. package/lib/NavItem.js +1 -1
  77. package/lib/NavItem.js.map +1 -1
  78. package/lib/{NavToggle-D-udBTou.js → NavToggle-DL74d1aQ.js} +2 -2
  79. package/lib/NavToggle-DL74d1aQ.js.map +1 -0
  80. package/lib/NavToggle.js +1 -1
  81. package/lib/Navigation.js +1 -1
  82. package/lib/Navigation.js.map +1 -1
  83. package/lib/Notification.js +1 -1
  84. package/lib/Notification.js.map +1 -1
  85. package/lib/NotificationGroup.js +1 -1
  86. package/lib/NotificationGroup.js.map +1 -1
  87. package/lib/NotificationMixin-DOUQsx7N.js.map +1 -1
  88. package/lib/Popout-k_ddK22Q.js +2 -0
  89. package/lib/Popout-k_ddK22Q.js.map +1 -0
  90. package/lib/Popout.js +1 -1
  91. package/lib/Progress.js +2 -0
  92. package/lib/Progress.js.map +1 -0
  93. package/lib/ProgressBar.js +1 -1
  94. package/lib/ProgressBar.js.map +1 -1
  95. package/lib/Qrcode.js.map +1 -1
  96. package/lib/Radio.js +1 -1
  97. package/lib/Radio.js.map +1 -1
  98. package/lib/Range.js +1 -1
  99. package/lib/Range.js.map +1 -1
  100. package/lib/ScrollbarController-BFC67Y2x.js +2 -0
  101. package/lib/ScrollbarController-BFC67Y2x.js.map +1 -0
  102. package/lib/SegmentedControl.js +1 -1
  103. package/lib/SegmentedControl.js.map +1 -1
  104. package/lib/SegmentedControlItem.js +44 -1
  105. package/lib/SegmentedControlItem.js.map +1 -1
  106. package/lib/Select.js +1 -1
  107. package/lib/Select.js.map +1 -1
  108. package/lib/SelectEvent.js.map +1 -1
  109. package/lib/ShortcutController-BIb3WGzH.js.map +1 -1
  110. package/lib/SizeMixin-CU9cLbLC.js.map +1 -1
  111. package/lib/Skeleton.js.map +1 -1
  112. package/lib/SlotController-Z6eG7LSZ.js.map +1 -1
  113. package/lib/Spinner.js +1 -1
  114. package/lib/Spinner.js.map +1 -1
  115. package/lib/Stack.js +1 -1
  116. package/lib/Stack.js.map +1 -1
  117. package/lib/Tab.js +1 -1
  118. package/lib/Tab.js.map +1 -1
  119. package/lib/TabGroup.js +1 -1
  120. package/lib/TabGroup.js.map +1 -1
  121. package/lib/TabPanel.js.map +1 -1
  122. package/lib/Table.js +1 -1
  123. package/lib/Table.js.map +1 -1
  124. package/lib/Tag.js +1 -1
  125. package/lib/Tag.js.map +1 -1
  126. package/lib/TagGroup.js +1 -1
  127. package/lib/TagGroup.js.map +1 -1
  128. package/lib/{TextField-C5gYzfOp.js → TextField-BdEdZ0_b.js} +2 -2
  129. package/lib/TextField-BdEdZ0_b.js.map +1 -0
  130. package/lib/TextSelectableMixin-Cfv__lHS.js.map +1 -1
  131. package/lib/Textarea.js +1 -1
  132. package/lib/Textarea.js.map +1 -1
  133. package/lib/Toast.js +1 -1
  134. package/lib/Toast.js.map +1 -1
  135. package/lib/ToastGroup.js.map +1 -1
  136. package/lib/Toggle.js +1 -1
  137. package/lib/Toggle.js.map +1 -1
  138. package/lib/Tooltip.js +1 -1
  139. package/lib/Tooltip.js.map +1 -1
  140. package/lib/TopBar.js +1 -1
  141. package/lib/TopBar.js.map +1 -1
  142. package/lib/VisuallyHidden.js.map +1 -1
  143. package/lib/bundle.js +80 -26
  144. package/lib/bundle.js.map +1 -1
  145. package/lib/collection-Dvg2XbxV.js.map +1 -1
  146. package/lib/cond-CI1KbneT.js.map +1 -1
  147. package/lib/date-adapter.js +1 -1
  148. package/lib/date-adapter.js.map +1 -1
  149. package/lib/dates-CAAlPKZi.js +2 -0
  150. package/lib/dates-CAAlPKZi.js.map +1 -0
  151. package/lib/en-us.js +1 -1
  152. package/lib/en-us.js.map +1 -1
  153. package/lib/events-Bv6wNHwJ.js.map +1 -1
  154. package/lib/fi-fi.js.map +1 -1
  155. package/lib/fsm-Bq5jMQrK.js.map +1 -1
  156. package/lib/index.js +1 -1
  157. package/lib/interface-checked-small-BtICPEsp.js.map +1 -1
  158. package/lib/interface-close-small-CnpAFMO3.js.map +1 -1
  159. package/lib/localization.js +1 -1
  160. package/lib/localization.js.map +1 -1
  161. package/lib/localization2.js +1 -1
  162. package/lib/localization2.js.map +1 -1
  163. package/lib/localization3.js +1 -1
  164. package/lib/localization3.js.map +1 -1
  165. package/lib/localization4.js +1 -1
  166. package/lib/localization4.js.map +1 -1
  167. package/lib/localization5.js +1 -1
  168. package/lib/localization5.js.map +1 -1
  169. package/lib/localization6.js +1 -1
  170. package/lib/localization6.js.map +1 -1
  171. package/lib/localization7.js.map +1 -1
  172. package/lib/localization8.js +1 -1
  173. package/lib/localization8.js.map +1 -1
  174. package/lib/localization9.js +1 -1
  175. package/lib/localization9.js.map +1 -1
  176. package/lib/number-Dg2vCfGd.js.map +1 -1
  177. package/lib/observe-D0n0zOfU.js.map +1 -1
  178. package/lib/positioning-DDh0UNgJ.js +2 -0
  179. package/lib/positioning-DDh0UNgJ.js.map +1 -0
  180. package/lib/react.d.ts +117 -110
  181. package/lib/src/avatar/Avatar.d.ts +6 -6
  182. package/lib/src/badge/Badge.d.ts +4 -4
  183. package/lib/src/banner/Banner.d.ts +3 -3
  184. package/lib/src/button/Button.d.ts +12 -11
  185. package/lib/src/button-group/ButtonGroup.d.ts +4 -4
  186. package/lib/src/calendar/Calendar.d.ts +6 -6
  187. package/lib/src/calendar/DateSelectEvent.d.ts +1 -1
  188. package/lib/src/card/Card.d.ts +3 -3
  189. package/lib/src/checkbox/Checkbox.d.ts +2 -2
  190. package/lib/src/command-menu/CommandMenu.d.ts +7 -6
  191. package/lib/src/command-menu/CommandMenuAction.d.ts +4 -4
  192. package/lib/src/command-menu/ICommandMenuAction.d.ts +1 -1
  193. package/lib/src/command-menu/KeyboardController.d.ts +3 -3
  194. package/lib/src/command-menu/SelectEvent.d.ts +2 -2
  195. package/lib/src/common/collection.d.ts +7 -7
  196. package/lib/src/common/controllers/BroadcastChannelController.d.ts +3 -3
  197. package/lib/src/common/controllers/DirectionController.d.ts +2 -2
  198. package/lib/src/common/controllers/EventController.d.ts +1 -1
  199. package/lib/src/common/controllers/FocusTrapController.d.ts +1 -1
  200. package/lib/src/common/controllers/FormDataController.d.ts +4 -4
  201. package/lib/src/common/controllers/LightDismissController.d.ts +3 -3
  202. package/lib/src/common/controllers/LightDomController.d.ts +3 -3
  203. package/lib/src/common/controllers/LightSlotController.d.ts +4 -4
  204. package/lib/src/common/controllers/PortalController.d.ts +3 -3
  205. package/lib/src/common/controllers/ResizeController.d.ts +1 -1
  206. package/lib/src/common/controllers/ScrollbarController.d.ts +1 -1
  207. package/lib/src/common/controllers/ShortcutController.d.ts +3 -3
  208. package/lib/src/common/controllers/SlotController.d.ts +1 -1
  209. package/lib/src/common/controllers/SwipeController.d.ts +7 -7
  210. package/lib/src/common/dates.d.ts +3 -3
  211. package/lib/src/common/decorators/observe.d.ts +1 -1
  212. package/lib/src/common/directives/cond.d.ts +1 -1
  213. package/lib/src/common/fsm.d.ts +2 -2
  214. package/lib/src/common/mixins/AutocompleteMixin.d.ts +2 -2
  215. package/lib/src/common/mixins/DraftComponentMixin.d.ts +1 -1
  216. package/lib/src/common/mixins/FloatingComponentMixin.d.ts +4 -4
  217. package/lib/src/common/mixins/FocusableMixin.d.ts +2 -2
  218. package/lib/src/common/mixins/FormAssociatedMixin.d.ts +6 -6
  219. package/lib/src/common/mixins/InputMixin.d.ts +1 -1
  220. package/lib/src/common/mixins/NotificationMixin.d.ts +2 -2
  221. package/lib/src/common/mixins/ReadonlyMixin.d.ts +1 -1
  222. package/lib/src/common/mixins/SizeMixin.d.ts +2 -2
  223. package/lib/src/common/mixins/TextSelectableMixin.d.ts +5 -5
  224. package/lib/src/common/positioning.d.ts +3 -3
  225. package/lib/src/common/ref.d.ts +1 -1
  226. package/lib/src/date-picker/DatePicker.d.ts +11 -11
  227. package/lib/src/date-picker/date-adapter.d.ts +1 -1
  228. package/lib/src/divider/Divider.d.ts +3 -3
  229. package/lib/src/drawer/Drawer.d.ts +4 -4
  230. package/lib/src/dropdown/Dropdown.d.ts +4 -6
  231. package/lib/src/dropdown-group/DropdownGroup.d.ts +2 -2
  232. package/lib/src/dropdown-item/DropdownItem.d.ts +4 -3
  233. package/lib/src/empty-state/EmptyState.d.ts +2 -2
  234. package/lib/src/fieldset/Fieldset.d.ts +3 -3
  235. package/lib/src/footer/Footer.d.ts +3 -3
  236. package/lib/src/header/Header.d.ts +3 -3
  237. package/lib/src/icon/Icon.d.ts +4 -4
  238. package/lib/src/index.d.ts +58 -57
  239. package/lib/src/input/Input.d.ts +3 -3
  240. package/lib/src/layout/Layout.d.ts +6 -6
  241. package/lib/src/localization/LocalizeController.d.ts +4 -3
  242. package/lib/src/localization/en-us.d.ts +9 -9
  243. package/lib/src/localization/fi-fi.d.ts +1 -1
  244. package/lib/src/localization/translation.d.ts +11 -11
  245. package/lib/src/message/Message.d.ts +3 -2
  246. package/lib/src/modal/Modal.d.ts +4 -4
  247. package/lib/src/modal/ModalController.d.ts +6 -6
  248. package/lib/src/nav-group/NavGroup.d.ts +3 -3
  249. package/lib/src/nav-item/NavItem.d.ts +3 -2
  250. package/lib/src/nav-toggle/NavToggle.d.ts +4 -4
  251. package/lib/src/navigation/Navigation.d.ts +2 -2
  252. package/lib/src/notification/Notification.d.ts +4 -4
  253. package/lib/src/notification-group/NotificationGroup.d.ts +2 -2
  254. package/lib/src/popout/Popout.d.ts +2 -2
  255. package/lib/src/progress/Progress.d.ts +68 -0
  256. package/lib/src/progress-bar/ProgressBar.d.ts +2 -2
  257. package/lib/src/qrcode/Qrcode.d.ts +3 -3
  258. package/lib/src/radio/Radio.d.ts +4 -4
  259. package/lib/src/range/Range.d.ts +2 -2
  260. package/lib/src/segmented-control/SegmentedControl.d.ts +2 -2
  261. package/lib/src/segmented-control-item/SegmentedControlItem.d.ts +5 -5
  262. package/lib/src/select/Select.d.ts +3 -3
  263. package/lib/src/skeleton/Skeleton.d.ts +3 -3
  264. package/lib/src/spinner/Spinner.d.ts +3 -3
  265. package/lib/src/stack/Stack.d.ts +6 -6
  266. package/lib/src/tab/Tab.d.ts +2 -2
  267. package/lib/src/tab-group/TabGroup.d.ts +3 -3
  268. package/lib/src/tab-panel/TabPanel.d.ts +2 -2
  269. package/lib/src/table/Table.d.ts +3 -3
  270. package/lib/src/tag/Tag.d.ts +5 -5
  271. package/lib/src/tag-group/TagGroup.d.ts +4 -4
  272. package/lib/src/textarea/Textarea.d.ts +3 -3
  273. package/lib/src/toast/Toast.d.ts +3 -3
  274. package/lib/src/toast-group/ToastGroup.d.ts +4 -4
  275. package/lib/src/toggle/Toggle.d.ts +3 -3
  276. package/lib/src/tooltip/Tooltip.d.ts +3 -3
  277. package/lib/src/top-bar/TopBar.d.ts +2 -2
  278. package/lib/src/visually-hidden/VisuallyHidden.d.ts +2 -2
  279. package/lib/translation.js.map +1 -1
  280. package/lib/tslib.es6-CmLYFWVC.js.map +1 -1
  281. package/lib/vue.d.ts +116 -108
  282. package/package.json +29 -123
  283. package/lib/Calendar-CYcI340m.js +0 -2
  284. package/lib/Calendar-CYcI340m.js.map +0 -1
  285. package/lib/DropdownItem-BheCmR9u.js +0 -2
  286. package/lib/DropdownItem-BheCmR9u.js.map +0 -1
  287. package/lib/FormField-CUC_H-0e.js.map +0 -1
  288. package/lib/NavToggle-D-udBTou.js.map +0 -1
  289. package/lib/Popout-DBLHeeXk.js +0 -2
  290. package/lib/Popout-DBLHeeXk.js.map +0 -1
  291. package/lib/ScrollbarController-C5CMxfb3.js +0 -2
  292. package/lib/ScrollbarController-C5CMxfb3.js.map +0 -1
  293. package/lib/TextField-C5gYzfOp.js.map +0 -1
  294. package/lib/dates-lbaNvUdr.js +0 -2
  295. package/lib/dates-lbaNvUdr.js.map +0 -1
  296. package/lib/positioning-CsfLhMSW.js +0 -2
  297. package/lib/positioning-CsfLhMSW.js.map +0 -1
  298. package/lib/src/avatar/Avatar.test.d.ts +0 -2
  299. package/lib/src/badge/Badge.test.d.ts +0 -5
  300. package/lib/src/banner/Banner.test.d.ts +0 -5
  301. package/lib/src/button/Button.test.d.ts +0 -7
  302. package/lib/src/button-group/ButtonGroup.test.d.ts +0 -6
  303. package/lib/src/calendar/Calendar.test.d.ts +0 -1
  304. package/lib/src/card/Card.test.d.ts +0 -6
  305. package/lib/src/checkbox/Checkbox.test.d.ts +0 -4
  306. package/lib/src/command-menu/CommandMenu.test.d.ts +0 -1
  307. package/lib/src/common/dates.test.d.ts +0 -1
  308. package/lib/src/date-picker/DatePicker.test.d.ts +0 -1
  309. package/lib/src/divider/Divider.test.d.ts +0 -2
  310. package/lib/src/drawer/Drawer.test.d.ts +0 -9
  311. package/lib/src/dropdown/Dropdown.test.d.ts +0 -8
  312. package/lib/src/dropdown-group/DropdownGroup.test.d.ts +0 -1
  313. package/lib/src/dropdown-item/DropdownItem.test.d.ts +0 -2
  314. package/lib/src/empty-state/EmptyState.test.d.ts +0 -3
  315. package/lib/src/fieldset/Fieldset.test.d.ts +0 -3
  316. package/lib/src/footer/Footer.test.d.ts +0 -4
  317. package/lib/src/header/Header.test.d.ts +0 -4
  318. package/lib/src/icon/Icon.test.d.ts +0 -1
  319. package/lib/src/input/Input.test.d.ts +0 -7
  320. package/lib/src/layout/Layout.test.d.ts +0 -26
  321. package/lib/src/localization/LocalizeController.test.d.ts +0 -1
  322. package/lib/src/localization/translation.test.d.ts +0 -1
  323. package/lib/src/message/Message.test.d.ts +0 -2
  324. package/lib/src/modal/Modal.test.d.ts +0 -7
  325. package/lib/src/nav-group/NavGroup.test.d.ts +0 -2
  326. package/lib/src/nav-item/NavItem.test.d.ts +0 -1
  327. package/lib/src/nav-toggle/NavToggle.test.d.ts +0 -2
  328. package/lib/src/navigation/Navigation.test.d.ts +0 -16
  329. package/lib/src/notification/Notification.test.d.ts +0 -1
  330. package/lib/src/notification-group/NotificationGroup.test.d.ts +0 -1
  331. package/lib/src/popout/Popout.test.d.ts +0 -9
  332. package/lib/src/progress-bar/ProgressBar.test.d.ts +0 -3
  333. package/lib/src/qrcode/Qrcode.test.d.ts +0 -2
  334. package/lib/src/radio/Radio.test.d.ts +0 -3
  335. package/lib/src/range/Range.test.d.ts +0 -2
  336. package/lib/src/segmented-control/SegmentedControl.test.d.ts +0 -8
  337. package/lib/src/segmented-control-item/SegmentedControlItem.test.d.ts +0 -3
  338. package/lib/src/select/Select.test.d.ts +0 -1
  339. package/lib/src/skeleton/Skeleton.test.d.ts +0 -3
  340. package/lib/src/spinner/Spinner.test.d.ts +0 -2
  341. package/lib/src/stack/Stack.test.d.ts +0 -4
  342. package/lib/src/tab/Tab.test.d.ts +0 -1
  343. package/lib/src/tab-group/TabGroup.test.d.ts +0 -9
  344. package/lib/src/tab-panel/TabPanel.test.d.ts +0 -1
  345. package/lib/src/table/Table.test.d.ts +0 -7
  346. package/lib/src/tag/Tag.test.d.ts +0 -7
  347. package/lib/src/tag-group/TagGroup.test.d.ts +0 -4
  348. package/lib/src/textarea/Textarea.test.d.ts +0 -3
  349. package/lib/src/toast/Toast.test.d.ts +0 -2
  350. package/lib/src/toast-group/ToastGroup.test.d.ts +0 -1
  351. package/lib/src/toggle/Toggle.test.d.ts +0 -3
  352. package/lib/src/tooltip/Tooltip.test.d.ts +0 -4
  353. package/lib/src/top-bar/TopBar.test.d.ts +0 -9
  354. package/lib/src/visually-hidden/VisuallyHidden.test.d.ts +0 -1
  355. package/lib/test-utils/commands/examples/command.d.ts +0 -13
  356. package/lib/test-utils/commands/mouse/command.d.ts +0 -7
  357. package/lib/test-utils/commands/select/command.d.ts +0 -5
  358. package/lib/test-utils/spy.d.ts +0 -13
package/lib/Tooltip.js CHANGED
@@ -1,2 +1,2 @@
1
- import{_ as t}from"./tslib.es6-CmLYFWVC.js";import{css as i,LitElement as e,html as s}from"lit";import{state as o,property as n,customElement as r}from"lit/decorators.js";import{c as a,l,o as d,f as h,s as c}from"./positioning-CsfLhMSW.js";import{S as p}from"./SlotController-Z6eG7LSZ.js";import{s as u}from"./Component-DSU3Qp0O.js";import{E as v}from"./EventController-BBOmvfLa.js";import{f as m}from"./fsm-Bq5jMQrK.js";import{o as y}from"./observe-D0n0zOfU.js";function b(t,i){const e=t.getAttribute(i);return e?e.split(/\s+/):[]}function f(t,i,e){t.setAttribute(i,e.join(" "))}const g=i`:host{--_n-tooltip-max-size:var(--n-tooltip-max-size, 50ch);--_n-tooltip-background:rgba(20, 20, 20, 0.95);--_n-tooltip-color:#fff;--_n-tooltip-key-border:rgba(255, 255, 255, 0.03);--_n-tooltip-key-background:rgba(255, 255, 255, 0.1);position:fixed;pointer-events:none;visibility:hidden;opacity:0;transition:opacity var(--n-transition-slowly),visibility var(--n-transition-slowly);transition-timing-function:ease;z-index:var(--n-index-popout)}.n-tooltip{gap:var(--n-space-s);font-family:var(--n-font-family);font-size:var(--n-font-size-xs);line-height:var(--n-line-height);color:var(--_n-tooltip-color);padding:calc(var(--n-space-s)/ 1.5) var(--n-space-s);background-color:var(--_n-tooltip-background);border-radius:var(--n-border-radius-s);word-break:break-word;max-inline-size:var(--_n-tooltip-max-size)}.n-tooltip,.n-tooltip-shortcut{display:flex;align-items:center}.n-tooltip-shortcut{gap:2px}::slotted([slot=shortcut]){box-sizing:border-box;margin:0;inline-size:var(--n-size-icon-m);block-size:var(--n-size-icon-m);border-radius:var(--n-border-radius-s);border:1px solid var(--_n-tooltip-key-border)!important;padding:1px!important;text-align:center;font-size:var(--n-font-size-xs);line-height:var(--n-line-height-tight);letter-spacing:-.5px;vertical-align:middle!important;background-color:var(--_n-tooltip-key-background)}[slot=shortcut]::slotted(nord-icon:not([size])){--_n-icon-size:var(--n-size-icon-s)}`;var x;function k(t,i){return Boolean(i.id)&&t.nodeType===Node.ELEMENT_NODE&&t.getAttribute("aria-describedby")===i.id}function w(t){var i;const e=null===(i=null==t?void 0:t.focusableRef)||void 0===i?void 0:i.value;return e&&"focusableRef"in e?w(e):e}const{transition:E}=m({hidden:{show:"waiting"},visible:{hide:"hidden",reposition:"positioning",show:"positioning"},waiting:{timeout:"positioning",hide:"hidden"},positioning:{positioned:"visible",hide:"hidden"}});let z=x=class extends e{constructor(){super(...arguments),this.shortcutSlot=new p(this,"shortcut"),this.events=new v(this),this.state="hidden",this.coords=[0,0],this.position="block-start",this.role="tooltip",this.id="",this.delay=500,this.updatePosition=t=>a(t,this,{strategy:"fixed",placement:l(this.position),middleware:[d(8),h(),c({padding:8})]}).then((({x:t,y:i})=>{this.coords=[t,i],this.state=E(this.state,"positioned")})),this.hideTooltip=()=>{this.state=E(this.state,"hide")},this.reposition=()=>{this.state=E(this.state,"reposition")},this.handleShow=t=>{const i=t.target;k(i,this)&&(this.currentElement=i,this.state=E(this.state,"show"))},this.handleHide=t=>{t.target===this.currentElement&&this.hideTooltip()},this.hideOnEscape=t=>{"Escape"===t.key&&this.hideTooltip()},this.addDescribedBy=()=>{const t=w(this.currentElement);t&&this.proxy&&(this.proxy.hidden=!0,this.proxy.id=this.id,this.proxy.textContent=this.textContent,t.insertAdjacentElement("afterend",this.proxy),function(t,i,e){const s=b(t,i);s.includes(e)||f(t,i,s.concat(e))}(t,"aria-describedby",this.id))},this.removeDescribedBy=()=>{const t=w(this.currentElement);t&&this.proxy&&(this.proxy.remove(),function(t,i,e){const s=b(t,i);s.includes(e)&&f(t,i,s.filter((t=>t!==e)))}(t,"aria-describedby",this.id))}}connectedCallback(){super.connectedCallback(),this.proxy=document.createElement("span");const t=this.getRootNode();this.events.listen(t,"keydown",this.hideOnEscape),this.events.listen(t,"mouseover",this.handleShow),this.events.listen(t,"focusin",this.handleShow),this.events.listen(t,"mouseout",this.handleHide),this.events.listen(t,"focusout",this.handleHide),this.events.listen(t,"click",this.handleHide,{capture:!0}),this.events.listen(window,"resize",this.reposition,{passive:!0}),this.events.listen(window,"scroll",this.reposition,{passive:!0})}disconnectedCallback(){var t;super.disconnectedCallback(),null===(t=this.proxy)||void 0===t||t.remove(),this.proxy=void 0}render(){return s`<div class="n-tooltip"><slot></slot><div class="n-tooltip-shortcut" ?hidden="${this.shortcutSlot.isEmpty}"><slot class="n-tooltip-key" name="shortcut"></slot></div></div>`}handleIdChange(){this.id||console.warn("NORD: The tooltip requires an id attribute and value")}handleStateChange(t){var i;switch(this.state){case"hidden":"waiting"===t&&this.timeoutId&&clearTimeout(this.timeoutId),this.removeDescribedBy(),this.currentElement=void 0,this.style.visibility="hidden",this.style.opacity="0";break;case"visible":{this.timeoutId=void 0,x.lastOpened=this,this.addDescribedBy();const[t,i]=this.coords;this.style.left=`${t}px`,this.style.top=`${i}px`,this.style.visibility="visible",this.style.opacity="1";break}case"waiting":this.timeoutId=setTimeout((()=>{this.state=E(this.state,"timeout")}),this.delay);break;case"positioning":x.lastOpened!==this&&(null===(i=x.lastOpened)||void 0===i||i.hideTooltip()),this.currentElement&&this.updatePosition(this.currentElement)}}};z.styles=[u,g],t([o()],z.prototype,"state",void 0),t([n({reflect:!0})],z.prototype,"position",void 0),t([n({reflect:!0})],z.prototype,"role",void 0),t([n({reflect:!0})],z.prototype,"id",void 0),t([n({reflect:!0,type:Number})],z.prototype,"delay",void 0),t([y("id")],z.prototype,"handleIdChange",null),t([y("state")],z.prototype,"handleStateChange",null),z=x=t([r("nord-tooltip")],z);var C=z;export{C as default};
1
+ import{_ as t}from"./tslib.es6-CmLYFWVC.js";import{c as i,l as e,o as s,f as o,s as n}from"./positioning-DDh0UNgJ.js";import{css as r,LitElement as a,html as l}from"lit";import{state as d,property as h,customElement as c}from"lit/decorators.js";import{E as p}from"./EventController-BBOmvfLa.js";import{S as u}from"./SlotController-Z6eG7LSZ.js";import{o as v}from"./observe-D0n0zOfU.js";import{f as m}from"./fsm-Bq5jMQrK.js";import{s as y}from"./Component-DSU3Qp0O.js";function b(t,i){const e=t.getAttribute(i);return e?e.split(/\s+/):[]}function f(t,i,e){t.setAttribute(i,e.join(" "))}const g=r`:host{--_n-tooltip-max-size:var(--n-tooltip-max-size, 50ch);--_n-tooltip-background:rgb(20, 20, 20, 0.95);--_n-tooltip-color:#fff;--_n-tooltip-key-border:rgb(255, 255, 255, 0.03);--_n-tooltip-key-background:rgb(255, 255, 255, 0.1);position:fixed;pointer-events:none;visibility:hidden;opacity:0;transition:opacity var(--n-transition-slowly),visibility var(--n-transition-slowly);transition-timing-function:ease;z-index:var(--n-index-popout)}.n-tooltip{gap:var(--n-space-s);font-family:var(--n-font-family);font-size:var(--n-font-size-xs);line-height:var(--n-line-height);color:var(--_n-tooltip-color);padding:calc(var(--n-space-s)/ 1.5) var(--n-space-s);background-color:var(--_n-tooltip-background);border-radius:var(--n-border-radius-s);word-break:break-word;max-inline-size:var(--_n-tooltip-max-size)}.n-tooltip,.n-tooltip-shortcut{display:flex;align-items:center}.n-tooltip-shortcut{gap:2px}::slotted([slot=shortcut]){box-sizing:border-box;margin:0;inline-size:var(--n-size-icon-m);block-size:var(--n-size-icon-m);border-radius:var(--n-border-radius-s);border:1px solid var(--_n-tooltip-key-border)!important;padding:1px!important;text-align:center;font-size:var(--n-font-size-xs);line-height:var(--n-line-height-tight);letter-spacing:-.5px;vertical-align:middle!important;background-color:var(--_n-tooltip-key-background)}[slot=shortcut]::slotted(nord-icon:not([size])){--_n-icon-size:var(--n-size-icon-s)}`;var x;function k(t,i){return Boolean(i.id)&&t.nodeType===Node.ELEMENT_NODE&&t.getAttribute("aria-describedby")===i.id}function w(t){var i;const e=null===(i=null==t?void 0:t.focusableRef)||void 0===i?void 0:i.value;return e&&"focusableRef"in e?w(e):e}const{transition:z}=m({hidden:{show:"waiting"},visible:{hide:"hidden",reposition:"positioning",show:"positioning"},waiting:{timeout:"positioning",hide:"hidden"},positioning:{positioned:"visible",hide:"hidden"}});let E=x=class extends a{constructor(){super(...arguments),this.shortcutSlot=new u(this,"shortcut"),this.events=new p(this),this.state="hidden",this.coords=[0,0],this.position="block-start",this.role="tooltip",this.id="",this.delay=500,this.updatePosition=t=>i(t,this,{strategy:"fixed",placement:e(this.position),middleware:[s(8),o(),n({padding:8})]}).then((({x:t,y:i})=>{this.coords=[t,i],this.state=z(this.state,"positioned")})),this.hideTooltip=()=>{this.state=z(this.state,"hide")},this.reposition=()=>{this.state=z(this.state,"reposition")},this.handleShow=t=>{const i=t.target;k(i,this)&&(this.currentElement=i,this.state=z(this.state,"show"))},this.handleHide=t=>{t.target===this.currentElement&&this.hideTooltip()},this.hideOnEscape=t=>{"Escape"===t.key&&this.hideTooltip()},this.addDescribedBy=()=>{const t=w(this.currentElement);t&&this.proxy&&(this.proxy.hidden=!0,this.proxy.id=this.id,this.proxy.textContent=this.textContent,t.insertAdjacentElement("afterend",this.proxy),function(t,i,e){const s=b(t,i);s.includes(e)||f(t,i,s.concat(e))}(t,"aria-describedby",this.id))},this.removeDescribedBy=()=>{const t=w(this.currentElement);t&&this.proxy&&(this.proxy.remove(),function(t,i,e){const s=b(t,i);s.includes(e)&&f(t,i,s.filter((t=>t!==e)))}(t,"aria-describedby",this.id))}}connectedCallback(){super.connectedCallback(),this.proxy=document.createElement("span");const t=this.getRootNode();this.events.listen(t,"keydown",this.hideOnEscape),this.events.listen(t,"mouseover",this.handleShow),this.events.listen(t,"focusin",this.handleShow),this.events.listen(t,"mouseout",this.handleHide),this.events.listen(t,"focusout",this.handleHide),this.events.listen(t,"click",this.handleHide,{capture:!0}),this.events.listen(window,"resize",this.reposition,{passive:!0}),this.events.listen(window,"scroll",this.reposition,{passive:!0})}disconnectedCallback(){var t;super.disconnectedCallback(),null===(t=this.proxy)||void 0===t||t.remove(),this.proxy=void 0}render(){return l`<div class="n-tooltip"><slot></slot><div class="n-tooltip-shortcut" ?hidden="${this.shortcutSlot.isEmpty}"><slot class="n-tooltip-key" name="shortcut"></slot></div></div>`}handleIdChange(){this.id||console.warn("NORD: The tooltip requires an id attribute and value")}handleStateChange(t){var i;switch(this.state){case"hidden":"waiting"===t&&this.timeoutId&&clearTimeout(this.timeoutId),this.removeDescribedBy(),this.currentElement=void 0,this.style.visibility="hidden",this.style.opacity="0";break;case"visible":{this.timeoutId=void 0,x.lastOpened=this,this.addDescribedBy();const[t,i]=this.coords;this.style.left=`${t}px`,this.style.top=`${i}px`,this.style.visibility="visible",this.style.opacity="1";break}case"waiting":this.timeoutId=setTimeout((()=>{this.state=z(this.state,"timeout")}),this.delay);break;case"positioning":x.lastOpened!==this&&(null===(i=x.lastOpened)||void 0===i||i.hideTooltip()),this.currentElement&&this.updatePosition(this.currentElement)}}};E.styles=[y,g],t([d()],E.prototype,"state",void 0),t([h({reflect:!0})],E.prototype,"position",void 0),t([h({reflect:!0})],E.prototype,"role",void 0),t([h({reflect:!0})],E.prototype,"id",void 0),t([h({reflect:!0,type:Number})],E.prototype,"delay",void 0),t([v("id")],E.prototype,"handleIdChange",null),t([v("state")],E.prototype,"handleStateChange",null),E=x=t([c("nord-tooltip")],E);var C=E;export{C as default};
2
2
  //# sourceMappingURL=Tooltip.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Tooltip.js","sources":["../src/common/attribute.ts","../src/tooltip/Tooltip.ts"],"sourcesContent":["function getTokens(element: Element, attr: string) {\n const value = element.getAttribute(attr)\n return value ? value.split(/\\s+/) : []\n}\n\nfunction setTokens(element: Element, attr: string, tokens: string[]) {\n element.setAttribute(attr, tokens.join(\" \"))\n}\n\n/**\n * Carefully adds a token to a space-separated attribute\n * Similar to classList, but for any attribute.\n * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMTokenList/add\n */\nexport function add(element: Element, attr: string, token: string) {\n const tokens = getTokens(element, attr)\n\n if (!tokens.includes(token)) {\n setTokens(element, attr, tokens.concat(token))\n }\n}\n\n/**\n * Carefully removes a token from a space-separated attribute.\n * Similar to classList, but for any attribute.\n * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMTokenList/remove\n */\nexport function remove(element: Element, attr: string, token: string) {\n const tokens = getTokens(element, attr)\n\n if (tokens.includes(token)) {\n setTokens(\n element,\n attr,\n tokens.filter(t => t !== token)\n )\n }\n}\n","import { LitElement, html } from \"lit\"\nimport { customElement, property, state } from \"lit/decorators.js\"\nimport { computePosition, flip, shift, offset } from \"@floating-ui/dom\"\n\nimport * as attr from \"../common/attribute.js\"\nimport type { FocusableMixinInterface } from \"../common/mixins/FocusableMixin.js\"\nimport { SlotController } from \"../common/controllers/SlotController.js\"\nimport componentStyle from \"../common/styles/Component.css\"\nimport style from \"./Tooltip.css\"\nimport { EventController } from \"../common/controllers/EventController.js\"\nimport { States, fsm } from \"../common/fsm.js\"\nimport { logicalToPhysical } from \"../common/positioning.js\"\nimport { observe } from \"../common/decorators/observe.js\"\n\n// @ts-expect-error we're being naughty and accessing a protected field!\n// however this means we always get the correct types,\n// and it will ensure this file is not forgotten about if focusable mixin ever changes\ntype FocusableElement = HTMLElement & Pick<FocusableMixinInterface, \"focusableRef\">\n\nfunction isElement(el: Node): el is Element {\n return el.nodeType === Node.ELEMENT_NODE\n}\n\nfunction referencesTooltip(node: Node, tooltip: Tooltip) {\n return Boolean(tooltip.id) && isElement(node) && node.getAttribute(\"aria-describedby\") === tooltip.id\n}\n\nfunction getFocusable(el?: FocusableElement): HTMLElement | undefined {\n const focusable = el?.focusableRef?.value as HTMLElement | FocusableElement | undefined\n\n if (focusable && \"focusableRef\" in focusable) {\n return getFocusable(focusable)\n }\n\n return focusable\n}\n\nconst { transition } = fsm({\n hidden: {\n show: \"waiting\",\n },\n visible: {\n hide: \"hidden\",\n reposition: \"positioning\",\n show: \"positioning\",\n },\n waiting: {\n timeout: \"positioning\",\n hide: \"hidden\",\n },\n positioning: {\n positioned: \"visible\",\n hide: \"hidden\",\n },\n})\n\ntype TooltipStates = States<typeof transition>\n\n/**\n * Tooltips are floating containers for displaying additional information\n * for the currently focused element. A tooltip can be useful when you want\n * to e.g. give a hint about an existing Command Menu shortcut.\n *\n * @status ready\n * @category overlay\n * @slot - The tooltip content\n * @slot shortcut - Optional slot that holds shortcut keys to access the subject\n * @cssprop [--n-tooltip-max-size=50ch] - Controls the maximum inline size, or width, of the tooltip.\n */\n@customElement(\"nord-tooltip\")\nexport default class Tooltip extends LitElement {\n static styles = [componentStyle, style]\n\n // tracks the last tooltip opened, so we can enforce only one is ever open at a time\n private static lastOpened?: Tooltip\n\n private shortcutSlot = new SlotController(this, \"shortcut\")\n private events = new EventController(this)\n\n // The current element which revealed the tooltip shown\n private currentElement?: FocusableElement\n private timeoutId?: ReturnType<typeof setTimeout>\n\n /**\n * the proxy element is for cases where the targetElement is a web component,\n * and the WC has a focusable child in its shadow root e.g. a button component.\n * in this case, when the tooltip is shown, we inject the proxy into targetElement's shadow root\n * and wire up aria-describedby from the focusable element to the proxy.\n * when the tooltip is hidden, we remove the proxy and remove the aria-describedby relationship.\n */\n private proxy?: HTMLSpanElement\n\n /**\n * The current state of the tooltip, dependent on the state machine\n */\n @state() private state: TooltipStates = \"hidden\"\n\n // The current coordinates for the tooltip\n private coords: [number, number] = [0, 0]\n\n /**\n * Control the position of the tooltip component.\n * When set to \"none\", the tooltip will be shown above\n * but accommodate for browser boundaries.\n */\n @property({ reflect: true }) position: \"block-end\" | \"block-start\" | \"inline-start\" | \"inline-end\" = \"block-start\"\n\n /**\n * The tooltip role, set on the component by default.\n */\n // eslint-disable-next-line lit/no-native-attributes\n @property({ reflect: true }) role = \"tooltip\"\n\n /**\n * The id for the active element to reference via aria-describedby.\n */\n // eslint-disable-next-line lit/no-native-attributes\n @property({ reflect: true }) id: string = \"\"\n\n /**\n * The delay in milliseconds before the tooltip is opened.\n */\n @property({ reflect: true, type: Number }) delay: number = 500\n\n /**\n * Apply all event listeners\n */\n connectedCallback() {\n super.connectedCallback()\n\n this.proxy = document.createElement(\"span\")\n\n const rootNode = this.getRootNode() as Document\n\n this.events.listen(rootNode, \"keydown\", this.hideOnEscape)\n\n // we treat mouseover and focusin the same, since they both show tooltip\n this.events.listen(rootNode, \"mouseover\", this.handleShow)\n this.events.listen(rootNode, \"focusin\", this.handleShow)\n\n // we treat focusout, mouseout, click the same, since they all hide tooltip\n this.events.listen(rootNode, \"mouseout\", this.handleHide)\n this.events.listen(rootNode, \"focusout\", this.handleHide)\n // we use event capture here to handle cases where e.g. a close button causes its ancestor to be removed from the DOM.\n // in this case the click event will never bubble up to the rootNode, so we never receive it, and the tooltip can remain open\n // by capturing, we get this event first, and can close the tooltip eagerly\n this.events.listen(rootNode, \"click\", this.handleHide, { capture: true })\n\n this.events.listen(window, \"resize\", this.reposition, { passive: true })\n this.events.listen(window, \"scroll\", this.reposition, { passive: true })\n }\n\n disconnectedCallback() {\n super.disconnectedCallback()\n\n this.proxy?.remove()\n this.proxy = undefined\n }\n\n render() {\n return html`\n <div class=\"n-tooltip\">\n <slot></slot>\n <div class=\"n-tooltip-shortcut\" ?hidden=${this.shortcutSlot.isEmpty}>\n <slot class=\"n-tooltip-key\" name=\"shortcut\"></slot>\n </div>\n </div>\n `\n }\n\n @observe(\"id\")\n protected handleIdChange() {\n if (!this.id) {\n // eslint-disable-next-line no-console\n console.warn(\"NORD: The tooltip requires an id attribute and value\")\n }\n }\n\n @observe(\"state\")\n private handleStateChange(prevState: TooltipStates) {\n switch (this.state) {\n case \"hidden\": {\n if (prevState === \"waiting\" && this.timeoutId) {\n clearTimeout(this.timeoutId)\n }\n\n this.removeDescribedBy()\n this.currentElement = undefined\n this.style.visibility = \"hidden\"\n this.style.opacity = \"0\"\n break\n }\n\n case \"visible\": {\n this.timeoutId = undefined\n Tooltip.lastOpened = this\n this.addDescribedBy()\n\n const [x, y] = this.coords\n\n // use physical properties here since floating-ui\n // works exclusively in physical dimensions\n // we do all the mapping in logicalToPhysical\n this.style.left = `${x}px`\n this.style.top = `${y}px`\n this.style.visibility = \"visible\"\n this.style.opacity = \"1\"\n break\n }\n\n case \"waiting\": {\n this.timeoutId = setTimeout(() => {\n this.state = transition(this.state, \"timeout\")\n }, this.delay)\n break\n }\n\n case \"positioning\": {\n if (Tooltip.lastOpened !== this) {\n Tooltip.lastOpened?.hideTooltip()\n }\n\n if (this.currentElement) {\n this.updatePosition(this.currentElement)\n }\n break\n }\n }\n }\n\n /**\n * Setting and updating the position of the tooltip\n */\n private updatePosition = (currentElement: HTMLElement) =>\n computePosition(currentElement, this, {\n strategy: \"fixed\",\n placement: logicalToPhysical(this.position),\n middleware: [\n offset(8),\n flip(),\n shift({\n padding: 8,\n }),\n ],\n }).then(({ x, y }) => {\n this.coords = [x, y]\n this.state = transition(this.state, \"positioned\")\n })\n\n private hideTooltip = () => {\n this.state = transition(this.state, \"hide\")\n }\n\n private reposition = () => {\n this.state = transition(this.state, \"reposition\")\n }\n\n private handleShow = (e: Event) => {\n const target = e.target as FocusableElement\n\n if (referencesTooltip(target, this)) {\n this.currentElement = target\n this.state = transition(this.state, \"show\")\n }\n }\n\n private handleHide = (e: Event) => {\n if (e.target === this.currentElement) {\n this.hideTooltip()\n }\n }\n\n private hideOnEscape = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") {\n this.hideTooltip()\n }\n }\n\n private addDescribedBy = () => {\n const focusable = getFocusable(this.currentElement)\n\n if (focusable && this.proxy) {\n this.proxy.hidden = true\n this.proxy.id = this.id\n this.proxy.textContent = this.textContent\n\n focusable.insertAdjacentElement(\"afterend\", this.proxy)\n attr.add(focusable, \"aria-describedby\", this.id)\n }\n }\n\n private removeDescribedBy = () => {\n const focusable = getFocusable(this.currentElement)\n\n if (focusable && this.proxy) {\n this.proxy.remove()\n attr.remove(focusable, \"aria-describedby\", this.id)\n }\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"nord-tooltip\": Tooltip\n }\n}\n"],"names":["getTokens","element","attr","value","getAttribute","split","setTokens","tokens","setAttribute","join","referencesTooltip","node","tooltip","Boolean","id","nodeType","Node","ELEMENT_NODE","getFocusable","el","focusable","_a","focusableRef","transition","fsm","hidden","show","visible","hide","reposition","waiting","timeout","positioning","positioned","Tooltip","Tooltip_1","LitElement","constructor","this","shortcutSlot","SlotController","events","EventController","state","coords","position","role","delay","updatePosition","currentElement","computePosition","strategy","placement","logicalToPhysical","middleware","offset","flip","shift","padding","then","x","y","hideTooltip","handleShow","e","target","handleHide","hideOnEscape","key","addDescribedBy","proxy","textContent","insertAdjacentElement","token","includes","concat","attr.add","removeDescribedBy","remove","filter","t","attr.remove","connectedCallback","super","document","createElement","rootNode","getRootNode","listen","capture","window","passive","disconnectedCallback","undefined","render","html","isEmpty","handleIdChange","console","warn","handleStateChange","prevState","timeoutId","clearTimeout","style","visibility","opacity","lastOpened","left","top","setTimeout","styles","componentStyle","__decorate","prototype","property","reflect","type","Number","observe","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"Tooltip.js","sources":["../src/common/attribute.ts","../src/tooltip/Tooltip.ts"],"sourcesContent":["function getTokens(element: Element, attr: string) {\n const value = element.getAttribute(attr)\n return value ? value.split(/\\s+/) : []\n}\n\nfunction setTokens(element: Element, attr: string, tokens: string[]) {\n element.setAttribute(attr, tokens.join(' '))\n}\n\n/**\n * Carefully adds a token to a space-separated attribute\n * Similar to classList, but for any attribute.\n * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMTokenList/add\n */\nexport function add(element: Element, attr: string, token: string) {\n const tokens = getTokens(element, attr)\n\n if (!tokens.includes(token)) {\n setTokens(element, attr, tokens.concat(token))\n }\n}\n\n/**\n * Carefully removes a token from a space-separated attribute.\n * Similar to classList, but for any attribute.\n * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMTokenList/remove\n */\nexport function remove(element: Element, attr: string, token: string) {\n const tokens = getTokens(element, attr)\n\n if (tokens.includes(token)) {\n setTokens(\n element,\n attr,\n tokens.filter(t => t !== token),\n )\n }\n}\n","import type { States } from '../common/fsm.js'\nimport type { FocusableMixinInterface } from '../common/mixins/FocusableMixin.js'\nimport { computePosition, flip, offset, shift } from '@floating-ui/dom'\n\nimport { html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport * as attr from '../common/attribute.js'\nimport { EventController } from '../common/controllers/EventController.js'\nimport { SlotController } from '../common/controllers/SlotController.js'\nimport { observe } from '../common/decorators/observe.js'\nimport { fsm } from '../common/fsm.js'\nimport { logicalToPhysical } from '../common/positioning.js'\nimport componentStyle from '../common/styles/Component.css'\nimport style from './Tooltip.css'\n\n// @ts-expect-error we're being naughty and accessing a protected field!\n// however this means we always get the correct types,\n// and it will ensure this file is not forgotten about if focusable mixin ever changes\ntype FocusableElement = HTMLElement & Pick<FocusableMixinInterface, 'focusableRef'>\n\nfunction isElement(el: Node): el is Element {\n return el.nodeType === Node.ELEMENT_NODE\n}\n\nfunction referencesTooltip(node: Node, tooltip: Tooltip) {\n return Boolean(tooltip.id) && isElement(node) && node.getAttribute('aria-describedby') === tooltip.id\n}\n\nfunction getFocusable(el?: FocusableElement): HTMLElement | undefined {\n const focusable = el?.focusableRef?.value as HTMLElement | FocusableElement | undefined\n\n if (focusable && 'focusableRef' in focusable) {\n return getFocusable(focusable)\n }\n\n return focusable\n}\n\nconst { transition } = fsm({\n hidden: {\n show: 'waiting',\n },\n visible: {\n hide: 'hidden',\n reposition: 'positioning',\n show: 'positioning',\n },\n waiting: {\n timeout: 'positioning',\n hide: 'hidden',\n },\n positioning: {\n positioned: 'visible',\n hide: 'hidden',\n },\n})\n\ntype TooltipStates = States<typeof transition>\n\n/**\n * Tooltips are floating containers for displaying additional information\n * for the currently focused element. A tooltip can be useful when you want\n * to e.g. give a hint about an existing Command Menu shortcut.\n *\n * @status ready\n * @category overlay\n * @slot - The tooltip content\n * @slot shortcut - Optional slot that holds shortcut keys to access the subject\n * @cssprop [--n-tooltip-max-size=50ch] - Controls the maximum inline size, or width, of the tooltip.\n */\n@customElement('nord-tooltip')\nexport default class Tooltip extends LitElement {\n static styles = [componentStyle, style]\n\n // tracks the last tooltip opened, so we can enforce only one is ever open at a time\n private static lastOpened?: Tooltip\n\n private shortcutSlot = new SlotController(this, 'shortcut')\n private events = new EventController(this)\n\n // The current element which revealed the tooltip shown\n private currentElement?: FocusableElement\n private timeoutId?: ReturnType<typeof setTimeout>\n\n /**\n * the proxy element is for cases where the targetElement is a web component,\n * and the WC has a focusable child in its shadow root e.g. a button component.\n * in this case, when the tooltip is shown, we inject the proxy into targetElement's shadow root\n * and wire up aria-describedby from the focusable element to the proxy.\n * when the tooltip is hidden, we remove the proxy and remove the aria-describedby relationship.\n */\n private proxy?: HTMLSpanElement\n\n /**\n * The current state of the tooltip, dependent on the state machine\n */\n @state() private state: TooltipStates = 'hidden'\n\n // The current coordinates for the tooltip\n private coords: [number, number] = [0, 0]\n\n /**\n * Control the position of the tooltip component.\n * When set to \"none\", the tooltip will be shown above\n * but accommodate for browser boundaries.\n */\n @property({ reflect: true }) position: 'block-end' | 'block-start' | 'inline-start' | 'inline-end' = 'block-start'\n\n /**\n * The tooltip role, set on the component by default.\n */\n\n @property({ reflect: true }) role = 'tooltip'\n\n /**\n * The id for the active element to reference via aria-describedby.\n */\n\n @property({ reflect: true }) id: string = ''\n\n /**\n * The delay in milliseconds before the tooltip is opened.\n */\n @property({ reflect: true, type: Number }) delay: number = 500\n\n /**\n * Apply all event listeners\n */\n connectedCallback() {\n super.connectedCallback()\n\n this.proxy = document.createElement('span')\n\n const rootNode = this.getRootNode() as Document\n\n this.events.listen(rootNode, 'keydown', this.hideOnEscape)\n\n // we treat mouseover and focusin the same, since they both show tooltip\n this.events.listen(rootNode, 'mouseover', this.handleShow)\n this.events.listen(rootNode, 'focusin', this.handleShow)\n\n // we treat focusout, mouseout, click the same, since they all hide tooltip\n this.events.listen(rootNode, 'mouseout', this.handleHide)\n this.events.listen(rootNode, 'focusout', this.handleHide)\n // we use event capture here to handle cases where e.g. a close button causes its ancestor to be removed from the DOM.\n // in this case the click event will never bubble up to the rootNode, so we never receive it, and the tooltip can remain open\n // by capturing, we get this event first, and can close the tooltip eagerly\n this.events.listen(rootNode, 'click', this.handleHide, { capture: true })\n\n this.events.listen(window, 'resize', this.reposition, { passive: true })\n this.events.listen(window, 'scroll', this.reposition, { passive: true })\n }\n\n disconnectedCallback() {\n super.disconnectedCallback()\n\n this.proxy?.remove()\n this.proxy = undefined\n }\n\n render() {\n return html`\n <div class=\"n-tooltip\">\n <slot></slot>\n <div class=\"n-tooltip-shortcut\" ?hidden=${this.shortcutSlot.isEmpty}>\n <slot class=\"n-tooltip-key\" name=\"shortcut\"></slot>\n </div>\n </div>\n `\n }\n\n @observe('id')\n protected handleIdChange() {\n if (!this.id) {\n console.warn('NORD: The tooltip requires an id attribute and value')\n }\n }\n\n @observe('state')\n private handleStateChange(prevState: TooltipStates) {\n switch (this.state) {\n case 'hidden': {\n if (prevState === 'waiting' && this.timeoutId) {\n clearTimeout(this.timeoutId)\n }\n\n this.removeDescribedBy()\n this.currentElement = undefined\n this.style.visibility = 'hidden'\n this.style.opacity = '0'\n break\n }\n\n case 'visible': {\n this.timeoutId = undefined\n Tooltip.lastOpened = this\n this.addDescribedBy()\n\n const [x, y] = this.coords\n\n // use physical properties here since floating-ui\n // works exclusively in physical dimensions\n // we do all the mapping in logicalToPhysical\n this.style.left = `${x}px`\n this.style.top = `${y}px`\n this.style.visibility = 'visible'\n this.style.opacity = '1'\n break\n }\n\n case 'waiting': {\n this.timeoutId = setTimeout(() => {\n this.state = transition(this.state, 'timeout')\n }, this.delay)\n break\n }\n\n case 'positioning': {\n if (Tooltip.lastOpened !== this) {\n Tooltip.lastOpened?.hideTooltip()\n }\n\n if (this.currentElement) {\n this.updatePosition(this.currentElement)\n }\n break\n }\n }\n }\n\n /**\n * Setting and updating the position of the tooltip\n */\n private updatePosition = (currentElement: HTMLElement) =>\n computePosition(currentElement, this, {\n strategy: 'fixed',\n placement: logicalToPhysical(this.position),\n middleware: [\n offset(8),\n flip(),\n shift({\n padding: 8,\n }),\n ],\n }).then(({ x, y }) => {\n this.coords = [x, y]\n this.state = transition(this.state, 'positioned')\n })\n\n private hideTooltip = () => {\n this.state = transition(this.state, 'hide')\n }\n\n private reposition = () => {\n this.state = transition(this.state, 'reposition')\n }\n\n private handleShow = (e: Event) => {\n const target = e.target as FocusableElement\n\n if (referencesTooltip(target, this)) {\n this.currentElement = target\n this.state = transition(this.state, 'show')\n }\n }\n\n private handleHide = (e: Event) => {\n if (e.target === this.currentElement) {\n this.hideTooltip()\n }\n }\n\n private hideOnEscape = (e: KeyboardEvent) => {\n if (e.key === 'Escape') {\n this.hideTooltip()\n }\n }\n\n private addDescribedBy = () => {\n const focusable = getFocusable(this.currentElement)\n\n if (focusable && this.proxy) {\n this.proxy.hidden = true\n this.proxy.id = this.id\n this.proxy.textContent = this.textContent\n\n focusable.insertAdjacentElement('afterend', this.proxy)\n attr.add(focusable, 'aria-describedby', this.id)\n }\n }\n\n private removeDescribedBy = () => {\n const focusable = getFocusable(this.currentElement)\n\n if (focusable && this.proxy) {\n this.proxy.remove()\n attr.remove(focusable, 'aria-describedby', this.id)\n }\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nord-tooltip': Tooltip\n }\n}\n"],"names":["getTokens","element","attr","value","getAttribute","split","setTokens","tokens","setAttribute","join","referencesTooltip","node","tooltip","Boolean","id","nodeType","Node","ELEMENT_NODE","getFocusable","el","focusable","_a","focusableRef","transition","fsm","hidden","show","visible","hide","reposition","waiting","timeout","positioning","positioned","Tooltip","Tooltip_1","LitElement","constructor","this","shortcutSlot","SlotController","events","EventController","state","coords","position","role","delay","updatePosition","currentElement","computePosition","strategy","placement","logicalToPhysical","middleware","offset","flip","shift","padding","then","x","y","hideTooltip","handleShow","e","target","handleHide","hideOnEscape","key","addDescribedBy","proxy","textContent","insertAdjacentElement","token","includes","concat","attr.add","removeDescribedBy","remove","filter","t","attr.remove","connectedCallback","super","document","createElement","rootNode","getRootNode","listen","capture","window","passive","disconnectedCallback","undefined","render","html","isEmpty","handleIdChange","console","warn","handleStateChange","prevState","timeoutId","clearTimeout","style","visibility","opacity","lastOpened","left","top","setTimeout","styles","componentStyle","__decorate","prototype","property","reflect","type","Number","observe","customElement"],"mappings":"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"}
package/lib/TopBar.js CHANGED
@@ -1,2 +1,2 @@
1
- import{_ as n}from"./tslib.es6-CmLYFWVC.js";import{css as o,LitElement as t,html as r}from"lit";import{customElement as a}from"lit/decorators.js";import{s as e}from"./Component-DSU3Qp0O.js";const i=o`:host{background:var(--n-color-accent-secondary);block-size:var(--n-size-top-bar);display:flex;align-items:center;color:var(--n-color-text-on-accent);font-weight:var(--n-font-weight-active);padding-inline-start:calc(var(--n-space-m) + var(--_n-header-gutter,0px));padding-inline-end:var(--n-space-s);gap:var(--n-space-xs)}slot{display:block}slot:not([name]){flex:1}slot[name=end]{display:flex;margin-inline-start:auto;align-items:center;gap:1px}::slotted(:is(h1, h2, h3, h4, h5, h6, p, em, span)){color:var(--n-color-text-on-accent)!important;font-size:var(--n-font-size-m)!important;line-height:var(--n-line-height)!important;font-weight:var(--n-font-weight-active)!important;font-style:normal!important}::slotted(:is(nord-avatar, nord-dropdown)){--n-avatar-color:var(--n-color-accent-secondary);--n-avatar-box-shadow:inset 0 0 0 100px rgba(255, 255, 255, 0.2),0 0 0 1px rgba(255, 255, 255, 0.6)}::slotted(nord-input){--n-input-background:rgba(255, 255, 255, 0.15);--n-input-border-color:rgba(255, 255, 255, 0.4);--n-input-placeholder-color:rgba(255, 255, 255, 0.85);--n-input-icon-color:rgba(255, 255, 255, 0.85);--n-input-color:#fff;transition:inline-size var(--n-transition-slowly);inline-size:min(400px,100%)}::slotted(nord-input:hover){--n-input-border-color:rgba(255, 255, 255, 0.4);--n-input-placeholder-color:rgb(255, 255, 255);--n-input-icon-color:rgb(255, 255, 255)}::slotted(nord-input:focus){--n-input-background:var(--n-color-surface);--n-input-border-color:var(--n-color-surface);--n-input-placeholder-color:var(--n-color-text-weaker);--n-input-icon-color:var(--n-color-icon);--n-input-color:var(--n-color-text);--n-input-font-size:var(--n-font-size-l);inline-size:min(745px,100%)}::slotted(nord-dropdown){--n-button-gap:calc(var(--n-space-xs) / 2);--n-button-background-color:transparent;--n-button-toggle-icon-color:rgba(255, 255, 255, 0.85);--n-button-padding-inline:calc(var(--n-space-s) + 2px);--n-button-overflow:visible}::slotted(nord-dropdown:is(:hover, [open], :focus-within)){--n-button-background-color:rgba(255, 255, 255, 0.18)}`;let l=class extends t{render(){return r`<slot></slot><slot name="end"></slot>`}};l.styles=[e,i],l=n([a("nord-top-bar")],l);var s=l;export{s as default};
1
+ import{_ as n}from"./tslib.es6-CmLYFWVC.js";import{css as o,LitElement as t,html as r}from"lit";import{customElement as e}from"lit/decorators.js";import{s as a}from"./Component-DSU3Qp0O.js";const i=o`:host{background:var(--n-color-accent-secondary);block-size:var(--n-size-top-bar);display:flex;align-items:center;color:var(--n-color-text-on-accent);font-weight:var(--n-font-weight-active);padding-inline-start:calc(var(--n-space-m) + var(--_n-header-gutter,0px));padding-inline-end:var(--n-space-s);gap:var(--n-space-xs)}slot{display:block}slot:not([name]){flex:1}slot[name=end]{display:flex;margin-inline-start:auto;align-items:center;gap:1px}::slotted(:is(h1, h2, h3, h4, h5, h6, p, em, span)){color:var(--n-color-text-on-accent)!important;font-size:var(--n-font-size-m)!important;line-height:var(--n-line-height)!important;font-weight:var(--n-font-weight-active)!important;font-style:normal!important}::slotted(:is(nord-avatar, nord-dropdown)){--n-avatar-color:var(--n-color-accent-secondary);--n-avatar-box-shadow:inset 0 0 0 100px rgb(255, 255, 255, 0.2),0 0 0 1px rgb(255, 255, 255, 0.6)}::slotted(nord-input){--n-input-background:rgb(255, 255, 255, 0.15);--n-input-border-color:rgb(255, 255, 255, 0.4);--n-input-placeholder-color:rgb(255, 255, 255, 0.85);--n-input-icon-color:rgb(255, 255, 255, 0.85);--n-input-color:#fff;transition:inline-size var(--n-transition-slowly);inline-size:min(400px,100%)}::slotted(nord-input:hover){--n-input-border-color:rgb(255, 255, 255, 0.4);--n-input-placeholder-color:rgb(255, 255, 255);--n-input-icon-color:rgb(255, 255, 255)}::slotted(nord-input:focus){--n-input-background:var(--n-color-surface);--n-input-border-color:var(--n-color-surface);--n-input-placeholder-color:var(--n-color-text-weaker);--n-input-icon-color:var(--n-color-icon);--n-input-color:var(--n-color-text);--n-input-font-size:var(--n-font-size-l);inline-size:min(745px,100%)}::slotted(nord-dropdown){--n-button-gap:calc(var(--n-space-xs) / 2);--n-button-background-color:transparent;--n-button-toggle-icon-color:rgb(255, 255, 255, 0.85);--n-button-padding-inline:calc(var(--n-space-s) + 2px);--n-button-overflow:visible}::slotted(nord-dropdown:is(:hover, [open], :focus-within)){--n-button-background-color:rgb(255, 255, 255, 0.18)}`;let l=class extends t{render(){return r`<slot></slot><slot name="end"></slot>`}};l.styles=[a,i],l=n([e("nord-top-bar")],l);var s=l;export{s as default};
2
2
  //# sourceMappingURL=TopBar.js.map
package/lib/TopBar.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"TopBar.js","sources":["../src/top-bar/TopBar.ts"],"sourcesContent":["import { LitElement, html } from \"lit\"\nimport { customElement } from \"lit/decorators.js\"\n\nimport componentStyle from \"../common/styles/Component.css\"\nimport style from \"./TopBar.css\"\n\n/**\n * Top bar is a header component that is always visible at the top of the interface. Top bar allows functionality such as search and contextual menus to be placed at the top of the interface.\n *\n * @status ready\n * @category structure\n * @slot - Used for the main content of the top bar. We recommend placing your application’s global search functionality into this slot.\n * @slot end - Optional slot for menus, buttons, toggles, etc.\n */\n@customElement(\"nord-top-bar\")\nexport default class TopBar extends LitElement {\n static styles = [componentStyle, style]\n\n render() {\n return html`\n <slot></slot>\n <slot name=\"end\"></slot>\n `\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"nord-top-bar\": TopBar\n }\n}\n"],"names":["TopBar","LitElement","render","html","styles","componentStyle","style","__decorate","customElement"],"mappings":"itEAee,IAAMA,EAAN,cAAqBC,EAGlC,MAAAC,GACE,OAAOC,CAAI,uCAIZ,GAPMH,EAAAI,OAAS,CAACC,EAAgBC,GADdN,EAAMO,EAAA,CAD1BC,EAAc,iBACMR,SAAAA"}
1
+ {"version":3,"file":"TopBar.js","sources":["../src/top-bar/TopBar.ts"],"sourcesContent":["import { html, LitElement } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\nimport componentStyle from '../common/styles/Component.css'\nimport style from './TopBar.css'\n\n/**\n * Top bar is a header component that is always visible at the top of the interface. Top bar allows functionality such as search and contextual menus to be placed at the top of the interface.\n *\n * @status ready\n * @category structure\n * @slot - Used for the main content of the top bar. We recommend placing your application’s global search functionality into this slot.\n * @slot end - Optional slot for menus, buttons, toggles, etc.\n */\n@customElement('nord-top-bar')\nexport default class TopBar extends LitElement {\n static styles = [componentStyle, style]\n\n render() {\n return html`\n <slot></slot>\n <slot name=\"end\"></slot>\n `\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nord-top-bar': TopBar\n }\n}\n"],"names":["TopBar","LitElement","render","html","styles","componentStyle","style","__decorate","customElement"],"mappings":"wsEAee,IAAMA,EAAN,cAAqBC,EAGlC,MAAAC,GACE,OAAOC,CAAI,uCAIZ,GAPMH,EAAAI,OAAS,CAACC,EAAgBC,GADdN,EAAMO,EAAA,CAD1BC,EAAc,iBACMR,SAAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"VisuallyHidden.js","sources":["../src/visually-hidden/VisuallyHidden.ts"],"sourcesContent":["import { LitElement, html } from \"lit\"\nimport { customElement } from \"lit/decorators.js\"\nimport style from \"./VisuallyHidden.css\"\n\n/**\n * Visually hidden is used when an element needs to be available\n * to assistive technologies like screen readers, but be otherwise\n * hidden.\n *\n * @status ready\n * @category text\n * @slot - The visually hidden content.\n */\n@customElement(\"nord-visually-hidden\")\nexport default class VisuallyHidden extends LitElement {\n static styles = style\n\n render() {\n return html`<slot></slot>`\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"nord-visually-hidden\": VisuallyHidden\n }\n}\n"],"names":["VisuallyHidden","LitElement","render","html","styles","style","__decorate","customElement"],"mappings":"yXAce,IAAMA,EAAN,cAA6BC,EAG1C,MAAAC,GACE,OAAOC,CAAI,eACZ,GAJMH,EAAMI,OAAGC,EADGL,EAAcM,EAAA,CADlCC,EAAc,yBACMP,SAAAA"}
1
+ {"version":3,"file":"VisuallyHidden.js","sources":["../src/visually-hidden/VisuallyHidden.ts"],"sourcesContent":["import { html, LitElement } from 'lit'\nimport { customElement } from 'lit/decorators.js'\nimport style from './VisuallyHidden.css'\n\n/**\n * Visually hidden is used when an element needs to be available\n * to assistive technologies like screen readers, but be otherwise\n * hidden.\n *\n * @status ready\n * @category text\n * @slot - The visually hidden content.\n */\n@customElement('nord-visually-hidden')\nexport default class VisuallyHidden extends LitElement {\n static styles = style\n\n render() {\n return html`<slot></slot>`\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nord-visually-hidden': VisuallyHidden\n }\n}\n"],"names":["VisuallyHidden","LitElement","render","html","styles","style","__decorate","customElement"],"mappings":"yXAce,IAAMA,EAAN,cAA6BC,EAG1C,MAAAC,GACE,OAAOC,CAAI,eACZ,GAJMH,EAAMI,OAAGC,EADGL,EAAcM,EAAA,CADlCC,EAAc,yBACMP,SAAAA"}