@okta/odyssey-react-mui 0.23.0 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1146) hide show
  1. package/CHANGELOG.md +56 -0
  2. package/README.md +43 -7
  3. package/dist/@types/i18next.d.js +14 -0
  4. package/dist/@types/i18next.d.js.map +1 -0
  5. package/dist/Autocomplete.js +15 -4
  6. package/dist/Autocomplete.js.map +1 -1
  7. package/dist/Banner.js +16 -6
  8. package/dist/Banner.js.map +1 -1
  9. package/dist/Box.js +29 -0
  10. package/dist/Box.js.map +1 -0
  11. package/dist/Button.js +35 -11
  12. package/dist/Button.js.map +1 -1
  13. package/dist/Callout.js +50 -0
  14. package/dist/Callout.js.map +1 -0
  15. package/dist/Checkbox.js +54 -15
  16. package/dist/Checkbox.js.map +1 -1
  17. package/dist/CheckboxGroup.js +16 -4
  18. package/dist/CheckboxGroup.js.map +1 -1
  19. package/dist/CircularProgress.js +14 -1
  20. package/dist/CircularProgress.js.map +1 -1
  21. package/dist/Dialog.js +26 -16
  22. package/dist/Dialog.js.map +1 -1
  23. package/dist/Field.js +21 -9
  24. package/dist/Field.js.map +1 -1
  25. package/dist/FieldError.js +9 -5
  26. package/dist/FieldError.js.map +1 -1
  27. package/dist/FieldHint.js +4 -4
  28. package/dist/FieldHint.js.map +1 -1
  29. package/dist/FieldLabel.js +22 -8
  30. package/dist/FieldLabel.js.map +1 -1
  31. package/dist/Fieldset.js +64 -0
  32. package/dist/Fieldset.js.map +1 -0
  33. package/dist/FieldsetContext.js +18 -0
  34. package/dist/FieldsetContext.js.map +1 -0
  35. package/dist/Form.js +81 -0
  36. package/dist/Form.js.map +1 -0
  37. package/dist/Link.js +18 -19
  38. package/dist/Link.js.map +1 -1
  39. package/dist/MenuButton.js +41 -27
  40. package/dist/MenuButton.js.map +1 -1
  41. package/dist/MenuContext.js +18 -0
  42. package/dist/MenuContext.js.map +1 -0
  43. package/dist/MenuItem.js +25 -10
  44. package/dist/MenuItem.js.map +1 -1
  45. package/dist/MuiPropsChild.js +4 -1
  46. package/dist/MuiPropsChild.js.map +1 -1
  47. package/dist/MuiPropsContext.js +3 -1
  48. package/dist/MuiPropsContext.js.map +1 -1
  49. package/dist/NativeSelect.js +61 -0
  50. package/dist/NativeSelect.js.map +1 -0
  51. package/dist/NullElement.js +2 -0
  52. package/dist/NullElement.js.map +1 -0
  53. package/dist/OdysseyCacheProvider.js +7 -5
  54. package/dist/OdysseyCacheProvider.js.map +1 -1
  55. package/dist/OdysseyDesignTokensContext.js +17 -0
  56. package/dist/OdysseyDesignTokensContext.js.map +1 -0
  57. package/dist/OdysseyI18n.js +97 -0
  58. package/dist/OdysseyI18n.js.map +1 -0
  59. package/dist/OdysseyProvider.js +44 -0
  60. package/dist/OdysseyProvider.js.map +1 -0
  61. package/dist/OdysseyThemeProvider.js +20 -7
  62. package/dist/OdysseyThemeProvider.js.map +1 -1
  63. package/dist/OdysseyTranslationProvider.js +47 -0
  64. package/dist/OdysseyTranslationProvider.js.map +1 -0
  65. package/dist/OdysseyTranslationProvider.types.js +14 -0
  66. package/dist/OdysseyTranslationProvider.types.js.map +1 -0
  67. package/dist/PasswordField.js +19 -5
  68. package/dist/PasswordField.js.map +1 -1
  69. package/dist/Radio.js +16 -8
  70. package/dist/Radio.js.map +1 -1
  71. package/dist/RadioGroup.js +12 -2
  72. package/dist/RadioGroup.js.map +1 -1
  73. package/dist/ScreenReaderText.js +8 -5
  74. package/dist/ScreenReaderText.js.map +1 -1
  75. package/dist/SearchField.js +47 -5
  76. package/dist/SearchField.js.map +1 -1
  77. package/dist/Select.js +132 -0
  78. package/dist/Select.js.map +1 -0
  79. package/dist/Status.js +10 -4
  80. package/dist/Status.js.map +1 -1
  81. package/dist/SvgIcon.js +15 -0
  82. package/dist/SvgIcon.js.map +1 -0
  83. package/dist/Tabs.js +48 -0
  84. package/dist/Tabs.js.map +1 -0
  85. package/dist/Tag.js +23 -5
  86. package/dist/Tag.js.map +1 -1
  87. package/dist/TagList.js +14 -2
  88. package/dist/TagList.js.map +1 -1
  89. package/dist/TagListContext.js +1 -0
  90. package/dist/TagListContext.js.map +1 -1
  91. package/dist/TextField.js +13 -2
  92. package/dist/TextField.js.map +1 -1
  93. package/dist/Toast.js +21 -8
  94. package/dist/Toast.js.map +1 -1
  95. package/dist/ToastStack.js +11 -8
  96. package/dist/ToastStack.js.map +1 -1
  97. package/dist/Tooltip.js +13 -2
  98. package/dist/Tooltip.js.map +1 -1
  99. package/dist/Typography.js +283 -0
  100. package/dist/Typography.js.map +1 -0
  101. package/dist/createUniqueAlphabeticalId.js +1 -2
  102. package/dist/createUniqueAlphabeticalId.js.map +1 -1
  103. package/dist/createUniqueId.js +1 -2
  104. package/dist/createUniqueId.js.map +1 -1
  105. package/dist/icons.generated/Add.js +33 -0
  106. package/dist/icons.generated/Add.js.map +1 -0
  107. package/dist/icons.generated/AddCircle.js +33 -0
  108. package/dist/icons.generated/AddCircle.js.map +1 -0
  109. package/dist/icons.generated/Apps.js +33 -0
  110. package/dist/icons.generated/Apps.js.map +1 -0
  111. package/dist/icons.generated/ArrowDown.js +33 -0
  112. package/dist/icons.generated/ArrowDown.js.map +1 -0
  113. package/dist/icons.generated/ArrowLeft.js +33 -0
  114. package/dist/icons.generated/ArrowLeft.js.map +1 -0
  115. package/dist/icons.generated/ArrowLowerLeft.js +33 -0
  116. package/dist/icons.generated/ArrowLowerLeft.js.map +1 -0
  117. package/dist/icons.generated/ArrowLowerRight.js +33 -0
  118. package/dist/icons.generated/ArrowLowerRight.js.map +1 -0
  119. package/dist/icons.generated/ArrowRight.js +33 -0
  120. package/dist/icons.generated/ArrowRight.js.map +1 -0
  121. package/dist/icons.generated/ArrowUnsorted.js +33 -0
  122. package/dist/icons.generated/ArrowUnsorted.js.map +1 -0
  123. package/dist/icons.generated/ArrowUp.js +33 -0
  124. package/dist/icons.generated/ArrowUp.js.map +1 -0
  125. package/dist/icons.generated/ArrowUpperLeft.js +33 -0
  126. package/dist/icons.generated/ArrowUpperLeft.js.map +1 -0
  127. package/dist/icons.generated/ArrowUpperRight.js +33 -0
  128. package/dist/icons.generated/ArrowUpperRight.js.map +1 -0
  129. package/dist/icons.generated/Bug.js +33 -0
  130. package/dist/icons.generated/Bug.js.map +1 -0
  131. package/dist/icons.generated/Calendar.js +33 -0
  132. package/dist/icons.generated/Calendar.js.map +1 -0
  133. package/dist/icons.generated/Call.js +33 -0
  134. package/dist/icons.generated/Call.js.map +1 -0
  135. package/dist/icons.generated/Chat.js +33 -0
  136. package/dist/icons.generated/Chat.js.map +1 -0
  137. package/dist/icons.generated/Check.js +33 -0
  138. package/dist/icons.generated/Check.js.map +1 -0
  139. package/dist/icons.generated/CheckCircleFilled.js +33 -0
  140. package/dist/icons.generated/CheckCircleFilled.js.map +1 -0
  141. package/dist/icons.generated/ChevronDown.js +33 -0
  142. package/dist/icons.generated/ChevronDown.js.map +1 -0
  143. package/dist/icons.generated/ChevronLeft.js +33 -0
  144. package/dist/icons.generated/ChevronLeft.js.map +1 -0
  145. package/dist/icons.generated/ChevronRight.js +33 -0
  146. package/dist/icons.generated/ChevronRight.js.map +1 -0
  147. package/dist/icons.generated/ChevronUp.js +33 -0
  148. package/dist/icons.generated/ChevronUp.js.map +1 -0
  149. package/dist/icons.generated/Clock.js +33 -0
  150. package/dist/icons.generated/Clock.js.map +1 -0
  151. package/dist/icons.generated/Close.js +33 -0
  152. package/dist/icons.generated/Close.js.map +1 -0
  153. package/dist/icons.generated/CloseCircleFilled.js +33 -0
  154. package/dist/icons.generated/CloseCircleFilled.js.map +1 -0
  155. package/dist/icons.generated/CollapseLeft.js +33 -0
  156. package/dist/icons.generated/CollapseLeft.js.map +1 -0
  157. package/dist/icons.generated/CollapseRight.js +33 -0
  158. package/dist/icons.generated/CollapseRight.js.map +1 -0
  159. package/dist/icons.generated/Copy.js +33 -0
  160. package/dist/icons.generated/Copy.js.map +1 -0
  161. package/dist/icons.generated/DangerDiamond.js +33 -0
  162. package/dist/icons.generated/DangerDiamond.js.map +1 -0
  163. package/dist/icons.generated/DangerDiamondFilled.js +33 -0
  164. package/dist/icons.generated/DangerDiamondFilled.js.map +1 -0
  165. package/dist/icons.generated/Delete.js +33 -0
  166. package/dist/icons.generated/Delete.js.map +1 -0
  167. package/dist/icons.generated/Deny.js +33 -0
  168. package/dist/icons.generated/Deny.js.map +1 -0
  169. package/dist/icons.generated/Devices.js +33 -0
  170. package/dist/icons.generated/Devices.js.map +1 -0
  171. package/dist/icons.generated/Directory.js +33 -0
  172. package/dist/icons.generated/Directory.js.map +1 -0
  173. package/dist/icons.generated/Documentation.js +33 -0
  174. package/dist/icons.generated/Documentation.js.map +1 -0
  175. package/dist/icons.generated/Download.js +33 -0
  176. package/dist/icons.generated/Download.js.map +1 -0
  177. package/dist/icons.generated/DragIndicator.js +33 -0
  178. package/dist/icons.generated/DragIndicator.js.map +1 -0
  179. package/dist/icons.generated/Edit.js +33 -0
  180. package/dist/icons.generated/Edit.js.map +1 -0
  181. package/dist/icons.generated/ExpandLeft.js +33 -0
  182. package/dist/icons.generated/ExpandLeft.js.map +1 -0
  183. package/dist/icons.generated/ExpandRight.js +33 -0
  184. package/dist/icons.generated/ExpandRight.js.map +1 -0
  185. package/dist/icons.generated/ExternalLink.js +33 -0
  186. package/dist/icons.generated/ExternalLink.js.map +1 -0
  187. package/dist/icons.generated/Filter.js +33 -0
  188. package/dist/icons.generated/Filter.js.map +1 -0
  189. package/dist/icons.generated/Folder.js +33 -0
  190. package/dist/icons.generated/Folder.js.map +1 -0
  191. package/dist/icons.generated/Globe.js +33 -0
  192. package/dist/icons.generated/Globe.js.map +1 -0
  193. package/dist/icons.generated/Grid.js +74 -0
  194. package/dist/icons.generated/Grid.js.map +1 -0
  195. package/dist/icons.generated/Group.js +33 -0
  196. package/dist/icons.generated/Group.js.map +1 -0
  197. package/dist/icons.generated/Hide.js +33 -0
  198. package/dist/icons.generated/Hide.js.map +1 -0
  199. package/dist/icons.generated/Home.js +33 -0
  200. package/dist/icons.generated/Home.js.map +1 -0
  201. package/dist/icons.generated/InformationCircle.js +33 -0
  202. package/dist/icons.generated/InformationCircle.js.map +1 -0
  203. package/dist/icons.generated/InformationCircleFilled.js +33 -0
  204. package/dist/icons.generated/InformationCircleFilled.js.map +1 -0
  205. package/dist/icons.generated/Link.js +33 -0
  206. package/dist/icons.generated/Link.js.map +1 -0
  207. package/dist/icons.generated/List.js +33 -0
  208. package/dist/icons.generated/List.js.map +1 -0
  209. package/dist/icons.generated/Lock.js +33 -0
  210. package/dist/icons.generated/Lock.js.map +1 -0
  211. package/dist/icons.generated/More.js +33 -0
  212. package/dist/icons.generated/More.js.map +1 -0
  213. package/dist/icons.generated/Notification.js +33 -0
  214. package/dist/icons.generated/Notification.js.map +1 -0
  215. package/dist/icons.generated/Pause.js +33 -0
  216. package/dist/icons.generated/Pause.js.map +1 -0
  217. package/dist/icons.generated/QuestionCircle.js +33 -0
  218. package/dist/icons.generated/QuestionCircle.js.map +1 -0
  219. package/dist/icons.generated/QuestionCircleFilled.js +33 -0
  220. package/dist/icons.generated/QuestionCircleFilled.js.map +1 -0
  221. package/dist/icons.generated/Refresh.js +33 -0
  222. package/dist/icons.generated/Refresh.js.map +1 -0
  223. package/dist/icons.generated/Reset.js +33 -0
  224. package/dist/icons.generated/Reset.js.map +1 -0
  225. package/dist/icons.generated/Resume.js +33 -0
  226. package/dist/icons.generated/Resume.js.map +1 -0
  227. package/dist/icons.generated/Search.js +33 -0
  228. package/dist/icons.generated/Search.js.map +1 -0
  229. package/dist/icons.generated/Server.js +33 -0
  230. package/dist/icons.generated/Server.js.map +1 -0
  231. package/dist/icons.generated/Settings.js +33 -0
  232. package/dist/icons.generated/Settings.js.map +1 -0
  233. package/dist/icons.generated/Show.js +33 -0
  234. package/dist/icons.generated/Show.js.map +1 -0
  235. package/dist/icons.generated/Subtract.js +33 -0
  236. package/dist/icons.generated/Subtract.js.map +1 -0
  237. package/dist/icons.generated/Sync.js +33 -0
  238. package/dist/icons.generated/Sync.js.map +1 -0
  239. package/dist/icons.generated/Unlock.js +33 -0
  240. package/dist/icons.generated/Unlock.js.map +1 -0
  241. package/dist/icons.generated/Upload.js +33 -0
  242. package/dist/icons.generated/Upload.js.map +1 -0
  243. package/dist/icons.generated/User.js +33 -0
  244. package/dist/icons.generated/User.js.map +1 -0
  245. package/dist/icons.generated/Video.js +33 -0
  246. package/dist/icons.generated/Video.js.map +1 -0
  247. package/dist/icons.generated/Warning.js +33 -0
  248. package/dist/icons.generated/Warning.js.map +1 -0
  249. package/dist/icons.generated/WarningFilled.js +33 -0
  250. package/dist/icons.generated/WarningFilled.js.map +1 -0
  251. package/dist/icons.generated/index.js +85 -0
  252. package/dist/icons.generated/index.js.map +1 -0
  253. package/dist/index.js +15 -8
  254. package/dist/index.js.map +1 -1
  255. package/dist/labs/DatePicker.js +42 -0
  256. package/dist/labs/DatePicker.js.map +1 -0
  257. package/dist/labs/DatePicker.types.js +12 -0
  258. package/dist/labs/DatePicker.types.js.map +1 -0
  259. package/dist/labs/PaginatedTable.js +170 -0
  260. package/dist/labs/PaginatedTable.js.map +1 -0
  261. package/dist/labs/StaticTable.js +82 -0
  262. package/dist/labs/StaticTable.js.map +1 -0
  263. package/dist/labs/datePickerTheme.js +456 -0
  264. package/dist/labs/datePickerTheme.js.map +1 -0
  265. package/dist/labs/index.js +20 -0
  266. package/dist/labs/index.js.map +1 -0
  267. package/dist/labs/materialReactTableTypes.js +2 -0
  268. package/dist/labs/materialReactTableTypes.js.map +1 -0
  269. package/dist/properties/ts/odyssey-react-mui.js +16 -0
  270. package/dist/properties/ts/odyssey-react-mui.js.map +1 -0
  271. package/dist/properties/ts/odyssey-react-mui_cs.js +16 -0
  272. package/dist/properties/ts/odyssey-react-mui_cs.js.map +1 -0
  273. package/dist/properties/ts/odyssey-react-mui_da.js +16 -0
  274. package/dist/properties/ts/odyssey-react-mui_da.js.map +1 -0
  275. package/dist/properties/ts/odyssey-react-mui_de.js +16 -0
  276. package/dist/properties/ts/odyssey-react-mui_de.js.map +1 -0
  277. package/dist/properties/ts/odyssey-react-mui_el.js +16 -0
  278. package/dist/properties/ts/odyssey-react-mui_el.js.map +1 -0
  279. package/dist/properties/ts/odyssey-react-mui_es.js +16 -0
  280. package/dist/properties/ts/odyssey-react-mui_es.js.map +1 -0
  281. package/dist/properties/ts/odyssey-react-mui_fi.js +16 -0
  282. package/dist/properties/ts/odyssey-react-mui_fi.js.map +1 -0
  283. package/dist/properties/ts/odyssey-react-mui_fr.js +16 -0
  284. package/dist/properties/ts/odyssey-react-mui_fr.js.map +1 -0
  285. package/dist/properties/ts/odyssey-react-mui_hu.js +16 -0
  286. package/dist/properties/ts/odyssey-react-mui_hu.js.map +1 -0
  287. package/dist/properties/ts/odyssey-react-mui_id.js +16 -0
  288. package/dist/properties/ts/odyssey-react-mui_id.js.map +1 -0
  289. package/dist/properties/ts/odyssey-react-mui_it.js +16 -0
  290. package/dist/properties/ts/odyssey-react-mui_it.js.map +1 -0
  291. package/dist/properties/ts/odyssey-react-mui_ja.js +16 -0
  292. package/dist/properties/ts/odyssey-react-mui_ja.js.map +1 -0
  293. package/dist/properties/ts/odyssey-react-mui_ko.js +16 -0
  294. package/dist/properties/ts/odyssey-react-mui_ko.js.map +1 -0
  295. package/dist/properties/ts/odyssey-react-mui_ms.js +16 -0
  296. package/dist/properties/ts/odyssey-react-mui_ms.js.map +1 -0
  297. package/dist/properties/ts/odyssey-react-mui_nb.js +16 -0
  298. package/dist/properties/ts/odyssey-react-mui_nb.js.map +1 -0
  299. package/dist/properties/ts/odyssey-react-mui_nl_NL.js +16 -0
  300. package/dist/properties/ts/odyssey-react-mui_nl_NL.js.map +1 -0
  301. package/dist/properties/ts/odyssey-react-mui_ok_PL.js +11 -0
  302. package/dist/properties/ts/odyssey-react-mui_ok_PL.js.map +1 -0
  303. package/dist/properties/ts/odyssey-react-mui_ok_SK.js +11 -0
  304. package/dist/properties/ts/odyssey-react-mui_ok_SK.js.map +1 -0
  305. package/dist/properties/ts/odyssey-react-mui_pl.js +16 -0
  306. package/dist/properties/ts/odyssey-react-mui_pl.js.map +1 -0
  307. package/dist/properties/ts/odyssey-react-mui_pt_BR.js +16 -0
  308. package/dist/properties/ts/odyssey-react-mui_pt_BR.js.map +1 -0
  309. package/dist/properties/ts/odyssey-react-mui_ro.js +16 -0
  310. package/dist/properties/ts/odyssey-react-mui_ro.js.map +1 -0
  311. package/dist/properties/ts/odyssey-react-mui_ru.js +16 -0
  312. package/dist/properties/ts/odyssey-react-mui_ru.js.map +1 -0
  313. package/dist/properties/ts/odyssey-react-mui_sv.js +16 -0
  314. package/dist/properties/ts/odyssey-react-mui_sv.js.map +1 -0
  315. package/dist/properties/ts/odyssey-react-mui_th.js +16 -0
  316. package/dist/properties/ts/odyssey-react-mui_th.js.map +1 -0
  317. package/dist/properties/ts/odyssey-react-mui_tr.js +16 -0
  318. package/dist/properties/ts/odyssey-react-mui_tr.js.map +1 -0
  319. package/dist/properties/ts/odyssey-react-mui_uk.js +16 -0
  320. package/dist/properties/ts/odyssey-react-mui_uk.js.map +1 -0
  321. package/dist/properties/ts/odyssey-react-mui_vi.js +16 -0
  322. package/dist/properties/ts/odyssey-react-mui_vi.js.map +1 -0
  323. package/dist/properties/ts/odyssey-react-mui_zh_CN.js +16 -0
  324. package/dist/properties/ts/odyssey-react-mui_zh_CN.js.map +1 -0
  325. package/dist/properties/ts/odyssey-react-mui_zh_TW.js +16 -0
  326. package/dist/properties/ts/odyssey-react-mui_zh_TW.js.map +1 -0
  327. package/dist/scripts/generateIconsIndex.d.ts +13 -0
  328. package/dist/scripts/generateIconsIndex.d.ts.map +1 -0
  329. package/dist/src/Autocomplete.d.ts +34 -1
  330. package/dist/src/Autocomplete.d.ts.map +1 -1
  331. package/dist/src/Banner.d.ts +4 -2
  332. package/dist/src/Banner.d.ts.map +1 -1
  333. package/dist/src/Box.d.ts +20 -0
  334. package/dist/src/Box.d.ts.map +1 -0
  335. package/dist/src/Button.d.ts +66 -9
  336. package/dist/src/Button.d.ts.map +1 -1
  337. package/dist/src/Callout.d.ts +37 -0
  338. package/dist/src/Callout.d.ts.map +1 -0
  339. package/dist/src/Checkbox.d.ts +40 -5
  340. package/dist/src/Checkbox.d.ts.map +1 -1
  341. package/dist/src/CheckboxGroup.d.ts +20 -1
  342. package/dist/src/CheckboxGroup.d.ts.map +1 -1
  343. package/dist/src/CircularProgress.d.ts +9 -1
  344. package/dist/src/CircularProgress.d.ts.map +1 -1
  345. package/dist/src/Dialog.d.ts +29 -7
  346. package/dist/src/Dialog.d.ts.map +1 -1
  347. package/dist/src/Field.d.ts +10 -6
  348. package/dist/src/Field.d.ts.map +1 -1
  349. package/dist/src/FieldError.d.ts.map +1 -1
  350. package/dist/src/FieldHint.d.ts.map +1 -1
  351. package/dist/src/FieldLabel.d.ts +1 -2
  352. package/dist/src/FieldLabel.d.ts.map +1 -1
  353. package/dist/src/Fieldset.d.ts +46 -0
  354. package/dist/src/Fieldset.d.ts.map +1 -0
  355. package/dist/src/FieldsetContext.d.ts +18 -0
  356. package/dist/src/FieldsetContext.d.ts.map +1 -0
  357. package/dist/src/Form.d.ts +76 -0
  358. package/dist/src/Form.d.ts.map +1 -0
  359. package/dist/src/Link.d.ts +23 -4
  360. package/dist/src/Link.d.ts.map +1 -1
  361. package/dist/src/MenuButton.d.ts +40 -10
  362. package/dist/src/MenuButton.d.ts.map +1 -1
  363. package/dist/src/MenuContext.d.ts +18 -0
  364. package/dist/src/MenuContext.d.ts.map +1 -0
  365. package/dist/src/MenuItem.d.ts +32 -6
  366. package/dist/src/MenuItem.d.ts.map +1 -1
  367. package/dist/src/MuiPropsChild.d.ts.map +1 -1
  368. package/dist/src/MuiPropsContext.d.ts +1 -0
  369. package/dist/src/MuiPropsContext.d.ts.map +1 -1
  370. package/dist/src/NativeSelect.d.ts +75 -0
  371. package/dist/src/NativeSelect.d.ts.map +1 -0
  372. package/dist/src/NullElement.d.ts +13 -0
  373. package/dist/src/NullElement.d.ts.map +1 -0
  374. package/dist/src/OdysseyCacheProvider.d.ts +8 -5
  375. package/dist/src/OdysseyCacheProvider.d.ts.map +1 -1
  376. package/dist/src/OdysseyDesignTokensContext.d.ts +16 -0
  377. package/dist/src/OdysseyDesignTokensContext.d.ts.map +1 -0
  378. package/dist/src/OdysseyI18n.d.ts +429 -0
  379. package/dist/src/OdysseyI18n.d.ts.map +1 -0
  380. package/dist/src/OdysseyProvider.d.ts +21 -0
  381. package/dist/src/OdysseyProvider.d.ts.map +1 -0
  382. package/dist/src/OdysseyThemeProvider.d.ts +9 -6
  383. package/dist/src/OdysseyThemeProvider.d.ts.map +1 -1
  384. package/dist/src/OdysseyTranslationProvider.d.ts +24 -0
  385. package/dist/src/OdysseyTranslationProvider.d.ts.map +1 -0
  386. package/dist/src/OdysseyTranslationProvider.types.d.ts +14 -0
  387. package/dist/src/OdysseyTranslationProvider.types.d.ts.map +1 -0
  388. package/dist/src/PasswordField.d.ts.map +1 -1
  389. package/dist/src/Radio.d.ts +20 -3
  390. package/dist/src/Radio.d.ts.map +1 -1
  391. package/dist/src/RadioGroup.d.ts +7 -7
  392. package/dist/src/RadioGroup.d.ts.map +1 -1
  393. package/dist/src/ScreenReaderText.d.ts.map +1 -1
  394. package/dist/src/SearchField.d.ts +4 -0
  395. package/dist/src/SearchField.d.ts.map +1 -1
  396. package/dist/src/Select.d.ts +71 -0
  397. package/dist/src/Select.d.ts.map +1 -0
  398. package/dist/src/Status.d.ts +11 -5
  399. package/dist/src/Status.d.ts.map +1 -1
  400. package/dist/src/SvgIcon.d.ts +21 -0
  401. package/dist/src/SvgIcon.d.ts.map +1 -0
  402. package/dist/src/Tabs.d.ts +51 -0
  403. package/dist/src/Tabs.d.ts.map +1 -0
  404. package/dist/src/Tag.d.ts +15 -5
  405. package/dist/src/Tag.d.ts.map +1 -1
  406. package/dist/src/TagList.d.ts +4 -1
  407. package/dist/src/TagList.d.ts.map +1 -1
  408. package/dist/src/TextField.d.ts +4 -8
  409. package/dist/src/TextField.d.ts.map +1 -1
  410. package/dist/src/Toast.d.ts +12 -11
  411. package/dist/src/Toast.d.ts.map +1 -1
  412. package/dist/src/ToastStack.d.ts +3 -0
  413. package/dist/src/ToastStack.d.ts.map +1 -1
  414. package/dist/src/Tooltip.d.ts +15 -3
  415. package/dist/src/Tooltip.d.ts.map +1 -1
  416. package/dist/src/Typography.d.ts +95 -0
  417. package/dist/src/Typography.d.ts.map +1 -0
  418. package/dist/src/icons.generated/Add.d.ts +16 -0
  419. package/dist/src/icons.generated/Add.d.ts.map +1 -0
  420. package/dist/src/icons.generated/AddCircle.d.ts +16 -0
  421. package/dist/src/icons.generated/AddCircle.d.ts.map +1 -0
  422. package/dist/src/icons.generated/Apps.d.ts +16 -0
  423. package/dist/src/icons.generated/Apps.d.ts.map +1 -0
  424. package/dist/src/icons.generated/ArrowDown.d.ts +16 -0
  425. package/dist/src/icons.generated/ArrowDown.d.ts.map +1 -0
  426. package/dist/src/icons.generated/ArrowLeft.d.ts +16 -0
  427. package/dist/src/icons.generated/ArrowLeft.d.ts.map +1 -0
  428. package/dist/src/icons.generated/ArrowLowerLeft.d.ts +16 -0
  429. package/dist/src/icons.generated/ArrowLowerLeft.d.ts.map +1 -0
  430. package/dist/src/icons.generated/ArrowLowerRight.d.ts +16 -0
  431. package/dist/src/icons.generated/ArrowLowerRight.d.ts.map +1 -0
  432. package/dist/src/icons.generated/ArrowRight.d.ts +16 -0
  433. package/dist/src/icons.generated/ArrowRight.d.ts.map +1 -0
  434. package/dist/src/icons.generated/ArrowUnsorted.d.ts +16 -0
  435. package/dist/src/icons.generated/ArrowUnsorted.d.ts.map +1 -0
  436. package/dist/src/icons.generated/ArrowUp.d.ts +16 -0
  437. package/dist/src/icons.generated/ArrowUp.d.ts.map +1 -0
  438. package/dist/src/icons.generated/ArrowUpperLeft.d.ts +16 -0
  439. package/dist/src/icons.generated/ArrowUpperLeft.d.ts.map +1 -0
  440. package/dist/src/icons.generated/ArrowUpperRight.d.ts +16 -0
  441. package/dist/src/icons.generated/ArrowUpperRight.d.ts.map +1 -0
  442. package/dist/src/icons.generated/Bug.d.ts +16 -0
  443. package/dist/src/icons.generated/Bug.d.ts.map +1 -0
  444. package/dist/src/icons.generated/Calendar.d.ts +16 -0
  445. package/dist/src/icons.generated/Calendar.d.ts.map +1 -0
  446. package/dist/src/icons.generated/Call.d.ts +16 -0
  447. package/dist/src/icons.generated/Call.d.ts.map +1 -0
  448. package/dist/src/icons.generated/Chat.d.ts +16 -0
  449. package/dist/src/icons.generated/Chat.d.ts.map +1 -0
  450. package/dist/src/icons.generated/Check.d.ts +16 -0
  451. package/dist/src/icons.generated/Check.d.ts.map +1 -0
  452. package/dist/src/icons.generated/CheckCircleFilled.d.ts +16 -0
  453. package/dist/src/icons.generated/CheckCircleFilled.d.ts.map +1 -0
  454. package/dist/src/icons.generated/ChevronDown.d.ts +16 -0
  455. package/dist/src/icons.generated/ChevronDown.d.ts.map +1 -0
  456. package/dist/src/icons.generated/ChevronLeft.d.ts +16 -0
  457. package/dist/src/icons.generated/ChevronLeft.d.ts.map +1 -0
  458. package/dist/src/icons.generated/ChevronRight.d.ts +16 -0
  459. package/dist/src/icons.generated/ChevronRight.d.ts.map +1 -0
  460. package/dist/src/icons.generated/ChevronUp.d.ts +16 -0
  461. package/dist/src/icons.generated/ChevronUp.d.ts.map +1 -0
  462. package/dist/src/icons.generated/Clock.d.ts +16 -0
  463. package/dist/src/icons.generated/Clock.d.ts.map +1 -0
  464. package/dist/src/icons.generated/Close.d.ts +16 -0
  465. package/dist/src/icons.generated/Close.d.ts.map +1 -0
  466. package/dist/src/icons.generated/CloseCircleFilled.d.ts +16 -0
  467. package/dist/src/icons.generated/CloseCircleFilled.d.ts.map +1 -0
  468. package/dist/src/icons.generated/CollapseLeft.d.ts +16 -0
  469. package/dist/src/icons.generated/CollapseLeft.d.ts.map +1 -0
  470. package/dist/src/icons.generated/CollapseRight.d.ts +16 -0
  471. package/dist/src/icons.generated/CollapseRight.d.ts.map +1 -0
  472. package/dist/src/icons.generated/Copy.d.ts +16 -0
  473. package/dist/src/icons.generated/Copy.d.ts.map +1 -0
  474. package/dist/src/icons.generated/DangerDiamond.d.ts +16 -0
  475. package/dist/src/icons.generated/DangerDiamond.d.ts.map +1 -0
  476. package/dist/src/icons.generated/DangerDiamondFilled.d.ts +16 -0
  477. package/dist/src/icons.generated/DangerDiamondFilled.d.ts.map +1 -0
  478. package/dist/src/icons.generated/Delete.d.ts +16 -0
  479. package/dist/src/icons.generated/Delete.d.ts.map +1 -0
  480. package/dist/src/icons.generated/Deny.d.ts +16 -0
  481. package/dist/src/icons.generated/Deny.d.ts.map +1 -0
  482. package/dist/src/icons.generated/Devices.d.ts +16 -0
  483. package/dist/src/icons.generated/Devices.d.ts.map +1 -0
  484. package/dist/src/icons.generated/Directory.d.ts +16 -0
  485. package/dist/src/icons.generated/Directory.d.ts.map +1 -0
  486. package/dist/src/icons.generated/Documentation.d.ts +16 -0
  487. package/dist/src/icons.generated/Documentation.d.ts.map +1 -0
  488. package/dist/src/icons.generated/Download.d.ts +16 -0
  489. package/dist/src/icons.generated/Download.d.ts.map +1 -0
  490. package/dist/src/icons.generated/DragIndicator.d.ts +16 -0
  491. package/dist/src/icons.generated/DragIndicator.d.ts.map +1 -0
  492. package/dist/src/icons.generated/Edit.d.ts +16 -0
  493. package/dist/src/icons.generated/Edit.d.ts.map +1 -0
  494. package/dist/src/icons.generated/ExpandLeft.d.ts +16 -0
  495. package/dist/src/icons.generated/ExpandLeft.d.ts.map +1 -0
  496. package/dist/src/icons.generated/ExpandRight.d.ts +16 -0
  497. package/dist/src/icons.generated/ExpandRight.d.ts.map +1 -0
  498. package/dist/src/icons.generated/ExternalLink.d.ts +16 -0
  499. package/dist/src/icons.generated/ExternalLink.d.ts.map +1 -0
  500. package/dist/src/icons.generated/Filter.d.ts +16 -0
  501. package/dist/src/icons.generated/Filter.d.ts.map +1 -0
  502. package/dist/src/icons.generated/Folder.d.ts +16 -0
  503. package/dist/src/icons.generated/Folder.d.ts.map +1 -0
  504. package/dist/src/icons.generated/Globe.d.ts +16 -0
  505. package/dist/src/icons.generated/Globe.d.ts.map +1 -0
  506. package/dist/src/icons.generated/Grid.d.ts +16 -0
  507. package/dist/src/icons.generated/Grid.d.ts.map +1 -0
  508. package/dist/src/icons.generated/Group.d.ts +16 -0
  509. package/dist/src/icons.generated/Group.d.ts.map +1 -0
  510. package/dist/src/icons.generated/Hide.d.ts +16 -0
  511. package/dist/src/icons.generated/Hide.d.ts.map +1 -0
  512. package/dist/src/icons.generated/Home.d.ts +16 -0
  513. package/dist/src/icons.generated/Home.d.ts.map +1 -0
  514. package/dist/src/icons.generated/InformationCircle.d.ts +16 -0
  515. package/dist/src/icons.generated/InformationCircle.d.ts.map +1 -0
  516. package/dist/src/icons.generated/InformationCircleFilled.d.ts +16 -0
  517. package/dist/src/icons.generated/InformationCircleFilled.d.ts.map +1 -0
  518. package/dist/src/icons.generated/Link.d.ts +16 -0
  519. package/dist/src/icons.generated/Link.d.ts.map +1 -0
  520. package/dist/src/icons.generated/List.d.ts +16 -0
  521. package/dist/src/icons.generated/List.d.ts.map +1 -0
  522. package/dist/src/icons.generated/Lock.d.ts +16 -0
  523. package/dist/src/icons.generated/Lock.d.ts.map +1 -0
  524. package/dist/src/icons.generated/More.d.ts +16 -0
  525. package/dist/src/icons.generated/More.d.ts.map +1 -0
  526. package/dist/src/icons.generated/Notification.d.ts +16 -0
  527. package/dist/src/icons.generated/Notification.d.ts.map +1 -0
  528. package/dist/src/icons.generated/Pause.d.ts +16 -0
  529. package/dist/src/icons.generated/Pause.d.ts.map +1 -0
  530. package/dist/src/icons.generated/QuestionCircle.d.ts +16 -0
  531. package/dist/src/icons.generated/QuestionCircle.d.ts.map +1 -0
  532. package/dist/src/icons.generated/QuestionCircleFilled.d.ts +16 -0
  533. package/dist/src/icons.generated/QuestionCircleFilled.d.ts.map +1 -0
  534. package/dist/src/icons.generated/Refresh.d.ts +16 -0
  535. package/dist/src/icons.generated/Refresh.d.ts.map +1 -0
  536. package/dist/src/icons.generated/Reset.d.ts +16 -0
  537. package/dist/src/icons.generated/Reset.d.ts.map +1 -0
  538. package/dist/src/icons.generated/Resume.d.ts +16 -0
  539. package/dist/src/icons.generated/Resume.d.ts.map +1 -0
  540. package/dist/src/icons.generated/Search.d.ts +16 -0
  541. package/dist/src/icons.generated/Search.d.ts.map +1 -0
  542. package/dist/src/icons.generated/Server.d.ts +16 -0
  543. package/dist/src/icons.generated/Server.d.ts.map +1 -0
  544. package/dist/src/icons.generated/Settings.d.ts +16 -0
  545. package/dist/src/icons.generated/Settings.d.ts.map +1 -0
  546. package/dist/src/icons.generated/Show.d.ts +16 -0
  547. package/dist/src/icons.generated/Show.d.ts.map +1 -0
  548. package/dist/src/icons.generated/Subtract.d.ts +16 -0
  549. package/dist/src/icons.generated/Subtract.d.ts.map +1 -0
  550. package/dist/src/icons.generated/Sync.d.ts +16 -0
  551. package/dist/src/icons.generated/Sync.d.ts.map +1 -0
  552. package/dist/src/icons.generated/Unlock.d.ts +16 -0
  553. package/dist/src/icons.generated/Unlock.d.ts.map +1 -0
  554. package/dist/src/icons.generated/Upload.d.ts +16 -0
  555. package/dist/src/icons.generated/Upload.d.ts.map +1 -0
  556. package/dist/src/icons.generated/User.d.ts +16 -0
  557. package/dist/src/icons.generated/User.d.ts.map +1 -0
  558. package/dist/src/icons.generated/Video.d.ts +16 -0
  559. package/dist/src/icons.generated/Video.d.ts.map +1 -0
  560. package/dist/src/icons.generated/Warning.d.ts +16 -0
  561. package/dist/src/icons.generated/Warning.d.ts.map +1 -0
  562. package/dist/src/icons.generated/WarningFilled.d.ts +16 -0
  563. package/dist/src/icons.generated/WarningFilled.d.ts.map +1 -0
  564. package/dist/src/icons.generated/index.d.ts +85 -0
  565. package/dist/src/icons.generated/index.d.ts.map +1 -0
  566. package/dist/src/index.d.ts +36 -21
  567. package/dist/src/index.d.ts.map +1 -1
  568. package/dist/src/labs/DatePicker.d.ts +19 -0
  569. package/dist/src/labs/DatePicker.d.ts.map +1 -0
  570. package/dist/src/labs/DatePicker.types.d.ts +19 -0
  571. package/dist/src/labs/DatePicker.types.d.ts.map +1 -0
  572. package/dist/src/labs/PaginatedTable.d.ts +35 -0
  573. package/dist/src/labs/PaginatedTable.d.ts.map +1 -0
  574. package/dist/src/labs/StaticTable.d.ts +29 -0
  575. package/dist/src/labs/StaticTable.d.ts.map +1 -0
  576. package/dist/src/labs/datePickerTheme.d.ts +14 -0
  577. package/dist/src/labs/datePickerTheme.d.ts.map +1 -0
  578. package/dist/src/labs/index.d.ts +21 -0
  579. package/dist/src/labs/index.d.ts.map +1 -0
  580. package/dist/src/labs/materialReactTableTypes.d.ts +15 -0
  581. package/dist/src/labs/materialReactTableTypes.d.ts.map +1 -0
  582. package/dist/src/properties/ts/odyssey-react-mui.d.ts +16 -0
  583. package/dist/src/properties/ts/odyssey-react-mui.d.ts.map +1 -0
  584. package/dist/src/properties/ts/odyssey-react-mui_cs.d.ts +16 -0
  585. package/dist/src/properties/ts/odyssey-react-mui_cs.d.ts.map +1 -0
  586. package/dist/src/properties/ts/odyssey-react-mui_da.d.ts +16 -0
  587. package/dist/src/properties/ts/odyssey-react-mui_da.d.ts.map +1 -0
  588. package/dist/src/properties/ts/odyssey-react-mui_de.d.ts +16 -0
  589. package/dist/src/properties/ts/odyssey-react-mui_de.d.ts.map +1 -0
  590. package/dist/src/properties/ts/odyssey-react-mui_el.d.ts +16 -0
  591. package/dist/src/properties/ts/odyssey-react-mui_el.d.ts.map +1 -0
  592. package/dist/src/properties/ts/odyssey-react-mui_es.d.ts +16 -0
  593. package/dist/src/properties/ts/odyssey-react-mui_es.d.ts.map +1 -0
  594. package/dist/src/properties/ts/odyssey-react-mui_fi.d.ts +16 -0
  595. package/dist/src/properties/ts/odyssey-react-mui_fi.d.ts.map +1 -0
  596. package/dist/src/properties/ts/odyssey-react-mui_fr.d.ts +16 -0
  597. package/dist/src/properties/ts/odyssey-react-mui_fr.d.ts.map +1 -0
  598. package/dist/src/properties/ts/odyssey-react-mui_hu.d.ts +16 -0
  599. package/dist/src/properties/ts/odyssey-react-mui_hu.d.ts.map +1 -0
  600. package/dist/src/properties/ts/odyssey-react-mui_id.d.ts +16 -0
  601. package/dist/src/properties/ts/odyssey-react-mui_id.d.ts.map +1 -0
  602. package/dist/src/properties/ts/odyssey-react-mui_it.d.ts +16 -0
  603. package/dist/src/properties/ts/odyssey-react-mui_it.d.ts.map +1 -0
  604. package/dist/src/properties/ts/odyssey-react-mui_ja.d.ts +16 -0
  605. package/dist/src/properties/ts/odyssey-react-mui_ja.d.ts.map +1 -0
  606. package/dist/src/properties/ts/odyssey-react-mui_ko.d.ts +16 -0
  607. package/dist/src/properties/ts/odyssey-react-mui_ko.d.ts.map +1 -0
  608. package/dist/src/properties/ts/odyssey-react-mui_ms.d.ts +16 -0
  609. package/dist/src/properties/ts/odyssey-react-mui_ms.d.ts.map +1 -0
  610. package/dist/src/properties/ts/odyssey-react-mui_nb.d.ts +16 -0
  611. package/dist/src/properties/ts/odyssey-react-mui_nb.d.ts.map +1 -0
  612. package/dist/src/properties/ts/odyssey-react-mui_nl_NL.d.ts +16 -0
  613. package/dist/src/properties/ts/odyssey-react-mui_nl_NL.d.ts.map +1 -0
  614. package/dist/src/properties/ts/odyssey-react-mui_ok_PL.d.ts +11 -0
  615. package/dist/src/properties/ts/odyssey-react-mui_ok_PL.d.ts.map +1 -0
  616. package/dist/src/properties/ts/odyssey-react-mui_ok_SK.d.ts +11 -0
  617. package/dist/src/properties/ts/odyssey-react-mui_ok_SK.d.ts.map +1 -0
  618. package/dist/src/properties/ts/odyssey-react-mui_pl.d.ts +16 -0
  619. package/dist/src/properties/ts/odyssey-react-mui_pl.d.ts.map +1 -0
  620. package/dist/src/properties/ts/odyssey-react-mui_pt_BR.d.ts +16 -0
  621. package/dist/src/properties/ts/odyssey-react-mui_pt_BR.d.ts.map +1 -0
  622. package/dist/src/properties/ts/odyssey-react-mui_ro.d.ts +16 -0
  623. package/dist/src/properties/ts/odyssey-react-mui_ro.d.ts.map +1 -0
  624. package/dist/src/properties/ts/odyssey-react-mui_ru.d.ts +16 -0
  625. package/dist/src/properties/ts/odyssey-react-mui_ru.d.ts.map +1 -0
  626. package/dist/src/properties/ts/odyssey-react-mui_sv.d.ts +16 -0
  627. package/dist/src/properties/ts/odyssey-react-mui_sv.d.ts.map +1 -0
  628. package/dist/src/properties/ts/odyssey-react-mui_th.d.ts +16 -0
  629. package/dist/src/properties/ts/odyssey-react-mui_th.d.ts.map +1 -0
  630. package/dist/src/properties/ts/odyssey-react-mui_tr.d.ts +16 -0
  631. package/dist/src/properties/ts/odyssey-react-mui_tr.d.ts.map +1 -0
  632. package/dist/src/properties/ts/odyssey-react-mui_uk.d.ts +16 -0
  633. package/dist/src/properties/ts/odyssey-react-mui_uk.d.ts.map +1 -0
  634. package/dist/src/properties/ts/odyssey-react-mui_vi.d.ts +16 -0
  635. package/dist/src/properties/ts/odyssey-react-mui_vi.d.ts.map +1 -0
  636. package/dist/src/properties/ts/odyssey-react-mui_zh_CN.d.ts +16 -0
  637. package/dist/src/properties/ts/odyssey-react-mui_zh_CN.d.ts.map +1 -0
  638. package/dist/src/properties/ts/odyssey-react-mui_zh_TW.d.ts +16 -0
  639. package/dist/src/properties/ts/odyssey-react-mui_zh_TW.d.ts.map +1 -0
  640. package/dist/src/theme/components.d.ts +2 -1
  641. package/dist/src/theme/components.d.ts.map +1 -1
  642. package/dist/src/theme/components.types.d.ts +4 -2
  643. package/dist/src/theme/components.types.d.ts.map +1 -1
  644. package/dist/src/theme/index.d.ts +1 -2
  645. package/dist/src/theme/index.d.ts.map +1 -1
  646. package/dist/src/theme/mixins.d.ts +2 -1
  647. package/dist/src/theme/mixins.d.ts.map +1 -1
  648. package/dist/src/theme/palette.d.ts +2 -1
  649. package/dist/src/theme/palette.d.ts.map +1 -1
  650. package/dist/src/theme/shape.d.ts +2 -1
  651. package/dist/src/theme/shape.d.ts.map +1 -1
  652. package/dist/src/theme/spacing.d.ts +2 -1
  653. package/dist/src/theme/spacing.d.ts.map +1 -1
  654. package/dist/src/theme/theme.d.ts +4 -2
  655. package/dist/src/theme/theme.d.ts.map +1 -1
  656. package/dist/src/theme/typography.d.ts +2 -1
  657. package/dist/src/theme/typography.d.ts.map +1 -1
  658. package/dist/src/theme/typography.types.d.ts +2 -2
  659. package/dist/src/theme/typography.types.d.ts.map +1 -1
  660. package/dist/theme/components.js +1673 -1738
  661. package/dist/theme/components.js.map +1 -1
  662. package/dist/theme/components.types.js +1 -0
  663. package/dist/theme/components.types.js.map +1 -1
  664. package/dist/theme/index.js +1 -2
  665. package/dist/theme/index.js.map +1 -1
  666. package/dist/theme/mixins.js +8 -6
  667. package/dist/theme/mixins.js.map +1 -1
  668. package/dist/theme/mixins.types.js +1 -0
  669. package/dist/theme/mixins.types.js.map +1 -1
  670. package/dist/theme/palette.js +89 -87
  671. package/dist/theme/palette.js.map +1 -1
  672. package/dist/theme/palette.types.js +1 -0
  673. package/dist/theme/palette.types.js.map +1 -1
  674. package/dist/theme/shape.js +6 -4
  675. package/dist/theme/shape.js.map +1 -1
  676. package/dist/theme/spacing.js +4 -2
  677. package/dist/theme/spacing.js.map +1 -1
  678. package/dist/theme/theme.js +8 -9
  679. package/dist/theme/theme.js.map +1 -1
  680. package/dist/theme/typography.js +115 -83
  681. package/dist/theme/typography.js.map +1 -1
  682. package/dist/theme/typography.types.js +1 -0
  683. package/dist/theme/typography.types.js.map +1 -1
  684. package/dist/tsconfig.production.tsbuildinfo +1 -1
  685. package/dist/useUniqueAlphabeticalId.js +1 -0
  686. package/dist/useUniqueAlphabeticalId.js.map +1 -1
  687. package/dist/useUniqueId.js +1 -0
  688. package/dist/useUniqueId.js.map +1 -1
  689. package/i18n.config.json +7 -0
  690. package/package.json +28 -8
  691. package/scripts/generateIconsIndex.ts +49 -0
  692. package/scripts/properties-to-ts.js +96 -0
  693. package/src/@types/i18next.d.ts +22 -0
  694. package/src/Autocomplete.tsx +36 -1
  695. package/src/Banner.tsx +30 -15
  696. package/src/Box.tsx +28 -0
  697. package/src/Button.tsx +100 -19
  698. package/src/Callout.tsx +62 -0
  699. package/src/Checkbox.tsx +102 -26
  700. package/src/CheckboxGroup.tsx +24 -2
  701. package/src/CircularProgress.tsx +13 -1
  702. package/src/Dialog.tsx +44 -16
  703. package/src/Field.tsx +32 -9
  704. package/src/FieldError.tsx +8 -2
  705. package/src/FieldHint.tsx +2 -1
  706. package/src/FieldLabel.tsx +8 -6
  707. package/src/Fieldset.tsx +106 -0
  708. package/src/FieldsetContext.tsx +23 -0
  709. package/src/Form.tsx +152 -0
  710. package/src/Link.tsx +49 -29
  711. package/src/MenuButton.tsx +89 -39
  712. package/src/MenuContext.ts +25 -0
  713. package/src/MenuItem.tsx +68 -23
  714. package/src/MuiPropsChild.tsx +1 -0
  715. package/src/MuiPropsContext.ts +3 -1
  716. package/src/NativeSelect.tsx +146 -0
  717. package/src/NullElement.tsx +13 -0
  718. package/src/OdysseyCacheProvider.test.tsx +1 -1
  719. package/src/OdysseyCacheProvider.tsx +13 -7
  720. package/src/OdysseyDesignTokensContext.tsx +19 -0
  721. package/src/OdysseyI18n.ts +105 -0
  722. package/src/OdysseyProvider.tsx +60 -0
  723. package/src/OdysseyThemeProvider.tsx +33 -10
  724. package/src/OdysseyTranslationProvider.test.tsx +63 -0
  725. package/src/OdysseyTranslationProvider.tsx +65 -0
  726. package/src/OdysseyTranslationProvider.types.ts +44 -0
  727. package/src/PasswordField.tsx +9 -7
  728. package/src/Radio.tsx +23 -7
  729. package/src/RadioGroup.tsx +8 -7
  730. package/src/ScreenReaderText.tsx +6 -2
  731. package/src/SearchField.tsx +55 -5
  732. package/src/Select.tsx +264 -0
  733. package/src/Status.tsx +26 -9
  734. package/src/SvgIcon.ts +23 -0
  735. package/src/Tabs.tsx +103 -0
  736. package/src/Tag.tsx +34 -14
  737. package/src/TagList.tsx +12 -2
  738. package/src/TextField.tsx +12 -10
  739. package/src/Toast.tsx +82 -77
  740. package/src/ToastStack.tsx +12 -2
  741. package/src/Tooltip.tsx +15 -3
  742. package/src/Typography.tsx +357 -0
  743. package/src/icons.generated/Add.tsx +41 -0
  744. package/src/icons.generated/AddCircle.tsx +43 -0
  745. package/src/icons.generated/Apps.tsx +43 -0
  746. package/src/icons.generated/ArrowDown.tsx +43 -0
  747. package/src/icons.generated/ArrowLeft.tsx +43 -0
  748. package/src/icons.generated/ArrowLowerLeft.tsx +44 -0
  749. package/src/icons.generated/ArrowLowerRight.tsx +44 -0
  750. package/src/icons.generated/ArrowRight.tsx +43 -0
  751. package/src/icons.generated/ArrowUnsorted.tsx +44 -0
  752. package/src/icons.generated/ArrowUp.tsx +43 -0
  753. package/src/icons.generated/ArrowUpperLeft.tsx +44 -0
  754. package/src/icons.generated/ArrowUpperRight.tsx +44 -0
  755. package/src/icons.generated/Bug.tsx +41 -0
  756. package/src/icons.generated/Calendar.tsx +43 -0
  757. package/src/icons.generated/Call.tsx +43 -0
  758. package/src/icons.generated/Chat.tsx +43 -0
  759. package/src/icons.generated/Check.tsx +43 -0
  760. package/src/icons.generated/CheckCircleFilled.tsx +44 -0
  761. package/src/icons.generated/ChevronDown.tsx +43 -0
  762. package/src/icons.generated/ChevronLeft.tsx +43 -0
  763. package/src/icons.generated/ChevronRight.tsx +44 -0
  764. package/src/icons.generated/ChevronUp.tsx +43 -0
  765. package/src/icons.generated/Clock.tsx +43 -0
  766. package/src/icons.generated/Close.tsx +43 -0
  767. package/src/icons.generated/CloseCircleFilled.tsx +44 -0
  768. package/src/icons.generated/CollapseLeft.tsx +44 -0
  769. package/src/icons.generated/CollapseRight.tsx +44 -0
  770. package/src/icons.generated/Copy.tsx +43 -0
  771. package/src/icons.generated/DangerDiamond.tsx +44 -0
  772. package/src/icons.generated/DangerDiamondFilled.tsx +44 -0
  773. package/src/icons.generated/Delete.tsx +43 -0
  774. package/src/icons.generated/Deny.tsx +43 -0
  775. package/src/icons.generated/Devices.tsx +43 -0
  776. package/src/icons.generated/Directory.tsx +43 -0
  777. package/src/icons.generated/Documentation.tsx +44 -0
  778. package/src/icons.generated/Download.tsx +43 -0
  779. package/src/icons.generated/DragIndicator.tsx +44 -0
  780. package/src/icons.generated/Edit.tsx +43 -0
  781. package/src/icons.generated/ExpandLeft.tsx +43 -0
  782. package/src/icons.generated/ExpandRight.tsx +43 -0
  783. package/src/icons.generated/ExternalLink.tsx +44 -0
  784. package/src/icons.generated/Filter.tsx +43 -0
  785. package/src/icons.generated/Folder.tsx +43 -0
  786. package/src/icons.generated/Globe.tsx +43 -0
  787. package/src/icons.generated/Grid.tsx +46 -0
  788. package/src/icons.generated/Group.tsx +43 -0
  789. package/src/icons.generated/Hide.tsx +43 -0
  790. package/src/icons.generated/Home.tsx +43 -0
  791. package/src/icons.generated/InformationCircle.tsx +44 -0
  792. package/src/icons.generated/InformationCircleFilled.tsx +44 -0
  793. package/src/icons.generated/Link.tsx +43 -0
  794. package/src/icons.generated/List.tsx +43 -0
  795. package/src/icons.generated/Lock.tsx +43 -0
  796. package/src/icons.generated/More.tsx +43 -0
  797. package/src/icons.generated/Notification.tsx +44 -0
  798. package/src/icons.generated/Pause.tsx +43 -0
  799. package/src/icons.generated/QuestionCircle.tsx +44 -0
  800. package/src/icons.generated/QuestionCircleFilled.tsx +44 -0
  801. package/src/icons.generated/Refresh.tsx +43 -0
  802. package/src/icons.generated/Reset.tsx +43 -0
  803. package/src/icons.generated/Resume.tsx +43 -0
  804. package/src/icons.generated/Search.tsx +43 -0
  805. package/src/icons.generated/Server.tsx +43 -0
  806. package/src/icons.generated/Settings.tsx +43 -0
  807. package/src/icons.generated/Show.tsx +43 -0
  808. package/src/icons.generated/Subtract.tsx +43 -0
  809. package/src/icons.generated/Sync.tsx +43 -0
  810. package/src/icons.generated/Unlock.tsx +43 -0
  811. package/src/icons.generated/Upload.tsx +43 -0
  812. package/src/icons.generated/User.tsx +43 -0
  813. package/src/icons.generated/Video.tsx +43 -0
  814. package/src/icons.generated/Warning.tsx +43 -0
  815. package/src/icons.generated/WarningFilled.tsx +44 -0
  816. package/src/icons.generated/index.ts +87 -0
  817. package/src/index.ts +28 -74
  818. package/src/labs/DatePicker.tsx +48 -0
  819. package/src/labs/DatePicker.types.ts +24 -0
  820. package/src/labs/PaginatedTable.tsx +272 -0
  821. package/src/labs/README.md +44 -0
  822. package/src/labs/StaticTable.tsx +122 -0
  823. package/src/labs/datePickerTheme.tsx +341 -0
  824. package/src/labs/index.ts +24 -0
  825. package/src/labs/materialReactTableTypes.ts +19 -0
  826. package/src/properties/odyssey-react-mui.properties +13 -0
  827. package/src/properties/translations/odyssey-react-mui_cs.properties +14 -0
  828. package/src/properties/translations/odyssey-react-mui_da.properties +14 -0
  829. package/src/properties/translations/odyssey-react-mui_de.properties +14 -0
  830. package/src/properties/translations/odyssey-react-mui_el.properties +14 -0
  831. package/src/properties/translations/odyssey-react-mui_es.properties +14 -0
  832. package/src/properties/translations/odyssey-react-mui_fi.properties +14 -0
  833. package/src/properties/translations/odyssey-react-mui_fr.properties +14 -0
  834. package/src/properties/translations/odyssey-react-mui_hu.properties +14 -0
  835. package/src/properties/translations/odyssey-react-mui_id.properties +14 -0
  836. package/src/properties/translations/odyssey-react-mui_it.properties +14 -0
  837. package/src/properties/translations/odyssey-react-mui_ja.properties +14 -0
  838. package/src/properties/translations/odyssey-react-mui_ko.properties +14 -0
  839. package/src/properties/translations/odyssey-react-mui_ms.properties +14 -0
  840. package/src/properties/translations/odyssey-react-mui_nb.properties +14 -0
  841. package/src/properties/translations/odyssey-react-mui_nl_NL.properties +14 -0
  842. package/src/properties/translations/odyssey-react-mui_ok_PL.properties +8 -0
  843. package/src/properties/translations/odyssey-react-mui_ok_SK.properties +8 -0
  844. package/src/properties/translations/odyssey-react-mui_pl.properties +14 -0
  845. package/src/properties/translations/odyssey-react-mui_pt_BR.properties +14 -0
  846. package/src/properties/translations/odyssey-react-mui_ro.properties +14 -0
  847. package/src/properties/translations/odyssey-react-mui_ru.properties +14 -0
  848. package/src/properties/translations/odyssey-react-mui_sv.properties +14 -0
  849. package/src/properties/translations/odyssey-react-mui_th.properties +14 -0
  850. package/src/properties/translations/odyssey-react-mui_tr.properties +14 -0
  851. package/src/properties/translations/odyssey-react-mui_uk.properties +14 -0
  852. package/src/properties/translations/odyssey-react-mui_vi.properties +14 -0
  853. package/src/properties/translations/odyssey-react-mui_zh_CN.properties +14 -0
  854. package/src/properties/translations/odyssey-react-mui_zh_TW.properties +14 -0
  855. package/src/properties/ts/odyssey-react-mui.ts +1 -0
  856. package/src/properties/ts/odyssey-react-mui_cs.ts +1 -0
  857. package/src/properties/ts/odyssey-react-mui_da.ts +1 -0
  858. package/src/properties/ts/odyssey-react-mui_de.ts +1 -0
  859. package/src/properties/ts/odyssey-react-mui_el.ts +1 -0
  860. package/src/properties/ts/odyssey-react-mui_es.ts +1 -0
  861. package/src/properties/ts/odyssey-react-mui_fi.ts +1 -0
  862. package/src/properties/ts/odyssey-react-mui_fr.ts +1 -0
  863. package/src/properties/ts/odyssey-react-mui_hu.ts +1 -0
  864. package/src/properties/ts/odyssey-react-mui_id.ts +1 -0
  865. package/src/properties/ts/odyssey-react-mui_it.ts +1 -0
  866. package/src/properties/ts/odyssey-react-mui_ja.ts +1 -0
  867. package/src/properties/ts/odyssey-react-mui_ko.ts +1 -0
  868. package/src/properties/ts/odyssey-react-mui_ms.ts +1 -0
  869. package/src/properties/ts/odyssey-react-mui_nb.ts +1 -0
  870. package/src/properties/ts/odyssey-react-mui_nl_NL.ts +1 -0
  871. package/src/properties/ts/odyssey-react-mui_ok_PL.ts +1 -0
  872. package/src/properties/ts/odyssey-react-mui_ok_SK.ts +1 -0
  873. package/src/properties/ts/odyssey-react-mui_pl.ts +1 -0
  874. package/src/properties/ts/odyssey-react-mui_pt_BR.ts +1 -0
  875. package/src/properties/ts/odyssey-react-mui_ro.ts +1 -0
  876. package/src/properties/ts/odyssey-react-mui_ru.ts +1 -0
  877. package/src/properties/ts/odyssey-react-mui_sv.ts +1 -0
  878. package/src/properties/ts/odyssey-react-mui_th.ts +1 -0
  879. package/src/properties/ts/odyssey-react-mui_tr.ts +1 -0
  880. package/src/properties/ts/odyssey-react-mui_uk.ts +1 -0
  881. package/src/properties/ts/odyssey-react-mui_vi.ts +1 -0
  882. package/src/properties/ts/odyssey-react-mui_zh_CN.ts +1 -0
  883. package/src/properties/ts/odyssey-react-mui_zh_TW.ts +1 -0
  884. package/src/theme/components.tsx +1919 -1727
  885. package/src/theme/components.types.ts +4 -2
  886. package/src/theme/index.ts +1 -2
  887. package/src/theme/mixins.ts +9 -6
  888. package/src/theme/palette.ts +94 -89
  889. package/src/theme/shape.ts +11 -8
  890. package/src/theme/spacing.ts +18 -13
  891. package/src/theme/theme.ts +13 -11
  892. package/src/theme/typography.ts +120 -83
  893. package/src/theme/typography.types.ts +2 -2
  894. package/tsconfig.json +3 -0
  895. package/dist/Icon.js +0 -31
  896. package/dist/Icon.js.map +0 -1
  897. package/dist/Infobox.js +0 -38
  898. package/dist/Infobox.js.map +0 -1
  899. package/dist/ThemeProvider.js +0 -30
  900. package/dist/ThemeProvider.js.map +0 -1
  901. package/dist/a11yCheck.js +0 -26
  902. package/dist/a11yCheck.js.map +0 -1
  903. package/dist/iconDictionary/Add.js +0 -34
  904. package/dist/iconDictionary/Add.js.map +0 -1
  905. package/dist/iconDictionary/AddCircle.js +0 -34
  906. package/dist/iconDictionary/AddCircle.js.map +0 -1
  907. package/dist/iconDictionary/AlertCircle.js +0 -34
  908. package/dist/iconDictionary/AlertCircle.js.map +0 -1
  909. package/dist/iconDictionary/AlertCircleFilled.js +0 -34
  910. package/dist/iconDictionary/AlertCircleFilled.js.map +0 -1
  911. package/dist/iconDictionary/AlertTriangleFilled.js +0 -34
  912. package/dist/iconDictionary/AlertTriangleFilled.js.map +0 -1
  913. package/dist/iconDictionary/Anchor.js +0 -36
  914. package/dist/iconDictionary/Anchor.js.map +0 -1
  915. package/dist/iconDictionary/ArrowDown.js +0 -34
  916. package/dist/iconDictionary/ArrowDown.js.map +0 -1
  917. package/dist/iconDictionary/ArrowLeft.js +0 -34
  918. package/dist/iconDictionary/ArrowLeft.js.map +0 -1
  919. package/dist/iconDictionary/ArrowRight.js +0 -34
  920. package/dist/iconDictionary/ArrowRight.js.map +0 -1
  921. package/dist/iconDictionary/ArrowUp.js +0 -34
  922. package/dist/iconDictionary/ArrowUp.js.map +0 -1
  923. package/dist/iconDictionary/ArrowUpDown.js +0 -34
  924. package/dist/iconDictionary/ArrowUpDown.js.map +0 -1
  925. package/dist/iconDictionary/Calendar.js +0 -34
  926. package/dist/iconDictionary/Calendar.js.map +0 -1
  927. package/dist/iconDictionary/Check.js +0 -34
  928. package/dist/iconDictionary/Check.js.map +0 -1
  929. package/dist/iconDictionary/CheckCircleFilled.js +0 -34
  930. package/dist/iconDictionary/CheckCircleFilled.js.map +0 -1
  931. package/dist/iconDictionary/ChevronDown.js +0 -34
  932. package/dist/iconDictionary/ChevronDown.js.map +0 -1
  933. package/dist/iconDictionary/ChevronUp.js +0 -34
  934. package/dist/iconDictionary/ChevronUp.js.map +0 -1
  935. package/dist/iconDictionary/Close.js +0 -34
  936. package/dist/iconDictionary/Close.js.map +0 -1
  937. package/dist/iconDictionary/CloseCircleFilled.js +0 -34
  938. package/dist/iconDictionary/CloseCircleFilled.js.map +0 -1
  939. package/dist/iconDictionary/Copy.js +0 -34
  940. package/dist/iconDictionary/Copy.js.map +0 -1
  941. package/dist/iconDictionary/Delete.js +0 -34
  942. package/dist/iconDictionary/Delete.js.map +0 -1
  943. package/dist/iconDictionary/Download.js +0 -34
  944. package/dist/iconDictionary/Download.js.map +0 -1
  945. package/dist/iconDictionary/DragHandle.js +0 -34
  946. package/dist/iconDictionary/DragHandle.js.map +0 -1
  947. package/dist/iconDictionary/Edit.js +0 -34
  948. package/dist/iconDictionary/Edit.js.map +0 -1
  949. package/dist/iconDictionary/ExternalLink.js +0 -34
  950. package/dist/iconDictionary/ExternalLink.js.map +0 -1
  951. package/dist/iconDictionary/Eye.js +0 -34
  952. package/dist/iconDictionary/Eye.js.map +0 -1
  953. package/dist/iconDictionary/EyeOff.js +0 -34
  954. package/dist/iconDictionary/EyeOff.js.map +0 -1
  955. package/dist/iconDictionary/Filter.js +0 -34
  956. package/dist/iconDictionary/Filter.js.map +0 -1
  957. package/dist/iconDictionary/Globe.js +0 -34
  958. package/dist/iconDictionary/Globe.js.map +0 -1
  959. package/dist/iconDictionary/Home.js +0 -34
  960. package/dist/iconDictionary/Home.js.map +0 -1
  961. package/dist/iconDictionary/InformationCircle.js +0 -34
  962. package/dist/iconDictionary/InformationCircle.js.map +0 -1
  963. package/dist/iconDictionary/InformationCircleFilled.js +0 -34
  964. package/dist/iconDictionary/InformationCircleFilled.js.map +0 -1
  965. package/dist/iconDictionary/Notification.js +0 -34
  966. package/dist/iconDictionary/Notification.js.map +0 -1
  967. package/dist/iconDictionary/OverflowVertical.js +0 -34
  968. package/dist/iconDictionary/OverflowVertical.js.map +0 -1
  969. package/dist/iconDictionary/QuestionCircle.js +0 -34
  970. package/dist/iconDictionary/QuestionCircle.js.map +0 -1
  971. package/dist/iconDictionary/QuestionCircleFilled.js +0 -34
  972. package/dist/iconDictionary/QuestionCircleFilled.js.map +0 -1
  973. package/dist/iconDictionary/Search.js +0 -34
  974. package/dist/iconDictionary/Search.js.map +0 -1
  975. package/dist/iconDictionary/Settings.js +0 -32
  976. package/dist/iconDictionary/Settings.js.map +0 -1
  977. package/dist/iconDictionary/Subtract.js +0 -34
  978. package/dist/iconDictionary/Subtract.js.map +0 -1
  979. package/dist/iconDictionary/SvgIcon.js +0 -14
  980. package/dist/iconDictionary/SvgIcon.js.map +0 -1
  981. package/dist/iconDictionary/User.js +0 -34
  982. package/dist/iconDictionary/User.js.map +0 -1
  983. package/dist/iconDictionary/UserGroup.js +0 -34
  984. package/dist/iconDictionary/UserGroup.js.map +0 -1
  985. package/dist/iconDictionary/index.js +0 -134
  986. package/dist/iconDictionary/index.js.map +0 -1
  987. package/dist/iconDictionary/types.js +0 -2
  988. package/dist/iconDictionary/types.js.map +0 -1
  989. package/dist/src/Icon.d.ts +0 -27
  990. package/dist/src/Icon.d.ts.map +0 -1
  991. package/dist/src/Infobox.d.ts +0 -36
  992. package/dist/src/Infobox.d.ts.map +0 -1
  993. package/dist/src/ThemeProvider.d.ts +0 -17
  994. package/dist/src/ThemeProvider.d.ts.map +0 -1
  995. package/dist/src/a11yCheck.d.ts +0 -14
  996. package/dist/src/a11yCheck.d.ts.map +0 -1
  997. package/dist/src/iconDictionary/Add.d.ts +0 -16
  998. package/dist/src/iconDictionary/Add.d.ts.map +0 -1
  999. package/dist/src/iconDictionary/AddCircle.d.ts +0 -16
  1000. package/dist/src/iconDictionary/AddCircle.d.ts.map +0 -1
  1001. package/dist/src/iconDictionary/AlertCircle.d.ts +0 -16
  1002. package/dist/src/iconDictionary/AlertCircle.d.ts.map +0 -1
  1003. package/dist/src/iconDictionary/AlertCircleFilled.d.ts +0 -16
  1004. package/dist/src/iconDictionary/AlertCircleFilled.d.ts.map +0 -1
  1005. package/dist/src/iconDictionary/AlertTriangleFilled.d.ts +0 -16
  1006. package/dist/src/iconDictionary/AlertTriangleFilled.d.ts.map +0 -1
  1007. package/dist/src/iconDictionary/Anchor.d.ts +0 -16
  1008. package/dist/src/iconDictionary/Anchor.d.ts.map +0 -1
  1009. package/dist/src/iconDictionary/ArrowDown.d.ts +0 -16
  1010. package/dist/src/iconDictionary/ArrowDown.d.ts.map +0 -1
  1011. package/dist/src/iconDictionary/ArrowLeft.d.ts +0 -16
  1012. package/dist/src/iconDictionary/ArrowLeft.d.ts.map +0 -1
  1013. package/dist/src/iconDictionary/ArrowRight.d.ts +0 -16
  1014. package/dist/src/iconDictionary/ArrowRight.d.ts.map +0 -1
  1015. package/dist/src/iconDictionary/ArrowUp.d.ts +0 -16
  1016. package/dist/src/iconDictionary/ArrowUp.d.ts.map +0 -1
  1017. package/dist/src/iconDictionary/ArrowUpDown.d.ts +0 -16
  1018. package/dist/src/iconDictionary/ArrowUpDown.d.ts.map +0 -1
  1019. package/dist/src/iconDictionary/Calendar.d.ts +0 -16
  1020. package/dist/src/iconDictionary/Calendar.d.ts.map +0 -1
  1021. package/dist/src/iconDictionary/Check.d.ts +0 -16
  1022. package/dist/src/iconDictionary/Check.d.ts.map +0 -1
  1023. package/dist/src/iconDictionary/CheckCircleFilled.d.ts +0 -16
  1024. package/dist/src/iconDictionary/CheckCircleFilled.d.ts.map +0 -1
  1025. package/dist/src/iconDictionary/ChevronDown.d.ts +0 -16
  1026. package/dist/src/iconDictionary/ChevronDown.d.ts.map +0 -1
  1027. package/dist/src/iconDictionary/ChevronUp.d.ts +0 -16
  1028. package/dist/src/iconDictionary/ChevronUp.d.ts.map +0 -1
  1029. package/dist/src/iconDictionary/Close.d.ts +0 -16
  1030. package/dist/src/iconDictionary/Close.d.ts.map +0 -1
  1031. package/dist/src/iconDictionary/CloseCircleFilled.d.ts +0 -16
  1032. package/dist/src/iconDictionary/CloseCircleFilled.d.ts.map +0 -1
  1033. package/dist/src/iconDictionary/Copy.d.ts +0 -16
  1034. package/dist/src/iconDictionary/Copy.d.ts.map +0 -1
  1035. package/dist/src/iconDictionary/Delete.d.ts +0 -16
  1036. package/dist/src/iconDictionary/Delete.d.ts.map +0 -1
  1037. package/dist/src/iconDictionary/Download.d.ts +0 -16
  1038. package/dist/src/iconDictionary/Download.d.ts.map +0 -1
  1039. package/dist/src/iconDictionary/DragHandle.d.ts +0 -16
  1040. package/dist/src/iconDictionary/DragHandle.d.ts.map +0 -1
  1041. package/dist/src/iconDictionary/Edit.d.ts +0 -16
  1042. package/dist/src/iconDictionary/Edit.d.ts.map +0 -1
  1043. package/dist/src/iconDictionary/ExternalLink.d.ts +0 -16
  1044. package/dist/src/iconDictionary/ExternalLink.d.ts.map +0 -1
  1045. package/dist/src/iconDictionary/Eye.d.ts +0 -16
  1046. package/dist/src/iconDictionary/Eye.d.ts.map +0 -1
  1047. package/dist/src/iconDictionary/EyeOff.d.ts +0 -16
  1048. package/dist/src/iconDictionary/EyeOff.d.ts.map +0 -1
  1049. package/dist/src/iconDictionary/Filter.d.ts +0 -16
  1050. package/dist/src/iconDictionary/Filter.d.ts.map +0 -1
  1051. package/dist/src/iconDictionary/Globe.d.ts +0 -16
  1052. package/dist/src/iconDictionary/Globe.d.ts.map +0 -1
  1053. package/dist/src/iconDictionary/Home.d.ts +0 -16
  1054. package/dist/src/iconDictionary/Home.d.ts.map +0 -1
  1055. package/dist/src/iconDictionary/InformationCircle.d.ts +0 -16
  1056. package/dist/src/iconDictionary/InformationCircle.d.ts.map +0 -1
  1057. package/dist/src/iconDictionary/InformationCircleFilled.d.ts +0 -16
  1058. package/dist/src/iconDictionary/InformationCircleFilled.d.ts.map +0 -1
  1059. package/dist/src/iconDictionary/Notification.d.ts +0 -16
  1060. package/dist/src/iconDictionary/Notification.d.ts.map +0 -1
  1061. package/dist/src/iconDictionary/OverflowVertical.d.ts +0 -16
  1062. package/dist/src/iconDictionary/OverflowVertical.d.ts.map +0 -1
  1063. package/dist/src/iconDictionary/QuestionCircle.d.ts +0 -16
  1064. package/dist/src/iconDictionary/QuestionCircle.d.ts.map +0 -1
  1065. package/dist/src/iconDictionary/QuestionCircleFilled.d.ts +0 -16
  1066. package/dist/src/iconDictionary/QuestionCircleFilled.d.ts.map +0 -1
  1067. package/dist/src/iconDictionary/Search.d.ts +0 -16
  1068. package/dist/src/iconDictionary/Search.d.ts.map +0 -1
  1069. package/dist/src/iconDictionary/Settings.d.ts +0 -16
  1070. package/dist/src/iconDictionary/Settings.d.ts.map +0 -1
  1071. package/dist/src/iconDictionary/Subtract.d.ts +0 -16
  1072. package/dist/src/iconDictionary/Subtract.d.ts.map +0 -1
  1073. package/dist/src/iconDictionary/SvgIcon.d.ts +0 -14
  1074. package/dist/src/iconDictionary/SvgIcon.d.ts.map +0 -1
  1075. package/dist/src/iconDictionary/User.d.ts +0 -16
  1076. package/dist/src/iconDictionary/User.d.ts.map +0 -1
  1077. package/dist/src/iconDictionary/UserGroup.d.ts +0 -16
  1078. package/dist/src/iconDictionary/UserGroup.d.ts.map +0 -1
  1079. package/dist/src/iconDictionary/index.d.ts +0 -94
  1080. package/dist/src/iconDictionary/index.d.ts.map +0 -1
  1081. package/dist/src/iconDictionary/types.d.ts +0 -19
  1082. package/dist/src/iconDictionary/types.d.ts.map +0 -1
  1083. package/dist/src/theme/OdysseyTheme.d.ts +0 -23
  1084. package/dist/src/theme/OdysseyTheme.d.ts.map +0 -1
  1085. package/dist/src/theme/temp.d.ts +0 -16
  1086. package/dist/src/theme/temp.d.ts.map +0 -1
  1087. package/dist/src/theme/useTheme.d.ts +0 -14
  1088. package/dist/src/theme/useTheme.d.ts.map +0 -1
  1089. package/dist/theme/OdysseyTheme.js +0 -2
  1090. package/dist/theme/OdysseyTheme.js.map +0 -1
  1091. package/dist/theme/temp.js +0 -15
  1092. package/dist/theme/temp.js.map +0 -1
  1093. package/dist/theme/useTheme.js +0 -16
  1094. package/dist/theme/useTheme.js.map +0 -1
  1095. package/scripts/resolveIconSrcPath.cjs +0 -20
  1096. package/src/Icon.test.tsx +0 -51
  1097. package/src/Icon.tsx +0 -57
  1098. package/src/Infobox.tsx +0 -48
  1099. package/src/ThemeProvider.tsx +0 -26
  1100. package/src/a11yCheck.ts +0 -28
  1101. package/src/iconDictionary/Add.tsx +0 -42
  1102. package/src/iconDictionary/AddCircle.tsx +0 -44
  1103. package/src/iconDictionary/AlertCircle.tsx +0 -44
  1104. package/src/iconDictionary/AlertCircleFilled.tsx +0 -45
  1105. package/src/iconDictionary/AlertTriangleFilled.tsx +0 -45
  1106. package/src/iconDictionary/Anchor.tsx +0 -46
  1107. package/src/iconDictionary/ArrowDown.tsx +0 -44
  1108. package/src/iconDictionary/ArrowLeft.tsx +0 -44
  1109. package/src/iconDictionary/ArrowRight.tsx +0 -44
  1110. package/src/iconDictionary/ArrowUp.tsx +0 -44
  1111. package/src/iconDictionary/ArrowUpDown.tsx +0 -44
  1112. package/src/iconDictionary/Calendar.tsx +0 -44
  1113. package/src/iconDictionary/Check.tsx +0 -44
  1114. package/src/iconDictionary/CheckCircleFilled.tsx +0 -45
  1115. package/src/iconDictionary/ChevronDown.tsx +0 -44
  1116. package/src/iconDictionary/ChevronUp.tsx +0 -44
  1117. package/src/iconDictionary/Close.tsx +0 -44
  1118. package/src/iconDictionary/CloseCircleFilled.tsx +0 -45
  1119. package/src/iconDictionary/Copy.tsx +0 -44
  1120. package/src/iconDictionary/Delete.tsx +0 -44
  1121. package/src/iconDictionary/Download.tsx +0 -44
  1122. package/src/iconDictionary/DragHandle.tsx +0 -44
  1123. package/src/iconDictionary/Edit.tsx +0 -44
  1124. package/src/iconDictionary/ExternalLink.tsx +0 -45
  1125. package/src/iconDictionary/Eye.tsx +0 -42
  1126. package/src/iconDictionary/EyeOff.tsx +0 -44
  1127. package/src/iconDictionary/Filter.tsx +0 -44
  1128. package/src/iconDictionary/Globe.tsx +0 -44
  1129. package/src/iconDictionary/Home.tsx +0 -44
  1130. package/src/iconDictionary/InformationCircle.tsx +0 -45
  1131. package/src/iconDictionary/InformationCircleFilled.tsx +0 -45
  1132. package/src/iconDictionary/Notification.tsx +0 -45
  1133. package/src/iconDictionary/OverflowVertical.tsx +0 -45
  1134. package/src/iconDictionary/QuestionCircle.tsx +0 -45
  1135. package/src/iconDictionary/QuestionCircleFilled.tsx +0 -45
  1136. package/src/iconDictionary/Search.tsx +0 -44
  1137. package/src/iconDictionary/Settings.tsx +0 -42
  1138. package/src/iconDictionary/Subtract.tsx +0 -44
  1139. package/src/iconDictionary/SvgIcon.ts +0 -14
  1140. package/src/iconDictionary/User.tsx +0 -44
  1141. package/src/iconDictionary/UserGroup.tsx +0 -44
  1142. package/src/iconDictionary/index.ts +0 -176
  1143. package/src/iconDictionary/types.ts +0 -20
  1144. package/src/theme/OdysseyTheme.ts +0 -25
  1145. package/src/theme/temp.ts +0 -19
  1146. package/src/theme/useTheme.ts +0 -18
