@okta/odyssey-react-mui 1.32.4 → 1.33.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 (351) hide show
  1. package/dist/cjs/Autocomplete.cjs +1 -1
  2. package/dist/cjs/Autocomplete.cjs.map +1 -1
  3. package/dist/cjs/Breadcrumbs.cjs +23 -7
  4. package/dist/cjs/Breadcrumbs.cjs.map +1 -1
  5. package/dist/cjs/DatePickers/datePickerTheme.cjs +1 -1
  6. package/dist/cjs/DatePickers/datePickerTheme.cjs.map +1 -1
  7. package/dist/cjs/OdysseyProvider.cjs +2 -2
  8. package/dist/cjs/OdysseyProvider.cjs.map +1 -1
  9. package/dist/cjs/OdysseyThemeProvider.cjs +2 -2
  10. package/dist/cjs/OdysseyThemeProvider.cjs.map +1 -1
  11. package/dist/cjs/hexToRgb.cjs.map +1 -1
  12. package/dist/cjs/properties/ts/odyssey-react-mui.cjs +1 -0
  13. package/dist/cjs/properties/ts/odyssey-react-mui.cjs.map +1 -1
  14. package/dist/cjs/properties/ts/odyssey-react-mui_cs.cjs +1 -0
  15. package/dist/cjs/properties/ts/odyssey-react-mui_cs.cjs.map +1 -1
  16. package/dist/cjs/properties/ts/odyssey-react-mui_da.cjs +1 -0
  17. package/dist/cjs/properties/ts/odyssey-react-mui_da.cjs.map +1 -1
  18. package/dist/cjs/properties/ts/odyssey-react-mui_de.cjs +1 -0
  19. package/dist/cjs/properties/ts/odyssey-react-mui_de.cjs.map +1 -1
  20. package/dist/cjs/properties/ts/odyssey-react-mui_el.cjs +1 -0
  21. package/dist/cjs/properties/ts/odyssey-react-mui_el.cjs.map +1 -1
  22. package/dist/cjs/properties/ts/odyssey-react-mui_es.cjs +1 -0
  23. package/dist/cjs/properties/ts/odyssey-react-mui_es.cjs.map +1 -1
  24. package/dist/cjs/properties/ts/odyssey-react-mui_fi.cjs +1 -0
  25. package/dist/cjs/properties/ts/odyssey-react-mui_fi.cjs.map +1 -1
  26. package/dist/cjs/properties/ts/odyssey-react-mui_fr.cjs +1 -0
  27. package/dist/cjs/properties/ts/odyssey-react-mui_fr.cjs.map +1 -1
  28. package/dist/cjs/properties/ts/odyssey-react-mui_ht.cjs +1 -0
  29. package/dist/cjs/properties/ts/odyssey-react-mui_ht.cjs.map +1 -1
  30. package/dist/cjs/properties/ts/odyssey-react-mui_hu.cjs +1 -0
  31. package/dist/cjs/properties/ts/odyssey-react-mui_hu.cjs.map +1 -1
  32. package/dist/cjs/properties/ts/odyssey-react-mui_id.cjs +1 -0
  33. package/dist/cjs/properties/ts/odyssey-react-mui_id.cjs.map +1 -1
  34. package/dist/cjs/properties/ts/odyssey-react-mui_it.cjs +1 -0
  35. package/dist/cjs/properties/ts/odyssey-react-mui_it.cjs.map +1 -1
  36. package/dist/cjs/properties/ts/odyssey-react-mui_ja.cjs +1 -0
  37. package/dist/cjs/properties/ts/odyssey-react-mui_ja.cjs.map +1 -1
  38. package/dist/cjs/properties/ts/odyssey-react-mui_ko.cjs +1 -0
  39. package/dist/cjs/properties/ts/odyssey-react-mui_ko.cjs.map +1 -1
  40. package/dist/cjs/properties/ts/odyssey-react-mui_ms.cjs +1 -0
  41. package/dist/cjs/properties/ts/odyssey-react-mui_ms.cjs.map +1 -1
  42. package/dist/cjs/properties/ts/odyssey-react-mui_nb.cjs +1 -0
  43. package/dist/cjs/properties/ts/odyssey-react-mui_nb.cjs.map +1 -1
  44. package/dist/cjs/properties/ts/odyssey-react-mui_nl_NL.cjs +1 -0
  45. package/dist/cjs/properties/ts/odyssey-react-mui_nl_NL.cjs.map +1 -1
  46. package/dist/cjs/properties/ts/odyssey-react-mui_pl.cjs +1 -0
  47. package/dist/cjs/properties/ts/odyssey-react-mui_pl.cjs.map +1 -1
  48. package/dist/cjs/properties/ts/odyssey-react-mui_pt_BR.cjs +1 -0
  49. package/dist/cjs/properties/ts/odyssey-react-mui_pt_BR.cjs.map +1 -1
  50. package/dist/cjs/properties/ts/odyssey-react-mui_ro.cjs +1 -0
  51. package/dist/cjs/properties/ts/odyssey-react-mui_ro.cjs.map +1 -1
  52. package/dist/cjs/properties/ts/odyssey-react-mui_ru.cjs +1 -0
  53. package/dist/cjs/properties/ts/odyssey-react-mui_ru.cjs.map +1 -1
  54. package/dist/cjs/properties/ts/odyssey-react-mui_sv.cjs +1 -0
  55. package/dist/cjs/properties/ts/odyssey-react-mui_sv.cjs.map +1 -1
  56. package/dist/cjs/properties/ts/odyssey-react-mui_th.cjs +1 -0
  57. package/dist/cjs/properties/ts/odyssey-react-mui_th.cjs.map +1 -1
  58. package/dist/cjs/properties/ts/odyssey-react-mui_tr.cjs +1 -0
  59. package/dist/cjs/properties/ts/odyssey-react-mui_tr.cjs.map +1 -1
  60. package/dist/cjs/properties/ts/odyssey-react-mui_uk.cjs +1 -0
  61. package/dist/cjs/properties/ts/odyssey-react-mui_uk.cjs.map +1 -1
  62. package/dist/cjs/properties/ts/odyssey-react-mui_vi.cjs +1 -0
  63. package/dist/cjs/properties/ts/odyssey-react-mui_vi.cjs.map +1 -1
  64. package/dist/cjs/properties/ts/odyssey-react-mui_zh_CN.cjs +1 -0
  65. package/dist/cjs/properties/ts/odyssey-react-mui_zh_CN.cjs.map +1 -1
  66. package/dist/cjs/properties/ts/odyssey-react-mui_zh_TW.cjs +1 -0
  67. package/dist/cjs/properties/ts/odyssey-react-mui_zh_TW.cjs.map +1 -1
  68. package/dist/cjs/theme/pxToRem.cjs +21 -0
  69. package/dist/cjs/theme/pxToRem.cjs.map +1 -0
  70. package/dist/cjs/theme/theme.cjs +22 -0
  71. package/dist/cjs/theme/theme.cjs.map +1 -1
  72. package/dist/cjs/theme/useMediaQuery.cjs +34 -0
  73. package/dist/cjs/theme/useMediaQuery.cjs.map +1 -0
  74. package/dist/cjs/ui-shell/AppSwitcher/AppSwitcher.cjs +3 -3
  75. package/dist/cjs/ui-shell/AppSwitcher/AppSwitcher.cjs.map +1 -1
  76. package/dist/cjs/ui-shell/NarrowUiShellContent.cjs +340 -0
  77. package/dist/cjs/ui-shell/NarrowUiShellContent.cjs.map +1 -0
  78. package/dist/cjs/ui-shell/SideNav/SideNav.cjs +62 -44
  79. package/dist/cjs/ui-shell/SideNav/SideNav.cjs.map +1 -1
  80. package/dist/cjs/ui-shell/SideNav/SideNavHeader.cjs +8 -5
  81. package/dist/cjs/ui-shell/SideNav/SideNavHeader.cjs.map +1 -1
  82. package/dist/cjs/ui-shell/SideNav/SideNavItemContent.cjs +3 -0
  83. package/dist/cjs/ui-shell/SideNav/SideNavItemContent.cjs.map +1 -1
  84. package/dist/cjs/ui-shell/SideNav/SideNavLogo.cjs +2 -2
  85. package/dist/cjs/ui-shell/SideNav/SideNavLogo.cjs.map +1 -1
  86. package/dist/cjs/ui-shell/SideNav/SideNavToggleButton.cjs +2 -1
  87. package/dist/cjs/ui-shell/SideNav/SideNavToggleButton.cjs.map +1 -1
  88. package/dist/cjs/ui-shell/SideNav/types.cjs.map +1 -1
  89. package/dist/cjs/ui-shell/TopNav/HamburgerMenuIcon.cjs +37 -0
  90. package/dist/cjs/ui-shell/TopNav/HamburgerMenuIcon.cjs.map +1 -0
  91. package/dist/cjs/ui-shell/TopNav/TopNav.cjs +5 -5
  92. package/dist/cjs/ui-shell/TopNav/TopNav.cjs.map +1 -1
  93. package/dist/cjs/ui-shell/UiShell.cjs +37 -18
  94. package/dist/cjs/ui-shell/UiShell.cjs.map +1 -1
  95. package/dist/cjs/ui-shell/UiShellProvider.cjs +10 -3
  96. package/dist/cjs/ui-shell/UiShellProvider.cjs.map +1 -1
  97. package/dist/cjs/ui-shell/WideUiShellContent.cjs +171 -0
  98. package/dist/cjs/ui-shell/WideUiShellContent.cjs.map +1 -0
  99. package/dist/cjs/ui-shell/index.cjs +37 -9
  100. package/dist/cjs/ui-shell/index.cjs.map +1 -1
  101. package/dist/cjs/ui-shell/renderUiShell.cjs +19 -20
  102. package/dist/cjs/ui-shell/renderUiShell.cjs.map +1 -1
  103. package/dist/cjs/ui-shell/uiShellContentTypes.cjs +20 -0
  104. package/dist/cjs/ui-shell/uiShellContentTypes.cjs.map +1 -0
  105. package/dist/cjs/ui-shell/uiShellSharedConstants.cjs +22 -0
  106. package/dist/cjs/ui-shell/uiShellSharedConstants.cjs.map +1 -0
  107. package/dist/cjs/ui-shell/useMatchAppElementToUiShellAppArea.cjs +108 -0
  108. package/dist/cjs/ui-shell/useMatchAppElementToUiShellAppArea.cjs.map +1 -0
  109. package/dist/cjs/ui-shell/useScrollState.cjs +2 -4
  110. package/dist/cjs/ui-shell/useScrollState.cjs.map +1 -1
  111. package/dist/cjs/ui-shell/useUiShellBreakpoints.cjs +41 -0
  112. package/dist/cjs/ui-shell/useUiShellBreakpoints.cjs.map +1 -0
  113. package/dist/cjs/web-component/createReactRootElements.cjs.map +1 -1
  114. package/dist/cjs/web-component/renderReactInWebComponent.cjs +6 -1
  115. package/dist/cjs/web-component/renderReactInWebComponent.cjs.map +1 -1
  116. package/dist/esm/Autocomplete.js +1 -1
  117. package/dist/esm/Autocomplete.js.map +1 -1
  118. package/dist/esm/Breadcrumbs.js +23 -7
  119. package/dist/esm/Breadcrumbs.js.map +1 -1
  120. package/dist/esm/DatePickers/datePickerTheme.js +1 -1
  121. package/dist/esm/DatePickers/datePickerTheme.js.map +1 -1
  122. package/dist/esm/OdysseyProvider.js +2 -2
  123. package/dist/esm/OdysseyProvider.js.map +1 -1
  124. package/dist/esm/OdysseyThemeProvider.js +2 -2
  125. package/dist/esm/OdysseyThemeProvider.js.map +1 -1
  126. package/dist/esm/hexToRgb.js.map +1 -1
  127. package/dist/esm/properties/ts/odyssey-react-mui.js +1 -0
  128. package/dist/esm/properties/ts/odyssey-react-mui.js.map +1 -1
  129. package/dist/esm/properties/ts/odyssey-react-mui_cs.js +1 -0
  130. package/dist/esm/properties/ts/odyssey-react-mui_cs.js.map +1 -1
  131. package/dist/esm/properties/ts/odyssey-react-mui_da.js +1 -0
  132. package/dist/esm/properties/ts/odyssey-react-mui_da.js.map +1 -1
  133. package/dist/esm/properties/ts/odyssey-react-mui_de.js +1 -0
  134. package/dist/esm/properties/ts/odyssey-react-mui_de.js.map +1 -1
  135. package/dist/esm/properties/ts/odyssey-react-mui_el.js +1 -0
  136. package/dist/esm/properties/ts/odyssey-react-mui_el.js.map +1 -1
  137. package/dist/esm/properties/ts/odyssey-react-mui_es.js +1 -0
  138. package/dist/esm/properties/ts/odyssey-react-mui_es.js.map +1 -1
  139. package/dist/esm/properties/ts/odyssey-react-mui_fi.js +1 -0
  140. package/dist/esm/properties/ts/odyssey-react-mui_fi.js.map +1 -1
  141. package/dist/esm/properties/ts/odyssey-react-mui_fr.js +1 -0
  142. package/dist/esm/properties/ts/odyssey-react-mui_fr.js.map +1 -1
  143. package/dist/esm/properties/ts/odyssey-react-mui_ht.js +1 -0
  144. package/dist/esm/properties/ts/odyssey-react-mui_ht.js.map +1 -1
  145. package/dist/esm/properties/ts/odyssey-react-mui_hu.js +1 -0
  146. package/dist/esm/properties/ts/odyssey-react-mui_hu.js.map +1 -1
  147. package/dist/esm/properties/ts/odyssey-react-mui_id.js +1 -0
  148. package/dist/esm/properties/ts/odyssey-react-mui_id.js.map +1 -1
  149. package/dist/esm/properties/ts/odyssey-react-mui_it.js +1 -0
  150. package/dist/esm/properties/ts/odyssey-react-mui_it.js.map +1 -1
  151. package/dist/esm/properties/ts/odyssey-react-mui_ja.js +1 -0
  152. package/dist/esm/properties/ts/odyssey-react-mui_ja.js.map +1 -1
  153. package/dist/esm/properties/ts/odyssey-react-mui_ko.js +1 -0
  154. package/dist/esm/properties/ts/odyssey-react-mui_ko.js.map +1 -1
  155. package/dist/esm/properties/ts/odyssey-react-mui_ms.js +1 -0
  156. package/dist/esm/properties/ts/odyssey-react-mui_ms.js.map +1 -1
  157. package/dist/esm/properties/ts/odyssey-react-mui_nb.js +1 -0
  158. package/dist/esm/properties/ts/odyssey-react-mui_nb.js.map +1 -1
  159. package/dist/esm/properties/ts/odyssey-react-mui_nl_NL.js +1 -0
  160. package/dist/esm/properties/ts/odyssey-react-mui_nl_NL.js.map +1 -1
  161. package/dist/esm/properties/ts/odyssey-react-mui_pl.js +1 -0
  162. package/dist/esm/properties/ts/odyssey-react-mui_pl.js.map +1 -1
  163. package/dist/esm/properties/ts/odyssey-react-mui_pt_BR.js +1 -0
  164. package/dist/esm/properties/ts/odyssey-react-mui_pt_BR.js.map +1 -1
  165. package/dist/esm/properties/ts/odyssey-react-mui_ro.js +1 -0
  166. package/dist/esm/properties/ts/odyssey-react-mui_ro.js.map +1 -1
  167. package/dist/esm/properties/ts/odyssey-react-mui_ru.js +1 -0
  168. package/dist/esm/properties/ts/odyssey-react-mui_ru.js.map +1 -1
  169. package/dist/esm/properties/ts/odyssey-react-mui_sv.js +1 -0
  170. package/dist/esm/properties/ts/odyssey-react-mui_sv.js.map +1 -1
  171. package/dist/esm/properties/ts/odyssey-react-mui_th.js +1 -0
  172. package/dist/esm/properties/ts/odyssey-react-mui_th.js.map +1 -1
  173. package/dist/esm/properties/ts/odyssey-react-mui_tr.js +1 -0
  174. package/dist/esm/properties/ts/odyssey-react-mui_tr.js.map +1 -1
  175. package/dist/esm/properties/ts/odyssey-react-mui_uk.js +1 -0
  176. package/dist/esm/properties/ts/odyssey-react-mui_uk.js.map +1 -1
  177. package/dist/esm/properties/ts/odyssey-react-mui_vi.js +1 -0
  178. package/dist/esm/properties/ts/odyssey-react-mui_vi.js.map +1 -1
  179. package/dist/esm/properties/ts/odyssey-react-mui_zh_CN.js +1 -0
  180. package/dist/esm/properties/ts/odyssey-react-mui_zh_CN.js.map +1 -1
  181. package/dist/esm/properties/ts/odyssey-react-mui_zh_TW.js +1 -0
  182. package/dist/esm/properties/ts/odyssey-react-mui_zh_TW.js.map +1 -1
  183. package/dist/esm/theme/pxToRem.js +14 -0
  184. package/dist/esm/theme/pxToRem.js.map +1 -0
  185. package/dist/esm/theme/theme.js +2 -0
  186. package/dist/esm/theme/theme.js.map +1 -1
  187. package/dist/esm/theme/useMediaQuery.js +27 -0
  188. package/dist/esm/theme/useMediaQuery.js.map +1 -0
  189. package/dist/esm/ui-shell/AppSwitcher/AppSwitcher.js +2 -2
  190. package/dist/esm/ui-shell/AppSwitcher/AppSwitcher.js.map +1 -1
  191. package/dist/esm/ui-shell/NarrowUiShellContent.js +334 -0
  192. package/dist/esm/ui-shell/NarrowUiShellContent.js.map +1 -0
  193. package/dist/esm/ui-shell/SideNav/SideNav.js +61 -43
  194. package/dist/esm/ui-shell/SideNav/SideNav.js.map +1 -1
  195. package/dist/esm/ui-shell/SideNav/SideNavHeader.js +7 -4
  196. package/dist/esm/ui-shell/SideNav/SideNavHeader.js.map +1 -1
  197. package/dist/esm/ui-shell/SideNav/SideNavItemContent.js +3 -0
  198. package/dist/esm/ui-shell/SideNav/SideNavItemContent.js.map +1 -1
  199. package/dist/esm/ui-shell/SideNav/SideNavLogo.js +2 -2
  200. package/dist/esm/ui-shell/SideNav/SideNavLogo.js.map +1 -1
  201. package/dist/esm/ui-shell/SideNav/SideNavToggleButton.js +2 -1
  202. package/dist/esm/ui-shell/SideNav/SideNavToggleButton.js.map +1 -1
  203. package/dist/esm/ui-shell/SideNav/types.js.map +1 -1
  204. package/dist/esm/ui-shell/TopNav/HamburgerMenuIcon.js +32 -0
  205. package/dist/esm/ui-shell/TopNav/HamburgerMenuIcon.js.map +1 -0
  206. package/dist/esm/ui-shell/TopNav/TopNav.js +2 -2
  207. package/dist/esm/ui-shell/TopNav/TopNav.js.map +1 -1
  208. package/dist/esm/ui-shell/UiShell.js +37 -18
  209. package/dist/esm/ui-shell/UiShell.js.map +1 -1
  210. package/dist/esm/ui-shell/UiShellProvider.js +10 -3
  211. package/dist/esm/ui-shell/UiShellProvider.js.map +1 -1
  212. package/dist/esm/ui-shell/WideUiShellContent.js +165 -0
  213. package/dist/esm/ui-shell/WideUiShellContent.js.map +1 -0
  214. package/dist/esm/ui-shell/index.js +3 -1
  215. package/dist/esm/ui-shell/index.js.map +1 -1
  216. package/dist/esm/ui-shell/renderUiShell.js +19 -20
  217. package/dist/esm/ui-shell/renderUiShell.js.map +1 -1
  218. package/dist/esm/ui-shell/uiShellContentTypes.js +14 -0
  219. package/dist/esm/ui-shell/uiShellContentTypes.js.map +1 -0
  220. package/dist/esm/ui-shell/uiShellSharedConstants.js +16 -0
  221. package/dist/esm/ui-shell/uiShellSharedConstants.js.map +1 -0
  222. package/dist/esm/ui-shell/useMatchAppElementToUiShellAppArea.js +99 -0
  223. package/dist/esm/ui-shell/useMatchAppElementToUiShellAppArea.js.map +1 -0
  224. package/dist/esm/ui-shell/useScrollState.js +3 -5
  225. package/dist/esm/ui-shell/useScrollState.js.map +1 -1
  226. package/dist/esm/ui-shell/useUiShellBreakpoints.js +34 -0
  227. package/dist/esm/ui-shell/useUiShellBreakpoints.js.map +1 -0
  228. package/dist/esm/web-component/createReactRootElements.js.map +1 -1
  229. package/dist/esm/web-component/renderReactInWebComponent.js +6 -1
  230. package/dist/esm/web-component/renderReactInWebComponent.js.map +1 -1
  231. package/dist/index.cjs +1 -1
  232. package/dist/index.mjs +1 -1
  233. package/dist/index.scss +1 -1
  234. package/dist/tsconfig.production.tsbuildinfo +1 -1
  235. package/dist/types/Autocomplete.d.ts +1 -1
  236. package/dist/types/Breadcrumbs.d.ts +4 -3
  237. package/dist/types/Breadcrumbs.d.ts.map +1 -1
  238. package/dist/types/OdysseyProvider.d.ts +1 -1
  239. package/dist/types/OdysseyProvider.d.ts.map +1 -1
  240. package/dist/types/OdysseyThemeProvider.d.ts.map +1 -1
  241. package/dist/types/OdysseyTranslationProvider.d.ts +1 -1
  242. package/dist/types/OdysseyTranslationProvider.d.ts.map +1 -1
  243. package/dist/types/hexToRgb.d.ts.map +1 -1
  244. package/dist/types/i18n.d.ts +28 -0
  245. package/dist/types/i18n.d.ts.map +1 -1
  246. package/dist/types/properties/ts/odyssey-react-mui.d.ts +1 -0
  247. package/dist/types/properties/ts/odyssey-react-mui.d.ts.map +1 -1
  248. package/dist/types/properties/ts/odyssey-react-mui_cs.d.ts +1 -0
  249. package/dist/types/properties/ts/odyssey-react-mui_cs.d.ts.map +1 -1
  250. package/dist/types/properties/ts/odyssey-react-mui_da.d.ts +1 -0
  251. package/dist/types/properties/ts/odyssey-react-mui_da.d.ts.map +1 -1
  252. package/dist/types/properties/ts/odyssey-react-mui_de.d.ts +1 -0
  253. package/dist/types/properties/ts/odyssey-react-mui_de.d.ts.map +1 -1
  254. package/dist/types/properties/ts/odyssey-react-mui_el.d.ts +1 -0
  255. package/dist/types/properties/ts/odyssey-react-mui_el.d.ts.map +1 -1
  256. package/dist/types/properties/ts/odyssey-react-mui_es.d.ts +1 -0
  257. package/dist/types/properties/ts/odyssey-react-mui_es.d.ts.map +1 -1
  258. package/dist/types/properties/ts/odyssey-react-mui_fi.d.ts +1 -0
  259. package/dist/types/properties/ts/odyssey-react-mui_fi.d.ts.map +1 -1
  260. package/dist/types/properties/ts/odyssey-react-mui_fr.d.ts +1 -0
  261. package/dist/types/properties/ts/odyssey-react-mui_fr.d.ts.map +1 -1
  262. package/dist/types/properties/ts/odyssey-react-mui_ht.d.ts +1 -0
  263. package/dist/types/properties/ts/odyssey-react-mui_ht.d.ts.map +1 -1
  264. package/dist/types/properties/ts/odyssey-react-mui_hu.d.ts +1 -0
  265. package/dist/types/properties/ts/odyssey-react-mui_hu.d.ts.map +1 -1
  266. package/dist/types/properties/ts/odyssey-react-mui_id.d.ts +1 -0
  267. package/dist/types/properties/ts/odyssey-react-mui_id.d.ts.map +1 -1
  268. package/dist/types/properties/ts/odyssey-react-mui_it.d.ts +1 -0
  269. package/dist/types/properties/ts/odyssey-react-mui_it.d.ts.map +1 -1
  270. package/dist/types/properties/ts/odyssey-react-mui_ja.d.ts +1 -0
  271. package/dist/types/properties/ts/odyssey-react-mui_ja.d.ts.map +1 -1
  272. package/dist/types/properties/ts/odyssey-react-mui_ko.d.ts +1 -0
  273. package/dist/types/properties/ts/odyssey-react-mui_ko.d.ts.map +1 -1
  274. package/dist/types/properties/ts/odyssey-react-mui_ms.d.ts +1 -0
  275. package/dist/types/properties/ts/odyssey-react-mui_ms.d.ts.map +1 -1
  276. package/dist/types/properties/ts/odyssey-react-mui_nb.d.ts +1 -0
  277. package/dist/types/properties/ts/odyssey-react-mui_nb.d.ts.map +1 -1
  278. package/dist/types/properties/ts/odyssey-react-mui_nl_NL.d.ts +1 -0
  279. package/dist/types/properties/ts/odyssey-react-mui_nl_NL.d.ts.map +1 -1
  280. package/dist/types/properties/ts/odyssey-react-mui_pl.d.ts +1 -0
  281. package/dist/types/properties/ts/odyssey-react-mui_pl.d.ts.map +1 -1
  282. package/dist/types/properties/ts/odyssey-react-mui_pt_BR.d.ts +1 -0
  283. package/dist/types/properties/ts/odyssey-react-mui_pt_BR.d.ts.map +1 -1
  284. package/dist/types/properties/ts/odyssey-react-mui_ro.d.ts +1 -0
  285. package/dist/types/properties/ts/odyssey-react-mui_ro.d.ts.map +1 -1
  286. package/dist/types/properties/ts/odyssey-react-mui_ru.d.ts +1 -0
  287. package/dist/types/properties/ts/odyssey-react-mui_ru.d.ts.map +1 -1
  288. package/dist/types/properties/ts/odyssey-react-mui_sv.d.ts +1 -0
  289. package/dist/types/properties/ts/odyssey-react-mui_sv.d.ts.map +1 -1
  290. package/dist/types/properties/ts/odyssey-react-mui_th.d.ts +1 -0
  291. package/dist/types/properties/ts/odyssey-react-mui_th.d.ts.map +1 -1
  292. package/dist/types/properties/ts/odyssey-react-mui_tr.d.ts +1 -0
  293. package/dist/types/properties/ts/odyssey-react-mui_tr.d.ts.map +1 -1
  294. package/dist/types/properties/ts/odyssey-react-mui_uk.d.ts +1 -0
  295. package/dist/types/properties/ts/odyssey-react-mui_uk.d.ts.map +1 -1
  296. package/dist/types/properties/ts/odyssey-react-mui_vi.d.ts +1 -0
  297. package/dist/types/properties/ts/odyssey-react-mui_vi.d.ts.map +1 -1
  298. package/dist/types/properties/ts/odyssey-react-mui_zh_CN.d.ts +1 -0
  299. package/dist/types/properties/ts/odyssey-react-mui_zh_CN.d.ts.map +1 -1
  300. package/dist/types/properties/ts/odyssey-react-mui_zh_TW.d.ts +1 -0
  301. package/dist/types/properties/ts/odyssey-react-mui_zh_TW.d.ts.map +1 -1
  302. package/dist/types/theme/pxToRem.d.ts +13 -0
  303. package/dist/types/theme/pxToRem.d.ts.map +1 -0
  304. package/dist/types/theme/theme.d.ts +2 -0
  305. package/dist/types/theme/theme.d.ts.map +1 -1
  306. package/dist/types/theme/useMediaQuery.d.ts +13 -0
  307. package/dist/types/theme/useMediaQuery.d.ts.map +1 -0
  308. package/dist/types/ui-shell/AppSwitcher/AppSwitcher.d.ts.map +1 -1
  309. package/dist/types/ui-shell/NarrowUiShellContent.d.ts +17 -0
  310. package/dist/types/ui-shell/NarrowUiShellContent.d.ts.map +1 -0
  311. package/dist/types/ui-shell/SideNav/SideNav.d.ts +1 -3
  312. package/dist/types/ui-shell/SideNav/SideNav.d.ts.map +1 -1
  313. package/dist/types/ui-shell/SideNav/SideNavHeader.d.ts.map +1 -1
  314. package/dist/types/ui-shell/SideNav/SideNavItemContent.d.ts.map +1 -1
  315. package/dist/types/ui-shell/SideNav/SideNavToggleButton.d.ts.map +1 -1
  316. package/dist/types/ui-shell/SideNav/types.d.ts +7 -1
  317. package/dist/types/ui-shell/SideNav/types.d.ts.map +1 -1
  318. package/dist/types/ui-shell/TopNav/HamburgerMenuIcon.d.ts +16 -0
  319. package/dist/types/ui-shell/TopNav/HamburgerMenuIcon.d.ts.map +1 -0
  320. package/dist/types/ui-shell/TopNav/TopNav.d.ts +0 -1
  321. package/dist/types/ui-shell/TopNav/TopNav.d.ts.map +1 -1
  322. package/dist/types/ui-shell/UiShell.d.ts +20 -7
  323. package/dist/types/ui-shell/UiShell.d.ts.map +1 -1
  324. package/dist/types/ui-shell/UiShellProvider.d.ts +8 -6
  325. package/dist/types/ui-shell/UiShellProvider.d.ts.map +1 -1
  326. package/dist/types/ui-shell/WideUiShellContent.d.ts +16 -0
  327. package/dist/types/ui-shell/WideUiShellContent.d.ts.map +1 -0
  328. package/dist/types/ui-shell/index.d.ts +3 -1
  329. package/dist/types/ui-shell/index.d.ts.map +1 -1
  330. package/dist/types/ui-shell/renderUiShell.d.ts +7 -11
  331. package/dist/types/ui-shell/renderUiShell.d.ts.map +1 -1
  332. package/dist/types/ui-shell/{UiShellContent.d.ts → uiShellContentTypes.d.ts} +45 -31
  333. package/dist/types/ui-shell/uiShellContentTypes.d.ts.map +1 -0
  334. package/dist/types/ui-shell/uiShellSharedConstants.d.ts +17 -0
  335. package/dist/types/ui-shell/uiShellSharedConstants.d.ts.map +1 -0
  336. package/dist/types/ui-shell/useMatchAppElementToUiShellAppArea.d.ts +38 -0
  337. package/dist/types/ui-shell/useMatchAppElementToUiShellAppArea.d.ts.map +1 -0
  338. package/dist/types/ui-shell/useScrollState.d.ts +0 -1
  339. package/dist/types/ui-shell/useScrollState.d.ts.map +1 -1
  340. package/dist/types/ui-shell/useUiShellBreakpoints.d.ts +18 -0
  341. package/dist/types/ui-shell/useUiShellBreakpoints.d.ts.map +1 -0
  342. package/dist/types/web-component/createReactRootElements.d.ts +6 -4
  343. package/dist/types/web-component/createReactRootElements.d.ts.map +1 -1
  344. package/dist/types/web-component/renderReactInWebComponent.d.ts +12 -5
  345. package/dist/types/web-component/renderReactInWebComponent.d.ts.map +1 -1
  346. package/package.json +4 -4
  347. package/dist/cjs/ui-shell/UiShellContent.cjs +0 -242
  348. package/dist/cjs/ui-shell/UiShellContent.cjs.map +0 -1
  349. package/dist/esm/ui-shell/UiShellContent.js +0 -234
  350. package/dist/esm/ui-shell/UiShellContent.js.map +0 -1
  351. package/dist/types/ui-shell/UiShellContent.d.ts.map +0 -1
