@okta/odyssey-react-mui 1.32.0 → 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 (759) 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/components.cjs +6 -0
  69. package/dist/cjs/theme/components.cjs.map +1 -1
  70. package/{src/theme/palette.types.ts → dist/cjs/theme/pxToRem.cjs} +10 -13
  71. package/dist/cjs/theme/pxToRem.cjs.map +1 -0
  72. package/dist/cjs/theme/theme.cjs +22 -0
  73. package/dist/cjs/theme/theme.cjs.map +1 -1
  74. package/dist/cjs/theme/useMediaQuery.cjs +34 -0
  75. package/dist/cjs/theme/useMediaQuery.cjs.map +1 -0
  76. package/dist/cjs/ui-shell/AppSwitcher/AppSwitcher.cjs +3 -3
  77. package/dist/cjs/ui-shell/AppSwitcher/AppSwitcher.cjs.map +1 -1
  78. package/dist/cjs/ui-shell/NarrowUiShellContent.cjs +340 -0
  79. package/dist/cjs/ui-shell/NarrowUiShellContent.cjs.map +1 -0
  80. package/dist/cjs/ui-shell/SideNav/SideNav.cjs +64 -45
  81. package/dist/cjs/ui-shell/SideNav/SideNav.cjs.map +1 -1
  82. package/dist/cjs/ui-shell/SideNav/SideNavHeader.cjs +8 -5
  83. package/dist/cjs/ui-shell/SideNav/SideNavHeader.cjs.map +1 -1
  84. package/dist/cjs/ui-shell/SideNav/SideNavItemContent.cjs +39 -11
  85. package/dist/cjs/ui-shell/SideNav/SideNavItemContent.cjs.map +1 -1
  86. package/dist/cjs/ui-shell/SideNav/SideNavItemLinkContent.cjs +3 -1
  87. package/dist/cjs/ui-shell/SideNav/SideNavItemLinkContent.cjs.map +1 -1
  88. package/dist/cjs/ui-shell/SideNav/SideNavLogo.cjs +14 -2
  89. package/dist/cjs/ui-shell/SideNav/SideNavLogo.cjs.map +1 -1
  90. package/dist/cjs/ui-shell/SideNav/SideNavToggleButton.cjs +2 -1
  91. package/dist/cjs/ui-shell/SideNav/SideNavToggleButton.cjs.map +1 -1
  92. package/dist/cjs/ui-shell/SideNav/types.cjs.map +1 -1
  93. package/dist/cjs/ui-shell/TopNav/HamburgerMenuIcon.cjs +37 -0
  94. package/dist/cjs/ui-shell/TopNav/HamburgerMenuIcon.cjs.map +1 -0
  95. package/dist/cjs/ui-shell/TopNav/TopNav.cjs +5 -5
  96. package/dist/cjs/ui-shell/TopNav/TopNav.cjs.map +1 -1
  97. package/dist/cjs/ui-shell/UiShell.cjs +37 -18
  98. package/dist/cjs/ui-shell/UiShell.cjs.map +1 -1
  99. package/dist/cjs/ui-shell/UiShellProvider.cjs +10 -3
  100. package/dist/cjs/ui-shell/UiShellProvider.cjs.map +1 -1
  101. package/dist/cjs/ui-shell/WideUiShellContent.cjs +171 -0
  102. package/dist/cjs/ui-shell/WideUiShellContent.cjs.map +1 -0
  103. package/dist/cjs/ui-shell/index.cjs +36 -0
  104. package/dist/cjs/ui-shell/index.cjs.map +1 -1
  105. package/dist/cjs/ui-shell/renderUiShell.cjs +19 -20
  106. package/dist/cjs/ui-shell/renderUiShell.cjs.map +1 -1
  107. package/{src/TagListContext.tsx → dist/cjs/ui-shell/uiShellContentTypes.cjs} +9 -12
  108. package/dist/cjs/ui-shell/uiShellContentTypes.cjs.map +1 -0
  109. package/dist/cjs/ui-shell/uiShellSharedConstants.cjs +22 -0
  110. package/dist/cjs/ui-shell/uiShellSharedConstants.cjs.map +1 -0
  111. package/dist/cjs/ui-shell/useMatchAppElementToUiShellAppArea.cjs +108 -0
  112. package/dist/cjs/ui-shell/useMatchAppElementToUiShellAppArea.cjs.map +1 -0
  113. package/dist/cjs/ui-shell/useScrollState.cjs +2 -4
  114. package/dist/cjs/ui-shell/useScrollState.cjs.map +1 -1
  115. package/dist/cjs/ui-shell/useUiShellBreakpoints.cjs +41 -0
  116. package/dist/cjs/ui-shell/useUiShellBreakpoints.cjs.map +1 -0
  117. package/dist/cjs/useContrastMode.cjs +1 -1
  118. package/dist/cjs/useContrastMode.cjs.map +1 -1
  119. package/dist/cjs/web-component/createReactRootElements.cjs.map +1 -1
  120. package/dist/cjs/web-component/renderReactInWebComponent.cjs +6 -1
  121. package/dist/cjs/web-component/renderReactInWebComponent.cjs.map +1 -1
  122. package/dist/esm/Autocomplete.js +1 -1
  123. package/dist/esm/Autocomplete.js.map +1 -1
  124. package/dist/esm/Breadcrumbs.js +23 -7
  125. package/dist/esm/Breadcrumbs.js.map +1 -1
  126. package/dist/esm/DatePickers/datePickerTheme.js +1 -1
  127. package/dist/esm/DatePickers/datePickerTheme.js.map +1 -1
  128. package/dist/esm/OdysseyProvider.js +2 -2
  129. package/dist/esm/OdysseyProvider.js.map +1 -1
  130. package/dist/esm/OdysseyThemeProvider.js +2 -2
  131. package/dist/esm/OdysseyThemeProvider.js.map +1 -1
  132. package/dist/esm/hexToRgb.js.map +1 -1
  133. package/dist/esm/properties/ts/odyssey-react-mui.js +1 -0
  134. package/dist/esm/properties/ts/odyssey-react-mui.js.map +1 -1
  135. package/dist/esm/properties/ts/odyssey-react-mui_cs.js +1 -0
  136. package/dist/esm/properties/ts/odyssey-react-mui_cs.js.map +1 -1
  137. package/dist/esm/properties/ts/odyssey-react-mui_da.js +1 -0
  138. package/dist/esm/properties/ts/odyssey-react-mui_da.js.map +1 -1
  139. package/dist/esm/properties/ts/odyssey-react-mui_de.js +1 -0
  140. package/dist/esm/properties/ts/odyssey-react-mui_de.js.map +1 -1
  141. package/dist/esm/properties/ts/odyssey-react-mui_el.js +1 -0
  142. package/dist/esm/properties/ts/odyssey-react-mui_el.js.map +1 -1
  143. package/dist/esm/properties/ts/odyssey-react-mui_es.js +1 -0
  144. package/dist/esm/properties/ts/odyssey-react-mui_es.js.map +1 -1
  145. package/dist/esm/properties/ts/odyssey-react-mui_fi.js +1 -0
  146. package/dist/esm/properties/ts/odyssey-react-mui_fi.js.map +1 -1
  147. package/dist/esm/properties/ts/odyssey-react-mui_fr.js +1 -0
  148. package/dist/esm/properties/ts/odyssey-react-mui_fr.js.map +1 -1
  149. package/dist/esm/properties/ts/odyssey-react-mui_ht.js +1 -0
  150. package/dist/esm/properties/ts/odyssey-react-mui_ht.js.map +1 -1
  151. package/dist/esm/properties/ts/odyssey-react-mui_hu.js +1 -0
  152. package/dist/esm/properties/ts/odyssey-react-mui_hu.js.map +1 -1
  153. package/dist/esm/properties/ts/odyssey-react-mui_id.js +1 -0
  154. package/dist/esm/properties/ts/odyssey-react-mui_id.js.map +1 -1
  155. package/dist/esm/properties/ts/odyssey-react-mui_it.js +1 -0
  156. package/dist/esm/properties/ts/odyssey-react-mui_it.js.map +1 -1
  157. package/dist/esm/properties/ts/odyssey-react-mui_ja.js +1 -0
  158. package/dist/esm/properties/ts/odyssey-react-mui_ja.js.map +1 -1
  159. package/dist/esm/properties/ts/odyssey-react-mui_ko.js +1 -0
  160. package/dist/esm/properties/ts/odyssey-react-mui_ko.js.map +1 -1
  161. package/dist/esm/properties/ts/odyssey-react-mui_ms.js +1 -0
  162. package/dist/esm/properties/ts/odyssey-react-mui_ms.js.map +1 -1
  163. package/dist/esm/properties/ts/odyssey-react-mui_nb.js +1 -0
  164. package/dist/esm/properties/ts/odyssey-react-mui_nb.js.map +1 -1
  165. package/dist/esm/properties/ts/odyssey-react-mui_nl_NL.js +1 -0
  166. package/dist/esm/properties/ts/odyssey-react-mui_nl_NL.js.map +1 -1
  167. package/dist/esm/properties/ts/odyssey-react-mui_pl.js +1 -0
  168. package/dist/esm/properties/ts/odyssey-react-mui_pl.js.map +1 -1
  169. package/dist/esm/properties/ts/odyssey-react-mui_pt_BR.js +1 -0
  170. package/dist/esm/properties/ts/odyssey-react-mui_pt_BR.js.map +1 -1
  171. package/dist/esm/properties/ts/odyssey-react-mui_ro.js +1 -0
  172. package/dist/esm/properties/ts/odyssey-react-mui_ro.js.map +1 -1
  173. package/dist/esm/properties/ts/odyssey-react-mui_ru.js +1 -0
  174. package/dist/esm/properties/ts/odyssey-react-mui_ru.js.map +1 -1
  175. package/dist/esm/properties/ts/odyssey-react-mui_sv.js +1 -0
  176. package/dist/esm/properties/ts/odyssey-react-mui_sv.js.map +1 -1
  177. package/dist/esm/properties/ts/odyssey-react-mui_th.js +1 -0
  178. package/dist/esm/properties/ts/odyssey-react-mui_th.js.map +1 -1
  179. package/dist/esm/properties/ts/odyssey-react-mui_tr.js +1 -0
  180. package/dist/esm/properties/ts/odyssey-react-mui_tr.js.map +1 -1
  181. package/dist/esm/properties/ts/odyssey-react-mui_uk.js +1 -0
  182. package/dist/esm/properties/ts/odyssey-react-mui_uk.js.map +1 -1
  183. package/dist/esm/properties/ts/odyssey-react-mui_vi.js +1 -0
  184. package/dist/esm/properties/ts/odyssey-react-mui_vi.js.map +1 -1
  185. package/dist/esm/properties/ts/odyssey-react-mui_zh_CN.js +1 -0
  186. package/dist/esm/properties/ts/odyssey-react-mui_zh_CN.js.map +1 -1
  187. package/dist/esm/properties/ts/odyssey-react-mui_zh_TW.js +1 -0
  188. package/dist/esm/properties/ts/odyssey-react-mui_zh_TW.js.map +1 -1
  189. package/dist/esm/theme/components.js +6 -0
  190. package/dist/esm/theme/components.js.map +1 -1
  191. package/{src/shadow-dom/index.ts → dist/esm/theme/pxToRem.js} +2 -1
  192. package/dist/esm/theme/pxToRem.js.map +1 -0
  193. package/dist/esm/theme/theme.js +2 -0
  194. package/dist/esm/theme/theme.js.map +1 -1
  195. package/{src/ui-shell/useHasUiShell.ts → dist/esm/theme/useMediaQuery.js} +13 -11
  196. package/dist/esm/theme/useMediaQuery.js.map +1 -0
  197. package/dist/esm/ui-shell/AppSwitcher/AppSwitcher.js +2 -2
  198. package/dist/esm/ui-shell/AppSwitcher/AppSwitcher.js.map +1 -1
  199. package/dist/esm/ui-shell/NarrowUiShellContent.js +334 -0
  200. package/dist/esm/ui-shell/NarrowUiShellContent.js.map +1 -0
  201. package/dist/esm/ui-shell/SideNav/SideNav.js +63 -44
  202. package/dist/esm/ui-shell/SideNav/SideNav.js.map +1 -1
  203. package/dist/esm/ui-shell/SideNav/SideNavHeader.js +7 -4
  204. package/dist/esm/ui-shell/SideNav/SideNavHeader.js.map +1 -1
  205. package/dist/esm/ui-shell/SideNav/SideNavItemContent.js +40 -12
  206. package/dist/esm/ui-shell/SideNav/SideNavItemContent.js.map +1 -1
  207. package/dist/esm/ui-shell/SideNav/SideNavItemLinkContent.js +3 -1
  208. package/dist/esm/ui-shell/SideNav/SideNavItemLinkContent.js.map +1 -1
  209. package/dist/esm/ui-shell/SideNav/SideNavLogo.js +14 -2
  210. package/dist/esm/ui-shell/SideNav/SideNavLogo.js.map +1 -1
  211. package/dist/esm/ui-shell/SideNav/SideNavToggleButton.js +2 -1
  212. package/dist/esm/ui-shell/SideNav/SideNavToggleButton.js.map +1 -1
  213. package/dist/esm/ui-shell/SideNav/types.js.map +1 -1
  214. package/dist/esm/ui-shell/TopNav/HamburgerMenuIcon.js +32 -0
  215. package/dist/esm/ui-shell/TopNav/HamburgerMenuIcon.js.map +1 -0
  216. package/dist/esm/ui-shell/TopNav/TopNav.js +2 -2
  217. package/dist/esm/ui-shell/TopNav/TopNav.js.map +1 -1
  218. package/dist/esm/ui-shell/UiShell.js +37 -18
  219. package/dist/esm/ui-shell/UiShell.js.map +1 -1
  220. package/dist/esm/ui-shell/UiShellProvider.js +10 -3
  221. package/dist/esm/ui-shell/UiShellProvider.js.map +1 -1
  222. package/dist/esm/ui-shell/WideUiShellContent.js +165 -0
  223. package/dist/esm/ui-shell/WideUiShellContent.js.map +1 -0
  224. package/dist/esm/ui-shell/index.js +3 -0
  225. package/dist/esm/ui-shell/index.js.map +1 -1
  226. package/dist/esm/ui-shell/renderUiShell.js +19 -20
  227. package/dist/esm/ui-shell/renderUiShell.js.map +1 -1
  228. package/{src/DataTable/constants.ts → dist/esm/ui-shell/uiShellContentTypes.js} +3 -2
  229. package/dist/esm/ui-shell/uiShellContentTypes.js.map +1 -0
  230. package/{src/CssBaseline.tsx → dist/esm/ui-shell/uiShellSharedConstants.js} +7 -11
  231. package/dist/esm/ui-shell/uiShellSharedConstants.js.map +1 -0
  232. package/dist/esm/ui-shell/useMatchAppElementToUiShellAppArea.js +99 -0
  233. package/dist/esm/ui-shell/useMatchAppElementToUiShellAppArea.js.map +1 -0
  234. package/dist/esm/ui-shell/useScrollState.js +3 -5
  235. package/dist/esm/ui-shell/useScrollState.js.map +1 -1
  236. package/dist/esm/ui-shell/useUiShellBreakpoints.js +34 -0
  237. package/dist/esm/ui-shell/useUiShellBreakpoints.js.map +1 -0
  238. package/dist/esm/useContrastMode.js +2 -2
  239. package/dist/esm/useContrastMode.js.map +1 -1
  240. package/dist/esm/web-component/createReactRootElements.js.map +1 -1
  241. package/dist/esm/web-component/renderReactInWebComponent.js +6 -1
  242. package/dist/esm/web-component/renderReactInWebComponent.js.map +1 -1
  243. package/dist/index.cjs +1 -1
  244. package/dist/index.mjs +1 -1
  245. package/dist/index.scss +1 -1
  246. package/dist/tsconfig.production.tsbuildinfo +1 -1
  247. package/dist/types/Autocomplete.d.ts +1 -1
  248. package/dist/types/Breadcrumbs.d.ts +4 -3
  249. package/dist/types/Breadcrumbs.d.ts.map +1 -1
  250. package/dist/types/OdysseyProvider.d.ts +1 -1
  251. package/dist/types/OdysseyProvider.d.ts.map +1 -1
  252. package/dist/types/OdysseyThemeProvider.d.ts.map +1 -1
  253. package/dist/types/OdysseyTranslationProvider.d.ts +1 -1
  254. package/dist/types/OdysseyTranslationProvider.d.ts.map +1 -1
  255. package/dist/types/hexToRgb.d.ts.map +1 -1
  256. package/dist/types/i18n.d.ts +28 -0
  257. package/dist/types/i18n.d.ts.map +1 -1
  258. package/dist/types/properties/ts/odyssey-react-mui.d.ts +1 -0
  259. package/dist/types/properties/ts/odyssey-react-mui.d.ts.map +1 -1
  260. package/dist/types/properties/ts/odyssey-react-mui_cs.d.ts +1 -0
  261. package/dist/types/properties/ts/odyssey-react-mui_cs.d.ts.map +1 -1
  262. package/dist/types/properties/ts/odyssey-react-mui_da.d.ts +1 -0
  263. package/dist/types/properties/ts/odyssey-react-mui_da.d.ts.map +1 -1
  264. package/dist/types/properties/ts/odyssey-react-mui_de.d.ts +1 -0
  265. package/dist/types/properties/ts/odyssey-react-mui_de.d.ts.map +1 -1
  266. package/dist/types/properties/ts/odyssey-react-mui_el.d.ts +1 -0
  267. package/dist/types/properties/ts/odyssey-react-mui_el.d.ts.map +1 -1
  268. package/dist/types/properties/ts/odyssey-react-mui_es.d.ts +1 -0
  269. package/dist/types/properties/ts/odyssey-react-mui_es.d.ts.map +1 -1
  270. package/dist/types/properties/ts/odyssey-react-mui_fi.d.ts +1 -0
  271. package/dist/types/properties/ts/odyssey-react-mui_fi.d.ts.map +1 -1
  272. package/dist/types/properties/ts/odyssey-react-mui_fr.d.ts +1 -0
  273. package/dist/types/properties/ts/odyssey-react-mui_fr.d.ts.map +1 -1
  274. package/dist/types/properties/ts/odyssey-react-mui_ht.d.ts +1 -0
  275. package/dist/types/properties/ts/odyssey-react-mui_ht.d.ts.map +1 -1
  276. package/dist/types/properties/ts/odyssey-react-mui_hu.d.ts +1 -0
  277. package/dist/types/properties/ts/odyssey-react-mui_hu.d.ts.map +1 -1
  278. package/dist/types/properties/ts/odyssey-react-mui_id.d.ts +1 -0
  279. package/dist/types/properties/ts/odyssey-react-mui_id.d.ts.map +1 -1
  280. package/dist/types/properties/ts/odyssey-react-mui_it.d.ts +1 -0
  281. package/dist/types/properties/ts/odyssey-react-mui_it.d.ts.map +1 -1
  282. package/dist/types/properties/ts/odyssey-react-mui_ja.d.ts +1 -0
  283. package/dist/types/properties/ts/odyssey-react-mui_ja.d.ts.map +1 -1
  284. package/dist/types/properties/ts/odyssey-react-mui_ko.d.ts +1 -0
  285. package/dist/types/properties/ts/odyssey-react-mui_ko.d.ts.map +1 -1
  286. package/dist/types/properties/ts/odyssey-react-mui_ms.d.ts +1 -0
  287. package/dist/types/properties/ts/odyssey-react-mui_ms.d.ts.map +1 -1
  288. package/dist/types/properties/ts/odyssey-react-mui_nb.d.ts +1 -0
  289. package/dist/types/properties/ts/odyssey-react-mui_nb.d.ts.map +1 -1
  290. package/dist/types/properties/ts/odyssey-react-mui_nl_NL.d.ts +1 -0
  291. package/dist/types/properties/ts/odyssey-react-mui_nl_NL.d.ts.map +1 -1
  292. package/dist/types/properties/ts/odyssey-react-mui_pl.d.ts +1 -0
  293. package/dist/types/properties/ts/odyssey-react-mui_pl.d.ts.map +1 -1
  294. package/dist/types/properties/ts/odyssey-react-mui_pt_BR.d.ts +1 -0
  295. package/dist/types/properties/ts/odyssey-react-mui_pt_BR.d.ts.map +1 -1
  296. package/dist/types/properties/ts/odyssey-react-mui_ro.d.ts +1 -0
  297. package/dist/types/properties/ts/odyssey-react-mui_ro.d.ts.map +1 -1
  298. package/dist/types/properties/ts/odyssey-react-mui_ru.d.ts +1 -0
  299. package/dist/types/properties/ts/odyssey-react-mui_ru.d.ts.map +1 -1
  300. package/dist/types/properties/ts/odyssey-react-mui_sv.d.ts +1 -0
  301. package/dist/types/properties/ts/odyssey-react-mui_sv.d.ts.map +1 -1
  302. package/dist/types/properties/ts/odyssey-react-mui_th.d.ts +1 -0
  303. package/dist/types/properties/ts/odyssey-react-mui_th.d.ts.map +1 -1
  304. package/dist/types/properties/ts/odyssey-react-mui_tr.d.ts +1 -0
  305. package/dist/types/properties/ts/odyssey-react-mui_tr.d.ts.map +1 -1
  306. package/dist/types/properties/ts/odyssey-react-mui_uk.d.ts +1 -0
  307. package/dist/types/properties/ts/odyssey-react-mui_uk.d.ts.map +1 -1
  308. package/dist/types/properties/ts/odyssey-react-mui_vi.d.ts +1 -0
  309. package/dist/types/properties/ts/odyssey-react-mui_vi.d.ts.map +1 -1
  310. package/dist/types/properties/ts/odyssey-react-mui_zh_CN.d.ts +1 -0
  311. package/dist/types/properties/ts/odyssey-react-mui_zh_CN.d.ts.map +1 -1
  312. package/dist/types/properties/ts/odyssey-react-mui_zh_TW.d.ts +1 -0
  313. package/dist/types/properties/ts/odyssey-react-mui_zh_TW.d.ts.map +1 -1
  314. package/dist/types/theme/components.d.ts.map +1 -1
  315. package/{src/DatePickers/index.ts → dist/types/theme/pxToRem.d.ts} +3 -5
  316. package/dist/types/theme/pxToRem.d.ts.map +1 -0
  317. package/dist/types/theme/theme.d.ts +2 -0
  318. package/dist/types/theme/theme.d.ts.map +1 -1
  319. package/{src/web-component/index.ts → dist/types/theme/useMediaQuery.d.ts} +2 -2
  320. package/dist/types/theme/useMediaQuery.d.ts.map +1 -0
  321. package/dist/types/ui-shell/AppSwitcher/AppSwitcher.d.ts.map +1 -1
  322. package/dist/types/ui-shell/NarrowUiShellContent.d.ts +17 -0
  323. package/dist/types/ui-shell/NarrowUiShellContent.d.ts.map +1 -0
  324. package/dist/types/ui-shell/SideNav/SideNav.d.ts +1 -3
  325. package/dist/types/ui-shell/SideNav/SideNav.d.ts.map +1 -1
  326. package/dist/types/ui-shell/SideNav/SideNavHeader.d.ts.map +1 -1
  327. package/dist/types/ui-shell/SideNav/SideNavItemContent.d.ts +9 -7
  328. package/dist/types/ui-shell/SideNav/SideNavItemContent.d.ts.map +1 -1
  329. package/dist/types/ui-shell/SideNav/SideNavItemLinkContent.d.ts +1 -1
  330. package/dist/types/ui-shell/SideNav/SideNavItemLinkContent.d.ts.map +1 -1
  331. package/dist/types/ui-shell/SideNav/SideNavLogo.d.ts.map +1 -1
  332. package/dist/types/ui-shell/SideNav/SideNavToggleButton.d.ts.map +1 -1
  333. package/dist/types/ui-shell/SideNav/types.d.ts +12 -2
  334. package/dist/types/ui-shell/SideNav/types.d.ts.map +1 -1
  335. package/{src/Buttons/ButtonContext.tsx → dist/types/ui-shell/TopNav/HamburgerMenuIcon.d.ts} +5 -12
  336. package/dist/types/ui-shell/TopNav/HamburgerMenuIcon.d.ts.map +1 -0
  337. package/dist/types/ui-shell/TopNav/TopNav.d.ts +0 -1
  338. package/dist/types/ui-shell/TopNav/TopNav.d.ts.map +1 -1
  339. package/dist/types/ui-shell/UiShell.d.ts +20 -7
  340. package/dist/types/ui-shell/UiShell.d.ts.map +1 -1
  341. package/dist/types/ui-shell/UiShellProvider.d.ts +8 -6
  342. package/dist/types/ui-shell/UiShellProvider.d.ts.map +1 -1
  343. package/{src/Buttons/index.ts → dist/types/ui-shell/WideUiShellContent.d.ts} +5 -14
  344. package/dist/types/ui-shell/WideUiShellContent.d.ts.map +1 -0
  345. package/dist/types/ui-shell/index.d.ts +3 -1
  346. package/dist/types/ui-shell/index.d.ts.map +1 -1
  347. package/dist/types/ui-shell/renderUiShell.d.ts +7 -11
  348. package/dist/types/ui-shell/renderUiShell.d.ts.map +1 -1
  349. package/dist/types/ui-shell/uiShellContentTypes.d.ts +96 -0
  350. package/dist/types/ui-shell/uiShellContentTypes.d.ts.map +1 -0
  351. package/{src/@types/i18next.d.ts → dist/types/ui-shell/uiShellSharedConstants.d.ts} +7 -14
  352. package/dist/types/ui-shell/uiShellSharedConstants.d.ts.map +1 -0
  353. package/dist/types/ui-shell/useMatchAppElementToUiShellAppArea.d.ts +38 -0
  354. package/dist/types/ui-shell/useMatchAppElementToUiShellAppArea.d.ts.map +1 -0
  355. package/dist/types/ui-shell/useScrollState.d.ts +0 -1
  356. package/dist/types/ui-shell/useScrollState.d.ts.map +1 -1
  357. package/{src/FieldsetContext.tsx → dist/types/ui-shell/useUiShellBreakpoints.d.ts} +7 -12
  358. package/dist/types/ui-shell/useUiShellBreakpoints.d.ts.map +1 -0
  359. package/dist/types/web-component/createReactRootElements.d.ts +6 -4
  360. package/dist/types/web-component/createReactRootElements.d.ts.map +1 -1
  361. package/dist/types/web-component/renderReactInWebComponent.d.ts +12 -5
  362. package/dist/types/web-component/renderReactInWebComponent.d.ts.map +1 -1
  363. package/package.json +4 -4
  364. package/.browserslistrc +0 -1
  365. package/.svgrrc.cjs +0 -13
  366. package/CHANGELOG.md +0 -1490
  367. package/babel.config.cjs +0 -112
  368. package/dist/cjs/ui-shell/UiShellContent.cjs +0 -226
  369. package/dist/cjs/ui-shell/UiShellContent.cjs.map +0 -1
  370. package/dist/esm/ui-shell/UiShellContent.js +0 -220
  371. package/dist/esm/ui-shell/UiShellContent.js.map +0 -1
  372. package/dist/types/ui-shell/UiShellContent.d.ts +0 -76
  373. package/dist/types/ui-shell/UiShellContent.d.ts.map +0 -1
  374. package/i18n.config.json +0 -10
  375. package/scripts/generateIconsIndex.ts +0 -49
  376. package/scripts/generateTestSelectorsJson.ts +0 -33
  377. package/scripts/properties-to-ts.ts +0 -111
  378. package/src/@types/properties.d.ts +0 -292
  379. package/src/@types/react-augment.d.ts +0 -22
  380. package/src/Accordion.tsx +0 -117
  381. package/src/Autocomplete.tsx +0 -321
  382. package/src/Badge.tsx +0 -112
  383. package/src/Banner.tsx +0 -112
  384. package/src/Box.tsx +0 -44
  385. package/src/Breadcrumbs.tsx +0 -221
  386. package/src/Buttons/BaseButton.tsx +0 -250
  387. package/src/Buttons/BaseMenuButton.tsx +0 -342
  388. package/src/Buttons/Button.tsx +0 -30
  389. package/src/Buttons/MenuButton.tsx +0 -33
  390. package/src/Buttons/MenuContext.ts +0 -25
  391. package/src/Buttons/MenuItem.tsx +0 -103
  392. package/src/Callout.tsx +0 -176
  393. package/src/Card.tsx +0 -186
  394. package/src/Checkbox.tsx +0 -261
  395. package/src/CheckboxGroup.tsx +0 -127
  396. package/src/CircularProgress.tsx +0 -42
  397. package/src/DataTable/DataTable.tsx +0 -968
  398. package/src/DataTable/DataTableRowActions.tsx +0 -132
  399. package/src/DataTable/DataTableSettings.tsx +0 -136
  400. package/src/DataTable/index.tsx +0 -28
  401. package/src/DataTable/reorderDataRowsLocally.tsx +0 -48
  402. package/src/DataTable/useRowReordering.tsx +0 -232
  403. package/src/DataTable/useScrollIndication.tsx +0 -125
  404. package/src/DatePickers/DateField.tsx +0 -267
  405. package/src/DatePickers/DateFieldActionBar.tsx +0 -65
  406. package/src/DatePickers/DateFieldLocalizationProvider.tsx +0 -46
  407. package/src/DatePickers/DatePicker.test.tsx +0 -66
  408. package/src/DatePickers/DatePicker.tsx +0 -299
  409. package/src/DatePickers/DatePicker.types.d.ts +0 -14
  410. package/src/DatePickers/TimeZonePicker.tsx +0 -59
  411. package/src/DatePickers/datePickerTheme.tsx +0 -377
  412. package/src/DatePickers/useDateFieldsTranslations.ts +0 -94
  413. package/src/DatePickers/useOdysseyDateFields.ts +0 -303
  414. package/src/Dialog.tsx +0 -178
  415. package/src/Drawer.tsx +0 -255
  416. package/src/EmptyState.tsx +0 -79
  417. package/src/ErrorMessageList.tsx +0 -56
  418. package/src/Field.tsx +0 -189
  419. package/src/FieldComponentProps.ts +0 -66
  420. package/src/FieldError.tsx +0 -59
  421. package/src/FieldHint.tsx +0 -72
  422. package/src/FieldLabel.tsx +0 -67
  423. package/src/Fieldset.tsx +0 -116
  424. package/src/FileUploader/FileUploadIllustration.tsx +0 -66
  425. package/src/FileUploader/FileUploadPreview.tsx +0 -151
  426. package/src/FileUploader/FileUploader.tsx +0 -311
  427. package/src/FileUploader/index.ts +0 -13
  428. package/src/Form.tsx +0 -185
  429. package/src/FormCheckedProps.ts +0 -59
  430. package/src/HintLink.tsx +0 -28
  431. package/src/HtmlProps.ts +0 -112
  432. package/src/IconWithTooltip.tsx +0 -90
  433. package/src/Link.tsx +0 -115
  434. package/src/MuiPropsChild.tsx +0 -42
  435. package/src/MuiPropsContext.ts +0 -18
  436. package/src/NativeSelect.tsx +0 -249
  437. package/src/NullElement.tsx +0 -13
  438. package/src/OdysseyCacheProvider.test.tsx +0 -39
  439. package/src/OdysseyCacheProvider.tsx +0 -86
  440. package/src/OdysseyDesignTokensContext.tsx +0 -23
  441. package/src/OdysseyProvider.tsx +0 -92
  442. package/src/OdysseyThemeProvider.test.tsx +0 -211
  443. package/src/OdysseyThemeProvider.tsx +0 -109
  444. package/src/OdysseyTranslationProvider.test.tsx +0 -95
  445. package/src/OdysseyTranslationProvider.tsx +0 -77
  446. package/src/OdysseyTranslationProvider.types.ts +0 -47
  447. package/src/Pagination/Pagination.test.tsx +0 -327
  448. package/src/Pagination/Pagination.tsx +0 -417
  449. package/src/Pagination/constants.ts +0 -13
  450. package/src/Pagination/index.ts +0 -15
  451. package/src/Pagination/usePagination.ts +0 -45
  452. package/src/PasswordField.tsx +0 -253
  453. package/src/Radio.tsx +0 -199
  454. package/src/RadioGroup.tsx +0 -164
  455. package/src/ScreenReaderText.tsx +0 -53
  456. package/src/SearchField.tsx +0 -240
  457. package/src/Select.tsx +0 -576
  458. package/src/Stack.tsx +0 -56
  459. package/src/Status.tsx +0 -67
  460. package/src/Surface.tsx +0 -61
  461. package/src/SvgIcon.ts +0 -22
  462. package/src/Switch.tsx +0 -425
  463. package/src/Tabs.tsx +0 -259
  464. package/src/Tag.tsx +0 -317
  465. package/src/TagList.tsx +0 -55
  466. package/src/TextField.tsx +0 -298
  467. package/src/Toast.tsx +0 -151
  468. package/src/ToastStack.tsx +0 -43
  469. package/src/Tooltip.tsx +0 -61
  470. package/src/Typography.test.tsx +0 -26
  471. package/src/Typography.tsx +0 -474
  472. package/src/createContrastColors.ts +0 -112
  473. package/src/createUniqueAlphabeticalId.test.ts +0 -22
  474. package/src/createUniqueAlphabeticalId.ts +0 -17
  475. package/src/createUniqueId.test.ts +0 -22
  476. package/src/createUniqueId.ts +0 -17
  477. package/src/getTypedObjectKeys.ts +0 -15
  478. package/src/hexToRgb.ts +0 -40
  479. package/src/i18n.ts +0 -110
  480. package/src/icons.generated/Add.tsx +0 -44
  481. package/src/icons.generated/AddCircle.tsx +0 -46
  482. package/src/icons.generated/Apps.tsx +0 -44
  483. package/src/icons.generated/ArrowBottom.tsx +0 -46
  484. package/src/icons.generated/ArrowDown.tsx +0 -46
  485. package/src/icons.generated/ArrowLeft.tsx +0 -46
  486. package/src/icons.generated/ArrowLowerLeft.tsx +0 -46
  487. package/src/icons.generated/ArrowLowerRight.tsx +0 -46
  488. package/src/icons.generated/ArrowRight.tsx +0 -46
  489. package/src/icons.generated/ArrowTop.tsx +0 -46
  490. package/src/icons.generated/ArrowUnsorted.tsx +0 -46
  491. package/src/icons.generated/ArrowUp.tsx +0 -46
  492. package/src/icons.generated/ArrowUpperLeft.tsx +0 -46
  493. package/src/icons.generated/ArrowUpperRight.tsx +0 -46
  494. package/src/icons.generated/Bug.tsx +0 -44
  495. package/src/icons.generated/Calendar.tsx +0 -46
  496. package/src/icons.generated/Call.tsx +0 -44
  497. package/src/icons.generated/Chat.tsx +0 -44
  498. package/src/icons.generated/Check.tsx +0 -44
  499. package/src/icons.generated/CheckCircleFilled.tsx +0 -47
  500. package/src/icons.generated/ChevronDown.tsx +0 -46
  501. package/src/icons.generated/ChevronLeft.tsx +0 -46
  502. package/src/icons.generated/ChevronRight.tsx +0 -46
  503. package/src/icons.generated/ChevronUp.tsx +0 -46
  504. package/src/icons.generated/Clock.tsx +0 -44
  505. package/src/icons.generated/Close.tsx +0 -44
  506. package/src/icons.generated/CloseCircleFilled.tsx +0 -47
  507. package/src/icons.generated/CollapseLeft.tsx +0 -46
  508. package/src/icons.generated/CollapseRight.tsx +0 -46
  509. package/src/icons.generated/Copy.tsx +0 -44
  510. package/src/icons.generated/Custom.tsx +0 -50
  511. package/src/icons.generated/DangerDiamond.tsx +0 -46
  512. package/src/icons.generated/DangerDiamondFilled.tsx +0 -47
  513. package/src/icons.generated/Delete.tsx +0 -44
  514. package/src/icons.generated/Deny.tsx +0 -44
  515. package/src/icons.generated/Devices.tsx +0 -46
  516. package/src/icons.generated/Directory.tsx +0 -46
  517. package/src/icons.generated/Documentation.tsx +0 -46
  518. package/src/icons.generated/Download.tsx +0 -46
  519. package/src/icons.generated/DragIndicator.tsx +0 -46
  520. package/src/icons.generated/Duo.tsx +0 -62
  521. package/src/icons.generated/Edit.tsx +0 -44
  522. package/src/icons.generated/Email.tsx +0 -49
  523. package/src/icons.generated/ExpandLeft.tsx +0 -46
  524. package/src/icons.generated/ExpandRight.tsx +0 -46
  525. package/src/icons.generated/ExternalLink.tsx +0 -44
  526. package/src/icons.generated/Fido2.tsx +0 -72
  527. package/src/icons.generated/Filter.tsx +0 -44
  528. package/src/icons.generated/Folder.tsx +0 -44
  529. package/src/icons.generated/Globe.tsx +0 -44
  530. package/src/icons.generated/GoogleAuth.tsx +0 -70
  531. package/src/icons.generated/Grid.tsx +0 -47
  532. package/src/icons.generated/Group.tsx +0 -44
  533. package/src/icons.generated/Hide.tsx +0 -44
  534. package/src/icons.generated/Home.tsx +0 -44
  535. package/src/icons.generated/Idp.tsx +0 -54
  536. package/src/icons.generated/InformationCircle.tsx +0 -47
  537. package/src/icons.generated/InformationCircleFilled.tsx +0 -47
  538. package/src/icons.generated/Link.tsx +0 -44
  539. package/src/icons.generated/List.tsx +0 -44
  540. package/src/icons.generated/Lock.tsx +0 -44
  541. package/src/icons.generated/More.tsx +0 -44
  542. package/src/icons.generated/Notification.tsx +0 -46
  543. package/src/icons.generated/OktaVerify.tsx +0 -46
  544. package/src/icons.generated/OnPremMfa.tsx +0 -52
  545. package/src/icons.generated/OneTimePassword.tsx +0 -65
  546. package/src/icons.generated/Password.tsx +0 -80
  547. package/src/icons.generated/Pause.tsx +0 -44
  548. package/src/icons.generated/QuestionCircle.tsx +0 -46
  549. package/src/icons.generated/QuestionCircleFilled.tsx +0 -47
  550. package/src/icons.generated/Refresh.tsx +0 -46
  551. package/src/icons.generated/Reset.tsx +0 -44
  552. package/src/icons.generated/Resume.tsx +0 -44
  553. package/src/icons.generated/Search.tsx +0 -44
  554. package/src/icons.generated/SecurityQuestion.tsx +0 -51
  555. package/src/icons.generated/Server.tsx +0 -44
  556. package/src/icons.generated/Settings.tsx +0 -46
  557. package/src/icons.generated/Show.tsx +0 -44
  558. package/src/icons.generated/SmartCard.tsx +0 -65
  559. package/src/icons.generated/Sms.tsx +0 -55
  560. package/src/icons.generated/Subtract.tsx +0 -46
  561. package/src/icons.generated/SymantecVip.tsx +0 -52
  562. package/src/icons.generated/Sync.tsx +0 -44
  563. package/src/icons.generated/ThumbsDown.tsx +0 -46
  564. package/src/icons.generated/ThumbsUp.tsx +0 -46
  565. package/src/icons.generated/Unlock.tsx +0 -44
  566. package/src/icons.generated/Upload.tsx +0 -44
  567. package/src/icons.generated/User.tsx +0 -44
  568. package/src/icons.generated/Video.tsx +0 -44
  569. package/src/icons.generated/VoiceCall.tsx +0 -62
  570. package/src/icons.generated/Warning.tsx +0 -46
  571. package/src/icons.generated/WarningFilled.tsx +0 -46
  572. package/src/icons.generated/Yubikey.tsx +0 -44
  573. package/src/icons.generated/index.ts +0 -107
  574. package/src/index.ts +0 -118
  575. package/src/inputUtils.ts +0 -80
  576. package/src/labs/AppTile.tsx +0 -421
  577. package/src/labs/DataFilters.tsx +0 -871
  578. package/src/labs/DataTable.tsx +0 -877
  579. package/src/labs/DataTablePagination.tsx +0 -88
  580. package/src/labs/DataView/BulkActionsMenu.tsx +0 -98
  581. package/src/labs/DataView/CardLayoutContent.tsx +0 -272
  582. package/src/labs/DataView/DataCard.tsx +0 -357
  583. package/src/labs/DataView/DataTable.tsx +0 -128
  584. package/src/labs/DataView/DataView.test.tsx +0 -1168
  585. package/src/labs/DataView/DataView.tsx +0 -504
  586. package/src/labs/DataView/DetailPanel.tsx +0 -31
  587. package/src/labs/DataView/LayoutSwitcher.tsx +0 -72
  588. package/src/labs/DataView/RowActions.tsx +0 -125
  589. package/src/labs/DataView/TableLayoutContent.tsx +0 -500
  590. package/src/labs/DataView/TableSettings.tsx +0 -144
  591. package/src/labs/DataView/componentTypes.ts +0 -129
  592. package/src/labs/DataView/constants.tsx +0 -28
  593. package/src/labs/DataView/dataTypes.ts +0 -83
  594. package/src/labs/DataView/fetchData.ts +0 -49
  595. package/src/labs/DataView/index.ts +0 -19
  596. package/src/labs/DataView/tableConstants.tsx +0 -137
  597. package/src/labs/DataView/testSupportData.tsx +0 -301
  598. package/src/labs/DataView/useFilterConversion.ts +0 -88
  599. package/src/labs/DatePickers/DateTimeField.tsx +0 -267
  600. package/src/labs/DatePickers/DateTimePicker.test.tsx +0 -70
  601. package/src/labs/DatePickers/DateTimePicker.tsx +0 -303
  602. package/src/labs/DatePickers/dateTimePickerTheme.ts +0 -216
  603. package/src/labs/DatePickers/index.ts +0 -13
  604. package/src/labs/GroupPicker.tsx +0 -261
  605. package/src/labs/OdysseyPickers/ComposablePicker.test.tsx +0 -32
  606. package/src/labs/OdysseyPickers/ComposablePicker.tsx +0 -188
  607. package/src/labs/OdysseyPickers/Picker.tsx +0 -381
  608. package/src/labs/OdysseyPickers/PickerVirtualizationListBox.tsx +0 -192
  609. package/src/labs/OdysseyPickers/PickerWithOptionAdornment.tsx +0 -429
  610. package/src/labs/OdysseyPickers/index.ts +0 -15
  611. package/src/labs/PageTemplate/Layout.tsx +0 -85
  612. package/src/labs/PageTemplate/PageTemplate.tsx +0 -234
  613. package/src/labs/PageTemplate/index.ts +0 -14
  614. package/src/labs/PaginatedTable.tsx +0 -290
  615. package/src/labs/README.md +0 -46
  616. package/src/labs/StaticTable.tsx +0 -131
  617. package/src/labs/UserProfile.tsx +0 -104
  618. package/src/labs/UserProfileMenuButton.tsx +0 -86
  619. package/src/labs/index.ts +0 -47
  620. package/src/labs/materialReactTableTypes.tsx +0 -19
  621. package/src/properties/odyssey-react-mui.properties +0 -140
  622. package/src/properties/translations/odyssey-react-mui_cs.properties +0 -140
  623. package/src/properties/translations/odyssey-react-mui_da.properties +0 -140
  624. package/src/properties/translations/odyssey-react-mui_de.properties +0 -140
  625. package/src/properties/translations/odyssey-react-mui_el.properties +0 -140
  626. package/src/properties/translations/odyssey-react-mui_es.properties +0 -140
  627. package/src/properties/translations/odyssey-react-mui_fi.properties +0 -140
  628. package/src/properties/translations/odyssey-react-mui_fr.properties +0 -140
  629. package/src/properties/translations/odyssey-react-mui_ht.properties +0 -140
  630. package/src/properties/translations/odyssey-react-mui_hu.properties +0 -140
  631. package/src/properties/translations/odyssey-react-mui_id.properties +0 -140
  632. package/src/properties/translations/odyssey-react-mui_it.properties +0 -140
  633. package/src/properties/translations/odyssey-react-mui_ja.properties +0 -140
  634. package/src/properties/translations/odyssey-react-mui_ko.properties +0 -140
  635. package/src/properties/translations/odyssey-react-mui_ms.properties +0 -140
  636. package/src/properties/translations/odyssey-react-mui_nb.properties +0 -140
  637. package/src/properties/translations/odyssey-react-mui_nl_NL.properties +0 -140
  638. package/src/properties/translations/odyssey-react-mui_ok_PL.properties +0 -126
  639. package/src/properties/translations/odyssey-react-mui_ok_SK.properties +0 -126
  640. package/src/properties/translations/odyssey-react-mui_pl.properties +0 -140
  641. package/src/properties/translations/odyssey-react-mui_pt_BR.properties +0 -140
  642. package/src/properties/translations/odyssey-react-mui_ro.properties +0 -140
  643. package/src/properties/translations/odyssey-react-mui_ru.properties +0 -140
  644. package/src/properties/translations/odyssey-react-mui_sv.properties +0 -140
  645. package/src/properties/translations/odyssey-react-mui_th.properties +0 -140
  646. package/src/properties/translations/odyssey-react-mui_tr.properties +0 -140
  647. package/src/properties/translations/odyssey-react-mui_uk.properties +0 -140
  648. package/src/properties/translations/odyssey-react-mui_vi.properties +0 -140
  649. package/src/properties/translations/odyssey-react-mui_zh_CN.properties +0 -140
  650. package/src/properties/translations/odyssey-react-mui_zh_TW.properties +0 -140
  651. package/src/properties/ts/odyssey-react-mui.ts +0 -1
  652. package/src/properties/ts/odyssey-react-mui_cs.ts +0 -1
  653. package/src/properties/ts/odyssey-react-mui_da.ts +0 -1
  654. package/src/properties/ts/odyssey-react-mui_de.ts +0 -1
  655. package/src/properties/ts/odyssey-react-mui_el.ts +0 -1
  656. package/src/properties/ts/odyssey-react-mui_es.ts +0 -1
  657. package/src/properties/ts/odyssey-react-mui_fi.ts +0 -1
  658. package/src/properties/ts/odyssey-react-mui_fr.ts +0 -1
  659. package/src/properties/ts/odyssey-react-mui_ht.ts +0 -1
  660. package/src/properties/ts/odyssey-react-mui_hu.ts +0 -1
  661. package/src/properties/ts/odyssey-react-mui_id.ts +0 -1
  662. package/src/properties/ts/odyssey-react-mui_it.ts +0 -1
  663. package/src/properties/ts/odyssey-react-mui_ja.ts +0 -1
  664. package/src/properties/ts/odyssey-react-mui_ko.ts +0 -1
  665. package/src/properties/ts/odyssey-react-mui_ms.ts +0 -1
  666. package/src/properties/ts/odyssey-react-mui_nb.ts +0 -1
  667. package/src/properties/ts/odyssey-react-mui_nl_NL.ts +0 -1
  668. package/src/properties/ts/odyssey-react-mui_ok_PL.ts +0 -1
  669. package/src/properties/ts/odyssey-react-mui_ok_SK.ts +0 -1
  670. package/src/properties/ts/odyssey-react-mui_pl.ts +0 -1
  671. package/src/properties/ts/odyssey-react-mui_pt_BR.ts +0 -1
  672. package/src/properties/ts/odyssey-react-mui_ro.ts +0 -1
  673. package/src/properties/ts/odyssey-react-mui_ru.ts +0 -1
  674. package/src/properties/ts/odyssey-react-mui_sv.ts +0 -1
  675. package/src/properties/ts/odyssey-react-mui_th.ts +0 -1
  676. package/src/properties/ts/odyssey-react-mui_tr.ts +0 -1
  677. package/src/properties/ts/odyssey-react-mui_uk.ts +0 -1
  678. package/src/properties/ts/odyssey-react-mui_vi.ts +0 -1
  679. package/src/properties/ts/odyssey-react-mui_zh_CN.ts +0 -1
  680. package/src/properties/ts/odyssey-react-mui_zh_TW.ts +0 -1
  681. package/src/remUtils.ts +0 -27
  682. package/src/shadow-dom/shadow-dom.test.ts +0 -24
  683. package/src/shadow-dom/shadow-dom.ts +0 -54
  684. package/src/test-selectors/getByQuerySelector.ts +0 -176
  685. package/src/test-selectors/getComputedAccessibleErrorMessageText.ts +0 -52
  686. package/src/test-selectors/getComputedAccessibleText.ts +0 -36
  687. package/src/test-selectors/index.ts +0 -15
  688. package/src/test-selectors/interpolateString.ts +0 -41
  689. package/src/test-selectors/linkedHtmlSelectors.ts +0 -73
  690. package/src/test-selectors/queryOdysseySelector.ts +0 -36
  691. package/src/test-selectors/querySelector.ts +0 -249
  692. package/src/test-selectors/sanityChecks.ts +0 -53
  693. package/src/test-selectors/testSelector.ts +0 -143
  694. package/src/theme/components.tsx +0 -3275
  695. package/src/theme/components.types.ts +0 -111
  696. package/src/theme/createOdysseyMuiTheme.ts +0 -54
  697. package/src/theme/index.ts +0 -13
  698. package/src/theme/mixins.ts +0 -29
  699. package/src/theme/mixins.types.ts +0 -31
  700. package/src/theme/palette.ts +0 -112
  701. package/src/theme/shape.ts +0 -31
  702. package/src/theme/spacing.ts +0 -34
  703. package/src/theme/theme.ts +0 -13
  704. package/src/theme/typography.ts +0 -137
  705. package/src/theme/typography.types.ts +0 -41
  706. package/src/theme/useContrastMode.test.tsx +0 -504
  707. package/src/ui-shell/AppSwitcher/AppSwitcher.tsx +0 -94
  708. package/src/ui-shell/AppSwitcher/AppSwitcherApp.tsx +0 -146
  709. package/src/ui-shell/AppSwitcher/OktaAura.tsx +0 -50
  710. package/src/ui-shell/AppSwitcher/index.ts +0 -13
  711. package/src/ui-shell/SideNav/CollapseIcon.tsx +0 -34
  712. package/src/ui-shell/SideNav/HandleIcon.tsx +0 -35
  713. package/src/ui-shell/SideNav/NavAccordion.tsx +0 -243
  714. package/src/ui-shell/SideNav/OktaLogo.tsx +0 -34
  715. package/src/ui-shell/SideNav/SideNav.test.tsx +0 -326
  716. package/src/ui-shell/SideNav/SideNav.tsx +0 -810
  717. package/src/ui-shell/SideNav/SideNavFooterContent.tsx +0 -85
  718. package/src/ui-shell/SideNav/SideNavHeader.tsx +0 -134
  719. package/src/ui-shell/SideNav/SideNavItemContent.tsx +0 -402
  720. package/src/ui-shell/SideNav/SideNavItemContentContext.tsx +0 -29
  721. package/src/ui-shell/SideNav/SideNavItemLinkContent.tsx +0 -90
  722. package/src/ui-shell/SideNav/SideNavLogo.tsx +0 -65
  723. package/src/ui-shell/SideNav/SideNavToggleButton.tsx +0 -272
  724. package/src/ui-shell/SideNav/SortableList/SortableItem.tsx +0 -237
  725. package/src/ui-shell/SideNav/SortableList/SortableList.tsx +0 -132
  726. package/src/ui-shell/SideNav/SortableList/SortableOverlay.tsx +0 -34
  727. package/src/ui-shell/SideNav/index.ts +0 -16
  728. package/src/ui-shell/SideNav/types.ts +0 -224
  729. package/src/ui-shell/TopNav/TopNav.tsx +0 -109
  730. package/src/ui-shell/TopNav/TopNavLinksList.tsx +0 -68
  731. package/src/ui-shell/TopNav/TopNavListItem.tsx +0 -209
  732. package/src/ui-shell/TopNav/index.ts +0 -13
  733. package/src/ui-shell/UiShell.test.tsx +0 -366
  734. package/src/ui-shell/UiShell.tsx +0 -153
  735. package/src/ui-shell/UiShellContent.tsx +0 -350
  736. package/src/ui-shell/UiShellProvider.tsx +0 -103
  737. package/src/ui-shell/bufferLatest.test.ts +0 -79
  738. package/src/ui-shell/bufferLatest.ts +0 -64
  739. package/src/ui-shell/createMessageBus.test.ts +0 -115
  740. package/src/ui-shell/createMessageBus.ts +0 -53
  741. package/src/ui-shell/createStore.test.ts +0 -103
  742. package/src/ui-shell/createStore.ts +0 -37
  743. package/src/ui-shell/index.ts +0 -21
  744. package/src/ui-shell/renderUiShell.test.tsx +0 -203
  745. package/src/ui-shell/renderUiShell.tsx +0 -158
  746. package/src/ui-shell/useScrollState.ts +0 -59
  747. package/src/useAutocomplete.tsx +0 -184
  748. package/src/useContrastMode.tsx +0 -143
  749. package/src/useNormalizedKey.ts +0 -17
  750. package/src/useUniqueAlphabeticalId.ts +0 -21
  751. package/src/useUniqueId.ts +0 -21
  752. package/src/web-component/createReactRootElements.test.ts +0 -40
  753. package/src/web-component/createReactRootElements.ts +0 -39
  754. package/src/web-component/renderReactInWebComponent.test.tsx +0 -128
  755. package/src/web-component/renderReactInWebComponent.ts +0 -135
  756. package/tsconfig.json +0 -16
  757. package/tsconfig.production.json +0 -13
  758. package/vitest.config.ts +0 -36
  759. package/vitest.setup.ts +0 -32
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.HamburgerMenuIcon = void 0;
7
+ var _react = require("react");
8
+ var _SvgIcon = require("../../SvgIcon.cjs");
9
+ var _jsxRuntime = require("react/jsx-runtime");
10
+ /*!
11
+ * Copyright (c) 2024-present, Okta, Inc. and/or its affiliates. All rights reserved.
12
+ * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
13
+ *
14
+ * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
15
+ * Unless required by applicable law or agreed to in writing, software
16
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
17
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18
+ *
19
+ * See the License for the specific language governing permissions and limitations under the License.
20
+ */const HamburgerMenuIcon = (0, _react.forwardRef)((props, ref) => {
21
+ return (0, _jsxRuntime.jsx)(_SvgIcon.SvgIcon, {
22
+ viewBox: "0 0 24 24",
23
+ fill: "none",
24
+ xmlns: "http://www.w3.org/2000/svg",
25
+ ref: ref,
26
+ ...props,
27
+ children: (0, _jsxRuntime.jsx)("path", {
28
+ fillRule: "evenodd",
29
+ clipRule: "evenodd",
30
+ d: "M21.333 5.778H2.667V4H21.333V5.778ZM21.333 12.885H2.667V11.111H21.333V12.885ZM2.667 20H21.333V18.221H2.667V20Z",
31
+ fill: "currentColor"
32
+ })
33
+ });
34
+ });
35
+ const MemoizedHamburgerMenuIcon = exports.HamburgerMenuIcon = (0, _react.memo)(HamburgerMenuIcon);
36
+ MemoizedHamburgerMenuIcon.displayName = "HamburgerMenuIcon";
37
+ //# sourceMappingURL=HamburgerMenuIcon.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HamburgerMenuIcon.cjs","names":["_react","require","_SvgIcon","_jsxRuntime","HamburgerMenuIcon","forwardRef","props","ref","jsx","SvgIcon","viewBox","fill","xmlns","children","fillRule","clipRule","d","MemoizedHamburgerMenuIcon","exports","memo","displayName"],"sources":["../../../../src/ui-shell/TopNav/HamburgerMenuIcon.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\n// Code automatically generated; DO NOT EDIT.\n\nimport { forwardRef, memo } from \"react\";\nimport { SvgIcon, type SvgIconNoChildrenProps } from \"../../SvgIcon.js\";\n\nexport type HamburgerMenuProps = SvgIconNoChildrenProps;\n\nconst HamburgerMenuIcon = forwardRef<SVGSVGElement, HamburgerMenuProps>(\n (props, ref) => {\n return (\n <SvgIcon\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n ref={ref}\n {...props}\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M21.333 5.778H2.667V4H21.333V5.778ZM21.333 12.885H2.667V11.111H21.333V12.885ZM2.667 20H21.333V18.221H2.667V20Z\"\n fill=\"currentColor\"\n />\n </SvgIcon>\n );\n },\n);\n\nconst MemoizedHamburgerMenuIcon = memo(HamburgerMenuIcon);\nMemoizedHamburgerMenuIcon.displayName = \"HamburgerMenuIcon\";\n\nexport { MemoizedHamburgerMenuIcon as HamburgerMenuIcon };\n"],"mappings":";;;;;;AAcA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AAAwE,IAAAE,WAAA,GAAAF,OAAA;AAfxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GASA,MAAMG,iBAAiB,GAAG,IAAAC,iBAAU,EAClC,CAACC,KAAK,EAAEC,GAAG,KAAK;EACd,OACE,IAAAJ,WAAA,CAAAK,GAAA,EAACN,QAAA,CAAAO,OAAO;IACNC,OAAO,EAAC,WAAW;IACnBC,IAAI,EAAC,MAAM;IACXC,KAAK,EAAC,4BAA4B;IAClCL,GAAG,EAAEA,GAAI;IAAA,GACLD,KAAK;IAAAO,QAAA,EAET,IAAAV,WAAA,CAAAK,GAAA;MACEM,QAAQ,EAAC,SAAS;MAClBC,QAAQ,EAAC,SAAS;MAClBC,CAAC,EAAC,gHAAgH;MAClHL,IAAI,EAAC;IAAc,CACpB;EAAC,CACK,CAAC;AAEd,CACF,CAAC;AAED,MAAMM,yBAAyB,GAAAC,OAAA,CAAAd,iBAAA,GAAG,IAAAe,WAAI,EAACf,iBAAiB,CAAC;AACzDa,yBAAyB,CAACG,WAAW,GAAG,mBAAmB","ignoreList":[]}
@@ -3,11 +3,12 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.TopNav = exports.TOP_NAV_HEIGHT = void 0;
6
+ exports.TopNav = void 0;
7
7
  var _styled = _interopRequireDefault(require("@emotion/styled"));