@@ -0,0 +1,106 @@
1
+ /*!
2
+ * Copyright (c) 2022-present, Okta, Inc. and/or its affiliates. All rights reserved.
3
+ * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
4
+ *
5
+ * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
6
+ * Unless required by applicable law or agreed to in writing, software
7
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
8
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
9
+ *
10
+ * See the License for the specific language governing permissions and limitations under the License.
11
+ */
12
+
13
+ import { Box } from "@mui/material";
14
+ import { memo, ReactElement, useMemo } from "react";
15
+
16
+ import { Callout } from "./Callout";
17
+ import { FieldsetContext } from "./FieldsetContext";
18
+ import { Legend, Subordinate } from "./Typography";
19
+ import { useOdysseyDesignTokens } from "./OdysseyDesignTokensContext";
20
+ import { useUniqueId } from "./useUniqueId";
21
+
22
+ export type FieldsetProps = {
23
+ /**
24
+ * A Callout indicating a Fieldset-wide error or status update.
25
+ */
26
+ alert?: ReactElement<typeof Callout>;
27
+ /**
28
+ * The Field components within the Fieldset
29
+ */
30
+ children: ReactElement | Array<ReactElement>;
31
+ /**
32
+ * A supplementary description
33
+ */
34
+ description?: string;
35
+ /**
36
+ * Defines a unique identifier (ID) which must be unique in the whole document.
37
+ */
38
+ id?: string;
39
+ /**
40
+ * Disables the component and any wrapped input fields.
41
+ */
42
+ isDisabled?: boolean;
43
+ /**
44
+ * The title of the Fieldset
45
+ */
46
+ legend: string;
47
+ /**
48
+ * The name associated with the group.
49
+ */
50
+ name?: string;
51
+ };
52
+
53
+ const Fieldset = ({
54
+ alert,
55
+ children,
56
+ description,
57
+ id: idOverride,
58
+ isDisabled = false,
59
+ legend,
60
+ name,
61
+ }: FieldsetProps) => {
62
+ const odysseyDesignTokens = useOdysseyDesignTokens();
63
+ const id = useUniqueId(idOverride);
64
+
65
+ const fieldsetContextValue = useMemo(
66
+ () => ({
67
+ isDisabled,
68
+ }),
69
+ [isDisabled]
70
+ );
71
+
72
+ return (
73
+ <Box
74
+ component="fieldset"
75
+ disabled={isDisabled}
76
+ name={name}
77
+ id={id}
78
+ sx={{
79
+ border: "0",
80
+ margin: odysseyDesignTokens.Spacing0,
81
+ marginBlockEnd: odysseyDesignTokens.Spacing6,
82
+ maxWidth: odysseyDesignTokens.TypographyLineLengthMax,
83
+ padding: odysseyDesignTokens.Spacing0,
84
+
85
+ "&:last-child": {
86
+ marginBlockEnd: odysseyDesignTokens.Spacing0,
87
+ },
88
+ }}
89
+ >
90
+ <Legend>{legend}</Legend>
91
+
92
+ {description && <Subordinate component="p">{description}</Subordinate>}
93
+
94
+ {alert}
95
+
96
+ <FieldsetContext.Provider value={fieldsetContextValue}>
97
+ {children}
98
+ </FieldsetContext.Provider>
99
+ </Box>
100
+ );
101
+ };
102
+
103
+ const MemoizedFieldset = memo(Fieldset);
104
+ MemoizedFieldset.displayName = "Fieldset";
105
+
106
+ export { MemoizedFieldset as Fieldset };
@@ -0,0 +1,23 @@
1
+ /*!
2
+ * Copyright (c) 2023-present, Okta, Inc. and/or its affiliates. All rights reserved.
3
+ * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
4
+ *
5
+ * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
6
+ * Unless required by applicable law or agreed to in writing, software
7
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
8
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
9
+ *
10
+ * See the License for the specific language governing permissions and limitations under the License.
11
+ */
12
+
13
+ import { createContext, useContext } from "react";
14
+
15
+ export type FieldsetContextValue = {
16
+ isDisabled: boolean;
17
+ };
18
+
19
+ export const FieldsetContext = createContext<FieldsetContextValue>({
20
+ isDisabled: false,
21
+ });
22
+
23
+ export const useFieldset = () => useContext(FieldsetContext);
package/src/Form.tsx ADDED
@@ -0,0 +1,152 @@
1
+ /*!
2
+ * Copyright (c) 2022-present, Okta, Inc. and/or its affiliates. All rights reserved.
3
+ * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
4
+ *
5
+ * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
6
+ * Unless required by applicable law or agreed to in writing, software
7
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
8
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
9
+ *
10
+ * See the License for the specific language governing permissions and limitations under the License.
11
+ */
12
+
13
+ import { memo, ReactElement } from "react";
14
+
15
+ import { Box } from "@mui/material";
16
+ import { Button } from "./Button";
17
+ import { Callout } from "./Callout";
18
+ import { Heading4, Support } from "./Typography";
19
+ import { useUniqueId } from "./useUniqueId";
20
+
21
+ export const formEncodingTypeValues = [
22
+ "application/x-www-form-urlencoded",
23
+ "application/json",
24
+ "multipart/form-data",
25
+ "text/plain",
26
+ ] as const;
27
+ export const formAutoCompleteTypeValues = ["on", "off"] as const;
28
+ export const formMethodValues = ["post", "get", "dialog"] as const;
29
+
30
+ export type FormProps = {
31
+ /**
32
+ * A Callout indicating a Form-wide error or status update.
33
+ */
34
+ alert?: ReactElement<typeof Callout>;
35
+ /**
36
+ * Indicates whether input elements can by default have their values automatically completed by the browser.
37
+ * `autocomplete` attributes on form elements override it on <form>
38
+ */
39
+ autoCompleteType?: (typeof formAutoCompleteTypeValues)[number];
40
+ /**
41
+ * The Field or FieldSet components within the Form
42
+ */
43
+ children: ReactElement | Array<ReactElement>;
44
+ /**
45
+ * A supplementary description
46
+ */
47
+ description?: string;
48
+ /**
49
+ * If the value of the method attribute is post, enctype is the MIME type of the form submission.
50
+ * This value can be overridden by formenctype attributes on <button>, <input type="submit">, or <input type="image"> elements.
51
+ */
52
+ encodingType?: (typeof formEncodingTypeValues)[number];
53
+ /**
54
+ * The Field or FieldGroup components within the Form
55
+ */
56
+ formActions?:
57
+ | ReactElement<typeof Button>
58
+ | Array<ReactElement<typeof Button>>;
59
+ /**
60
+ * Defines a unique identifier (ID) which must be unique in the whole document.
61
+ */
62
+ id?: string;
63
+ /**
64
+ * The HTTP method to submit the form with.
65
+ * This value is overridden by formmethod attributes on <button>, <input type="submit">, or <input type="image"> elements.
66
+ */
67
+ method?: (typeof formMethodValues)[number];
68
+ /**
69
+ * The name of the form. The value must not be the empty string, and must be unique among the form elements in the forms collection that it is in, if any.
70
+ */
71
+ name: string;
72
+ /**
73
+ * This Boolean attribute indicates that the form shouldn't be validated when submitted.
74
+ * If this attribute is not set (and therefore the form is validated),
75
+ * it can be overridden by a formnovalidate attribute on a <button>, <input type="submit">, or <input type="image"> element belonging to the form.
76
+ */
77
+ noValidate?: boolean;
78
+ /**
79
+ * Indicates where to display the response after submitting the form. It is a name/keyword for a browsing context (for example, tab, window, or iframe).
80
+ * This value can be overridden by a formtarget attribute on a <button>, <input type="submit">, or <input type="image"> element.
81
+ */
82
+ target?: string;
83
+ /**
84
+ * The title of the Form
85
+ */
86
+ title?: string;
87
+ };
88
+
89
+ const Form = ({
90
+ alert,
91
+ autoCompleteType,
92
+ children,
93
+ description,
94
+ encodingType,
95
+ formActions,
96
+ id: idOverride,
97
+ method,
98
+ name,
99
+ noValidate = false,
100
+ target,
101
+ title,
102
+ }: FormProps) => {
103
+ const id = useUniqueId(idOverride);
104
+
105
+ return (
106
+ <Box
107
+ component="form"
108
+ autoComplete={autoCompleteType}
109
+ name={name}
110
+ encType={encodingType}
111
+ method={method}
112
+ noValidate={noValidate}
113
+ target={target}
114
+ id={id}
115
+ sx={{
116
+ maxWidth: (theme) => theme.mixins.maxWidth,
117
+ margin: (theme) => theme.spacing(0),
118
+ padding: (theme) => theme.spacing(0),
119
+ }}
120
+ >
121
+ <Box
122
+ component="div"
123
+ sx={{
124
+ marginBlockEnd: (theme) => theme.spacing(4),
125
+ }}
126
+ >
127
+ {title && <Heading4 component="h1">{title}</Heading4>}
128
+ {description && <Support>{description}</Support>}
129
+ {alert}
130
+ </Box>
131
+ <Box component="div">{children}</Box>
132
+ {formActions && (
133
+ <Box
134
+ component="div"
135
+ sx={{
136
+ display: "flex",
137
+ justifyContent: "flex-start",
138
+ gap: (theme) => theme.spacing(1),
139
+ marginBlockStart: (theme) => theme.spacing(7),
140
+ }}
141
+ >
142
+ {formActions}
143
+ </Box>
144
+ )}
145
+ </Box>
146
+ );
147
+ };
148
+
149
+ const MemoizedForm = memo(Form);
150
+ MemoizedForm.displayName = "Form";
151
+
152
+ export { MemoizedForm as Form };
package/src/Link.tsx CHANGED
@@ -10,41 +10,61 @@
10
10
  * See the License for the specific language governing permissions and limitations under the License.
