@equinor/eds-core-react 0.15.0 → 0.16.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 (401) hide show
  1. package/dist/core-react.cjs.js +7588 -17138
  2. package/dist/esm/components/Accordion/Accordion.js +28 -0
  3. package/dist/esm/components/Accordion/Accordion.tokens.js +112 -0
  4. package/dist/esm/components/Accordion/AccordionHeader.js +137 -0
  5. package/dist/esm/components/Accordion/AccordionHeaderTitle.js +30 -0
  6. package/dist/esm/components/Accordion/AccordionItem.js +47 -0
  7. package/dist/esm/components/Accordion/AccordionPanel.js +40 -0
  8. package/dist/esm/components/Accordion/index.js +17 -0
  9. package/dist/esm/components/Avatar/Avatar.js +40 -0
  10. package/dist/esm/components/Avatar/Avatar.tokens.js +13 -0
  11. package/dist/esm/components/Banner/Banner.js +51 -0
  12. package/dist/esm/components/Banner/Banner.tokens.js +86 -0
  13. package/dist/esm/components/Banner/BannerActions.js +36 -0
  14. package/dist/esm/components/Banner/BannerIcon.js +41 -0
  15. package/dist/esm/components/Banner/BannerMessage.js +25 -0
  16. package/dist/esm/components/Banner/index.js +14 -0
  17. package/dist/esm/components/Breadcrumbs/Breadcrumb.js +49 -0
  18. package/dist/esm/components/Breadcrumbs/Breadcrumbs.js +98 -0
  19. package/dist/esm/components/Breadcrumbs/Breadcrumbs.tokens.js +39 -0
  20. package/dist/esm/components/Breadcrumbs/index.js +8 -0
  21. package/dist/esm/components/Button/Button.js +106 -0
  22. package/dist/esm/components/Button/InnerFullWidth.js +26 -0
  23. package/dist/esm/components/Button/tokens/button.js +127 -0
  24. package/dist/esm/components/Button/tokens/contained.js +86 -0
  25. package/dist/esm/components/Button/tokens/ghost.js +84 -0
  26. package/dist/esm/components/Button/tokens/icon.js +123 -0
  27. package/dist/esm/components/Button/tokens/index.js +27 -0
  28. package/dist/esm/components/Button/tokens/outlined.js +111 -0
  29. package/dist/esm/components/Card/Card.js +39 -0
  30. package/dist/esm/components/Card/Card.tokens.js +54 -0
  31. package/dist/esm/components/Card/CardActions.js +36 -0
  32. package/dist/esm/components/Card/CardContent.js +24 -0
  33. package/dist/esm/components/Card/CardHeader.js +25 -0
  34. package/dist/esm/components/Card/CardHeaderTitle.js +21 -0
  35. package/dist/esm/components/Card/CardMedia.js +30 -0
  36. package/dist/esm/components/Card/index.js +20 -0
  37. package/dist/esm/components/Checkbox/Checkbox.js +44 -0
  38. package/dist/esm/components/Checkbox/Checkbox.tokens.js +91 -0
  39. package/dist/esm/components/Checkbox/Input.js +117 -0
  40. package/dist/esm/components/Chip/Chip.js +126 -0
  41. package/dist/esm/components/Chip/Chip.tokens.js +148 -0
  42. package/dist/esm/components/Chip/Icon.js +31 -0
  43. package/dist/esm/components/Dialog/Actions.js +24 -0
  44. package/dist/esm/components/Dialog/CustomContent.js +40 -0
  45. package/dist/esm/components/Dialog/Dialog.js +31 -0
  46. package/dist/esm/components/Dialog/Dialog.tokens.js +73 -0
  47. package/dist/esm/components/Dialog/Title.js +35 -0
  48. package/dist/esm/components/Dialog/index.js +14 -0
  49. package/dist/esm/components/Divider/Divider.js +32 -0
  50. package/dist/esm/components/Divider/Divider.tokens.js +59 -0
  51. package/dist/esm/components/EdsProvider/eds.context.js +35 -0
  52. package/dist/esm/components/Icon/Icon.js +102 -0
  53. package/dist/esm/components/Icon/index.js +7 -0
  54. package/dist/esm/components/Icon/library.js +19 -0
  55. package/dist/esm/components/Input/Input.js +58 -0
  56. package/dist/esm/components/Input/Input.tokens.js +172 -0
  57. package/dist/esm/components/Label/Label.js +41 -0
  58. package/dist/esm/components/Label/Label.tokens.js +30 -0
  59. package/dist/esm/components/List/List.js +30 -0
  60. package/dist/esm/components/List/List.tokens.js +12 -0
  61. package/dist/esm/components/List/ListItem.js +14 -0
  62. package/dist/esm/components/List/index.js +8 -0
  63. package/dist/esm/components/Menu/Menu.context.js +48 -0
  64. package/dist/esm/components/Menu/Menu.js +116 -0
  65. package/dist/esm/components/Menu/Menu.tokens.js +132 -0
  66. package/dist/esm/components/Menu/MenuItem.js +90 -0
  67. package/dist/esm/components/Menu/MenuList.js +96 -0
  68. package/dist/esm/components/Menu/MenuSection.js +36 -0
  69. package/dist/esm/components/Menu/index.js +11 -0
  70. package/dist/esm/components/Pagination/Pagination.js +154 -0
  71. package/dist/esm/components/Pagination/Pagination.tokens.js +40 -0
  72. package/dist/esm/components/Pagination/PaginationItem.js +30 -0
  73. package/dist/esm/components/Pagination/paginationControl.js +46 -0
  74. package/dist/esm/components/Paper/Paper.js +24 -0
  75. package/dist/esm/components/Paper/Paper.tokens.js +19 -0
  76. package/dist/esm/components/Popover/Popover.js +96 -0
  77. package/dist/esm/components/Popover/Popover.tokens.js +73 -0
  78. package/dist/esm/components/Popover/PopoverContent.js +21 -0
  79. package/dist/esm/components/Popover/PopoverTitle.js +31 -0
  80. package/dist/esm/components/Popover/index.js +11 -0
  81. package/dist/esm/components/Progress/Circular/CircularProgress.js +94 -0
  82. package/dist/esm/components/Progress/Circular/CircularProgress.tokens.js +42 -0
  83. package/dist/esm/components/Progress/Dots/DotProgress.js +55 -0
  84. package/dist/esm/components/Progress/Dots/DotProgress.tokens.js +30 -0
  85. package/dist/esm/components/Progress/Linear/LinearProgress.js +50 -0
  86. package/dist/esm/components/Progress/Linear/LinearProgress.tokens.js +24 -0
  87. package/dist/esm/components/Progress/Star/StarProgress.js +62 -0
  88. package/dist/esm/components/Progress/Star/StarProgress.tokens.js +16 -0
  89. package/dist/esm/components/Progress/index.js +17 -0
  90. package/dist/esm/components/Radio/Radio.js +130 -0
  91. package/dist/esm/components/Radio/Radio.tokens.js +91 -0
  92. package/dist/esm/components/Scrim/Scrim.js +62 -0
  93. package/dist/esm/components/Scrim/Scrim.tokens.js +18 -0
  94. package/dist/esm/components/Search/Search.js +182 -0
  95. package/dist/esm/components/Search/Search.tokens.js +103 -0
  96. package/dist/esm/components/Select/MultiSelect/MultiSelect.js +202 -0
  97. package/dist/esm/components/Select/NativeSelect/NativeSelect.js +66 -0
  98. package/dist/esm/components/Select/NativeSelect/NativeSelect.tokens.js +66 -0
  99. package/dist/esm/components/Select/Select.tokens.js +98 -0
  100. package/dist/esm/components/Select/SingleSelect/SingleSelect.js +145 -0
  101. package/dist/esm/components/Select/commonStyles.js +54 -0
  102. package/dist/esm/components/SideSheet/SideSheet.js +60 -0
  103. package/dist/esm/components/SideSheet/SideSheet.tokens.js +45 -0
  104. package/dist/esm/components/Slider/MinMax.js +26 -0
  105. package/dist/esm/components/Slider/Output.js +32 -0
  106. package/dist/esm/components/Slider/Slider.js +243 -0
  107. package/dist/esm/components/Slider/Slider.tokens.js +136 -0
  108. package/dist/esm/components/Slider/SliderInput.js +60 -0
  109. package/dist/esm/components/Snackbar/Snackbar.js +63 -0
  110. package/dist/esm/components/Snackbar/Snackbar.tokens.js +74 -0
  111. package/dist/esm/components/Snackbar/SnackbarAction.js +22 -0
  112. package/dist/esm/components/Snackbar/index.js +7 -0
  113. package/dist/esm/components/Switch/Switch.js +67 -0
  114. package/dist/esm/components/Switch/Switch.styles.js +34 -0
  115. package/dist/esm/components/Switch/Switch.tokens.js +168 -0
  116. package/dist/esm/components/Switch/SwitchDefault.js +61 -0
  117. package/dist/esm/components/Switch/SwitchSmall.js +59 -0
  118. package/dist/esm/components/Table/Body.js +25 -0
  119. package/dist/esm/components/Table/Caption.js +19 -0
  120. package/dist/esm/components/Table/Cell.js +33 -0
  121. package/dist/esm/components/Table/DataCell/DataCell.js +49 -0
  122. package/dist/esm/components/Table/DataCell/DataCell.tokens.js +151 -0
  123. package/dist/esm/components/Table/Head/Head.js +29 -0
  124. package/dist/esm/components/Table/Head/Head.tokens.js +30 -0
  125. package/dist/esm/components/Table/HeaderCell/HeaderCell.js +67 -0
  126. package/dist/esm/components/Table/HeaderCell/HeaderCell.tokens.js +118 -0
  127. package/dist/esm/components/Table/Inner.context.js +8 -0
  128. package/dist/esm/components/Table/Row/Row.js +34 -0
  129. package/dist/esm/components/Table/Row/Row.tokens.js +26 -0
  130. package/dist/esm/components/Table/Table.js +20 -0
  131. package/dist/esm/components/Table/index.js +20 -0
  132. package/dist/esm/components/TableOfContents/LinkItem.js +23 -0
  133. package/dist/esm/components/TableOfContents/TableOfContents.js +43 -0
  134. package/dist/esm/components/TableOfContents/TableOfContents.tokens.js +103 -0
  135. package/dist/esm/components/TableOfContents/index.js +8 -0
  136. package/dist/esm/components/Tabs/Tab.js +44 -0
  137. package/dist/esm/components/Tabs/TabList.js +90 -0
  138. package/dist/esm/components/Tabs/TabPanel.js +29 -0
  139. package/dist/esm/components/Tabs/TabPanels.js +25 -0
  140. package/dist/esm/components/Tabs/Tabs.context.js +13 -0
  141. package/dist/esm/components/Tabs/Tabs.js +59 -0
  142. package/dist/esm/components/Tabs/Tabs.tokens.js +127 -0
  143. package/dist/esm/components/Tabs/index.js +17 -0
  144. package/dist/esm/components/TextField/Field.js +145 -0
  145. package/dist/esm/components/TextField/HelperText/HelperText.js +83 -0
  146. package/dist/esm/components/TextField/HelperText/HelperText.token.js +49 -0
  147. package/dist/esm/components/TextField/Icon/Icon.js +62 -0
  148. package/dist/esm/components/TextField/Icon/Icon.tokens.js +46 -0
  149. package/dist/esm/components/TextField/TextField.context.js +37 -0
  150. package/dist/esm/components/TextField/TextField.js +83 -0
  151. package/dist/esm/components/TextField/TextField.tokens.js +124 -0
  152. package/dist/esm/components/Textarea/Textarea.js +92 -0
  153. package/dist/esm/components/Tooltip/Tooltip.js +119 -0
  154. package/dist/esm/components/Tooltip/Tooltip.tokens.js +63 -0
  155. package/dist/esm/components/TopBar/Actions.js +20 -0
  156. package/dist/esm/components/TopBar/CustomContent.js +20 -0
  157. package/dist/esm/components/TopBar/Header.js +20 -0
  158. package/dist/esm/components/TopBar/TopBar.js +29 -0
  159. package/dist/esm/components/TopBar/TopBar.tokens.js +32 -0
  160. package/dist/esm/components/TopBar/index.js +14 -0
  161. package/dist/esm/components/Typography/Typography.js +93 -0
  162. package/dist/esm/components/Typography/Typography.tokens.js +61 -0
  163. package/dist/esm/hooks/useAutoResize.js +39 -0
  164. package/dist/esm/hooks/useCombinedRefs.js +14 -0
  165. package/dist/esm/hooks/useGlobalKeyPress.js +34 -0
  166. package/dist/esm/hooks/useHideBodyScroll.js +12 -0
  167. package/dist/esm/hooks/useId.js +14 -0
  168. package/dist/esm/hooks/useMountedRef.js +12 -0
  169. package/dist/esm/hooks/useOutsideClick.js +18 -0
  170. package/dist/esm/hooks/usePopper.js +31 -0
  171. package/dist/esm/hooks/useToken.js +16 -0
  172. package/dist/esm/index.js +40 -0
  173. package/dist/esm/utils/joinHandlers.js +10 -0
  174. package/dist/esm/utils/setReactInputValue.js +18 -0
  175. package/dist/esm/utils/templates/borders.js +35 -0
  176. package/dist/esm/utils/templates/common.js +19 -0
  177. package/dist/esm/utils/templates/focus.js +35 -0
  178. package/dist/esm/utils/templates/index.js +52 -0
  179. package/dist/types/components/Accordion/Accordion.d.ts +4 -4
  180. package/dist/types/components/Accordion/Accordion.tokens.d.ts +10 -10
  181. package/dist/types/components/Accordion/Accordion.types.d.ts +6 -6
  182. package/dist/types/components/Accordion/AccordionHeader.d.ts +35 -35
  183. package/dist/types/components/Accordion/AccordionHeaderTitle.d.ts +14 -14
  184. package/dist/types/components/Accordion/AccordionItem.d.ts +19 -19
  185. package/dist/types/components/Accordion/AccordionPanel.d.ts +18 -18
  186. package/dist/types/components/Accordion/index.d.ts +15 -15
  187. package/dist/types/components/Avatar/Avatar.d.ts +23 -23
  188. package/dist/types/components/Avatar/Avatar.tokens.d.ts +10 -10
  189. package/dist/types/components/Avatar/index.d.ts +1 -1
  190. package/dist/types/components/Banner/Banner.d.ts +7 -7
  191. package/dist/types/components/Banner/Banner.tokens.d.ts +9 -9
  192. package/dist/types/components/Banner/BannerActions.d.ts +11 -11
  193. package/dist/types/components/Banner/BannerIcon.d.ts +15 -15
  194. package/dist/types/components/Banner/BannerMessage.d.ts +10 -10
  195. package/dist/types/components/Banner/index.d.ts +12 -12
  196. package/dist/types/components/Breadcrumbs/Breadcrumb.d.ts +11 -11
  197. package/dist/types/components/Breadcrumbs/Breadcrumbs.d.ts +11 -11
  198. package/dist/types/components/Breadcrumbs/Breadcrumbs.tokens.d.ts +2 -2
  199. package/dist/types/components/Breadcrumbs/index.d.ts +8 -8
  200. package/dist/types/components/Button/Button.d.ts +43 -43
  201. package/dist/types/components/Button/Button.types.d.ts +12 -12
  202. package/dist/types/components/Button/InnerFullWidth.d.ts +2 -2
  203. package/dist/types/components/Button/index.d.ts +1 -1
  204. package/dist/types/components/Button/tokens/button.d.ts +2 -2
  205. package/dist/types/components/Button/tokens/contained.d.ts +4 -4
  206. package/dist/types/components/Button/tokens/ghost.d.ts +4 -4
  207. package/dist/types/components/Button/tokens/icon.d.ts +4 -4
  208. package/dist/types/components/Button/tokens/index.d.ts +8 -8
  209. package/dist/types/components/Button/tokens/outlined.d.ts +4 -4
  210. package/dist/types/components/Card/Card.d.ts +9 -9
  211. package/dist/types/components/Card/Card.tokens.d.ts +6 -6
  212. package/dist/types/components/Card/CardActions.d.ts +13 -13
  213. package/dist/types/components/Card/CardContent.d.ts +3 -3
  214. package/dist/types/components/Card/CardHeader.d.ts +3 -3
  215. package/dist/types/components/Card/CardHeaderTitle.d.ts +3 -3
  216. package/dist/types/components/Card/CardMedia.d.ts +9 -9
  217. package/dist/types/components/Card/index.d.ts +16 -16
  218. package/dist/types/components/Checkbox/Checkbox.d.ts +15 -15
  219. package/dist/types/components/Checkbox/Checkbox.tokens.d.ts +4 -4
  220. package/dist/types/components/Checkbox/Input.d.ts +12 -12
  221. package/dist/types/components/Checkbox/index.d.ts +1 -1
  222. package/dist/types/components/Chip/Chip.d.ts +17 -17
  223. package/dist/types/components/Chip/Chip.tokens.d.ts +8 -8
  224. package/dist/types/components/Chip/Icon.d.ts +6 -6
  225. package/dist/types/components/Chip/index.d.ts +1 -1
  226. package/dist/types/components/Combobox/Combobox.d.ts +55 -55
  227. package/dist/types/components/Combobox/Combobox.tokens.d.ts +3 -3
  228. package/dist/types/components/Combobox/index.d.ts +1 -1
  229. package/dist/types/components/Dialog/Actions.d.ts +3 -3
  230. package/dist/types/components/Dialog/CustomContent.d.ts +9 -9
  231. package/dist/types/components/Dialog/Dialog.d.ts +3 -3
  232. package/dist/types/components/Dialog/Dialog.tokens.d.ts +4 -4
  233. package/dist/types/components/Dialog/Title.d.ts +3 -3
  234. package/dist/types/components/Dialog/index.d.ts +12 -12
  235. package/dist/types/components/Divider/Divider.d.ts +17 -17
  236. package/dist/types/components/Divider/Divider.tokens.d.ts +12 -12
  237. package/dist/types/components/Divider/index.d.ts +1 -1
  238. package/dist/types/components/EdsProvider/eds.context.d.ts +15 -15
  239. package/dist/types/components/EdsProvider/index.d.ts +1 -1
  240. package/dist/types/components/Icon/Icon.d.ts +20 -20
  241. package/dist/types/components/Icon/Icon.types.d.ts +11 -11
  242. package/dist/types/components/Icon/index.d.ts +5 -5
  243. package/dist/types/components/Icon/library.d.ts +8 -8
  244. package/dist/types/components/Input/Input.d.ts +26 -26
  245. package/dist/types/components/Input/Input.tokens.d.ts +12 -12
  246. package/dist/types/components/Input/index.d.ts +1 -1
  247. package/dist/types/components/Label/Label.d.ts +11 -11
  248. package/dist/types/components/Label/Label.tokens.d.ts +4 -4
  249. package/dist/types/components/Label/index.d.ts +1 -1
  250. package/dist/types/components/List/List.d.ts +14 -14
  251. package/dist/types/components/List/List.tokens.d.ts +4 -4
  252. package/dist/types/components/List/ListItem.d.ts +4 -4
  253. package/dist/types/components/List/index.d.ts +8 -8
  254. package/dist/types/components/Menu/Menu.context.d.ts +15 -15
  255. package/dist/types/components/Menu/Menu.d.ts +27 -27
  256. package/dist/types/components/Menu/Menu.tokens.d.ts +4 -4
  257. package/dist/types/components/Menu/Menu.types.d.ts +1 -1
  258. package/dist/types/components/Menu/MenuItem.d.ts +21 -21
  259. package/dist/types/components/Menu/MenuList.d.ts +8 -8
  260. package/dist/types/components/Menu/MenuSection.d.ts +11 -11
  261. package/dist/types/components/Menu/index.d.ts +10 -10
  262. package/dist/types/components/Pagination/Pagination.d.ts +25 -25
  263. package/dist/types/components/Pagination/Pagination.tokens.d.ts +2 -2
  264. package/dist/types/components/Pagination/PaginationItem.d.ts +8 -8
  265. package/dist/types/components/Pagination/index.d.ts +1 -1
  266. package/dist/types/components/Pagination/paginationControl.d.ts +1 -1
  267. package/dist/types/components/Paper/Paper.d.ts +8 -8
  268. package/dist/types/components/Paper/Paper.tokens.d.ts +12 -12
  269. package/dist/types/components/Paper/index.d.ts +1 -1
  270. package/dist/types/components/Popover/Popover.d.ts +22 -22
  271. package/dist/types/components/Popover/Popover.tokens.d.ts +4 -4
  272. package/dist/types/components/Popover/PopoverContent.d.ts +3 -3
  273. package/dist/types/components/Popover/PopoverTitle.d.ts +3 -3
  274. package/dist/types/components/Popover/index.d.ts +10 -10
  275. package/dist/types/components/Progress/Circular/CircularProgress.d.ts +16 -16
  276. package/dist/types/components/Progress/Circular/CircularProgress.tokens.d.ts +8 -8
  277. package/dist/types/components/Progress/Dots/DotProgress.d.ts +11 -11
  278. package/dist/types/components/Progress/Dots/DotProgress.tokens.d.ts +5 -5
  279. package/dist/types/components/Progress/Linear/LinearProgress.d.ts +18 -18
  280. package/dist/types/components/Progress/Linear/LinearProgress.tokens.d.ts +7 -7
  281. package/dist/types/components/Progress/Star/StarProgress.d.ts +14 -14
  282. package/dist/types/components/Progress/Star/StarProgress.tokens.d.ts +2 -2
  283. package/dist/types/components/Progress/index.d.ts +15 -15
  284. package/dist/types/components/Radio/Radio.d.ts +10 -10
  285. package/dist/types/components/Radio/Radio.tokens.d.ts +4 -4
  286. package/dist/types/components/Radio/index.d.ts +1 -1
  287. package/dist/types/components/Scrim/Scrim.d.ts +15 -15
  288. package/dist/types/components/Scrim/Scrim.tokens.d.ts +2 -2
  289. package/dist/types/components/Scrim/index.d.ts +1 -1
  290. package/dist/types/components/Search/Search.d.ts +3 -3
  291. package/dist/types/components/Search/Search.tokens.d.ts +4 -4
  292. package/dist/types/components/Search/index.d.ts +1 -1
  293. package/dist/types/components/Select/MultiSelect/MultiSelect.d.ts +48 -48
  294. package/dist/types/components/Select/MultiSelect/index.d.ts +1 -1
  295. package/dist/types/components/Select/NativeSelect/NativeSelect.d.ts +29 -29
  296. package/dist/types/components/Select/NativeSelect/NativeSelect.tokens.d.ts +4 -4
  297. package/dist/types/components/Select/NativeSelect/index.d.ts +1 -1
  298. package/dist/types/components/Select/Select.tokens.d.ts +3 -3
  299. package/dist/types/components/Select/SingleSelect/SingleSelect.d.ts +48 -48
  300. package/dist/types/components/Select/SingleSelect/index.d.ts +1 -1
  301. package/dist/types/components/Select/commonStyles.d.ts +32 -32
  302. package/dist/types/components/Select/index.d.ts +3 -3
  303. package/dist/types/components/SideSheet/SideSheet.d.ts +21 -21
  304. package/dist/types/components/SideSheet/SideSheet.tokens.d.ts +10 -10
  305. package/dist/types/components/SideSheet/index.d.ts +1 -1
  306. package/dist/types/components/Slider/MinMax.d.ts +5 -5
  307. package/dist/types/components/Slider/Output.d.ts +9 -9
  308. package/dist/types/components/Slider/Slider.d.ts +49 -49
  309. package/dist/types/components/Slider/Slider.tokens.d.ts +4 -4
  310. package/dist/types/components/Slider/SliderInput.d.ts +21 -21
  311. package/dist/types/components/Slider/index.d.ts +1 -1
  312. package/dist/types/components/Snackbar/Snackbar.d.ts +21 -21
  313. package/dist/types/components/Snackbar/Snackbar.tokens.d.ts +4 -4
  314. package/dist/types/components/Snackbar/SnackbarAction.d.ts +5 -5
  315. package/dist/types/components/Snackbar/index.d.ts +8 -8
  316. package/dist/types/components/Switch/Switch.d.ts +12 -12
  317. package/dist/types/components/Switch/Switch.styles.d.ts +5 -5
  318. package/dist/types/components/Switch/Switch.tokens.d.ts +3 -3
  319. package/dist/types/components/Switch/SwitchDefault.d.ts +6 -6
  320. package/dist/types/components/Switch/SwitchSmall.d.ts +6 -6
  321. package/dist/types/components/Switch/index.d.ts +1 -1
  322. package/dist/types/components/Table/Body.d.ts +3 -3
  323. package/dist/types/components/Table/Caption.d.ts +4 -4
  324. package/dist/types/components/Table/Cell.d.ts +11 -11
  325. package/dist/types/components/Table/DataCell/DataCell.d.ts +8 -8
  326. package/dist/types/components/Table/DataCell/DataCell.tokens.d.ts +15 -15
  327. package/dist/types/components/Table/DataCell/index.d.ts +1 -1
  328. package/dist/types/components/Table/Head/Head.d.ts +9 -9
  329. package/dist/types/components/Table/Head/Head.tokens.d.ts +2 -2
  330. package/dist/types/components/Table/Head/index.d.ts +1 -1
  331. package/dist/types/components/Table/HeaderCell/HeaderCell.d.ts +5 -5
  332. package/dist/types/components/Table/HeaderCell/HeaderCell.tokens.d.ts +3 -3
  333. package/dist/types/components/Table/HeaderCell/index.d.ts +1 -1
  334. package/dist/types/components/Table/Inner.context.d.ts +7 -7
  335. package/dist/types/components/Table/Row/Row.d.ts +9 -9
  336. package/dist/types/components/Table/Row/Row.tokens.d.ts +2 -2
  337. package/dist/types/components/Table/Row/index.d.ts +1 -1
  338. package/dist/types/components/Table/Table.d.ts +3 -3
  339. package/dist/types/components/Table/Table.types.d.ts +2 -2
  340. package/dist/types/components/Table/index.d.ts +16 -16
  341. package/dist/types/components/TableOfContents/LinkItem.d.ts +3 -3
  342. package/dist/types/components/TableOfContents/TableOfContents.d.ts +14 -14
  343. package/dist/types/components/TableOfContents/TableOfContents.tokens.d.ts +4 -4
  344. package/dist/types/components/TableOfContents/index.d.ts +8 -8
  345. package/dist/types/components/Tabs/Tab.d.ts +13 -13
  346. package/dist/types/components/Tabs/TabList.d.ts +11 -11
  347. package/dist/types/components/Tabs/TabPanel.d.ts +10 -10
  348. package/dist/types/components/Tabs/TabPanels.d.ts +4 -4
  349. package/dist/types/components/Tabs/Tabs.context.d.ts +13 -13
  350. package/dist/types/components/Tabs/Tabs.d.ts +19 -19
  351. package/dist/types/components/Tabs/Tabs.tokens.d.ts +2 -2
  352. package/dist/types/components/Tabs/Tabs.types.d.ts +1 -1
  353. package/dist/types/components/Tabs/index.d.ts +14 -14
  354. package/dist/types/components/TextField/Field.d.ts +34 -34
  355. package/dist/types/components/TextField/HelperText/HelperText.d.ts +14 -14
  356. package/dist/types/components/TextField/HelperText/HelperText.token.d.ts +15 -15
  357. package/dist/types/components/TextField/HelperText/index.d.ts +1 -1
  358. package/dist/types/components/TextField/Icon/Icon.d.ts +13 -13
  359. package/dist/types/components/TextField/Icon/Icon.tokens.d.ts +14 -14
  360. package/dist/types/components/TextField/Icon/index.d.ts +1 -1
  361. package/dist/types/components/TextField/TextField.context.d.ts +17 -17
  362. package/dist/types/components/TextField/TextField.d.ts +37 -37
  363. package/dist/types/components/TextField/TextField.tokens.d.ts +10 -10
  364. package/dist/types/components/TextField/index.d.ts +1 -1
  365. package/dist/types/components/TextField/types.d.ts +6 -6
  366. package/dist/types/components/Textarea/Textarea.d.ts +30 -30
  367. package/dist/types/components/Textarea/index.d.ts +1 -1
  368. package/dist/types/components/Tooltip/Tooltip.d.ts +22 -22
  369. package/dist/types/components/Tooltip/Tooltip.tokens.d.ts +4 -4
  370. package/dist/types/components/Tooltip/index.d.ts +1 -1
  371. package/dist/types/components/TopBar/Actions.d.ts +3 -3
  372. package/dist/types/components/TopBar/CustomContent.d.ts +3 -3
  373. package/dist/types/components/TopBar/Header.d.ts +3 -3
  374. package/dist/types/components/TopBar/TopBar.d.ts +3 -3
  375. package/dist/types/components/TopBar/TopBar.tokens.d.ts +4 -4
  376. package/dist/types/components/TopBar/index.d.ts +12 -12
  377. package/dist/types/components/Typography/Typography.d.ts +15 -15
  378. package/dist/types/components/Typography/Typography.tokens.d.ts +454 -453
  379. package/dist/types/components/Typography/index.d.ts +1 -1
  380. package/dist/types/hooks/index.d.ts +9 -9
  381. package/dist/types/hooks/useAutoResize.d.ts +1 -1
  382. package/dist/types/hooks/useCombinedRefs.d.ts +3 -3
  383. package/dist/types/hooks/useGlobalKeyPress.d.ts +10 -10
  384. package/dist/types/hooks/useHideBodyScroll.d.ts +1 -1
  385. package/dist/types/hooks/useId.d.ts +1 -1
  386. package/dist/types/hooks/useMountedRef.d.ts +1 -1
  387. package/dist/types/hooks/useOutsideClick.d.ts +1 -1
  388. package/dist/types/hooks/usePopper.d.ts +12 -12
  389. package/dist/types/hooks/useToken.d.ts +7 -7
  390. package/dist/types/index.d.ts +34 -35
  391. package/dist/types/utils/index.d.ts +4 -4
  392. package/dist/types/utils/joinHandlers.d.ts +3 -3
  393. package/dist/types/utils/setReactInputValue.d.ts +7 -7
  394. package/dist/types/utils/templates/borders.d.ts +2 -2
  395. package/dist/types/utils/templates/common.d.ts +9 -9
  396. package/dist/types/utils/templates/focus.d.ts +2 -2
  397. package/dist/types/utils/templates/index.d.ts +7 -7
  398. package/package.json +12 -16
  399. package/dist/core-react.esm.js +0 -18407
  400. package/dist/core-react.umd.js +0 -18479
  401. package/src/index.ts +0 -37