8
8
  var _react = require("react");
9
9
  var _OdysseyDesignTokensContext = require("../../OdysseyDesignTokensContext.cjs");
10
10
  var _UiShellProvider = require("../../ui-shell/UiShellProvider.cjs");
11
+ var _uiShellSharedConstants = require("../uiShellSharedConstants.cjs");
11
12
  var _jsxRuntime = require("react/jsx-runtime");
12
13
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
13
14
  /*!
@@ -22,7 +23,6 @@ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e
22
23
  * See the License for the specific language governing permissions and limitations under the License.
23
24
  */
24
25
 
25
- const TOP_NAV_HEIGHT = exports.TOP_NAV_HEIGHT = `${64 / 14}rem`;
26
26
  const StyledLeftSideContainer = (0, _styled.default)("div")(() => ({
27
27
  flexGrow: 1
28
28
  }));
@@ -44,13 +44,13 @@ const StyledTopNavContainer = (0, _styled.default)("div", {
44
44
  gap: odysseyDesignTokens.Spacing4,
45
45
  height: "100%",
46
46
  justifyContent: "space-between",
47
- maxHeight: TOP_NAV_HEIGHT,
48
- minHeight: TOP_NAV_HEIGHT,
47
+ maxHeight: _uiShellSharedConstants.TOP_NAV_HEIGHT,
48
+ minHeight: _uiShellSharedConstants.TOP_NAV_HEIGHT,
49
49
  paddingBlock: odysseyDesignTokens.Spacing2,
50
50
  paddingInline: odysseyDesignTokens.Spacing8,
51
51
  position: "relative",
52
52
  transition: `box-shadow ${odysseyDesignTokens.TransitionDurationMain} ${odysseyDesignTokens.TransitionTimingMain}`,
53
- zIndex: 100,
53
+ zIndex: _uiShellSharedConstants.UI_SHELL_BASE_Z_INDEX,
54
54
  ...(topNavBackgroundColor === odysseyDesignTokens.HueNeutralWhite && {
55
55
  borderBottom: `${odysseyDesignTokens.BorderWidthMain} ${odysseyDesignTokens.BorderStyleMain} ${odysseyDesignTokens.HueNeutral100}`
56
56
  })
@@ -1 +1 @@
1
- {"version":3,"file":"TopNav.cjs","names":["_styled","_interopRequireDefault","require","_react","_OdysseyDesignTokensContext","_UiShellProvider","_jsxRuntime","e","__esModule","default","TOP_NAV_HEIGHT","exports","StyledLeftSideContainer","styled","flexGrow","StyledRightSideContainer","flexShrink","StyledTopNavContainer","shouldForwardProp","prop","odysseyDesignTokens","isScrolled","topNavBackgroundColor","alignItems","backgroundColor","boxShadow","DepthMedium","undefined","clipPath","display","gap","Spacing4","height","justifyContent","maxHeight","minHeight","paddingBlock","Spacing2","paddingInline","Spacing8","position","transition","TransitionDurationMain","TransitionTimingMain","zIndex","HueNeutralWhite","borderBottom","BorderWidthMain","BorderStyleMain","HueNeutral100","TopNav","leftSideComponent","rightSideComponent","useOdysseyDesignTokens","uiShellContext","useUiShellContext","jsxs","children","jsx","MemoizedTopNav","memo","displayName"],"sources":["../../../../src/ui-shell/TopNav/TopNav.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 { memo, type ReactElement } from \"react\";\n\nimport type { HtmlProps } from \"../../HtmlProps.js\";\nimport {\n DesignTokens,\n useOdysseyDesignTokens,\n} from \"../../OdysseyDesignTokensContext.js\";\nimport {\n UiShellColors,\n useUiShellContext,\n} from \"../../ui-shell/UiShellProvider.js\";\n\nexport const TOP_NAV_HEIGHT = `${64 / 14}rem`;\n\nconst StyledLeftSideContainer = styled(\"div\")(() => ({\n flexGrow: 1,\n}));\n\nconst StyledRightSideContainer = styled(\"div\")(() => ({\n flexShrink: 0,\n}));\n\nconst StyledTopNavContainer = styled(\"div\", {\n shouldForwardProp: (prop) =>\n prop !== \"odysseyDesignTokens\" &&\n prop !== \"isScrolled\" &&\n prop !== \"topNavBackgroundColor\",\n})<{\n isScrolled?: boolean;\n odysseyDesignTokens: DesignTokens;\n topNavBackgroundColor?: UiShellColors[\"topNavBackgroundColor\"];\n}>(({ odysseyDesignTokens, isScrolled, topNavBackgroundColor }) => ({\n alignItems: \"center\",\n backgroundColor: topNavBackgroundColor,\n boxShadow: isScrolled ? odysseyDesignTokens.DepthMedium : undefined,\n clipPath: \"inset(0 0 -100vh 0)\",\n display: \"flex\",\n gap: odysseyDesignTokens.Spacing4,\n height: \"100%\",\n justifyContent: \"space-between\",\n maxHeight: TOP_NAV_HEIGHT,\n minHeight: TOP_NAV_HEIGHT,\n paddingBlock: odysseyDesignTokens.Spacing2,\n paddingInline: odysseyDesignTokens.Spacing8,\n position: \"relative\",\n transition: `box-shadow ${odysseyDesignTokens.TransitionDurationMain} ${odysseyDesignTokens.TransitionTimingMain}`,\n zIndex: 100,\n\n ...(topNavBackgroundColor === odysseyDesignTokens.HueNeutralWhite && {\n borderBottom: `${odysseyDesignTokens.BorderWidthMain} ${odysseyDesignTokens.BorderStyleMain} ${odysseyDesignTokens.HueNeutral100}`,\n }),\n}));\n\nexport type TopNavProps = {\n /**\n * Whether or not the underlying content has been scrolled\n */\n isScrolled?: boolean;\n /**\n * React components that render into the left side of the top nav.\n */\n leftSideComponent?: ReactElement;\n /**\n * React components that render into the right side of the top nav.\n */\n rightSideComponent?: ReactElement;\n} & Pick<HtmlProps, \"testId\">;\n\nconst TopNav = ({\n isScrolled,\n leftSideComponent,\n rightSideComponent,\n}: TopNavProps) => {\n const odysseyDesignTokens = useOdysseyDesignTokens();\n const uiShellContext = useUiShellContext();\n\n return (\n <StyledTopNavContainer\n odysseyDesignTokens={odysseyDesignTokens}\n isScrolled={isScrolled}\n topNavBackgroundColor={uiShellContext?.topNavBackgroundColor}\n >\n <StyledLeftSideContainer>\n {leftSideComponent ?? <div />}\n </StyledLeftSideContainer>\n <StyledRightSideContainer>\n {rightSideComponent ?? <div />}\n </StyledRightSideContainer>\n </StyledTopNavContainer>\n );\n};\n\nconst MemoizedTopNav = memo(TopNav);\nMemoizedTopNav.displayName = \"TopNav\";\n\nexport { MemoizedTopNav as TopNav };\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"TopNav.cjs","names":["_styled","_interopRequireDefault","require","_react","_OdysseyDesignTokensContext","_UiShellProvider","_uiShellSharedConstants","_jsxRuntime","e","__esModule","default","StyledLeftSideContainer","styled","flexGrow","StyledRightSideContainer","flexShrink","StyledTopNavContainer","shouldForwardProp","prop","odysseyDesignTokens","isScrolled","topNavBackgroundColor","alignItems","backgroundColor","boxShadow","DepthMedium","undefined","clipPath","display","gap","Spacing4","height","justifyContent","maxHeight","TOP_NAV_HEIGHT","minHeight","paddingBlock","Spacing2","paddingInline","Spacing8","position","transition","TransitionDurationMain","TransitionTimingMain","zIndex","UI_SHELL_BASE_Z_INDEX","HueNeutralWhite","borderBottom","BorderWidthMain","BorderStyleMain","HueNeutral100","TopNav","leftSideComponent","rightSideComponent","useOdysseyDesignTokens","uiShellContext","useUiShellContext","jsxs","children","jsx","MemoizedTopNav","exports","memo","displayName"],"sources":["../../../../src/ui-shell/TopNav/TopNav.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 { memo, type ReactElement } from \"react\";\n\nimport type { HtmlProps } from \"../../HtmlProps.js\";\nimport {\n DesignTokens,\n useOdysseyDesignTokens,\n} from \"../../OdysseyDesignTokensContext.js\";\nimport {\n UiShellColors,\n useUiShellContext,\n} from \"../../ui-shell/UiShellProvider.js\";\nimport {\n TOP_NAV_HEIGHT,\n UI_SHELL_BASE_Z_INDEX,\n} from \"../uiShellSharedConstants.js\";\n\nconst StyledLeftSideContainer = styled(\"div\")(() => ({\n flexGrow: 1,\n}));\n\nconst StyledRightSideContainer = styled(\"div\")(() => ({\n flexShrink: 0,\n}));\n\nconst StyledTopNavContainer = styled(\"div\", {\n shouldForwardProp: (prop) =>\n prop !== \"odysseyDesignTokens\" &&\n prop !== \"isScrolled\" &&\n prop !== \"topNavBackgroundColor\",\n})<{\n isScrolled?: boolean;\n odysseyDesignTokens: DesignTokens;\n topNavBackgroundColor?: UiShellColors[\"topNavBackgroundColor\"];\n}>(({ odysseyDesignTokens, isScrolled, topNavBackgroundColor }) => ({\n alignItems: \"center\",\n backgroundColor: topNavBackgroundColor,\n boxShadow: isScrolled ? odysseyDesignTokens.DepthMedium : undefined,\n clipPath: \"inset(0 0 -100vh 0)\",\n display: \"flex\",\n gap: odysseyDesignTokens.Spacing4,\n height: \"100%\",\n justifyContent: \"space-between\",\n maxHeight: TOP_NAV_HEIGHT,\n minHeight: TOP_NAV_HEIGHT,\n paddingBlock: odysseyDesignTokens.Spacing2,\n paddingInline: odysseyDesignTokens.Spacing8,\n position: \"relative\",\n transition: `box-shadow ${odysseyDesignTokens.TransitionDurationMain} ${odysseyDesignTokens.TransitionTimingMain}`,\n zIndex: UI_SHELL_BASE_Z_INDEX,\n\n ...(topNavBackgroundColor === odysseyDesignTokens.HueNeutralWhite && {\n borderBottom: `${odysseyDesignTokens.BorderWidthMain} ${odysseyDesignTokens.BorderStyleMain} ${odysseyDesignTokens.HueNeutral100}`,\n }),\n}));\n\nexport type TopNavProps = {\n /**\n * Whether or not the underlying content has been scrolled\n */\n isScrolled?: boolean;\n /**\n * React components that render into the left side of the top nav.\n */\n leftSideComponent?: ReactElement;\n /**\n * React components that render into the right side of the top nav.\n */\n rightSideComponent?: ReactElement;\n} & Pick<HtmlProps, \"testId\">;\n\nconst TopNav = ({\n isScrolled,\n leftSideComponent,\n rightSideComponent,\n}: TopNavProps) => {\n const odysseyDesignTokens = useOdysseyDesignTokens();\n const uiShellContext = useUiShellContext();\n\n return (\n <StyledTopNavContainer\n odysseyDesignTokens={odysseyDesignTokens}\n isScrolled={isScrolled}\n topNavBackgroundColor={uiShellContext?.topNavBackgroundColor}\n >\n <StyledLeftSideContainer>\n {leftSideComponent ?? <div />}\n </StyledLeftSideContainer>\n <StyledRightSideContainer>\n {rightSideComponent ?? <div />}\n </StyledRightSideContainer>\n </StyledTopNavContainer>\n );\n};\n\nconst MemoizedTopNav = memo(TopNav);\nMemoizedTopNav.displayName = \"TopNav\";\n\nexport { MemoizedTopNav as TopNav };\n"],"mappings":"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","ignoreList":[]}
@@ -7,9 +7,11 @@ exports.defaultComponentProps = exports.UiShell = void 0;
7
7
  var _react = require("react");
8
8
  var _reactErrorBoundary = require("react-error-boundary");
9
9
  var _CssBaseline = require("../CssBaseline.cjs");
10
+ var _NarrowUiShellContent = require("./NarrowUiShellContent.cjs");
10
11
  var _OdysseyProvider = require("../OdysseyProvider.cjs");
11
- var _UiShellContent = require("./UiShellContent.cjs");
12
12
  var _UiShellProvider = require("./UiShellProvider.cjs");
13
+ var _useUiShellBreakpoints = require("./useUiShellBreakpoints.cjs");
14
+ var _WideUiShellContent = require("./WideUiShellContent.cjs");
13
15
  var _jsxRuntime = require("react/jsx-runtime");
14
16
  /*!
15
17
  * Copyright (c) 2024-present, Okta, Inc. and/or its affiliates. All rights reserved.
@@ -27,24 +29,27 @@ const defaultComponentProps = exports.defaultComponentProps = {
27
29
  sideNavProps: undefined,
28
30
  topNavProps: undefined
29
31
  };
32
+ const errorComponent = (0, _jsxRuntime.jsx)("div", {
33
+ "data-error": true
34
+ });
30
35
  const UiShell = ({
31
36
  appBackgroundColor,
32
37
  appBackgroundContrastMode,
33
- appComponent,
34
- appRootElement,
35
- appContainerElement,
36
- appContainerScrollingMode,
38
+ appElement,
39
+ appElementScrollingMode,
37
40
  hasStandardAppContentPadding,
38
41
  initialVisibleSections,
39
42
  onError = console.error,
40
43
  onSubscriptionCreated,
41
44
  optionalComponents,
42
45
  sideNavBackgroundColor,
43
- stylesRootElement,
46
+ subscribeToPropChanges,
44
47
  topNavBackgroundColor,
45
- subscribeToPropChanges
48
+ uiShellAppElement,
49
+ uiShellStylesElement
46
50
  }) => {
47
51
  const [componentProps, setComponentProps] = (0, _react.useState)(defaultComponentProps);
52
+ const activeBreakpoint = (0, _useUiShellBreakpoints.useUiShellBreakpoints)();
48
53
  (0, _react.useEffect)(() => {
49
54
  const unsubscribe = subscribeToPropChanges(componentProps => {
50
55
  setComponentProps(componentProps || defaultComponentProps);
@@ -54,30 +59,44 @@ const UiShell = ({
54
59
  unsubscribe();
55
60
  };
56
61
  }, [onSubscriptionCreated, subscribeToPropChanges]);
57
- return (0, _jsxRuntime.jsx)(_reactErrorBoundary.ErrorBoundary, {
58
- fallback: appComponent,
62
+ return activeBreakpoint === "none" ? null : (0, _jsxRuntime.jsx)(_reactErrorBoundary.ErrorBoundary, {
63
+ fallback: errorComponent,
59
64
  onError: onError,
60
65
  children: (0, _jsxRuntime.jsx)(_OdysseyProvider.OdysseyProvider, {
61
- emotionRootElement: stylesRootElement,
62
- shadowRootElement: appRootElement,
63
- hasScopedCssBaseline: false,
66
+ emotionRootElement: uiShellStylesElement,
67
+ shadowRootElement: uiShellAppElement,
64
68
  children: (0, _jsxRuntime.jsxs)(_reactErrorBoundary.ErrorBoundary, {
65
- fallback: appComponent,
69
+ fallback: errorComponent,
66
70
  onError: onError,
67
- children: [(0, _jsxRuntime.jsx)(_CssBaseline.CssBaseline, {}), (0, _jsxRuntime.jsx)(_UiShellProvider.UiShellProvider, {
71
+ children: [(0, _jsxRuntime.jsx)(_CssBaseline.CssBaseline, {}), (0, _jsxRuntime.jsxs)(_UiShellProvider.UiShellProvider, {
68
72
  appBackgroundColor: appBackgroundColor,
69
73
  appBackgroundContrastMode: appBackgroundContrastMode,
70
74
  sideNavBackgroundColor: sideNavBackgroundColor,
71
75
  topNavBackgroundColor: topNavBackgroundColor,
72
- children: (0, _jsxRuntime.jsx)(_UiShellContent.UiShellContent, {
76
+ children: [activeBreakpoint === "constrained" && (0, _jsxRuntime.jsx)(_NarrowUiShellContent.NarrowUiShellContent, {
77
+ ...componentProps,
78
+ appElement: appElement,
79
+ appElementScrollingMode: appElementScrollingMode,
80
+ hasStandardAppContentPadding: hasStandardAppContentPadding,
81
+ initialVisibleSections: initialVisibleSections,
82
+ onError: onError,
83
+ optionalComponents: optionalComponents
84
+ }), (activeBreakpoint === "compact" || activeBreakpoint === "comfortable") && (0, _jsxRuntime.jsx)(_WideUiShellContent.WideUiShellContent, {
73
85
  ...componentProps,
74
- appContainerElement: appContainerElement,
75
- appContainerScrollingMode: appContainerScrollingMode,
86
+ ...(componentProps.sideNavProps ? {
87
+ sideNavProps: {
88
+ ...componentProps.sideNavProps,
89
+ isCollapsed: activeBreakpoint === "compact" || componentProps.sideNavProps?.isCollapsed,
90
+ isCollapsible: activeBreakpoint === "compact" || componentProps.sideNavProps?.isCollapsible
91
+ }
92
+ } : {}),
93
+ appElement: appElement,
94
+ appElementScrollingMode: appElementScrollingMode,
76
95
  hasStandardAppContentPadding: hasStandardAppContentPadding,
77
96
  initialVisibleSections: initialVisibleSections,
78
97
  onError: onError,
79
98
  optionalComponents: optionalComponents
80
- })
99
+ })]
81
100
  })]
82
101
  })
83
102
  })
@@ -1 +1 @@
1
- {"version":3,"file":"UiShell.cjs","names":["_react","require","_reactErrorBoundary","_CssBaseline","_OdysseyProvider","_UiShellContent","_UiShellProvider","_jsxRuntime","defaultComponentProps","exports","sideNavProps","undefined","topNavProps","UiShell","appBackgroundColor","appBackgroundContrastMode","appComponent","appRootElement","appContainerElement","appContainerScrollingMode","hasStandardAppContentPadding","initialVisibleSections","onError","console","error","onSubscriptionCreated","optionalComponents","sideNavBackgroundColor","stylesRootElement","topNavBackgroundColor","subscribeToPropChanges","componentProps","setComponentProps","useState","useEffect","unsubscribe","jsx","ErrorBoundary","fallback","children","OdysseyProvider","emotionRootElement","shadowRootElement","hasScopedCssBaseline","jsxs","CssBaseline","UiShellProvider","UiShellContent","MemoizedUiShell","memo","displayName"],"sources":["../../../src/ui-shell/UiShell.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 {\n memo,\n ReactNode,\n useEffect,\n useState,\n type SetStateAction,\n} from \"react\";\nimport { ErrorBoundary } from \"react-error-boundary\";\n\nimport { CssBaseline } from \"../CssBaseline.js\";\nimport { OdysseyProvider } from \"../OdysseyProvider.js\";\nimport {\n UiShellContent,\n type UiShellContentProps,\n type UiShellNavComponentProps,\n} from \"./UiShellContent.js\";\nimport { type ReactRootElements } from \"../web-component/renderReactInWebComponent.js\";\nimport { UiShellProvider } from \"./UiShellProvider.js\";\n\nexport const defaultComponentProps: UiShellNavComponentProps = {\n sideNavProps: undefined,\n topNavProps: undefined,\n} as const;\n\nexport type UiShellProps = {\n /**\n * Notifies when subscribed to prop changes.\n *\n * UI Shell listens to prop updates, and it won't subscribe synchronously. Because of that, this callback notifies when that subscription is ready.\n */\n onSubscriptionCreated: () => void;\n /**\n * This is a callback that provides a subscriber callback to listen for changes to state.\n * It allows UI Shell to listen for state changes.\n *\n * The props coming in this callback go directly to a React state; therefore, it shares the same signature and provides a previous state.\n */\n subscribeToPropChanges: (\n subscriber: (\n componentProps: SetStateAction<UiShellNavComponentProps>,\n ) => void,\n ) => () => void;\n /**\n * Sets a custom background color for the side nav area.\n */\n sideNavBackgroundColor?: string;\n /**\n * Sets a custom background color for the top nav area.\n */\n topNavBackgroundColor?: string;\n /**\n * React app component that renders as children in the correct location of the shell. Only used as fallback for ErrorBoundary.\n */\n appComponent?: ReactNode;\n} & Pick<ReactRootElements, \"appRootElement\" | \"stylesRootElement\"> &\n Pick<\n UiShellContentProps,\n | \"appBackgroundColor\"\n | \"appBackgroundContrastMode\"\n | \"appContainerElement\"\n | \"appContainerScrollingMode\"\n | \"hasStandardAppContentPadding\"\n | \"initialVisibleSections\"\n | \"onError\"\n | \"optionalComponents\"\n >;\n\n/**\n * Our new Unified Platform UI Shell.\n *\n * This includes the top and side navigation as well as the footer and provides a spot for your app to render into.\n *\n * If an error occurs, this will revert to only showing the app.\n */\nconst UiShell = ({\n appBackgroundColor,\n appBackgroundContrastMode,\n appComponent,\n appRootElement,\n appContainerElement,\n appContainerScrollingMode,\n hasStandardAppContentPadding,\n initialVisibleSections,\n onError = console.error,\n onSubscriptionCreated,\n optionalComponents,\n sideNavBackgroundColor,\n stylesRootElement,\n topNavBackgroundColor,\n subscribeToPropChanges,\n}: UiShellProps) => {\n const [componentProps, setComponentProps] = useState(defaultComponentProps);\n\n useEffect(() => {\n const unsubscribe = subscribeToPropChanges((componentProps) => {\n // If for some reason nothing is passed as `componentProps`, we fallback on `defaultComponentProps` as a safety mechanism to ensure nothing breaks.\n setComponentProps(componentProps || defaultComponentProps);\n });\n\n onSubscriptionCreated();\n\n return () => {\n unsubscribe();\n };\n }, [onSubscriptionCreated, subscribeToPropChanges]);\n\n return (\n <ErrorBoundary fallback={appComponent} onError={onError}>\n <OdysseyProvider\n emotionRootElement={stylesRootElement}\n shadowRootElement={appRootElement}\n hasScopedCssBaseline={false}\n >\n <ErrorBoundary fallback={appComponent} onError={onError}>\n <CssBaseline />\n <UiShellProvider\n appBackgroundColor={appBackgroundColor}\n appBackgroundContrastMode={appBackgroundContrastMode}\n sideNavBackgroundColor={sideNavBackgroundColor}\n topNavBackgroundColor={topNavBackgroundColor}\n >\n <UiShellContent\n {...componentProps}\n appContainerElement={appContainerElement}\n appContainerScrollingMode={appContainerScrollingMode}\n hasStandardAppContentPadding={hasStandardAppContentPadding}\n initialVisibleSections={initialVisibleSections}\n onError={onError}\n optionalComponents={optionalComponents}\n />\n </UiShellProvider>\n </ErrorBoundary>\n </OdysseyProvider>\n </ErrorBoundary>\n );\n};\n\nconst MemoizedUiShell = memo(UiShell);\nMemoizedUiShell.displayName = \"UiShell\";\n\nexport { MemoizedUiShell as UiShell };\n"],"mappings":";;;;;;AAYA,IAAAA,MAAA,GAAAC,OAAA;AAOA,IAAAC,mBAAA,GAAAD,OAAA;AAEA,IAAAE,YAAA,GAAAF,OAAA;AACA,IAAAG,gBAAA,GAAAH,OAAA;AACA,IAAAI,eAAA,GAAAJ,OAAA;AAMA,IAAAK,gBAAA,GAAAL,OAAA;AAAuD,IAAAM,WAAA,GAAAN,OAAA;AA7BvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAqBO,MAAMO,qBAA+C,GAAAC,OAAA,CAAAD,qBAAA,GAAG;EAC7DE,YAAY,EAAEC,SAAS;EACvBC,WAAW,EAAED;AACf,CAAU;AAoDV,MAAME,OAAO,GAAGA,CAAC;EACfC,kBAAkB;EAClBC,yBAAyB;EACzBC,YAAY;EACZC,cAAc;EACdC,mBAAmB;EACnBC,yBAAyB;EACzBC,4BAA4B;EAC5BC,sBAAsB;EACtBC,OAAO,GAAGC,OAAO,CAACC,KAAK;EACvBC,qBAAqB;EACrBC,kBAAkB;EAClBC,sBAAsB;EACtBC,iBAAiB;EACjBC,qBAAqB;EACrBC;AACY,CAAC,KAAK;EAClB,MAAM,CAACC,cAAc,EAAEC,iBAAiB,CAAC,GAAG,IAAAC,eAAQ,EAACzB,qBAAqB,CAAC;EAE3E,IAAA0B,gBAAS,EAAC,MAAM;IACd,MAAMC,WAAW,GAAGL,sBAAsB,CAAEC,cAAc,IAAK;MAE7DC,iBAAiB,CAACD,cAAc,IAAIvB,qBAAqB,CAAC;IAC5D,CAAC,CAAC;IAEFiB,qBAAqB,CAAC,CAAC;IAEvB,OAAO,MAAM;MACXU,WAAW,CAAC,CAAC;IACf,CAAC;EACH,CAAC,EAAE,CAACV,qBAAqB,EAAEK,sBAAsB,CAAC,CAAC;EAEnD,OACE,IAAAvB,WAAA,CAAA6B,GAAA,EAAClC,mBAAA,CAAAmC,aAAa;IAACC,QAAQ,EAAEtB,YAAa;IAACM,OAAO,EAAEA,OAAQ;IAAAiB,QAAA,EACtD,IAAAhC,WAAA,CAAA6B,GAAA,EAAChC,gBAAA,CAAAoC,eAAe;MACdC,kBAAkB,EAAEb,iBAAkB;MACtCc,iBAAiB,EAAEzB,cAAe;MAClC0B,oBAAoB,EAAE,KAAM;MAAAJ,QAAA,EAE5B,IAAAhC,WAAA,CAAAqC,IAAA,EAAC1C,mBAAA,CAAAmC,aAAa;QAACC,QAAQ,EAAEtB,YAAa;QAACM,OAAO,EAAEA,OAAQ;QAAAiB,QAAA,GACtD,IAAAhC,WAAA,CAAA6B,GAAA,EAACjC,YAAA,CAAA0C,WAAW,IAAE,CAAC,EACf,IAAAtC,WAAA,CAAA6B,GAAA,EAAC9B,gBAAA,CAAAwC,eAAe;UACdhC,kBAAkB,EAAEA,kBAAmB;UACvCC,yBAAyB,EAAEA,yBAA0B;UACrDY,sBAAsB,EAAEA,sBAAuB;UAC/CE,qBAAqB,EAAEA,qBAAsB;UAAAU,QAAA,EAE7C,IAAAhC,WAAA,CAAA6B,GAAA,EAAC/B,eAAA,CAAA0C,cAAc;YAAA,GACThB,cAAc;YAClBb,mBAAmB,EAAEA,mBAAoB;YACzCC,yBAAyB,EAAEA,yBAA0B;YACrDC,4BAA4B,EAAEA,4BAA6B;YAC3DC,sBAAsB,EAAEA,sBAAuB;YAC/CC,OAAO,EAAEA,OAAQ;YACjBI,kBAAkB,EAAEA;UAAmB,CACxC;QAAC,CACa,CAAC;MAAA,CACL;IAAC,CACD;EAAC,CACL,CAAC;AAEpB,CAAC;AAED,MAAMsB,eAAe,GAAAvC,OAAA,CAAAI,OAAA,GAAG,IAAAoC,WAAI,EAACpC,OAAO,CAAC;AACrCmC,eAAe,CAACE,WAAW,GAAG,SAAS","ignoreList":[]}
1
+ {"version":3,"file":"UiShell.cjs","names":["_react","require","_reactErrorBoundary","_CssBaseline","_NarrowUiShellContent","_OdysseyProvider","_UiShellProvider","_useUiShellBreakpoints","_WideUiShellContent","_jsxRuntime","defaultComponentProps","exports","sideNavProps","undefined","topNavProps","errorComponent","jsx","UiShell","appBackgroundColor","appBackgroundContrastMode","appElement","appElementScrollingMode","hasStandardAppContentPadding","initialVisibleSections","onError","console","error","onSubscriptionCreated","optionalComponents","sideNavBackgroundColor","subscribeToPropChanges","topNavBackgroundColor","uiShellAppElement","uiShellStylesElement","componentProps","setComponentProps","useState","activeBreakpoint","useUiShellBreakpoints","useEffect","unsubscribe","ErrorBoundary","fallback","children","OdysseyProvider","emotionRootElement","shadowRootElement","jsxs","CssBaseline","UiShellProvider","NarrowUiShellContent","WideUiShellContent","isCollapsed","isCollapsible","MemoizedUiShell","memo","displayName"],"sources":["../../../src/ui-shell/UiShell.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 { memo, useEffect, useState, type SetStateAction } from \"react\";\nimport { ErrorBoundary } from \"react-error-boundary\";\n\nimport { type ReactRootElements } from \"../web-component/createReactRootElements.js\";\nimport { CssBaseline } from \"../CssBaseline.js\";\nimport { NarrowUiShellContent } from \"./NarrowUiShellContent.js\";\nimport { OdysseyProvider } from \"../OdysseyProvider.js\";\nimport { UiShellProvider } from \"./UiShellProvider.js\";\nimport {\n UiShellNavComponentProps,\n UiShellContentProps,\n} from \"./uiShellContentTypes.js\";\nimport { useUiShellBreakpoints } from \"./useUiShellBreakpoints.js\";\nimport { ContrastMode } from \"../useContrastMode.js\";\nimport { WideUiShellContent } from \"./WideUiShellContent.js\";\n\nexport const defaultComponentProps: UiShellNavComponentProps = {\n sideNavProps: undefined,\n topNavProps: undefined,\n} as const;\n\nconst errorComponent = <div data-error />;\n\nexport type UiShellProps = {\n /**\n * Sets a custom background color for the app content area.\n */\n appBackgroundColor?: string;\n /**\n * Sets either a gray or white background color for the app content area.\n */\n appBackgroundContrastMode?: ContrastMode;\n /**\n * Notifies when subscribed to prop changes.\n *\n * UI Shell listens to prop updates, and it won't subscribe synchronously. Because of that, this callback notifies when that subscription is ready.\n */\n onSubscriptionCreated: () => void;\n /**\n * This is a callback that provides a subscriber callback to listen for changes to state.\n * It allows UI Shell to listen for state changes.\n *\n * The props coming in this callback go directly to a React state; therefore, it shares the same signature and provides a previous state.\n */\n subscribeToPropChanges: (\n subscriber: (\n componentProps: SetStateAction<UiShellNavComponentProps>,\n ) => void,\n ) => () => void;\n /**\n * Sets a custom background color for the side nav area.\n */\n sideNavBackgroundColor?: string;\n /**\n * Sets a custom background color for the top nav area.\n */\n topNavBackgroundColor?: string;\n /**\n * Element inside UI Shell's React root component renders into. If using a web component, this is going to exist inside it.\n */\n uiShellAppElement: ReactRootElements[\"appRootElement\"];\n /**\n * Typically, this is your `<head>` element. If using a web component, you need to create one yourself as Shadow DOM's don't have a `<head>`.\n */\n uiShellStylesElement: ReactRootElements[\"stylesRootElement\"];\n} & Pick<\n UiShellContentProps,\n | \"appElement\"\n | \"appElementScrollingMode\"\n | \"hasStandardAppContentPadding\"\n | \"initialVisibleSections\"\n | \"onError\"\n | \"optionalComponents\"\n>;\n\n/**\n * Our new Unified Platform UI Shell.\n *\n * This includes the top and side navigation as well as the footer and provides a spot for your app to render into.\n *\n * If an error occurs, this will revert to only showing the app.\n */\nconst UiShell = ({\n appBackgroundColor,\n appBackgroundContrastMode,\n appElement,\n appElementScrollingMode,\n hasStandardAppContentPadding,\n initialVisibleSections,\n onError = console.error,\n onSubscriptionCreated,\n optionalComponents,\n sideNavBackgroundColor,\n subscribeToPropChanges,\n topNavBackgroundColor,\n uiShellAppElement,\n uiShellStylesElement,\n}: UiShellProps) => {\n const [componentProps, setComponentProps] = useState(defaultComponentProps);\n\n const activeBreakpoint = useUiShellBreakpoints();\n\n useEffect(() => {\n const unsubscribe = subscribeToPropChanges((componentProps) => {\n // If for some reason nothing is passed as `componentProps`, we fallback on `defaultComponentProps` as a safety mechanism to ensure nothing breaks.\n setComponentProps(componentProps || defaultComponentProps);\n });\n\n onSubscriptionCreated();\n\n return () => {\n unsubscribe();\n };\n }, [onSubscriptionCreated, subscribeToPropChanges]);\n\n return activeBreakpoint === \"none\" ? null : (\n <ErrorBoundary fallback={errorComponent} onError={onError}>\n <OdysseyProvider\n emotionRootElement={uiShellStylesElement}\n shadowRootElement={uiShellAppElement}\n >\n <ErrorBoundary fallback={errorComponent} onError={onError}>\n <CssBaseline />\n\n <UiShellProvider\n appBackgroundColor={appBackgroundColor}\n appBackgroundContrastMode={appBackgroundContrastMode}\n sideNavBackgroundColor={sideNavBackgroundColor}\n topNavBackgroundColor={topNavBackgroundColor}\n >\n {activeBreakpoint === \"constrained\" && (\n <NarrowUiShellContent\n {...componentProps}\n appElement={appElement}\n appElementScrollingMode={appElementScrollingMode}\n hasStandardAppContentPadding={hasStandardAppContentPadding}\n initialVisibleSections={initialVisibleSections}\n onError={onError}\n optionalComponents={optionalComponents}\n />\n )}\n\n {(activeBreakpoint === \"compact\" ||\n activeBreakpoint === \"comfortable\") && (\n <WideUiShellContent\n {...{\n ...componentProps,\n ...(componentProps.sideNavProps\n ? {\n sideNavProps: {\n ...componentProps.sideNavProps,\n isCollapsed:\n activeBreakpoint === \"compact\" ||\n componentProps.sideNavProps?.isCollapsed,\n isCollapsible:\n activeBreakpoint === \"compact\" ||\n componentProps.sideNavProps?.isCollapsible,\n // We have to use `as` because sideNavProps expects you to have `sideNavItems` defined even though it had to be passed in `...componentProps.sideNavProps`.\n } as typeof componentProps.sideNavProps,\n }\n : {}),\n }}\n appElement={appElement}\n appElementScrollingMode={appElementScrollingMode}\n hasStandardAppContentPadding={hasStandardAppContentPadding}\n initialVisibleSections={initialVisibleSections}\n onError={onError}\n optionalComponents={optionalComponents}\n />\n )}\n </UiShellProvider>\n </ErrorBoundary>\n </OdysseyProvider>\n </ErrorBoundary>\n );\n};\n\nconst MemoizedUiShell = memo(UiShell);\nMemoizedUiShell.displayName = \"UiShell\";\n\nexport { MemoizedUiShell as UiShell };\n"],"mappings":"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","ignoreList":[]}
@@ -7,6 +7,7 @@ exports.useUiShellContext = exports.UiShellProvider = void 0;
7
7
  var _react = require("react");