11
11
  */
12
12
 
13
- import { forwardRef, ReactElement } from "react";
13
+ import { memo, ReactElement } from "react";
14
+ import { ExternalLinkIcon } from "./icons.generated";
14
15
 
15
- import {
16
- Link as MuiLink,
17
- LinkProps as MuiLinkProps,
18
- SvgIcon,
19
- } from "@mui/material";
16
+ import { Link as MuiLink } from "@mui/material";
17
+
18
+ export const linkVariantValues = ["default", "monochrome"] as const;
20
19
 
21
20
  export type LinkProps = {
21
+ /**
22
+ * The content within the Link
23
+ */
22
24
  children: React.ReactNode;
25
+ /**
26
+ * The Link destination
27
+ */
23
28
  href: string;
29
+ /**
30
+ * An optional Icon component at the start of the Link
31
+ */
24
32
  icon?: ReactElement;
33
+ /**
34
+ * The HTML `rel` attribute for the Link
35
+ */
25
36
  rel?: string;
26
- target?: "_self" | "_blank" | "_parent" | "_top" | string;
27
- variant?: MuiLinkProps["variant"];
37
+ /**
38
+ * The HTML `target` attribute for the Link
39
+ */
40
+ target?:
41
+ | "_self"
42
+ | "_blank"
43
+ | "_parent"
44
+ | "_top"
45
+ | (string & NonNullable<unknown>);
46
+ /**
47
+ * The visual presentation of the Link (default or monochrome)
48
+ */
49
+ variant?: (typeof linkVariantValues)[number];
28
50
  };
