@equinor/eds-core-react 0.14.3 → 0.15.0-dev.20211116

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 (399) hide show
  1. package/dist/core-react.cjs.js +7365 -17203
  2. package/dist/esm/components/Accordion/Accordion.js +27 -0
  3. package/dist/esm/components/Accordion/Accordion.tokens.js +112 -0
  4. package/dist/esm/components/Accordion/AccordionHeader.js +135 -0
  5. package/dist/esm/components/Accordion/AccordionHeaderTitle.js +28 -0
  6. package/dist/esm/components/Accordion/AccordionItem.js +46 -0
  7. package/dist/esm/components/Accordion/AccordionPanel.js +39 -0
  8. package/dist/esm/components/Accordion/index.js +17 -0
  9. package/dist/esm/components/Avatar/Avatar.js +38 -0
  10. package/dist/esm/components/Avatar/Avatar.tokens.js +13 -0
  11. package/dist/esm/components/Banner/Banner.js +49 -0
  12. package/dist/esm/components/Banner/Banner.tokens.js +86 -0
  13. package/dist/esm/components/Banner/BannerActions.js +34 -0
  14. package/dist/esm/components/Banner/BannerIcon.js +39 -0
  15. package/dist/esm/components/Banner/BannerMessage.js +23 -0
  16. package/dist/esm/components/Banner/index.js +14 -0
  17. package/dist/esm/components/Breadcrumbs/Breadcrumb.js +44 -0
  18. package/dist/esm/components/Breadcrumbs/Breadcrumbs.js +86 -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 +98 -0
  22. package/dist/esm/components/Button/InnerFullWidth.js +22 -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 +28 -0
  32. package/dist/esm/components/Card/CardHeader.js +22 -0
  33. package/dist/esm/components/Card/CardHeaderTitle.js +18 -0
  34. package/dist/esm/components/Card/CardMedia.js +27 -0
  35. package/dist/esm/components/Card/index.js +17 -0
  36. package/dist/esm/components/Checkbox/Checkbox.js +40 -0
  37. package/dist/esm/components/Checkbox/Checkbox.tokens.js +91 -0
  38. package/dist/esm/components/Checkbox/Input.js +108 -0
  39. package/dist/esm/components/Chip/Chip.js +125 -0
  40. package/dist/esm/components/Chip/Chip.tokens.js +148 -0
  41. package/dist/esm/components/Chip/Icon.js +31 -0
  42. package/dist/esm/components/Dialog/Actions.js +22 -0
  43. package/dist/esm/components/Dialog/CustomContent.js +36 -0
  44. package/dist/esm/components/Dialog/Dialog.js +30 -0
  45. package/dist/esm/components/Dialog/Dialog.tokens.js +73 -0
  46. package/dist/esm/components/Dialog/Title.js +31 -0
  47. package/dist/esm/components/Dialog/index.js +14 -0
  48. package/dist/esm/components/Divider/Divider.js +32 -0
  49. package/dist/esm/components/Divider/Divider.tokens.js +59 -0
  50. package/dist/esm/components/EdsProvider/eds.context.js +33 -0
  51. package/dist/esm/components/Icon/Icon.js +98 -0
  52. package/dist/esm/components/Icon/index.js +7 -0
  53. package/dist/esm/components/Icon/library.js +19 -0
  54. package/dist/esm/components/Input/Input.js +55 -0
  55. package/dist/esm/components/Input/Input.tokens.js +172 -0
  56. package/dist/esm/components/Label/Label.js +35 -0
  57. package/dist/esm/components/Label/Label.tokens.js +30 -0
  58. package/dist/esm/components/List/List.js +28 -0
  59. package/dist/esm/components/List/List.tokens.js +12 -0
  60. package/dist/esm/components/List/ListItem.js +13 -0
  61. package/dist/esm/components/List/index.js +8 -0
  62. package/dist/esm/components/Menu/Menu.context.js +41 -0
  63. package/dist/esm/components/Menu/Menu.js +102 -0
  64. package/dist/esm/components/Menu/Menu.tokens.js +132 -0
  65. package/dist/esm/components/Menu/MenuItem.js +87 -0
  66. package/dist/esm/components/Menu/MenuList.js +95 -0
  67. package/dist/esm/components/Menu/MenuSection.js +28 -0
  68. package/dist/esm/components/Menu/index.js +11 -0
  69. package/dist/esm/components/Pagination/Pagination.js +148 -0
  70. package/dist/esm/components/Pagination/Pagination.tokens.js +40 -0
  71. package/dist/esm/components/Pagination/PaginationItem.js +28 -0
  72. package/dist/esm/components/Pagination/paginationControl.js +46 -0
  73. package/dist/esm/components/Paper/Paper.js +24 -0
  74. package/dist/esm/components/Paper/Paper.tokens.js +19 -0
  75. package/dist/esm/components/Popover/Popover.js +91 -0
  76. package/dist/esm/components/Popover/Popover.tokens.js +73 -0
  77. package/dist/esm/components/Popover/PopoverContent.js +18 -0
  78. package/dist/esm/components/Popover/PopoverTitle.js +26 -0
  79. package/dist/esm/components/Popover/index.js +11 -0
  80. package/dist/esm/components/Progress/Circular/CircularProgress.js +93 -0
  81. package/dist/esm/components/Progress/Circular/CircularProgress.tokens.js +42 -0
  82. package/dist/esm/components/Progress/Dots/DotProgress.js +54 -0
  83. package/dist/esm/components/Progress/Dots/DotProgress.tokens.js +30 -0
  84. package/dist/esm/components/Progress/Linear/LinearProgress.js +49 -0
  85. package/dist/esm/components/Progress/Linear/LinearProgress.tokens.js +24 -0
  86. package/dist/esm/components/Progress/Star/StarProgress.js +61 -0
  87. package/dist/esm/components/Progress/Star/StarProgress.tokens.js +16 -0
  88. package/dist/esm/components/Progress/index.js +17 -0
  89. package/dist/esm/components/Radio/Radio.js +120 -0
  90. package/dist/esm/components/Radio/Radio.tokens.js +91 -0
  91. package/dist/esm/components/Scrim/Scrim.js +59 -0
  92. package/dist/esm/components/Scrim/Scrim.tokens.js +18 -0
  93. package/dist/esm/components/Search/Search.js +176 -0
  94. package/dist/esm/components/Search/Search.tokens.js +96 -0
  95. package/dist/esm/components/Select/MultiSelect/MultiSelect.js +190 -0
  96. package/dist/esm/components/Select/NativeSelect/NativeSelect.js +59 -0
  97. package/dist/esm/components/Select/NativeSelect/NativeSelect.tokens.js +66 -0
  98. package/dist/esm/components/Select/Select.tokens.js +98 -0
  99. package/dist/esm/components/Select/SingleSelect/SingleSelect.js +135 -0
  100. package/dist/esm/components/Select/commonStyles.js +54 -0
  101. package/dist/esm/components/SideSheet/SideSheet.js +55 -0
  102. package/dist/esm/components/SideSheet/SideSheet.tokens.js +45 -0
  103. package/dist/esm/components/Slider/MinMax.js +24 -0
  104. package/dist/esm/components/Slider/Output.js +30 -0
  105. package/dist/esm/components/Slider/Slider.js +224 -0
  106. package/dist/esm/components/Slider/Slider.tokens.js +136 -0
  107. package/dist/esm/components/Slider/SliderInput.js +60 -0
  108. package/dist/esm/components/Snackbar/Snackbar.js +59 -0
  109. package/dist/esm/components/Snackbar/Snackbar.tokens.js +74 -0
  110. package/dist/esm/components/Snackbar/SnackbarAction.js +19 -0
  111. package/dist/esm/components/Snackbar/index.js +7 -0
  112. package/dist/esm/components/Switch/Switch.js +63 -0
  113. package/dist/esm/components/Switch/Switch.styles.js +34 -0
  114. package/dist/esm/components/Switch/Switch.tokens.js +168 -0
  115. package/dist/esm/components/Switch/SwitchDefault.js +57 -0
  116. package/dist/esm/components/Switch/SwitchSmall.js +54 -0
  117. package/dist/esm/components/Table/Body.js +23 -0
  118. package/dist/esm/components/Table/Caption.js +19 -0
  119. package/dist/esm/components/Table/Cell.js +29 -0
  120. package/dist/esm/components/Table/DataCell/DataCell.js +47 -0
  121. package/dist/esm/components/Table/DataCell/DataCell.tokens.js +151 -0
  122. package/dist/esm/components/Table/Head/Head.js +27 -0
  123. package/dist/esm/components/Table/Head/Head.tokens.js +30 -0
  124. package/dist/esm/components/Table/HeaderCell/HeaderCell.js +63 -0
  125. package/dist/esm/components/Table/HeaderCell/HeaderCell.tokens.js +118 -0
  126. package/dist/esm/components/Table/Inner.context.js +8 -0
  127. package/dist/esm/components/Table/Row/Row.js +33 -0
  128. package/dist/esm/components/Table/Row/Row.tokens.js +26 -0
  129. package/dist/esm/components/Table/Table.js +19 -0
  130. package/dist/esm/components/Table/index.js +20 -0
  131. package/dist/esm/components/TableOfContents/LinkItem.js +22 -0
  132. package/dist/esm/components/TableOfContents/TableOfContents.js +38 -0
  133. package/dist/esm/components/TableOfContents/TableOfContents.tokens.js +103 -0
  134. package/dist/esm/components/TableOfContents/index.js +8 -0
  135. package/dist/esm/components/Tabs/Tab.js +43 -0
  136. package/dist/esm/components/Tabs/TabList.js +89 -0
  137. package/dist/esm/components/Tabs/TabPanel.js +27 -0
  138. package/dist/esm/components/Tabs/TabPanels.js +23 -0
  139. package/dist/esm/components/Tabs/Tabs.context.js +13 -0
  140. package/dist/esm/components/Tabs/Tabs.js +58 -0
  141. package/dist/esm/components/Tabs/Tabs.tokens.js +127 -0
  142. package/dist/esm/components/Tabs/index.js +17 -0
  143. package/dist/esm/components/TextField/Field.js +137 -0
  144. package/dist/esm/components/TextField/HelperText/HelperText.js +80 -0
  145. package/dist/esm/components/TextField/HelperText/HelperText.token.js +49 -0
  146. package/dist/esm/components/TextField/Icon/Icon.js +59 -0
  147. package/dist/esm/components/TextField/Icon/Icon.tokens.js +46 -0
  148. package/dist/esm/components/TextField/TextField.context.js +35 -0
  149. package/dist/esm/components/TextField/TextField.js +74 -0
  150. package/dist/esm/components/TextField/TextField.tokens.js +124 -0
  151. package/dist/esm/components/Textarea/Textarea.js +90 -0
  152. package/dist/esm/components/Tooltip/Tooltip.js +113 -0
  153. package/dist/esm/components/Tooltip/Tooltip.tokens.js +63 -0
  154. package/dist/esm/components/TopBar/Actions.js +18 -0
  155. package/dist/esm/components/TopBar/CustomContent.js +18 -0
  156. package/dist/esm/components/TopBar/Header.js +18 -0
  157. package/dist/esm/components/TopBar/TopBar.js +28 -0
  158. package/dist/esm/components/TopBar/TopBar.tokens.js +32 -0
  159. package/dist/esm/components/TopBar/index.js +14 -0
  160. package/dist/esm/components/Typography/Typography.js +91 -0
  161. package/dist/esm/components/Typography/Typography.tokens.js +61 -0
  162. package/dist/esm/hooks/useAutoResize.js +39 -0
  163. package/dist/esm/hooks/useCombinedRefs.js +14 -0
  164. package/dist/esm/hooks/useGlobalKeyPress.js +34 -0
  165. package/dist/esm/hooks/useHideBodyScroll.js +12 -0
  166. package/dist/esm/hooks/useId.js +14 -0
  167. package/dist/esm/hooks/useMountedRef.js +12 -0
  168. package/dist/esm/hooks/useOutsideClick.js +18 -0
  169. package/dist/esm/hooks/usePopper.js +31 -0
  170. package/dist/esm/hooks/useToken.js +16 -0
  171. package/dist/esm/index.js +41 -0
  172. package/dist/esm/utils/joinHandlers.js +10 -0
  173. package/dist/esm/utils/setReactInputValue.js +18 -0
  174. package/dist/esm/utils/templates/borders.js +35 -0
  175. package/dist/esm/utils/templates/common.js +19 -0
  176. package/dist/esm/utils/templates/focus.js +35 -0
  177. package/dist/esm/utils/templates/index.js +59 -0
  178. package/dist/types/components/Accordion/Accordion.d.ts +4 -4
  179. package/dist/types/components/Accordion/Accordion.tokens.d.ts +10 -10
  180. package/dist/types/components/Accordion/Accordion.types.d.ts +6 -6
  181. package/dist/types/components/Accordion/AccordionHeader.d.ts +35 -35
  182. package/dist/types/components/Accordion/AccordionHeaderTitle.d.ts +14 -14
  183. package/dist/types/components/Accordion/AccordionItem.d.ts +19 -19
  184. package/dist/types/components/Accordion/AccordionPanel.d.ts +18 -18
  185. package/dist/types/components/Accordion/index.d.ts +15 -15
  186. package/dist/types/components/Avatar/Avatar.d.ts +23 -23
  187. package/dist/types/components/Avatar/Avatar.tokens.d.ts +10 -10
  188. package/dist/types/components/Avatar/index.d.ts +1 -1
  189. package/dist/types/components/Banner/Banner.d.ts +7 -7
  190. package/dist/types/components/Banner/Banner.tokens.d.ts +9 -9
  191. package/dist/types/components/Banner/BannerActions.d.ts +11 -11
  192. package/dist/types/components/Banner/BannerIcon.d.ts +15 -15
  193. package/dist/types/components/Banner/BannerMessage.d.ts +10 -10
  194. package/dist/types/components/Banner/index.d.ts +12 -12
  195. package/dist/types/components/Breadcrumbs/Breadcrumb.d.ts +11 -11
  196. package/dist/types/components/Breadcrumbs/Breadcrumbs.d.ts +11 -11
  197. package/dist/types/components/Breadcrumbs/Breadcrumbs.tokens.d.ts +2 -2
  198. package/dist/types/components/Breadcrumbs/index.d.ts +8 -8
  199. package/dist/types/components/Button/Button.d.ts +43 -43
  200. package/dist/types/components/Button/Button.types.d.ts +12 -12
  201. package/dist/types/components/Button/InnerFullWidth.d.ts +2 -2
  202. package/dist/types/components/Button/index.d.ts +1 -1
  203. package/dist/types/components/Button/tokens/button.d.ts +2 -2
  204. package/dist/types/components/Button/tokens/contained.d.ts +4 -4
  205. package/dist/types/components/Button/tokens/ghost.d.ts +4 -4
  206. package/dist/types/components/Button/tokens/icon.d.ts +4 -4
  207. package/dist/types/components/Button/tokens/index.d.ts +8 -8
  208. package/dist/types/components/Button/tokens/outlined.d.ts +4 -4
  209. package/dist/types/components/Card/Card.d.ts +9 -9
  210. package/dist/types/components/Card/Card.tokens.d.ts +6 -6
  211. package/dist/types/components/Card/CardActions.d.ts +13 -13
  212. package/dist/types/components/Card/CardHeader.d.ts +3 -3
  213. package/dist/types/components/Card/CardHeaderTitle.d.ts +3 -3
  214. package/dist/types/components/Card/CardMedia.d.ts +9 -9
  215. package/dist/types/components/Card/index.d.ts +14 -14
  216. package/dist/types/components/Checkbox/Checkbox.d.ts +15 -15
  217. package/dist/types/components/Checkbox/Checkbox.tokens.d.ts +4 -4
  218. package/dist/types/components/Checkbox/Input.d.ts +12 -12
  219. package/dist/types/components/Checkbox/index.d.ts +1 -1
  220. package/dist/types/components/Chip/Chip.d.ts +17 -17
  221. package/dist/types/components/Chip/Chip.tokens.d.ts +8 -8
  222. package/dist/types/components/Chip/Icon.d.ts +6 -6
  223. package/dist/types/components/Chip/index.d.ts +1 -1
  224. package/dist/types/components/Combobox/Combobox.d.ts +55 -55
  225. package/dist/types/components/Combobox/Combobox.tokens.d.ts +3 -3
  226. package/dist/types/components/Combobox/index.d.ts +1 -1
  227. package/dist/types/components/Dialog/Actions.d.ts +3 -3
  228. package/dist/types/components/Dialog/CustomContent.d.ts +9 -9
  229. package/dist/types/components/Dialog/Dialog.d.ts +3 -3
  230. package/dist/types/components/Dialog/Dialog.tokens.d.ts +4 -4
  231. package/dist/types/components/Dialog/Title.d.ts +3 -3
  232. package/dist/types/components/Dialog/index.d.ts +12 -12
  233. package/dist/types/components/Divider/Divider.d.ts +17 -17
  234. package/dist/types/components/Divider/Divider.tokens.d.ts +12 -12
  235. package/dist/types/components/Divider/index.d.ts +1 -1
  236. package/dist/types/components/EdsProvider/eds.context.d.ts +15 -15
  237. package/dist/types/components/EdsProvider/index.d.ts +1 -1
  238. package/dist/types/components/Icon/Icon.d.ts +20 -20
  239. package/dist/types/components/Icon/Icon.types.d.ts +11 -11
  240. package/dist/types/components/Icon/index.d.ts +5 -5
  241. package/dist/types/components/Icon/library.d.ts +8 -8
  242. package/dist/types/components/Input/Input.d.ts +26 -26
  243. package/dist/types/components/Input/Input.tokens.d.ts +12 -12
  244. package/dist/types/components/Input/index.d.ts +1 -1
  245. package/dist/types/components/Label/Label.d.ts +11 -11
  246. package/dist/types/components/Label/Label.tokens.d.ts +4 -4
  247. package/dist/types/components/Label/index.d.ts +1 -1
  248. package/dist/types/components/List/List.d.ts +14 -14
  249. package/dist/types/components/List/List.tokens.d.ts +4 -4
  250. package/dist/types/components/List/ListItem.d.ts +4 -4
  251. package/dist/types/components/List/index.d.ts +8 -8
  252. package/dist/types/components/Menu/Menu.context.d.ts +15 -15
  253. package/dist/types/components/Menu/Menu.d.ts +27 -27
  254. package/dist/types/components/Menu/Menu.tokens.d.ts +4 -4
  255. package/dist/types/components/Menu/Menu.types.d.ts +1 -1
  256. package/dist/types/components/Menu/MenuItem.d.ts +21 -21
  257. package/dist/types/components/Menu/MenuList.d.ts +8 -8
  258. package/dist/types/components/Menu/MenuSection.d.ts +11 -11
  259. package/dist/types/components/Menu/index.d.ts +10 -10
  260. package/dist/types/components/Pagination/Pagination.d.ts +25 -25
  261. package/dist/types/components/Pagination/Pagination.tokens.d.ts +2 -2
  262. package/dist/types/components/Pagination/PaginationItem.d.ts +8 -8
  263. package/dist/types/components/Pagination/index.d.ts +1 -1
  264. package/dist/types/components/Pagination/paginationControl.d.ts +1 -1
  265. package/dist/types/components/Paper/Paper.d.ts +8 -8
  266. package/dist/types/components/Paper/Paper.tokens.d.ts +12 -12
  267. package/dist/types/components/Paper/index.d.ts +1 -1
  268. package/dist/types/components/Popover/Popover.d.ts +22 -22
  269. package/dist/types/components/Popover/Popover.tokens.d.ts +4 -4
  270. package/dist/types/components/Popover/PopoverContent.d.ts +3 -3
  271. package/dist/types/components/Popover/PopoverTitle.d.ts +3 -3
  272. package/dist/types/components/Popover/index.d.ts +10 -10
  273. package/dist/types/components/Progress/Circular/CircularProgress.d.ts +16 -16
  274. package/dist/types/components/Progress/Circular/CircularProgress.tokens.d.ts +8 -8
  275. package/dist/types/components/Progress/Dots/DotProgress.d.ts +11 -11
  276. package/dist/types/components/Progress/Dots/DotProgress.tokens.d.ts +5 -5
  277. package/dist/types/components/Progress/Linear/LinearProgress.d.ts +18 -18
  278. package/dist/types/components/Progress/Linear/LinearProgress.tokens.d.ts +7 -7
  279. package/dist/types/components/Progress/Star/StarProgress.d.ts +14 -14
  280. package/dist/types/components/Progress/Star/StarProgress.tokens.d.ts +2 -2
  281. package/dist/types/components/Progress/index.d.ts +15 -15
  282. package/dist/types/components/Radio/Radio.d.ts +10 -10
  283. package/dist/types/components/Radio/Radio.tokens.d.ts +4 -4
  284. package/dist/types/components/Radio/index.d.ts +1 -1
  285. package/dist/types/components/Scrim/Scrim.d.ts +15 -15
  286. package/dist/types/components/Scrim/Scrim.tokens.d.ts +2 -2
  287. package/dist/types/components/Scrim/index.d.ts +1 -1
  288. package/dist/types/components/Search/Search.d.ts +3 -3
  289. package/dist/types/components/Search/Search.tokens.d.ts +4 -4
  290. package/dist/types/components/Search/index.d.ts +1 -1
  291. package/dist/types/components/Select/MultiSelect/MultiSelect.d.ts +48 -48
  292. package/dist/types/components/Select/MultiSelect/index.d.ts +1 -1
  293. package/dist/types/components/Select/NativeSelect/NativeSelect.d.ts +29 -29
  294. package/dist/types/components/Select/NativeSelect/NativeSelect.tokens.d.ts +4 -4
  295. package/dist/types/components/Select/NativeSelect/index.d.ts +1 -1
  296. package/dist/types/components/Select/Select.tokens.d.ts +3 -3
  297. package/dist/types/components/Select/SingleSelect/SingleSelect.d.ts +48 -48
  298. package/dist/types/components/Select/SingleSelect/index.d.ts +1 -1
  299. package/dist/types/components/Select/commonStyles.d.ts +32 -32
  300. package/dist/types/components/Select/index.d.ts +3 -3
  301. package/dist/types/components/SideSheet/SideSheet.d.ts +21 -21
  302. package/dist/types/components/SideSheet/SideSheet.tokens.d.ts +10 -10
  303. package/dist/types/components/SideSheet/index.d.ts +1 -1
  304. package/dist/types/components/Slider/MinMax.d.ts +5 -5
  305. package/dist/types/components/Slider/Output.d.ts +9 -9
  306. package/dist/types/components/Slider/Slider.d.ts +49 -49
  307. package/dist/types/components/Slider/Slider.tokens.d.ts +4 -4
  308. package/dist/types/components/Slider/SliderInput.d.ts +21 -21
  309. package/dist/types/components/Slider/index.d.ts +1 -1
  310. package/dist/types/components/Snackbar/Snackbar.d.ts +21 -21
  311. package/dist/types/components/Snackbar/Snackbar.tokens.d.ts +4 -4
  312. package/dist/types/components/Snackbar/SnackbarAction.d.ts +5 -5
  313. package/dist/types/components/Snackbar/index.d.ts +8 -8
  314. package/dist/types/components/Switch/Switch.d.ts +12 -12
  315. package/dist/types/components/Switch/Switch.styles.d.ts +5 -5
  316. package/dist/types/components/Switch/Switch.tokens.d.ts +3 -3
  317. package/dist/types/components/Switch/SwitchDefault.d.ts +6 -6
  318. package/dist/types/components/Switch/SwitchSmall.d.ts +6 -6
  319. package/dist/types/components/Switch/index.d.ts +1 -1
  320. package/dist/types/components/Table/Body.d.ts +3 -3
  321. package/dist/types/components/Table/Caption.d.ts +4 -4
  322. package/dist/types/components/Table/Cell.d.ts +11 -11
  323. package/dist/types/components/Table/DataCell/DataCell.d.ts +8 -8
  324. package/dist/types/components/Table/DataCell/DataCell.tokens.d.ts +15 -15
  325. package/dist/types/components/Table/DataCell/index.d.ts +1 -1
  326. package/dist/types/components/Table/Head/Head.d.ts +9 -9
  327. package/dist/types/components/Table/Head/Head.tokens.d.ts +2 -2
  328. package/dist/types/components/Table/Head/index.d.ts +1 -1
  329. package/dist/types/components/Table/HeaderCell/HeaderCell.d.ts +5 -5
  330. package/dist/types/components/Table/HeaderCell/HeaderCell.tokens.d.ts +3 -3
  331. package/dist/types/components/Table/HeaderCell/index.d.ts +1 -1
  332. package/dist/types/components/Table/Inner.context.d.ts +7 -7
  333. package/dist/types/components/Table/Row/Row.d.ts +9 -9
  334. package/dist/types/components/Table/Row/Row.tokens.d.ts +2 -2
  335. package/dist/types/components/Table/Row/index.d.ts +1 -1
  336. package/dist/types/components/Table/Table.d.ts +3 -3
  337. package/dist/types/components/Table/Table.types.d.ts +2 -2
  338. package/dist/types/components/Table/index.d.ts +16 -16
  339. package/dist/types/components/TableOfContents/LinkItem.d.ts +3 -3
  340. package/dist/types/components/TableOfContents/TableOfContents.d.ts +14 -14
  341. package/dist/types/components/TableOfContents/TableOfContents.tokens.d.ts +4 -4
  342. package/dist/types/components/TableOfContents/index.d.ts +8 -8
  343. package/dist/types/components/Tabs/Tab.d.ts +13 -13
  344. package/dist/types/components/Tabs/TabList.d.ts +11 -11
  345. package/dist/types/components/Tabs/TabPanel.d.ts +10 -10
  346. package/dist/types/components/Tabs/TabPanels.d.ts +4 -4
  347. package/dist/types/components/Tabs/Tabs.context.d.ts +13 -13
  348. package/dist/types/components/Tabs/Tabs.d.ts +19 -19
  349. package/dist/types/components/Tabs/Tabs.tokens.d.ts +2 -2
  350. package/dist/types/components/Tabs/Tabs.types.d.ts +1 -1
  351. package/dist/types/components/Tabs/index.d.ts +14 -14
  352. package/dist/types/components/TextField/Field.d.ts +34 -34
  353. package/dist/types/components/TextField/HelperText/HelperText.d.ts +14 -14
  354. package/dist/types/components/TextField/HelperText/HelperText.token.d.ts +15 -15
  355. package/dist/types/components/TextField/HelperText/index.d.ts +1 -1
  356. package/dist/types/components/TextField/Icon/Icon.d.ts +13 -13
  357. package/dist/types/components/TextField/Icon/Icon.tokens.d.ts +14 -14
  358. package/dist/types/components/TextField/Icon/index.d.ts +1 -1
  359. package/dist/types/components/TextField/TextField.context.d.ts +17 -17
  360. package/dist/types/components/TextField/TextField.d.ts +37 -37
  361. package/dist/types/components/TextField/TextField.tokens.d.ts +10 -10
  362. package/dist/types/components/TextField/index.d.ts +1 -1
  363. package/dist/types/components/TextField/types.d.ts +6 -6
  364. package/dist/types/components/Textarea/Textarea.d.ts +30 -30
  365. package/dist/types/components/Textarea/index.d.ts +1 -1
  366. package/dist/types/components/Tooltip/Tooltip.d.ts +22 -22
  367. package/dist/types/components/Tooltip/Tooltip.tokens.d.ts +4 -4
  368. package/dist/types/components/Tooltip/index.d.ts +1 -1
  369. package/dist/types/components/TopBar/Actions.d.ts +3 -3
  370. package/dist/types/components/TopBar/CustomContent.d.ts +3 -3
  371. package/dist/types/components/TopBar/Header.d.ts +3 -3
  372. package/dist/types/components/TopBar/TopBar.d.ts +3 -3
  373. package/dist/types/components/TopBar/TopBar.tokens.d.ts +4 -4
  374. package/dist/types/components/TopBar/index.d.ts +12 -12
  375. package/dist/types/components/Typography/Typography.d.ts +15 -15
  376. package/dist/types/components/Typography/Typography.tokens.d.ts +453 -453
  377. package/dist/types/components/Typography/index.d.ts +1 -1
  378. package/dist/types/hooks/index.d.ts +9 -9
  379. package/dist/types/hooks/useAutoResize.d.ts +1 -1
  380. package/dist/types/hooks/useCombinedRefs.d.ts +3 -3
  381. package/dist/types/hooks/useGlobalKeyPress.d.ts +10 -10
  382. package/dist/types/hooks/useHideBodyScroll.d.ts +1 -1
  383. package/dist/types/hooks/useId.d.ts +1 -1
  384. package/dist/types/hooks/useMountedRef.d.ts +1 -1
  385. package/dist/types/hooks/useOutsideClick.d.ts +1 -1
  386. package/dist/types/hooks/usePopper.d.ts +12 -12
  387. package/dist/types/hooks/useToken.d.ts +7 -7
  388. package/dist/types/index.d.ts +35 -35
  389. package/dist/types/utils/index.d.ts +4 -4
  390. package/dist/types/utils/joinHandlers.d.ts +3 -3
  391. package/dist/types/utils/setReactInputValue.d.ts +7 -7
  392. package/dist/types/utils/templates/borders.d.ts +2 -2
  393. package/dist/types/utils/templates/common.d.ts +9 -9
  394. package/dist/types/utils/templates/focus.d.ts +2 -2
  395. package/dist/types/utils/templates/index.d.ts +7 -7
  396. package/package.json +10 -15
  397. package/dist/core-react.esm.js +0 -18369
  398. package/dist/core-react.umd.js +0 -18441
  399. package/src/index.ts +0 -37
