@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
@@ -1,968 +0,0 @@
1
- /*!
2
- * Copyright (c) 2023-present, Okta, Inc. and/or its affiliates. All rights reserved.
3
- * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
4
- *
5
- * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
6
- * Unless required by applicable law or agreed to in writing, software
7
- * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
8
- * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
9
- *
10
- * See the License for the specific language governing permissions and limitations under the License.
11
- */
12
-
13
- import {
14
- ReactNode,
15
- memo,
16
- useCallback,
17
- useEffect,
18
- useMemo,
19
- useRef,
20
- useState,
21
- } from "react";
22
- import {
23
- MRT_Cell,
24
- MRT_DensityState,
25
- MRT_Row,
26
- MRT_SortingState,
27
- MRT_TableOptions,
28
- MRT_RowSelectionState,
29
- MRT_RowVirtualizer,
30
- MRT_VisibilityState,
31
- useMaterialReactTable,
32
- MRT_TableContainer,
33
- MRT_Column,
34
- MRT_ColumnDef,
35
- MRT_TableInstance,
36
- } from "material-react-table";
37
- import { useTranslation } from "react-i18next";
38
- import {
39
- ArrowDownIcon,
40
- ArrowUnsortedIcon,
41
- ChevronDownIcon,
42
- DragIndicatorIcon,
43
- MoreIcon,
44
- } from "../icons.generated/index.js";
45
- import { densityValues } from "./constants.js";
46
- import {
47
- Pagination,
48
- paginationTypeValues,
49
- usePagination,
50
- } from "../Pagination/index.js";
51
- import { DataFilter, DataFilters } from "../labs/DataFilters.js";
52
- import {
53
- DataTableRowActions,
54
- DataTableRowActionsProps,
55
- } from "./DataTableRowActions.js";
56
- import { useRowReordering } from "./useRowReordering.js";
57
- import { DataTableSettings } from "./DataTableSettings.js";
58
- import { Box } from "../Box.js";
59
- import { DataTableRowSelectionState, DataTableRowData } from "./index.js";
60
- import {
61
- DesignTokens,
62
- useOdysseyDesignTokens,
63
- } from "../OdysseyDesignTokensContext.js";
64
- import { useScrollIndication } from "./useScrollIndication.js";
65
- import styled from "@emotion/styled";
66
- import { EmptyState } from "../EmptyState.js";
67
- import { Button, MenuButton, MenuButtonProps } from "../Buttons/index.js";
68
- import { Callout } from "../Callout.js";
69
-
70
- export type DataTableColumn<T extends DataTableRowData> = MRT_ColumnDef<T> & {
71
- /**
72
- * @deprecated use hasTextWrapping instead of enableWrapping
73
- */
74
- enableWrapping?: boolean;
75
- hasTextWrapping?: boolean;
76
- };
77
-
78
- type DataTableColumnInstance<T extends DataTableRowData> = Omit<
79
- MRT_Column<T, unknown>,
80
- "columnDef"
81
- > & {
82
- columnDef: DataTableColumn<T>;
83
- };
84
-
85
- type DataTableCell<T extends DataTableRowData> = Omit<MRT_Cell<T>, "column"> & {
86
- column: DataTableColumnInstance<T>;
87
- };
88
-
89
- export type DataTableGetDataType = {
90
- page?: number;
91
- resultsPerPage?: number;
92
- search?: string;
93
- filters?: DataFilter[];
94
- sort?: MRT_SortingState;
95
- };
96
-
97
- export type DataTableOnReorderRowsType = {
98
- rowId: string;
99
- newRowIndex: number;
100
- };
101
-
102
- export type DataTableRenderDetailPanelType = {
103
- row: MRT_Row<DataTableRowData>;
104
- table: MRT_TableInstance<DataTableRowData>;
105
- };
106
-
107
- export type DataTableProps = {
108
- /**
109
- * An optional action button above the table.
110
- */
111
- additionalActionButton?: ReactNode;
112
- /**
113
- * MenuItems that go in an optional action menu above the table.
114
- */
115
- additionalActionMenuItems?: ReactNode;
116
- /**
117
- * Menu items to include in the bulk actions menu, which appears above the table if a row or rows are selected
118
- */
119
- bulkActionMenuItems?: (
120
- selectedRows: MRT_RowSelectionState,
121
- ) => MenuButtonProps["children"];
122
- /**
123
- * The columns that make up the table
124
- */
125
- columns: DataTableColumn<DataTableRowData>[];
126
- /**
127
- * The current page number.
128
- */
129
- currentPage?: number;
130
- /**
131
- * If `error` is not undefined, the DataTable will indicate an error.
132
- */
133
- errorMessage?: string;
134
- /**
135
- * The component to display when the table is displaying the initial empty state
136
- */
137
- emptyPlaceholder?: ReactNode;
138
- /**
139
- * An optional set of filters to render in the filters menu
140
- */
141
- filters?: Array<DataFilter | DataTableColumn<DataTableRowData> | string>;
142
- /**
143
- * The function to get the ID of a row
144
- */
145
- getRowId?: MRT_TableOptions<DataTableRowData>["getRowId"];
146
- /**
147
- * Callback that fires whenever the table needs to fetch new data, due to changes in
148
- * page, results per page, search input, filters, or sorting
149
- */
150
- getData: ({
151
- page,
152
- resultsPerPage,
153
- search,
154
- filters,
155
- sort,
156
- }: DataTableGetDataType) =>
157
- | MRT_TableOptions<DataTableRowData>["data"]
158
- | Promise<MRT_TableOptions<DataTableRowData>["data"]>;
159
- /**
160
- * If true, the end user can resize individual columns.
161
- */
162
- hasColumnResizing?: boolean;
163
- /**
164
- * If true, the end user will be able to show/hide columns.
165
- */
166
- hasColumnVisibility?: boolean;
167
- /**
168
- * If true, the end user will be able to filter columns.
169
- */
170
- hasFilters?: boolean;
171
- /**
172
- * If true, the table will include pagination controls.
173
- */
174
- hasPagination?: boolean;
175
- /**
176
- * If true, the end user can reorder rows via a drag-and-drop interface
177
- */
178
- hasRowReordering?: boolean;
179
- /**
180
- * If true, the table will include checkboxes on each row, enabling
181
- * the user to select some or all rows.
182
- */
183
- hasRowSelection?: boolean;
184
- /**
185
- * If true, the global table search controls will be shown.
186
- */
187
- hasSearch?: boolean;
188
- /**
189
- * If true, the search field will include a Search button, rather than
190
- * firing on input change.
191
- */
192
- hasSearchSubmitButton?: boolean;
193
- /**
194
- * If true, the end user can sort columns (ascending, descending, or neither)
195
- */
196
- hasSorting?: boolean;
197
- /**
198
- * If true, the end user will be able to change the table density.
199
- */
200
- hasChangeableDensity?: boolean;
201
- /**
202
- * The initial density (height & padding) of the table rows. This is available even if the
203
- * table density isn't changeable by the end user via hasChangeableDensity.
204
- */
205
- initialDensity?: (typeof densityValues)[number];
206
- /**
207
- * The initial search value
208
- */
209
- initialSearchValue?: string;
210
- /**
211
- * Is the next or show-more button disabled
212
- */
213
- isPaginationMoreDisabled?: boolean;
214
- /**
215
- * The component to display when the query returns no results
216
- */
217
- noResultsPlaceholder?: ReactNode;
218
- /**
219
- * The number of results per page.
220
- */
221
- resultsPerPage?: number;
222
- /**
223
- * The optional component to display when expanding a row.
224
- */
225
- renderDetailPanel?: MRT_TableOptions<DataTableRowData>["renderDetailPanel"];
226
- /**
227
- * Action buttons to display in each row
228
- */
229
- rowActionButtons?: DataTableRowActionsProps["rowActionButtons"];
230
- /**
231
- * Menu items to include in the optional actions menu on each row.
232
- */
233
- rowActionMenuItems?: DataTableRowActionsProps["rowActionMenuItems"];
234
- /**
235
- * The debounce time, in milliseconds, for the search input firing
236
- * `onChangeSearch` when changed. If `hasSearchSubmitButton` is true,
237
- * this doesn't do anything.
238
- */
239
- searchDelayTime?: number;
240
- /**
241
- * Callback that fires when a row (or rows) is selected or unselected.
242
- */
243
- onChangeRowSelection?: (rowSelection: DataTableRowSelectionState) => void;
244
- /**
245
- * Callback that fires when the user reorders rows within the table. Can be used
246
- * to propogate order change to the backend.
247
- */
248
- onReorderRows?: ({ rowId, newRowIndex }: DataTableOnReorderRowsType) => void;
249
- /**
250
- * The type of pagination controls shown. Defaults to next/prev buttons, but can be
251
- * set to a simple "Load more" button by setting to "loadMore".
252
- */
253
- paginationType?: (typeof paginationTypeValues)[number];
254
- /**
255
- * The total number of rows in the table. Optional, because it's sometimes impossible
256
- * to calculate. Used in table pagination to know when to disable the "next"/"more" button.
257
- */
258
- totalRows?: number;
259
- /**
260
- * The largest number of rows allowed to be shown per page. This only affects the row input
261
- * in pagination.
262
- */
263
- maxResultsPerPage?: number;
264
- /**
265
- * The highest page number allowed to be manually input in pagination
266
- */
267
- maxPages?: number;
268
- };
269
-
270
- const ScrollableTableContainer = styled("div", {
271
- shouldForwardProp: (prop) =>
272
- prop !== "odysseyDesignTokens" &&
273
- prop !== "isScrollableStart" &&
274
- prop !== "isScrollableEnd",
275
- })<{
276
- odysseyDesignTokens: DesignTokens;
277
- isScrollableStart: boolean;
278
- isScrollableEnd: boolean;
279
- }>(({ odysseyDesignTokens, isScrollableStart, isScrollableEnd }) => ({
280
- marginBlockEnd: odysseyDesignTokens.Spacing4,
281
- position: "relative",
282
- borderInlineStartColor: isScrollableStart
283
- ? odysseyDesignTokens.HueNeutral200
284
- : "transparent",
285
- borderInlineStartStyle: "solid",
286
- borderInlineStartWidth: odysseyDesignTokens.BorderWidthMain,
287
- "::before": {
288
- background:
289
- "linear-gradient(-90deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.33) 50%, rgba(0, 0, 0, 1) 100%)",
290
- content: '""',
291
- opacity: isScrollableStart ? "0.075" : "0",
292
- pointerEvents: "none",
293
- position: "absolute",
294
- top: 0,
295
- left: 0,
296
- bottom: 0,
297
- width: odysseyDesignTokens.Spacing6,
298
- zIndex: 100,
299
- transition: `opacity ${odysseyDesignTokens.TransitionDurationMain} ${odysseyDesignTokens.TransitionTimingMain}`,
300
- },
301
- borderInlineEndColor: isScrollableEnd
302
- ? odysseyDesignTokens.HueNeutral200
303
- : "transparent",
304
- borderInlineEndStyle: "solid",
305
- borderInlineEndWidth: odysseyDesignTokens.BorderWidthMain,
306
- "::after": {
307
- background:
308
- "linear-gradient(90deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.33) 50%, rgba(0, 0, 0, 1) 100%)",
309
- content: '""',
310
- opacity: isScrollableEnd ? "0.075" : "0",
311
- pointerEvents: "none",
312
- position: "absolute",
313
- top: 0,
314
- right: 0,
315
- bottom: 0,
316
- width: odysseyDesignTokens.Spacing6,
317
- transition: `opacity ${odysseyDesignTokens.TransitionDurationMain} ${odysseyDesignTokens.TransitionTimingMain}`,
318
- },
319
- }));
320
-
321
- const defaultGetRowId: DataTableProps["getRowId"] = (row) => row.id as string;
322
-
323
- const DataTable = ({
324
- additionalActionButton,
325
- additionalActionMenuItems,
326
- bulkActionMenuItems,
327
- columns,
328
- currentPage = 1,
329
- emptyPlaceholder,
330
- errorMessage: errorMessageProp,
331
- filters: filtersProp,
332
- getData,
333
- getRowId = defaultGetRowId,
334
- hasChangeableDensity,
335
- hasColumnResizing,
336
- hasColumnVisibility,
337
- hasFilters,
338
- hasPagination,
339
- hasRowReordering,
340
- hasRowSelection,
341
- hasSearch,
342
- hasSearchSubmitButton,
343
- hasSorting,
344
- initialDensity = densityValues[0],
345
- initialSearchValue = "",
346
- isPaginationMoreDisabled,
347
- noResultsPlaceholder,
348
- onChangeRowSelection,
349
- onReorderRows,
350
- paginationType = "paged",
351
- renderDetailPanel,
352
- resultsPerPage = 20,
353
- maxResultsPerPage,
354
- maxPages,
355
- rowActionButtons,
356
- rowActionMenuItems,
357
- searchDelayTime,
358
- totalRows,
359
- }: DataTableProps) => {
360
- const { t } = useTranslation();
361
-
362
- const [data, setData] = useState<DataTableRowData[]>([]);
363
- const [pagination, setPagination] = useState({
364
- pageIndex: currentPage,
365
- pageSize: resultsPerPage,
366
- });
367
- const [draggingRow, setDraggingRow] =
368
- useState<MRT_Row<DataTableRowData> | null>();
369
- const [isTableContainerScrolledToStart, setIsTableContainerScrolledToStart] =
370
- useState(true);
371
- const [isTableContainerScrolledToEnd, setIsTableContainerScrolledToEnd] =
372
- useState(true);
373
- const [tableInnerContainerWidth, setTableInnerContainerWidth] =
374
- useState<string>("100%");
375
- const tableOuterContainerRef = useRef<HTMLDivElement>(null);
376
- const tableInnerContainerRef = useRef<HTMLDivElement>(null);
377
- const tableContentRef = useRef<HTMLTableElement>(null);
378
-
379
- // Table states
380
- const [columnSorting, setColumnSorting] = useState<MRT_SortingState>([]);
381
- const [columnVisibility, setColumnVisibility] =
382
- useState<MRT_VisibilityState>();
383
- const [rowDensity, setRowDensity] =
384
- useState<MRT_DensityState>(initialDensity);
385
- const [rowSelection, setRowSelection] = useState<MRT_RowSelectionState>({});
386
- const [search, setSearch] = useState<string>(initialSearchValue);
387
- const [filters, setFilters] = useState<DataFilter[]>();
388
- const [initialFilters, setInitialFilters] = useState<DataFilter[]>();
389
- const [isLoading, setIsLoading] = useState<boolean | undefined>(true);
390
- const [isEmpty, setIsEmpty] = useState<boolean | undefined>();
391
- const [errorMessage, setErrorMessage] = useState<string | undefined>(
392
- errorMessageProp,
393
- );
394
-
395
- useScrollIndication({
396
- tableOuterContainer: tableOuterContainerRef.current,
397
- tableInnerContainer: tableInnerContainerRef.current,
398
- setIsTableContainerScrolledToStart: setIsTableContainerScrolledToStart,
399
- setIsTableContainerScrolledToEnd: setIsTableContainerScrolledToEnd,
400
- setTableInnerContainerWidth: setTableInnerContainerWidth,
401
- });
402
-
403
- const odysseyDesignTokens = useOdysseyDesignTokens();
404
-
405
- const {
406
- dragHandleStyles,
407
- dragHandleText,
408
- draggableTableBodyRowClassName,
409
- handleDragHandleKeyDown,
410
- handleDragHandleOnDragCapture,
411
- handleDragHandleOnDragEnd,
412
- resetDraggingAndHoveredRow,
413
- updateRowOrder,
414
- } = useRowReordering({
415
- totalRows,
416
- onReorderRows,
417
- data,
418
- setData,
419
- draggingRow,
420
- setDraggingRow,
421
- resultsPerPage: pagination.pageSize,
422
- page: pagination.pageIndex,
423
- });
424
-
425
- const rowDensityClassName = useMemo(() => {
426
- return rowDensity === "spacious"
427
- ? "MuiTableBody-spacious"
428
- : rowDensity === "compact"
429
- ? "MuiTableBody-compact"
430
- : "MuiTableBody-default";
431
- }, [rowDensity]);
432
-
433
- const renderRowActions = useCallback(
434
- ({ row }: { row: MRT_Row<DataTableRowData> }) => {
435
- const currentIndex =
436
- row.index + (pagination.pageIndex - 1) * pagination.pageSize;
437
- return (
438
- <DataTableRowActions
439
- row={row}
440
- rowIndex={currentIndex}
441
- rowActionButtons={rowActionButtons}
442
- rowActionMenuItems={rowActionMenuItems}
443
- totalRows={totalRows}
444
- updateRowOrder={
445
- hasRowReordering && onReorderRows ? updateRowOrder : undefined
446
- }
447
- />
448
- );
449
- },
450
- [
451
- pagination,
452
- rowActionButtons,
453
- rowActionMenuItems,
454
- hasRowReordering,
455
- onReorderRows,
456
- totalRows,
457
- updateRowOrder,
458
- ],
459
- );
460
-
461
- /**
462
- * This hack is to provide compatibility with Material-React-Table's
463
- * filterOptions format, which allows for strings and { label: string, value: string }
464
- */
465
- const convertFilterSelectOptions = useCallback(
466
- (options: DataTableColumn<DataTableRowData>["filterSelectOptions"]) =>
467
- options?.map((option) =>
468
- typeof option === "string"
469
- ? {
470
- label: option,
471
- value: option,
472
- }
473
- : {
474
- // If the option isn't a string, it must have value and/or option defined
475
- // If either is undefined, use the other
476
- // These shouldn't need `as`, but this is a legacy file now. --Kevin Ghadyani
477
- label: (option.label ?? option.value) as string,
478
- value: (option.value ?? option.label) as string,
479
- },
480
- ),
481
- [],
482
- );
483
-
484
- const convertColumnToFilter = useCallback(
485
- (column: DataTableColumn<DataTableRowData>) =>
486
- column.enableColumnFilter !== false && column.accessorKey
487
- ? ({
488
- id: column.accessorKey,
489
- label: column.header,
490
- variant: column.filterVariant,
491
- options: convertFilterSelectOptions(column.filterSelectOptions),
492
- } satisfies DataFilter as DataFilter)
493
- : null,
494
- [convertFilterSelectOptions],
495
- );
496
-
497
- /**
498
- * Filters default to the columns, but can be overridden
499
- * with the `filters` prop. `filters` should be an array
500
- * of column accessorKeys, column defs, or DataFilters.
501
- */
502
- const dataTableFilters = useMemo(() => {
503
- const providedFilters = filtersProp || columns;
504
- return providedFilters.reduce<DataFilter[]>((accumulator, item) => {
505
- if (typeof item === "string") {
506
- const foundColumn = columns.find(
507
- (column) => column.accessorKey === item,
508
- );
509
- if (foundColumn) {
510
- const filter = convertColumnToFilter(foundColumn);
511
- if (filter) {
512
- return accumulator.concat(filter);
513
- }
514
- }
515
- } else if ("accessorKey" in item) {
516
- // Checks if it's a column
517
- const filter = convertColumnToFilter(item);
518
- if (filter) {
519
- return accumulator.concat(filter);
520
- }
521
- } else if ("label" in item) {
522
- // Checks if it's a DataFilter
523
- return accumulator.concat(item);
524
- }
525
- // If none of the conditions match, item is ignored (not mapping to undefined)
526
- return accumulator;
527
- }, []);
528
- }, [columns, filtersProp, convertColumnToFilter]);
529
-
530
- const defaultCell = useCallback(
531
- ({ cell }: { cell: DataTableCell<DataTableRowData> }) => {
532
- const value = cell.getValue<string>();
533
- const hasTextWrapping =
534
- cell.column.columnDef.hasTextWrapping ||
535
- cell.column.columnDef.enableWrapping;
536
-
537
- return hasTextWrapping ? (
538
- value
539
- ) : (
540
- <Box
541
- sx={{
542
- whiteSpace: "nowrap",
543
- textOverflow: "ellipsis",
544
- overflow: "hidden",
545
- }}
546
- >
547
- {value}
548
- </Box>
549
- );
550
- },
551
- [],
552
- );
553
-
554
- const emptyState = useCallback(() => {
555
- const noResultsInnerContent = noResultsPlaceholder || (
556
- <EmptyState
557
- heading={t("table.noresults.heading")}
558
- description={t("table.noresults.text")}
559
- />
560
- );
561
-
562
- const emptyStateInnerContent =
563
- emptyPlaceholder && isEmpty ? emptyPlaceholder : noResultsInnerContent;
564
-
565
- return (
566
- <Box sx={{ width: tableInnerContainerWidth }}>
567
- {emptyStateInnerContent}
568
- </Box>
569
- );
570
- }, [
571
- emptyPlaceholder,
572
- isEmpty,
573
- noResultsPlaceholder,
574
- t,
575
- tableInnerContainerWidth,
576
- ]);
577
-
578
- const columnIds = useMemo(() => {
579
- return columns.map((column) => column.accessorKey);
580
- }, [columns]);
581
-
582
- const columnOrder = useMemo(
583
- () => [
584
- "mrt-row-drag",
585
- "mrt-row-select",
586
- "mrt-row-expand",
587
- ...columnIds,
588
- "mrt-row-actions",
589
- ],
590
- [columnIds],
591
- ) as string[];
592
-
593
- const shouldDisplayRowActions = useMemo(
594
- () =>
595
- (hasRowReordering === true && onReorderRows) ||
596
- rowActionButtons ||
597
- rowActionMenuItems
598
- ? true
599
- : false,
600
- [hasRowReordering, onReorderRows, rowActionButtons, rowActionMenuItems],
601
- );
602
-
603
- const dataTable = useMaterialReactTable({
604
- columns: columns,
605
- data: data,
606
- getRowId,
607
- state: {
608
- sorting: columnSorting,
609
- globalFilter: search,
610
- columnVisibility,
611
- isLoading,
612
- rowSelection,
613
- columnOrder,
614
- },
615
- icons: {
616
- ArrowDownwardIcon: ArrowDownIcon,
617
- DragHandleIcon: DragIndicatorIcon,
618
- SyncAltIcon: ArrowUnsortedIcon,
619
- ExpandMoreIcon: ChevronDownIcon,
620
- },
621
-
622
- // Base table settings
623
- enableColumnActions: false,
624
- enableColumnResizing: hasColumnResizing,
625
- enableDensityToggle: false,
626
- enableFilters: false,
627
- enableFullScreenToggle: false,
628
- enableGlobalFilter: false,
629
- enableHiding: false,
630
- enablePagination: false,
631
- layoutMode: "grid-no-grow",
632
- manualFiltering: true,
633
- manualSorting: true,
634
- muiTablePaperProps: {
635
- elevation: 0,
636
- sx: {
637
- overflow: "visible",
638
- },
639
- },
640
- selectAllMode: "all",
641
- displayColumnDefOptions: {
642
- "mrt-row-actions": {
643
- header: "",
644
- grow: true,
645
- muiTableBodyCellProps: {
646
- align: "right",
647
- sx: {
648
- overflow: "visible",
649
- width: "unset",
650
- },
651
- className: "ods-actions-cell",
652
- },
653
- muiTableHeadCellProps: {
654
- align: "right",
655
- sx: {
656
- width: "unset",
657
- },
658
- className: "ods-actions-cell",
659
- children: (
660
- <Box sx={{ display: "flex", visibility: "hidden" }}>
661
- {rowActionButtons && rowActionButtons({ id: null })}
662
- {((hasRowReordering && onReorderRows) || rowActionMenuItems) && (
663
- <Box>
664
- <Button
665
- endIcon={<MoreIcon />}
666
- size="small"
667
- variant="floating"
668
- ariaLabel={t("table.moreactions.arialabel")}
669
- isDisabled
670
- />
671
- </Box>
672
- )}
673
- </Box>
674
- ),
675
- },
676
- },
677
- "mrt-row-drag": {
678
- header: "",
679
- muiTableBodyCellProps: {
680
- sx: {
681
- minWidth: 0,
682
- width: "auto",
683
- },
684
- className: "ods-drag-handle",
685
- },
686
- muiTableHeadCellProps: {
687
- sx: {
688
- minWidth: 0,
689
- width: "auto",
690
- },
691
- children: (
692
- // Add a spacer to simulate the width of the drag handle in the column.
693
- // Without this, the head cells are offset from their body cell counterparts
694
- <Box sx={{ marginInline: "-0.1rem" }}>
695
- <DragIndicatorIcon sx={{ marginInline: 1, opacity: 0 }} />
696
- </Box>
697
- ),
698
- },
699
- },
700
- "mrt-row-select": {
701
- muiTableHeadCellProps: {
702
- padding: "checkbox",
703
- },
704
- muiTableBodyCellProps: {
705
- padding: "checkbox",
706
- },
707
- },
708
- "mrt-row-expand": {
709
- header: "",
710
- },
711
- },
712
- muiTableBodyProps: () => ({
713
- className: rowDensityClassName,
714
- }),
715
- defaultColumn: {
716
- Cell: defaultCell,
717
- },
718
- muiTableBodyCellProps: ({ column }) => ({
719
- className: column.getIsResizing() ? "isResizing" : "",
720
- }),
721
-
722
- // Reordering
723
- enableRowOrdering: hasRowReordering && Boolean(onReorderRows),
724
- enableRowDragging: hasRowReordering && Boolean(onReorderRows),
725
- muiTableBodyRowProps: ({ table, row }) => ({
726
- className: draggableTableBodyRowClassName({
727
- currentRowId: row.id,
728
- draggingRowId: draggingRow?.id,
729
- hoveredRowId: table.getState().hoveredRow?.id,
730
- }),
731
- }),
732
- muiRowDragHandleProps: ({ table, row }) => ({
733
- onKeyDown: (event) => handleDragHandleKeyDown({ table, row, event }),
734
- onBlur: () => resetDraggingAndHoveredRow(table),
735
- onDragEnd: () => handleDragHandleOnDragEnd(table),
736
- onDragCapture: () => handleDragHandleOnDragCapture(table),
737
- sx: dragHandleStyles,
738
- ...dragHandleText,
739
- }),
740
-
741
- // Row actions
742
- enableRowActions: shouldDisplayRowActions,
743
- positionActionsColumn:
744
- "last" as MRT_TableOptions<DataTableRowData>["positionActionsColumn"],
745
- renderRowActions: ({ row }) => renderRowActions({ row }),
746
-
747
- // Row selection
748
- enableRowSelection: hasRowSelection,
749
- onRowSelectionChange: setRowSelection,
750
-
751
- // Sorting
752
- enableSorting: hasSorting,
753
- onSortingChange: setColumnSorting,
754
- muiTableHeadCellProps: ({ column: currentColumn }) => ({
755
- className: columnSorting.find(
756
- (sortedColumn) => sortedColumn.id === currentColumn.id,
757
- )
758
- ? "isSorted"
759
- : "isUnsorted",
760
- }),
761
-
762
- // Virtualization
763
- enableRowVirtualization:
764
- paginationType !== "loadMore" && pagination.pageSize > 50,
765
- rowVirtualizerInstanceRef:
766
- useRef<MRT_RowVirtualizer<HTMLDivElement, HTMLTableRowElement>>(null),
767
- rowVirtualizerOptions: {
768
- overscan: 4,
769
- },
770
-
771
- // States
772
- renderEmptyRowsFallback: emptyState,
773
-
774
- // Refs
775
- muiTableProps: {
776
- ref: tableContentRef,
777
- className:
778
- !shouldDisplayRowActions && hasColumnResizing
779
- ? "ods-hide-spacer-column"
780
- : "",
781
- },
782
-
783
- muiTableContainerProps: {
784
- ref: tableInnerContainerRef,
785
- },
786
-
787
- // Row expansion
788
- enableExpandAll: false,
789
- renderDetailPanel: renderDetailPanel,
790
- });
791
-
792
- // Effects
793
- const bulkActionMenuButton = useMemo(
794
- () => (
795
- <>
796
- <MenuButton
797
- buttonVariant="secondary"
798
- endIcon={<MoreIcon />}
799
- isDisabled={Object.keys(rowSelection).length === 0}
800
- ariaLabel="More actions"
801
- >
802
- {bulkActionMenuItems?.(rowSelection)}
803
- </MenuButton>
804
- </>
805
- ),
806
- [bulkActionMenuItems, rowSelection],
807
- );
808
-
809
- useEffect(() => {
810
- (async () => {
811
- setIsLoading(true);
812
- setErrorMessage(errorMessageProp);
813
- try {
814
- const incomingData = await getData?.({
815
- page: pagination.pageIndex,
816
- resultsPerPage: pagination.pageSize,
817
- search,
818
- filters,
819
- sort: columnSorting,
820
- });
821
- setData(incomingData);
822
- } catch (error) {
823
- setErrorMessage(typeof error === "string" ? error : t("table.error"));
824
- } finally {
825
- setIsLoading(false);
826
- }
827
- })();
828
- }, [
829
- columnSorting,
830
- errorMessageProp,
831
- filters,
832
- getData,
833
- pagination,
834
- search,
835
- t,
836
- ]);
837
-
838
- useEffect(() => {
839
- if (!initialFilters && filters) {
840
- setInitialFilters(filters);
841
- }
842
-
843
- setIsEmpty(
844
- pagination.pageIndex === currentPage &&
845
- pagination.pageSize === resultsPerPage &&
846
- search === "" &&
847
- filters === initialFilters &&
848
- data.length === 0,
849
- );
850
- }, [
851
- filters,
852
- pagination,
853
- search,
854
- data,
855
- currentPage,
856
- initialFilters,
857
- resultsPerPage,
858
- ]);
859
-
860
- useEffect(() => {
861
- setPagination((prev) => ({
862
- pageIndex: 1,
863
- pageSize: prev.pageSize,
864
- }));
865
- }, [filters, search]);
866
-
867
- useEffect(() => {
868
- onChangeRowSelection?.(rowSelection);
869
- }, [rowSelection, onChangeRowSelection]);
870
-
871
- const { lastRow } = usePagination({
872
- currentRowsCount: data.length,
873
- pageIndex: pagination.pageIndex,
874
- pageSize: pagination.pageSize,
875
- totalRows,
876
- });
877
-
878
- // Render the table
879
- return (
880
- <>
881
- {(hasSearch ||
882
- hasFilters ||
883
- hasChangeableDensity ||
884
- hasColumnVisibility ||
885
- bulkActionMenuItems ||
886
- additionalActionButton ||
887
- additionalActionMenuItems) && (
888
- <Box sx={{ marginBottom: 5 }}>
889
- <DataFilters
890
- onChangeSearch={hasSearch ? setSearch : undefined}
891
- onChangeFilters={hasFilters ? setFilters : undefined}
892
- hasSearchSubmitButton={hasSearchSubmitButton}
893
- searchDelayTime={searchDelayTime}
894
- filters={hasFilters ? dataTableFilters : undefined}
895
- defaultSearchTerm={initialSearchValue}
896
- isDisabled={isEmpty}
897
- additionalActions={
898
- <>
899
- <DataTableSettings
900
- hasChangeableDensity={hasChangeableDensity}
901
- rowDensity={rowDensity}
902
- setRowDensity={setRowDensity}
903
- hasColumnVisibility={hasColumnVisibility}
904
- columns={columns}
905
- columnVisibility={columnVisibility}
906
- setColumnVisibility={setColumnVisibility}
907
- />
908
- {bulkActionMenuItems && bulkActionMenuButton}
909
- {additionalActionButton}
910
- {additionalActionMenuItems && (
911
- <MenuButton
912
- endIcon={<MoreIcon />}
913
- ariaLabel={t("table.moreactions.arialabel")}
914
- buttonVariant="secondary"
915
- menuAlignment="right"
916
- >
917
- {additionalActionMenuItems}
918
- </MenuButton>
919
- )}
920
- </>
921
- }
922
- />
923
- </Box>
924
- )}
925
-
926
- {errorMessage && (
927
- <Box sx={{ marginBlockEnd: 2 }}>
928
- <Callout severity="error" text={errorMessage} />
929
- </Box>
930
- )}
931
-
932
- <ScrollableTableContainer
933
- odysseyDesignTokens={odysseyDesignTokens}
934
- isScrollableStart={!isTableContainerScrolledToStart}
935
- isScrollableEnd={!isTableContainerScrolledToEnd}
936
- ref={tableOuterContainerRef}
937
- >
938
- <MRT_TableContainer table={dataTable} />
939
- </ScrollableTableContainer>
940
-
941
- {hasPagination && (
942
- <Pagination
943
- pageIndex={pagination.pageIndex}
944
- pageSize={pagination.pageSize}
945
- maxPageIndex={maxPages}
946
- maxPageSize={maxResultsPerPage}
947
- onPaginationChange={setPagination}
948
- lastRow={lastRow}
949
- totalRows={totalRows}
950
- currentRowsCount={data.length}
951
- isDisabled={isEmpty}
952
- isMoreDisabled={isPaginationMoreDisabled}
953
- variant={paginationType}
954
- rowsPerPageLabel={t("pagination.rowsperpage")}
955
- currentPageLabel={t("pagination.page")}
956
- previousLabel={t("pagination.previous")}
957
- nextLabel={t("pagination.next")}
958
- loadMoreLabel={t("pagination.loadmore")}
959
- />
960
- )}
961
- </>
962
- );
963
- };
964
-
965
- const MemoizedDataTable = memo(DataTable);
966
- MemoizedDataTable.displayName = "DataTable";
967
-
968
- export { MemoizedDataTable as DataTable };