@okta/odyssey-react-mui 1.25.0 → 1.26.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 (491) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/dist/Autocomplete.js +30 -191
  3. package/dist/Autocomplete.js.map +1 -1
  4. package/dist/Box.js +2 -0
  5. package/dist/Box.js.map +1 -1
  6. package/dist/Card.js +1 -0
  7. package/dist/Card.js.map +1 -1
  8. package/dist/OdysseyDesignTokensContext.js +3 -2
  9. package/dist/OdysseyDesignTokensContext.js.map +1 -1
  10. package/dist/OdysseyProvider.js +9 -7
  11. package/dist/OdysseyProvider.js.map +1 -1
  12. package/dist/OdysseyThemeProvider.js +33 -13
  13. package/dist/OdysseyThemeProvider.js.map +1 -1
  14. package/dist/Pagination/Pagination.js +46 -14
  15. package/dist/Pagination/Pagination.js.map +1 -1
  16. package/dist/Surface.js +4 -1
  17. package/dist/Surface.js.map +1 -1
  18. package/dist/Tag.js +42 -27
  19. package/dist/Tag.js.map +1 -1
  20. package/dist/index.js +6 -7
  21. package/dist/index.js.map +1 -1
  22. package/dist/index.scss +1 -1
  23. package/dist/labs/AppTile.js +137 -39
  24. package/dist/labs/AppTile.js.map +1 -1
  25. package/dist/labs/DataView/CardLayoutContent.js +7 -8
  26. package/dist/labs/DataView/CardLayoutContent.js.map +1 -1
  27. package/dist/labs/DataView/DataCard.js +96 -43
  28. package/dist/labs/DataView/DataCard.js.map +1 -1
  29. package/dist/labs/DataView/TableLayoutContent.js +3 -2
  30. package/dist/labs/DataView/TableLayoutContent.js.map +1 -1
  31. package/dist/labs/DataView/componentTypes.js.map +1 -1
  32. package/dist/labs/DataView/index.js.map +1 -1
  33. package/dist/labs/OdysseyPickers/ComposablePicker.js +113 -0
  34. package/dist/labs/OdysseyPickers/ComposablePicker.js.map +1 -0
  35. package/dist/labs/OdysseyPickers/Picker.js +261 -0
  36. package/dist/labs/OdysseyPickers/Picker.js.map +1 -0
  37. package/dist/labs/OdysseyPickers/PickerVirtualizationListBox.js +132 -0
  38. package/dist/labs/OdysseyPickers/PickerVirtualizationListBox.js.map +1 -0
  39. package/dist/labs/OdysseyPickers/PickerWithOptionAdornment.js +291 -0
  40. package/dist/labs/OdysseyPickers/PickerWithOptionAdornment.js.map +1 -0
  41. package/dist/{src/createShadowDomElements.d.ts → labs/OdysseyPickers/index.js} +4 -7
  42. package/dist/labs/OdysseyPickers/index.js.map +1 -0
  43. package/dist/labs/PageTemplate.js +14 -10
  44. package/dist/labs/PageTemplate.js.map +1 -1
  45. package/dist/labs/SideNav/CollapseIcon.js +11 -25
  46. package/dist/labs/SideNav/CollapseIcon.js.map +1 -1
  47. package/dist/labs/SideNav/HandleIcon.js +32 -0
  48. package/dist/labs/SideNav/HandleIcon.js.map +1 -0
  49. package/dist/labs/{NavAccordion.js → SideNav/NavAccordion.js} +35 -6
  50. package/dist/labs/SideNav/NavAccordion.js.map +1 -0
  51. package/dist/labs/SideNav/OktaAura.js +32 -0
  52. package/dist/labs/SideNav/OktaAura.js.map +1 -0
  53. package/dist/labs/SideNav/OktaLogo.js +6 -9
  54. package/dist/labs/SideNav/OktaLogo.js.map +1 -1
  55. package/dist/labs/SideNav/SideNav.js +239 -169
  56. package/dist/labs/SideNav/SideNav.js.map +1 -1
  57. package/dist/labs/SideNav/SideNavFooterContent.js +32 -18
  58. package/dist/labs/SideNav/SideNavFooterContent.js.map +1 -1
  59. package/dist/labs/SideNav/SideNavHeader.js +48 -37
  60. package/dist/labs/SideNav/SideNavHeader.js.map +1 -1
  61. package/dist/labs/SideNav/SideNavItemContent.js +100 -58
  62. package/dist/labs/SideNav/SideNavItemContent.js.map +1 -1
  63. package/dist/labs/SideNav/SideNavItemContentContext.js +19 -0
  64. package/dist/labs/SideNav/SideNavItemContentContext.js.map +1 -0
  65. package/dist/labs/SideNav/SideNavItemLinkContent.js +14 -13
  66. package/dist/labs/SideNav/SideNavItemLinkContent.js.map +1 -1
  67. package/dist/labs/SideNav/SideNavLogo.js +42 -0
  68. package/dist/labs/SideNav/SideNavLogo.js.map +1 -0
  69. package/dist/labs/SideNav/SideNavToggleButton.js +170 -0
  70. package/dist/labs/SideNav/SideNavToggleButton.js.map +1 -0
  71. package/dist/labs/SideNav/types.js.map +1 -1
  72. package/dist/labs/TopNav/TopNav.js +65 -0
  73. package/dist/labs/TopNav/TopNav.js.map +1 -0
  74. package/dist/labs/TopNav/TopNavLinksList.js +38 -0
  75. package/dist/labs/TopNav/TopNavLinksList.js.map +1 -0
  76. package/dist/labs/TopNav/TopNavListItem.js +132 -0
  77. package/dist/labs/TopNav/TopNavListItem.js.map +1 -0
  78. package/dist/labs/TopNav/UserProfile.js +65 -0
  79. package/dist/labs/TopNav/UserProfile.js.map +1 -0
  80. package/dist/labs/TopNav/index.js +14 -0
  81. package/dist/labs/TopNav/index.js.map +1 -0
  82. package/dist/labs/UiShell/UiShell.js +68 -0
  83. package/dist/labs/UiShell/UiShell.js.map +1 -0
  84. package/dist/labs/UiShell/UiShellContent.js +114 -0
  85. package/dist/labs/UiShell/UiShellContent.js.map +1 -0
  86. package/dist/labs/UiShell/bufferLatest.js +37 -0
  87. package/dist/labs/UiShell/bufferLatest.js.map +1 -0
  88. package/dist/labs/UiShell/createMessageBus.js +30 -0
  89. package/dist/labs/UiShell/createMessageBus.js.map +1 -0
  90. package/dist/labs/UiShell/createStore.js +24 -0
  91. package/dist/labs/UiShell/createStore.js.map +1 -0
  92. package/dist/labs/UiShell/index.js +15 -0
  93. package/dist/labs/UiShell/index.js.map +1 -0
  94. package/dist/labs/UiShell/renderUiShell.js +78 -0
  95. package/dist/labs/UiShell/renderUiShell.js.map +1 -0
  96. package/dist/labs/UiShell/useHasUiShell.js +22 -0
  97. package/dist/labs/UiShell/useHasUiShell.js.map +1 -0
  98. package/dist/labs/UiShell/useScrollState.js +41 -0
  99. package/dist/labs/UiShell/useScrollState.js.map +1 -0
  100. package/dist/labs/index.js +5 -3
  101. package/dist/labs/index.js.map +1 -1
  102. package/dist/properties/ts/odyssey-react-mui.js +7 -1
  103. package/dist/properties/ts/odyssey-react-mui.js.map +1 -1
  104. package/dist/properties/ts/odyssey-react-mui_cs.js +3 -1
  105. package/dist/properties/ts/odyssey-react-mui_cs.js.map +1 -1
  106. package/dist/properties/ts/odyssey-react-mui_da.js +3 -1
  107. package/dist/properties/ts/odyssey-react-mui_da.js.map +1 -1
  108. package/dist/properties/ts/odyssey-react-mui_de.js +3 -1
  109. package/dist/properties/ts/odyssey-react-mui_de.js.map +1 -1
  110. package/dist/properties/ts/odyssey-react-mui_el.js +3 -1
  111. package/dist/properties/ts/odyssey-react-mui_el.js.map +1 -1
  112. package/dist/properties/ts/odyssey-react-mui_es.js +3 -1
  113. package/dist/properties/ts/odyssey-react-mui_es.js.map +1 -1
  114. package/dist/properties/ts/odyssey-react-mui_fi.js +3 -1
  115. package/dist/properties/ts/odyssey-react-mui_fi.js.map +1 -1
  116. package/dist/properties/ts/odyssey-react-mui_fr.js +5 -3
  117. package/dist/properties/ts/odyssey-react-mui_fr.js.map +1 -1
  118. package/dist/properties/ts/odyssey-react-mui_ht.js +3 -1
  119. package/dist/properties/ts/odyssey-react-mui_ht.js.map +1 -1
  120. package/dist/properties/ts/odyssey-react-mui_hu.js +3 -1
  121. package/dist/properties/ts/odyssey-react-mui_hu.js.map +1 -1
  122. package/dist/properties/ts/odyssey-react-mui_id.js +3 -1
  123. package/dist/properties/ts/odyssey-react-mui_id.js.map +1 -1
  124. package/dist/properties/ts/odyssey-react-mui_it.js +4 -2
  125. package/dist/properties/ts/odyssey-react-mui_it.js.map +1 -1
  126. package/dist/properties/ts/odyssey-react-mui_ja.js +9 -7
  127. package/dist/properties/ts/odyssey-react-mui_ja.js.map +1 -1
  128. package/dist/properties/ts/odyssey-react-mui_ko.js +3 -1
  129. package/dist/properties/ts/odyssey-react-mui_ko.js.map +1 -1
  130. package/dist/properties/ts/odyssey-react-mui_ms.js +3 -1
  131. package/dist/properties/ts/odyssey-react-mui_ms.js.map +1 -1
  132. package/dist/properties/ts/odyssey-react-mui_nb.js +3 -1
  133. package/dist/properties/ts/odyssey-react-mui_nb.js.map +1 -1
  134. package/dist/properties/ts/odyssey-react-mui_nl_NL.js +3 -1
  135. package/dist/properties/ts/odyssey-react-mui_nl_NL.js.map +1 -1
  136. package/dist/properties/ts/odyssey-react-mui_pl.js +3 -1
  137. package/dist/properties/ts/odyssey-react-mui_pl.js.map +1 -1
  138. package/dist/properties/ts/odyssey-react-mui_pt_BR.js +3 -1
  139. package/dist/properties/ts/odyssey-react-mui_pt_BR.js.map +1 -1
  140. package/dist/properties/ts/odyssey-react-mui_ro.js +3 -1
  141. package/dist/properties/ts/odyssey-react-mui_ro.js.map +1 -1
  142. package/dist/properties/ts/odyssey-react-mui_ru.js +3 -1
  143. package/dist/properties/ts/odyssey-react-mui_ru.js.map +1 -1
  144. package/dist/properties/ts/odyssey-react-mui_sv.js +3 -1
  145. package/dist/properties/ts/odyssey-react-mui_sv.js.map +1 -1
  146. package/dist/properties/ts/odyssey-react-mui_th.js +3 -1
  147. package/dist/properties/ts/odyssey-react-mui_th.js.map +1 -1
  148. package/dist/properties/ts/odyssey-react-mui_tr.js +4 -2
  149. package/dist/properties/ts/odyssey-react-mui_tr.js.map +1 -1
  150. package/dist/properties/ts/odyssey-react-mui_uk.js +3 -1
  151. package/dist/properties/ts/odyssey-react-mui_uk.js.map +1 -1
  152. package/dist/properties/ts/odyssey-react-mui_vi.js +3 -1
  153. package/dist/properties/ts/odyssey-react-mui_vi.js.map +1 -1
  154. package/dist/properties/ts/odyssey-react-mui_zh_CN.js +3 -1
  155. package/dist/properties/ts/odyssey-react-mui_zh_CN.js.map +1 -1
  156. package/dist/properties/ts/odyssey-react-mui_zh_TW.js +3 -1
  157. package/dist/properties/ts/odyssey-react-mui_zh_TW.js.map +1 -1
  158. package/dist/src/Autocomplete.d.ts +21 -22
  159. package/dist/src/Autocomplete.d.ts.map +1 -1
  160. package/dist/src/Box.d.ts +3 -1
  161. package/dist/src/Box.d.ts.map +1 -1
  162. package/dist/src/Card.d.ts.map +1 -1
  163. package/dist/src/OdysseyDesignTokensContext.d.ts +5 -4
  164. package/dist/src/OdysseyDesignTokensContext.d.ts.map +1 -1
  165. package/dist/src/OdysseyProvider.d.ts +3 -3
  166. package/dist/src/OdysseyProvider.d.ts.map +1 -1
  167. package/dist/src/OdysseyThemeProvider.d.ts +10 -12
  168. package/dist/src/OdysseyThemeProvider.d.ts.map +1 -1
  169. package/dist/src/OdysseyTranslationProvider.d.ts +1 -1
  170. package/dist/src/OdysseyTranslationProvider.d.ts.map +1 -1
  171. package/dist/src/Pagination/Pagination.d.ts +21 -7
  172. package/dist/src/Pagination/Pagination.d.ts.map +1 -1
  173. package/dist/src/Surface.d.ts.map +1 -1
  174. package/dist/src/Tag.d.ts +5 -2
  175. package/dist/src/Tag.d.ts.map +1 -1
  176. package/dist/src/index.d.ts +6 -7
  177. package/dist/src/index.d.ts.map +1 -1
  178. package/dist/src/labs/AppTile.d.ts +3 -1
  179. package/dist/src/labs/AppTile.d.ts.map +1 -1
  180. package/dist/src/labs/DataView/CardLayoutContent.d.ts.map +1 -1
  181. package/dist/src/labs/DataView/DataCard.d.ts +9 -3
  182. package/dist/src/labs/DataView/DataCard.d.ts.map +1 -1
  183. package/dist/src/labs/DataView/TableLayoutContent.d.ts.map +1 -1
  184. package/dist/src/labs/DataView/componentTypes.d.ts +1 -1
  185. package/dist/src/labs/DataView/componentTypes.d.ts.map +1 -1
  186. package/dist/src/labs/DataView/index.d.ts +1 -0
  187. package/dist/src/labs/DataView/index.d.ts.map +1 -1
  188. package/dist/src/labs/OdysseyPickers/ComposablePicker.d.ts +33 -0
  189. package/dist/src/labs/OdysseyPickers/ComposablePicker.d.ts.map +1 -0
  190. package/dist/src/labs/OdysseyPickers/Picker.d.ts +98 -0
  191. package/dist/src/labs/OdysseyPickers/Picker.d.ts.map +1 -0
  192. package/dist/src/labs/OdysseyPickers/PickerVirtualizationListBox.d.ts +17 -0
  193. package/dist/src/labs/OdysseyPickers/PickerVirtualizationListBox.d.ts.map +1 -0
  194. package/dist/src/labs/OdysseyPickers/PickerWithOptionAdornment.d.ts +26 -0
  195. package/dist/src/labs/OdysseyPickers/PickerWithOptionAdornment.d.ts.map +1 -0
  196. package/dist/src/labs/OdysseyPickers/index.d.ts +15 -0
  197. package/dist/src/labs/OdysseyPickers/index.d.ts.map +1 -0
  198. package/dist/src/labs/PageTemplate.d.ts +1 -1
  199. package/dist/src/labs/PageTemplate.d.ts.map +1 -1
  200. package/dist/src/labs/SideNav/CollapseIcon.d.ts +1 -4
  201. package/dist/src/labs/SideNav/CollapseIcon.d.ts.map +1 -1
  202. package/dist/src/labs/SideNav/HandleIcon.d.ts +14 -0
  203. package/dist/src/labs/SideNav/HandleIcon.d.ts.map +1 -0
  204. package/dist/src/labs/{NavAccordion.d.ts → SideNav/NavAccordion.d.ts} +6 -2
  205. package/dist/src/labs/SideNav/NavAccordion.d.ts.map +1 -0
  206. package/dist/src/labs/SideNav/OktaAura.d.ts +14 -0
  207. package/dist/src/labs/SideNav/OktaAura.d.ts.map +1 -0
  208. package/dist/src/labs/SideNav/OktaLogo.d.ts.map +1 -1
  209. package/dist/src/labs/SideNav/SideNav.d.ts +2 -1
  210. package/dist/src/labs/SideNav/SideNav.d.ts.map +1 -1
  211. package/dist/src/labs/SideNav/SideNavFooterContent.d.ts +1 -1
  212. package/dist/src/labs/SideNav/SideNavFooterContent.d.ts.map +1 -1
  213. package/dist/src/labs/SideNav/SideNavHeader.d.ts +12 -3
  214. package/dist/src/labs/SideNav/SideNavHeader.d.ts.map +1 -1
  215. package/dist/src/labs/SideNav/SideNavItemContent.d.ts +2 -3
  216. package/dist/src/labs/SideNav/SideNavItemContent.d.ts.map +1 -1
  217. package/dist/src/labs/SideNav/SideNavItemContentContext.d.ts +18 -0
  218. package/dist/src/labs/SideNav/SideNavItemContentContext.d.ts.map +1 -0
  219. package/dist/src/labs/SideNav/SideNavItemLinkContent.d.ts +1 -1
  220. package/dist/src/labs/SideNav/SideNavItemLinkContent.d.ts.map +1 -1
  221. package/dist/src/labs/SideNav/SideNavLogo.d.ts +15 -0
  222. package/dist/src/labs/SideNav/SideNavLogo.d.ts.map +1 -0
  223. package/dist/src/labs/SideNav/SideNavToggleButton.d.ts +38 -0
  224. package/dist/src/labs/SideNav/SideNavToggleButton.d.ts.map +1 -0
  225. package/dist/src/labs/SideNav/types.d.ts +67 -33
  226. package/dist/src/labs/SideNav/types.d.ts.map +1 -1
  227. package/dist/src/labs/TopNav/TopNav.d.ts +31 -0
  228. package/dist/src/labs/TopNav/TopNav.d.ts.map +1 -0
  229. package/dist/src/labs/TopNav/TopNavLinksList.d.ts +44 -0
  230. package/dist/src/labs/TopNav/TopNavLinksList.d.ts.map +1 -0
  231. package/dist/src/labs/TopNav/TopNavListItem.d.ts +42 -0
  232. package/dist/src/labs/TopNav/TopNavListItem.d.ts.map +1 -0
  233. package/dist/src/labs/TopNav/UserProfile.d.ts +29 -0
  234. package/dist/src/labs/TopNav/UserProfile.d.ts.map +1 -0
  235. package/dist/src/labs/TopNav/index.d.ts +14 -0
  236. package/dist/src/labs/TopNav/index.d.ts.map +1 -0
  237. package/dist/src/labs/UiShell/UiShell.d.ts +33 -0
  238. package/dist/src/labs/UiShell/UiShell.d.ts.map +1 -0
  239. package/dist/src/labs/UiShell/UiShellContent.d.ts +47 -0
  240. package/dist/src/labs/UiShell/UiShellContent.d.ts.map +1 -0
  241. package/dist/src/labs/UiShell/bufferLatest.d.ts +31 -0
  242. package/dist/src/labs/UiShell/bufferLatest.d.ts.map +1 -0
  243. package/dist/src/labs/UiShell/createMessageBus.d.ts +24 -0
  244. package/dist/src/labs/UiShell/createMessageBus.d.ts.map +1 -0
  245. package/dist/src/labs/UiShell/createStore.d.ts +22 -0
  246. package/dist/src/labs/UiShell/createStore.d.ts.map +1 -0
  247. package/dist/src/labs/UiShell/index.d.ts +16 -0
  248. package/dist/src/labs/UiShell/index.d.ts.map +1 -0
  249. package/dist/src/labs/UiShell/renderUiShell.d.ts +45 -0
  250. package/dist/src/labs/UiShell/renderUiShell.d.ts.map +1 -0
  251. package/dist/src/labs/UiShell/useHasUiShell.d.ts +13 -0
  252. package/dist/src/labs/UiShell/useHasUiShell.d.ts.map +1 -0
  253. package/dist/src/labs/UiShell/useScrollState.d.ts +16 -0
  254. package/dist/src/labs/UiShell/useScrollState.d.ts.map +1 -0
  255. package/dist/src/labs/index.d.ts +6 -2
  256. package/dist/src/labs/index.d.ts.map +1 -1
  257. package/dist/src/properties/ts/odyssey-react-mui.d.ts +6 -0
  258. package/dist/src/properties/ts/odyssey-react-mui.d.ts.map +1 -1
  259. package/dist/src/properties/ts/odyssey-react-mui_cs.d.ts +2 -0
  260. package/dist/src/properties/ts/odyssey-react-mui_cs.d.ts.map +1 -1
  261. package/dist/src/properties/ts/odyssey-react-mui_da.d.ts +2 -0
  262. package/dist/src/properties/ts/odyssey-react-mui_da.d.ts.map +1 -1
  263. package/dist/src/properties/ts/odyssey-react-mui_de.d.ts +2 -0
  264. package/dist/src/properties/ts/odyssey-react-mui_de.d.ts.map +1 -1
  265. package/dist/src/properties/ts/odyssey-react-mui_el.d.ts +2 -0
  266. package/dist/src/properties/ts/odyssey-react-mui_el.d.ts.map +1 -1
  267. package/dist/src/properties/ts/odyssey-react-mui_es.d.ts +2 -0
  268. package/dist/src/properties/ts/odyssey-react-mui_es.d.ts.map +1 -1
  269. package/dist/src/properties/ts/odyssey-react-mui_fi.d.ts +2 -0
  270. package/dist/src/properties/ts/odyssey-react-mui_fi.d.ts.map +1 -1
  271. package/dist/src/properties/ts/odyssey-react-mui_fr.d.ts +2 -0
  272. package/dist/src/properties/ts/odyssey-react-mui_fr.d.ts.map +1 -1
  273. package/dist/src/properties/ts/odyssey-react-mui_ht.d.ts +2 -0
  274. package/dist/src/properties/ts/odyssey-react-mui_ht.d.ts.map +1 -1
  275. package/dist/src/properties/ts/odyssey-react-mui_hu.d.ts +2 -0
  276. package/dist/src/properties/ts/odyssey-react-mui_hu.d.ts.map +1 -1
  277. package/dist/src/properties/ts/odyssey-react-mui_id.d.ts +2 -0
  278. package/dist/src/properties/ts/odyssey-react-mui_id.d.ts.map +1 -1
  279. package/dist/src/properties/ts/odyssey-react-mui_it.d.ts +2 -0
  280. package/dist/src/properties/ts/odyssey-react-mui_it.d.ts.map +1 -1
  281. package/dist/src/properties/ts/odyssey-react-mui_ja.d.ts +2 -0
  282. package/dist/src/properties/ts/odyssey-react-mui_ja.d.ts.map +1 -1
  283. package/dist/src/properties/ts/odyssey-react-mui_ko.d.ts +2 -0
  284. package/dist/src/properties/ts/odyssey-react-mui_ko.d.ts.map +1 -1
  285. package/dist/src/properties/ts/odyssey-react-mui_ms.d.ts +2 -0
  286. package/dist/src/properties/ts/odyssey-react-mui_ms.d.ts.map +1 -1
  287. package/dist/src/properties/ts/odyssey-react-mui_nb.d.ts +2 -0
  288. package/dist/src/properties/ts/odyssey-react-mui_nb.d.ts.map +1 -1
  289. package/dist/src/properties/ts/odyssey-react-mui_nl_NL.d.ts +2 -0
  290. package/dist/src/properties/ts/odyssey-react-mui_nl_NL.d.ts.map +1 -1
  291. package/dist/src/properties/ts/odyssey-react-mui_pl.d.ts +2 -0
  292. package/dist/src/properties/ts/odyssey-react-mui_pl.d.ts.map +1 -1
  293. package/dist/src/properties/ts/odyssey-react-mui_pt_BR.d.ts +2 -0
  294. package/dist/src/properties/ts/odyssey-react-mui_pt_BR.d.ts.map +1 -1
  295. package/dist/src/properties/ts/odyssey-react-mui_ro.d.ts +2 -0
  296. package/dist/src/properties/ts/odyssey-react-mui_ro.d.ts.map +1 -1
  297. package/dist/src/properties/ts/odyssey-react-mui_ru.d.ts +2 -0
  298. package/dist/src/properties/ts/odyssey-react-mui_ru.d.ts.map +1 -1
  299. package/dist/src/properties/ts/odyssey-react-mui_sv.d.ts +2 -0
  300. package/dist/src/properties/ts/odyssey-react-mui_sv.d.ts.map +1 -1
  301. package/dist/src/properties/ts/odyssey-react-mui_th.d.ts +2 -0
  302. package/dist/src/properties/ts/odyssey-react-mui_th.d.ts.map +1 -1
  303. package/dist/src/properties/ts/odyssey-react-mui_tr.d.ts +2 -0
  304. package/dist/src/properties/ts/odyssey-react-mui_tr.d.ts.map +1 -1
  305. package/dist/src/properties/ts/odyssey-react-mui_uk.d.ts +2 -0
  306. package/dist/src/properties/ts/odyssey-react-mui_uk.d.ts.map +1 -1
  307. package/dist/src/properties/ts/odyssey-react-mui_vi.d.ts +2 -0
  308. package/dist/src/properties/ts/odyssey-react-mui_vi.d.ts.map +1 -1
  309. package/dist/src/properties/ts/odyssey-react-mui_zh_CN.d.ts +2 -0
  310. package/dist/src/properties/ts/odyssey-react-mui_zh_CN.d.ts.map +1 -1
  311. package/dist/src/properties/ts/odyssey-react-mui_zh_TW.d.ts +2 -0
  312. package/dist/src/properties/ts/odyssey-react-mui_zh_TW.d.ts.map +1 -1
  313. package/dist/src/test-selectors/querySelector.d.ts +2 -2
  314. package/dist/src/theme/components.d.ts +3 -1
  315. package/dist/src/theme/components.d.ts.map +1 -1
  316. package/dist/src/theme/createOdysseyMuiTheme.d.ts +2 -1
  317. package/dist/src/theme/createOdysseyMuiTheme.d.ts.map +1 -1
  318. package/dist/src/useAutocomplete.d.ts +29 -0
  319. package/dist/src/useAutocomplete.d.ts.map +1 -0
  320. package/dist/src/useContrastMode.d.ts +46 -0
  321. package/dist/src/useContrastMode.d.ts.map +1 -0
  322. package/dist/src/web-component/index.d.ts +14 -0
  323. package/dist/src/web-component/index.d.ts.map +1 -0
  324. package/dist/src/web-component/renderReactInWebComponent.d.ts +76 -0
  325. package/dist/src/web-component/renderReactInWebComponent.d.ts.map +1 -0
  326. package/dist/src/web-component/shadow-dom.d.ts +23 -0
  327. package/dist/src/web-component/shadow-dom.d.ts.map +1 -0
  328. package/dist/test-selectors/querySelector.js.map +1 -1
  329. package/dist/theme/components.js +36 -32
  330. package/dist/theme/components.js.map +1 -1
  331. package/dist/theme/createOdysseyMuiTheme.js +3 -2
  332. package/dist/theme/createOdysseyMuiTheme.js.map +1 -1
  333. package/dist/tsconfig.production.tsbuildinfo +1 -1
  334. package/dist/tsconfig.tsbuildinfo +1 -1
  335. package/dist/useAutocomplete.js +105 -0
  336. package/dist/useAutocomplete.js.map +1 -0
  337. package/dist/useContrastMode.js +93 -0
  338. package/dist/useContrastMode.js.map +1 -0
  339. package/dist/web-component/index.js +14 -0
  340. package/dist/web-component/index.js.map +1 -0
  341. package/dist/web-component/renderReactInWebComponent.js +72 -0
  342. package/dist/web-component/renderReactInWebComponent.js.map +1 -0
  343. package/dist/{createShadowDomElements.js → web-component/shadow-dom.js} +10 -12
  344. package/dist/web-component/shadow-dom.js.map +1 -0
  345. package/jest.config.cjs +1 -1
  346. package/jest.setup.js +0 -3
  347. package/package.json +4 -3
  348. package/src/Autocomplete.tsx +40 -330
  349. package/src/Box.tsx +4 -2
  350. package/src/Card.tsx +1 -0
  351. package/src/OdysseyDesignTokensContext.tsx +6 -3
  352. package/src/OdysseyProvider.tsx +13 -8
  353. package/src/OdysseyThemeProvider.test.tsx +209 -0
  354. package/src/OdysseyThemeProvider.tsx +42 -26
  355. package/src/Pagination/Pagination.test.tsx +305 -0
  356. package/src/Pagination/Pagination.tsx +86 -38
  357. package/src/Surface.tsx +2 -1
  358. package/src/Tag.tsx +64 -39
  359. package/src/createUniqueAlphabeticalId.test.ts +1 -1
  360. package/src/createUniqueId.test.ts +1 -1
  361. package/src/index.ts +6 -7
  362. package/src/labs/AppTile.tsx +169 -40
  363. package/src/labs/DataView/CardLayoutContent.tsx +12 -14
  364. package/src/labs/DataView/DataCard.tsx +137 -69
  365. package/src/labs/DataView/DataView.test.tsx +6 -4
  366. package/src/labs/DataView/TableLayoutContent.tsx +6 -2
  367. package/src/labs/DataView/componentTypes.ts +1 -1
  368. package/src/labs/DataView/index.tsx +1 -0
  369. package/src/labs/OdysseyPickers/ComposablePicker.test.tsx +29 -0
  370. package/src/labs/OdysseyPickers/ComposablePicker.tsx +188 -0
  371. package/src/labs/OdysseyPickers/Picker.tsx +381 -0
  372. package/src/labs/OdysseyPickers/PickerVirtualizationListBox.tsx +191 -0
  373. package/src/labs/OdysseyPickers/PickerWithOptionAdornment.tsx +429 -0
  374. package/src/labs/OdysseyPickers/index.ts +15 -0
  375. package/src/labs/PageTemplate.tsx +18 -10
  376. package/src/labs/SideNav/CollapseIcon.tsx +14 -28
  377. package/src/labs/SideNav/HandleIcon.tsx +35 -0
  378. package/src/labs/{NavAccordion.tsx → SideNav/NavAccordion.tsx} +48 -8
  379. package/src/labs/SideNav/OktaAura.tsx +35 -0
  380. package/src/labs/SideNav/OktaLogo.tsx +5 -10
  381. package/src/labs/SideNav/SideNav.test.tsx +323 -0
  382. package/src/labs/SideNav/SideNav.tsx +291 -204
  383. package/src/labs/SideNav/SideNavFooterContent.tsx +36 -28
  384. package/src/labs/SideNav/SideNavHeader.tsx +62 -45
  385. package/src/labs/SideNav/SideNavItemContent.tsx +142 -62
  386. package/src/labs/SideNav/SideNavItemContentContext.tsx +27 -0
  387. package/src/labs/SideNav/SideNavItemLinkContent.tsx +17 -14
  388. package/src/labs/SideNav/SideNavLogo.tsx +41 -0
  389. package/src/labs/SideNav/SideNavToggleButton.tsx +249 -0
  390. package/src/labs/SideNav/types.ts +72 -33
  391. package/src/labs/TopNav/TopNav.tsx +95 -0
  392. package/src/labs/TopNav/TopNavLinksList.tsx +68 -0
  393. package/src/labs/TopNav/TopNavListItem.tsx +209 -0
  394. package/src/labs/TopNav/UserProfile.tsx +79 -0
  395. package/src/labs/TopNav/index.ts +14 -0
  396. package/src/labs/UiShell/UiShell.test.tsx +284 -0
  397. package/src/labs/UiShell/UiShell.tsx +109 -0
  398. package/src/labs/UiShell/UiShellContent.tsx +170 -0
  399. package/src/labs/UiShell/bufferLatest.test.ts +79 -0
  400. package/src/labs/UiShell/bufferLatest.ts +64 -0
  401. package/src/labs/UiShell/createMessageBus.test.ts +115 -0
  402. package/src/labs/UiShell/createMessageBus.ts +53 -0
  403. package/src/labs/UiShell/createStore.test.ts +103 -0
  404. package/src/labs/UiShell/createStore.ts +37 -0
  405. package/src/labs/UiShell/index.ts +17 -0
  406. package/src/labs/UiShell/renderUiShell.test.tsx +197 -0
  407. package/src/labs/UiShell/renderUiShell.tsx +132 -0
  408. package/src/labs/UiShell/useHasUiShell.ts +25 -0
  409. package/src/labs/UiShell/useScrollState.ts +56 -0
  410. package/src/labs/index.ts +10 -3
  411. package/src/properties/odyssey-react-mui.properties +7 -0
  412. package/src/properties/translations/odyssey-react-mui_cs.properties +2 -1
  413. package/src/properties/translations/odyssey-react-mui_da.properties +2 -1
  414. package/src/properties/translations/odyssey-react-mui_de.properties +2 -1
  415. package/src/properties/translations/odyssey-react-mui_el.properties +2 -1
  416. package/src/properties/translations/odyssey-react-mui_es.properties +2 -1
  417. package/src/properties/translations/odyssey-react-mui_fi.properties +2 -1
  418. package/src/properties/translations/odyssey-react-mui_fr.properties +4 -3
  419. package/src/properties/translations/odyssey-react-mui_ht.properties +2 -1
  420. package/src/properties/translations/odyssey-react-mui_hu.properties +2 -1
  421. package/src/properties/translations/odyssey-react-mui_id.properties +2 -1
  422. package/src/properties/translations/odyssey-react-mui_it.properties +3 -2
  423. package/src/properties/translations/odyssey-react-mui_ja.properties +8 -7
  424. package/src/properties/translations/odyssey-react-mui_ko.properties +2 -1
  425. package/src/properties/translations/odyssey-react-mui_ms.properties +2 -1
  426. package/src/properties/translations/odyssey-react-mui_nb.properties +2 -1
  427. package/src/properties/translations/odyssey-react-mui_nl_NL.properties +2 -1
  428. package/src/properties/translations/odyssey-react-mui_pl.properties +2 -1
  429. package/src/properties/translations/odyssey-react-mui_pt_BR.properties +2 -1
  430. package/src/properties/translations/odyssey-react-mui_ro.properties +2 -1
  431. package/src/properties/translations/odyssey-react-mui_ru.properties +2 -1
  432. package/src/properties/translations/odyssey-react-mui_sv.properties +2 -1
  433. package/src/properties/translations/odyssey-react-mui_th.properties +2 -1
  434. package/src/properties/translations/odyssey-react-mui_tr.properties +3 -2
  435. package/src/properties/translations/odyssey-react-mui_uk.properties +2 -1
  436. package/src/properties/translations/odyssey-react-mui_vi.properties +2 -1
  437. package/src/properties/translations/odyssey-react-mui_zh_CN.properties +2 -1
  438. package/src/properties/translations/odyssey-react-mui_zh_TW.properties +2 -1
  439. package/src/properties/ts/odyssey-react-mui.ts +1 -1
  440. package/src/properties/ts/odyssey-react-mui_cs.ts +1 -1
  441. package/src/properties/ts/odyssey-react-mui_da.ts +1 -1
  442. package/src/properties/ts/odyssey-react-mui_de.ts +1 -1
  443. package/src/properties/ts/odyssey-react-mui_el.ts +1 -1
  444. package/src/properties/ts/odyssey-react-mui_es.ts +1 -1
  445. package/src/properties/ts/odyssey-react-mui_fi.ts +1 -1
  446. package/src/properties/ts/odyssey-react-mui_fr.ts +1 -1
  447. package/src/properties/ts/odyssey-react-mui_ht.ts +1 -1
  448. package/src/properties/ts/odyssey-react-mui_hu.ts +1 -1
  449. package/src/properties/ts/odyssey-react-mui_id.ts +1 -1
  450. package/src/properties/ts/odyssey-react-mui_it.ts +1 -1
  451. package/src/properties/ts/odyssey-react-mui_ja.ts +1 -1
  452. package/src/properties/ts/odyssey-react-mui_ko.ts +1 -1
  453. package/src/properties/ts/odyssey-react-mui_ms.ts +1 -1
  454. package/src/properties/ts/odyssey-react-mui_nb.ts +1 -1
  455. package/src/properties/ts/odyssey-react-mui_nl_NL.ts +1 -1
  456. package/src/properties/ts/odyssey-react-mui_pl.ts +1 -1
  457. package/src/properties/ts/odyssey-react-mui_pt_BR.ts +1 -1
  458. package/src/properties/ts/odyssey-react-mui_ro.ts +1 -1
  459. package/src/properties/ts/odyssey-react-mui_ru.ts +1 -1
  460. package/src/properties/ts/odyssey-react-mui_sv.ts +1 -1
  461. package/src/properties/ts/odyssey-react-mui_th.ts +1 -1
  462. package/src/properties/ts/odyssey-react-mui_tr.ts +1 -1
  463. package/src/properties/ts/odyssey-react-mui_uk.ts +1 -1
  464. package/src/properties/ts/odyssey-react-mui_vi.ts +1 -1
  465. package/src/properties/ts/odyssey-react-mui_zh_CN.ts +1 -1
  466. package/src/properties/ts/odyssey-react-mui_zh_TW.ts +1 -1
  467. package/src/test-selectors/querySelector.ts +1 -1
  468. package/src/theme/components.tsx +50 -33
  469. package/src/theme/createOdysseyMuiTheme.ts +4 -3
  470. package/src/theme/useContrastMode.test.tsx +503 -0
  471. package/src/useAutocomplete.tsx +183 -0
  472. package/src/useContrastMode.tsx +149 -0
  473. package/src/web-component/index.ts +14 -0
  474. package/src/web-component/renderReactInWebComponent.test.tsx +156 -0
  475. package/src/web-component/renderReactInWebComponent.ts +153 -0
  476. package/src/web-component/shadow-dom.test.ts +24 -0
  477. package/src/{createShadowDomElements.ts → web-component/shadow-dom.ts} +15 -14
  478. package/dist/ContrastModeProvider.js +0 -86
  479. package/dist/ContrastModeProvider.js.map +0 -1
  480. package/dist/createShadowDomElements.js.map +0 -1
  481. package/dist/labs/NavAccordion.js.map +0 -1
  482. package/dist/labs/TopNav.js +0 -281
  483. package/dist/labs/TopNav.js.map +0 -1
  484. package/dist/src/ContrastModeProvider.d.ts +0 -34
  485. package/dist/src/ContrastModeProvider.d.ts.map +0 -1
  486. package/dist/src/createShadowDomElements.d.ts.map +0 -1
  487. package/dist/src/labs/NavAccordion.d.ts.map +0 -1
  488. package/dist/src/labs/TopNav.d.ts +0 -78
  489. package/dist/src/labs/TopNav.d.ts.map +0 -1
  490. package/src/ContrastModeProvider.tsx +0 -131
  491. package/src/labs/TopNav.tsx +0 -396