8
8
  var _createContrastColors = require("../createContrastColors.cjs");
9
9
  var _OdysseyDesignTokensContext = require("../OdysseyDesignTokensContext.cjs");
10
+ var _createMessageBus = require("./createMessageBus.cjs");
10
11
  var _jsxRuntime = require("react/jsx-runtime");
11
12
  /*!
12
13
  * Copyright (c) 2022-present, Okta, Inc. and/or its affiliates. All rights reserved.
@@ -28,9 +29,9 @@ exports.useUiShellContext = useUiShellContext;
28
29
  const UiShellProvider = ({
29
30
  appBackgroundColor,
30
31
  appBackgroundContrastMode = "lowContrast",
32
+ children,
31
33
  sideNavBackgroundColor,
32
- topNavBackgroundColor,
33
- children
34
+ topNavBackgroundColor
34
35
  }) => {
35
36
  const odysseyDesignTokens = (0, _OdysseyDesignTokensContext.useOdysseyDesignTokens)();
36
37
  const defaultedSideNavBackgroundColor = sideNavBackgroundColor || odysseyDesignTokens.HueNeutralWhite;
@@ -39,12 +40,18 @@ const UiShellProvider = ({
39
40
  const defaultTopAndAppBackgroundColor = isAppBackgroundHightContrast ? odysseyDesignTokens.HueNeutralWhite : odysseyDesignTokens.HueNeutral50;
40
41
  const topNavColor = topNavBackgroundColor || defaultTopAndAppBackgroundColor;
41
42
  const appContentBackgroundColor = appBackgroundColor || defaultTopAndAppBackgroundColor;
43
+ const {
44
+ publish: publishSideNavItemClicked,
45
+ subscribe: subscribeSideNavItemClicked
46
+ } = (0, _react.useMemo)(() => (0, _createMessageBus.createMessageBus)(), []);
42
47
  const memoizedContextValue = (0, _react.useMemo)(() => ({
43
48
  appBackgroundColor: appContentBackgroundColor,
49
+ publishSideNavItemClicked,
44
50
  sideNavBackgroundColor: sideNavBackgroundColor || odysseyDesignTokens.HueNeutralWhite,
45
51
  sideNavContrastColors,
52
+ subscribeSideNavItemClicked,
46
53
  topNavBackgroundColor: topNavColor
47
- }), [appContentBackgroundColor, odysseyDesignTokens, sideNavBackgroundColor, sideNavContrastColors, topNavColor]);
54
+ }), [appContentBackgroundColor, odysseyDesignTokens, publishSideNavItemClicked, sideNavBackgroundColor, sideNavContrastColors, subscribeSideNavItemClicked, topNavColor]);
48
55
  return (0, _jsxRuntime.jsx)(UiShellContext.Provider, {
49
56
  value: memoizedContextValue,
50
57
  children: children
@@ -1 +1 @@
1
- {"version":3,"file":"UiShellProvider.cjs","names":["_react","require","_createContrastColors","_OdysseyDesignTokensContext","_jsxRuntime","UiShellContext","createContext","undefined","useUiShellContext","useContext","exports","UiShellProvider","appBackgroundColor","appBackgroundContrastMode","sideNavBackgroundColor","topNavBackgroundColor","children","odysseyDesignTokens","useOdysseyDesignTokens","defaultedSideNavBackgroundColor","HueNeutralWhite","sideNavContrastColors","generateContrastColors","isAppBackgroundHightContrast","defaultTopAndAppBackgroundColor","HueNeutral50","topNavColor","appContentBackgroundColor","memoizedContextValue","useMemo","jsx","Provider","value","MemoizedUiShellProvider","memo"],"sources":["../../../src/ui-shell/UiShellProvider.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 {\n createContext,\n memo,\n PropsWithChildren,\n useContext,\n useMemo,\n} from \"react\";\nimport {\n generateContrastColors,\n ContrastColors,\n} from \"../createContrastColors.js\";\nimport { useOdysseyDesignTokens } from \"../OdysseyDesignTokensContext.js\";\n\nexport type UiShellColors = {\n appBackgroundColor: string;\n sideNavBackgroundColor: string;\n sideNavContrastColors?: ContrastColors | undefined;\n topNavBackgroundColor: string;\n};\n\nconst UiShellContext = createContext<UiShellColors | undefined>(undefined);\n\nexport const useUiShellContext = () => {\n return useContext(UiShellContext);\n};\n\nexport type UiShellProviderProps = {\n appBackgroundColor?: string;\n sideNavBackgroundColor?: string;\n topNavBackgroundColor?: string;\n appBackgroundContrastMode?: string;\n};\n\nconst UiShellProvider = ({\n appBackgroundColor,\n appBackgroundContrastMode = \"lowContrast\",\n sideNavBackgroundColor,\n topNavBackgroundColor,\n children,\n}: PropsWithChildren<UiShellProviderProps>) => {\n const odysseyDesignTokens = useOdysseyDesignTokens();\n const defaultedSideNavBackgroundColor =\n sideNavBackgroundColor || odysseyDesignTokens.HueNeutralWhite;\n\n const sideNavContrastColors =\n defaultedSideNavBackgroundColor !== odysseyDesignTokens.HueNeutralWhite\n ? generateContrastColors(\n defaultedSideNavBackgroundColor,\n odysseyDesignTokens,\n )\n : undefined;\n\n const isAppBackgroundHightContrast =\n appBackgroundContrastMode === \"highContrast\";\n\n const defaultTopAndAppBackgroundColor = isAppBackgroundHightContrast\n ? odysseyDesignTokens.HueNeutralWhite\n : odysseyDesignTokens.HueNeutral50;\n\n const topNavColor = topNavBackgroundColor || defaultTopAndAppBackgroundColor;\n\n const appContentBackgroundColor =\n appBackgroundColor || defaultTopAndAppBackgroundColor;\n\n const memoizedContextValue = useMemo(\n () => ({\n appBackgroundColor: appContentBackgroundColor,\n sideNavBackgroundColor:\n sideNavBackgroundColor || odysseyDesignTokens.HueNeutralWhite,\n sideNavContrastColors,\n topNavBackgroundColor: topNavColor,\n }),\n [\n appContentBackgroundColor,\n odysseyDesignTokens,\n sideNavBackgroundColor,\n sideNavContrastColors,\n topNavColor,\n ],\n );\n\n return (\n <UiShellContext.Provider value={memoizedContextValue}>\n {children}\n </UiShellContext.Provider>\n );\n};\n\nconst MemoizedUiShellProvider = memo(UiShellProvider);\n\nexport { MemoizedUiShellProvider as UiShellProvider };\n"],"mappings":";;;;;;AAYA,IAAAA,MAAA,GAAAC,OAAA;AAOA,IAAAC,qBAAA,GAAAD,OAAA;AAIA,IAAAE,2BAAA,GAAAF,OAAA;AAA0E,IAAAG,WAAA,GAAAH,OAAA;AAvB1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAsBA,MAAMI,cAAc,GAAG,IAAAC,oBAAa,EAA4BC,SAAS,CAAC;AAEnE,MAAMC,iBAAiB,GAAGA,CAAA,KAAM;EACrC,OAAO,IAAAC,iBAAU,EAACJ,cAAc,CAAC;AACnC,CAAC;AAACK,OAAA,CAAAF,iBAAA,GAAAA,iBAAA;AASF,MAAMG,eAAe,GAAGA,CAAC;EACvBC,kBAAkB;EAClBC,yBAAyB,GAAG,aAAa;EACzCC,sBAAsB;EACtBC,qBAAqB;EACrBC;AACuC,CAAC,KAAK;EAC7C,MAAMC,mBAAmB,GAAG,IAAAC,kDAAsB,EAAC,CAAC;EACpD,MAAMC,+BAA+B,GACnCL,sBAAsB,IAAIG,mBAAmB,CAACG,eAAe;EAE/D,MAAMC,qBAAqB,GACzBF,+BAA+B,KAAKF,mBAAmB,CAACG,eAAe,GACnE,IAAAE,4CAAsB,EACpBH,+BAA+B,EAC/BF,mBACF,CAAC,GACDV,SAAS;EAEf,MAAMgB,4BAA4B,GAChCV,yBAAyB,KAAK,cAAc;EAE9C,MAAMW,+BAA+B,GAAGD,4BAA4B,GAChEN,mBAAmB,CAACG,eAAe,GACnCH,mBAAmB,CAACQ,YAAY;EAEpC,MAAMC,WAAW,GAAGX,qBAAqB,IAAIS,+BAA+B;EAE5E,MAAMG,yBAAyB,GAC7Bf,kBAAkB,IAAIY,+BAA+B;EAEvD,MAAMI,oBAAoB,GAAG,IAAAC,cAAO,EAClC,OAAO;IACLjB,kBAAkB,EAAEe,yBAAyB;IAC7Cb,sBAAsB,EACpBA,sBAAsB,IAAIG,mBAAmB,CAACG,eAAe;IAC/DC,qBAAqB;IACrBN,qBAAqB,EAAEW;EACzB,CAAC,CAAC,EACF,CACEC,yBAAyB,EACzBV,mBAAmB,EACnBH,sBAAsB,EACtBO,qBAAqB,EACrBK,WAAW,CAEf,CAAC;EAED,OACE,IAAAtB,WAAA,CAAA0B,GAAA,EAACzB,cAAc,CAAC0B,QAAQ;IAACC,KAAK,EAAEJ,oBAAqB;IAAAZ,QAAA,EAClDA;EAAQ,CACc,CAAC;AAE9B,CAAC;AAED,MAAMiB,uBAAuB,GAAAvB,OAAA,CAAAC,eAAA,GAAG,IAAAuB,WAAI,EAACvB,eAAe,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"UiShellProvider.cjs","names":["_react","require","_createContrastColors","_OdysseyDesignTokensContext","_createMessageBus","_jsxRuntime","UiShellContext","createContext","undefined","useUiShellContext","useContext","exports","UiShellProvider","appBackgroundColor","appBackgroundContrastMode","children","sideNavBackgroundColor","topNavBackgroundColor","odysseyDesignTokens","useOdysseyDesignTokens","defaultedSideNavBackgroundColor","HueNeutralWhite","sideNavContrastColors","generateContrastColors","isAppBackgroundHightContrast","defaultTopAndAppBackgroundColor","HueNeutral50","topNavColor","appContentBackgroundColor","publish","publishSideNavItemClicked","subscribe","subscribeSideNavItemClicked","useMemo","createMessageBus","memoizedContextValue","jsx","Provider","value","MemoizedUiShellProvider","memo"],"sources":["../../../src/ui-shell/UiShellProvider.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 {\n createContext,\n memo,\n PropsWithChildren,\n useContext,\n useMemo,\n} from \"react\";\nimport {\n ContrastColors,\n generateContrastColors,\n} from \"../createContrastColors.js\";\nimport { useOdysseyDesignTokens } from \"../OdysseyDesignTokensContext.js\";\nimport { createMessageBus, MessageBus } from \"./createMessageBus.js\";\n\nexport type UiShellColors = {\n appBackgroundColor: string;\n sideNavBackgroundColor: string;\n sideNavContrastColors?: ContrastColors | undefined;\n topNavBackgroundColor: string;\n};\n\nexport type UiShellContext = {\n publishSideNavItemClicked: MessageBus<void>[\"publish\"];\n subscribeSideNavItemClicked: MessageBus<void>[\"subscribe\"];\n} & UiShellColors;\n\nconst UiShellContext = createContext<UiShellContext | undefined>(undefined);\n\nexport const useUiShellContext = () => {\n return useContext(UiShellContext);\n};\n\nexport type UiShellProviderProps = {\n appBackgroundContrastMode?: string;\n} & Partial<\n Pick<\n UiShellColors,\n \"appBackgroundColor\" | \"sideNavBackgroundColor\" | \"topNavBackgroundColor\"\n >\n>;\n\nconst UiShellProvider = ({\n appBackgroundColor,\n appBackgroundContrastMode = \"lowContrast\",\n children,\n sideNavBackgroundColor,\n topNavBackgroundColor,\n}: PropsWithChildren<UiShellProviderProps>) => {\n const odysseyDesignTokens = useOdysseyDesignTokens();\n const defaultedSideNavBackgroundColor =\n sideNavBackgroundColor || odysseyDesignTokens.HueNeutralWhite;\n\n const sideNavContrastColors =\n defaultedSideNavBackgroundColor !== odysseyDesignTokens.HueNeutralWhite\n ? generateContrastColors(\n defaultedSideNavBackgroundColor,\n odysseyDesignTokens,\n )\n : undefined;\n\n const isAppBackgroundHightContrast =\n appBackgroundContrastMode === \"highContrast\";\n\n const defaultTopAndAppBackgroundColor = isAppBackgroundHightContrast\n ? odysseyDesignTokens.HueNeutralWhite\n : odysseyDesignTokens.HueNeutral50;\n\n const topNavColor = topNavBackgroundColor || defaultTopAndAppBackgroundColor;\n\n const appContentBackgroundColor =\n appBackgroundColor || defaultTopAndAppBackgroundColor;\n\n const {\n publish: publishSideNavItemClicked,\n subscribe: subscribeSideNavItemClicked,\n } = useMemo(() => createMessageBus(), []);\n\n const memoizedContextValue = useMemo(\n () => ({\n appBackgroundColor: appContentBackgroundColor,\n publishSideNavItemClicked,\n sideNavBackgroundColor:\n sideNavBackgroundColor || odysseyDesignTokens.HueNeutralWhite,\n sideNavContrastColors,\n subscribeSideNavItemClicked,\n topNavBackgroundColor: topNavColor,\n }),\n [\n appContentBackgroundColor,\n odysseyDesignTokens,\n publishSideNavItemClicked,\n sideNavBackgroundColor,\n sideNavContrastColors,\n subscribeSideNavItemClicked,\n topNavColor,\n ],\n );\n\n return (\n <UiShellContext.Provider value={memoizedContextValue}>\n {children}\n </UiShellContext.Provider>\n );\n};\n\nconst MemoizedUiShellProvider = memo(UiShellProvider);\n\nexport { MemoizedUiShellProvider as UiShellProvider };\n"],"mappings":";;;;;;AAYA,IAAAA,MAAA,GAAAC,OAAA;AAOA,IAAAC,qBAAA,GAAAD,OAAA;AAIA,IAAAE,2BAAA,GAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAH,OAAA;AAAqE,IAAAI,WAAA,GAAAJ,OAAA;AAxBrE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AA4BA,MAAMK,cAAc,GAAG,IAAAC,oBAAa,EAA6BC,SAAS,CAAC;AAEpE,MAAMC,iBAAiB,GAAGA,CAAA,KAAM;EACrC,OAAO,IAAAC,iBAAU,EAACJ,cAAc,CAAC;AACnC,CAAC;AAACK,OAAA,CAAAF,iBAAA,GAAAA,iBAAA;AAWF,MAAMG,eAAe,GAAGA,CAAC;EACvBC,kBAAkB;EAClBC,yBAAyB,GAAG,aAAa;EACzCC,QAAQ;EACRC,sBAAsB;EACtBC;AACuC,CAAC,KAAK;EAC7C,MAAMC,mBAAmB,GAAG,IAAAC,kDAAsB,EAAC,CAAC;EACpD,MAAMC,+BAA+B,GACnCJ,sBAAsB,IAAIE,mBAAmB,CAACG,eAAe;EAE/D,MAAMC,qBAAqB,GACzBF,+BAA+B,KAAKF,mBAAmB,CAACG,eAAe,GACnE,IAAAE,4CAAsB,EACpBH,+BAA+B,EAC/BF,mBACF,CAAC,GACDV,SAAS;EAEf,MAAMgB,4BAA4B,GAChCV,yBAAyB,KAAK,cAAc;EAE9C,MAAMW,+BAA+B,GAAGD,4BAA4B,GAChEN,mBAAmB,CAACG,eAAe,GACnCH,mBAAmB,CAACQ,YAAY;EAEpC,MAAMC,WAAW,GAAGV,qBAAqB,IAAIQ,+BAA+B;EAE5E,MAAMG,yBAAyB,GAC7Bf,kBAAkB,IAAIY,+BAA+B;EAEvD,MAAM;IACJI,OAAO,EAAEC,yBAAyB;IAClCC,SAAS,EAAEC;EACb,CAAC,GAAG,IAAAC,cAAO,EAAC,MAAM,IAAAC,kCAAgB,EAAC,CAAC,EAAE,EAAE,CAAC;EAEzC,MAAMC,oBAAoB,GAAG,IAAAF,cAAO,EAClC,OAAO;IACLpB,kBAAkB,EAAEe,yBAAyB;IAC7CE,yBAAyB;IACzBd,sBAAsB,EACpBA,sBAAsB,IAAIE,mBAAmB,CAACG,eAAe;IAC/DC,qBAAqB;IACrBU,2BAA2B;IAC3Bf,qBAAqB,EAAEU;EACzB,CAAC,CAAC,EACF,CACEC,yBAAyB,EACzBV,mBAAmB,EACnBY,yBAAyB,EACzBd,sBAAsB,EACtBM,qBAAqB,EACrBU,2BAA2B,EAC3BL,WAAW,CAEf,CAAC;EAED,OACE,IAAAtB,WAAA,CAAA+B,GAAA,EAAC9B,cAAc,CAAC+B,QAAQ;IAACC,KAAK,EAAEH,oBAAqB;IAAApB,QAAA,EAClDA;EAAQ,CACc,CAAC;AAE9B,CAAC;AAED,MAAMwB,uBAAuB,GAAA5B,OAAA,CAAAC,eAAA,GAAG,IAAA4B,WAAI,EAAC5B,eAAe,CAAC","ignoreList":[]}
@@ -0,0 +1,171 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.WideUiShellContent = void 0;
7
+ var _styled = _interopRequireDefault(require("@emotion/styled"));
8
+ var _react = require("react");
9
+ var _reactErrorBoundary = require("react-error-boundary");
10
+ var _index = require("./AppSwitcher/index.cjs");
11
+ var _OdysseyDesignTokensContext = require("../OdysseyDesignTokensContext.cjs");
12
+ var _index2 = require("./SideNav/index.cjs");
13
+ var _index3 = require("./TopNav/index.cjs");
14
+ var _useScrollState = require("./useScrollState.cjs");
15
+ var _useMatchAppElementToUiShellAppArea = require("./useMatchAppElementToUiShellAppArea.cjs");
16
+ var _UiShellProvider = require("./UiShellProvider.cjs");
17
+ var _jsxRuntime = require("react/jsx-runtime");
18
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
19
+ /*!
20
+ * Copyright (c) 2024-present, Okta, Inc. and/or its affiliates. All rights reserved.
21
+ * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
22
+ *
23
+ * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
24
+ * Unless required by applicable law or agreed to in writing, software
25
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
26
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
27
+ *
28
+ * See the License for the specific language governing permissions and limitations under the License.
29
+ */
30
+
31
+ const emptySideNavItems = [];
32
+ const StyledAppContainer = (0, _styled.default)("div", {
33
+ shouldForwardProp: prop => prop !== "appBackgroundColor" && prop !== "odysseyDesignTokens"
34
+ })(({
35
+ appBackgroundColor
36
+ }) => ({
37
+ gridArea: "app-content",
38
+ backgroundColor: appBackgroundColor
39
+ }));
40
+ const StyledAppSwitcherContainer = (0, _styled.default)("div")({
41
+ gridArea: "app-switcher"
42
+ });
43
+ const StyledBannersContainer = (0, _styled.default)("div")({
44
+ gridArea: "banners"
45
+ });
46
+ const StyledSideNavContainer = (0, _styled.default)("div")({
47
+ gridArea: "side-nav"
48
+ });
49
+ const StyledShellContainer = (0, _styled.default)("div", {
50
+ shouldForwardProp: prop => prop !== "odysseyDesignTokens"
51
+ })(({
52
+ odysseyDesignTokens
53
+ }) => ({
54
+ backgroundColor: odysseyDesignTokens.HueNeutral50,
55
+ display: "grid",
56
+ gridGap: 0,
57
+ gridTemplateAreas: `
58
+ "banners banners banners"
59
+ "app-switcher side-nav top-nav"
60
+ "app-switcher side-nav app-content"
61
+ `,
62
+ gridTemplateColumns: "auto auto 1fr",
63
+ gridTemplateRows: "auto auto 1fr",
64
+ height: "100vh",
65
+ width: "100vw"
66
+ }));
67
+ const StyledTopNavContainer = (0, _styled.default)("div")({
68
+ gridArea: "top-nav"
69
+ });
70
+ const WideUiShellContent = ({
71
+ appElement,
72
+ appElementScrollingMode,
73
+ appSwitcherProps,
74
+ hasStandardAppContentPadding = true,
75
+ initialVisibleSections = ["TopNav", "SideNav", "AppSwitcher"],
76
+ onError = console.error,
77
+ optionalComponents,
78
+ sideNavProps,
79
+ topNavProps
80
+ }) => {
81
+ const odysseyDesignTokens = (0, _OdysseyDesignTokensContext.useOdysseyDesignTokens)();
82
+ const uiShellContext = (0, _UiShellProvider.useUiShellContext)();
83
+ const {
84
+ isContentScrolled
85
+ } = (0, _useScrollState.useScrollState)(appElement);
86
+ const sideNavContainerRef = (0, _react.useRef)(null);
87
+ const topNavContainerRef = (0, _react.useRef)(null);
88
+ const uiShellAppAreaRef = (0, _react.useRef)(null);
89
+ const {
90
+ parentContainerRef
91
+ } = (0, _useMatchAppElementToUiShellAppArea.useMatchAppElementToUiShellAppArea)({
92
+ appElement,
93
+ appElementScrollingMode,
94
+ paddingMode: hasStandardAppContentPadding ? "comfortable" : "none",
95
+ uiShellAppAreaRef,
96
+ uiShellResizableRefs: [sideNavContainerRef, topNavContainerRef, uiShellAppAreaRef]
97
+ });
98
+ return (0, _jsxRuntime.jsxs)(StyledShellContainer, {
99
+ odysseyDesignTokens: odysseyDesignTokens,
100
+ ref: parentContainerRef,
101
+ children: [(0, _jsxRuntime.jsx)(StyledBannersContainer, {
102
+ children: optionalComponents?.banners
103
+ }), (0, _jsxRuntime.jsxs)(StyledAppSwitcherContainer, {
104
+ children: [initialVisibleSections?.includes("AppSwitcher") && !appSwitcherProps && (0, _jsxRuntime.jsx)(_reactErrorBoundary.ErrorBoundary, {
105
+ fallback: null,
106
+ onError: onError,
107
+ children: (0, _jsxRuntime.jsx)(_index.AppSwitcher, {
108
+ isLoading: true,
109
+ appIcons: [],
110
+ selectedAppName: ""
111
+ })
112
+ }), appSwitcherProps && (0, _jsxRuntime.jsx)(_reactErrorBoundary.ErrorBoundary, {
113
+ fallback: null,
114
+ onError: onError,
115
+ children: (0, _jsxRuntime.jsx)(_index.AppSwitcher, {
116
+ ...appSwitcherProps
117
+ })
118
+ })]
119
+ }), (0, _jsxRuntime.jsxs)(StyledSideNavContainer, {
120
+ ref: sideNavContainerRef,
121
+ children: [initialVisibleSections?.includes("SideNav") && sideNavProps === undefined && (0, _jsxRuntime.jsx)(_reactErrorBoundary.ErrorBoundary, {
122
+ fallback: null,
123
+ onError: onError,
124
+ children: (0, _jsxRuntime.jsx)(_index2.SideNav, {
125
+ isLoading: true,
126
+ sideNavItems: emptySideNavItems
127
+ })
128
+ }), sideNavProps && (0, _jsxRuntime.jsx)(_reactErrorBoundary.ErrorBoundary, {
129
+ fallback: null,
130
+ onError: onError,
131
+ children: (0, _jsxRuntime.jsx)(_index2.SideNav, {
132
+ ...sideNavProps,
133
+ ...(sideNavProps.hasCustomFooter && optionalComponents?.sideNavFooter ? {
134
+ footerComponent: optionalComponents.sideNavFooter,
135
+ footerItems: undefined,
136
+ hasCustomFooter: sideNavProps.hasCustomFooter
137
+ } : {
138
+ footerItems: sideNavProps.footerItems,
139
+ hasCustomFooter: false
140
+ })
141
+ })
142
+ })]
143
+ }), (0, _jsxRuntime.jsxs)(StyledTopNavContainer, {
144
+ ref: topNavContainerRef,
145
+ children: [initialVisibleSections?.includes("TopNav") && topNavProps === undefined && (0, _jsxRuntime.jsx)(_reactErrorBoundary.ErrorBoundary, {
146
+ fallback: null,
147
+ onError: onError,
148
+ children: (0, _jsxRuntime.jsx)(_index3.TopNav, {
149
+ leftSideComponent: optionalComponents?.topNavLeftSide,
150
+ rightSideComponent: optionalComponents?.topNavRightSide
151
+ })
152
+ }), topNavProps && (0, _jsxRuntime.jsx)(_reactErrorBoundary.ErrorBoundary, {
153
+ fallback: null,
154
+ onError: onError,
155
+ children: (0, _jsxRuntime.jsx)(_index3.TopNav, {
156
+ ...topNavProps,
157
+ isScrolled: isContentScrolled,
158
+ leftSideComponent: optionalComponents?.topNavLeftSide,
159
+ rightSideComponent: optionalComponents?.topNavRightSide
160
+ })
161
+ })]
162
+ }), (0, _jsxRuntime.jsx)(StyledAppContainer, {
163
+ appBackgroundColor: uiShellContext?.appBackgroundColor,
164
+ tabIndex: 0,
165
+ ref: uiShellAppAreaRef
166
+ })]
167
+ });
168
+ };
169
+ const MemoizedWideUiShellContent = exports.WideUiShellContent = (0, _react.memo)(WideUiShellContent);
170
+ MemoizedWideUiShellContent.displayName = "WideUiShellContent";
171
+ //# sourceMappingURL=WideUiShellContent.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WideUiShellContent.cjs","names":["_styled","_interopRequireDefault","require","_react","_reactErrorBoundary","_index","_OdysseyDesignTokensContext","_index2","_index3","_useScrollState","_useMatchAppElementToUiShellAppArea","_UiShellProvider","_jsxRuntime","e","__esModule","default","emptySideNavItems","StyledAppContainer","styled","shouldForwardProp","prop","appBackgroundColor","gridArea","backgroundColor","StyledAppSwitcherContainer","StyledBannersContainer","StyledSideNavContainer","StyledShellContainer","odysseyDesignTokens","HueNeutral50","display","gridGap","gridTemplateAreas","gridTemplateColumns","gridTemplateRows","height","width","StyledTopNavContainer","WideUiShellContent","appElement","appElementScrollingMode","appSwitcherProps","hasStandardAppContentPadding","initialVisibleSections","onError","console","error","optionalComponents","sideNavProps","topNavProps","useOdysseyDesignTokens","uiShellContext","useUiShellContext","isContentScrolled","useScrollState","sideNavContainerRef","useRef","topNavContainerRef","uiShellAppAreaRef","parentContainerRef","useMatchAppElementToUiShellAppArea","paddingMode","uiShellResizableRefs","jsxs","ref","children","jsx","banners","includes","ErrorBoundary","fallback","AppSwitcher","isLoading","appIcons","selectedAppName","undefined","SideNav","sideNavItems","hasCustomFooter","sideNavFooter","footerComponent","footerItems","TopNav","leftSideComponent","topNavLeftSide","rightSideComponent","topNavRightSide","isScrolled","tabIndex","MemoizedWideUiShellContent","exports","memo","displayName"],"sources":["../../../src/ui-shell/WideUiShellContent.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, useRef } from \"react\";\nimport { ErrorBoundary } from \"react-error-boundary\";\n\nimport { AppSwitcher } from \"./AppSwitcher/index.js\";\nimport {\n useOdysseyDesignTokens,\n type DesignTokens,\n} from \"../OdysseyDesignTokensContext.js\";\nimport {\n UiShellNavComponentProps,\n UiShellContentProps,\n} from \"./uiShellContentTypes.js\";\nimport { SideNav, type SideNavProps } from \"./SideNav/index.js\";\nimport { TopNav } from \"./TopNav/index.js\";\nimport { useScrollState } from \"./useScrollState.js\";\nimport { useMatchAppElementToUiShellAppArea } from \"./useMatchAppElementToUiShellAppArea.js\";\nimport { UiShellColors, useUiShellContext } from \"./UiShellProvider.js\";\n\nconst emptySideNavItems = [] satisfies SideNavProps[\"sideNavItems\"];\n\nconst StyledAppContainer = styled(\"div\", {\n shouldForwardProp: (prop) =>\n prop !== \"appBackgroundColor\" && prop !== \"odysseyDesignTokens\",\n})<{\n appBackgroundColor?: UiShellColors[\"appBackgroundColor\"];\n}>(({ appBackgroundColor }) => ({\n gridArea: \"app-content\",\n backgroundColor: appBackgroundColor,\n}));\n\nconst StyledAppSwitcherContainer = styled(\"div\")({\n gridArea: \"app-switcher\",\n});\n\nconst StyledBannersContainer = styled(\"div\")({\n gridArea: \"banners\",\n});\n\nconst StyledSideNavContainer = styled(\"div\")({\n gridArea: \"side-nav\",\n});\n\nconst StyledShellContainer = 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 banners banners\"\n \"app-switcher side-nav top-nav\"\n \"app-switcher side-nav app-content\"\n `,\n gridTemplateColumns: \"auto auto 1fr\",\n gridTemplateRows: \"auto auto 1fr\",\n height: \"100vh\",\n width: \"100vw\",\n}));\n\nconst StyledTopNavContainer = styled(\"div\")({\n gridArea: \"top-nav\",\n});\n\nexport type WideUiShellContentProps = UiShellNavComponentProps &\n UiShellContentProps;\n\n/**\n * Our new Unified Platform UI Shell.\n *\n * This includes the top and side navigation as well as the footer and provides a spot for your app to render into.\n *\n * If an error occurs, this will revert to only showing the app.\n */\nconst WideUiShellContent = ({\n appElement,\n appElementScrollingMode,\n appSwitcherProps,\n hasStandardAppContentPadding = true,\n initialVisibleSections = [\"TopNav\", \"SideNav\", \"AppSwitcher\"],\n onError = console.error,\n optionalComponents,\n sideNavProps,\n topNavProps,\n}: WideUiShellContentProps) => {\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 { parentContainerRef } = useMatchAppElementToUiShellAppArea({\n appElement,\n appElementScrollingMode,\n paddingMode: hasStandardAppContentPadding ? \"comfortable\" : \"none\",\n uiShellAppAreaRef,\n uiShellResizableRefs: [\n sideNavContainerRef,\n topNavContainerRef,\n uiShellAppAreaRef,\n ],\n });\n\n return (\n <StyledShellContainer\n odysseyDesignTokens={odysseyDesignTokens}\n ref={parentContainerRef}\n >\n <StyledBannersContainer>\n {optionalComponents?.banners}\n </StyledBannersContainer>\n\n <StyledAppSwitcherContainer>\n {\n /* If AppSwitcher should be initially visible and we have not yet received props, render AppSwitcher in the loading state */\n initialVisibleSections?.includes(\"AppSwitcher\") &&\n !appSwitcherProps && (\n <ErrorBoundary fallback={null} onError={onError}>\n <AppSwitcher isLoading appIcons={[]} selectedAppName=\"\" />\n </ErrorBoundary>\n )\n }\n\n {appSwitcherProps && (\n <ErrorBoundary fallback={null} onError={onError}>\n <AppSwitcher {...appSwitcherProps} />\n </ErrorBoundary>\n )}\n </StyledAppSwitcherContainer>\n\n <StyledSideNavContainer ref={sideNavContainerRef}>\n {\n /* If SideNav should be initially visible and we have not yet received props, render SideNav with minimal inputs */\n initialVisibleSections?.includes(\"SideNav\") &&\n sideNavProps === undefined && (\n <ErrorBoundary fallback={null} onError={onError}>\n <SideNav isLoading sideNavItems={emptySideNavItems} />\n </ErrorBoundary>\n )\n }\n\n {sideNavProps && (\n <ErrorBoundary fallback={null} onError={onError}>\n <SideNav\n {...{\n ...sideNavProps,\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 />\n </ErrorBoundary>\n )}\n </StyledSideNavContainer>\n\n <StyledTopNavContainer ref={topNavContainerRef}>\n {\n /* If TopNav should be initially visible and we have not yet received props, render Topnav with minimal inputs */\n initialVisibleSections?.includes(\"TopNav\") &&\n topNavProps === undefined && (\n <ErrorBoundary fallback={null} onError={onError}>\n <TopNav\n leftSideComponent={optionalComponents?.topNavLeftSide}\n rightSideComponent={optionalComponents?.topNavRightSide}\n />\n </ErrorBoundary>\n )\n }\n\n {topNavProps && (\n <ErrorBoundary fallback={null} onError={onError}>\n <TopNav\n {...topNavProps}\n isScrolled={isContentScrolled}\n leftSideComponent={optionalComponents?.topNavLeftSide}\n rightSideComponent={optionalComponents?.topNavRightSide}\n />\n </ErrorBoundary>\n )}\n </StyledTopNavContainer>\n\n <StyledAppContainer\n appBackgroundColor={uiShellContext?.appBackgroundColor}\n tabIndex={0}\n ref={uiShellAppAreaRef}\n />\n </StyledShellContainer>\n );\n};\n\nconst MemoizedWideUiShellContent = memo(WideUiShellContent);\nMemoizedWideUiShellContent.displayName = \"WideUiShellContent\";\n\nexport { MemoizedWideUiShellContent as WideUiShellContent };\n"],"mappings":";;;;;;AAYA,IAAAA,OAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AACA,IAAAE,mBAAA,GAAAF,OAAA;AAEA,IAAAG,MAAA,GAAAH,OAAA;AACA,IAAAI,2BAAA,GAAAJ,OAAA;AAQA,IAAAK,OAAA,GAAAL,OAAA;AACA,IAAAM,OAAA,GAAAN,OAAA;AACA,IAAAO,eAAA,GAAAP,OAAA;AACA,IAAAQ,mCAAA,GAAAR,OAAA;AACA,IAAAS,gBAAA,GAAAT,OAAA;AAAwE,IAAAU,WAAA,GAAAV,OAAA;AAAA,SAAAD,uBAAAY,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AA7BxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAqBA,MAAMG,iBAAiB,GAAG,EAAyC;AAEnE,MAAMC,kBAAkB,GAAG,IAAAC,eAAM,EAAC,KAAK,EAAE;EACvCC,iBAAiB,EAAGC,IAAI,IACtBA,IAAI,KAAK,oBAAoB,IAAIA,IAAI,KAAK;AAC9C,CAAC,CAAC,CAEC,CAAC;EAAEC;AAAmB,CAAC,MAAM;EAC9BC,QAAQ,EAAE,aAAa;EACvBC,eAAe,EAAEF;AACnB,CAAC,CAAC,CAAC;AAEH,MAAMG,0BAA0B,GAAG,IAAAN,eAAM,EAAC,KAAK,CAAC,CAAC;EAC/CI,QAAQ,EAAE;AACZ,CAAC,CAAC;AAEF,MAAMG,sBAAsB,GAAG,IAAAP,eAAM,EAAC,KAAK,CAAC,CAAC;EAC3CI,QAAQ,EAAE;AACZ,CAAC,CAAC;AAEF,MAAMI,sBAAsB,GAAG,IAAAR,eAAM,EAAC,KAAK,CAAC,CAAC;EAC3CI,QAAQ,EAAE;AACZ,CAAC,CAAC;AAEF,MAAMK,oBAAoB,GAAG,IAAAT,eAAM,EAAC,KAAK,EAAE;EACzCC,iBAAiB,EAAGC,IAAI,IAAKA,IAAI,KAAK;AACxC,CAAC,CAAC,CAEC,CAAC;EAAEQ;AAAoB,CAAC,MAAM;EAC/BL,eAAe,EAAEK,mBAAmB,CAACC,YAAY;EACjDC,OAAO,EAAE,MAAM;EACfC,OAAO,EAAE,CAAC;EACVC,iBAAiB,EAAE;AACrB;AACA;AACA;AACA,GAAG;EACDC,mBAAmB,EAAE,eAAe;EACpCC,gBAAgB,EAAE,eAAe;EACjCC,MAAM,EAAE,OAAO;EACfC,KAAK,EAAE;AACT,CAAC,CAAC,CAAC;AAEH,MAAMC,qBAAqB,GAAG,IAAAnB,eAAM,EAAC,KAAK,CAAC,CAAC;EAC1CI,QAAQ,EAAE;AACZ,CAAC,CAAC;AAYF,MAAMgB,kBAAkB,GAAGA,CAAC;EAC1BC,UAAU;EACVC,uBAAuB;EACvBC,gBAAgB;EAChBC,4BAA4B,GAAG,IAAI;EACnCC,sBAAsB,GAAG,CAAC,QAAQ,EAAE,SAAS,EAAE,aAAa,CAAC;EAC7DC,OAAO,GAAGC,OAAO,CAACC,KAAK;EACvBC,kBAAkB;EAClBC,YAAY;EACZC;AACuB,CAAC,KAAK;EAC7B,MAAMrB,mBAAmB,GAAG,IAAAsB,kDAAsB,EAAC,CAAC;EACpD,MAAMC,cAAc,GAAG,IAAAC,kCAAiB,EAAC,CAAC;EAE1C,MAAM;IAAEC;EAAkB,CAAC,GAAG,IAAAC,8BAAc,EAACf,UAAU,CAAC;EAExD,MAAMgB,mBAAmB,GAAG,IAAAC,aAAM,EAAiB,IAAI,CAAC;EACxD,MAAMC,kBAAkB,GAAG,IAAAD,aAAM,EAAiB,IAAI,CAAC;EACvD,MAAME,iBAAiB,GAAG,IAAAF,aAAM,EAAiB,IAAI,CAAC;EAEtD,MAAM;IAAEG;EAAmB,CAAC,GAAG,IAAAC,sEAAkC,EAAC;IAChErB,UAAU;IACVC,uBAAuB;IACvBqB,WAAW,EAAEnB,4BAA4B,GAAG,aAAa,GAAG,MAAM;IAClEgB,iBAAiB;IACjBI,oBAAoB,EAAE,CACpBP,mBAAmB,EACnBE,kBAAkB,EAClBC,iBAAiB;EAErB,CAAC,CAAC;EAEF,OACE,IAAA9C,WAAA,CAAAmD,IAAA,EAACpC,oBAAoB;IACnBC,mBAAmB,EAAEA,mBAAoB;IACzCoC,GAAG,EAAEL,kBAAmB;IAAAM,QAAA,GAExB,IAAArD,WAAA,CAAAsD,GAAA,EAACzC,sBAAsB;MAAAwC,QAAA,EACpBlB,kBAAkB,EAAEoB;IAAO,CACN,CAAC,EAEzB,IAAAvD,WAAA,CAAAmD,IAAA,EAACvC,0BAA0B;MAAAyC,QAAA,GAGvBtB,sBAAsB,EAAEyB,QAAQ,CAAC,aAAa,CAAC,IAC7C,CAAC3B,gBAAgB,IACf,IAAA7B,WAAA,CAAAsD,GAAA,EAAC9D,mBAAA,CAAAiE,aAAa;QAACC,QAAQ,EAAE,IAAK;QAAC1B,OAAO,EAAEA,OAAQ;QAAAqB,QAAA,EAC9C,IAAArD,WAAA,CAAAsD,GAAA,EAAC7D,MAAA,CAAAkE,WAAW;UAACC,SAAS;UAACC,QAAQ,EAAE,EAAG;UAACC,eAAe,EAAC;QAAE,CAAE;MAAC,CAC7C,CAChB,EAGJjC,gBAAgB,IACf,IAAA7B,WAAA,CAAAsD,GAAA,EAAC9D,mBAAA,CAAAiE,aAAa;QAACC,QAAQ,EAAE,IAAK;QAAC1B,OAAO,EAAEA,OAAQ;QAAAqB,QAAA,EAC9C,IAAArD,WAAA,CAAAsD,GAAA,EAAC7D,MAAA,CAAAkE,WAAW;UAAA,GAAK9B;QAAgB,CAAG;MAAC,CACxB,CAChB;IAAA,CACyB,CAAC,EAE7B,IAAA7B,WAAA,CAAAmD,IAAA,EAACrC,sBAAsB;MAACsC,GAAG,EAAET,mBAAoB;MAAAU,QAAA,GAG7CtB,sBAAsB,EAAEyB,QAAQ,CAAC,SAAS,CAAC,IACzCpB,YAAY,KAAK2B,SAAS,IACxB,IAAA/D,WAAA,CAAAsD,GAAA,EAAC9D,mBAAA,CAAAiE,aAAa;QAACC,QAAQ,EAAE,IAAK;QAAC1B,OAAO,EAAEA,OAAQ;QAAAqB,QAAA,EAC9C,IAAArD,WAAA,CAAAsD,GAAA,EAAC3D,OAAA,CAAAqE,OAAO;UAACJ,SAAS;UAACK,YAAY,EAAE7D;QAAkB,CAAE;MAAC,CACzC,CAChB,EAGJgC,YAAY,IACX,IAAApC,WAAA,CAAAsD,GAAA,EAAC9D,mBAAA,CAAAiE,aAAa;QAACC,QAAQ,EAAE,IAAK;QAAC1B,OAAO,EAAEA,OAAQ;QAAAqB,QAAA,EAC9C,IAAArD,WAAA,CAAAsD,GAAA,EAAC3D,OAAA,CAAAqE,OAAO;UAEJ,GAAG5B,YAAY;UACf,IAAIA,YAAY,CAAC8B,eAAe,IAChC/B,kBAAkB,EAAEgC,aAAa,GAC7B;YACEC,eAAe,EAAEjC,kBAAkB,CAACgC,aAAa;YACjDE,WAAW,EAAEN,SAAS;YACtBG,eAAe,EAAE9B,YAAY,CAAC8B;UAChC,CAAC,GACD;YACEG,WAAW,EAAEjC,YAAY,CAACiC,WAAW;YACrCH,eAAe,EAAE;UACnB,CAAC;QAAC,CAET;MAAC,CACW,CAChB;IAAA,CACqB,CAAC,EAEzB,IAAAlE,WAAA,CAAAmD,IAAA,EAAC1B,qBAAqB;MAAC2B,GAAG,EAAEP,kBAAmB;MAAAQ,QAAA,GAG3CtB,sBAAsB,EAAEyB,QAAQ,CAAC,QAAQ,CAAC,IACxCnB,WAAW,KAAK0B,SAAS,IACvB,IAAA/D,WAAA,CAAAsD,GAAA,EAAC9D,mBAAA,CAAAiE,aAAa;QAACC,QAAQ,EAAE,IAAK;QAAC1B,OAAO,EAAEA,OAAQ;QAAAqB,QAAA,EAC9C,IAAArD,WAAA,CAAAsD,GAAA,EAAC1D,OAAA,CAAA0E,MAAM;UACLC,iBAAiB,EAAEpC,kBAAkB,EAAEqC,cAAe;UACtDC,kBAAkB,EAAEtC,kBAAkB,EAAEuC;QAAgB,CACzD;MAAC,CACW,CAChB,EAGJrC,WAAW,IACV,IAAArC,WAAA,CAAAsD,GAAA,EAAC9D,mBAAA,CAAAiE,aAAa;QAACC,QAAQ,EAAE,IAAK;QAAC1B,OAAO,EAAEA,OAAQ;QAAAqB,QAAA,EAC9C,IAAArD,WAAA,CAAAsD,GAAA,EAAC1D,OAAA,CAAA0E,MAAM;UAAA,GACDjC,WAAW;UACfsC,UAAU,EAAElC,iBAAkB;UAC9B8B,iBAAiB,EAAEpC,kBAAkB,EAAEqC,cAAe;UACtDC,kBAAkB,EAAEtC,kBAAkB,EAAEuC;QAAgB,CACzD;MAAC,CACW,CAChB;IAAA,CACoB,CAAC,EAExB,IAAA1E,WAAA,CAAAsD,GAAA,EAACjD,kBAAkB;MACjBI,kBAAkB,EAAE8B,cAAc,EAAE9B,kBAAmB;MACvDmE,QAAQ,EAAE,CAAE;MACZxB,GAAG,EAAEN;IAAkB,CACxB,CAAC;EAAA,CACkB,CAAC;AAE3B,CAAC;AAED,MAAM+B,0BAA0B,GAAAC,OAAA,CAAApD,kBAAA,GAAG,IAAAqD,WAAI,EAACrD,kBAAkB,CAAC;AAC3DmD,0BAA0B,CAACG,WAAW,GAAG,oBAAoB","ignoreList":[]}
@@ -24,6 +24,18 @@ Object.keys(_index).forEach(function (key) {
24
24
  }
25
25
  });