@@ -0,0 +1,14 @@
1
+ /*!
2
+ * Copyright (c) 2025-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
+ export const pxToRem = pixels => Number(pixels) / 14;
14
+ //# sourceMappingURL=pxToRem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pxToRem.js","names":["pxToRem","pixels","Number"],"sources":["../../../src/theme/pxToRem.ts"],"sourcesContent":["/*!\n * Copyright (c) 2025-present, Okta, Inc. and/or its affiliates. All rights reserved.\n * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the \"License.\")\n *\n * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n *\n * See the License for the specific language governing permissions and limitations under the License.\n */\n\nexport const pxToRem = <Pixels extends number | string>(pixels: Pixels) =>\n Number(pixels) / 14;\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO,MAAMA,OAAO,GAAoCC,MAAc,IACpEC,MAAM,CAACD,MAAM,CAAC,GAAG,EAAE","ignoreList":[]}
@@ -11,4 +11,6 @@
11
11
  */
12
12
 
13
13
  export * from "./createOdysseyMuiTheme.js";
14
+ export * from "./pxToRem.js";
15
+ export * from "./useMediaQuery.js";
14
16
  //# sourceMappingURL=theme.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"theme.js","names":[],"sources":["../../../src/theme/theme.ts"],"sourcesContent":["/*!\n * Copyright (c) 2022-present, Okta, Inc. and/or its affiliates. All rights reserved.\n * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the \"License.\")\n *\n * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n *\n * See the License for the specific language governing permissions and limitations under the License.\n */\n\nexport * from \"./createOdysseyMuiTheme.js\";\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,cAAc,4BAA4B","ignoreList":[]}