@@ -0,0 +1,44 @@
1
+ import { forwardRef } from 'react';
2
+ import styled, { css } from 'styled-components';
3
+ import { token } from './Tabs.tokens.js';
4
+ import { jsx } from 'react/jsx-runtime';
5
+ import { spacingsTemplate } from '../../utils/templates/index.js';
6
+ import { outlineTemplate } from '../../utils/templates/focus.js';
7
+ import { bordersTemplate } from '../../utils/templates/borders.js';
8
+
9
+ const {
10
+ entities: {
11
+ tab
12
+ }
13
+ } = token;
14
+ const StyledTab = styled.button.attrs(({
15
+ active = false,
16
+ disabled = false
17
+ }) => ({
18
+ type: 'button',
19
+ role: 'tab',
20
+ 'aria-selected': active,
21
+ 'aria-disabled': disabled,
22
+ tabIndex: active ? '0' : '-1'
23
+ })).withConfig({
24
+ displayName: "Tab__StyledTab",
25
+ componentId: "sc-scjkct-0"
26
+ })(["appearance:none;box-sizing:border-box;font-family:inherit;border:none;outline:none;font-size:1rem;height:", ";", " color:", ";background-color:", ";position:relative;white-space:nowrap;text-overflow:ellipsis;overflow-x:hidden;&:focus{outline:none;}&[data-focus],&[data-focus-visible-added]:focus{", "}&:focus-visible{", "}&::-moz-focus-inner{border:0;}@media (hover:hover) and (pointer:fine){&[data-hover],&:hover{color:", ";", "}}", " ", ""], tab.height, spacingsTemplate(tab.spacings), ({
27
+ active
28
+ }) => active ? tab.states.active.typography.color : tab.typography.color, tab.background, outlineTemplate(tab.states.focus.outline), outlineTemplate(tab.states.focus.outline), ({
29
+ active
30
+ }) => active ? tab.states.active.states.hover.typography.color : tab.typography.color, ({
31
+ disabled
32
+ }) => disabled ? css(["background:", ";cursor:not-allowed;"], tab.states.disabled.background) : css(["background:", ";cursor:pointer;"], tab.states.hover.background), ({
33
+ disabled
34
+ }) => disabled ? bordersTemplate(tab.states.disabled.border) : bordersTemplate(tab.border), ({
35
+ active
36
+ }) => active && bordersTemplate(tab.states.active.border));
37
+ const Tab = /*#__PURE__*/forwardRef(function Tab(props, ref) {
38
+ return /*#__PURE__*/jsx(StyledTab, {
39
+ ref: ref,
40
+ ...props
41
+ });
42
+ });
43
+
44
+ export { Tab };
@@ -0,0 +1,90 @@
1
+ import { forwardRef, useContext, useRef, useCallback, useEffect, Children, cloneElement } from 'react';
2
+ import styled from 'styled-components';
3
+ import { TabsContext } from './Tabs.context.js';
4
+ import { jsx } from 'react/jsx-runtime';
5
+ import { useCombinedRefs } from '../../hooks/useCombinedRefs.js';
6
+
7
+ const variants = {
8
+ fullWidth: 'minmax(1%, 360px)',
9
+ minWidth: 'max-content'
10
+ };
11
+ const StyledTabList = styled.div.attrs(() => ({
12
+ role: 'tablist'
13
+ })).withConfig({
14
+ displayName: "TabList__StyledTabList",
15
+ componentId: "sc-1g1p5i1-0"
16
+ })(["display:grid;grid-auto-flow:column;grid-auto-columns:", ";"], ({
17
+ variant
18
+ }) => variants[variant]);
19
+ const TabList = /*#__PURE__*/forwardRef(function TabsList({
20
+ children = [],
21
+ ...props
22
+ }, ref) {
23
+ const {
24
+ activeTab,
25
+ handleChange,
26
+ tabsId,
27
+ variant = 'minWidth',
28
+ tabsFocused
29
+ } = useContext(TabsContext);
30
+ const currentTab = useRef(activeTab);
31
+ const selectedTabRef = useCallback(node => {
32
+ if (node !== null && tabsFocused) {
33
+ node.focus();
34
+ }
35
+ }, [tabsFocused]);
36
+ useEffect(() => {
37
+ currentTab.current = activeTab;
38
+ }, [activeTab]);
39
+ const Tabs = Children.map(children, (child, index) => {
40
+ const tabRef = index === activeTab ? // eslint-disable-next-line react-hooks/rules-of-hooks
41
+ useCombinedRefs(child.ref, selectedTabRef) : child.ref;
42
+ return /*#__PURE__*/cloneElement(child, {
43
+ id: "".concat(tabsId, "-tab-").concat(index + 1),
44
+ 'aria-controls': "".concat(tabsId, "-panel-").concat(index + 1),
45
+ active: index === activeTab,
46
+ index,
47
+ onClick: () => handleChange(index),
48
+ ref: tabRef
49
+ });
50
+ });
51
+ const focusableChildren = Tabs.filter(child => {
52
+ const childProps = child.props;
53
+ return !childProps.disabled;
54
+ }).map(child => {
55
+ const childProps = child.props;
56
+ return childProps.index;
57
+ });
58
+ const firstFocusableChild = focusableChildren[0];
59
+ const lastFocusableChild = focusableChildren[focusableChildren.length - 1];
60
+
61
+ const handleTabsChange = (direction, fallbackTab) => {
62
+ const i = direction === 'left' ? 1 : -1;
63
+ const nextTab = focusableChildren[focusableChildren.indexOf(currentTab.current) - i];
64
+ handleChange(nextTab === undefined ? fallbackTab : nextTab);
65
+ };
66
+
67
+ const handleKeyPress = event => {
68
+ const {
69
+ key
70
+ } = event;
71
+
72
+ if (key === 'ArrowLeft') {
73
+ handleTabsChange('left', lastFocusableChild);
74
+ }
75
+
76
+ if (key === 'ArrowRight') {
77
+ handleTabsChange('right', firstFocusableChild);
78
+ }
79
+ };
80
+
81
+ return /*#__PURE__*/jsx(StyledTabList, {
82
+ onKeyDown: handleKeyPress,
83
+ ref: ref,
84
+ ...props,
85
+ variant: variant,
86
+ children: Tabs
87
+ });
88
+ });
89
+
90
+ export { TabList };
@@ -0,0 +1,29 @@
1
+ import { forwardRef } from 'react';
2
+ import styled from 'styled-components';
3
+ import { token } from './Tabs.tokens.js';
4
+ import { jsx } from 'react/jsx-runtime';
5
+ import { spacingsTemplate } from '../../utils/templates/index.js';
6
+ import { outlineTemplate } from '../../utils/templates/focus.js';
7
+
8
+ const {
9
+ entities: {
10
+ panel
11
+ }
12
+ } = token;
13
+ const StyledTabPanel = styled.div.attrs(() => ({
14
+ tabIndex: 0,
15
+ role: 'tabpanel'
16
+ })).withConfig({
17
+ displayName: "TabPanel__StyledTabPanel",
18
+ componentId: "sc-e8v1d4-0"
19
+ })(["", " &:focus{outline:none;}&[data-focus-visible-added]:focus{", "}&:focus-visible{", "}"], spacingsTemplate(panel.spacings), outlineTemplate(panel.states.focus.outline), outlineTemplate(panel.states.focus.outline));
20
+ const TabPanel = /*#__PURE__*/forwardRef(function TabPanel({ ...props
21
+ }, ref) {
22
+ return /*#__PURE__*/jsx(StyledTabPanel, {
23
+ ref: ref,
24
+ ...props,
25
+ children: props.children
26
+ });
27
+ });
28
+
29
+ export { TabPanel };
@@ -0,0 +1,25 @@
1
+ import { forwardRef, useContext, Children, cloneElement } from 'react';
2
+ import { TabsContext } from './Tabs.context.js';
3
+ import { jsx } from 'react/jsx-runtime';
4
+
5
+ const TabPanels = /*#__PURE__*/forwardRef(function TabPanels({
6
+ children,
7
+ ...props
8
+ }, ref) {
9
+ const {
10
+ activeTab,
11
+ tabsId
12
+ } = useContext(TabsContext);
13
+ const Panels = Children.map(children, (child, index) => /*#__PURE__*/cloneElement(child, {
14
+ id: "".concat(tabsId, "-panel-").concat(index + 1),
15
+ 'aria-labelledby': "".concat(tabsId, "-tab-").concat(index + 1),
16
+ hidden: activeTab !== index
17
+ }));
18
+ return /*#__PURE__*/jsx("div", {
19
+ ref: ref,
20
+ ...props,
21
+ children: Panels
22
+ });
23
+ });
24
+
25
+ export { TabPanels };
@@ -0,0 +1,13 @@
1
+ import { createContext } from 'react';
2
+
3
+ const TabsContext = /*#__PURE__*/createContext({
4
+ variant: 'minWidth',
5
+ handleChange: () => null,
6
+ activeTab: 0,
7
+ tabsId: '',
8
+ tabsFocused: false
9
+ });
10
+ const TabsProvider = TabsContext.Provider;
11
+ TabsContext.Consumer;
12
+
13
+ export { TabsContext, TabsProvider };
@@ -0,0 +1,59 @@
1
+ import { forwardRef, useState } from 'react';
2
+ import { TabsProvider } from './Tabs.context.js';
3
+ import { jsx } from 'react/jsx-runtime';
4
+ import { useId } from '../../hooks/useId.js';
5
+
6
+ const Tabs = /*#__PURE__*/forwardRef(function Tabs({
7
+ activeTab = 0,
8
+ onChange,
9
+ onBlur,
10
+ onFocus,
11
+ variant = 'minWidth',
12
+ id,
13
+ ...props
14
+ }, ref) {
15
+ const tabsId = useId(id, 'tabs');
16
+ const [tabsFocused, setTabsFocused] = useState(false);
17
+ let blurTimer;
18
+
19
+ const handleBlur = e => {
20
+ blurTimer = setTimeout(() => {
21
+ if (tabsFocused) {
22
+ setTabsFocused(false);
23
+ }
24
+ }, 0);
25
+ onBlur && onBlur(e);
26
+ };
27
+
28
+ const handleFocus = e => {
29
+ if (e.target.getAttribute('role') !== 'tab') {
30
+ return;
31
+ }
32
+
33
+ clearTimeout(blurTimer);
34
+
35
+ if (!tabsFocused) {
36
+ setTabsFocused(true);
37
+ }
38
+
39
+ onFocus && onFocus(e);
40
+ };
41
+
42
+ return /*#__PURE__*/jsx(TabsProvider, {
43
+ value: {
44
+ activeTab,
45
+ handleChange: onChange,
46
+ tabsId,
47
+ variant,
48
+ tabsFocused
49
+ },
50
+ children: /*#__PURE__*/jsx("div", {
51
+ ref: ref,
52
+ ...props,
53
+ onBlur: handleBlur,
54
+ onFocus: handleFocus
55
+ })
56
+ });
57
+ });
58
+
59
+ export { Tabs };
@@ -0,0 +1,127 @@
1
+ import { tokens } from '@equinor/eds-tokens';
2
+
3
+ const {
4
+ colors: {
5
+ text: {
6
+ static_icons__tertiary: {
7
+ rgba: defaultColor
8
+ }
9
+ },
10
+ ui: {
11
+ background__medium: {
12
+ rgba: defaultBorderColor
13
+ }
14
+ },
15
+ interactive: {
16
+ focus: {
17
+ rgba: focusOutlineColor
18
+ },
19
+ primary__hover_alt: {
20
+ rgba: hoverBackgroundColor
21
+ },
22
+ primary__resting: {
23
+ rgba: activeColor
24
+ },
25
+ primary__hover: {
26
+ rgba: activeHoverColor
27
+ }
28
+ }
29
+ },
30
+ clickbounds: {
31
+ default__base: clickboundsHeight
32
+ },
33
+ spacings: {
34
+ comfortable: {
35
+ medium: spacingMedium
36
+ }
37
+ }
38
+ } = tokens;
39
+ const token = {
40
+ entities: {
41
+ panel: {
42
+ spacings: {
43
+ top: spacingMedium,
44
+ bottom: spacingMedium
45
+ },
46
+ states: {
47
+ focus: {
48
+ outline: {
49
+ type: 'outline',
50
+ width: '1px',
51
+ style: 'dashed',
52
+ color: focusOutlineColor
53
+ }
54
+ }
55
+ }
56
+ },
57
+ tab: {
58
+ background: 'transparent',
59
+ height: clickboundsHeight,
60
+ clickbound: {
61
+ height: clickboundsHeight,
62
+ offset: {
63
+ top: '2px'
64
+ }
65
+ },
66
+ spacings: {
67
+ left: spacingMedium,
68
+ right: spacingMedium
69
+ },
70
+ typography: {
71
+ color: defaultColor,
72
+ textAlign: 'center'
73
+ },
74
+ border: {
75
+ type: 'bordergroup',
76
+ bottom: {
77
+ color: defaultBorderColor,
78
+ style: 'solid',
79
+ width: '2px'
80
+ }
81
+ },
82
+ states: {
83
+ disabled: {
84
+ border: {
85
+ type: 'border',
86
+ width: 0,
87
+ color: 'transparent',
88
+ style: 'solid'
89
+ }
90
+ },
91
+ hover: {
92
+ background: hoverBackgroundColor
93
+ },
94
+ focus: {
95
+ outline: {
96
+ type: 'outline',
97
+ width: '1px',
98
+ style: 'dashed',
99
+ color: focusOutlineColor
100
+ }
101
+ },
102
+ active: {
103
+ typography: {
104
+ color: activeColor
105
+ },
106
+ border: {
107
+ type: 'bordergroup',
108
+ bottom: {
109
+ color: activeColor,
110
+ style: 'solid',
111
+ width: '2px'
112
+ }
113
+ },
114
+ states: {
115
+ hover: {
116
+ typography: {
117
+ color: activeHoverColor
118
+ }
119
+ }
120
+ }
121
+ }
122
+ }
123
+ }
124
+ }
125
+ };
126
+
127
+ export { token };
@@ -0,0 +1,17 @@
1
+ import { Tabs as Tabs$1 } from './Tabs.js';
2
+ import { TabList } from './TabList.js';
3
+ import { Tab } from './Tab.js';
4
+ import { TabPanels } from './TabPanels.js';
5
+ import { TabPanel } from './TabPanel.js';
6
+
7
+ const Tabs = Tabs$1;
8
+ Tabs.Tab = Tab;
9
+ Tabs.Panels = TabPanels;
10
+ Tabs.Panel = TabPanel;
11
+ Tabs.List = TabList;
12
+ Tabs.Tab.displayName = 'Tabs.Tab';
13
+ Tabs.Panels.displayName = 'Tabs.Panels';
14
+ Tabs.Panel.displayName = 'Tabs.Panel';
15
+ Tabs.List.displayName = 'Tabs.List';
16
+
17
+ export { Tabs };
@@ -0,0 +1,145 @@
1
+ import { forwardRef } from 'react';
2
+ import { useTextField } from './TextField.context.js';
3
+ import styled, { css } from 'styled-components';
4
+ import * as TextField_tokens from './TextField.tokens.js';
5
+ import { jsxs, jsx } from 'react/jsx-runtime';
6
+ import { Input } from '../Input/Input.js';
7
+ import { Textarea } from '../Textarea/Textarea.js';
8
+ import { Icon as InputIcon } from './Icon/Icon.js';
9
+ import { typographyTemplate } from '../../utils/templates/index.js';
10
+ import { useEds } from '../EdsProvider/eds.context.js';
11
+ import { outlineTemplate } from '../../utils/templates/focus.js';
12
+
13
+ const {
14
+ textfield
15
+ } = TextField_tokens;
16
+
17
+ const Variation = ({
18
+ variant,
19
+ isFocused,
20
+ token
21
+ }) => {
22
+ var _token$border, _token$border2, _token$border3, _token$border4;
23
+
24
+ if (!variant) {
25
+ return "";
26
+ }
27
+
28
+ return css(["box-shadow:", ";", ""], isFocused ? "none" : variant === 'default' ? "inset 0 -1px 0 0 ".concat(((_token$border = token.border) === null || _token$border === void 0 ? void 0 : _token$border.type) === 'border' && ((_token$border2 = token.border) === null || _token$border2 === void 0 ? void 0 : _token$border2.color)) : "0 0 0 1px ".concat(((_token$border3 = token.border) === null || _token$border3 === void 0 ? void 0 : _token$border3.type) === 'border' && ((_token$border4 = token.border) === null || _token$border4 === void 0 ? void 0 : _token$border4.color)), isFocused && outlineTemplate(token.states.focus.outline));
29
+ };
30
+
31
+ const StrippedInput = styled(Input).withConfig({
32
+ displayName: "Field__StrippedInput",
33
+ componentId: "sc-455b88-0"
34
+ })(["outline:none;&:active,&:focus{outline:none;box-shadow:none;}"]);
35
+ const StrippedTextarea = styled(Textarea).withConfig({
36
+ displayName: "Field__StrippedTextarea",
37
+ componentId: "sc-455b88-1"
38
+ })(["outline:none;&:active,&:focus{outline:none;box-shadow:none;}"]);
39
+ const InputWrapper = styled.div.withConfig({
40
+ displayName: "Field__InputWrapper",
41
+ componentId: "sc-455b88-2"
42
+ })(({
43
+ inputIcon,
44
+ unit,
45
+ isDisabled,
46
+ isReadOnly,
47
+ multiline,
48
+ variant
49
+ }) => css(["", " ", " ", " ", " ", ""], Variation, (inputIcon || unit) && css(["display:flex;align-items:center;background:", ";padding-right:", ";"], textfield.background, textfield.spacings.right), isReadOnly && css(["box-shadow:", ";background:", ";"], textfield.states.readOnly.boxShadow, textfield.states.readOnly.background), isDisabled && css(["box-shadow:none;cursor:not-allowed;outline:none;"]), multiline && variant === 'default' && !inputIcon && !unit && css(["box-shadow:none;"])));
50
+ const Unit = styled.span.withConfig({
51
+ displayName: "Field__Unit",
52
+ componentId: "sc-455b88-3"
53
+ })(["", ";display:inline-block;margin-top:3px;", ""], typographyTemplate(textfield.entities.unit.typography), ({
54
+ isDisabled
55
+ }) => isDisabled && {
56
+ color: textfield.entities.unit.states.disabled.typography.color
57
+ });
58
+ const Adornments = styled.div.withConfig({
59
+ displayName: "Field__Adornments",
60
+ componentId: "sc-455b88-4"
61
+ })(["display:flex;align-items:center;justify-content:center;height:100%;margin-left:", ";& div:nth-child(2){margin-left:", ";}", ""], textfield.spacings.left, textfield.spacings.left, ({
62
+ multiline,
63
+ theme
64
+ }) => multiline && {
65
+ marginTop: theme.spacings.top,
66
+ alignSelf: 'start'
67
+ });
68
+ const Field = /*#__PURE__*/forwardRef(function Field({
69
+ multiline,
70
+ variant,
71
+ disabled,
72
+ readOnly,
73
+ type,
74
+ unit,
75
+ inputIcon,
76
+ rowsMax,
77
+ onBlur,
78
+ onFocus,
79
+ ...other
80
+ }, ref) {
81
+ const {
82
+ handleFocus,
83
+ handleBlur,
84
+ isFocused
85
+ } = useTextField();
86
+ const {
87
+ density
88
+ } = useEds();
89
+ const iconSize = density === 'compact' ? 16 : 24;
90
+ const actualVariant = variant === 'default' ? 'textfield' : variant;
91
+ const inputVariant = TextField_tokens[actualVariant];
92
+
93
+ const focusHandler = e => {
94
+ handleFocus();
95
+ onFocus && onFocus(e);
96
+ };
97
+
98
+ const blurHandler = e => {
99
+ handleBlur();
100
+ onBlur && onBlur(e);
101
+ };
102
+
103
+ const inputWrapperProps = {
104
+ isFocused,
105
+ isDisabled: disabled,
106
+ isReadOnly: readOnly,
107
+ variant,
108
+ token: inputVariant,
109
+ inputIcon,
110
+ unit,
111
+ multiline
112
+ };
113
+ const inputProps = {
114
+ ref: ref,
115
+ type,
116
+ disabled,
117
+ readOnly,
118
+ variant,
119
+ onBlur: blurHandler,
120
+ onFocus: focusHandler,
121
+ ...other
122
+ };
123
+ const textareaProps = { ...inputProps,
124
+ rowsMax,
125
+ ref: ref
126
+ };
127
+ return /*#__PURE__*/jsxs(InputWrapper, { ...inputWrapperProps,
128
+ children: [multiline ? /*#__PURE__*/jsx(StrippedTextarea, { ...textareaProps
129
+ }) : /*#__PURE__*/jsx(StrippedInput, { ...inputProps
130
+ }), (inputIcon || unit) && /*#__PURE__*/jsxs(Adornments, {
131
+ multiline: multiline,
132
+ children: [unit && /*#__PURE__*/jsx(Unit, {
133
+ isDisabled: disabled,
134
+ children: unit
135
+ }), inputIcon && /*#__PURE__*/jsx(InputIcon, {
136
+ isDisabled: disabled,
137
+ variant: variant,
138
+ size: iconSize,
139
+ children: inputIcon
140
+ })]
141
+ })]
142
+ });
143
+ });
144
+
145
+ export { Field, InputWrapper };
@@ -0,0 +1,83 @@
1
+ import { forwardRef } from 'react';
2
+ import styled, { css } from 'styled-components';
3
+ import { helperText } from './HelperText.token.js';
4
+ import { useTextField } from '../TextField.context.js';
5
+ import { jsxs, jsx } from 'react/jsx-runtime';
6
+ import { Icon as InputIcon } from '../Icon/Icon.js';
7
+ import { typographyTemplate } from '../../../utils/templates/index.js';
8
+
9
+ const Variation = ({
10
+ variant,
11
+ isFocused,
12
+ isDisabled
13
+ }) => {
14
+ if (!variant) {
15
+ return "";
16
+ }
17
+
18
+ const {
19
+ focusColor,
20
+ color,
21
+ disabledColor
22
+ } = variant;
23
+
24
+ if (isDisabled) {
25
+ return css(["color:", ";"], disabledColor);
26
+ }
27
+
28
+ if (isFocused) {
29
+ return css(["color:", ";"], focusColor);
30
+ }
31
+
32
+ return css(["color:", ";"], color);
33
+ };
34
+
35
+ const Container = styled.div.withConfig({
36
+ displayName: "HelperText__Container",
37
+ componentId: "sc-1kfkyxg-0"
38
+ })(["display:flex;align-items:flex-start;margin-top:", ";"], ({
39
+ spacings
40
+ }) => spacings.top);
41
+ const Text = styled.p.withConfig({
42
+ displayName: "HelperText__Text",
43
+ componentId: "sc-1kfkyxg-1"
44
+ })(["", " margin:0 0 0 ", ";", ""], typographyTemplate(helperText.typography), ({
45
+ spacings
46
+ }) => spacings.left, Variation);
47
+ const TextfieldHelperText = /*#__PURE__*/forwardRef(function TextfieldHelperText({
48
+ helperText: helperText$1,
49
+ icon,
50
+ variant = 'default',
51
+ disabled: isDisabled,
52
+ ...rest
53
+ }, ref) {
54
+ const helperVariant = helperText[variant];
55
+ const spacings = helperText.spacings.comfortable;
56
+ const {
57
+ isFocused
58
+ } = useTextField();
59
+ const colors = {
60
+ color: helperVariant.color,
61
+ disabledColor: helperVariant.disabledColor,
62
+ focusColor: helperVariant.focusColor
63
+ };
64
+ return /*#__PURE__*/jsxs(Container, {
65
+ ref: ref,
66
+ ...rest,
67
+ spacings: spacings,
68
+ children: [icon && /*#__PURE__*/jsx(InputIcon, {
69
+ isDisabled: isDisabled,
70
+ colors: colors,
71
+ size: 16,
72
+ children: icon
73
+ }), /*#__PURE__*/jsx(Text, {
74
+ variant: helperVariant,
75
+ isFocused: isFocused,
76
+ isDisabled: isDisabled,
77
+ spacings: spacings,
78
+ children: helperText$1
79
+ })]
80
+ });
81
+ });
82
+
83
+ export { TextfieldHelperText as HelperText };
@@ -0,0 +1,49 @@
1
+ import { tokens } from '@equinor/eds-tokens';
2
+
3
+ const {
4
+ colors,
5
+ spacings: {
6
+ comfortable
7
+ },
8
+ typography
9
+ } = tokens;
10
+ const helperText = {
11
+ background: colors.ui.background__light.hex,
12
+ typography: typography.input.helper,
13
+ spacings: {
14
+ comfortable: {
15
+ left: comfortable.small,
16
+ right: comfortable.small,
17
+ top: comfortable.small,
18
+ bottom: '6px'
19
+ },
20
+ compact: {
21
+ left: comfortable.small,
22
+ right: comfortable.small,
23
+ top: comfortable.xx_small,
24
+ bottom: '6px'
25
+ }
26
+ },
27
+ default: {
28
+ color: colors.text.static_icons__tertiary.hex,
29
+ disabledColor: colors.interactive.disabled__text.hex,
30
+ focusColor: colors.text.static_icons__tertiary.hex
31
+ },
32
+ error: {
33
+ color: colors.interactive.danger__text.hex,
34
+ disabledColor: colors.interactive.disabled__text.hex,
35
+ focusColor: colors.interactive.danger__hover.hex
36
+ },
37
+ warning: {
38
+ color: colors.interactive.warning__text.hex,
39
+ disabledColor: colors.interactive.disabled__text.hex,
40
+ focusColor: colors.interactive.warning__hover.hex
41
+ },
42
+ success: {
43
+ color: colors.interactive.success__text.hex,
44
+ disabledColor: colors.interactive.disabled__text.hex,
45
+ focusColor: colors.interactive.success__hover.hex
46
+ }
47
+ };
48
+
49
+ export { helperText };