@equinor/eds-core-react 0.15.0 → 0.17.0-dev.20220209

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 (408) hide show
  1. package/README.md +1 -1
  2. package/dist/eds-core-react.cjs.js +9617 -0
  3. package/dist/esm/components/Accordion/Accordion.js +41 -0
  4. package/dist/esm/components/Accordion/Accordion.tokens.js +115 -0
  5. package/dist/esm/components/Accordion/AccordionHeader.js +151 -0
  6. package/dist/esm/components/Accordion/AccordionHeaderTitle.js +32 -0
  7. package/dist/esm/components/Accordion/AccordionItem.js +48 -0
  8. package/dist/esm/components/Accordion/AccordionPanel.js +48 -0
  9. package/dist/esm/components/Accordion/index.js +17 -0
  10. package/dist/esm/components/Avatar/Avatar.js +47 -0
  11. package/dist/esm/components/Avatar/Avatar.tokens.js +13 -0
  12. package/dist/esm/components/Banner/Banner.js +63 -0
  13. package/dist/esm/components/Banner/Banner.tokens.js +95 -0
  14. package/dist/esm/components/Banner/BannerActions.js +35 -0
  15. package/dist/esm/components/Banner/BannerIcon.js +45 -0
  16. package/dist/esm/components/Banner/BannerMessage.js +26 -0
  17. package/dist/esm/components/Banner/index.js +14 -0
  18. package/dist/esm/components/Breadcrumbs/Breadcrumb.js +53 -0
  19. package/dist/esm/components/Breadcrumbs/Breadcrumbs.js +99 -0
  20. package/dist/esm/components/Breadcrumbs/Breadcrumbs.tokens.js +39 -0
  21. package/dist/esm/components/Breadcrumbs/index.js +8 -0
  22. package/dist/esm/components/Button/Button.js +105 -0
  23. package/dist/esm/components/Button/InnerFullWidth.js +27 -0
  24. package/dist/esm/components/Button/tokens/button.js +134 -0
  25. package/dist/esm/components/Button/tokens/contained.js +86 -0
  26. package/dist/esm/components/Button/tokens/ghost.js +84 -0
  27. package/dist/esm/components/Button/tokens/icon.js +123 -0
  28. package/dist/esm/components/Button/tokens/index.js +27 -0
  29. package/dist/esm/components/Button/tokens/outlined.js +111 -0
  30. package/dist/esm/components/Card/Card.js +46 -0
  31. package/dist/esm/components/Card/Card.tokens.js +54 -0
  32. package/dist/esm/components/Card/CardActions.js +40 -0
  33. package/dist/esm/components/Card/CardContent.js +25 -0
  34. package/dist/esm/components/Card/CardHeader.js +26 -0
  35. package/dist/esm/components/Card/CardHeaderTitle.js +22 -0
  36. package/dist/esm/components/Card/CardMedia.js +34 -0
  37. package/dist/esm/components/Card/index.js +20 -0
  38. package/dist/esm/components/Checkbox/Checkbox.js +48 -0
  39. package/dist/esm/components/Checkbox/Checkbox.tokens.js +91 -0
  40. package/dist/esm/components/Checkbox/Input.js +143 -0
  41. package/dist/esm/components/Chip/Chip.js +142 -0
  42. package/dist/esm/components/Chip/Chip.tokens.js +148 -0
  43. package/dist/esm/components/Chip/Icon.js +36 -0
  44. package/dist/esm/components/Dialog/Dialog.js +70 -0
  45. package/dist/esm/components/Dialog/Dialog.tokens.js +68 -0
  46. package/dist/esm/components/Dialog/DialogActions.js +27 -0
  47. package/dist/esm/components/Dialog/DialogContent.js +44 -0
  48. package/dist/esm/components/Dialog/DialogHeader.js +37 -0
  49. package/dist/esm/components/Dialog/DialogTitle.js +31 -0
  50. package/dist/esm/components/Dialog/index.js +18 -0
  51. package/dist/esm/components/Divider/Divider.js +33 -0
  52. package/dist/esm/components/Divider/Divider.tokens.js +59 -0
  53. package/dist/esm/components/EdsProvider/eds.context.js +36 -0
  54. package/dist/esm/components/Icon/Icon.js +133 -0
  55. package/dist/esm/components/Icon/index.js +7 -0
  56. package/dist/esm/components/Icon/library.js +19 -0
  57. package/dist/esm/components/Input/Input.js +58 -0
  58. package/dist/esm/components/Input/Input.tokens.js +172 -0
  59. package/dist/esm/components/Label/Label.js +44 -0
  60. package/dist/esm/components/Label/Label.tokens.js +30 -0
  61. package/dist/esm/components/List/List.js +34 -0
  62. package/dist/esm/components/List/List.tokens.js +12 -0
  63. package/dist/esm/components/List/ListItem.js +15 -0
  64. package/dist/esm/components/List/index.js +8 -0
  65. package/dist/esm/components/Menu/Menu.context.js +49 -0
  66. package/dist/esm/components/Menu/Menu.js +125 -0
  67. package/dist/esm/components/Menu/Menu.tokens.js +132 -0
  68. package/dist/esm/components/Menu/MenuItem.js +103 -0
  69. package/dist/esm/components/Menu/MenuList.js +97 -0
  70. package/dist/esm/components/Menu/MenuSection.js +36 -0
  71. package/dist/esm/components/Menu/index.js +11 -0
  72. package/dist/esm/components/Pagination/Pagination.js +158 -0
  73. package/dist/esm/components/Pagination/Pagination.tokens.js +40 -0
  74. package/dist/esm/components/Pagination/PaginationItem.js +31 -0
  75. package/dist/esm/components/Pagination/paginationControl.js +46 -0
  76. package/dist/esm/components/Paper/Paper.js +28 -0
  77. package/dist/esm/components/Paper/Paper.tokens.js +19 -0
  78. package/dist/esm/components/Popover/Popover.js +115 -0
  79. package/dist/esm/components/Popover/Popover.tokens.js +66 -0
  80. package/dist/esm/components/Popover/PopoverActions.js +28 -0
  81. package/dist/esm/components/Popover/PopoverContent.js +27 -0
  82. package/dist/esm/components/Popover/PopoverHeader.js +36 -0
  83. package/dist/esm/components/Popover/PopoverTitle.js +27 -0
  84. package/dist/esm/components/Popover/index.js +17 -0
  85. package/dist/esm/components/Progress/Circular/CircularProgress.js +98 -0
  86. package/dist/esm/components/Progress/Circular/CircularProgress.tokens.js +42 -0
  87. package/dist/esm/components/Progress/Dots/DotProgress.js +59 -0
  88. package/dist/esm/components/Progress/Dots/DotProgress.tokens.js +30 -0
  89. package/dist/esm/components/Progress/Linear/LinearProgress.js +51 -0
  90. package/dist/esm/components/Progress/Linear/LinearProgress.tokens.js +24 -0
  91. package/dist/esm/components/Progress/Star/StarProgress.js +66 -0
  92. package/dist/esm/components/Progress/Star/StarProgress.tokens.js +16 -0
  93. package/dist/esm/components/Progress/index.js +17 -0
  94. package/dist/esm/components/Radio/Radio.js +162 -0
  95. package/dist/esm/components/Radio/Radio.tokens.js +91 -0
  96. package/dist/esm/components/Scrim/Scrim.js +67 -0
  97. package/dist/esm/components/Scrim/Scrim.tokens.js +18 -0
  98. package/dist/esm/components/Search/Search.js +205 -0
  99. package/dist/esm/components/Search/Search.tokens.js +107 -0
  100. package/dist/esm/components/Select/MultiSelect/MultiSelect.js +213 -0
  101. package/dist/esm/components/Select/NativeSelect/NativeSelect.js +68 -0
  102. package/dist/esm/components/Select/NativeSelect/NativeSelect.tokens.js +66 -0
  103. package/dist/esm/components/Select/Select.tokens.js +101 -0
  104. package/dist/esm/components/Select/SingleSelect/SingleSelect.js +151 -0
  105. package/dist/esm/components/Select/commonStyles.js +55 -0
  106. package/dist/esm/components/SideSheet/SideSheet.js +63 -0
  107. package/dist/esm/components/SideSheet/SideSheet.tokens.js +45 -0
  108. package/dist/esm/components/Slider/MinMax.js +27 -0
  109. package/dist/esm/components/Slider/Output.js +36 -0
  110. package/dist/esm/components/Slider/Slider.js +271 -0
  111. package/dist/esm/components/Slider/Slider.tokens.js +136 -0
  112. package/dist/esm/components/Slider/SliderInput.js +60 -0
  113. package/dist/esm/components/Snackbar/Snackbar.js +74 -0
  114. package/dist/esm/components/Snackbar/Snackbar.tokens.js +77 -0
  115. package/dist/esm/components/Snackbar/SnackbarAction.js +27 -0
  116. package/dist/esm/components/Snackbar/index.js +7 -0
  117. package/dist/esm/components/Switch/Switch.js +73 -0
  118. package/dist/esm/components/Switch/Switch.styles.js +41 -0
  119. package/dist/esm/components/Switch/Switch.tokens.js +168 -0
  120. package/dist/esm/components/Switch/SwitchDefault.js +71 -0
  121. package/dist/esm/components/Switch/SwitchSmall.js +69 -0
  122. package/dist/esm/components/Table/Body.js +26 -0
  123. package/dist/esm/components/Table/Caption.js +22 -0
  124. package/dist/esm/components/Table/Cell.js +36 -0
  125. package/dist/esm/components/Table/DataCell/DataCell.js +50 -0
  126. package/dist/esm/components/Table/DataCell/DataCell.tokens.js +161 -0
  127. package/dist/esm/components/Table/Head/Head.js +30 -0
  128. package/dist/esm/components/Table/Head/Head.tokens.js +30 -0
  129. package/dist/esm/components/Table/HeaderCell/HeaderCell.js +66 -0
  130. package/dist/esm/components/Table/HeaderCell/HeaderCell.tokens.js +128 -0
  131. package/dist/esm/components/Table/Inner.context.js +8 -0
  132. package/dist/esm/components/Table/Row/Row.js +36 -0
  133. package/dist/esm/components/Table/Row/Row.tokens.js +26 -0
  134. package/dist/esm/components/Table/Table.js +21 -0
  135. package/dist/esm/components/Table/index.js +20 -0
  136. package/dist/esm/components/TableOfContents/LinkItem.js +26 -0
  137. package/dist/esm/components/TableOfContents/TableOfContents.js +63 -0
  138. package/dist/esm/components/TableOfContents/TableOfContents.tokens.js +106 -0
  139. package/dist/esm/components/TableOfContents/index.js +8 -0
  140. package/dist/esm/components/Tabs/Tab.js +41 -0
  141. package/dist/esm/components/Tabs/TabList.js +94 -0
  142. package/dist/esm/components/Tabs/TabPanel.js +33 -0
  143. package/dist/esm/components/Tabs/TabPanels.js +26 -0
  144. package/dist/esm/components/Tabs/Tabs.context.js +13 -0
  145. package/dist/esm/components/Tabs/Tabs.js +72 -0
  146. package/dist/esm/components/Tabs/Tabs.tokens.js +130 -0
  147. package/dist/esm/components/Tabs/index.js +17 -0
  148. package/dist/esm/components/TextField/Field.js +158 -0
  149. package/dist/esm/components/TextField/HelperText/HelperText.js +92 -0
  150. package/dist/esm/components/TextField/HelperText/HelperText.token.js +49 -0
  151. package/dist/esm/components/TextField/Icon/Icon.js +64 -0
  152. package/dist/esm/components/TextField/Icon/Icon.tokens.js +46 -0
  153. package/dist/esm/components/TextField/TextField.context.js +38 -0
  154. package/dist/esm/components/TextField/TextField.js +87 -0
  155. package/dist/esm/components/TextField/TextField.tokens.js +124 -0
  156. package/dist/esm/components/Textarea/Textarea.js +92 -0
  157. package/dist/esm/components/Tooltip/Tooltip.js +113 -0
  158. package/dist/esm/components/Tooltip/Tooltip.tokens.js +63 -0
  159. package/dist/esm/components/TopBar/Actions.js +21 -0
  160. package/dist/esm/components/TopBar/CustomContent.js +21 -0
  161. package/dist/esm/components/TopBar/Header.js +21 -0
  162. package/dist/esm/components/TopBar/TopBar.js +37 -0
  163. package/dist/esm/components/TopBar/TopBar.tokens.js +35 -0
  164. package/dist/esm/components/TopBar/index.js +14 -0
  165. package/dist/esm/components/Typography/Typography.js +114 -0
  166. package/dist/esm/components/Typography/Typography.tokens.js +61 -0
  167. package/dist/esm/index.js +41 -0
  168. package/dist/esm/node_modules/.pnpm/ramda@0.27.2/node_modules/ramda/src/internal/_curry1.js +25 -0
  169. package/dist/esm/node_modules/.pnpm/ramda@0.27.2/node_modules/ramda/src/internal/_curry2.js +38 -0
  170. package/dist/esm/node_modules/.pnpm/ramda@0.27.2/node_modules/ramda/src/internal/_curry3.js +57 -0
  171. package/dist/esm/node_modules/.pnpm/ramda@0.27.2/node_modules/ramda/src/internal/_has.js +7 -0
  172. package/dist/esm/node_modules/.pnpm/ramda@0.27.2/node_modules/ramda/src/internal/_isObject.js +7 -0
  173. package/dist/esm/node_modules/.pnpm/ramda@0.27.2/node_modules/ramda/src/internal/_isPlaceholder.js +7 -0
  174. package/dist/esm/node_modules/.pnpm/ramda@0.27.2/node_modules/ramda/src/mergeDeepRight.js +37 -0
  175. package/dist/esm/node_modules/.pnpm/ramda@0.27.2/node_modules/ramda/src/mergeDeepWithKey.js +49 -0
  176. package/dist/esm/node_modules/.pnpm/ramda@0.27.2/node_modules/ramda/src/mergeWithKey.js +53 -0
  177. package/dist/types/components/Accordion/Accordion.d.ts +4 -4
  178. package/dist/types/components/Accordion/Accordion.tokens.d.ts +10 -10
  179. package/dist/types/components/Accordion/Accordion.types.d.ts +6 -6
  180. package/dist/types/components/Accordion/AccordionHeader.d.ts +35 -35
  181. package/dist/types/components/Accordion/AccordionHeaderTitle.d.ts +14 -14
  182. package/dist/types/components/Accordion/AccordionItem.d.ts +19 -19
  183. package/dist/types/components/Accordion/AccordionPanel.d.ts +18 -18
  184. package/dist/types/components/Accordion/index.d.ts +15 -15
  185. package/dist/types/components/Avatar/Avatar.d.ts +23 -23
  186. package/dist/types/components/Avatar/Avatar.tokens.d.ts +10 -10
  187. package/dist/types/components/Avatar/index.d.ts +1 -1
  188. package/dist/types/components/Banner/Banner.d.ts +7 -7
  189. package/dist/types/components/Banner/Banner.tokens.d.ts +9 -9
  190. package/dist/types/components/Banner/BannerActions.d.ts +11 -11
  191. package/dist/types/components/Banner/BannerIcon.d.ts +15 -15
  192. package/dist/types/components/Banner/BannerMessage.d.ts +10 -10
  193. package/dist/types/components/Banner/index.d.ts +12 -12
  194. package/dist/types/components/Breadcrumbs/Breadcrumb.d.ts +11 -11
  195. package/dist/types/components/Breadcrumbs/Breadcrumbs.d.ts +11 -11
  196. package/dist/types/components/Breadcrumbs/Breadcrumbs.tokens.d.ts +2 -2
  197. package/dist/types/components/Breadcrumbs/index.d.ts +8 -8
  198. package/dist/types/components/Button/Button.d.ts +43 -43
  199. package/dist/types/components/Button/Button.types.d.ts +12 -12
  200. package/dist/types/components/Button/InnerFullWidth.d.ts +2 -2
  201. package/dist/types/components/Button/index.d.ts +1 -1
  202. package/dist/types/components/Button/tokens/button.d.ts +2 -2
  203. package/dist/types/components/Button/tokens/contained.d.ts +4 -4
  204. package/dist/types/components/Button/tokens/ghost.d.ts +4 -4
  205. package/dist/types/components/Button/tokens/icon.d.ts +4 -4
  206. package/dist/types/components/Button/tokens/index.d.ts +8 -8
  207. package/dist/types/components/Button/tokens/outlined.d.ts +4 -4
  208. package/dist/types/components/Card/Card.d.ts +9 -9
  209. package/dist/types/components/Card/Card.tokens.d.ts +6 -6
  210. package/dist/types/components/Card/CardActions.d.ts +13 -13
  211. package/dist/types/components/Card/CardContent.d.ts +3 -3
  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 +16 -16
  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/Dialog/Dialog.d.ts +19 -3
  225. package/dist/types/components/Dialog/Dialog.tokens.d.ts +4 -4
  226. package/dist/types/components/Dialog/DialogActions.d.ts +3 -0
  227. package/dist/types/components/Dialog/{CustomContent.d.ts → DialogContent.d.ts} +9 -9
  228. package/dist/types/components/Dialog/DialogHeader.d.ts +3 -0
  229. package/dist/types/components/Dialog/DialogTitle.d.ts +3 -0
  230. package/dist/types/components/Dialog/index.d.ts +15 -12
  231. package/dist/types/components/Divider/Divider.d.ts +17 -17
  232. package/dist/types/components/Divider/Divider.tokens.d.ts +12 -12
  233. package/dist/types/components/Divider/index.d.ts +1 -1
  234. package/dist/types/components/EdsProvider/eds.context.d.ts +15 -15
  235. package/dist/types/components/EdsProvider/index.d.ts +1 -1
  236. package/dist/types/components/Group/Group.d.ts +3 -0
  237. package/dist/types/components/Group/Group.tokens.d.ts +4 -0
  238. package/dist/types/components/Group/index.d.ts +1 -0
  239. package/dist/types/components/Icon/Icon.d.ts +20 -20
  240. package/dist/types/components/Icon/Icon.types.d.ts +11 -11
  241. package/dist/types/components/Icon/index.d.ts +5 -5
  242. package/dist/types/components/Icon/library.d.ts +8 -8
  243. package/dist/types/components/Input/Input.d.ts +26 -26
  244. package/dist/types/components/Input/Input.tokens.d.ts +12 -12
  245. package/dist/types/components/Input/index.d.ts +1 -1
  246. package/dist/types/components/Label/Label.d.ts +11 -11
  247. package/dist/types/components/Label/Label.tokens.d.ts +4 -4
  248. package/dist/types/components/Label/index.d.ts +1 -1
  249. package/dist/types/components/List/List.d.ts +14 -14
  250. package/dist/types/components/List/List.tokens.d.ts +4 -4
  251. package/dist/types/components/List/ListItem.d.ts +4 -4
  252. package/dist/types/components/List/index.d.ts +8 -8
  253. package/dist/types/components/Menu/Menu.context.d.ts +15 -15
  254. package/dist/types/components/Menu/Menu.d.ts +27 -27
  255. package/dist/types/components/Menu/Menu.tokens.d.ts +4 -4
  256. package/dist/types/components/Menu/Menu.types.d.ts +1 -1
  257. package/dist/types/components/Menu/MenuItem.d.ts +21 -21
  258. package/dist/types/components/Menu/MenuList.d.ts +8 -8
  259. package/dist/types/components/Menu/MenuSection.d.ts +10 -11
  260. package/dist/types/components/Menu/index.d.ts +10 -10
  261. package/dist/types/components/Pagination/Pagination.d.ts +25 -25
  262. package/dist/types/components/Pagination/Pagination.tokens.d.ts +2 -2
  263. package/dist/types/components/Pagination/PaginationItem.d.ts +8 -8
  264. package/dist/types/components/Pagination/index.d.ts +1 -1
  265. package/dist/types/components/Pagination/paginationControl.d.ts +1 -1
  266. package/dist/types/components/Paper/Paper.d.ts +8 -8
  267. package/dist/types/components/Paper/Paper.tokens.d.ts +12 -12
  268. package/dist/types/components/Paper/index.d.ts +1 -1
  269. package/dist/types/components/Popover/Popover.d.ts +22 -22
  270. package/dist/types/components/Popover/Popover.tokens.d.ts +4 -4
  271. package/dist/types/components/Popover/PopoverActions.d.ts +3 -0
  272. package/dist/types/components/Popover/PopoverContent.d.ts +3 -3
  273. package/dist/types/components/Popover/PopoverHeader.d.ts +3 -0
  274. package/dist/types/components/Popover/PopoverTitle.d.ts +3 -3
  275. package/dist/types/components/Popover/index.d.ts +14 -10
  276. package/dist/types/components/Progress/Circular/CircularProgress.d.ts +16 -16
  277. package/dist/types/components/Progress/Circular/CircularProgress.tokens.d.ts +8 -8
  278. package/dist/types/components/Progress/Dots/DotProgress.d.ts +11 -11
  279. package/dist/types/components/Progress/Dots/DotProgress.tokens.d.ts +5 -5
  280. package/dist/types/components/Progress/Linear/LinearProgress.d.ts +18 -18
  281. package/dist/types/components/Progress/Linear/LinearProgress.tokens.d.ts +7 -7
  282. package/dist/types/components/Progress/Star/StarProgress.d.ts +14 -14
  283. package/dist/types/components/Progress/Star/StarProgress.tokens.d.ts +2 -2
  284. package/dist/types/components/Progress/index.d.ts +15 -15
  285. package/dist/types/components/Radio/Radio.d.ts +10 -10
  286. package/dist/types/components/Radio/Radio.tokens.d.ts +4 -4
  287. package/dist/types/components/Radio/index.d.ts +1 -1
  288. package/dist/types/components/Scrim/Scrim.d.ts +19 -15
  289. package/dist/types/components/Scrim/Scrim.tokens.d.ts +2 -2
  290. package/dist/types/components/Scrim/index.d.ts +1 -1
  291. package/dist/types/components/Search/Search.d.ts +3 -3
  292. package/dist/types/components/Search/Search.tokens.d.ts +4 -4
  293. package/dist/types/components/Search/index.d.ts +1 -1
  294. package/dist/types/components/Select/MultiSelect/MultiSelect.d.ts +48 -48
  295. package/dist/types/components/Select/MultiSelect/index.d.ts +1 -1
  296. package/dist/types/components/Select/NativeSelect/NativeSelect.d.ts +29 -29
  297. package/dist/types/components/Select/NativeSelect/NativeSelect.tokens.d.ts +4 -4
  298. package/dist/types/components/Select/NativeSelect/index.d.ts +1 -1
  299. package/dist/types/components/Select/Select.tokens.d.ts +3 -3
  300. package/dist/types/components/Select/SingleSelect/SingleSelect.d.ts +48 -48
  301. package/dist/types/components/Select/SingleSelect/index.d.ts +1 -1
  302. package/dist/types/components/Select/commonStyles.d.ts +32 -32
  303. package/dist/types/components/Select/index.d.ts +3 -3
  304. package/dist/types/components/SideSheet/SideSheet.d.ts +21 -21
  305. package/dist/types/components/SideSheet/SideSheet.tokens.d.ts +10 -10
  306. package/dist/types/components/SideSheet/index.d.ts +1 -1
  307. package/dist/types/components/Slider/MinMax.d.ts +5 -5
  308. package/dist/types/components/Slider/Output.d.ts +9 -9
  309. package/dist/types/components/Slider/Slider.d.ts +49 -49
  310. package/dist/types/components/Slider/Slider.tokens.d.ts +4 -4
  311. package/dist/types/components/Slider/SliderInput.d.ts +21 -21
  312. package/dist/types/components/Slider/index.d.ts +1 -1
  313. package/dist/types/components/Snackbar/Snackbar.d.ts +21 -21
  314. package/dist/types/components/Snackbar/Snackbar.tokens.d.ts +4 -4
  315. package/dist/types/components/Snackbar/SnackbarAction.d.ts +5 -5
  316. package/dist/types/components/Snackbar/index.d.ts +8 -8
  317. package/dist/types/components/Switch/Switch.d.ts +12 -12
  318. package/dist/types/components/Switch/Switch.styles.d.ts +6 -5
  319. package/dist/types/components/Switch/Switch.tokens.d.ts +3 -3
  320. package/dist/types/components/Switch/SwitchDefault.d.ts +6 -6
  321. package/dist/types/components/Switch/SwitchSmall.d.ts +6 -6
  322. package/dist/types/components/Switch/index.d.ts +1 -1
  323. package/dist/types/components/Table/Body.d.ts +3 -3
  324. package/dist/types/components/Table/Caption.d.ts +4 -4
  325. package/dist/types/components/Table/Cell.d.ts +11 -11
  326. package/dist/types/components/Table/DataCell/DataCell.d.ts +8 -8
  327. package/dist/types/components/Table/DataCell/DataCell.tokens.d.ts +15 -15
  328. package/dist/types/components/Table/DataCell/index.d.ts +1 -1
  329. package/dist/types/components/Table/Head/Head.d.ts +9 -9
  330. package/dist/types/components/Table/Head/Head.tokens.d.ts +2 -2
  331. package/dist/types/components/Table/Head/index.d.ts +1 -1
  332. package/dist/types/components/Table/HeaderCell/HeaderCell.d.ts +5 -5
  333. package/dist/types/components/Table/HeaderCell/HeaderCell.tokens.d.ts +3 -3
  334. package/dist/types/components/Table/HeaderCell/index.d.ts +1 -1
  335. package/dist/types/components/Table/Inner.context.d.ts +7 -7
  336. package/dist/types/components/Table/Row/Row.d.ts +9 -9
  337. package/dist/types/components/Table/Row/Row.tokens.d.ts +2 -2
  338. package/dist/types/components/Table/Row/index.d.ts +1 -1
  339. package/dist/types/components/Table/Table.d.ts +3 -3
  340. package/dist/types/components/Table/Table.types.d.ts +2 -2
  341. package/dist/types/components/Table/index.d.ts +16 -16
  342. package/dist/types/components/TableOfContents/LinkItem.d.ts +3 -3
  343. package/dist/types/components/TableOfContents/TableOfContents.d.ts +14 -14
  344. package/dist/types/components/TableOfContents/TableOfContents.tokens.d.ts +4 -4
  345. package/dist/types/components/TableOfContents/index.d.ts +8 -8
  346. package/dist/types/components/Tabs/Tab.d.ts +13 -13
  347. package/dist/types/components/Tabs/TabList.d.ts +11 -11
  348. package/dist/types/components/Tabs/TabPanel.d.ts +10 -10
  349. package/dist/types/components/Tabs/TabPanels.d.ts +4 -4
  350. package/dist/types/components/Tabs/Tabs.context.d.ts +13 -13
  351. package/dist/types/components/Tabs/Tabs.d.ts +19 -19
  352. package/dist/types/components/Tabs/Tabs.tokens.d.ts +2 -2
  353. package/dist/types/components/Tabs/Tabs.types.d.ts +1 -1
  354. package/dist/types/components/Tabs/index.d.ts +14 -14
  355. package/dist/types/components/TextField/Field.d.ts +34 -34
  356. package/dist/types/components/TextField/HelperText/HelperText.d.ts +14 -14
  357. package/dist/types/components/TextField/HelperText/HelperText.token.d.ts +15 -15
  358. package/dist/types/components/TextField/HelperText/index.d.ts +1 -1
  359. package/dist/types/components/TextField/Icon/Icon.d.ts +13 -13
  360. package/dist/types/components/TextField/Icon/Icon.tokens.d.ts +14 -14
  361. package/dist/types/components/TextField/Icon/index.d.ts +1 -1
  362. package/dist/types/components/TextField/TextField.context.d.ts +17 -17
  363. package/dist/types/components/TextField/TextField.d.ts +37 -37
  364. package/dist/types/components/TextField/TextField.tokens.d.ts +10 -10
  365. package/dist/types/components/TextField/index.d.ts +1 -1
  366. package/dist/types/components/TextField/types.d.ts +6 -6
  367. package/dist/types/components/Textarea/Textarea.d.ts +30 -30
  368. package/dist/types/components/Textarea/index.d.ts +1 -1
  369. package/dist/types/components/Tooltip/Tooltip.d.ts +22 -22
  370. package/dist/types/components/Tooltip/Tooltip.tokens.d.ts +4 -4
  371. package/dist/types/components/Tooltip/index.d.ts +1 -1
  372. package/dist/types/components/TopBar/Actions.d.ts +3 -3
  373. package/dist/types/components/TopBar/CustomContent.d.ts +3 -3
  374. package/dist/types/components/TopBar/Header.d.ts +3 -3
  375. package/dist/types/components/TopBar/TopBar.d.ts +3 -3
  376. package/dist/types/components/TopBar/TopBar.tokens.d.ts +4 -4
  377. package/dist/types/components/TopBar/index.d.ts +12 -12
  378. package/dist/types/components/Typography/Typography.d.ts +15 -15
  379. package/dist/types/components/Typography/Typography.tokens.d.ts +454 -453
  380. package/dist/types/components/Typography/index.d.ts +1 -1
  381. package/dist/types/index.d.ts +35 -35
  382. package/package.json +52 -48
  383. package/dist/core-react.cjs.js +0 -18477
  384. package/dist/core-react.esm.js +0 -18407
  385. package/dist/core-react.umd.js +0 -18479
  386. package/dist/types/components/Combobox/Combobox.d.ts +0 -55
  387. package/dist/types/components/Combobox/Combobox.tokens.d.ts +0 -3
  388. package/dist/types/components/Combobox/index.d.ts +0 -1
  389. package/dist/types/components/Dialog/Actions.d.ts +0 -3
  390. package/dist/types/components/Dialog/Title.d.ts +0 -3
  391. package/dist/types/hooks/index.d.ts +0 -9
  392. package/dist/types/hooks/useAutoResize.d.ts +0 -1
  393. package/dist/types/hooks/useCombinedRefs.d.ts +0 -3
  394. package/dist/types/hooks/useGlobalKeyPress.d.ts +0 -10
  395. package/dist/types/hooks/useHideBodyScroll.d.ts +0 -1
  396. package/dist/types/hooks/useId.d.ts +0 -1
  397. package/dist/types/hooks/useMountedRef.d.ts +0 -1
  398. package/dist/types/hooks/useOutsideClick.d.ts +0 -1
  399. package/dist/types/hooks/usePopper.d.ts +0 -12
  400. package/dist/types/hooks/useToken.d.ts +0 -7
  401. package/dist/types/utils/index.d.ts +0 -4
  402. package/dist/types/utils/joinHandlers.d.ts +0 -3
  403. package/dist/types/utils/setReactInputValue.d.ts +0 -7
  404. package/dist/types/utils/templates/borders.d.ts +0 -2
  405. package/dist/types/utils/templates/common.d.ts +0 -9
  406. package/dist/types/utils/templates/focus.d.ts +0 -2
  407. package/dist/types/utils/templates/index.d.ts +0 -7
  408. package/src/index.ts +0 -37
