@equinor/eds-core-react 0.14.2 → 0.15.0-dev.20211118

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 +7574 -17437
  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 +40 -0
  30. package/dist/esm/components/Card/Card.tokens.js +54 -0
  31. package/dist/esm/components/Card/CardActions.js +32 -0
  32. package/dist/esm/components/Card/CardHeader.js +25 -0
  33. package/dist/esm/components/Card/CardHeaderTitle.js +21 -0
  34. package/dist/esm/components/Card/CardMedia.js +30 -0
  35. package/dist/esm/components/Card/index.js +17 -0
  36. package/dist/esm/components/Checkbox/Checkbox.js +44 -0
  37. package/dist/esm/components/Checkbox/Checkbox.tokens.js +91 -0
  38. package/dist/esm/components/Checkbox/Input.js +115 -0
  39. package/dist/esm/components/Chip/Chip.js +126 -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 +24 -0
  43. package/dist/esm/components/Dialog/CustomContent.js +40 -0
  44. package/dist/esm/components/Dialog/Dialog.js +31 -0
  45. package/dist/esm/components/Dialog/Dialog.tokens.js +73 -0
  46. package/dist/esm/components/Dialog/Title.js +35 -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 +35 -0
  51. package/dist/esm/components/Icon/Icon.js +102 -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 +58 -0
  55. package/dist/esm/components/Input/Input.tokens.js +172 -0
  56. package/dist/esm/components/Label/Label.js +41 -0
  57. package/dist/esm/components/Label/Label.tokens.js +30 -0
  58. package/dist/esm/components/List/List.js +30 -0
  59. package/dist/esm/components/List/List.tokens.js +12 -0
  60. package/dist/esm/components/List/ListItem.js +14 -0
  61. package/dist/esm/components/List/index.js +8 -0
  62. package/dist/esm/components/Menu/Menu.context.js +43 -0
  63. package/dist/esm/components/Menu/Menu.js +110 -0
  64. package/dist/esm/components/Menu/Menu.tokens.js +132 -0
  65. package/dist/esm/components/Menu/MenuItem.js +90 -0
  66. package/dist/esm/components/Menu/MenuList.js +96 -0
  67. package/dist/esm/components/Menu/MenuSection.js +36 -0
  68. package/dist/esm/components/Menu/index.js +11 -0
  69. package/dist/esm/components/Pagination/Pagination.js +159 -0
  70. package/dist/esm/components/Pagination/Pagination.tokens.js +40 -0
  71. package/dist/esm/components/Pagination/PaginationItem.js +30 -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 +96 -0
  76. package/dist/esm/components/Popover/Popover.tokens.js +73 -0
  77. package/dist/esm/components/Popover/PopoverContent.js +21 -0
  78. package/dist/esm/components/Popover/PopoverTitle.js +31 -0
  79. package/dist/esm/components/Popover/index.js +11 -0
  80. package/dist/esm/components/Progress/Circular/CircularProgress.js +94 -0
  81. package/dist/esm/components/Progress/Circular/CircularProgress.tokens.js +42 -0
  82. package/dist/esm/components/Progress/Dots/DotProgress.js +55 -0
  83. package/dist/esm/components/Progress/Dots/DotProgress.tokens.js +30 -0
  84. package/dist/esm/components/Progress/Linear/LinearProgress.js +50 -0
  85. package/dist/esm/components/Progress/Linear/LinearProgress.tokens.js +24 -0
  86. package/dist/esm/components/Progress/Star/StarProgress.js +62 -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 +128 -0
  90. package/dist/esm/components/Radio/Radio.tokens.js +91 -0
  91. package/dist/esm/components/Scrim/Scrim.js +62 -0
  92. package/dist/esm/components/Scrim/Scrim.tokens.js +18 -0
  93. package/dist/esm/components/Search/Search.js +180 -0
  94. package/dist/esm/components/Search/Search.tokens.js +96 -0
  95. package/dist/esm/components/Select/MultiSelect/MultiSelect.js +202 -0
  96. package/dist/esm/components/Select/NativeSelect/NativeSelect.js +66 -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 +145 -0
  100. package/dist/esm/components/Select/commonStyles.js +54 -0
  101. package/dist/esm/components/SideSheet/SideSheet.js +60 -0
  102. package/dist/esm/components/SideSheet/SideSheet.tokens.js +45 -0
  103. package/dist/esm/components/Slider/MinMax.js +26 -0
  104. package/dist/esm/components/Slider/Output.js +32 -0
  105. package/dist/esm/components/Slider/Slider.js +243 -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 +63 -0
  109. package/dist/esm/components/Snackbar/Snackbar.tokens.js +74 -0
  110. package/dist/esm/components/Snackbar/SnackbarAction.js +22 -0
  111. package/dist/esm/components/Snackbar/index.js +7 -0
  112. package/dist/esm/components/Switch/Switch.js +67 -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 +61 -0
  116. package/dist/esm/components/Switch/SwitchSmall.js +59 -0
  117. package/dist/esm/components/Table/Body.js +25 -0
  118. package/dist/esm/components/Table/Caption.js +19 -0
  119. package/dist/esm/components/Table/Cell.js +33 -0
  120. package/dist/esm/components/Table/DataCell/DataCell.js +49 -0
  121. package/dist/esm/components/Table/DataCell/DataCell.tokens.js +151 -0
  122. package/dist/esm/components/Table/Head/Head.js +29 -0
  123. package/dist/esm/components/Table/Head/Head.tokens.js +30 -0
  124. package/dist/esm/components/Table/HeaderCell/HeaderCell.js +67 -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 +34 -0
  128. package/dist/esm/components/Table/Row/Row.tokens.js +26 -0
  129. package/dist/esm/components/Table/Table.js +20 -0
  130. package/dist/esm/components/Table/index.js +20 -0
  131. package/dist/esm/components/TableOfContents/LinkItem.js +23 -0
  132. package/dist/esm/components/TableOfContents/TableOfContents.js +43 -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 +44 -0
  136. package/dist/esm/components/Tabs/TabList.js +90 -0
  137. package/dist/esm/components/Tabs/TabPanel.js +29 -0
  138. package/dist/esm/components/Tabs/TabPanels.js +25 -0
  139. package/dist/esm/components/Tabs/Tabs.context.js +13 -0
  140. package/dist/esm/components/Tabs/Tabs.js +59 -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 +145 -0
  144. package/dist/esm/components/TextField/HelperText/HelperText.js +83 -0
  145. package/dist/esm/components/TextField/HelperText/HelperText.token.js +49 -0
  146. package/dist/esm/components/TextField/Icon/Icon.js +62 -0
  147. package/dist/esm/components/TextField/Icon/Icon.tokens.js +46 -0
  148. package/dist/esm/components/TextField/TextField.context.js +37 -0
  149. package/dist/esm/components/TextField/TextField.js +83 -0
  150. package/dist/esm/components/TextField/TextField.tokens.js +124 -0
  151. package/dist/esm/components/Textarea/Textarea.js +92 -0
  152. package/dist/esm/components/Tooltip/Tooltip.js +119 -0
  153. package/dist/esm/components/Tooltip/Tooltip.tokens.js +63 -0
  154. package/dist/esm/components/TopBar/Actions.js +20 -0
  155. package/dist/esm/components/TopBar/CustomContent.js +20 -0
  156. package/dist/esm/components/TopBar/Header.js +20 -0
  157. package/dist/esm/components/TopBar/TopBar.js +29 -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 +93 -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 +40 -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 +36 -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 +34 -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 +3 -2
  395. package/dist/types/utils/templates/index.d.ts +7 -7
  396. package/package.json +17 -24
  397. package/dist/core-react.esm.js +0 -18687
  398. package/dist/core-react.umd.js +0 -18759
  399. package/src/index.ts +0 -37