29
51
 
30
- export const Link = forwardRef<HTMLAnchorElement, LinkProps>((props, ref) => {
31
- const { icon, children, target, variant } = props;
32
- return (
33
- <MuiLink ref={ref} variant={variant} target={target}>
34
- {icon && <span className="Link-icon">{icon}</span>}
35
- {children}
36
- {target === "_blank" && (
37
- <span className="Link-indicator" role="presentation">
38
- <SvgIcon viewBox="0 0 16 16">
39
- <path
40
- fillRule="evenodd"
41
- clipRule="evenodd"
42
- d="M13.2929 2H7.99998V1H14.5C14.7761 1 15 1.22386 15 1.5V8H14V2.70711L6.35353 10.3536L5.64642 9.64645L13.2929 2ZM1.5 4H1V4.5V14.5V15H1.5H11.5H12V14.5V8H11V14H2V5H8V4H1.5Z"
43
- fill="currentColor"
44
- />
45
- </SvgIcon>
46
- </span>
47
- )}
48
- </MuiLink>
49
- );
50
- });
52
+ const Link = ({ children, href, icon, target, rel, variant }: LinkProps) => (
53
+ <MuiLink href={href} rel={rel} target={target} variant={variant}>
54
+ {icon && <span className="Link-icon">{icon}</span>}
55
+
56
+ {children}
57
+
58
+ {target === "_blank" && (
59
+ <span className="Link-indicator" role="presentation">
60
+ <ExternalLinkIcon />
61
+ </span>
62
+ )}
63
+ </MuiLink>
64
+ );
65
+
66
+ const MemoizedLink = memo(Link);
67
+
68
+ MemoizedLink.displayName = "Link";
69
+
70
+ export { MemoizedLink as Link };
@@ -10,29 +10,27 @@
10
10
  * See the License for the specific language governing permissions and limitations under the License.