@@ -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,58 @@
1
+ import _extends from '@babel/runtime/helpers/extends';
2
+ import { forwardRef, useState } from 'react';
3
+ import { TabsProvider } from './Tabs.context.js';
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__*/React.createElement(TabsProvider, {
43
+ value: {
44
+ activeTab,
45
+ handleChange: onChange,
46
+ tabsId,
47
+ variant,
48
+ tabsFocused
49
+ }
50
+ }, /*#__PURE__*/React.createElement("div", _extends({
51
+ ref: ref
52
+ }, props, {
53
+ onBlur: handleBlur,
54
+ onFocus: handleFocus
55
+ })));
56
+ });
57
+
58
+ 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,137 @@
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 { Input } from '../Input/Input.js';
6
+ import { Textarea } from '../Textarea/Textarea.js';
7
+ import { Icon as InputIcon } from './Icon/Icon.js';
8
+ import { typographyTemplate } from '../../utils/templates/index.js';
9
+ import { useEds } from '../EdsProvider/eds.context.js';
10
+ import { outlineTemplate } from '../../utils/templates/focus.js';
11
+
12
+ const {
13
+ textfield
14
+ } = TextField_tokens;
15
+
16
+ const Variation = ({
17
+ variant,
18
+ isFocused,
19
+ token
20
+ }) => {
21
+ var _token$border, _token$border2, _token$border3, _token$border4;
22
+
23
+ if (!variant) {
24
+ return ``;
25
+ }
26
+
27
+ return css(["box-shadow:", ";", ""], isFocused ? `none` : variant === 'default' ? `inset 0 -1px 0 0 ${((_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 ${((_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));
28
+ };
29
+
30
+ const StrippedInput = styled(Input).withConfig({
31
+ displayName: "Field__StrippedInput",
32
+ componentId: "sc-455b88-0"
33
+ })(["outline:none;&:active,&:focus{outline:none;box-shadow:none;}"]);
34
+ const StrippedTextarea = styled(Textarea).withConfig({
35
+ displayName: "Field__StrippedTextarea",
36
+ componentId: "sc-455b88-1"
37
+ })(["outline:none;&:active,&:focus{outline:none;box-shadow:none;}"]);
38
+ const InputWrapper = styled.div.withConfig({
39
+ displayName: "Field__InputWrapper",
40
+ componentId: "sc-455b88-2"
41
+ })(({
42
+ inputIcon,
43
+ unit,
44
+ isDisabled,
45
+ isReadOnly,
46
+ multiline,
47
+ variant
48
+ }) => 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;"])));
49
+ const Unit = styled.span.withConfig({
50
+ displayName: "Field__Unit",
51
+ componentId: "sc-455b88-3"
52
+ })(["", ";display:inline-block;margin-top:3px;", ""], typographyTemplate(textfield.entities.unit.typography), ({
53
+ isDisabled
54
+ }) => isDisabled && {
55
+ color: textfield.entities.unit.states.disabled.typography.color
56
+ });
57
+ const Adornments = styled.div.withConfig({
58
+ displayName: "Field__Adornments",
59
+ componentId: "sc-455b88-4"
60
+ })(["display:flex;align-items:center;justify-content:center;height:100%;margin-left:", ";& div:nth-child(2){margin-left:", ";}", ""], textfield.spacings.left, textfield.spacings.left, ({
61
+ multiline,
62
+ theme
63
+ }) => multiline && {
64
+ marginTop: theme.spacings.top,
65
+ alignSelf: 'start'
66
+ });
67
+ const Field = /*#__PURE__*/forwardRef(function Field({
68
+ multiline,
69
+ variant,
70
+ disabled,
71
+ readOnly,
72
+ type,
73
+ unit,
74
+ inputIcon,
75
+ rowsMax,
76
+ onBlur,
77
+ onFocus,
78
+ ...other
79
+ }, ref) {
80
+ const {
81
+ handleFocus,
82
+ handleBlur,
83
+ isFocused
84
+ } = useTextField();
85
+ const {
86
+ density
87
+ } = useEds();
88
+ const iconSize = density === 'compact' ? 16 : 24;
89
+ const actualVariant = variant === 'default' ? 'textfield' : variant;
90
+ const inputVariant = TextField_tokens[actualVariant];
91
+
92
+ const focusHandler = e => {
93
+ handleFocus();
94
+ onFocus && onFocus(e);
95
+ };
96
+
97
+ const blurHandler = e => {
98
+ handleBlur();
99
+ onBlur && onBlur(e);
100
+ };
101
+
102
+ const inputWrapperProps = {
103
+ isFocused,
104
+ isDisabled: disabled,
105
+ isReadOnly: readOnly,
106
+ variant,
107
+ token: inputVariant,
108
+ inputIcon,
109
+ unit,
110
+ multiline
111
+ };
112
+ const inputProps = {
113
+ ref: ref,
114
+ type,
115
+ disabled,
116
+ readOnly,
117
+ variant,
118
+ onBlur: blurHandler,
119
+ onFocus: focusHandler,
120
+ ...other
121
+ };
122
+ const textareaProps = { ...inputProps,
123
+ rowsMax,
124
+ ref: ref
125
+ };
126
+ return /*#__PURE__*/React.createElement(InputWrapper, inputWrapperProps, multiline ? /*#__PURE__*/React.createElement(StrippedTextarea, textareaProps) : /*#__PURE__*/React.createElement(StrippedInput, inputProps), (inputIcon || unit) && /*#__PURE__*/React.createElement(Adornments, {
127
+ multiline: multiline
128
+ }, unit && /*#__PURE__*/React.createElement(Unit, {
129
+ isDisabled: disabled
130
+ }, unit), inputIcon && /*#__PURE__*/React.createElement(InputIcon, {
131
+ isDisabled: disabled,
132
+ variant: variant,
133
+ size: iconSize
134
+ }, inputIcon)));
135
+ });
136
+
137
+ export { Field, InputWrapper };
@@ -0,0 +1,80 @@
1
+ import _extends from '@babel/runtime/helpers/extends';
2
+ import { forwardRef } from 'react';
3
+ import styled, { css } from 'styled-components';
4
+ import { helperText } from './HelperText.token.js';
5
+ import { useTextField } from '../TextField.context.js';
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__*/React.createElement(Container, _extends({
65
+ ref: ref
66
+ }, rest, {
67
+ spacings: spacings
68
+ }), icon && /*#__PURE__*/React.createElement(InputIcon, {
69
+ isDisabled: isDisabled,
70
+ colors: colors,
71
+ size: 16
72
+ }, icon), /*#__PURE__*/React.createElement(Text, {
73
+ variant: helperVariant,
74
+ isFocused: isFocused,
75
+ isDisabled: isDisabled,
76
+ spacings: spacings
77
+ }, helperText$1));
78
+ });
79
+
80
+ 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 };
@@ -0,0 +1,59 @@
1
+ import _extends from '@babel/runtime/helpers/extends';
2
+ import { forwardRef } from 'react';
3
+ import styled, { css } from 'styled-components';
4
+ import { useTextField } from '../TextField.context.js';
5
+ import { input } from './Icon.tokens.js';
6
+
7
+ const StyledIcon = styled.div.withConfig({
8
+ displayName: "Icon__StyledIcon",
9
+ componentId: "sc-jr0rqa-0"
10
+ })(({
11
+ colors,
12
+ isDisabled,
13
+ isFocused,
14
+ size
15
+ }) => {
16
+ const {
17
+ focusColor,
18
+ color,
19
+ disabledColor
20
+ } = colors;
21
+ let fill = color;
22
+
23
+ if (isDisabled) {
24
+ fill = disabledColor;
25
+ }
26
+
27
+ if (isFocused) {
28
+ fill = focusColor;
29
+ }
30
+
31
+ return css(["&,svg{fill:", ";width:", "px;height:", "px;}"], fill, size, size);
32
+ });
33
+ const InputIcon = /*#__PURE__*/forwardRef(function InputIcon({
34
+ size = 24,
35
+ variant = 'default',
36
+ isDisabled = false,
37
+ colors = {
38
+ color: input[variant].color,
39
+ disabledColor: input[variant].disabledColor,
40
+ focusColor: input[variant].focusColor
41
+ },
42
+ children,
43
+ ...other
44
+ }, ref) {
45
+ const {
46
+ isFocused
47
+ } = useTextField();
48
+ const iconProps = {
49
+ isDisabled,
50
+ colors,
51
+ isFocused,
52
+ size
53
+ };
54
+ return /*#__PURE__*/React.createElement(StyledIcon, _extends({
55
+ ref: ref
56
+ }, iconProps, other), children);
57
+ });
58
+
59
+ export { InputIcon as Icon };
@@ -0,0 +1,46 @@
1
+ import { tokens } from '@equinor/eds-tokens';
2
+
3
+ const {
4
+ colors,
5
+ spacings: {
6
+ comfortable
7
+ }
8
+ } = tokens;
9
+ const input = {
10
+ spacings: {
11
+ comfortable: {
12
+ left: comfortable.small,
13
+ right: comfortable.small,
14
+ top: '10px',
15
+ bottom: '10px'
16
+ },
17
+ compact: {
18
+ left: comfortable.small,
19
+ right: comfortable.small,
20
+ top: '10px',
21
+ bottom: '10px'
22
+ }
23
+ },
24
+ default: {
25
+ color: colors.text.static_icons__tertiary.hex,
26
+ disabledColor: colors.interactive.disabled__fill.hex,
27
+ focusColor: colors.interactive.primary__resting.hex
28
+ },
29
+ error: {
30
+ color: colors.interactive.danger__resting.hex,
31
+ disabledColor: colors.interactive.disabled__fill.hex,
32
+ focusColor: colors.interactive.danger__hover.hex
33
+ },
34
+ warning: {
35
+ color: colors.interactive.warning__resting.hex,
36
+ disabledColor: colors.interactive.disabled__fill.hex,
37
+ focusColor: colors.interactive.warning__hover.hex
38
+ },
39
+ success: {
40
+ color: colors.interactive.success__resting.hex,
41
+ disabledColor: colors.interactive.disabled__fill.hex,
42
+ focusColor: colors.interactive.success__hover.hex
43
+ }
44
+ };
45
+
46
+ export { input };
@@ -0,0 +1,35 @@
1
+ import { useState, useContext, createContext } from 'react';
2
+
3
+ const initalState = {
4
+ isFocused: false
5
+ };
6
+ const TextFieldContext = /*#__PURE__*/createContext(initalState);
7
+ const TextFieldProvider = ({
8
+ children
9
+ }) => {
10
+ const [state, setState] = useState(initalState);
11
+
12
+ const handleFocus = () => {
13
+ setState(prevState => ({ ...prevState,
14
+ isFocused: true
15
+ }));
16
+ };
17
+
18
+ const handleBlur = () => {
19
+ setState(prevState => ({ ...prevState,
20
+ isFocused: false
21
+ }));
22
+ };
23
+
24
+ const value = {
25
+ handleFocus,
26
+ handleBlur,
27
+ isFocused: state.isFocused
28
+ };
29
+ return /*#__PURE__*/React.createElement(TextFieldContext.Provider, {
30
+ value: value
31
+ }, children);
32
+ };
33
+ const useTextField = () => useContext(TextFieldContext);
34
+
35
+ export { TextFieldProvider, useTextField };
@@ -0,0 +1,74 @@
1
+ import { forwardRef } from 'react';
2
+ import styled, { ThemeProvider } from 'styled-components';
3
+ import { Field } from './Field.js';
4
+ import { TextFieldProvider } from './TextField.context.js';
5
+ import { textfield } from './TextField.tokens.js';
6
+ import { Label } from '../Label/Label.js';
7
+ import { HelperText as TextfieldHelperText } from './HelperText/HelperText.js';
8
+ import { useEds } from '../EdsProvider/eds.context.js';
9
+ import { useToken } from '../../hooks/useToken.js';
10
+
11
+ const Container = styled.div.withConfig({
12
+ displayName: "TextField__Container",
13
+ componentId: "sc-o1nc07-0"
14
+ })(["min-width:100px;width:100%;"]);
15
+ const TextField = /*#__PURE__*/forwardRef(function TextField({
16
+ id,
17
+ label,
18
+ meta,
19
+ unit,
20
+ helperText,
21
+ placeholder,
22
+ disabled,
23
+ multiline,
24
+ className,
25
+ variant = 'default',
26
+ inputRef,
27
+ inputIcon,
28
+ helperIcon,
29
+ rowsMax,
30
+ ...other
31
+ }, ref) {
32
+ const inputProps = {
33
+ multiline,
34
+ disabled,
35
+ placeholder,
36
+ id,
37
+ variant,
38
+ ref: inputRef,
39
+ inputIcon,
40
+ unit,
41
+ rowsMax,
42
+ ...other
43
+ };
44
+ const helperProps = {
45
+ variant,
46
+ helperText,
47
+ icon: helperIcon,
48
+ disabled
49
+ };
50
+ const containerProps = {
51
+ ref,
52
+ className,
53
+ style: other.style
54
+ };
55
+ const labelProps = {
56
+ htmlFor: id,
57
+ label,
58
+ meta,
59
+ disabled
60
+ };
61
+ const showLabel = label || meta;
62
+ const showHelperText = helperText;
63
+ const {
64
+ density
65
+ } = useEds();
66
+ const token = useToken({
67
+ density
68
+ }, textfield);
69
+ return /*#__PURE__*/React.createElement(ThemeProvider, {
70
+ theme: token
71
+ }, /*#__PURE__*/React.createElement(Container, containerProps, /*#__PURE__*/React.createElement(TextFieldProvider, null, showLabel && /*#__PURE__*/React.createElement(Label, labelProps), /*#__PURE__*/React.createElement(Field, inputProps), showHelperText && /*#__PURE__*/React.createElement(TextfieldHelperText, helperProps))));
72
+ });
73
+
74
+ export { TextField };