1
+ {"version":3,"file":"theme.js","names":[],"sources":["../../../src/theme/theme.ts"],"sourcesContent":["/*!\n * Copyright (c) 2022-present, Okta, Inc. and/or its affiliates. All rights reserved.\n * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the \"License.\")\n *\n * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n *\n * See the License for the specific language governing permissions and limitations under the License.\n */\n\nexport * from \"./createOdysseyMuiTheme.js\";\nexport * from \"./pxToRem.js\";\nexport * from \"./useMediaQuery.js\";\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,cAAc,4BAA4B;AAC1C,cAAc,cAAc;AAC5B,cAAc,oBAAoB","ignoreList":[]}
@@ -0,0 +1,27 @@
1
+ /*!
2
+ * Copyright (c) 2025-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 { useEffect, useState } from "react";
14
+ export const useMediaQuery = mediaQuery => {
15
+ const [hasMatches, setHasMatches] = useState(false);
16
+ useEffect(() => {
17
+ const mediaQueryList = window.matchMedia(mediaQuery);
18
+ const updateHasMatches = event => setHasMatches(event.matches);
19
+ mediaQueryList.addEventListener("change", updateHasMatches);
20
+ updateHasMatches(mediaQueryList);
21
+ return () => {
22
+ mediaQueryList.removeEventListener("change", updateHasMatches);
23
+ };
24
+ }, [hasMatches, mediaQuery]);
25
+ return hasMatches;
26
+ };
27
+ //# sourceMappingURL=useMediaQuery.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMediaQuery.js","names":["useEffect","useState","useMediaQuery","mediaQuery","hasMatches","setHasMatches","mediaQueryList","window","matchMedia","updateHasMatches","event","matches","addEventListener","removeEventListener"],"sources":["../../../src/theme/useMediaQuery.ts"],"sourcesContent":["/*!\n * Copyright (c) 2025-present, Okta, Inc. and/or its affiliates. All rights reserved.\n * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the \"License.\")\n *\n * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n *\n * See the License for the specific language governing permissions and limitations under the License.\n */\n\nimport { useEffect, useState } from \"react\";\n\nexport const useMediaQuery = (mediaQuery: string) => {\n const [hasMatches, setHasMatches] = useState(false);\n\n useEffect(() => {\n const mediaQueryList = window.matchMedia(mediaQuery);\n\n const updateHasMatches = (event: MediaQueryListEvent | MediaQueryList) =>\n setHasMatches(event.matches);\n\n mediaQueryList.addEventListener(\"change\", updateHasMatches);\n\n updateHasMatches(mediaQueryList);\n\n return () => {\n mediaQueryList.removeEventListener(\"change\", updateHasMatches);\n };\n }, [hasMatches, mediaQuery]);\n\n return hasMatches;\n};\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,SAASA,SAAS,EAAEC,QAAQ,QAAQ,OAAO;AAE3C,OAAO,MAAMC,aAAa,GAAIC,UAAkB,IAAK;EACnD,MAAM,CAACC,UAAU,EAAEC,aAAa,CAAC,GAAGJ,QAAQ,CAAC,KAAK,CAAC;EAEnDD,SAAS,CAAC,MAAM;IACd,MAAMM,cAAc,GAAGC,MAAM,CAACC,UAAU,CAACL,UAAU,CAAC;IAEpD,MAAMM,gBAAgB,GAAIC,KAA2C,IACnEL,aAAa,CAACK,KAAK,CAACC,OAAO,CAAC;IAE9BL,cAAc,CAACM,gBAAgB,CAAC,QAAQ,EAAEH,gBAAgB,CAAC;IAE3DA,gBAAgB,CAACH,cAAc,CAAC;IAEhC,OAAO,MAAM;MACXA,cAAc,CAACO,mBAAmB,CAAC,QAAQ,EAAEJ,gBAAgB,CAAC;IAChE,CAAC;EACH,CAAC,EAAE,CAACL,UAAU,EAAED,UAAU,CAAC,CAAC;EAE5B,OAAOC,UAAU;AACnB,CAAC","ignoreList":[]}
@@ -12,10 +12,10 @@
12
12
 