26
26
  });
27
+ var _NarrowUiShellContent = require("./NarrowUiShellContent.cjs");
28
+ Object.keys(_NarrowUiShellContent).forEach(function (key) {
29
+ if (key === "default" || key === "__esModule") return;
30
+ if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
31
+ if (key in exports && exports[key] === _NarrowUiShellContent[key]) return;
32
+ Object.defineProperty(exports, key, {
33
+ enumerable: true,
34
+ get: function () {
35
+ return _NarrowUiShellContent[key];
36
+ }
37
+ });
38
+ });
27
39
  var _renderUiShell = require("./renderUiShell.cjs");
28
40
  Object.keys(_renderUiShell).forEach(function (key) {
29
41
  if (key === "default" || key === "__esModule") return;
@@ -60,6 +72,18 @@ Object.keys(_index3).forEach(function (key) {
60
72
  }
61
73
  });
62
74
  });
75
+ var _uiShellContentTypes = require("./uiShellContentTypes.cjs");
76
+ Object.keys(_uiShellContentTypes).forEach(function (key) {
77
+ if (key === "default" || key === "__esModule") return;
78
+ if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
79
+ if (key in exports && exports[key] === _uiShellContentTypes[key]) return;
80
+ Object.defineProperty(exports, key, {
81
+ enumerable: true,
82
+ get: function () {
83
+ return _uiShellContentTypes[key];
84
+ }
85
+ });
86
+ });
63
87
  var _useHasUiShell = require("./useHasUiShell.cjs");
64
88
  Object.keys(_useHasUiShell).forEach(function (key) {
65
89
  if (key === "default" || key === "__esModule") return;
@@ -84,5 +108,17 @@ Object.keys(_renderReactInWebComponent).forEach(function (key) {
84
108
  }
85
109
  });
86
110
  });
111
+ var _WideUiShellContent = require("./WideUiShellContent.cjs");
112
+ Object.keys(_WideUiShellContent).forEach(function (key) {
113
+ if (key === "default" || key === "__esModule") return;
114
+ if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
115
+ if (key in exports && exports[key] === _WideUiShellContent[key]) return;
116
+ Object.defineProperty(exports, key, {
117
+ enumerable: true,
118
+ get: function () {
119
+ return _WideUiShellContent[key];
120
+ }
121
+ });
122
+ });
87
123
  var _UiShell = require("./UiShell.cjs");
88
124
  //# sourceMappingURL=index.cjs.map