11
11
  */
12
12
 
13
- import {
14
- Button,
15
- ButtonProps,
16
- ChevronDownIcon,
17
- Divider,
18
- ListSubheader,
19
- Menu,
20
- MenuItem,
21
- useUniqueId,
22
- } from "./";
23
- import { memo, MouseEvent, ReactElement, useMemo, useState } from "react";
13
+ import { Button, buttonVariantValues, MenuItem, useUniqueId } from "./";
14
+ import { Divider, ListSubheader, Menu } from "@mui/material";
15
+ import { ChevronDownIcon } from "./icons.generated";
16
+ import { memo, type ReactElement, useCallback, useMemo, useState } from "react";
17
+
18
+ import { MenuContext, MenuContextType } from "./MenuContext";
19
+ import { NullElement } from "./NullElement";
24
20
 
25
21
  export type MenuButtonProps = {
26
22
  /**
27
- * The <MenuItem> components within the Menu.
23
+ * The ARIA label for the Button
28
24
  */
29
- children: Array<
30
- ReactElement<typeof MenuItem | typeof Divider | typeof ListSubheader>
31
- >;
25
+ ariaLabel?: string;
32
26
  /**
33
- * The end Icon on the trigggering Button
27
+ * The ID of the element that labels the Button
28
+ */
29
+ ariaLabelledBy?: string;
30
+ /**
31
+ * The ID of the element that describes the Button
34
32
  */
35
- buttonEndIcon?: ReactElement;
33
+ ariaDescribedBy?: string;
36
34
  /**
37
35
  * The label on the triggering Button
38
36
  */
@@ -40,31 +38,67 @@ export type MenuButtonProps = {
40
38
  /**
41
39
  * The variant of the triggering Button
42
40
  */
43
- buttonVariant?: ButtonProps["variant"];
41
+ buttonVariant?: (typeof buttonVariantValues)[number];
42
+ /**
43
+ * The <MenuItem> components within the Menu.
44
+ */
45
+ children: Array<
46
+ ReactElement<
47
+ typeof MenuItem | typeof Divider | typeof ListSubheader | NullElement
48
+ >
49
+ >;
50
+ /**
51
+ * The end Icon on the trigggering Button
52
+ */
53
+ endIcon?: ReactElement;
44
54
  /**
45
- * The id of the `input` element.
55
+ * The id of the Button
46
56
  */
47
57
  id?: string;
48
- };
58
+ /**
59
+ * The tooltip text for the Button if it's icon-only
60
+ */
61
+ tooltipText?: string;
62
+ } & (
63
+ | {
64
+ ariaLabel?: string;
65
+ ariaLabelledBy?: string;
66
+ buttonLabel: string;
67
+ }
68
+ | {
69
+ ariaLabel: string;
70
+ ariaLabelledBy?: string;
71
+ buttonLabel?: undefined | "";
72
+ }
73
+ | {
74
+ ariaLabel?: string;
75
+ ariaLabelledBy: string;
76
+ buttonLabel?: undefined | "";
77
+ }
78
+ );
49
79
 