13
13
  import styled from "@emotion/styled";
14
14
  import { memo } from "react";
15
+ import { AppSwitcherApp, AppSwitcherAppSkeleton } from "./AppSwitcherApp.js";
15
16
  import { useOdysseyDesignTokens } from "../../OdysseyDesignTokensContext.js";
16
17
  import { OktaAura } from "./OktaAura.js";
17
- import { AppSwitcherApp, AppSwitcherAppSkeleton } from "./AppSwitcherApp.js";
18
- import { TOP_NAV_HEIGHT } from "../TopNav/index.js";
18
+ import { TOP_NAV_HEIGHT } from "../uiShellSharedConstants.js";
19
19
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
20
20
  const AppSwitcherWrapperComponent = styled("nav", {
21
21
  shouldForwardProp: prop => prop !== "odysseyDesignTokens"
@@ -1 +1 @@
1
- {"version":3,"file":"AppSwitcher.js","names":["styled","memo","useOdysseyDesignTokens","OktaAura","AppSwitcherApp","AppSwitcherAppSkeleton","TOP_NAV_HEIGHT","jsx","_jsx","jsxs","_jsxs","AppSwitcherWrapperComponent","shouldForwardProp","prop","odysseyDesignTokens","position","display","height","backgroundColor","HueNeutralWhite","borderInlineEndStyle","borderInlineEndWidth","BorderWidthMain","borderInlineEndColor","BorderColorDisplay","AppSwitcherOktaAuraWrapperComponent","padding","Spacing4","margin","marginBlockEnd","AppSwitcherAppIconULComponent","listStyleType","Spacing0","AppSwitcher","appIcons","isLoading","selectedAppName","children","map","key","appIcon","appName","MemoizedAppSwitcher","displayName"],"sources":["../../../../src/ui-shell/AppSwitcher/AppSwitcher.tsx"],"sourcesContent":["/*!\n * Copyright (c) 2024-present, Okta, Inc. and/or its affiliates. All rights reserved.\n * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the \"License.\")\n *\n * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n *\n * See the License for the specific language governing permissions and limitations under the License.\n */\n\nimport styled from \"@emotion/styled\";\nimport { memo } from \"react\";\nimport {\n DesignTokens,\n useOdysseyDesignTokens,\n} from \"../../OdysseyDesignTokensContext.js\";\nimport { OktaAura } from \"./OktaAura.js\";\nimport {\n AppSwitcherApp,\n AppSwitcherAppIconData,\n AppSwitcherAppSkeleton,\n} from \"./AppSwitcherApp.js\";\nimport { TOP_NAV_HEIGHT } from \"../TopNav/index.js\";\n\nexport type AppSwitcherProps = {\n appIcons: AppSwitcherAppIconData[];\n selectedAppName: string;\n isLoading: boolean;\n};\n\nconst AppSwitcherWrapperComponent = styled(\"nav\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{ odysseyDesignTokens: DesignTokens }>(({ odysseyDesignTokens }) => ({\n position: \"relative\",\n display: \"inline-block\",\n height: \"100%\",\n backgroundColor: odysseyDesignTokens.HueNeutralWhite,\n borderInlineEndStyle: \"solid\",\n borderInlineEndWidth: odysseyDesignTokens.BorderWidthMain,\n borderInlineEndColor: odysseyDesignTokens.BorderColorDisplay,\n}));\n\nconst AppSwitcherOktaAuraWrapperComponent = styled(\"div\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{ odysseyDesignTokens: DesignTokens }>(({ odysseyDesignTokens }) => ({\n height: TOP_NAV_HEIGHT,\n padding: odysseyDesignTokens.Spacing4,\n margin: \"auto\",\n marginBlockEnd: odysseyDesignTokens.Spacing4,\n}));\n\nconst AppSwitcherAppIconULComponent = styled(\"ul\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{ odysseyDesignTokens: DesignTokens }>(({ odysseyDesignTokens }) => ({\n listStyleType: \"none\",\n margin: odysseyDesignTokens.Spacing0,\n padding: odysseyDesignTokens.Spacing0,\n}));\n\nconst AppSwitcher = ({\n appIcons,\n isLoading,\n selectedAppName,\n}: AppSwitcherProps) => {\n const odysseyDesignTokens = useOdysseyDesignTokens();\n\n return (\n <AppSwitcherWrapperComponent odysseyDesignTokens={odysseyDesignTokens}>\n <AppSwitcherOktaAuraWrapperComponent\n odysseyDesignTokens={odysseyDesignTokens}\n >\n <OktaAura />\n </AppSwitcherOktaAuraWrapperComponent>\n <AppSwitcherAppIconULComponent odysseyDesignTokens={odysseyDesignTokens}>\n {isLoading\n ? [0, 1, 2].map((key) => <AppSwitcherAppSkeleton key={key} />)\n : appIcons?.map((appIcon) => (\n <AppSwitcherApp\n key={appIcon.appName}\n selectedAppName={selectedAppName}\n {...appIcon}\n />\n ))}\n </AppSwitcherAppIconULComponent>\n </AppSwitcherWrapperComponent>\n );\n};\n\nconst MemoizedAppSwitcher = memo(AppSwitcher);\nMemoizedAppSwitcher.displayName = \"AppSwitcher\";\n\nexport { MemoizedAppSwitcher as AppSwitcher };\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAOA,MAAM,MAAM,iBAAiB;AACpC,SAASC,IAAI,QAAQ,OAAO;AAC5B,SAEEC,sBAAsB,QACjB,qCAAqC;AAC5C,SAASC,QAAQ,QAAQ,eAAe;AACxC,SACEC,cAAc,EAEdC,sBAAsB,QACjB,qBAAqB;AAC5B,SAASC,cAAc,QAAQ,oBAAoB;AAAC,SAAAC,GAAA,IAAAC,IAAA,EAAAC,IAAA,IAAAC,KAAA;AAQpD,MAAMC,2BAA2B,GAAGX,MAAM,CAAC,KAAK,EAAE;EAChDY,iBAAiB,EAAGC,IAAI,IAAKA,IAAI,KAAK;AACxC,CAAC,CAAC,CAAwC,CAAC;EAAEC;AAAoB,CAAC,MAAM;EACtEC,QAAQ,EAAE,UAAU;EACpBC,OAAO,EAAE,cAAc;EACvBC,MAAM,EAAE,MAAM;EACdC,eAAe,EAAEJ,mBAAmB,CAACK,eAAe;EACpDC,oBAAoB,EAAE,OAAO;EAC7BC,oBAAoB,EAAEP,mBAAmB,CAACQ,eAAe;EACzDC,oBAAoB,EAAET,mBAAmB,CAACU;AAC5C,CAAC,CAAC,CAAC;AAEH,MAAMC,mCAAmC,GAAGzB,MAAM,CAAC,KAAK,EAAE;EACxDY,iBAAiB,EAAGC,IAAI,IAAKA,IAAI,KAAK;AACxC,CAAC,CAAC,CAAwC,CAAC;EAAEC;AAAoB,CAAC,MAAM;EACtEG,MAAM,EAAEX,cAAc;EACtBoB,OAAO,EAAEZ,mBAAmB,CAACa,QAAQ;EACrCC,MAAM,EAAE,MAAM;EACdC,cAAc,EAAEf,mBAAmB,CAACa;AACtC,CAAC,CAAC,CAAC;AAEH,MAAMG,6BAA6B,GAAG9B,MAAM,CAAC,IAAI,EAAE;EACjDY,iBAAiB,EAAGC,IAAI,IAAKA,IAAI,KAAK;AACxC,CAAC,CAAC,CAAwC,CAAC;EAAEC;AAAoB,CAAC,MAAM;EACtEiB,aAAa,EAAE,MAAM;EACrBH,MAAM,EAAEd,mBAAmB,CAACkB,QAAQ;EACpCN,OAAO,EAAEZ,mBAAmB,CAACkB;AAC/B,CAAC,CAAC,CAAC;AAEH,MAAMC,WAAW,GAAGA,CAAC;EACnBC,QAAQ;EACRC,SAAS;EACTC;AACgB,CAAC,KAAK;EACtB,MAAMtB,mBAAmB,GAAGZ,sBAAsB,CAAC,CAAC;EAEpD,OACEQ,KAAA,CAACC,2BAA2B;IAACG,mBAAmB,EAAEA,mBAAoB;IAAAuB,QAAA,GACpE7B,IAAA,CAACiB,mCAAmC;MAClCX,mBAAmB,EAAEA,mBAAoB;MAAAuB,QAAA,EAEzC7B,IAAA,CAACL,QAAQ,IAAE;IAAC,CACuB,CAAC,EACtCK,IAAA,CAACsB,6BAA6B;MAAChB,mBAAmB,EAAEA,mBAAoB;MAAAuB,QAAA,EACrEF,SAAS,GACN,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAACG,GAAG,CAAEC,GAAG,IAAK/B,IAAA,CAACH,sBAAsB,MAAMkC,GAAM,CAAC,CAAC,GAC5DL,QAAQ,EAAEI,GAAG,CAAEE,OAAO,IACpBhC,IAAA,CAACJ,cAAc;QAEbgC,eAAe,EAAEA,eAAgB;QAAA,GAC7BI;MAAO,GAFNA,OAAO,CAACC,OAGd,CACF;IAAC,CACuB,CAAC;EAAA,CACL,CAAC;AAElC,CAAC;AAED,MAAMC,mBAAmB,GAAGzC,IAAI,CAACgC,WAAW,CAAC;AAC7CS,mBAAmB,CAACC,WAAW,GAAG,aAAa;AAE/C,SAASD,mBAAmB,IAAIT,WAAW","ignoreList":[]}
1
+ {"version":3,"file":"AppSwitcher.js","names":["styled","memo","AppSwitcherApp","AppSwitcherAppSkeleton","useOdysseyDesignTokens","OktaAura","TOP_NAV_HEIGHT","jsx","_jsx","jsxs","_jsxs","AppSwitcherWrapperComponent","shouldForwardProp","prop","odysseyDesignTokens","position","display","height","backgroundColor","HueNeutralWhite","borderInlineEndStyle","borderInlineEndWidth","BorderWidthMain","borderInlineEndColor","BorderColorDisplay","AppSwitcherOktaAuraWrapperComponent","padding","Spacing4","margin","marginBlockEnd","AppSwitcherAppIconULComponent","listStyleType","Spacing0","AppSwitcher","appIcons","isLoading","selectedAppName","children","map","key","appIcon","appName","MemoizedAppSwitcher","displayName"],"sources":["../../../../src/ui-shell/AppSwitcher/AppSwitcher.tsx"],"sourcesContent":["/*!\n * Copyright (c) 2024-present, Okta, Inc. and/or its affiliates. All rights reserved.\n * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the \"License.\")\n *\n * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n *\n * See the License for the specific language governing permissions and limitations under the License.\n */\n\nimport styled from \"@emotion/styled\";\nimport { memo } from \"react\";\n\nimport {\n AppSwitcherApp,\n AppSwitcherAppIconData,\n AppSwitcherAppSkeleton,\n} from \"./AppSwitcherApp.js\";\nimport {\n DesignTokens,\n useOdysseyDesignTokens,\n} from \"../../OdysseyDesignTokensContext.js\";\nimport { OktaAura } from \"./OktaAura.js\";\nimport { TOP_NAV_HEIGHT } from \"../uiShellSharedConstants.js\";\n\nexport type AppSwitcherProps = {\n appIcons: AppSwitcherAppIconData[];\n selectedAppName: string;\n isLoading: boolean;\n};\n\nconst AppSwitcherWrapperComponent = styled(\"nav\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{ odysseyDesignTokens: DesignTokens }>(({ odysseyDesignTokens }) => ({\n position: \"relative\",\n display: \"inline-block\",\n height: \"100%\",\n backgroundColor: odysseyDesignTokens.HueNeutralWhite,\n borderInlineEndStyle: \"solid\",\n borderInlineEndWidth: odysseyDesignTokens.BorderWidthMain,\n borderInlineEndColor: odysseyDesignTokens.BorderColorDisplay,\n}));\n\nconst AppSwitcherOktaAuraWrapperComponent = styled(\"div\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{ odysseyDesignTokens: DesignTokens }>(({ odysseyDesignTokens }) => ({\n height: TOP_NAV_HEIGHT,\n padding: odysseyDesignTokens.Spacing4,\n margin: \"auto\",\n marginBlockEnd: odysseyDesignTokens.Spacing4,\n}));\n\nconst AppSwitcherAppIconULComponent = styled(\"ul\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{ odysseyDesignTokens: DesignTokens }>(({ odysseyDesignTokens }) => ({\n listStyleType: \"none\",\n margin: odysseyDesignTokens.Spacing0,\n padding: odysseyDesignTokens.Spacing0,\n}));\n\nconst AppSwitcher = ({\n appIcons,\n isLoading,\n selectedAppName,\n}: AppSwitcherProps) => {\n const odysseyDesignTokens = useOdysseyDesignTokens();\n\n return (\n <AppSwitcherWrapperComponent odysseyDesignTokens={odysseyDesignTokens}>\n <AppSwitcherOktaAuraWrapperComponent\n odysseyDesignTokens={odysseyDesignTokens}\n >\n <OktaAura />\n </AppSwitcherOktaAuraWrapperComponent>\n <AppSwitcherAppIconULComponent odysseyDesignTokens={odysseyDesignTokens}>\n {isLoading\n ? [0, 1, 2].map((key) => <AppSwitcherAppSkeleton key={key} />)\n : appIcons?.map((appIcon) => (\n <AppSwitcherApp\n key={appIcon.appName}\n selectedAppName={selectedAppName}\n {...appIcon}\n />\n ))}\n </AppSwitcherAppIconULComponent>\n </AppSwitcherWrapperComponent>\n );\n};\n\nconst MemoizedAppSwitcher = memo(AppSwitcher);\nMemoizedAppSwitcher.displayName = \"AppSwitcher\";\n\nexport { MemoizedAppSwitcher as AppSwitcher };\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAOA,MAAM,MAAM,iBAAiB;AACpC,SAASC,IAAI,QAAQ,OAAO;AAE5B,SACEC,cAAc,EAEdC,sBAAsB,QACjB,qBAAqB;AAC5B,SAEEC,sBAAsB,QACjB,qCAAqC;AAC5C,SAASC,QAAQ,QAAQ,eAAe;AACxC,SAASC,cAAc,QAAQ,8BAA8B;AAAC,SAAAC,GAAA,IAAAC,IAAA,EAAAC,IAAA,IAAAC,KAAA;AAQ9D,MAAMC,2BAA2B,GAAGX,MAAM,CAAC,KAAK,EAAE;EAChDY,iBAAiB,EAAGC,IAAI,IAAKA,IAAI,KAAK;AACxC,CAAC,CAAC,CAAwC,CAAC;EAAEC;AAAoB,CAAC,MAAM;EACtEC,QAAQ,EAAE,UAAU;EACpBC,OAAO,EAAE,cAAc;EACvBC,MAAM,EAAE,MAAM;EACdC,eAAe,EAAEJ,mBAAmB,CAACK,eAAe;EACpDC,oBAAoB,EAAE,OAAO;EAC7BC,oBAAoB,EAAEP,mBAAmB,CAACQ,eAAe;EACzDC,oBAAoB,EAAET,mBAAmB,CAACU;AAC5C,CAAC,CAAC,CAAC;AAEH,MAAMC,mCAAmC,GAAGzB,MAAM,CAAC,KAAK,EAAE;EACxDY,iBAAiB,EAAGC,IAAI,IAAKA,IAAI,KAAK;AACxC,CAAC,CAAC,CAAwC,CAAC;EAAEC;AAAoB,CAAC,MAAM;EACtEG,MAAM,EAAEX,cAAc;EACtBoB,OAAO,EAAEZ,mBAAmB,CAACa,QAAQ;EACrCC,MAAM,EAAE,MAAM;EACdC,cAAc,EAAEf,mBAAmB,CAACa;AACtC,CAAC,CAAC,CAAC;AAEH,MAAMG,6BAA6B,GAAG9B,MAAM,CAAC,IAAI,EAAE;EACjDY,iBAAiB,EAAGC,IAAI,IAAKA,IAAI,KAAK;AACxC,CAAC,CAAC,CAAwC,CAAC;EAAEC;AAAoB,CAAC,MAAM;EACtEiB,aAAa,EAAE,MAAM;EACrBH,MAAM,EAAEd,mBAAmB,CAACkB,QAAQ;EACpCN,OAAO,EAAEZ,mBAAmB,CAACkB;AAC/B,CAAC,CAAC,CAAC;AAEH,MAAMC,WAAW,GAAGA,CAAC;EACnBC,QAAQ;EACRC,SAAS;EACTC;AACgB,CAAC,KAAK;EACtB,MAAMtB,mBAAmB,GAAGV,sBAAsB,CAAC,CAAC;EAEpD,OACEM,KAAA,CAACC,2BAA2B;IAACG,mBAAmB,EAAEA,mBAAoB;IAAAuB,QAAA,GACpE7B,IAAA,CAACiB,mCAAmC;MAClCX,mBAAmB,EAAEA,mBAAoB;MAAAuB,QAAA,EAEzC7B,IAAA,CAACH,QAAQ,IAAE;IAAC,CACuB,CAAC,EACtCG,IAAA,CAACsB,6BAA6B;MAAChB,mBAAmB,EAAEA,mBAAoB;MAAAuB,QAAA,EACrEF,SAAS,GACN,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAACG,GAAG,CAAEC,GAAG,IAAK/B,IAAA,CAACL,sBAAsB,MAAMoC,GAAM,CAAC,CAAC,GAC5DL,QAAQ,EAAEI,GAAG,CAAEE,OAAO,IACpBhC,IAAA,CAACN,cAAc;QAEbkC,eAAe,EAAEA,eAAgB;QAAA,GAC7BI;MAAO,GAFNA,OAAO,CAACC,OAGd,CACF;IAAC,CACuB,CAAC;EAAA,CACL,CAAC;AAElC,CAAC;AAED,MAAMC,mBAAmB,GAAGzC,IAAI,CAACgC,WAAW,CAAC;AAC7CS,mBAAmB,CAACC,WAAW,GAAG,aAAa;AAE/C,SAASD,mBAAmB,IAAIT,WAAW","ignoreList":[]}
@@ -0,0 +1,334 @@
1
+ import _Skeleton from "@mui/material/Skeleton";
2
+ /*!
3
+ * Copyright (c) 2022-present, Okta, Inc. and/or its affiliates. All rights reserved.
4
+ * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
5
+ *
6
+ * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
7
+ * Unless required by applicable law or agreed to in writing, software
8
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
9
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
10
+ *
11
+ * See the License for the specific language governing permissions and limitations under the License.
12
+ */
13
+
14
+ import styled from "@emotion/styled";
15
+ import { memo, useCallback, useEffect, useRef, useState } from "react";
16
+ import { ErrorBoundary } from "react-error-boundary";
17
+ import { Button } from "../Buttons/Button.js";
18
+ import { CloseIcon } from "../icons.generated/Close.js";
19
+ import { MoreIcon } from "../icons.generated/More.js";
20
+ import { useOdysseyDesignTokens } from "../OdysseyDesignTokensContext.js";
21
+ import { SideNav } from "./SideNav/SideNav.js";
22
+ import { SideNavLogo } from "./SideNav/SideNavLogo.js";
23
+ import { HamburgerMenuIcon } from "./TopNav/HamburgerMenuIcon.js";
24
+ import { useUiShellContext } from "./UiShellProvider.js";
25
+ import { SIDE_NAV_WIDTH, TOP_NAV_HEIGHT, UI_SHELL_BASE_Z_INDEX } from "./uiShellSharedConstants.js";
26
+ import { useScrollState } from "./useScrollState.js";
27
+ import { useMatchAppElementToUiShellAppArea } from "./useMatchAppElementToUiShellAppArea.js";
28
+ import { hexToRgb } from "../hexToRgb.js";
29
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
30
+ const StyledAppContentArea = styled("div")({
31
+ gridArea: "app-content",
32
+ position: "relative",
33
+ display: "grid",
34
+ gridGap: 0,
35
+ gridTemplateAreas: `
36
+ "left-side app-container right-side"
37
+ `,
38
+ gridTemplateColumns: "auto 1fr auto",
39
+ gridTemplateRows: "1fr",
40
+ height: "100%",
41
+ width: "100%"
42
+ });
43
+ const StyledAppContainer = styled("div", {
44
+ shouldForwardProp: prop => prop !== "appBackgroundColor" && prop !== "odysseyDesignTokens"
45
+ })(({
46
+ appBackgroundColor
47
+ }) => ({
48
+ backgroundColor: appBackgroundColor,
49
+ height: "100%",
50
+ gridArea: "app-container",
51
+ overflow: "hidden",
52
+ width: "100%"
53
+ }));
54
+ const StyledBannersContainer = styled("div")({
55
+ gridArea: "banners",
56
+ zIndex: UI_SHELL_BASE_Z_INDEX
57
+ });
58
+ const StyledLeftSideContainer = styled("div", {
59
+ shouldForwardProp: prop => prop !== "isOpen"
60
+ })(({
61
+ isOpen
62
+ }) => ({
63
+ display: isOpen ? "block" : "none",
64
+ height: "100%",
65
+ gridArea: "left-side",
66
+ overflowY: "auto",
67
+ position: "absolute",
68
+ zIndex: UI_SHELL_BASE_Z_INDEX
69
+ }));
70
+ const StyledRightSideContainer = styled("div", {
71
+ shouldForwardProp: prop => prop !== "isOpen" && prop !== "odysseyDesignTokens"
72
+ })(({
73
+ isOpen,
74
+ odysseyDesignTokens
75
+ }) => ({
76
+ backgroundColor: odysseyDesignTokens.HueNeutralWhite,
77
+ display: isOpen ? "block" : "none",
78
+ gridArea: "right-side",
79
+ height: "100%",
80
+ maxWidth: SIDE_NAV_WIDTH,
81
+ overflowY: "auto",
82
+ position: "absolute",
83
+ right: 0,
84
+ width: SIDE_NAV_WIDTH,
85
+ zIndex: UI_SHELL_BASE_Z_INDEX
86
+ }));
87
+ const StyledMenuLogo = styled("div", {
88
+ shouldForwardProp: prop => prop !== "odysseyDesignTokens"
89
+ })(({
90
+ odysseyDesignTokens
91
+ }) => ({
92
+ alignItems: "center",
93
+ display: "inline-flex",
94
+ gap: odysseyDesignTokens.Spacing3
95
+ }));
96
+ const StyledLogoContainer = styled("div", {
97
+ shouldForwardProp: prop => prop !== "odysseyDesignTokens"
98
+ })(({
99
+ odysseyDesignTokens
100
+ }) => ({
101
+ height: TOP_NAV_HEIGHT,
102
+ paddingBlock: odysseyDesignTokens.Spacing4,
103
+ "svg, img": {
104
+ maxHeight: "100%",
105
+ width: "auto",
106
+ maxWidth: "100%"
107
+ }
108
+ }));
109
+ const StyledPageOverlay = styled("div", {
110
+ shouldForwardProp: prop => prop !== "odysseyDesignTokens"
111
+ })(({
112
+ odysseyDesignTokens
113
+ }) => ({
114
+ backgroundColor: hexToRgb(odysseyDesignTokens.HueNeutral900).asFormattedString.replace(/rgb\((.+)\)$/, "rgba($1, 0.26)"),
115
+ gridArea: "app-content",
116
+ height: "100vh",
117
+ left: 0,
118
+ position: "absolute",
119
+ top: 0,
120
+ width: "100vw",
121
+ zIndex: UI_SHELL_BASE_Z_INDEX
122
+ }));
123
+ const StyledSideNavContainer = styled("div")({
124
+ height: "100%"
125
+ });
126
+ const StyledUiShellContainer = styled("div", {
127
+ shouldForwardProp: prop => prop !== "odysseyDesignTokens"
128
+ })(({
129
+ odysseyDesignTokens
130
+ }) => ({
131
+ backgroundColor: odysseyDesignTokens.HueNeutral50,
132
+ display: "grid",
133
+ gridGap: 0,
134
+ gridTemplateAreas: `
135
+ "banners"
136
+ "top-nav"
137
+ "app-content"
138
+ `,
139
+ gridTemplateColumns: "1fr",
140
+ gridTemplateRows: "auto auto 1fr",
141
+ height: "100vh",
142
+ overflow: "hidden",
143
+ width: "100vw"
144
+ }));
145
+ const StyledTopNav = styled("div", {
146
+ shouldForwardProp: prop => prop !== "odysseyDesignTokens" && prop !== "isContentScrolled" && prop !== "topNavBackgroundColor"
147
+ })(({
148
+ odysseyDesignTokens,
149
+ isContentScrolled,
150
+ topNavBackgroundColor
151
+ }) => ({
152
+ alignItems: "stretch",
153
+ backgroundColor: odysseyDesignTokens.HueNeutralWhite || topNavBackgroundColor,
154
+ boxShadow: isContentScrolled ? odysseyDesignTokens.DepthMedium : undefined,
155
+ clipPath: "inset(0 0 -100vh 0)",
156
+ display: "flex",
157
+ flexDirection: "column",
158
+ gridArea: "top-nav",
159
+ height: "100%",
160
+ justifyContent: "center",
161
+ position: "relative",
162
+ transition: `box-shadow ${odysseyDesignTokens.TransitionDurationMain} ${odysseyDesignTokens.TransitionTimingMain}`,
163
+ zIndex: UI_SHELL_BASE_Z_INDEX
164
+ }));
165
+ const StyledTopNavMenu = styled("div", {
166
+ shouldForwardProp: prop => prop !== "odysseyDesignTokens" && prop !== "topNavBackgroundColor"
167
+ })(({
168
+ odysseyDesignTokens,
169
+ topNavBackgroundColor
170
+ }) => ({
171
+ alignItems: "center",
172
+ display: "flex",
173
+ gap: odysseyDesignTokens.Spacing3,
174
+ height: "100%",
175
+ justifyContent: "space-between",
176
+ maxHeight: TOP_NAV_HEIGHT,
177
+ minHeight: TOP_NAV_HEIGHT,
178
+ paddingBlock: odysseyDesignTokens.Spacing2,
179
+ paddingInline: odysseyDesignTokens.Spacing3,
180
+ transition: `box-shadow ${odysseyDesignTokens.TransitionDurationMain} ${odysseyDesignTokens.TransitionTimingMain}`,
181
+ ...(topNavBackgroundColor === odysseyDesignTokens.HueNeutralWhite && {
182
+ borderBottomColor: odysseyDesignTokens.HueNeutral100,
183
+ borderBottomStyle: odysseyDesignTokens.BorderStyleMain,
184
+ borderBottomWidth: odysseyDesignTokens.BorderWidthMain
185
+ })
186
+ }));
187
+ const StyledTopNavSearch = styled("div", {
188
+ shouldForwardProp: prop => prop !== "odysseyDesignTokens"
189
+ })(({
190
+ odysseyDesignTokens
191
+ }) => ({
192
+ paddingBlock: odysseyDesignTokens.Spacing2,
193
+ paddingInline: odysseyDesignTokens.Spacing3
194
+ }));
195
+ const NarrowUiShellContent = ({
196
+ appElement,
197
+ appElementScrollingMode,
198
+ hasStandardAppContentPadding = true,
199
+ initialVisibleSections = ["TopNav", "SideNav", "AppSwitcher"],
200
+ onError = console.error,
201
+ optionalComponents,
202
+ sideNavProps,
203
+ topNavProps
204
+ }) => {
205
+ const odysseyDesignTokens = useOdysseyDesignTokens();
206
+ const uiShellContext = useUiShellContext();
207
+ const {
208
+ isContentScrolled
209
+ } = useScrollState(appElement);
210
+ const sideNavContainerRef = useRef(null);
211
+ const topNavContainerRef = useRef(null);
212
+ const uiShellAppAreaRef = useRef(null);
213
+ const [isLeftSideMenuOpen, setIsLeftSideMenuOpen] = useState(false);
214
+ const [isRightSideMenuOpen, setIsRightSideMenuOpen] = useState(false);
215
+ const closeSideMenus = useCallback(() => {
216
+ setIsLeftSideMenuOpen(false);
217
+ setIsRightSideMenuOpen(false);
218
+ }, []);
219
+ useEffect(() => {
220
+ const unsubscribe = uiShellContext?.subscribeSideNavItemClicked(() => {
221
+ closeSideMenus();
222
+ });
223
+ return () => {
224
+ unsubscribe?.();
225
+ };
226
+ }, [closeSideMenus, uiShellContext]);
227
+ const toggleLeftSideMenu = useCallback(() => {
228
+ setIsRightSideMenuOpen(false);
229
+ setIsLeftSideMenuOpen(isLeftSideMenuOpen => !isLeftSideMenuOpen);
230
+ }, []);
231
+ const toggleRightSideMenu = useCallback(() => {
232
+ setIsLeftSideMenuOpen(false);
233
+ setIsRightSideMenuOpen(isRightSideMenuOpen => !isRightSideMenuOpen);
234
+ }, []);
235
+ const {
236
+ parentContainerRef
237
+ } = useMatchAppElementToUiShellAppArea({
238
+ appElement,
239
+ appElementScrollingMode,
240
+ paddingMode: hasStandardAppContentPadding ? "compact" : "none",
241
+ uiShellAppAreaRef,
242
+ uiShellResizableRefs: [sideNavContainerRef, topNavContainerRef, uiShellAppAreaRef]
243
+ });
244
+ return _jsxs(_Fragment, {
245
+ children: [(isLeftSideMenuOpen || isRightSideMenuOpen) && _jsx(StyledPageOverlay, {
246
+ odysseyDesignTokens: odysseyDesignTokens,
247
+ onClick: closeSideMenus
248
+ }), _jsxs(StyledUiShellContainer, {
249
+ odysseyDesignTokens: odysseyDesignTokens,
250
+ ref: parentContainerRef,
251
+ children: [_jsx(StyledBannersContainer, {
252
+ children: optionalComponents?.banners
253
+ }), (initialVisibleSections?.includes("TopNav") || topNavProps) && _jsx(ErrorBoundary, {
254
+ fallback: null,
255
+ onError: onError,
256
+ children: _jsxs(StyledTopNav, {
257
+ isContentScrolled: isContentScrolled,
258
+ odysseyDesignTokens: odysseyDesignTokens,
259
+ topNavBackgroundColor: uiShellContext?.topNavBackgroundColor,
260
+ children: [_jsxs(StyledTopNavMenu, {
261
+ odysseyDesignTokens: odysseyDesignTokens,
262
+ topNavBackgroundColor: uiShellContext?.sideNavBackgroundColor,
263
+ children: [_jsxs(StyledMenuLogo, {
264
+ odysseyDesignTokens: odysseyDesignTokens,
265
+ children: [_jsx(Button, {
266
+ onClick: toggleLeftSideMenu,
267
+ startIcon: _jsx(HamburgerMenuIcon, {}),
268
+ variant: "floating"
269
+ }), _jsx(StyledLogoContainer, {
270
+ odysseyDesignTokens: odysseyDesignTokens,
271
+ children: sideNavProps?.isLoading ? _jsx(_Skeleton, {
272
+ variant: "rounded",
273
+ height: 24,
274
+ width: 67
275
+ }) : _jsx(SideNavLogo, {
276
+ ...sideNavProps?.logoProps
277
+ })
278
+ })]
279
+ }), optionalComponents?.rightSideMenu && _jsx(Button, {
280
+ onClick: toggleRightSideMenu,
281
+ startIcon: isRightSideMenuOpen ? _jsx(CloseIcon, {}) : _jsx(MoreIcon, {}),
282
+ variant: "floating"
283
+ })]
284
+ }), optionalComponents?.topNavLeftSide && _jsx(StyledTopNavSearch, {
285
+ odysseyDesignTokens: odysseyDesignTokens,
286
+ children: optionalComponents?.topNavLeftSide
287
+ })]
288
+ })
289
+ }), _jsxs(StyledAppContentArea, {
290
+ children: [_jsx(StyledLeftSideContainer, {
291
+ isOpen: isLeftSideMenuOpen,
292
+ children: sideNavProps && _jsx(ErrorBoundary, {
293
+ fallback: null,
294
+ onError: onError,
295
+ children: _jsx(StyledSideNavContainer, {
296
+ children: _jsx(SideNav, {
297
+ ...{
298
+ ...sideNavProps,
299
+ appName: undefined,
300
+ logoProps: undefined
301
+ },
302
+ ...(sideNavProps.hasCustomFooter && optionalComponents?.sideNavFooter ? {
303
+ footerComponent: optionalComponents.sideNavFooter,
304
+ footerItems: undefined,
305
+ hasCustomFooter: sideNavProps.hasCustomFooter
306
+ } : {
307
+ footerItems: sideNavProps.footerItems,
308
+ hasCustomFooter: false
309
+ }),
310
+ isCollapsed: false,
311
+ isCollapsible: false,
312
+ isObtrusive: true
313
+ })
314
+ })
315
+ })
316
+ }), _jsx(StyledRightSideContainer, {
317
+ isOpen: isRightSideMenuOpen,
318
+ odysseyDesignTokens: odysseyDesignTokens,
319
+ children: _jsx(StyledSideNavContainer, {
320
+ children: optionalComponents?.rightSideMenu
321
+ })
322
+ }), _jsx(StyledAppContainer, {
323
+ appBackgroundColor: uiShellContext?.appBackgroundColor,
324
+ tabIndex: 0,
325
+ ref: uiShellAppAreaRef
326
+ })]
327
+ })]
328
+ })]
329
+ });
330
+ };
331
+ const MemoizedNarrowUiShellContent = memo(NarrowUiShellContent);
332
+ MemoizedNarrowUiShellContent.displayName = "NarrowUiShellContent";
333
+ export { MemoizedNarrowUiShellContent as NarrowUiShellContent };
334
+ //# sourceMappingURL=NarrowUiShellContent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NarrowUiShellContent.js","names":["styled","memo","useCallback","useEffect","useRef","useState","ErrorBoundary","Button","CloseIcon","MoreIcon","useOdysseyDesignTokens","SideNav","SideNavLogo","HamburgerMenuIcon","useUiShellContext","SIDE_NAV_WIDTH","TOP_NAV_HEIGHT","UI_SHELL_BASE_Z_INDEX","useScrollState","useMatchAppElementToUiShellAppArea","hexToRgb","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","StyledAppContentArea","gridArea","position","display","gridGap","gridTemplateAreas","gridTemplateColumns","gridTemplateRows","height","width","StyledAppContainer","shouldForwardProp","prop","appBackgroundColor","backgroundColor","overflow","StyledBannersContainer","zIndex","StyledLeftSideContainer","isOpen","overflowY","StyledRightSideContainer","odysseyDesignTokens","HueNeutralWhite","maxWidth","right","StyledMenuLogo","alignItems","gap","Spacing3","StyledLogoContainer","paddingBlock","Spacing4","maxHeight","StyledPageOverlay","HueNeutral900","asFormattedString","replace","left","top","StyledSideNavContainer","StyledUiShellContainer","HueNeutral50","StyledTopNav","isContentScrolled","topNavBackgroundColor","boxShadow","DepthMedium","undefined","clipPath","flexDirection","justifyContent","transition","TransitionDurationMain","TransitionTimingMain","StyledTopNavMenu","minHeight","Spacing2","paddingInline","borderBottomColor","HueNeutral100","borderBottomStyle","BorderStyleMain","borderBottomWidth","BorderWidthMain","StyledTopNavSearch","NarrowUiShellContent","appElement","appElementScrollingMode","hasStandardAppContentPadding","initialVisibleSections","onError","console","error","optionalComponents","sideNavProps","topNavProps","uiShellContext","sideNavContainerRef","topNavContainerRef","uiShellAppAreaRef","isLeftSideMenuOpen","setIsLeftSideMenuOpen","isRightSideMenuOpen","setIsRightSideMenuOpen","closeSideMenus","unsubscribe","subscribeSideNavItemClicked","toggleLeftSideMenu","toggleRightSideMenu","parentContainerRef","paddingMode","uiShellResizableRefs","children","onClick","ref","banners","includes","fallback","sideNavBackgroundColor","startIcon","variant","isLoading","_Skeleton","logoProps","rightSideMenu","topNavLeftSide","appName","hasCustomFooter","sideNavFooter","footerComponent","footerItems","isCollapsed","isCollapsible","isObtrusive","tabIndex","MemoizedNarrowUiShellContent","displayName"],"sources":["../../../src/ui-shell/NarrowUiShellContent.tsx"],"sourcesContent":["/*!\n * Copyright (c) 2022-present, Okta, Inc. and/or its affiliates. All rights reserved.\n * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the \"License.\")\n *\n * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n *\n * See the License for the specific language governing permissions and limitations under the License.\n */\n\nimport styled from \"@emotion/styled\";\nimport { Skeleton } from \"@mui/material\";\nimport {\n CSSProperties,\n memo,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport { ErrorBoundary } from \"react-error-boundary\";\n\nimport { Button } from \"../Buttons/Button.js\";\nimport type { HtmlProps } from \"../HtmlProps.js\";\nimport { CloseIcon } from \"../icons.generated/Close.js\";\nimport { MoreIcon } from \"../icons.generated/More.js\";\nimport {\n DesignTokens,\n useOdysseyDesignTokens,\n} from \"../OdysseyDesignTokensContext.js\";\nimport { SideNav } from \"./SideNav/SideNav.js\";\nimport { SideNavLogo } from \"./SideNav/SideNavLogo.js\";\nimport { HamburgerMenuIcon } from \"./TopNav/HamburgerMenuIcon.js\";\nimport { UiShellColors, useUiShellContext } from \"./UiShellProvider.js\";\nimport {\n UiShellNavComponentProps,\n UiShellContentProps,\n} from \"./uiShellContentTypes.js\";\nimport {\n SIDE_NAV_WIDTH,\n TOP_NAV_HEIGHT,\n UI_SHELL_BASE_Z_INDEX,\n} from \"./uiShellSharedConstants.js\";\nimport { useScrollState } from \"./useScrollState.js\";\nimport { useMatchAppElementToUiShellAppArea } from \"./useMatchAppElementToUiShellAppArea.js\";\nimport { hexToRgb } from \"../hexToRgb.js\";\n\nconst StyledAppContentArea = styled(\"div\")({\n gridArea: \"app-content\",\n position: \"relative\",\n display: \"grid\",\n gridGap: 0,\n gridTemplateAreas: `\n \"left-side app-container right-side\"\n `,\n gridTemplateColumns: \"auto 1fr auto\",\n gridTemplateRows: \"1fr\",\n height: \"100%\",\n width: \"100%\",\n});\n\nconst StyledAppContainer = styled(\"div\", {\n shouldForwardProp: (prop) =>\n prop !== \"appBackgroundColor\" && prop !== \"odysseyDesignTokens\",\n})<{\n appBackgroundColor?: UiShellColors[\"appBackgroundColor\"];\n}>(({ appBackgroundColor }) => ({\n backgroundColor: appBackgroundColor,\n height: \"100%\",\n gridArea: \"app-container\",\n overflow: \"hidden\",\n width: \"100%\",\n}));\n\nconst StyledBannersContainer = styled(\"div\")({\n gridArea: \"banners\",\n zIndex: UI_SHELL_BASE_Z_INDEX,\n});\n\nconst StyledLeftSideContainer = styled(\"div\", {\n shouldForwardProp: (prop) => prop !== \"isOpen\",\n})<{\n isOpen: boolean;\n}>(({ isOpen }) => ({\n display: isOpen ? \"block\" : \"none\",\n height: \"100%\",\n gridArea: \"left-side\",\n overflowY: \"auto\",\n position: \"absolute\",\n zIndex: UI_SHELL_BASE_Z_INDEX,\n}));\n\nconst StyledRightSideContainer = styled(\"div\", {\n shouldForwardProp: (prop) =>\n prop !== \"isOpen\" && prop !== \"odysseyDesignTokens\",\n})<{\n isOpen: boolean;\n odysseyDesignTokens: DesignTokens;\n}>(({ isOpen, odysseyDesignTokens }) => ({\n backgroundColor: odysseyDesignTokens.HueNeutralWhite,\n display: isOpen ? \"block\" : \"none\",\n gridArea: \"right-side\",\n height: \"100%\",\n maxWidth: SIDE_NAV_WIDTH,\n overflowY: \"auto\",\n position: \"absolute\",\n right: 0,\n width: SIDE_NAV_WIDTH,\n zIndex: UI_SHELL_BASE_Z_INDEX,\n}));\n\nconst StyledMenuLogo = styled(\"div\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{\n odysseyDesignTokens: DesignTokens;\n}>(({ odysseyDesignTokens }) => ({\n alignItems: \"center\",\n display: \"inline-flex\",\n gap: odysseyDesignTokens.Spacing3,\n}));\n\nconst StyledLogoContainer = styled(\"div\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{\n odysseyDesignTokens: DesignTokens;\n}>(({ odysseyDesignTokens }) => ({\n height: TOP_NAV_HEIGHT,\n paddingBlock: odysseyDesignTokens.Spacing4,\n\n \"svg, img\": {\n maxHeight: \"100%\",\n width: \"auto\",\n maxWidth: \"100%\",\n },\n}));\n\nconst StyledPageOverlay = styled(\"div\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{\n odysseyDesignTokens: DesignTokens;\n}>(({ odysseyDesignTokens }) => ({\n backgroundColor: hexToRgb(\n odysseyDesignTokens.HueNeutral900,\n ).asFormattedString.replace(/rgb\\((.+)\\)$/, \"rgba($1, 0.26)\"),\n gridArea: \"app-content\",\n height: \"100vh\",\n left: 0,\n position: \"absolute\",\n top: 0,\n width: \"100vw\",\n zIndex: UI_SHELL_BASE_Z_INDEX,\n}));\n\nconst StyledSideNavContainer = styled(\"div\")({\n height: \"100%\", // Without this value, side nav won't fill up the height if the content is too short.\n});\n\nconst StyledUiShellContainer = styled(\"div\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{\n odysseyDesignTokens: DesignTokens;\n}>(({ odysseyDesignTokens }) => ({\n backgroundColor: odysseyDesignTokens.HueNeutral50,\n display: \"grid\",\n gridGap: 0,\n gridTemplateAreas: `\n \"banners\"\n \"top-nav\"\n \"app-content\"\n `,\n gridTemplateColumns: \"1fr\",\n gridTemplateRows: \"auto auto 1fr\",\n height: \"100vh\",\n overflow: \"hidden\",\n width: \"100vw\",\n}));\n\nconst StyledTopNav = styled(\"div\", {\n shouldForwardProp: (prop) =>\n prop !== \"odysseyDesignTokens\" &&\n prop !== \"isContentScrolled\" &&\n prop !== \"topNavBackgroundColor\",\n})<{\n isContentScrolled?: boolean;\n odysseyDesignTokens: DesignTokens;\n topNavBackgroundColor?: UiShellColors[\"topNavBackgroundColor\"];\n}>(({ odysseyDesignTokens, isContentScrolled, topNavBackgroundColor }) => ({\n alignItems: \"stretch\",\n backgroundColor: odysseyDesignTokens.HueNeutralWhite || topNavBackgroundColor, // This logic doesn't make sense, but I wanted to leave it here for when we eventually make a decision on `topNavBackgroundColor`. --Kevin Ghadyani\n boxShadow: isContentScrolled ? odysseyDesignTokens.DepthMedium : undefined,\n clipPath: \"inset(0 0 -100vh 0)\",\n display: \"flex\",\n flexDirection: \"column\",\n gridArea: \"top-nav\",\n height: \"100%\",\n justifyContent: \"center\",\n position: \"relative\",\n transition: `box-shadow ${odysseyDesignTokens.TransitionDurationMain} ${odysseyDesignTokens.TransitionTimingMain}`,\n zIndex: UI_SHELL_BASE_Z_INDEX,\n}));\n\nconst StyledTopNavMenu = styled(\"div\", {\n shouldForwardProp: (prop) =>\n prop !== \"odysseyDesignTokens\" && prop !== \"topNavBackgroundColor\",\n})<{\n odysseyDesignTokens: DesignTokens;\n topNavBackgroundColor?: UiShellColors[\"topNavBackgroundColor\"];\n}>(({ odysseyDesignTokens, topNavBackgroundColor }) => ({\n alignItems: \"center\",\n display: \"flex\",\n gap: odysseyDesignTokens.Spacing3,\n height: \"100%\",\n justifyContent: \"space-between\",\n maxHeight: TOP_NAV_HEIGHT,\n minHeight: TOP_NAV_HEIGHT,\n paddingBlock: odysseyDesignTokens.Spacing2,\n paddingInline: odysseyDesignTokens.Spacing3,\n transition: `box-shadow ${odysseyDesignTokens.TransitionDurationMain} ${odysseyDesignTokens.TransitionTimingMain}`,\n\n ...(topNavBackgroundColor === odysseyDesignTokens.HueNeutralWhite &&\n ({\n borderBottomColor: odysseyDesignTokens.HueNeutral100,\n borderBottomStyle: odysseyDesignTokens.BorderStyleMain,\n borderBottomWidth: odysseyDesignTokens.BorderWidthMain,\n } as CSSProperties)),\n}));\n\nconst StyledTopNavSearch = styled(\"div\", {\n shouldForwardProp: (prop) => prop !== \"odysseyDesignTokens\",\n})<{\n odysseyDesignTokens: DesignTokens;\n}>(({ odysseyDesignTokens }) => ({\n paddingBlock: odysseyDesignTokens.Spacing2,\n paddingInline: odysseyDesignTokens.Spacing3,\n}));\n\nexport type NarrowUiShellContentProps = Pick<HtmlProps, \"testId\"> &\n Pick<UiShellNavComponentProps, \"sideNavProps\" | \"topNavProps\"> &\n UiShellContentProps;\n\nconst NarrowUiShellContent = ({\n appElement,\n appElementScrollingMode,\n hasStandardAppContentPadding = true,\n initialVisibleSections = [\"TopNav\", \"SideNav\", \"AppSwitcher\"],\n onError = console.error,\n optionalComponents,\n sideNavProps,\n topNavProps,\n}: NarrowUiShellContentProps) => {\n const odysseyDesignTokens = useOdysseyDesignTokens();\n const uiShellContext = useUiShellContext();\n\n const { isContentScrolled } = useScrollState(appElement);\n\n const sideNavContainerRef = useRef<HTMLDivElement>(null);\n const topNavContainerRef = useRef<HTMLDivElement>(null);\n const uiShellAppAreaRef = useRef<HTMLDivElement>(null);\n\n const [isLeftSideMenuOpen, setIsLeftSideMenuOpen] = useState(false);\n const [isRightSideMenuOpen, setIsRightSideMenuOpen] = useState(false);\n\n const closeSideMenus = useCallback(() => {\n setIsLeftSideMenuOpen(false);\n setIsRightSideMenuOpen(false);\n }, []);\n\n useEffect(() => {\n const unsubscribe = uiShellContext?.subscribeSideNavItemClicked(() => {\n closeSideMenus();\n });\n\n return () => {\n unsubscribe?.();\n };\n }, [closeSideMenus, uiShellContext]);\n\n const toggleLeftSideMenu = useCallback(() => {\n setIsRightSideMenuOpen(false);\n setIsLeftSideMenuOpen((isLeftSideMenuOpen) => !isLeftSideMenuOpen);\n }, []);\n\n const toggleRightSideMenu = useCallback(() => {\n setIsLeftSideMenuOpen(false);\n setIsRightSideMenuOpen((isRightSideMenuOpen) => !isRightSideMenuOpen);\n }, []);\n\n const { parentContainerRef } = useMatchAppElementToUiShellAppArea({\n appElement,\n appElementScrollingMode,\n paddingMode: hasStandardAppContentPadding ? \"compact\" : \"none\",\n uiShellAppAreaRef,\n uiShellResizableRefs: [\n sideNavContainerRef,\n topNavContainerRef,\n uiShellAppAreaRef,\n ],\n });\n\n return (\n <>\n {(isLeftSideMenuOpen || isRightSideMenuOpen) && (\n <StyledPageOverlay\n odysseyDesignTokens={odysseyDesignTokens}\n onClick={closeSideMenus}\n />\n )}\n\n <StyledUiShellContainer\n odysseyDesignTokens={odysseyDesignTokens}\n ref={parentContainerRef}\n >\n <StyledBannersContainer>\n {optionalComponents?.banners}\n </StyledBannersContainer>\n\n {(initialVisibleSections?.includes(\"TopNav\") || topNavProps) && (\n <ErrorBoundary fallback={null} onError={onError}>\n <StyledTopNav\n isContentScrolled={isContentScrolled}\n odysseyDesignTokens={odysseyDesignTokens}\n topNavBackgroundColor={uiShellContext?.topNavBackgroundColor}\n >\n <StyledTopNavMenu\n odysseyDesignTokens={odysseyDesignTokens}\n topNavBackgroundColor={uiShellContext?.sideNavBackgroundColor}\n >\n <StyledMenuLogo odysseyDesignTokens={odysseyDesignTokens}>\n <Button\n onClick={toggleLeftSideMenu}\n startIcon={<HamburgerMenuIcon />}\n variant=\"floating\"\n />\n\n <StyledLogoContainer\n odysseyDesignTokens={odysseyDesignTokens}\n >\n {sideNavProps?.isLoading ? (\n // The skeleton takes the hardcoded dimensions of the Okta logo\n <Skeleton variant=\"rounded\" height={24} width={67} />\n ) : (\n <SideNavLogo {...sideNavProps?.logoProps} />\n )}\n </StyledLogoContainer>\n </StyledMenuLogo>\n\n {optionalComponents?.rightSideMenu && (\n <Button\n onClick={toggleRightSideMenu}\n startIcon={\n isRightSideMenuOpen ? <CloseIcon /> : <MoreIcon />\n }\n variant=\"floating\"\n />\n )}\n </StyledTopNavMenu>\n\n {optionalComponents?.topNavLeftSide && (\n <StyledTopNavSearch odysseyDesignTokens={odysseyDesignTokens}>\n {optionalComponents?.topNavLeftSide}\n </StyledTopNavSearch>\n )}\n </StyledTopNav>\n </ErrorBoundary>\n )}\n\n <StyledAppContentArea>\n <StyledLeftSideContainer isOpen={isLeftSideMenuOpen}>\n {sideNavProps && (\n <ErrorBoundary fallback={null} onError={onError}>\n <StyledSideNavContainer>\n <SideNav\n {...{\n ...{\n ...sideNavProps,\n // This hides the side nav logo or app name from showing up as we already have one in the narrow top nav.\n appName: undefined,\n logoProps: undefined,\n },\n ...(sideNavProps.hasCustomFooter &&\n optionalComponents?.sideNavFooter\n ? {\n footerComponent: optionalComponents.sideNavFooter,\n footerItems: undefined,\n hasCustomFooter: sideNavProps.hasCustomFooter,\n }\n : {\n footerItems: sideNavProps.footerItems,\n hasCustomFooter: false,\n }),\n }}\n isCollapsed={false}\n isCollapsible={false}\n isObtrusive\n />\n </StyledSideNavContainer>\n </ErrorBoundary>\n )}\n </StyledLeftSideContainer>\n\n <StyledRightSideContainer\n isOpen={isRightSideMenuOpen}\n odysseyDesignTokens={odysseyDesignTokens}\n >\n <StyledSideNavContainer>\n {optionalComponents?.rightSideMenu}\n </StyledSideNavContainer>\n </StyledRightSideContainer>\n\n <StyledAppContainer\n appBackgroundColor={uiShellContext?.appBackgroundColor}\n tabIndex={0}\n ref={uiShellAppAreaRef}\n />\n </StyledAppContentArea>\n </StyledUiShellContainer>\n </>\n );\n};\n\nconst MemoizedNarrowUiShellContent = memo(NarrowUiShellContent);\nMemoizedNarrowUiShellContent.displayName = \"NarrowUiShellContent\";\n\nexport { MemoizedNarrowUiShellContent as NarrowUiShellContent };\n"],"mappings":"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","ignoreList":[]}