@@ -11,10 +11,30 @@
11
11
  */
12
12
 
13
13
  import { memo, useMemo } from "react";
14
- import { useOdysseyDesignTokens } from "../../OdysseyDesignTokensContext";
14
+ import styled from "@emotion/styled";
15
+
16
+ import {
17
+ useOdysseyDesignTokens,
18
+ DesignTokens,
19
+ } from "../../OdysseyDesignTokensContext";
15
20
  import type { SideNavFooterItem } from "./types";
16
21
  import { Box } from "../../Box";
17
22
  import { Link } from "../../Link";
23
+ import { useTranslation } from "react-i18next";
24
+
25
+ const StyledFooterNav = styled("nav")({
26
+ display: "flex",
27
+ });
28
+
29
+ const StyledFooterItemContainer = styled("div", {
30
+ shouldForwardProp: (prop) => prop !== "odysseyDesignTokens",
31
+ })(({ odysseyDesignTokens }: { odysseyDesignTokens: DesignTokens }) => ({
32
+ "& + &": {
33
+ marginInlineStart: odysseyDesignTokens.Spacing4,
34
+ paddingInlineStart: odysseyDesignTokens.Spacing4,
35
+ borderInlineStart: `1px solid ${odysseyDesignTokens.HueNeutral300}`,
36
+ },
37
+ }));
18
38
 