50
80
  const MenuButton = ({
81
+ ariaLabel,
82
+ ariaLabelledBy,
83
+ ariaDescribedBy,
51
84
  buttonLabel = "",
52
- children,
53
- buttonEndIcon = <ChevronDownIcon />,
54
85
  buttonVariant = "secondary",
86
+ children,
87
+ endIcon = <ChevronDownIcon />,
55
88
  id: idOverride,
89
+ tooltipText,
56
90
  }: MenuButtonProps) => {
57
91
  const [anchorEl, setAnchorEl] = useState<null | HTMLElement>(null);
58
92
 
59
- const open = Boolean(anchorEl);
93
+ const isOpen = Boolean(anchorEl);
60
94
 
61
- const handleClick = (event: MouseEvent<HTMLButtonElement>) => {
62
- setAnchorEl(event.currentTarget);
63
- };
64
-
65
- const handleClose = () => {
95
+ const closeMenu = useCallback<MenuContextType["closeMenu"]>(() => {
66
96
  setAnchorEl(null);
67
- };
97
+ }, []);
98
+
99
+ const openMenu = useCallback<MenuContextType["openMenu"]>((event) => {
100
+ setAnchorEl(event.currentTarget);
101
+ }, []);
68
102
 
69
103
  const uniqueId = useUniqueId(idOverride);
70
104
 
@@ -73,31 +107,47 @@ const MenuButton = ({
73
107
  [uniqueId]
74
108
  );
75
109
 
110
+ const providerValue = useMemo<MenuContextType>(
111
+ () => ({
112
+ closeMenu,
113
+ openMenu,
114
+ }),
115
+ [closeMenu, openMenu]
116
+ );
117
+
76
118
  return (
77
119
  <div>
78
120
  <Button
79
- endIcon={buttonEndIcon}
80
- id={`${uniqueId}-button`}
81
- aria-controls={open ? `${uniqueId}-menu` : undefined}
121
+ aria-controls={isOpen ? `${uniqueId}-menu` : undefined}
122
+ aria-expanded={isOpen ? "true" : undefined}
82
123
  aria-haspopup="true"
83
- aria-expanded={open ? "true" : undefined}
84
- onClick={handleClick}
85
- text={buttonLabel}
124
+ ariaDescribedBy={ariaDescribedBy}
125
+ ariaLabel={ariaLabel}
126
+ ariaLabelledBy={ariaLabelledBy}
127
+ endIcon={endIcon}
128
+ id={`${uniqueId}-button`}
129
+ label={buttonLabel}
130
+ onClick={openMenu}
131
+ tooltipText={tooltipText}
86
132
  variant={buttonVariant}
87
133
  />
134
+
88
135
  <Menu
89
- id={`${uniqueId}-menu`}
90
136
  anchorEl={anchorEl}
91
- open={open}
92
- onClose={handleClose}
137
+ id={`${uniqueId}-menu`}
93
138
  MenuListProps={menuListProps}
139
+ onClose={closeMenu}
140
+ open={isOpen}
94
141
  >
95
- {children}
142
+ <MenuContext.Provider value={providerValue}>
143
+ {children}
144
+ </MenuContext.Provider>
96
145
  </Menu>
97
146
  </div>
98
147
  );
99
148
  };
100
149
 
101
150
  const MemoizedMenuButton = memo(MenuButton);
151
+ MemoizedMenuButton.displayName = "MenuButton";
102
152
 
103
153
  export { MemoizedMenuButton as MenuButton };
@@ -0,0 +1,25 @@
1
+ /*!
2
+ * Copyright (c) 2023-present, Okta, Inc. and/or its affiliates. All rights reserved.
3
+ * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
4
+ *
5
+ * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
6
+ * Unless required by applicable law or agreed to in writing, software
7
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
8
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
9
+ *
10
+ * See the License for the specific language governing permissions and limitations under the License.
11
+ */
12
+
13
+ import { createContext, MouseEventHandler } from "react";
14
+
15
+ export type MenuContextType = {
16
+ closeMenu: () => void;
17
+ openMenu: MouseEventHandler<HTMLElement>;
18
+ };
19
+
20
+ export const MenuContext = createContext<MenuContextType>({
21
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
22
+ closeMenu: () => {},
23
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
24
+ openMenu: () => {},
25
+ });
package/src/MenuItem.tsx CHANGED
@@ -10,40 +10,85 @@
10
10
  * See the License for the specific language governing permissions and limitations under the License.
11
11
  */
12
12
 
13
- import { memo, forwardRef } from "react";
14
- import { MenuItem as MuiMenuItem } from "@mui/material";
13
+ import {
14
+ MenuItem as MuiMenuItem,
15
+ MenuItemProps as MuiMenuItemProps,
16
+ } from "@mui/material";
15
17
  import { menuItemClasses } from "@mui/material/MenuItem";
16
- import type { MenuItemProps as MuiMenuItemProps } from "@mui/material";
17
-
18
- export interface MenuItemProps
19
- extends Omit<
20
- MuiMenuItemProps,
21
- | "component"
22
- | "dense"
23
- | "disableGutters"
24
- | "divider"
25
- | "focusVisibleClassName"
26
- > {
18
+ import { memo, useCallback, useContext, type ReactNode } from "react";
19
+
20
+ import { MenuContext } from "./MenuContext";
21
+
22
+ export type MenuItemProps = {
23
+ /**
24
+ * The content of the menu item.
25
+ */
26
+ children: ReactNode;
27
+ /**
28
+ * If `true`, the menu item will receive focus automatically.
29
+ */
30
+ hasInitialFocus?: boolean;
31
+ /**
32
+ * If `true`, the menu item will be visually marked as selected.
33
+ */
34
+ isSelected?: boolean;
27
35
  /**
28
- * Toggles whether or not the MenuItem represents a destructive action.
36
+ * If `true`, the menu item will be visually marked as destructive.
29
37
  */
30
38
  isDestructive?: boolean;
31
- }
39
+ /**
40
+ * Callback fired when the menu item is clicked.
41
+ */
42
+ onClick?: MuiMenuItemProps["onClick"];
43
+ /**
44
+ * The value associated with the menu item.
45
+ */
46
+ value?: string;
47
+ /**
48
+ * The variant of the menu item.
49
+ * - "default": The default variant.
50
+ * - "destructive": A variant indicating a destructive action.
51
+ */
52
+ variant?: "default" | "destructive";
53
+ };
54
+
55
+ const MenuItem = ({
56
+ children,
57
+ hasInitialFocus,
58
+ isSelected,
59
+ onClick: onClickProp,
60
+ value,
61
+ variant = "default",
62
+ }: MenuItemProps) => {
63
+ const { closeMenu } = useContext(MenuContext);
64
+
65
+ const onClick = useCallback<NonNullable<MuiMenuItemProps["onClick"]>>(
66
+ (event) => {
67
+ onClickProp?.(event);
68
+ closeMenu();
69
+ },
70
+ [onClickProp, closeMenu]
71
+ );
32
72
 
33
- const MenuItem = forwardRef<HTMLLIElement, MenuItemProps>(
34
- ({ isDestructive, ...props }, ref) => (
73
+ return (
35
74
  <MuiMenuItem
36
- {...props}
37
- ref={ref}
75
+ /* eslint-disable-next-line jsx-a11y/no-autofocus */
76
+ autoFocus={hasInitialFocus}
77
+ selected={isSelected}
78
+ value={value}
79
+ onClick={onClick}
38
80
  className={
39
- isDestructive ? `${menuItemClasses.root}-destructive` : undefined
81
+ variant === "destructive"
82
+ ? `${menuItemClasses.root}-destructive`
83
+ : undefined
40
84
  }
41
85
  >
42
- {props.children}
86
+ {children}
43
87
  </MuiMenuItem>
44
- )
45
- );
88
+ );
89
+ };
46
90
 
47
91
  const MemoizedMenuItem = memo(MenuItem);
92
+ MemoizedMenuItem.displayName = "MenuItem";
48
93
 
49
94
  export { MemoizedMenuItem as MenuItem };