@@ -0,0 +1,62 @@
1
+ import { forwardRef } from 'react';
2
+ import styled, { keyframes, css } from 'styled-components';
3
+ import { token } from './StarProgress.tokens.js';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ const indeterminate = keyframes(["0%{opacity:1;}20%{opacity:0.8;}40%{opacity:0.6;}60%{opacity:0.4;}80%{opacity:0.2;}100%{opacity:0.05;}"]);
7
+ const determinate = keyframes(["0%{opacity:0;}10%{opacity:0.05;}20%{opacity:0.2;}40%{opacity:0.4;}60%{opacity:0.6;}80%{opacity:0.8;}100%{opacity:1;}"]);
8
+ const Svg = styled.svg.withConfig({
9
+ displayName: "StarProgress__Svg",
10
+ componentId: "sc-c0byj9-0"
11
+ })(["fill:", ";", ""], token.background, ({
12
+ variant,
13
+ progress
14
+ }) => variant === 'indeterminate' ? css(["path{&:nth-child(1){animation:", " 1.3s linear infinite;}&:nth-child(2){animation:", " 1.3s linear 0.3s infinite;}&:nth-child(3){animation:", " 1.3s linear 0.4s infinite;}&:nth-child(4){animation:", " 1.3s linear 0.6s infinite;}&:nth-child(5){animation:", " 1.3s linear 0.8s infinite;}&:nth-child(6){animation:", " 1.3s linear 1s infinite;}}"], indeterminate, indeterminate, indeterminate, indeterminate, indeterminate, indeterminate) : css(["path{animation:", " 1.3s linear;&:nth-child(6){animation-play-state:", ";}&:nth-child(5){animation-play-state:", ";}&:nth-child(4){animation-play-state:", ";}&:nth-child(3){animation-play-state:", ";}&:nth-child(2){animation-play-state:", ";}&:nth-child(1){animation-play-state:", ";}}"], determinate, progress > 90 ? 'running' : 'paused', progress > 80 ? 'running' : 'paused', progress > 60 ? 'running' : 'paused', progress > 40 ? 'running' : 'paused', progress > 20 ? 'running' : 'paused', progress <= 20 ? 'running' : 'paused'));
15
+ const StarProgress = /*#__PURE__*/forwardRef(function StarProgress({
16
+ variant = 'indeterminate',
17
+ value = null,
18
+ size = 48,
19
+ ...rest
20
+ }, ref) {
21
+ const progress = Math.round(value);
22
+ const height = size * 1.2;
23
+ const width = size;
24
+ const props = { ...rest,
25
+ ref,
26
+ variant,
27
+ progress
28
+ };
29
+
30
+ if (variant === 'determinate') {
31
+ if (value !== undefined) {
32
+ props['aria-valuenow'] = progress;
33
+ props['aria-valuemin'] = 0;
34
+ props['aria-valuemax'] = 100;
35
+ }
36
+ }
37
+
38
+ return /*#__PURE__*/jsxs(Svg, { ...props,
39
+ role: "progressbar",
40
+ width: width,
41
+ height: height,
42
+ viewBox: "0 0 40 48",
43
+ fill: "none",
44
+ xmlns: "http://www.w3.org/2000/svg",
45
+ preserveAspectRatio: "xMidYMid meet",
46
+ children: [/*#__PURE__*/jsx("path", {
47
+ d: "M32.756 34.6798L29.482 36.5817C29.4139 36.6219 29.3295 36.6227 29.2606 36.5829L25.9476 34.7151C25.7975 34.6306 25.7967 34.4149 25.9456 34.3284L29.2397 32.4256C29.3077 32.3858 29.3914 32.3858 29.4603 32.4248L32.754 34.2931C32.9033 34.3784 32.9041 34.5929 32.756 34.6798Z"
48
+ }), /*#__PURE__*/jsx("path", {
49
+ d: "M25.9596 45.4706L22.6655 43.5867C22.5966 43.5469 22.554 43.4744 22.554 43.396V41.4289V39.5922C22.5519 39.4204 22.7381 39.3109 22.8878 39.397L26.1819 41.2981C26.25 41.3379 26.2926 41.4104 26.2934 41.4896V43.4268V45.2762C26.2947 45.4472 26.1085 45.5559 25.9596 45.4706Z"
50
+ }), /*#__PURE__*/jsx("path", {
51
+ d: "M12.3022 47.7037V44.9795V42.6544C12.3022 42.5495 12.3576 42.4515 12.4482 42.3986L14.1262 41.4062L16.8143 39.8188C17.0119 39.7019 17.2617 39.8442 17.2625 40.0739L17.2633 42.7627V45.1456C17.2633 45.251 17.2079 45.3486 17.1165 45.4015L12.7496 47.9587C12.552 48.0748 12.3031 47.9325 12.3022 47.7037Z"
52
+ }), /*#__PURE__*/jsx("path", {
53
+ d: "M0.221343 34.2106L6.76939 30.4056C6.90636 30.326 7.07449 30.3256 7.21227 30.4023L13.8378 34.1401C14.138 34.3095 14.14 34.7413 13.8415 34.9131L7.25492 38.7182C7.11795 38.7977 6.94941 38.7985 6.81204 38.7206L0.225854 34.9836C-0.0734986 34.8139 -0.075549 34.3833 0.221343 34.2106Z"
54
+ }), /*#__PURE__*/jsx("path", {
55
+ d: "M6.03876 9.125L16.9237 15.5151C17.1513 15.6484 17.2903 15.8912 17.2903 16.1549V28.8331C17.2903 29.4076 16.665 29.7647 16.1704 29.4728L5.28546 23.0264C5.05869 22.8919 4.92008 22.6479 4.9209 22.3855V9.76307C4.92254 9.1902 5.54503 8.83467 6.03876 9.125Z"
56
+ }), /*#__PURE__*/jsx("path", {
57
+ d: "M39.6262 1.07261V11.7603V19.3368C39.627 19.7178 39.4265 20.0709 39.0988 20.2644L31.4145 24.8195L23.3545 29.5964C22.6385 30.0192 21.7339 29.5029 21.7339 28.6717V10.3259C21.7339 9.94495 21.9356 9.5927 22.2641 9.39955L38.008 0.149533C38.7232 -0.270381 39.6241 0.24385 39.6262 1.07261Z"
58
+ })]
59
+ });
60
+ }); // StarProgress.displayName = 'eds-star-progress'
61
+
62
+ export { StarProgress };
@@ -0,0 +1,16 @@
1
+ import { tokens } from '@equinor/eds-tokens';
2
+
3
+ const {
4
+ colors: {
5
+ logo: {
6
+ fill_positive: {
7
+ rgba: logoFillPositive
8
+ }
9
+ }
10
+ }
11
+ } = tokens;
12
+ const token = {
13
+ background: logoFillPositive
14
+ };
15
+
16
+ export { token };
@@ -0,0 +1,17 @@
1
+ import { LinearProgress } from './Linear/LinearProgress.js';
2
+ export { LinearProgress } from './Linear/LinearProgress.js';
3
+ import { CircularProgress } from './Circular/CircularProgress.js';
4
+ export { CircularProgress } from './Circular/CircularProgress.js';
5
+ import { StarProgress } from './Star/StarProgress.js';
6
+ export { StarProgress } from './Star/StarProgress.js';
7
+ import { DotProgress } from './Dots/DotProgress.js';
8
+ export { DotProgress } from './Dots/DotProgress.js';
9
+
10
+ const Progress = {
11
+ Linear: LinearProgress,
12
+ Circular: CircularProgress,
13
+ Star: StarProgress,
14
+ Dots: DotProgress
15
+ };
16
+
17
+ export { Progress };
@@ -0,0 +1,128 @@
1
+ import { forwardRef, useMemo } from 'react';
2
+ import styled, { ThemeProvider } from 'styled-components';
3
+ import { radio_button_selected, radio_button_unselected } from '@equinor/eds-icons';
4
+ import { comfortable } from './Radio.tokens.js';
5
+ import { jsxs, jsx } from 'react/jsx-runtime';
6
+ import { outlineTemplate } from '../../utils/templates/focus.js';
7
+ import { typographyTemplate, spacingsTemplate } from '../../utils/templates/index.js';
8
+ import { useEds } from '../EdsProvider/eds.context.js';
9
+ import { useToken } from '../../hooks/useToken.js';
10
+
11
+ /* eslint camelcase: "off" */
12
+ const Input = styled.input.attrs(({
13
+ type = 'radio'
14
+ }) => ({
15
+ type
16
+ })).withConfig({
17
+ displayName: "Radio__Input",
18
+ componentId: "sc-we59oz-0"
19
+ })(["--scale:", ";appearance:none;width:100%;height:100%;margin:0;grid-area:input;transform:scale(var(--scale));cursor:", ";&:focus{outline:none;}&[data-focus-visible-added]:focus + svg{", "}&:not(:checked) ~ svg path[name='selected']{display:none;}&:not(:checked) ~ svg path[name='unselected']{display:inline;}&:checked ~ svg path[name='unselected']{display:none;}&:checked ~ svg path[name='selected']{display:inline;}"], ({
20
+ theme,
21
+ iconSize
22
+ }) => parseFloat(theme.clickbound.height) / iconSize, ({
23
+ disabled
24
+ }) => disabled ? 'not-allowed' : 'pointer', ({
25
+ theme
26
+ }) => outlineTemplate(theme.states.focus.outline));
27
+ const StyledLabel = styled.label.withConfig({
28
+ displayName: "Radio__StyledLabel",
29
+ componentId: "sc-we59oz-1"
30
+ })(["display:inline-flex;align-items:center;cursor:", ";"], ({
31
+ disabled
32
+ }) => disabled ? 'not-allowed' : 'pointer');
33
+ const StyledPath = styled.path.attrs(({
34
+ icon
35
+ }) => ({
36
+ fillRule: 'evenodd',
37
+ clipRule: 'evenodd',
38
+ d: icon.svgPathData
39
+ })).withConfig({
40
+ displayName: "Radio__StyledPath",
41
+ componentId: "sc-we59oz-2"
42
+ })([""]);
43
+ const Svg = styled.svg.attrs(({
44
+ height,
45
+ width,
46
+ fill
47
+ }) => ({
48
+ name: null,
49
+ xmlns: 'http://www.w3.org/2000/svg',
50
+ height,
51
+ width,
52
+ fill
53
+ })).withConfig({
54
+ displayName: "Radio__Svg",
55
+ componentId: "sc-we59oz-3"
56
+ })(["grid-area:input;pointer-events:none;"]);
57
+ const LabelText = styled.span.withConfig({
58
+ displayName: "Radio__LabelText",
59
+ componentId: "sc-we59oz-4"
60
+ })(["", ""], typographyTemplate(comfortable.typography));
61
+ const InputWrapper = styled.span.withConfig({
62
+ displayName: "Radio__InputWrapper",
63
+ componentId: "sc-we59oz-5"
64
+ })(["", " display:inline-grid;grid:[input] 1fr / [input] 1fr;border-radius:50%;cursor:", ";@media (hover:hover) and (pointer:fine){&:hover{background-color:", ";}}"], ({
65
+ theme
66
+ }) => spacingsTemplate(theme.spacings), ({
67
+ disabled
68
+ }) => disabled ? 'not-allowed' : 'pointer', ({
69
+ disabled
70
+ }) => disabled ? 'transparent' : comfortable.states.hover.background);
71
+ const Radio = /*#__PURE__*/forwardRef(function Radio({
72
+ label,
73
+ disabled = false,
74
+ className,
75
+ ...rest
76
+ }, ref) {
77
+ const {
78
+ density
79
+ } = useEds();
80
+ const token = useToken({
81
+ density
82
+ }, comfortable);
83
+ const iconSize = 24;
84
+ const fill = disabled ? comfortable.states.disabled.background : comfortable.background;
85
+ const renderSVG = useMemo(() => {
86
+ return /*#__PURE__*/jsxs(Svg, {
87
+ width: iconSize,
88
+ height: iconSize,
89
+ viewBox: `0 0 ${iconSize} ${iconSize}`,
90
+ fill: fill,
91
+ "aria-hidden": true,
92
+ children: [/*#__PURE__*/jsx(StyledPath, {
93
+ icon: radio_button_selected,
94
+ name: "selected"
95
+ }), /*#__PURE__*/jsx(StyledPath, {
96
+ icon: radio_button_unselected,
97
+ name: "unselected"
98
+ })]
99
+ });
100
+ }, [fill]);
101
+ return /*#__PURE__*/jsx(ThemeProvider, {
102
+ theme: token,
103
+ children: label ? /*#__PURE__*/jsxs(StyledLabel, {
104
+ disabled: disabled,
105
+ className: className,
106
+ children: [/*#__PURE__*/jsxs(InputWrapper, {
107
+ disabled: disabled,
108
+ children: [/*#__PURE__*/jsx(Input, { ...rest,
109
+ ref: ref,
110
+ disabled: disabled,
111
+ iconSize: iconSize
112
+ }), renderSVG]
113
+ }), /*#__PURE__*/jsx(LabelText, {
114
+ children: label
115
+ })]
116
+ }) : /*#__PURE__*/jsxs(InputWrapper, {
117
+ disabled: disabled,
118
+ children: [/*#__PURE__*/jsx(Input, { ...rest,
119
+ ref: ref,
120
+ disabled: disabled,
121
+ iconSize: iconSize
122
+ }), renderSVG]
123
+ })
124
+ });
125
+ });
126
+ Radio.displayName = 'Radio';
127
+
128
+ export { Radio };
@@ -0,0 +1,91 @@
1
+ import { tokens } from '@equinor/eds-tokens';
2
+
3
+ const {
4
+ colors: {
5
+ interactive: {
6
+ primary__resting: {
7
+ rgba: primaryColor
8
+ },
9
+ primary__hover_alt: {
10
+ rgba: primaryHoverAlt
11
+ },
12
+ focus: {
13
+ rgba: focusOutlineColor
14
+ },
15
+ disabled__text: {
16
+ rgba: disabledText
17
+ }
18
+ }
19
+ },
20
+ typography: {
21
+ navigation: {
22
+ menu_title: labelTypography
23
+ }
24
+ },
25
+ spacings: {
26
+ comfortable: {
27
+ medium_small,
28
+ x_small
29
+ }
30
+ },
31
+ clickbounds: {
32
+ default__base: clicboundSize,
33
+ compact__standard: compactClickboundSize
34
+ }
35
+ } = tokens;
36
+ const comfortable = {
37
+ background: primaryColor,
38
+ typography: labelTypography,
39
+ spacings: {
40
+ bottom: medium_small,
41
+ top: medium_small,
42
+ left: medium_small,
43
+ right: medium_small
44
+ },
45
+ clickbound: {
46
+ height: clicboundSize
47
+ },
48
+ states: {
49
+ hover: {
50
+ background: primaryHoverAlt
51
+ },
52
+ disabled: {
53
+ background: disabledText
54
+ },
55
+ focus: {
56
+ outline: {
57
+ type: 'outline',
58
+ style: 'dashed',
59
+ width: '1px',
60
+ color: focusOutlineColor,
61
+ offset: '11px'
62
+ }
63
+ }
64
+ },
65
+ modes: {
66
+ compact: {
67
+ spacings: {
68
+ bottom: x_small,
69
+ top: x_small,
70
+ left: x_small,
71
+ right: x_small
72
+ },
73
+ clickbound: {
74
+ height: compactClickboundSize
75
+ },
76
+ states: {
77
+ focus: {
78
+ outline: {
79
+ type: 'outline',
80
+ style: 'dashed',
81
+ width: '1px',
82
+ color: focusOutlineColor,
83
+ offset: '3px'
84
+ }
85
+ }
86
+ }
87
+ }
88
+ }
89
+ };
90
+
91
+ export { comfortable };
@@ -0,0 +1,62 @@
1
+ import { forwardRef } from 'react';
2
+ import styled from 'styled-components';
3
+ import { scrim } from './Scrim.tokens.js';
4
+ import { jsx } from 'react/jsx-runtime';
5
+ import { useHideBodyScroll } from '../../hooks/useHideBodyScroll.js';
6
+ import { useGlobalKeyPress } from '../../hooks/useGlobalKeyPress.js';
7
+
8
+ const {
9
+ height,
10
+ width,
11
+ background
12
+ } = scrim;
13
+ const StyledScrim = styled.div.withConfig({
14
+ displayName: "Scrim__StyledScrim",
15
+ componentId: "sc-1fr7uvy-0"
16
+ })(["width:", ";height:", ";background:", ";position:fixed;z-index:500;top:0;left:0;align-items:center;justify-content:center;display:flex;"], width, height, background);
17
+ const ScrimContent = styled.div.withConfig({
18
+ displayName: "Scrim__ScrimContent",
19
+ componentId: "sc-1fr7uvy-1"
20
+ })(["width:auto;height:auto;"]);
21
+ const Scrim = /*#__PURE__*/forwardRef(function Scrim({
22
+ children,
23
+ onClose,
24
+ isDismissable = false,
25
+ ...rest
26
+ }, ref) {
27
+ const props = { ...rest,
28
+ isDismissable,
29
+ ref
30
+ };
31
+ const overflowState = document.body.style.overflow;
32
+ useHideBodyScroll(overflowState);
33
+ useGlobalKeyPress('Escape', e => {
34
+ if (isDismissable && onClose) {
35
+ onClose(e, false);
36
+ }
37
+ });
38
+
39
+ const handleMouseClose = event => {
40
+ if (event) {
41
+ if (event.type === 'click' && isDismissable) {
42
+ onClose && onClose(event, false);
43
+ }
44
+ }
45
+ };
46
+
47
+ const handleContentClick = event => {
48
+ // Avoid event bubbling inside dialog/content inside scrim
49
+ event.stopPropagation();
50
+ };
51
+
52
+ return /*#__PURE__*/jsx(StyledScrim, {
53
+ onClick: handleMouseClose,
54
+ ...props,
55
+ children: /*#__PURE__*/jsx(ScrimContent, {
56
+ onClick: handleContentClick,
57
+ children: children
58
+ })
59
+ });
60
+ });
61
+
62
+ export { Scrim };
@@ -0,0 +1,18 @@
1
+ import { tokens } from '@equinor/eds-tokens';
2
+
3
+ const {
4
+ colors: {
5
+ ui: {
6
+ background__scrim: {
7
+ rgba: background
8
+ }
9
+ }
10
+ }
11
+ } = tokens;
12
+ const scrim = {
13
+ width: '100%',
14
+ height: '100%',
15
+ background
16
+ };
17
+
18
+ export { scrim };
@@ -0,0 +1,180 @@
1
+ import { forwardRef, useRef, useState, useEffect } from 'react';
2
+ import styled, { css } from 'styled-components';
3
+ import { search as search$1, close } from '@equinor/eds-icons';
4
+ import { search } from './Search.tokens.js';
5
+ import { Icon } from '../Icon/index.js';
6
+ import { jsxs, jsx } from 'react/jsx-runtime';
7
+ import { useCombinedRefs } from '../../hooks/useCombinedRefs.js';
8
+ import { setReactInputValue } from '../../utils/setReactInputValue.js';
9
+ import { bordersTemplate } from '../../utils/templates/borders.js';
10
+ import { spacingsTemplate, typographyTemplate } from '../../utils/templates/index.js';
11
+
12
+ const {
13
+ height,
14
+ spacings,
15
+ background,
16
+ typography,
17
+ border,
18
+ clickbound,
19
+ entities: {
20
+ icon,
21
+ placeholder
22
+ },
23
+ states
24
+ } = search;
25
+ const Container = styled.span.withConfig({
26
+ displayName: "Search__Container",
27
+ componentId: "sc-v8l23u-0"
28
+ })(["position:relative;background:", ";width:100%;height:", ";display:grid;grid-gap:8px;grid-auto-flow:column;grid-auto-columns:max-content auto max-content;align-items:center;box-sizing:border-box;", " z-index:0;svg{fill:", ";}", " ", " &::placeholder{color:", ";}", " &::after{z-index:-1;position:absolute;top:-", ";left:0;width:100%;height:", ";content:'';}&::before{position:absolute;top:0;left:0;width:auto;min-height:auto;content:'';}"], background, height, bordersTemplate(border), icon.typography.color, spacingsTemplate(spacings), ({
29
+ isFocused
30
+ }) => isFocused && css(["", ""], bordersTemplate(states.focus.border)), placeholder.typography.color, ({
31
+ disabled
32
+ }) => disabled ? css(["cursor:not-allowed;"]) : css(["@media (hover:hover) and (pointer:fine){&:hover{", " cursor:text;}}"], bordersTemplate(states.focus.border)), clickbound.offset, clickbound.height);
33
+ const Input = styled.input.withConfig({
34
+ displayName: "Search__Input",
35
+ componentId: "sc-v8l23u-1"
36
+ })(["min-height:0;min-width:0;width:100%;height:100%;margin:0;padding:0;border:none;appearance:none;box-sizing:border-box;background:transparent;&[type='search']::-webkit-search-decoration,&[type='search']::-webkit-search-cancel-button,&[type='search']::-webkit-search-results-button,&[type='search']::-webkit-search-results-decoration{-webkit-appearance:none;}", " &:focus{outline:none;}", ""], typographyTemplate(typography), ({
37
+ disabled
38
+ }) => disabled && css(["cursor:not-allowed;"]));
39
+ const InsideButton = styled.div.withConfig({
40
+ displayName: "Search__InsideButton",
41
+ componentId: "sc-v8l23u-2"
42
+ })(["", " display:flex;align-items:center;visibility:hidden;z-index:1;padding:4px;height:16px;width:16px;position:relative;&::after{z-index:-1;position:absolute;top:-", ";left:0;width:100%;height:", ";content:'';}&::before{position:absolute;top:0;left:0;width:auto;min-height:auto;content:'';}", ""], bordersTemplate(icon.border), icon.clickbound.offset.top, icon.clickbound.height, ({
43
+ isActive
44
+ }) => isActive && css(["visibility:visible;@media (hover:hover) and (pointer:fine){&:hover{cursor:pointer;background:", ";}}"], icon.states.hover.background));
45
+ const Search = /*#__PURE__*/forwardRef(function Search({
46
+ onChange,
47
+ defaultValue = '',
48
+ value,
49
+ className = '',
50
+ disabled = false,
51
+ onBlur,
52
+ onFocus,
53
+ ...rest
54
+ }, ref) {
55
+ const isControlled = typeof value !== 'undefined';
56
+ const isActive = isControlled && value !== '' || defaultValue !== '';
57
+ const inputRef = useRef(null);
58
+ const [state, setState] = useState({
59
+ isActive,
60
+ isFocused: false
61
+ });
62
+ useEffect(() => {
63
+ setState(prevState => ({ ...prevState,
64
+ isActive
65
+ }));
66
+ }, [value, defaultValue, isActive]);
67
+
68
+ const handleOnClick = () => {
69
+ const inputEl = inputRef.current;
70
+ inputEl.focus();
71
+ };
72
+
73
+ const handleFocus = () => setState(prevState => ({ ...prevState,
74
+ isFocused: true
75
+ }));
76
+
77
+ const handleBlur = () => setState(prevState => ({ ...prevState,
78
+ isFocused: false
79
+ }));
80
+
81
+ const handleOnChange = event => {
82
+ setIsActive(event.target.value);
83
+ };
84
+
85
+ const handleOnDelete = () => {
86
+ const input = inputRef.current;
87
+ const clearedValue = '';
88
+ setReactInputValue(input, clearedValue);
89
+ setState(prevState => ({ ...prevState,
90
+ isActive: false
91
+ }));
92
+ };
93
+
94
+ const setIsActive = newValue => setState(prevState => ({ ...prevState,
95
+ isActive: newValue !== ''
96
+ }));
97
+ /** Applying props for controlled vs. uncontrolled scnarios */
98
+
99
+
100
+ const applyControllingProps = (props, value, defaultValue) => {
101
+ if (isControlled) {
102
+ return { ...props,
103
+ value
104
+ };
105
+ }
106
+
107
+ return { ...props,
108
+ defaultValue
109
+ };
110
+ };
111
+
112
+ const {
113
+ isFocused
114
+ } = state;
115
+ const size = 24;
116
+ const containerProps = {
117
+ isFocused,
118
+ className,
119
+ disabled,
120
+ role: 'search',
121
+ 'aria-label': rest['aria-label'],
122
+ onClick: handleOnClick
123
+ };
124
+ const inputProps = applyControllingProps({ ...rest,
125
+ disabled,
126
+ ref: useCombinedRefs(inputRef, ref),
127
+ type: 'search',
128
+ role: 'searchbox',
129
+ 'aria-label': 'search input',
130
+ onBlur: e => {
131
+ handleBlur();
132
+
133
+ if (onBlur) {
134
+ onBlur(e);
135
+ }
136
+ },
137
+ onFocus: e => {
138
+ handleFocus();
139
+
140
+ if (onFocus) {
141
+ onFocus(e);
142
+ }
143
+ },
144
+ onChange: e => {
145
+ handleOnChange(e);
146
+
147
+ if (onChange) {
148
+ onChange(e);
149
+ }
150
+ }
151
+ }, value, defaultValue);
152
+ const clearButtonProps = {
153
+ isActive: state.isActive,
154
+ size,
155
+ role: 'button',
156
+ onClick: e => {
157
+ e.stopPropagation();
158
+
159
+ if (state.isActive) {
160
+ handleOnDelete();
161
+ }
162
+ }
163
+ };
164
+ return /*#__PURE__*/jsxs(Container, { ...containerProps,
165
+ children: [/*#__PURE__*/jsx(Icon, {
166
+ data: search$1,
167
+ "aria-hidden": true,
168
+ size: size
169
+ }), /*#__PURE__*/jsx(Input, { ...inputProps
170
+ }), /*#__PURE__*/jsx(InsideButton, { ...clearButtonProps,
171
+ "aria-label": "Clear search",
172
+ children: /*#__PURE__*/jsx(Icon, {
173
+ data: close,
174
+ size: size
175
+ })
176
+ })]
177
+ });
178
+ }); // Search.displayName = 'eds-search'
179
+
180
+ export { Search };
@@ -0,0 +1,96 @@
1
+ import { tokens } from '@equinor/eds-tokens';
2
+
3
+ const {
4
+ colors: {
5
+ ui: {
6
+ background__light: {
7
+ rgba: background
8
+ }
9
+ },
10
+ interactive: {
11
+ primary__hover_alt: {
12
+ rgba: primaryHoverAlt
13
+ },
14
+ primary__resting: {
15
+ rgba: primaryColor
16
+ }
17
+ },
18
+ text: {
19
+ static_icons__tertiary: {
20
+ rgba: placeholderColor
21
+ }
22
+ }
23
+ },
24
+ spacings: {
25
+ comfortable: {
26
+ small
27
+ }
28
+ },
29
+ typography: {
30
+ input: {
31
+ text: typography
32
+ }
33
+ }
34
+ } = tokens;
35
+ const search = {
36
+ background,
37
+ typography,
38
+ height: '36px',
39
+ clickbound: {
40
+ offset: {
41
+ top: '6px'
42
+ },
43
+ height: '48px'
44
+ },
45
+ spacings: {
46
+ left: small,
47
+ right: small,
48
+ top: '6px',
49
+ bottom: '6px'
50
+ },
51
+ border: {
52
+ type: 'border',
53
+ width: '1px',
54
+ style: 'solid',
55
+ color: 'transparent'
56
+ },
57
+ states: {
58
+ focus: {
59
+ border: {
60
+ type: 'border',
61
+ width: '1px',
62
+ style: 'solid',
63
+ color: primaryColor
64
+ }
65
+ }
66
+ },
67
+ entities: {
68
+ placeholder: {
69
+ typography: {
70
+ color: placeholderColor
71
+ }
72
+ },
73
+ icon: {
74
+ typography: {
75
+ color: placeholderColor
76
+ },
77
+ border: {
78
+ type: 'border',
79
+ radius: '50%'
80
+ },
81
+ states: {
82
+ hover: {
83
+ background: primaryHoverAlt
84
+ }
85
+ },
86
+ clickbound: {
87
+ offset: {
88
+ top: '6px'
89
+ },
90
+ height: '36px'
91
+ }
92
+ }
93
+ }
94
+ };
95
+
96
+ export { search };