@@ -0,0 +1,44 @@
1
+ import { forwardRef } from 'react';
2
+ import styled from 'styled-components';
3
+ import { typographyTemplate } from '@equinor/eds-utils';
4
+ import { label } from './Label.tokens.js';
5
+ import { jsxs, jsx } from 'react/jsx-runtime';
6
+
7
+ const LabelBase = styled.label.withConfig({
8
+ displayName: "Label__LabelBase",
9
+ componentId: "sc-1gi2bcn-0"
10
+ })(["display:flex;justify-content:space-between;position:relative;", " margin-left:", ";margin-right:", ";color:", ";"], typographyTemplate(label.typography), label.spacings.left, label.spacings.right, _ref => {
11
+ let {
12
+ disabledText
13
+ } = _ref;
14
+ return disabledText ? label.states.disabled.typography.color : label.typography.color;
15
+ });
16
+ const Text = styled.span.withConfig({
17
+ displayName: "Label__Text",
18
+ componentId: "sc-1gi2bcn-1"
19
+ })(["margin:0;"]);
20
+ const Label = /*#__PURE__*/forwardRef(function Label(props, ref) {
21
+ const {
22
+ label = '',
23
+ meta,
24
+ disabled = false,
25
+ ...other
26
+ } = props;
27
+ return (
28
+ /*#__PURE__*/
29
+
30
+ /* @TODO: Other props spread has to be at the end for downshift to create the for attribute */
31
+ jsxs(LabelBase, {
32
+ ref: ref,
33
+ disabledText: disabled,
34
+ ...other,
35
+ children: [/*#__PURE__*/jsx(Text, {
36
+ children: label
37
+ }), meta && /*#__PURE__*/jsx(Text, {
38
+ children: meta
39
+ })]
40
+ })
41
+ );
42
+ }); // Label.displayName = 'eds-text-field-label'
43
+
44
+ export { Label };
@@ -0,0 +1,30 @@
1
+ import { tokens } from '@equinor/eds-tokens';
2
+
3
+ const {
4
+ colors,
5
+ spacings: {
6
+ comfortable
7
+ },
8
+ typography
9
+ } = tokens;
10
+ const label = {
11
+ background: colors.ui.background__light.rgba,
12
+ typography: { ...typography.input.label,
13
+ color: colors.text.static_icons__tertiary.rgba
14
+ },
15
+ spacings: {
16
+ left: comfortable.small,
17
+ right: comfortable.small,
18
+ top: '6px',
19
+ bottom: '6px'
20
+ },
21
+ states: {
22
+ disabled: {
23
+ typography: {
24
+ color: colors.interactive.disabled__text.rgba
25
+ }
26
+ }
27
+ }
28
+ };
29
+
30
+ export { label };
@@ -0,0 +1,34 @@
1
+ import { forwardRef } from 'react';
2
+ import styled, { css } from 'styled-components';
3
+ import { list } from './List.tokens.js';
4
+ import { typographyTemplate } from '@equinor/eds-utils';
5
+ import { jsx } from 'react/jsx-runtime';
6
+
7
+ const {
8
+ typography
9
+ } = list;
10
+ const StyledList = styled.ul.withConfig({
11
+ displayName: "List__StyledList",
12
+ componentId: "sc-v9d2hy-0"
13
+ })(["", " ", ""], _ref => {
14
+ let {
15
+ as
16
+ } = _ref;
17
+ return as === 'ol' ? css(["& ol{list-style-type:lower-alpha;}"]) : '';
18
+ }, typographyTemplate(typography));
19
+ const List = /*#__PURE__*/forwardRef(function List(_ref2, ref) {
20
+ let {
21
+ children,
22
+ variant = 'bullet',
23
+ ...props
24
+ } = _ref2;
25
+ const as = variant === 'numbered' ? 'ol' : 'ul';
26
+ return /*#__PURE__*/jsx(StyledList, {
27
+ as: as,
28
+ ref: ref,
29
+ ...props,
30
+ children: children
31
+ });
32
+ }); // List.displayName = 'List'
33
+
34
+ export { List };
@@ -0,0 +1,12 @@
1
+ import { tokens } from '@equinor/eds-tokens';
2
+
3
+ const {
4
+ typography: {
5
+ paragraph
6
+ }
7
+ } = tokens;
8
+ const list = {
9
+ typography: paragraph.body_short
10
+ };
11
+
12
+ export { list };
@@ -0,0 +1,15 @@
1
+ import { forwardRef } from 'react';
2
+ import { jsx } from 'react/jsx-runtime';
3
+
4
+ const ListItem = /*#__PURE__*/forwardRef(function ListItem(_ref, ref) {
5
+ let {
6
+ children,
7
+ ...props
8
+ } = _ref;
9
+ return /*#__PURE__*/jsx("li", { ...props,
10
+ ref: ref,
11
+ children: children
12
+ });
13
+ }); // ListItem.displayName = 'ListItem'
14
+
15
+ export { ListItem };
@@ -0,0 +1,8 @@
1
+ import { List as List$1 } from './List.js';
2
+ import { ListItem } from './ListItem.js';
3
+
4
+ const List = List$1;
5
+ List.Item = ListItem;
6
+ List.Item.displayName = 'List.Item';
7
+
8
+ export { List };
@@ -0,0 +1,49 @@
1
+ import { useState, useContext, createContext } from 'react';
2
+ import { jsx } from 'react/jsx-runtime';
3
+
4
+ const initalState = {
5
+ focusedIndex: -1,
6
+ onClose: null
7
+ };
8
+ const MenuContext = /*#__PURE__*/createContext(initalState);
9
+ const MenuProvider = _ref => {
10
+ let {
11
+ children
12
+ } = _ref;
13
+ const [state, setState] = useState(initalState);
14
+ const {
15
+ focusedIndex,
16
+ onClose
17
+ } = state;
18
+
19
+ const setFocusedIndex = i => {
20
+ setState(prevState => ({ ...prevState,
21
+ focusedIndex: i
22
+ }));
23
+ };
24
+
25
+ const setOnClose = onClose => {
26
+ const onCloseHelper = () => {
27
+ setFocusedIndex(-1);
28
+ onClose();
29
+ };
30
+
31
+ setState(prevState => ({ ...prevState,
32
+ onClose: onCloseHelper
33
+ }));
34
+ };
35
+
36
+ const value = {
37
+ setFocusedIndex,
38
+ focusedIndex,
39
+ setOnClose,
40
+ onClose
41
+ };
42
+ return /*#__PURE__*/jsx(MenuContext.Provider, {
43
+ value: value,
44
+ children: children
45
+ });
46
+ };
47
+ const useMenu = () => useContext(MenuContext);
48
+
49
+ export { MenuProvider, useMenu };
@@ -0,0 +1,125 @@
1
+ import { forwardRef, useState, useEffect } from 'react';
2
+ import * as ReactDom from 'react-dom';
3
+ import styled, { css, ThemeProvider } from 'styled-components';
4
+ import { MenuProvider, useMenu } from './Menu.context.js';
5
+ import { MenuList } from './MenuList.js';
6
+ import { bordersTemplate, useIsMounted, useToken, usePopper, useOutsideClick, useGlobalKeyPress } from '@equinor/eds-utils';
7
+ import { menu } from './Menu.tokens.js';
8
+ import { jsx, Fragment } from 'react/jsx-runtime';
9
+ import { Paper } from '../Paper/Paper.js';
10
+ import { useEds } from '../EdsProvider/eds.context.js';
11
+
12
+ const {
13
+ border
14
+ } = menu;
15
+ const MenuPaper = styled(Paper).withConfig({
16
+ displayName: "Menu__MenuPaper",
17
+ componentId: "sc-1vlnqcj-0"
18
+ })(["position:absolute;z-index:300;width:fit-content;min-width:fit-content;", ";", ""], bordersTemplate(border), _ref => {
19
+ let {
20
+ open
21
+ } = _ref;
22
+ return css({
23
+ visibility: open ? null : 'hidden'
24
+ });
25
+ });
26
+ const MenuContainer = /*#__PURE__*/forwardRef(function MenuContainer(_ref2, ref) {
27
+ let {
28
+ children,
29
+ anchorEl,
30
+ onClose: onCloseCallback,
31
+ open,
32
+ containerEl,
33
+ ...rest
34
+ } = _ref2;
35
+ const {
36
+ setOnClose,
37
+ onClose
38
+ } = useMenu();
39
+ useEffect(() => {
40
+ if (onClose === null && onCloseCallback) {
41
+ setOnClose(onCloseCallback);
42
+ }
43
+ }, [onClose, onCloseCallback, setOnClose]);
44
+ useOutsideClick(containerEl, e => {
45
+ if (open && onClose !== null && !anchorEl.contains(e.target)) {
46
+ onClose();
47
+ }
48
+ });
49
+ useGlobalKeyPress('Escape', () => {
50
+ if (open && onClose !== null) {
51
+ onClose();
52
+ anchorEl.focus();
53
+ }
54
+ });
55
+ useGlobalKeyPress('Enter', () => {
56
+ if (open && onClose !== null) {
57
+ setTimeout(() => {
58
+ if (window.document.contains(anchorEl)) {
59
+ anchorEl.focus();
60
+ }
61
+ }, 0);
62
+ }
63
+ });
64
+ return /*#__PURE__*/jsx(MenuList, { ...rest,
65
+ ref: ref,
66
+ children: children
67
+ });
68
+ });
69
+ const Menu = /*#__PURE__*/forwardRef(function Menu(_ref3, ref) {
70
+ let {
71
+ anchorEl,
72
+ open,
73
+ placement = 'auto',
74
+ style,
75
+ className,
76
+ ...rest
77
+ } = _ref3;
78
+ const [containerEl, setContainerEl] = useState(null);
79
+ const [storedAnchorEl, setStoredAnchorEl] = useState(null);
80
+ const isMounted = useIsMounted();
81
+ const {
82
+ density
83
+ } = useEds();
84
+ const token = useToken({
85
+ density
86
+ }, menu);
87
+ useEffect(() => {
88
+ open ? setStoredAnchorEl(anchorEl) : setStoredAnchorEl(null);
89
+ return () => setStoredAnchorEl(null);
90
+ }, [anchorEl, open]);
91
+ const {
92
+ styles,
93
+ attributes
94
+ } = usePopper(storedAnchorEl, containerEl, null, placement, 4);
95
+ const props = {
96
+ open,
97
+ style: { ...styles.popper,
98
+ ...style
99
+ },
100
+ className,
101
+ ...attributes.popper
102
+ };
103
+ const menuProps = { ...rest,
104
+ anchorEl,
105
+ open,
106
+ containerEl
107
+ };
108
+ return /*#__PURE__*/jsx(Fragment, {
109
+ children: isMounted && /*#__PURE__*/ReactDom.createPortal( /*#__PURE__*/jsx(ThemeProvider, {
110
+ theme: token,
111
+ children: /*#__PURE__*/jsx(MenuPaper, {
112
+ elevation: "raised",
113
+ ref: setContainerEl,
114
+ ...props,
115
+ children: /*#__PURE__*/jsx(MenuProvider, {
116
+ children: /*#__PURE__*/jsx(MenuContainer, { ...menuProps,
117
+ ref: ref
118
+ })
119
+ })
120
+ })
121
+ }), document.body)
122
+ });
123
+ });
124
+
125
+ export { Menu };
@@ -0,0 +1,132 @@
1
+ import { tokens } from '@equinor/eds-tokens';
2
+
3
+ const {
4
+ colors: {
5
+ ui: {
6
+ background__default: {
7
+ rgba: background
8
+ }
9
+ },
10
+ interactive: {
11
+ primary__selected_highlight: {
12
+ rgba: activeBackground
13
+ },
14
+ primary__resting: {
15
+ rgba: activeTextColor
16
+ },
17
+ focus: {
18
+ rgba: focusColor
19
+ },
20
+ disabled__fill: {
21
+ rgba: disabledIconColor
22
+ },
23
+ disabled__text: {
24
+ rgba: disabledTextColor
25
+ },
26
+ table__header__fill_hover: {
27
+ rgba: hoverBackground
28
+ }
29
+ },
30
+ text: {
31
+ static_icons__default: {
32
+ rgba: textColor
33
+ }
34
+ }
35
+ },
36
+ spacings: {
37
+ comfortable: {
38
+ medium,
39
+ large,
40
+ small
41
+ }
42
+ },
43
+ typography: {
44
+ navigation: {
45
+ menu_title: typography
46
+ }
47
+ }
48
+ } = tokens;
49
+ const menu = {
50
+ background,
51
+ spacings: {
52
+ top: small,
53
+ bottom: small,
54
+ left: '0px',
55
+ right: '0px'
56
+ },
57
+ border: {
58
+ type: 'border',
59
+ radius: '4px'
60
+ },
61
+ typography: { ...typography,
62
+ color: textColor
63
+ },
64
+ entities: {
65
+ icon: {
66
+ states: {
67
+ disabled: {
68
+ typography: {
69
+ color: disabledIconColor
70
+ }
71
+ }
72
+ }
73
+ },
74
+ item: {
75
+ spacings: {
76
+ left: large,
77
+ right: large,
78
+ top: medium,
79
+ bottom: medium
80
+ },
81
+ states: {
82
+ active: {
83
+ typography: { ...typography,
84
+ color: activeTextColor
85
+ },
86
+ background: activeBackground
87
+ },
88
+ focus: {
89
+ outline: {
90
+ color: focusColor,
91
+ style: 'dashed',
92
+ type: 'outline',
93
+ width: '2px',
94
+ offset: '2px'
95
+ }
96
+ },
97
+ hover: {
98
+ background: hoverBackground
99
+ },
100
+ disabled: {
101
+ typography: { ...typography,
102
+ color: disabledTextColor
103
+ }
104
+ }
105
+ }
106
+ },
107
+ title: {
108
+ spacings: {
109
+ left: large,
110
+ right: large,
111
+ top: small,
112
+ bottom: small
113
+ }
114
+ }
115
+ },
116
+ modes: {
117
+ compact: {
118
+ entities: {
119
+ item: {
120
+ spacings: {
121
+ left: large,
122
+ right: large,
123
+ top: small,
124
+ bottom: small
125
+ }
126
+ }
127
+ }
128
+ }
129
+ }
130
+ };
131
+
132
+ export { menu };
@@ -0,0 +1,103 @@
1
+ import { memo, forwardRef } from 'react';
2
+ import styled, { css } from 'styled-components';
3
+ import { menu } from './Menu.tokens.js';
4
+ import { typographyTemplate, spacingsTemplate, outlineTemplate, useCombinedRefs } from '@equinor/eds-utils';
5
+ import { useMenu } from './Menu.context.js';
6
+ import { jsx } from 'react/jsx-runtime';
7
+
8
+ const {
9
+ typography,
10
+ entities: {
11
+ item: {
12
+ states: {
13
+ active: activeToken,
14
+ focus,
15
+ hover,
16
+ disabled: disabledToken
17
+ }
18
+ },
19
+ icon
20
+ }
21
+ } = menu;
22
+ const Item = styled.button.attrs(_ref => {
23
+ let {
24
+ isFocused
25
+ } = _ref;
26
+ return {
27
+ role: 'menuitem',
28
+ tabIndex: isFocused ? -1 : 0
29
+ };
30
+ }).withConfig({
31
+ displayName: "MenuItem__Item",
32
+ componentId: "sc-1g9fpbe-0"
33
+ })(["border:0;background-color:transparent;width:auto;position:relative;z-index:2;", " ", " ", " ", ""], typographyTemplate(typography), _ref2 => {
34
+ let {
35
+ theme
36
+ } = _ref2;
37
+ return spacingsTemplate(theme.entities.item.spacings);
38
+ }, _ref3 => {
39
+ let {
40
+ active
41
+ } = _ref3;
42
+ return active && css(["background:", ";*{color:", ";}"], activeToken.background, activeToken.typography.color);
43
+ }, _ref4 => {
44
+ let {
45
+ disabled
46
+ } = _ref4;
47
+ return disabled ? css(["*{color:", ";}svg{fill:", ";}&:focus{outline:none;}@media (hover:hover) and (pointer:fine){&:hover{cursor:not-allowed;}}"], disabledToken.typography.color, icon.states.disabled.typography.color) : css(["@media (hover:hover) and (pointer:fine){&:hover{z-index:1;cursor:pointer;background:", ";}}&:focus{z-index:3;", "}"], hover.background, outlineTemplate(focus.outline));
48
+ });
49
+ const Content = styled.div.withConfig({
50
+ displayName: "MenuItem__Content",
51
+ componentId: "sc-1g9fpbe-1"
52
+ })(["width:auto;display:grid;grid-gap:16px;grid-auto-flow:column;grid-auto-columns:max-content auto max-content;align-items:center;"]);
53
+ const MenuItem = /*#__PURE__*/memo( /*#__PURE__*/forwardRef(function MenuItem(_ref5, ref) {
54
+ let {
55
+ children,
56
+ disabled,
57
+ index = 0,
58
+ onClick,
59
+ ...rest
60
+ } = _ref5;
61
+ const {
62
+ focusedIndex,
63
+ setFocusedIndex,
64
+ onClose
65
+ } = useMenu();
66
+
67
+ const toggleFocus = index_ => {
68
+ if (focusedIndex !== index_) {
69
+ setFocusedIndex(index_);
70
+ }
71
+ };
72
+
73
+ const isFocused = index === focusedIndex;
74
+ const props = { ...rest,
75
+ disabled,
76
+ isFocused
77
+ };
78
+ return /*#__PURE__*/jsx(Item, { ...props,
79
+ ref: useCombinedRefs(ref, el => {
80
+ if (isFocused) {
81
+ requestAnimationFrame(() => {
82
+ if (el !== null) el.focus();
83
+ });
84
+ }
85
+ }),
86
+ onFocus: () => toggleFocus(index),
87
+ onClick: e => {
88
+ if (onClick) {
89
+ onClick(e);
90
+
91
+ if (onClose !== null) {
92
+ onClose(e);
93
+ }
94
+ }
95
+ },
96
+ children: /*#__PURE__*/jsx(Content, {
97
+ children: children
98
+ })
99
+ });
100
+ }));
101
+ MenuItem.displayName = 'MenuItem';
102
+
103
+ export { MenuItem };
@@ -0,0 +1,97 @@
1
+ import { forwardRef, useMemo, Children, cloneElement, useEffect, isValidElement } from 'react';
2
+ import styled from 'styled-components';
3
+ import { useMenu } from './Menu.context.js';
4
+ import { MenuItem } from './MenuItem.js';
5
+ import { MenuSection } from './MenuSection.js';
6
+ import { menu } from './Menu.tokens.js';
7
+ import { spacingsTemplate } from '@equinor/eds-utils';
8
+ import { jsx } from 'react/jsx-runtime';
9
+
10
+ const List = styled.div.withConfig({
11
+ displayName: "MenuList__List",
12
+ componentId: "sc-104rzof-0"
13
+ })(["position:relative;list-style:none;display:flex;flex-direction:column;margin:0;", " li:first-child{z-index:3;}"], spacingsTemplate(menu.spacings));
14
+
15
+ function isIndexable(item) {
16
+ if ( /*#__PURE__*/isValidElement(item) && !item.props.disabled && item.type === MenuItem) return true;
17
+ return false;
18
+ }
19
+
20
+ const MenuList = /*#__PURE__*/forwardRef(function MenuList(_ref, ref) {
21
+ let {
22
+ children,
23
+ focus,
24
+ ...rest
25
+ } = _ref;
26
+ const {
27
+ focusedIndex,
28
+ setFocusedIndex
29
+ } = useMenu();
30
+ let index = -1;
31
+ const focusableIndexs = useMemo(() => [], []);
32
+ const updatedChildren = useMemo(() => Children.map(children, child => {
33
+ if (child.type === MenuSection) {
34
+ const updatedGrandChildren = Children.map(child.props.children, grandChild => {
35
+ index++;
36
+ if (isIndexable(grandChild)) focusableIndexs.push(index);
37
+ return /*#__PURE__*/cloneElement(grandChild, {
38
+ index
39
+ });
40
+ });
41
+ return /*#__PURE__*/cloneElement(child, null, updatedGrandChildren);
42
+ } else {
43
+ index++;
44
+ if (isIndexable(child)) focusableIndexs.push(index);
45
+ return /*#__PURE__*/cloneElement(child, {
46
+ index
47
+ });
48
+ }
49
+ }), [children, focusableIndexs, index]);
50
+ const firstFocusIndex = focusableIndexs[0];
51
+ const lastFocusIndex = focusableIndexs[focusableIndexs.length - 1];
52
+ useEffect(() => {
53
+ if (focus === 'first') {
54
+ setFocusedIndex(firstFocusIndex);
55
+ }
56
+
57
+ if (focus === 'last') {
58
+ setFocusedIndex(lastFocusIndex);
59
+ } // eslint-disable-next-line react-hooks/exhaustive-deps
60
+
61
+ }, [focus, firstFocusIndex, lastFocusIndex]);
62
+
63
+ const handleMenuItemChange = (direction, fallbackIndex) => {
64
+ const i = direction === 'down' ? 1 : -1;
65
+ const currentFocus = focusableIndexs.indexOf(focusedIndex);
66
+ const nextMenuItem = focusableIndexs[currentFocus + i];
67
+ const nextFocusedIndex = typeof nextMenuItem === 'undefined' ? fallbackIndex : nextMenuItem;
68
+ setFocusedIndex(nextFocusedIndex);
69
+ };
70
+
71
+ const handleKeyPress = event => {
72
+ const {
73
+ key
74
+ } = event;
75
+ event.stopPropagation();
76
+
77
+ if (key === 'ArrowDown') {
78
+ event.preventDefault();
79
+ handleMenuItemChange('down', firstFocusIndex);
80
+ }
81
+
82
+ if (key === 'ArrowUp') {
83
+ event.preventDefault();
84
+ handleMenuItemChange('up', lastFocusIndex);
85
+ }
86
+ };
87
+
88
+ return /*#__PURE__*/jsx(List, {
89
+ onKeyDown: handleKeyPress,
90
+ role: "menu",
91
+ ...rest,
92
+ ref: ref,
93
+ children: updatedChildren
94
+ });
95
+ }); // MenuList.displayName = 'EdsMenuList'
96
+
97
+ export { MenuList };
@@ -0,0 +1,36 @@
1
+ import { memo } from 'react';
2
+ import styled from 'styled-components';
3
+ import { menu } from './Menu.tokens.js';
4
+ import { spacingsTemplate } from '@equinor/eds-utils';
5
+ import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
6
+ import { Divider } from '../Divider/Divider.js';
7
+ import { Typography } from '../Typography/Typography.js';
8
+
9
+ const Header = styled.div.attrs(() => ({
10
+ tabIndex: 0
11
+ })).withConfig({
12
+ displayName: "MenuSection__Header",
13
+ componentId: "sc-gfcbvg-0"
14
+ })(["", " &:focus{outline:none;}"], spacingsTemplate(menu.entities.title.spacings));
15
+ const MenuSection = /*#__PURE__*/memo(function MenuSection(props) {
16
+ const {
17
+ children,
18
+ title,
19
+ index
20
+ } = props;
21
+ return /*#__PURE__*/jsxs(Fragment, {
22
+ children: [index !== 0 && /*#__PURE__*/jsx("div", {
23
+ children: /*#__PURE__*/jsx(Divider, {
24
+ variant: "small"
25
+ })
26
+ }), title && /*#__PURE__*/jsx(Header, {
27
+ children: /*#__PURE__*/jsx(Typography, {
28
+ group: "navigation",
29
+ variant: "label",
30
+ children: title
31
+ })
32
+ }), children]
33
+ });
34
+ }); // MenuSection.displayName = 'EdsMenuSection'
35
+
36
+ export { MenuSection };
@@ -0,0 +1,11 @@
1
+ import { Menu as Menu$1 } from './Menu.js';
2
+ import { MenuItem } from './MenuItem.js';
3
+ import { MenuSection } from './MenuSection.js';
4
+
5
+ const Menu = Menu$1;
6
+ Menu.Item = MenuItem;
7
+ Menu.Section = MenuSection;
8
+ Menu.Item.displayName = 'Menu.Item';
9
+ Menu.Section.displayName = 'Menu.Section';
10
+
11
+ export { Menu };