19
39
  const SideNavFooterContent = ({
20
40
  footerItems,
@@ -22,41 +42,29 @@ const SideNavFooterContent = ({
22
42
  footerItems: SideNavFooterItem[];
23
43
  }) => {
24
44
  const odysseyDesignTokens = useOdysseyDesignTokens();
45
+ const { t } = useTranslation();
25
46
 
26
- const footerContent = useMemo(() => {
27
- return footerItems?.map((item, index) => (
28
- <Box
29
- key={`${item.id}-wrapper`}
30
- sx={{
31
- display: "flex",
32
- }}
47
+ const memoizedFooterContent = useMemo(() => {
48
+ return footerItems?.map((item) => (
49
+ <StyledFooterItemContainer
50
+ key={item.id}
51
+ odysseyDesignTokens={odysseyDesignTokens}
52
+ role="menuitem"
33
53
  >
34
54
  {item.href ? (
35
- <Link key={item.id} href={item.href}>
36
- {item.label}
37
- </Link>
55
+ <Link href={item.href}>{item.label}</Link>
38
56
  ) : (
39
- <Box component="span" key={item.id}>
40
- {item.label}
41
- </Box>
42
- )}
43
- {index < footerItems.length - 1 && (
44
- <Box
45
- key={`${item.id}-separator`}
46
- sx={{
47
- marginLeft: odysseyDesignTokens.Spacing4,
48
- marginRight: odysseyDesignTokens.Spacing4,
49
- color: odysseyDesignTokens.HueNeutral300,
50
- }}
51
- >
52
- |
53
- </Box>
57
+ <Box component="span">{item.label}</Box>
54
58
  )}
55
- </Box>
59
+ </StyledFooterItemContainer>
56
60
  ));
57
61
  }, [footerItems, odysseyDesignTokens]);
58
62
 
59
- return footerContent;
63
+ return (
64
+ <StyledFooterNav role="menubar" aria-label={t("navigation.footer")}>
65
+ {memoizedFooterContent}
66
+ </StyledFooterNav>
67
+ );
60
68
  };
61
69
  const MemoizedSideNavFooterContent = memo(SideNavFooterContent);
62
70
  MemoizedSideNavFooterContent.displayName = "SideNavFooterContent";
@@ -11,77 +11,94 @@
11
11
  */
12
12
 
13
13
  import styled from "@emotion/styled";
14
- import { memo, ReactNode, useMemo } from "react";
14
+ import { memo } from "react";
15
+ import { Skeleton } from "@mui/material";
16
+
15
17
  import {
16
18
  type DesignTokens,
17
19
  useOdysseyDesignTokens,
18
20
  } from "../../OdysseyDesignTokensContext";
19
- import { Box } from "../../Box";
21
+ import { SideNavLogo } from "./SideNavLogo";
22
+ import { SideNavProps } from "./types";
20
23
  import { Heading6 } from "../../Typography";
21
- import { CollapseIcon } from "./CollapseIcon";
22
- import type { SideNavProps } from "./types";
23
- import { TOP_NAV_HEIGHT_TOKEN } from "../TopNav";
24
+ import { TOP_NAV_HEIGHT } from "../TopNav";
25
+
26
+ const SideNavHeaderContainer = styled("div", {
27
+ shouldForwardProp: (prop) => prop !== "odysseyDesignTokens",
28
+ })(({ odysseyDesignTokens }: { odysseyDesignTokens: DesignTokens }) => ({
29
+ position: "relative",
30
+ display: "flex",
31
+ flexDirection: "column",
32
+ backgroundColor: odysseyDesignTokens.HueNeutralWhite,
33
+ zIndex: 1,
34
+ }));
24
35
 
25
36
  const SideNavLogoContainer = styled("div", {
26
37
  shouldForwardProp: (prop) => prop !== "odysseyDesignTokens",
27
38
  })(({ odysseyDesignTokens }: { odysseyDesignTokens: DesignTokens }) => ({
28
- height: odysseyDesignTokens[TOP_NAV_HEIGHT_TOKEN],
29
- padding: odysseyDesignTokens.Spacing3,
30
- borderColor: odysseyDesignTokens.HueNeutral50,
31
- borderStyle: odysseyDesignTokens.BorderStyleMain,
32
- borderWidth: 0,
33
- borderBottomWidth: odysseyDesignTokens.BorderWidthMain,
39
+ display: "flex",
40
+ alignItems: "center",
41
+ height: TOP_NAV_HEIGHT,
42
+ padding: odysseyDesignTokens.Spacing4,
43
+
44
+ "svg, img": {
45
+ maxHeight: "100%",
46
+ width: "auto",
47
+ maxWidth: "100%",
48
+ },
34
49
  }));
35
50
 
36
- const SideNavHeaderContainer = styled("div", {
51
+ const SideNavHeadingContainer = styled("div", {
37
52
  shouldForwardProp: (prop) => prop !== "odysseyDesignTokens",
38
53
  })(({ odysseyDesignTokens }: { odysseyDesignTokens: DesignTokens }) => ({
39
54
  display: "flex",
40
55
  justifyContent: "space-between",
41
56
  alignItems: "center",
42
- paddingLeft: odysseyDesignTokens.Spacing4,
43
- paddingRight: odysseyDesignTokens.Spacing4,
44
- paddingTop: odysseyDesignTokens.Spacing3,
45
- paddingBottom: odysseyDesignTokens.Spacing3,
57
+ padding: odysseyDesignTokens.Spacing4,
58
+ width: "100%",
59
+
60
+ ["& .MuiTypography-root"]: {
61
+ margin: 0,
62
+ width: "100%",
63
+ },
46
64
  }));
47
65
 
66
+ export type SideNavHeaderProps = {
67
+ /**
68
+ * The app's name.
69
+ */
70
+ appName: string;
71
+ /**
72
+ * If the side nav currently has no items, it will be loading.
73
+ */
74
+ isLoading?: boolean;
75
+ } & Pick<SideNavProps, "logoProps">;
76
+
48
77
  const SideNavHeader = ({
49
- navHeaderText,
50
- isCollapsible,
51
- onCollapse,
52
- logo,
53
- }: Pick<
54
- SideNavProps,
55
- "navHeaderText" | "isCollapsible" | "onCollapse" | "logo"
56
- >): ReactNode => {
78
+ appName,
79
+ isLoading,
80
+ logoProps,
81
+ }: SideNavHeaderProps) => {
57
82
  const odysseyDesignTokens = useOdysseyDesignTokens();
58
83
 
59
- const sideNavHeaderStyles = useMemo(
60
- () => ({
61
- marginTop: odysseyDesignTokens.Spacing2,
62
- }),
63
- [odysseyDesignTokens],
64
- );
65
-
66
84
  return (
67
- <Box
68
- sx={{
69
- display: "flex",
70
- flexDirection: "column",
71
- }}
72
- >
85
+ <SideNavHeaderContainer odysseyDesignTokens={odysseyDesignTokens}>
73
86
  <SideNavLogoContainer odysseyDesignTokens={odysseyDesignTokens}>
74
- {logo}
87
+ {isLoading ? (
88
+ // The skeleton takes the hardcoded dimensions of the Okta logo
89
+ <Skeleton variant="rounded" height={24} width={67} />
90
+ ) : (
91
+ <SideNavLogo {...logoProps} />
92
+ )}
75
93
  </SideNavLogoContainer>
76
- <SideNavHeaderContainer odysseyDesignTokens={odysseyDesignTokens}>
77
- <Box sx={sideNavHeaderStyles}>
78
- <Heading6>{navHeaderText}</Heading6>
79
- </Box>
80
- {isCollapsible && <CollapseIcon onClick={onCollapse} />}
81
- </SideNavHeaderContainer>
82
- </Box>
94
+
95
+ <SideNavHeadingContainer odysseyDesignTokens={odysseyDesignTokens}>
96
+ <Heading6 component="h2">{isLoading ? <Skeleton /> : appName}</Heading6>
97
+ </SideNavHeadingContainer>
98
+ </SideNavHeaderContainer>
83
99
  );
84
100
  };
101
+
85
102
  const MemoizedSideNavHeader = memo(SideNavHeader);
86
103
  MemoizedSideNavHeader.displayName = "SideNavHeader";
87
104
 
@@ -17,55 +17,44 @@ import {
17
17
  useCallback,
18
18
  memo,
19
19
  KeyboardEvent,
20
+ useMemo,
20
21
  } from "react";
21
- import { Link } from "../../Link";
22
+ import { Link as NavItemLink } from "@mui/material";
22
23
  import {
23
24
  type DesignTokens,
24
25
  useOdysseyDesignTokens,
25
26
  } from "../../OdysseyDesignTokensContext";
26
27
  import { SideNavItemLinkContent } from "./SideNavItemLinkContent";
27
28
  import type { SideNavItem } from "./types";
29
+ import {
30
+ SideNavItemContentContextValue,
31
+ useSideNavItemContent,
32
+ } from "./SideNavItemContentContext";
33
+ import { ExternalLinkIcon } from "../../icons.generated";
28
34
 
29
- export const SideNavListItemContainer = styled("li", {
35
+ export const StyledSideNavListItem = styled("li", {
30
36
  shouldForwardProp: (prop) =>
31
- prop !== "odysseyDesignTokens" &&
32
- prop !== "isSelected" &&
33
- prop !== "isDisabled",
37
+ prop !== "odysseyDesignTokens" && prop !== "isSelected",
34
38
  })<{
35
39
  odysseyDesignTokens: DesignTokens;
36
40
  isSelected?: boolean;
37
41
  disabled?: boolean;
38
- isDisabled?: boolean;
39
- }>(({ odysseyDesignTokens, isSelected, isDisabled }) => ({
42
+ }>(({ odysseyDesignTokens, isSelected }) => ({
40
43
  display: "flex",
41
44
  alignItems: "center",
42
- cursor: isDisabled ? "default" : "pointer",
43
- pointerEvents: isDisabled ? "none" : "auto",
44
- backgroundColor: isSelected ? odysseyDesignTokens.HueNeutral50 : "unset",
45
- margin: `${odysseyDesignTokens.Spacing1} 0`,
45
+ backgroundColor: "unset",
46
+ borderRadius: odysseyDesignTokens.BorderRadiusMain,
47
+ lineHeight: 1.5,
48
+ transition: `backgroundColor ${odysseyDesignTokens.TransitionDurationMain}, color ${odysseyDesignTokens.TransitionDurationMain}`,
49
+
50
+ ...(isSelected && {
51
+ color: `${odysseyDesignTokens.TypographyColorAction} !important`,
52
+ backgroundColor: odysseyDesignTokens.HueBlue50,
53
+ }),
54
+
46
55
  "&:last-child": {
47
56
  marginBottom: odysseyDesignTokens.Spacing2,
48
57
  },
49
- "& a": {
50
- display: "flex",
51
- alignItems: "center",
52
- width: "100%",
53
- minHeight: "48px",
54
- padding: `${odysseyDesignTokens.Spacing3} ${odysseyDesignTokens.Spacing4}`,
55
- color: `${odysseyDesignTokens.TypographyColorHeading} !important`,
56
- pointerEvents: isDisabled ? "none" : "auto",
57
- },
58
- "& a:hover": {
59
- textDecoration: "none",
60
- cursor: isDisabled ? "default" : "pointer",
61
- backgroundColor: !isDisabled ? odysseyDesignTokens.HueNeutral50 : "inherit",
62
- },
63
- "& a:focus-visible": {
64
- outlineOffset: 0,
65
- borderRadius: 0,
66
- outlineWidth: odysseyDesignTokens.FocusOutlineWidthMain,
67
- backgroundColor: !isDisabled ? odysseyDesignTokens.HueNeutral50 : "inherit",
68
- },
69
58
  }));
70
59
 
71
60
  const scrollToNode = (node: HTMLElement | null) => {
@@ -82,7 +71,87 @@ type ScrollIntoViewHandle = {
82
71
  scrollIntoView: () => void;
83
72
  };
84
73
 
74
+ const GetNavItemContentStyles = ({
75
+ odysseyDesignTokens,
76
+ contextValue,
77
+ isDisabled,
78
+ isSelected,
79
+ }: {
80
+ odysseyDesignTokens: DesignTokens;
81
+ contextValue: SideNavItemContentContextValue;
82
+ isDisabled?: boolean;
83
+ isSelected?: boolean;
84
+ }) => {
85
+ return {
86
+ display: "flex",
87
+ alignItems: "center",
88
+ width: "100%",
89
+ textDecoration: "none",
90
+ color: `${odysseyDesignTokens.TypographyColorHeading} !important`,
91
+ minHeight: odysseyDesignTokens.Spacing7,
92
+ paddingBlock: odysseyDesignTokens.Spacing4,
93
+ paddingInline: `calc(${odysseyDesignTokens.Spacing4} * ${contextValue.depth})`,
94
+ borderRadius: odysseyDesignTokens.BorderRadiusMain,
95
+ transition: `backgroundColor ${odysseyDesignTokens.TransitionDurationMain}, color ${odysseyDesignTokens.TransitionDurationMain}`,
96
+
97
+ "&:hover": {
98
+ textDecoration: "none",
99
+ cursor: "pointer",
100
+ backgroundColor: !isDisabled
101
+ ? odysseyDesignTokens.HueNeutral50
102
+ : "inherit",
103
+
104
+ ...(isDisabled && {
105
+ color: "inherit",
106
+ cursor: "default",
107
+ }),
108
+
109
+ ...(isSelected && {
110
+ "&:hover": {
111
+ backgroundColor: odysseyDesignTokens.HueBlue50,
112
+ },
113
+ }),
114
+ },
115
+
116
+ ...(isSelected && {
117
+ color: `${odysseyDesignTokens.TypographyColorAction} !important`,
118
+ fontWeight: odysseyDesignTokens.TypographyWeightBodyBold,
119
+ }),
120
+
121
+ ...(isDisabled && {
122
+ color: `${odysseyDesignTokens.TypographyColorDisabled} !important`,
123
+ }),
124
+
125
+ ...(contextValue.isCompact && {
126
+ paddingBlock: odysseyDesignTokens.Spacing1,
127
+ minHeight: odysseyDesignTokens.Spacing6,
128
+ }),
129
+
130
+ "&:focus-visible": {
131
+ outline: "none",
132
+ boxShadow: `inset 0 0 0 3px ${odysseyDesignTokens.PalettePrimaryMain}`,
133
+ },
134
+ };
135
+ };
136
+
137
+ const NavItemContentContainer = styled("div", {
138
+ shouldForwardProp: (prop) =>
139
+ prop !== "odysseyDesignTokens" &&
140
+ prop != "contextValue" &&
141
+ prop !== "isDisabled" &&
142
+ prop !== "isSelected",
143
+ })(GetNavItemContentStyles);
144
+
145
+ const NavItemLinkContainer = styled(NavItemLink, {
146
+ shouldForwardProp: (prop) =>
147
+ prop !== "odysseyDesignTokens" &&
148
+ prop != "contextValue" &&
149
+ prop !== "isDisabled" &&
150
+ prop !== "isSelected",
151
+ })(GetNavItemContentStyles);
152
+
85
153
  const SideNavItemContent = ({
154
+ count,
86
155
  id,
87
156
  label,
88
157
  href,
@@ -97,6 +166,7 @@ const SideNavItemContent = ({
97
166
  scrollRef,
98
167
  }: Pick<
99
168
  SideNavItem,
169
+ | "count"
100
170
  | "id"
101
171
  | "label"
102
172
  | "href"
@@ -114,6 +184,13 @@ const SideNavItemContent = ({
114
184
  */
115
185
  scrollRef?: React.RefObject<ScrollIntoViewHandle>;
116
186
  }) => {
187
+ const sidenavItemContentContext = useSideNavItemContent();
188
+ const contextValue = useMemo(
189
+ () => sidenavItemContentContext,
190
+ [sidenavItemContentContext],
191
+ );
192
+ const odysseyDesignTokens = useOdysseyDesignTokens();
193
+
117
194
  const localScrollRef = useRef<HTMLLIElement>(null);
118
195
  useImperativeHandle(
119
196
  scrollRef,
@@ -126,26 +203,6 @@ const SideNavItemContent = ({
126
203
  },
127
204
  [],
128
205
  );
129
- const odysseyDesignTokens = useOdysseyDesignTokens();
130
-
131
- const NavItemContentClickContainer = styled("div", {
132
- shouldForwardProp: (prop) => prop !== "odysseyDesignTokens",
133
- })(() => ({
134
- display: "flex",
135
- alignItems: "center",
136
- width: "100%",
137
- minHeight: "48px",
138
- padding: `${odysseyDesignTokens.Spacing3} ${odysseyDesignTokens.Spacing4}`,
139
- color: `${isDisabled ? odysseyDesignTokens.TypographyColorDisabled : odysseyDesignTokens.TypographyColorHeading} !important`,
140
- "&:focus-visible": {
141
- borderRadius: 0,
142
- outlineColor: odysseyDesignTokens.FocusOutlineColorPrimary,
143
- outlineStyle: odysseyDesignTokens.FocusOutlineStyle,
144
- outlineWidth: odysseyDesignTokens.FocusOutlineWidthMain,
145
- backgroundColor: odysseyDesignTokens.HueNeutral50,
146
- textDecoration: "none",
147
- },
148
- }));
149
206
 
150
207
  const sideNavItemContentKeyHandler = useCallback(
151
208
  (event: KeyboardEvent<HTMLDivElement>) => {
@@ -158,56 +215,79 @@ const SideNavItemContent = ({
158
215
  );
159
216
 
160
217
  return (
161
- <SideNavListItemContainer
218
+ <StyledSideNavListItem
162
219
  ref={localScrollRef}
163
220
  id={id}
164
221
  key={id}
222
+ isSelected={isSelected}
165
223
  disabled={isDisabled}
166
224
  aria-disabled={isDisabled}
167
- isDisabled={isDisabled}
168
- isSelected={isSelected}
225
+ aria-current={isSelected ? "page" : undefined}
169
226
  odysseyDesignTokens={odysseyDesignTokens}
170
227
  >
171
228
  {
172
229
  // Use Link for nav items with links and div for disabled or non-link items
173
230
  isDisabled ? (
174
- <NavItemContentClickContainer>
231
+ <NavItemContentContainer
232
+ odysseyDesignTokens={odysseyDesignTokens}
233
+ contextValue={contextValue}
234
+ isDisabled={isDisabled}
235
+ isSelected={isSelected}
236
+ >
175
237
  <SideNavItemLinkContent
238
+ count={count}
176
239
  label={label}
177
240
  startIcon={startIcon}
178
241
  endIcon={endIcon}
179
242
  statusLabel={statusLabel}
180
243
  severity={severity}
181
244
  />
182
- </NavItemContentClickContainer>
245
+ </NavItemContentContainer>
183
246
  ) : !href ? (
184
- <NavItemContentClickContainer
185
- role="button"
247
+ <NavItemContentContainer
248
+ odysseyDesignTokens={odysseyDesignTokens}
249
+ contextValue={contextValue}
250
+ isDisabled={isDisabled}
186
251
  tabIndex={0}
187
252
  onClick={onClick}
188
253
  onKeyDown={sideNavItemContentKeyHandler}
189
254
  >
190
255
  <SideNavItemLinkContent
256
+ count={count}
191
257
  label={label}
192
258
  startIcon={startIcon}
193
259
  endIcon={endIcon}
194
260
  statusLabel={statusLabel}
195
261
  severity={severity}
196
262
  />
197
- </NavItemContentClickContainer>
263
+ </NavItemContentContainer>
198
264
  ) : (
199
- <Link href={href} target={target} onClick={onClick}>
265
+ <NavItemLinkContainer
266
+ odysseyDesignTokens={odysseyDesignTokens}
267
+ contextValue={contextValue}
268
+ isDisabled={isDisabled}
269
+ isSelected={isSelected}
270
+ href={href}
271
+ target={target}
272
+ onClick={onClick}
273
+ >
200
274
  <SideNavItemLinkContent
275
+ count={count}
201
276
  label={label}
202
277
  startIcon={startIcon}
203
278
  endIcon={endIcon}
204
279
  statusLabel={statusLabel}
205
280
  severity={severity}
206
281
  />
207
- </Link>
282
+ {target === "_blank" && (
283
+ <span className="Link-indicator" role="presentation">
284
+ <ExternalLinkIcon />
285
+ </span>
286
+ )}
287
+ </NavItemLinkContainer>
208
288
  )
209
289
  }
210
- </SideNavListItemContainer>
290
+ </StyledSideNavListItem>
211
291
  );
212
292
  };
213
293
  const MemoizedSideNavItemContent = memo(SideNavItemContent);
@@ -0,0 +1,27 @@
1
+ /*!
2
+ * Copyright (c) 2024-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 SideNavItemContentContextValue = {
16
+ isCompact?: boolean;
17
+ depth: number;
18
+ };
19
+
20
+ export const SideNavItemContentContext =
21
+ createContext<SideNavItemContentContextValue>({
22
+ isCompact: false,
23
+ depth: 1,
24
+ });
25
+
26
+ export const useSideNavItemContent = () =>
27
+ useContext(SideNavItemContentContext);
@@ -19,6 +19,7 @@ import {
19
19
  import { Box } from "../../Box";
20
20
  import { Status } from "../../Status";
21
21
  import type { SideNavItem } from "./types";
22
+ import { Badge } from "../../Badge";
22
23
 
23
24
  const SideNavItemLabelContainer = styled("div", {
24
25
  shouldForwardProp: (prop) =>
@@ -32,19 +33,11 @@ const SideNavItemLabelContainer = styled("div", {
32
33
  flexWrap: "wrap",
33
34
  alignItems: "center",
34
35
  fontSize: odysseyDesignTokens.TypographyScale0,
35
- fontWeight: odysseyDesignTokens.TypographyWeightHeading,
36
- marginLeft: isIconVisible ? odysseyDesignTokens.Spacing2 : 0,
37
- "& a": {
38
- color: `${odysseyDesignTokens.TypographyColorHeading} !important`,
39
- fontSize: odysseyDesignTokens.TypographyScale0,
40
- },
41
- "& a:hover": {
42
- textDecoration: "none",
43
- cursor: "pointer",
44
- },
36
+ marginInlineStart: isIconVisible ? odysseyDesignTokens.Spacing2 : 0,
45
37
  }));
46
38
 
47
39
  const SideNavItemLinkContent = ({
40
+ count,
48
41
  label,
49
42
  startIcon,
50
43
  endIcon,
@@ -52,13 +45,16 @@ const SideNavItemLinkContent = ({
52
45
  statusLabel,
53
46
  }: Pick<
54
47
  SideNavItem,
55
- "label" | "startIcon" | "endIcon" | "severity" | "statusLabel"
48
+ "count" | "label" | "startIcon" | "endIcon" | "severity" | "statusLabel"
56
49
  >): ReactNode => {
57
50
  const odysseyDesignTokens = useOdysseyDesignTokens();
58
51
 
59
52
  const sideNavItemContentStyles = useMemo(
60
53
  () => ({
61
- marginLeft: odysseyDesignTokens.Spacing2,
54
+ alignItems: "center",
55
+ display: "flex",
56
+ gap: odysseyDesignTokens.Spacing1,
57
+ marginInlineStart: odysseyDesignTokens.Spacing2,
62
58
  }),
63
59
  [odysseyDesignTokens],
64
60
  );
@@ -71,9 +67,16 @@ const SideNavItemLinkContent = ({
71
67
  isIconVisible={Boolean(startIcon)}
72
68
  >
73
69
  {label}
74
- {severity && (
70
+ {!count && severity && (
75
71
  <Box sx={sideNavItemContentStyles}>
76
- <Status severity={severity} label={statusLabel || ""} />
72
+ {severity && (
73
+ <Status severity={severity} label={statusLabel || ""} />
74
+ )}
75
+ </Box>
76
+ )}
77
+ {!severity && count && (
78
+ <Box sx={sideNavItemContentStyles}>
79
+ {count && <Badge badgeContent={count} />}
77
80
  </Box>
78
81
  )}
79
82
  </SideNavItemLabelContainer>
@@ -0,0 +1,41 @@
1
+ /*!
2
+ * Copyright (c) 2024-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, useMemo } from "react";
14
+ import { OktaLogo } from "./OktaLogo";
15
+ import { SideNavLogoProps } from "./types";
16
+
17
+ const SideNavLogo = ({
18
+ imageAltText,
19
+ href,
20
+ logoComponent,
21
+ imageUrl,
22
+ }: SideNavLogoProps) => {
23
+ const logo = useMemo(() => {
24
+ if (logoComponent) {
25
+ return logoComponent;
26
+ }
27
+
28
+ if (imageAltText && imageUrl) {
29
+ return <img src={imageUrl} alt={imageAltText} />;
30
+ }
31
+
32
+ return <OktaLogo />;
33
+ }, [imageAltText, logoComponent, imageUrl]);
34
+
35
+ return href ? <a href={href}>{logo}</a> : logo;
36
+ };
37
+
38
+ const MemoizedSideNavLogo = memo(SideNavLogo);
39
+ MemoizedSideNavLogo.displayName = "SideNavLogo";
40
+
41
+ export { MemoizedSideNavLogo as SideNavLogo };