@okta/odyssey-react-mui 1.21.2 → 1.23.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 (593) hide show
  1. package/CHANGELOG.md +34 -0
  2. package/dist/@types/i18next.d.js.map +1 -1
  3. package/dist/Autocomplete.js +106 -38
  4. package/dist/Autocomplete.js.map +1 -1
  5. package/dist/Callout.js +12 -24
  6. package/dist/Callout.js.map +1 -1
  7. package/dist/Checkbox.js +26 -11
  8. package/dist/Checkbox.js.map +1 -1
  9. package/dist/CheckboxGroup.js +14 -3
  10. package/dist/CheckboxGroup.js.map +1 -1
  11. package/dist/DataTable/DataTable.js +10 -2
  12. package/dist/DataTable/DataTable.js.map +1 -1
  13. package/dist/DataTable/useScrollIndication.js +9 -5
  14. package/dist/DataTable/useScrollIndication.js.map +1 -1
  15. package/dist/Field.js +3 -1
  16. package/dist/Field.js.map +1 -1
  17. package/dist/FileUploader/FileUploadIllustration.js.map +1 -0
  18. package/dist/FileUploader/FileUploadPreview.js.map +1 -0
  19. package/dist/{labs/FileUpload.js → FileUploader/FileUploader.js} +6 -5
  20. package/dist/FileUploader/FileUploader.js.map +1 -0
  21. package/dist/FileUploader/index.js +13 -0
  22. package/dist/FileUploader/index.js.map +1 -0
  23. package/dist/OdysseyCacheProvider.js +4 -3
  24. package/dist/OdysseyCacheProvider.js.map +1 -1
  25. package/dist/OdysseyProvider.js +10 -3
  26. package/dist/OdysseyProvider.js.map +1 -1
  27. package/dist/OdysseyThemeProvider.js +3 -2
  28. package/dist/OdysseyThemeProvider.js.map +1 -1
  29. package/dist/Radio.js +33 -6
  30. package/dist/Radio.js.map +1 -1
  31. package/dist/RadioGroup.js +17 -5
  32. package/dist/RadioGroup.js.map +1 -1
  33. package/dist/Select.js +89 -31
  34. package/dist/Select.js.map +1 -1
  35. package/dist/{labs/Switch.js → Switch.js} +77 -23
  36. package/dist/Switch.js.map +1 -0
  37. package/dist/Tabs.js +7 -9
  38. package/dist/Tabs.js.map +1 -1
  39. package/dist/Tag.js +102 -4
  40. package/dist/Tag.js.map +1 -1
  41. package/dist/TextField.js +16 -39
  42. package/dist/TextField.js.map +1 -1
  43. package/dist/Toast.js +2 -2
  44. package/dist/Toast.js.map +1 -1
  45. package/dist/ToastStack.js.map +1 -1
  46. package/dist/createShadowDomElements.js +43 -0
  47. package/dist/createShadowDomElements.js.map +1 -0
  48. package/dist/i18n.js +1 -1
  49. package/dist/i18n.js.map +1 -1
  50. package/dist/index.js +3 -2
  51. package/dist/index.js.map +1 -1
  52. package/dist/index.scss +96 -8
  53. package/dist/labs/AppTile.js +124 -0
  54. package/dist/labs/AppTile.js.map +1 -0
  55. package/dist/labs/DataView/BulkActionsMenu.js.map +1 -0
  56. package/dist/labs/{DataComponents/StackContent.js → DataView/CardLayoutContent.js} +14 -14
  57. package/dist/labs/DataView/CardLayoutContent.js.map +1 -0
  58. package/dist/labs/{DataComponents/StackCard.js → DataView/DataCard.js} +6 -6
  59. package/dist/labs/DataView/DataCard.js.map +1 -0
  60. package/dist/labs/{DataComponents → DataView}/DataTable.js +6 -2
  61. package/dist/labs/DataView/DataTable.js.map +1 -0
  62. package/dist/labs/{DataComponents → DataView}/DataView.js +79 -30
  63. package/dist/labs/DataView/DataView.js.map +1 -0
  64. package/dist/labs/DataView/DetailPanel.js.map +1 -0
  65. package/dist/labs/DataView/LayoutSwitcher.js.map +1 -0
  66. package/dist/labs/DataView/RowActions.js.map +1 -0
  67. package/dist/labs/{DataComponents/TableContent.js → DataView/TableLayoutContent.js} +34 -20
  68. package/dist/labs/DataView/TableLayoutContent.js.map +1 -0
  69. package/dist/labs/{DataComponents → DataView}/TableSettings.js +2 -2
  70. package/dist/labs/DataView/TableSettings.js.map +1 -0
  71. package/dist/labs/DataView/componentTypes.js.map +1 -0
  72. package/dist/labs/{DataComponents → DataView}/constants.js +2 -2
  73. package/dist/labs/DataView/constants.js.map +1 -0
  74. package/dist/labs/DataView/dataTypes.js.map +1 -0
  75. package/dist/labs/DataView/fetchData.js.map +1 -0
  76. package/dist/labs/{DataComponents → DataView}/index.js +0 -1
  77. package/dist/labs/DataView/index.js.map +1 -0
  78. package/dist/labs/DataView/tableConstants.js.map +1 -0
  79. package/dist/labs/DataView/useFilterConversion.js.map +1 -0
  80. package/dist/labs/DateField.js +2 -0
  81. package/dist/labs/DateField.js.map +1 -1
  82. package/dist/labs/DatePicker.js +5 -1
  83. package/dist/labs/DatePicker.js.map +1 -1
  84. package/dist/labs/SideNav/CollapseIcon.js +44 -0
  85. package/dist/labs/SideNav/CollapseIcon.js.map +1 -0
  86. package/dist/labs/SideNav/OktaLogo.js +36 -0
  87. package/dist/labs/SideNav/OktaLogo.js.map +1 -0
  88. package/dist/labs/SideNav/SideNav.js +335 -0
  89. package/dist/labs/SideNav/SideNav.js.map +1 -0
  90. package/dist/labs/SideNav/SideNavFooterContent.js +49 -0
  91. package/dist/labs/SideNav/SideNavFooterContent.js.map +1 -0
  92. package/dist/labs/SideNav/SideNavHeader.js +81 -0
  93. package/dist/labs/SideNav/SideNavHeader.js.map +1 -0
  94. package/dist/labs/SideNav/SideNavItemContent.js +157 -0
  95. package/dist/labs/SideNav/SideNavItemContent.js.map +1 -0
  96. package/dist/labs/SideNav/SideNavItemLinkContent.js +71 -0
  97. package/dist/labs/SideNav/SideNavItemLinkContent.js.map +1 -0
  98. package/dist/labs/SideNav/index.js +14 -0
  99. package/dist/labs/SideNav/index.js.map +1 -0
  100. package/dist/labs/SideNav/types.js +2 -0
  101. package/dist/labs/SideNav/types.js.map +1 -0
  102. package/dist/labs/TopNav.js +2 -1
  103. package/dist/labs/TopNav.js.map +1 -1
  104. package/dist/labs/index.js +3 -4
  105. package/dist/labs/index.js.map +1 -1
  106. package/dist/labs/useDateFieldsTranslations.js +1 -1
  107. package/dist/labs/useDateFieldsTranslations.js.map +1 -1
  108. package/dist/properties/ts/odyssey-react-mui.js +3 -1
  109. package/dist/properties/ts/odyssey-react-mui.js.map +1 -1
  110. package/dist/properties/ts/odyssey-react-mui_cs.js +17 -3
  111. package/dist/properties/ts/odyssey-react-mui_cs.js.map +1 -1
  112. package/dist/properties/ts/odyssey-react-mui_da.js +17 -3
  113. package/dist/properties/ts/odyssey-react-mui_da.js.map +1 -1
  114. package/dist/properties/ts/odyssey-react-mui_de.js +16 -2
  115. package/dist/properties/ts/odyssey-react-mui_de.js.map +1 -1
  116. package/dist/properties/ts/odyssey-react-mui_el.js +18 -4
  117. package/dist/properties/ts/odyssey-react-mui_el.js.map +1 -1
  118. package/dist/properties/ts/odyssey-react-mui_es.js +17 -3
  119. package/dist/properties/ts/odyssey-react-mui_es.js.map +1 -1
  120. package/dist/properties/ts/odyssey-react-mui_fi.js +17 -3
  121. package/dist/properties/ts/odyssey-react-mui_fi.js.map +1 -1
  122. package/dist/properties/ts/odyssey-react-mui_fr.js +17 -3
  123. package/dist/properties/ts/odyssey-react-mui_fr.js.map +1 -1
  124. package/dist/properties/ts/odyssey-react-mui_ht.js +18 -4
  125. package/dist/properties/ts/odyssey-react-mui_ht.js.map +1 -1
  126. package/dist/properties/ts/odyssey-react-mui_hu.js +17 -3
  127. package/dist/properties/ts/odyssey-react-mui_hu.js.map +1 -1
  128. package/dist/properties/ts/odyssey-react-mui_id.js +17 -3
  129. package/dist/properties/ts/odyssey-react-mui_id.js.map +1 -1
  130. package/dist/properties/ts/odyssey-react-mui_it.js +17 -3
  131. package/dist/properties/ts/odyssey-react-mui_it.js.map +1 -1
  132. package/dist/properties/ts/odyssey-react-mui_ja.js +16 -2
  133. package/dist/properties/ts/odyssey-react-mui_ja.js.map +1 -1
  134. package/dist/properties/ts/odyssey-react-mui_ko.js +16 -2
  135. package/dist/properties/ts/odyssey-react-mui_ko.js.map +1 -1
  136. package/dist/properties/ts/odyssey-react-mui_ms.js +17 -3
  137. package/dist/properties/ts/odyssey-react-mui_ms.js.map +1 -1
  138. package/dist/properties/ts/odyssey-react-mui_nb.js +17 -3
  139. package/dist/properties/ts/odyssey-react-mui_nb.js.map +1 -1
  140. package/dist/properties/ts/odyssey-react-mui_nl_NL.js +17 -3
  141. package/dist/properties/ts/odyssey-react-mui_nl_NL.js.map +1 -1
  142. package/dist/properties/ts/odyssey-react-mui_pl.js +17 -3
  143. package/dist/properties/ts/odyssey-react-mui_pl.js.map +1 -1
  144. package/dist/properties/ts/odyssey-react-mui_pt_BR.js +17 -3
  145. package/dist/properties/ts/odyssey-react-mui_pt_BR.js.map +1 -1
  146. package/dist/properties/ts/odyssey-react-mui_ro.js +17 -3
  147. package/dist/properties/ts/odyssey-react-mui_ro.js.map +1 -1
  148. package/dist/properties/ts/odyssey-react-mui_ru.js +17 -3
  149. package/dist/properties/ts/odyssey-react-mui_ru.js.map +1 -1
  150. package/dist/properties/ts/odyssey-react-mui_sv.js +17 -3
  151. package/dist/properties/ts/odyssey-react-mui_sv.js.map +1 -1
  152. package/dist/properties/ts/odyssey-react-mui_th.js +16 -2
  153. package/dist/properties/ts/odyssey-react-mui_th.js.map +1 -1
  154. package/dist/properties/ts/odyssey-react-mui_tr.js +17 -3
  155. package/dist/properties/ts/odyssey-react-mui_tr.js.map +1 -1
  156. package/dist/properties/ts/odyssey-react-mui_uk.js +17 -3
  157. package/dist/properties/ts/odyssey-react-mui_uk.js.map +1 -1
  158. package/dist/properties/ts/odyssey-react-mui_vi.js +17 -3
  159. package/dist/properties/ts/odyssey-react-mui_vi.js.map +1 -1
  160. package/dist/properties/ts/odyssey-react-mui_zh_CN.js +16 -2
  161. package/dist/properties/ts/odyssey-react-mui_zh_CN.js.map +1 -1
  162. package/dist/properties/ts/odyssey-react-mui_zh_TW.js +16 -2
  163. package/dist/properties/ts/odyssey-react-mui_zh_TW.js.map +1 -1
  164. package/dist/src/Autocomplete.d.ts +30 -0
  165. package/dist/src/Autocomplete.d.ts.map +1 -1
  166. package/dist/src/Callout.d.ts +11 -23
  167. package/dist/src/Callout.d.ts.map +1 -1
  168. package/dist/src/Checkbox.d.ts +2 -2
  169. package/dist/src/Checkbox.d.ts.map +1 -1
  170. package/dist/src/CheckboxGroup.d.ts +3 -3
  171. package/dist/src/CheckboxGroup.d.ts.map +1 -1
  172. package/dist/src/DataTable/DataTable.d.ts +9 -1
  173. package/dist/src/DataTable/DataTable.d.ts.map +1 -1
  174. package/dist/src/DataTable/useScrollIndication.d.ts.map +1 -1
  175. package/dist/src/Field.d.ts +3 -2
  176. package/dist/src/Field.d.ts.map +1 -1
  177. package/dist/src/FileUploader/FileUploadIllustration.d.ts.map +1 -0
  178. package/dist/src/{labs → FileUploader}/FileUploadPreview.d.ts +2 -2
  179. package/dist/src/FileUploader/FileUploadPreview.d.ts.map +1 -0
  180. package/dist/src/{labs/FileUpload.d.ts → FileUploader/FileUploader.d.ts} +5 -4
  181. package/dist/src/FileUploader/FileUploader.d.ts.map +1 -0
  182. package/dist/src/FileUploader/index.d.ts +13 -0
  183. package/dist/src/FileUploader/index.d.ts.map +1 -0
  184. package/dist/src/NativeSelect.d.ts +1 -1
  185. package/dist/src/OdysseyCacheProvider.d.ts +7 -3
  186. package/dist/src/OdysseyCacheProvider.d.ts.map +1 -1
  187. package/dist/src/OdysseyProvider.d.ts +1 -1
  188. package/dist/src/OdysseyProvider.d.ts.map +1 -1
  189. package/dist/src/OdysseyThemeProvider.d.ts +3 -1
  190. package/dist/src/OdysseyThemeProvider.d.ts.map +1 -1
  191. package/dist/src/OdysseyTranslationProvider.d.ts +1 -1
  192. package/dist/src/OdysseyTranslationProvider.d.ts.map +1 -1
  193. package/dist/src/PasswordField.d.ts +1 -1
  194. package/dist/src/Radio.d.ts +6 -8
  195. package/dist/src/Radio.d.ts.map +1 -1
  196. package/dist/src/RadioGroup.d.ts +4 -5
  197. package/dist/src/RadioGroup.d.ts.map +1 -1
  198. package/dist/src/SearchField.d.ts +1 -1
  199. package/dist/src/Select.d.ts +38 -2
  200. package/dist/src/Select.d.ts.map +1 -1
  201. package/dist/src/{labs/Switch.d.ts → Switch.d.ts} +8 -4
  202. package/dist/src/Switch.d.ts.map +1 -0
  203. package/dist/src/Tabs.d.ts +6 -8
  204. package/dist/src/Tabs.d.ts.map +1 -1
  205. package/dist/src/Tag.d.ts +7 -1
  206. package/dist/src/Tag.d.ts.map +1 -1
  207. package/dist/src/TextField.d.ts +17 -40
  208. package/dist/src/TextField.d.ts.map +1 -1
  209. package/dist/src/ToastStack.d.ts +2 -2
  210. package/dist/src/ToastStack.d.ts.map +1 -1
  211. package/dist/src/{createShadowRootElement.d.ts → createShadowDomElements.d.ts} +6 -1
  212. package/dist/src/createShadowDomElements.d.ts.map +1 -0
  213. package/dist/src/i18n.d.ts +2 -2
  214. package/dist/src/i18n.d.ts.map +1 -1
  215. package/dist/src/index.d.ts +3 -2
  216. package/dist/src/index.d.ts.map +1 -1
  217. package/dist/src/labs/AppTile.d.ts +39 -0
  218. package/dist/src/labs/AppTile.d.ts.map +1 -0
  219. package/dist/src/labs/DataView/BulkActionsMenu.d.ts.map +1 -0
  220. package/dist/src/labs/{DataComponents/StackContent.d.ts → DataView/CardLayoutContent.d.ts} +7 -7
  221. package/dist/src/labs/DataView/CardLayoutContent.d.ts.map +1 -0
  222. package/dist/src/labs/{DataComponents/StackCard.d.ts → DataView/DataCard.d.ts} +4 -4
  223. package/dist/src/labs/DataView/DataCard.d.ts.map +1 -0
  224. package/dist/src/labs/DataView/DataTable.d.ts +16 -0
  225. package/dist/src/labs/DataView/DataTable.d.ts.map +1 -0
  226. package/dist/src/labs/{DataComponents → DataView}/DataView.d.ts +1 -1
  227. package/dist/src/labs/DataView/DataView.d.ts.map +1 -0
  228. package/dist/src/labs/{DataComponents → DataView}/DetailPanel.d.ts +2 -2
  229. package/dist/src/labs/DataView/DetailPanel.d.ts.map +1 -0
  230. package/dist/src/labs/DataView/LayoutSwitcher.d.ts.map +1 -0
  231. package/dist/src/labs/DataView/RowActions.d.ts.map +1 -0
  232. package/dist/src/labs/{DataComponents/TableContent.d.ts → DataView/TableLayoutContent.d.ts} +8 -7
  233. package/dist/src/labs/DataView/TableLayoutContent.d.ts.map +1 -0
  234. package/dist/src/labs/{DataComponents → DataView}/TableSettings.d.ts +3 -3
  235. package/dist/src/labs/DataView/TableSettings.d.ts.map +1 -0
  236. package/dist/src/labs/{DataComponents → DataView}/componentTypes.d.ts +21 -9
  237. package/dist/src/labs/DataView/componentTypes.d.ts.map +1 -0
  238. package/dist/src/labs/{DataComponents → DataView}/constants.d.ts +1 -1
  239. package/dist/src/labs/DataView/constants.d.ts.map +1 -0
  240. package/dist/src/labs/DataView/dataTypes.d.ts.map +1 -0
  241. package/dist/src/labs/DataView/fetchData.d.ts.map +1 -0
  242. package/dist/src/labs/{DataComponents → DataView}/index.d.ts +0 -1
  243. package/dist/src/labs/DataView/index.d.ts.map +1 -0
  244. package/dist/src/labs/DataView/tableConstants.d.ts.map +1 -0
  245. package/dist/src/labs/{DataComponents → DataView}/useFilterConversion.d.ts +2 -2
  246. package/dist/src/labs/DataView/useFilterConversion.d.ts.map +1 -0
  247. package/dist/src/labs/DateField.d.ts +2 -2
  248. package/dist/src/labs/DateField.d.ts.map +1 -1
  249. package/dist/src/labs/DatePicker.d.ts +2 -2
  250. package/dist/src/labs/DatePicker.d.ts.map +1 -1
  251. package/dist/src/labs/SideNav/CollapseIcon.d.ts +17 -0
  252. package/dist/src/labs/SideNav/CollapseIcon.d.ts.map +1 -0
  253. package/dist/src/labs/SideNav/OktaLogo.d.ts +14 -0
  254. package/dist/src/labs/SideNav/OktaLogo.d.ts.map +1 -0
  255. package/dist/src/labs/SideNav/SideNav.d.ts +16 -0
  256. package/dist/src/labs/SideNav/SideNav.d.ts.map +1 -0
  257. package/dist/{test-selectors/odysseyTestSelectors.js → src/labs/SideNav/SideNavFooterContent.d.ts} +6 -9
  258. package/dist/src/labs/SideNav/SideNavFooterContent.d.ts.map +1 -0
  259. package/dist/src/labs/SideNav/SideNavHeader.d.ts +16 -0
  260. package/dist/src/labs/SideNav/SideNavHeader.d.ts.map +1 -0
  261. package/dist/src/labs/SideNav/SideNavItemContent.d.ts +33 -0
  262. package/dist/src/labs/SideNav/SideNavItemContent.d.ts.map +1 -0
  263. package/dist/src/labs/SideNav/SideNavItemLinkContent.d.ts +16 -0
  264. package/dist/src/labs/SideNav/SideNavItemLinkContent.d.ts.map +1 -0
  265. package/dist/src/labs/SideNav/index.d.ts +14 -0
  266. package/dist/src/labs/SideNav/index.d.ts.map +1 -0
  267. package/dist/src/labs/{SideNav.d.ts → SideNav/types.d.ts} +54 -33
  268. package/dist/src/labs/SideNav/types.d.ts.map +1 -0
  269. package/dist/src/labs/TopNav.d.ts +1 -0
  270. package/dist/src/labs/TopNav.d.ts.map +1 -1
  271. package/dist/src/labs/index.d.ts +2 -3
  272. package/dist/src/labs/index.d.ts.map +1 -1
  273. package/dist/src/properties/ts/odyssey-react-mui.d.ts +2 -0
  274. package/dist/src/properties/ts/odyssey-react-mui.d.ts.map +1 -1
  275. package/dist/src/properties/ts/odyssey-react-mui_cs.d.ts +15 -1
  276. package/dist/src/properties/ts/odyssey-react-mui_cs.d.ts.map +1 -1
  277. package/dist/src/properties/ts/odyssey-react-mui_da.d.ts +15 -1
  278. package/dist/src/properties/ts/odyssey-react-mui_da.d.ts.map +1 -1
  279. package/dist/src/properties/ts/odyssey-react-mui_de.d.ts +15 -1
  280. package/dist/src/properties/ts/odyssey-react-mui_de.d.ts.map +1 -1
  281. package/dist/src/properties/ts/odyssey-react-mui_el.d.ts +15 -1
  282. package/dist/src/properties/ts/odyssey-react-mui_el.d.ts.map +1 -1
  283. package/dist/src/properties/ts/odyssey-react-mui_es.d.ts +15 -1
  284. package/dist/src/properties/ts/odyssey-react-mui_es.d.ts.map +1 -1
  285. package/dist/src/properties/ts/odyssey-react-mui_fi.d.ts +15 -1
  286. package/dist/src/properties/ts/odyssey-react-mui_fi.d.ts.map +1 -1
  287. package/dist/src/properties/ts/odyssey-react-mui_fr.d.ts +15 -1
  288. package/dist/src/properties/ts/odyssey-react-mui_fr.d.ts.map +1 -1
  289. package/dist/src/properties/ts/odyssey-react-mui_ht.d.ts +16 -2
  290. package/dist/src/properties/ts/odyssey-react-mui_ht.d.ts.map +1 -1
  291. package/dist/src/properties/ts/odyssey-react-mui_hu.d.ts +15 -1
  292. package/dist/src/properties/ts/odyssey-react-mui_hu.d.ts.map +1 -1
  293. package/dist/src/properties/ts/odyssey-react-mui_id.d.ts +15 -1
  294. package/dist/src/properties/ts/odyssey-react-mui_id.d.ts.map +1 -1
  295. package/dist/src/properties/ts/odyssey-react-mui_it.d.ts +15 -1
  296. package/dist/src/properties/ts/odyssey-react-mui_it.d.ts.map +1 -1
  297. package/dist/src/properties/ts/odyssey-react-mui_ja.d.ts +15 -1
  298. package/dist/src/properties/ts/odyssey-react-mui_ja.d.ts.map +1 -1
  299. package/dist/src/properties/ts/odyssey-react-mui_ko.d.ts +15 -1
  300. package/dist/src/properties/ts/odyssey-react-mui_ko.d.ts.map +1 -1
  301. package/dist/src/properties/ts/odyssey-react-mui_ms.d.ts +15 -1
  302. package/dist/src/properties/ts/odyssey-react-mui_ms.d.ts.map +1 -1
  303. package/dist/src/properties/ts/odyssey-react-mui_nb.d.ts +15 -1
  304. package/dist/src/properties/ts/odyssey-react-mui_nb.d.ts.map +1 -1
  305. package/dist/src/properties/ts/odyssey-react-mui_nl_NL.d.ts +15 -1
  306. package/dist/src/properties/ts/odyssey-react-mui_nl_NL.d.ts.map +1 -1
  307. package/dist/src/properties/ts/odyssey-react-mui_pl.d.ts +15 -1
  308. package/dist/src/properties/ts/odyssey-react-mui_pl.d.ts.map +1 -1
  309. package/dist/src/properties/ts/odyssey-react-mui_pt_BR.d.ts +15 -1
  310. package/dist/src/properties/ts/odyssey-react-mui_pt_BR.d.ts.map +1 -1
  311. package/dist/src/properties/ts/odyssey-react-mui_ro.d.ts +15 -1
  312. package/dist/src/properties/ts/odyssey-react-mui_ro.d.ts.map +1 -1
  313. package/dist/src/properties/ts/odyssey-react-mui_ru.d.ts +15 -1
  314. package/dist/src/properties/ts/odyssey-react-mui_ru.d.ts.map +1 -1
  315. package/dist/src/properties/ts/odyssey-react-mui_sv.d.ts +15 -1
  316. package/dist/src/properties/ts/odyssey-react-mui_sv.d.ts.map +1 -1
  317. package/dist/src/properties/ts/odyssey-react-mui_th.d.ts +15 -1
  318. package/dist/src/properties/ts/odyssey-react-mui_th.d.ts.map +1 -1
  319. package/dist/src/properties/ts/odyssey-react-mui_tr.d.ts +15 -1
  320. package/dist/src/properties/ts/odyssey-react-mui_tr.d.ts.map +1 -1
  321. package/dist/src/properties/ts/odyssey-react-mui_uk.d.ts +15 -1
  322. package/dist/src/properties/ts/odyssey-react-mui_uk.d.ts.map +1 -1
  323. package/dist/src/properties/ts/odyssey-react-mui_vi.d.ts +15 -1
  324. package/dist/src/properties/ts/odyssey-react-mui_vi.d.ts.map +1 -1
  325. package/dist/src/properties/ts/odyssey-react-mui_zh_CN.d.ts +15 -1
  326. package/dist/src/properties/ts/odyssey-react-mui_zh_CN.d.ts.map +1 -1
  327. package/dist/src/properties/ts/odyssey-react-mui_zh_TW.d.ts +15 -1
  328. package/dist/src/properties/ts/odyssey-react-mui_zh_TW.d.ts.map +1 -1
  329. package/dist/src/test-selectors/getByQuerySelector.d.ts +148 -0
  330. package/dist/src/test-selectors/getByQuerySelector.d.ts.map +1 -0
  331. package/dist/src/test-selectors/getComputedAccessibleErrorMessageText.d.ts +14 -0
  332. package/dist/src/test-selectors/getComputedAccessibleErrorMessageText.d.ts.map +1 -0
  333. package/dist/src/test-selectors/getComputedAccessibleText.d.ts +23 -0
  334. package/dist/src/test-selectors/getComputedAccessibleText.d.ts.map +1 -0
  335. package/dist/src/test-selectors/index.d.ts +2 -2
  336. package/dist/src/test-selectors/index.d.ts.map +1 -1
  337. package/{src/test-selectors/odysseyTestSelectors.ts → dist/src/test-selectors/interpolateString.d.ts} +4 -11
  338. package/dist/src/test-selectors/interpolateString.d.ts.map +1 -0
  339. package/dist/src/test-selectors/linkedHtmlSelectors.d.ts +24 -0
  340. package/dist/src/test-selectors/linkedHtmlSelectors.d.ts.map +1 -0
  341. package/dist/src/test-selectors/queryOdysseySelector.d.ts +5755 -0
  342. package/dist/src/test-selectors/queryOdysseySelector.d.ts.map +1 -0
  343. package/dist/src/test-selectors/querySelector.d.ts +59 -3613
  344. package/dist/src/test-selectors/querySelector.d.ts.map +1 -1
  345. package/dist/src/test-selectors/sanityChecks.d.ts +18 -0
  346. package/dist/src/test-selectors/sanityChecks.d.ts.map +1 -0
  347. package/dist/src/test-selectors/testSelector.d.ts +46 -0
  348. package/dist/src/test-selectors/testSelector.d.ts.map +1 -0
  349. package/dist/src/theme/components.d.ts +3 -1
  350. package/dist/src/theme/components.d.ts.map +1 -1
  351. package/dist/src/theme/createOdysseyMuiTheme.d.ts +3 -1
  352. package/dist/src/theme/createOdysseyMuiTheme.d.ts.map +1 -1
  353. package/dist/test-selectors/getByQuerySelector.js +64 -0
  354. package/dist/test-selectors/getByQuerySelector.js.map +1 -0
  355. package/dist/test-selectors/getComputedAccessibleErrorMessageText.js +25 -0
  356. package/dist/test-selectors/getComputedAccessibleErrorMessageText.js.map +1 -0
  357. package/dist/test-selectors/getComputedAccessibleText.js +24 -0
  358. package/dist/test-selectors/getComputedAccessibleText.js.map +1 -0
  359. package/dist/test-selectors/index.js +2 -2
  360. package/dist/test-selectors/index.js.map +1 -1
  361. package/dist/test-selectors/interpolateString.js +25 -0
  362. package/dist/test-selectors/interpolateString.js.map +1 -0
  363. package/dist/test-selectors/linkedHtmlSelectors.js +34 -0
  364. package/dist/test-selectors/linkedHtmlSelectors.js.map +1 -0
  365. package/dist/test-selectors/queryOdysseySelector.js +26 -0
  366. package/dist/test-selectors/queryOdysseySelector.js.map +1 -0
  367. package/dist/test-selectors/querySelector.js +82 -58
  368. package/dist/test-selectors/querySelector.js.map +1 -1
  369. package/dist/test-selectors/sanityChecks.js +33 -0
  370. package/dist/test-selectors/sanityChecks.js.map +1 -0
  371. package/dist/test-selectors/testSelector.js +2 -0
  372. package/dist/test-selectors/testSelector.js.map +1 -0
  373. package/dist/test-selectors/testSelectors.json +1 -1
  374. package/dist/theme/components.js +231 -146
  375. package/dist/theme/components.js.map +1 -1
  376. package/dist/theme/createOdysseyMuiTheme.js +3 -2
  377. package/dist/theme/createOdysseyMuiTheme.js.map +1 -1
  378. package/dist/tsconfig.production.tsbuildinfo +1 -1
  379. package/dist/tsconfig.tsbuildinfo +1 -1
  380. package/jest.setup.js +3 -0
  381. package/package.json +5 -5
  382. package/scripts/generateTestSelectorsJson.ts +1 -1
  383. package/src/@types/i18next.d.ts +1 -1
  384. package/src/Autocomplete.tsx +140 -45
  385. package/src/Callout.tsx +13 -25
  386. package/src/Checkbox.tsx +39 -9
  387. package/src/CheckboxGroup.tsx +20 -4
  388. package/src/DataTable/DataTable.tsx +24 -1
  389. package/src/DataTable/useScrollIndication.tsx +11 -4
  390. package/src/Field.tsx +5 -2
  391. package/src/{labs → FileUploader}/FileUploadPreview.tsx +3 -3
  392. package/src/{labs/FileUpload.tsx → FileUploader/FileUploader.tsx} +7 -6
  393. package/src/FileUploader/index.ts +13 -0
  394. package/src/OdysseyCacheProvider.test.tsx +1 -0
  395. package/src/OdysseyCacheProvider.tsx +18 -4
  396. package/src/OdysseyProvider.tsx +12 -4
  397. package/src/OdysseyThemeProvider.tsx +6 -2
  398. package/src/Radio.tsx +41 -12
  399. package/src/RadioGroup.tsx +26 -7
  400. package/src/Select.tsx +116 -45
  401. package/src/{labs/Switch.tsx → Switch.tsx} +95 -41
  402. package/src/Tabs.tsx +8 -10
  403. package/src/Tag.tsx +134 -3
  404. package/src/TextField.tsx +18 -41
  405. package/src/Toast.tsx +1 -1
  406. package/src/ToastStack.tsx +2 -2
  407. package/src/createShadowDomElements.ts +53 -0
  408. package/src/i18n.ts +3 -3
  409. package/src/index.ts +7 -2
  410. package/src/labs/AppTile.tsx +200 -0
  411. package/src/labs/{DataComponents/StackContent.tsx → DataView/CardLayoutContent.tsx} +24 -19
  412. package/src/labs/{DataComponents/StackCard.tsx → DataView/DataCard.tsx} +7 -7
  413. package/src/labs/{DataComponents → DataView}/DataTable.tsx +8 -4
  414. package/src/labs/DataView/DataView.test.tsx +158 -0
  415. package/src/labs/{DataComponents → DataView}/DataView.tsx +119 -42
  416. package/src/labs/{DataComponents → DataView}/DetailPanel.tsx +2 -2
  417. package/src/labs/{DataComponents/TableContent.tsx → DataView/TableLayoutContent.tsx} +59 -27
  418. package/src/labs/{DataComponents → DataView}/TableSettings.tsx +5 -4
  419. package/src/labs/{DataComponents → DataView}/componentTypes.ts +24 -9
  420. package/src/labs/{DataComponents → DataView}/constants.tsx +2 -2
  421. package/src/labs/{DataComponents → DataView}/index.tsx +0 -1
  422. package/src/labs/{DataComponents → DataView}/useFilterConversion.ts +2 -2
  423. package/src/labs/DateField.tsx +3 -0
  424. package/src/labs/DatePicker.tsx +12 -1
  425. package/src/labs/SideNav/CollapseIcon.tsx +48 -0
  426. package/src/labs/SideNav/OktaLogo.tsx +39 -0
  427. package/src/labs/SideNav/SideNav.tsx +486 -0
  428. package/src/labs/SideNav/SideNavFooterContent.tsx +64 -0
  429. package/src/labs/SideNav/SideNavHeader.tsx +88 -0
  430. package/src/labs/SideNav/SideNavItemContent.tsx +216 -0
  431. package/src/labs/SideNav/SideNavItemLinkContent.tsx +87 -0
  432. package/src/labs/SideNav/index.ts +15 -0
  433. package/src/labs/SideNav/types.ts +152 -0
  434. package/src/labs/TopNav.tsx +3 -1
  435. package/src/labs/index.ts +3 -4
  436. package/src/labs/useDateFieldsTranslations.ts +1 -1
  437. package/src/properties/odyssey-react-mui.properties +2 -1
  438. package/src/properties/translations/odyssey-react-mui_cs.properties +15 -3
  439. package/src/properties/translations/odyssey-react-mui_da.properties +15 -3
  440. package/src/properties/translations/odyssey-react-mui_de.properties +14 -2
  441. package/src/properties/translations/odyssey-react-mui_el.properties +16 -4
  442. package/src/properties/translations/odyssey-react-mui_es.properties +15 -3
  443. package/src/properties/translations/odyssey-react-mui_fi.properties +15 -3
  444. package/src/properties/translations/odyssey-react-mui_fr.properties +15 -3
  445. package/src/properties/translations/odyssey-react-mui_ht.properties +17 -6
  446. package/src/properties/translations/odyssey-react-mui_hu.properties +15 -3
  447. package/src/properties/translations/odyssey-react-mui_id.properties +15 -3
  448. package/src/properties/translations/odyssey-react-mui_it.properties +15 -3
  449. package/src/properties/translations/odyssey-react-mui_ja.properties +14 -2
  450. package/src/properties/translations/odyssey-react-mui_ko.properties +14 -2
  451. package/src/properties/translations/odyssey-react-mui_ms.properties +15 -3
  452. package/src/properties/translations/odyssey-react-mui_nb.properties +15 -3
  453. package/src/properties/translations/odyssey-react-mui_nl_NL.properties +15 -3
  454. package/src/properties/translations/odyssey-react-mui_pl.properties +15 -3
  455. package/src/properties/translations/odyssey-react-mui_pt_BR.properties +15 -3
  456. package/src/properties/translations/odyssey-react-mui_ro.properties +15 -3
  457. package/src/properties/translations/odyssey-react-mui_ru.properties +15 -3
  458. package/src/properties/translations/odyssey-react-mui_sv.properties +15 -3
  459. package/src/properties/translations/odyssey-react-mui_th.properties +14 -2
  460. package/src/properties/translations/odyssey-react-mui_tr.properties +15 -3
  461. package/src/properties/translations/odyssey-react-mui_uk.properties +15 -3
  462. package/src/properties/translations/odyssey-react-mui_vi.properties +15 -3
  463. package/src/properties/translations/odyssey-react-mui_zh_CN.properties +14 -2
  464. package/src/properties/translations/odyssey-react-mui_zh_TW.properties +14 -2
  465. package/src/properties/ts/odyssey-react-mui.ts +1 -1
  466. package/src/properties/ts/odyssey-react-mui_cs.ts +1 -1
  467. package/src/properties/ts/odyssey-react-mui_da.ts +1 -1
  468. package/src/properties/ts/odyssey-react-mui_de.ts +1 -1
  469. package/src/properties/ts/odyssey-react-mui_el.ts +1 -1
  470. package/src/properties/ts/odyssey-react-mui_es.ts +1 -1
  471. package/src/properties/ts/odyssey-react-mui_fi.ts +1 -1
  472. package/src/properties/ts/odyssey-react-mui_fr.ts +1 -1
  473. package/src/properties/ts/odyssey-react-mui_ht.ts +1 -1
  474. package/src/properties/ts/odyssey-react-mui_hu.ts +1 -1
  475. package/src/properties/ts/odyssey-react-mui_id.ts +1 -1
  476. package/src/properties/ts/odyssey-react-mui_it.ts +1 -1
  477. package/src/properties/ts/odyssey-react-mui_ja.ts +1 -1
  478. package/src/properties/ts/odyssey-react-mui_ko.ts +1 -1
  479. package/src/properties/ts/odyssey-react-mui_ms.ts +1 -1
  480. package/src/properties/ts/odyssey-react-mui_nb.ts +1 -1
  481. package/src/properties/ts/odyssey-react-mui_nl_NL.ts +1 -1
  482. package/src/properties/ts/odyssey-react-mui_pl.ts +1 -1
  483. package/src/properties/ts/odyssey-react-mui_pt_BR.ts +1 -1
  484. package/src/properties/ts/odyssey-react-mui_ro.ts +1 -1
  485. package/src/properties/ts/odyssey-react-mui_ru.ts +1 -1
  486. package/src/properties/ts/odyssey-react-mui_sv.ts +1 -1
  487. package/src/properties/ts/odyssey-react-mui_th.ts +1 -1
  488. package/src/properties/ts/odyssey-react-mui_tr.ts +1 -1
  489. package/src/properties/ts/odyssey-react-mui_uk.ts +1 -1
  490. package/src/properties/ts/odyssey-react-mui_vi.ts +1 -1
  491. package/src/properties/ts/odyssey-react-mui_zh_CN.ts +1 -1
  492. package/src/properties/ts/odyssey-react-mui_zh_TW.ts +1 -1
  493. package/src/test-selectors/getByQuerySelector.ts +176 -0
  494. package/src/test-selectors/getComputedAccessibleErrorMessageText.ts +52 -0
  495. package/src/test-selectors/getComputedAccessibleText.ts +36 -0
  496. package/src/test-selectors/index.ts +2 -2
  497. package/src/test-selectors/interpolateString.ts +41 -0
  498. package/src/test-selectors/linkedHtmlSelectors.ts +73 -0
  499. package/src/test-selectors/queryOdysseySelector.ts +36 -0
  500. package/src/test-selectors/querySelector.ts +221 -170
  501. package/src/test-selectors/sanityChecks.ts +53 -0
  502. package/src/test-selectors/testSelector.ts +143 -0
  503. package/src/theme/components.tsx +238 -150
  504. package/src/theme/createOdysseyMuiTheme.ts +4 -1
  505. package/dist/createShadowRootElement.js +0 -26
  506. package/dist/createShadowRootElement.js.map +0 -1
  507. package/dist/labs/DataComponents/BulkActionsMenu.js.map +0 -1
  508. package/dist/labs/DataComponents/DataStack.js +0 -85
  509. package/dist/labs/DataComponents/DataStack.js.map +0 -1
  510. package/dist/labs/DataComponents/DataTable.js.map +0 -1
  511. package/dist/labs/DataComponents/DataView.js.map +0 -1
  512. package/dist/labs/DataComponents/DetailPanel.js.map +0 -1
  513. package/dist/labs/DataComponents/LayoutSwitcher.js.map +0 -1
  514. package/dist/labs/DataComponents/RowActions.js.map +0 -1
  515. package/dist/labs/DataComponents/StackCard.js.map +0 -1
  516. package/dist/labs/DataComponents/StackContent.js.map +0 -1
  517. package/dist/labs/DataComponents/TableContent.js.map +0 -1
  518. package/dist/labs/DataComponents/TableSettings.js.map +0 -1
  519. package/dist/labs/DataComponents/componentTypes.js.map +0 -1
  520. package/dist/labs/DataComponents/constants.js.map +0 -1
  521. package/dist/labs/DataComponents/dataTypes.js.map +0 -1
  522. package/dist/labs/DataComponents/fetchData.js.map +0 -1
  523. package/dist/labs/DataComponents/index.js.map +0 -1
  524. package/dist/labs/DataComponents/tableConstants.js.map +0 -1
  525. package/dist/labs/DataComponents/useFilterConversion.js.map +0 -1
  526. package/dist/labs/FileUpload.js.map +0 -1
  527. package/dist/labs/FileUploadIllustration.js.map +0 -1
  528. package/dist/labs/FileUploadPreview.js.map +0 -1
  529. package/dist/labs/SideNav.js +0 -478
  530. package/dist/labs/SideNav.js.map +0 -1
  531. package/dist/labs/Switch.js.map +0 -1
  532. package/dist/src/createShadowRootElement.d.ts.map +0 -1
  533. package/dist/src/labs/DataComponents/BulkActionsMenu.d.ts.map +0 -1
  534. package/dist/src/labs/DataComponents/DataStack.d.ts +0 -20
  535. package/dist/src/labs/DataComponents/DataStack.d.ts.map +0 -1
  536. package/dist/src/labs/DataComponents/DataTable.d.ts +0 -16
  537. package/dist/src/labs/DataComponents/DataTable.d.ts.map +0 -1
  538. package/dist/src/labs/DataComponents/DataView.d.ts.map +0 -1
  539. package/dist/src/labs/DataComponents/DetailPanel.d.ts.map +0 -1
  540. package/dist/src/labs/DataComponents/LayoutSwitcher.d.ts.map +0 -1
  541. package/dist/src/labs/DataComponents/RowActions.d.ts.map +0 -1
  542. package/dist/src/labs/DataComponents/StackCard.d.ts.map +0 -1
  543. package/dist/src/labs/DataComponents/StackContent.d.ts.map +0 -1
  544. package/dist/src/labs/DataComponents/TableContent.d.ts.map +0 -1
  545. package/dist/src/labs/DataComponents/TableSettings.d.ts.map +0 -1
  546. package/dist/src/labs/DataComponents/componentTypes.d.ts.map +0 -1
  547. package/dist/src/labs/DataComponents/constants.d.ts.map +0 -1
  548. package/dist/src/labs/DataComponents/dataTypes.d.ts.map +0 -1
  549. package/dist/src/labs/DataComponents/fetchData.d.ts.map +0 -1
  550. package/dist/src/labs/DataComponents/index.d.ts.map +0 -1
  551. package/dist/src/labs/DataComponents/tableConstants.d.ts.map +0 -1
  552. package/dist/src/labs/DataComponents/useFilterConversion.d.ts.map +0 -1
  553. package/dist/src/labs/FileUpload.d.ts.map +0 -1
  554. package/dist/src/labs/FileUploadIllustration.d.ts.map +0 -1
  555. package/dist/src/labs/FileUploadPreview.d.ts.map +0 -1
  556. package/dist/src/labs/SideNav.d.ts.map +0 -1
  557. package/dist/src/labs/Switch.d.ts.map +0 -1
  558. package/dist/src/test-selectors/featureTestSelector.d.ts +0 -31
  559. package/dist/src/test-selectors/featureTestSelector.d.ts.map +0 -1
  560. package/dist/src/test-selectors/odysseyTestSelectors.d.ts +0 -120
  561. package/dist/src/test-selectors/odysseyTestSelectors.d.ts.map +0 -1
  562. package/dist/test-selectors/featureTestSelector.js +0 -2
  563. package/dist/test-selectors/featureTestSelector.js.map +0 -1
  564. package/dist/test-selectors/odysseyTestSelectors.js.map +0 -1
  565. package/src/createShadowRootElement.ts +0 -31
  566. package/src/labs/DataComponents/DataStack.tsx +0 -105
  567. package/src/labs/SideNav.tsx +0 -745
  568. package/src/test-selectors/featureTestSelector.ts +0 -41
  569. /package/dist/{labs → FileUploader}/FileUploadIllustration.js +0 -0
  570. /package/dist/{labs → FileUploader}/FileUploadPreview.js +0 -0
  571. /package/dist/labs/{DataComponents → DataView}/BulkActionsMenu.js +0 -0
  572. /package/dist/labs/{DataComponents → DataView}/DetailPanel.js +0 -0
  573. /package/dist/labs/{DataComponents → DataView}/LayoutSwitcher.js +0 -0
  574. /package/dist/labs/{DataComponents → DataView}/RowActions.js +0 -0
  575. /package/dist/labs/{DataComponents → DataView}/componentTypes.js +0 -0
  576. /package/dist/labs/{DataComponents → DataView}/dataTypes.js +0 -0
  577. /package/dist/labs/{DataComponents → DataView}/fetchData.js +0 -0
  578. /package/dist/labs/{DataComponents → DataView}/tableConstants.js +0 -0
  579. /package/dist/labs/{DataComponents → DataView}/useFilterConversion.js +0 -0
  580. /package/dist/src/{labs → FileUploader}/FileUploadIllustration.d.ts +0 -0
  581. /package/dist/src/labs/{DataComponents → DataView}/BulkActionsMenu.d.ts +0 -0
  582. /package/dist/src/labs/{DataComponents → DataView}/LayoutSwitcher.d.ts +0 -0
  583. /package/dist/src/labs/{DataComponents → DataView}/RowActions.d.ts +0 -0
  584. /package/dist/src/labs/{DataComponents → DataView}/dataTypes.d.ts +0 -0
  585. /package/dist/src/labs/{DataComponents → DataView}/fetchData.d.ts +0 -0
  586. /package/dist/src/labs/{DataComponents → DataView}/tableConstants.d.ts +0 -0
  587. /package/src/{labs → FileUploader}/FileUploadIllustration.tsx +0 -0
  588. /package/src/labs/{DataComponents → DataView}/BulkActionsMenu.tsx +0 -0
  589. /package/src/labs/{DataComponents → DataView}/LayoutSwitcher.tsx +0 -0
  590. /package/src/labs/{DataComponents → DataView}/RowActions.tsx +0 -0
  591. /package/src/labs/{DataComponents → DataView}/dataTypes.ts +0 -0
  592. /package/src/labs/{DataComponents → DataView}/fetchData.ts +0 -0
  593. /package/src/labs/{DataComponents → DataView}/tableConstants.tsx +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"querySelector.js","names":["within","odysseyTestSelectors","interpolateString","string","values","interpolatedString","eval","Object","entries","map","key","value","JSON","stringify","join","test","getByQuerySelector","canvas","method","options","role","text","getByRole","getByLabelText","getByPlaceholderText","getByText","querySelector","templateArgs","templateArgsProp","testSelectors","element","selector","fromEntries","select","featureName","feature","queryOdysseySelector","componentName"],"sources":["../../src/test-selectors/querySelector.ts"],"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 queries,\n within,\n type BoundFunctions,\n type ByRoleOptions,\n type GetByText,\n GetByRole,\n} from \"@testing-library/dom\";\n\nimport {\n type FeatureTestSelector,\n type TestSelector,\n} from \"./featureTestSelector\";\nimport { odysseyTestSelectors } from \"./odysseyTestSelectors\";\n\nexport const interpolateString = (\n string: string,\n values: Record<string, string | RegExp>,\n) => {\n const interpolatedString = eval(`\n ${Object.entries(values)\n .map(\n ([key, value]) =>\n `const ${key} = ${\n typeof value === \"string\" ? JSON.stringify(value) : value\n };`,\n )\n .join(\"\")}\n\n \\`${string}\\`\n `) as string;\n\n if (/^\\/*(.+)\\/$/.test(interpolatedString)) {\n return eval(interpolatedString) as RegExp;\n }\n\n return interpolatedString;\n};\n\nconst getByQuerySelector = ({\n canvas,\n method,\n options,\n role,\n text,\n}: {\n canvas: BoundFunctions<typeof queries>;\n method: \"ByRole\" | \"ByLabelText\" | \"ByPlaceholderText\" | \"ByText\";\n options?: ByRoleOptions;\n role?: Parameters<GetByRole>[1];\n text?: Parameters<GetByText>[1];\n}) => {\n if (method === \"ByRole\") {\n return canvas.getByRole(\n // TODO: These should eventually reference `query` as the function identifier.\n role!,\n options,\n );\n } else if (method === \"ByLabelText\") {\n return canvas.getByLabelText(\n // These should eventually reference `query` as the function identifier.\n text!, // TODO: Use TypeScript `Infer` to ensure `label` is required when it's `ByLabelText`.\n options,\n );\n } else if (method === \"ByPlaceholderText\") {\n return canvas.getByPlaceholderText(\n // These should eventually reference `query` as the function identifier.\n text!, // TODO: Use TypeScript `Infer` to ensure `label` is required when it's `ByLabelText`.\n options,\n );\n } else if (method === \"ByText\") {\n return canvas.getByText(\n // These should eventually reference `query` as the function identifier.\n text!, // TODO: Use TypeScript `Infer` to ensure `description` is required when it's `ByLabelText`.\n options,\n );\n }\n\n return null;\n};\n\nexport const querySelector = <TestSelectors extends FeatureTestSelector>({\n canvas,\n templateArgs: templateArgsProp,\n testSelectors,\n}: {\n /**\n * Testing Library canvas. This is usually `screen`, but Storybook uses `within(canvas)`.\n */\n canvas: BoundFunctions<typeof queries>;\n templateArgs?: TestSelectors extends TestSelector\n ? Record<\n TestSelectors[\"selector\"][\"templateVariableNames\"][number],\n string | RegExp\n >\n : never;\n testSelectors: TestSelectors;\n}) => {\n const element =\n \"selector\" in testSelectors\n ? getByQuerySelector({\n canvas,\n method: testSelectors.selector.method,\n options:\n templateArgsProp && testSelectors.selector.options\n ? Object.fromEntries(\n Object.entries(testSelectors.selector.options).map(\n ([key, value]) => [\n key,\n interpolateString(value, templateArgsProp),\n ],\n ),\n )\n : testSelectors.selector.options,\n ...(testSelectors.selector.method === \"ByRole\"\n ? {\n role: templateArgsProp\n ? (interpolateString(\n testSelectors.selector?.role,\n templateArgsProp,\n ) as string)\n : testSelectors.selector?.role,\n }\n : {\n text: templateArgsProp\n ? interpolateString(\n testSelectors.selector?.text,\n templateArgsProp,\n )\n : testSelectors.selector?.text,\n }),\n })\n : null;\n\n const select =\n \"feature\" in testSelectors\n ? <FeatureName extends keyof (typeof testSelectors)[\"feature\"]>(\n featureName: FeatureName,\n templateArgs?: (typeof testSelectors)[\"feature\"][FeatureName] extends TestSelector\n ? Record<\n (typeof testSelectors)[\"feature\"][FeatureName][\"selector\"][\"templateVariableNames\"][number],\n string | RegExp\n >\n : never,\n ) =>\n querySelector({\n canvas: element ? within(element) : canvas,\n templateArgs,\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-expect-error: Type 'FeatureName' cannot be used to index type 'Record<string, FeatureTestSelector>'.ts(2536)\n testSelectors: testSelectors.feature[featureName],\n })\n : null;\n\n return {\n element,\n select,\n };\n};\n\nexport const queryOdysseySelector = <\n ComponentName extends keyof typeof odysseyTestSelectors,\n>({\n canvas,\n componentName,\n templateArgs,\n}: {\n canvas: Parameters<\n typeof querySelector<(typeof odysseyTestSelectors)[ComponentName]>\n >[0][\"canvas\"];\n /**\n * Name of the component you want to select within.\n */\n componentName: ComponentName;\n /**\n * String or RegExp values required for this selector.\n */\n templateArgs?: Parameters<\n typeof querySelector<(typeof odysseyTestSelectors)[ComponentName]>\n >[0][\"templateArgs\"];\n}) =>\n querySelector({\n canvas,\n templateArgs,\n testSelectors: odysseyTestSelectors[componentName],\n });\n"],"mappings":"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"}
1
+ {"version":3,"file":"querySelector.js","names":["getComputedAccessibleText","getByRoleQuerySelector","getByTextQuerySelector","getControlledElement","ElementError","captureElement","containerElement","queryMethod","querySelectorOptions","role","testSelector","sharedProps","element","queryOptions","Object","fromEntries","entries","elementSelector","options","map","testSelectorOptionKey","testingLibraryOptionKey","method","Array","isArray","selectionMethod","text","isControlledElement","error","querySelector","props","capturedElement","undefined","getAccessibleText","labelName","Error","type","accessibleText","selectChild","childProps","children","name"],"sources":["../../src/test-selectors/querySelector.ts"],"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 type AccessibleTextSelector,\n type AriaRole,\n type ElementChildSelector,\n type TestSelector,\n type ElementSelector,\n} from \"./testSelector\";\nimport { getComputedAccessibleText } from \"./getComputedAccessibleText\";\nimport {\n getByRoleQuerySelector,\n getByTextQuerySelector,\n type QueryMethod,\n} from \"./getByQuerySelector\";\nimport { getControlledElement } from \"./linkedHtmlSelectors\";\nimport { ElementError } from \"./sanityChecks\";\n\nexport type InnerQuerySelectorProps<\n LocalTestSelector extends TestSelector,\n LocalQueryMethod extends QueryMethod,\n> = {\n /**\n * Testing Library method used to query elements.\n */\n queryMethod?: LocalQueryMethod;\n} & (LocalTestSelector extends ElementSelector\n ? LocalTestSelector[\"elementSelector\"] extends {\n role: infer Role;\n }\n ? Role extends AriaRole[]\n ? {\n /**\n * Role is used when you have an optional `role`; otherwise, it'd baked into the metadata.\n */\n role: Role[number];\n }\n : object\n : object\n : object) &\n (LocalTestSelector extends ElementSelector\n ? {\n /**\n * Helps narrow down HTML selection to the correct element.\n */\n options: Record<\n keyof LocalTestSelector[\"elementSelector\"][\"options\"],\n string | RegExp\n >;\n }\n : object);\n\nexport const captureElement = <\n LocalTestSelector extends TestSelector,\n QuerySelectorOptions extends Record<string, string | RegExp>,\n LocalQueryMethod extends QueryMethod = \"get\",\n>({\n containerElement,\n queryMethod,\n querySelectorOptions,\n role,\n testSelector,\n}: {\n containerElement: HTMLElement;\n queryMethod: LocalQueryMethod;\n querySelectorOptions?: QuerySelectorOptions;\n role?: AriaRole;\n testSelector: LocalTestSelector;\n}) => {\n if (\"elementSelector\" in testSelector && querySelectorOptions) {\n const sharedProps = {\n element: containerElement,\n queryMethod,\n queryOptions: Object.fromEntries(\n Object.entries(testSelector.elementSelector.options).map(\n ([testSelectorOptionKey, testingLibraryOptionKey]) => [\n testingLibraryOptionKey,\n querySelectorOptions[testSelectorOptionKey],\n ],\n ),\n ),\n };\n\n if (testSelector.elementSelector.method === \"ByRole\") {\n return getByRoleQuerySelector({\n ...sharedProps,\n role:\n Array.isArray(testSelector.elementSelector.role) || role\n ? role || \"\"\n : testSelector.elementSelector.role,\n });\n }\n\n return getByTextQuerySelector({\n ...sharedProps,\n selectionMethod: testSelector.elementSelector.method,\n text: testSelector.elementSelector.text,\n });\n } else if (\n \"isControlledElement\" in testSelector &&\n testSelector.isControlledElement\n ) {\n try {\n return getControlledElement({ element: containerElement });\n } catch (error) {\n if (queryMethod === \"query\") {\n return null;\n }\n\n throw error;\n }\n }\n\n return null;\n};\n\nexport const querySelector =\n <LocalTestSelector extends TestSelector>(\n /**\n * Selectors object including children and accessible text selections.\n */\n testSelector: LocalTestSelector,\n ) =>\n <LocalQueryMethod extends QueryMethod = \"get\">(\n props: {\n /**\n * Refers to Testing Library's canvas. This is usually `screen`, but Storybook uses `within(canvas)`.\n */\n element: HTMLElement;\n } & InnerQuerySelectorProps<LocalTestSelector, LocalQueryMethod>,\n ) => {\n const { element: containerElement, queryMethod } = props;\n\n const capturedElement = captureElement({\n containerElement,\n queryMethod: queryMethod || (\"get\" as const),\n querySelectorOptions: \"options\" in props ? props.options : undefined,\n role: \"role\" in props ? (props.role as AriaRole) : undefined,\n testSelector,\n });\n\n const getAccessibleText = <\n LabelName extends LocalTestSelector extends AccessibleTextSelector\n ? keyof LocalTestSelector[\"accessibleText\"]\n : never,\n >(\n labelName: LabelName,\n ) => {\n if (!capturedElement) {\n throw new ElementError(\n \"No child HTML element available\",\n containerElement,\n );\n }\n\n if (!(\"accessibleText\" in testSelector)) {\n throw new Error(\"Missing `accessibleText` in `TestSelector`\");\n }\n\n return getComputedAccessibleText({\n element: capturedElement,\n type: testSelector.accessibleText[labelName],\n });\n };\n\n const selectChild = <\n ChildName extends LocalTestSelector extends ElementChildSelector\n ? keyof LocalTestSelector[\"children\"]\n : keyof ElementChildSelector,\n ChildQueryMethod extends QueryMethod = \"get\",\n >(\n childProps: {\n name: ChildName;\n } & InnerQuerySelectorProps<\n LocalTestSelector extends ElementChildSelector\n ? LocalTestSelector[\"children\"][ChildName]\n : TestSelector,\n ChildQueryMethod\n >,\n ) => {\n if (!capturedElement) {\n throw new ElementError(\n \"No child HTML element available\",\n containerElement,\n );\n }\n\n if (!(\"children\" in testSelector)) {\n throw new Error(\"Missing `children` in `TestSelector`\");\n }\n\n type Options = Record<\n LocalTestSelector extends ElementChildSelector\n ? LocalTestSelector[\"children\"][ChildName] extends ElementSelector\n ? keyof LocalTestSelector[\"children\"][ChildName][\"elementSelector\"][\"options\"]\n : never\n : never,\n string | RegExp\n >;\n\n return querySelector(\n testSelector.children[\n childProps.name\n ] as LocalTestSelector extends ElementChildSelector\n ? LocalTestSelector[\"children\"][ChildName]\n : TestSelector,\n )(\n // @ts-expect-error: Type '{ role?: AriaRole | undefined; options?: Record<LocalTestSelector extends ElementChildSelector ? LocalTestSelector[\"children\"][ChildName] extends TestSelector ? keyof LocalTestSelector[\"children\"][ChildName][\"selector\"][\"options\"] : string : string, string | RegExp> | undefined; element: HTMLElement...' is not assignable to type '(LocalTestSelector extends ElementChildSelector ? LocalTestSelector[\"children\"][ChildName] : TestSelector) extends { ...; } ? Role extends AriaRole[] ? { ...; } : object : object'.ts(2345)\n // `as testSelector.children[ChildName]` narrows the props down enough that TypeScript errors here. We're passing the correct information, but it doesn't know that, and it's difficult to fix this. -Kevin Ghadyani\n {\n element: capturedElement,\n queryMethod: childProps.queryMethod,\n ...(\"options\" in childProps && childProps.options\n ? {\n options: childProps.options as Options,\n }\n : {}),\n ...(\"role\" in childProps && childProps.role\n ? {\n role: childProps.role as AriaRole,\n }\n : {}),\n },\n );\n };\n\n return {\n element: capturedElement as LocalQueryMethod extends \"get\"\n ? HTMLElement\n : HTMLElement | null,\n getAccessibleText:\n getAccessibleText as LocalTestSelector extends AccessibleTextSelector\n ? typeof getAccessibleText\n : never,\n selectChild: selectChild as LocalTestSelector extends ElementChildSelector\n ? typeof selectChild\n : never,\n };\n };\n"],"mappings":"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"}
@@ -0,0 +1,33 @@
1
+ /*!
2
+ * Copyright (c) 2024-present, Okta, Inc. and/or its affiliates. All rights reserved.
3
+ * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
4
+ *
5
+ * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
6
+ * Unless required by applicable law or agreed to in writing, software
7
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
8
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
9
+ *
10
+ * See the License for the specific language governing permissions and limitations under the License.
11
+ */export class ElementError extends Error {
12
+ constructor(message, element) {
13
+ super(message);
14
+ this.name = "ElementError";
15
+ console.error("ElementError", element);
16
+ }
17
+ }
18
+ export const normalizeText = text => {
19
+ return text.replace(/\s+/g, " ").trim();
20
+ };
21
+ export const getWindow = htmlElement => {
22
+ if (!htmlElement || !htmlElement.ownerDocument || !htmlElement.ownerDocument.defaultView) {
23
+ throw new ElementError("Expected element to have a `window`", htmlElement);
24
+ }
25
+ return htmlElement.ownerDocument.defaultView;
26
+ };
27
+ export const validateHtmlElement = htmlElement => {
28
+ const window = getWindow(htmlElement);
29
+ if (!(htmlElement instanceof window.SVGElement) && !(htmlElement instanceof window.HTMLElement)) {
30
+ throw new ElementError("Expected element to be an HTMLElement or an SVGElement", htmlElement);
31
+ }
32
+ };
33
+ //# sourceMappingURL=sanityChecks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sanityChecks.js","names":["ElementError","Error","constructor","message","element","name","console","error","normalizeText","text","replace","trim","getWindow","htmlElement","ownerDocument","defaultView","validateHtmlElement","window","SVGElement","HTMLElement"],"sources":["../../src/test-selectors/sanityChecks.ts"],"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 modified from: https://github.com/testing-library/jest-dom/blob/main/src/utils.js\n\nexport class ElementError extends Error {\n constructor(message: string, element: HTMLElement) {\n super(message);\n\n this.name = \"ElementError\";\n\n console.error(\"ElementError\", element);\n }\n}\n\nexport const normalizeText = (text: string) => {\n return text.replace(/\\s+/g, \" \").trim();\n};\n\nexport const getWindow = (htmlElement: HTMLElement) => {\n if (\n !htmlElement ||\n !htmlElement.ownerDocument ||\n !htmlElement.ownerDocument.defaultView\n ) {\n throw new ElementError(\"Expected element to have a `window`\", htmlElement);\n }\n\n return htmlElement.ownerDocument.defaultView!;\n};\n\nexport const validateHtmlElement = (htmlElement: HTMLElement) => {\n const window = getWindow(htmlElement);\n\n if (\n !(htmlElement instanceof window.SVGElement) &&\n !(htmlElement instanceof window.HTMLElement)\n ) {\n throw new ElementError(\n \"Expected element to be an HTMLElement or an SVGElement\",\n htmlElement,\n );\n }\n};\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAIA,OAAO,MAAMA,YAAY,SAASC,KAAK,CAAC;EACtCC,WAAWA,CAACC,OAAe,EAAEC,OAAoB,EAAE;IACjD,KAAK,CAACD,OAAO,CAAC;IAEd,IAAI,CAACE,IAAI,GAAG,cAAc;IAE1BC,OAAO,CAACC,KAAK,CAAC,cAAc,EAAEH,OAAO,CAAC;EACxC;AACF;AAEA,OAAO,MAAMI,aAAa,GAAIC,IAAY,IAAK;EAC7C,OAAOA,IAAI,CAACC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAACC,IAAI,CAAC,CAAC;AACzC,CAAC;AAED,OAAO,MAAMC,SAAS,GAAIC,WAAwB,IAAK;EACrD,IACE,CAACA,WAAW,IACZ,CAACA,WAAW,CAACC,aAAa,IAC1B,CAACD,WAAW,CAACC,aAAa,CAACC,WAAW,EACtC;IACA,MAAM,IAAIf,YAAY,CAAC,qCAAqC,EAAEa,WAAW,CAAC;EAC5E;EAEA,OAAOA,WAAW,CAACC,aAAa,CAACC,WAAW;AAC9C,CAAC;AAED,OAAO,MAAMC,mBAAmB,GAAIH,WAAwB,IAAK;EAC/D,MAAMI,MAAM,GAAGL,SAAS,CAACC,WAAW,CAAC;EAErC,IACE,EAAEA,WAAW,YAAYI,MAAM,CAACC,UAAU,CAAC,IAC3C,EAAEL,WAAW,YAAYI,MAAM,CAACE,WAAW,CAAC,EAC5C;IACA,MAAM,IAAInB,YAAY,CACpB,wDAAwD,EACxDa,WACF,CAAC;EACH;AACF,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=testSelector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"testSelector.js","names":[],"sources":["../../src/test-selectors/testSelector.ts"],"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 type ByRoleOptions,\n type SelectorMatcherOptions,\n} from \"@testing-library/dom\";\n\nimport {\n type RoleSelectorMethod,\n type TextSelectorMethod,\n} from \"./getByQuerySelector\";\n\n/**\n * We can't use React's `AriaRole` because it allows any string value. We want to be very specific. This is otherwise copied straight from React's code.\n * @see https://github.com/DefinitelyTyped/DefinitelyTyped/blob/master/types/react/index.d.ts#L2815\n */\nexport type AriaRole =\n | \"alert\"\n | \"alertdialog\"\n | \"application\"\n | \"article\"\n | \"banner\"\n | \"button\"\n | \"cell\"\n | \"checkbox\"\n | \"columnheader\"\n | \"combobox\"\n | \"complementary\"\n | \"contentinfo\"\n | \"definition\"\n | \"dialog\"\n | \"directory\"\n | \"document\"\n | \"feed\"\n | \"figure\"\n | \"form\"\n | \"grid\"\n | \"gridcell\"\n | \"group\"\n | \"heading\"\n | \"img\"\n | \"link\"\n | \"list\"\n | \"listbox\"\n | \"listitem\"\n | \"log\"\n | \"main\"\n | \"marquee\"\n | \"math\"\n | \"menu\"\n | \"menubar\"\n | \"menuitem\"\n | \"menuitemcheckbox\"\n | \"menuitemradio\"\n | \"navigation\"\n | \"none\"\n | \"note\"\n | \"option\"\n | \"presentation\"\n | \"progressbar\"\n | \"radio\"\n | \"radiogroup\"\n | \"region\"\n | \"row\"\n | \"rowgroup\"\n | \"rowheader\"\n | \"scrollbar\"\n | \"search\"\n | \"searchbox\"\n | \"separator\"\n | \"slider\"\n | \"spinbutton\"\n | \"status\"\n | \"switch\"\n | \"tab\"\n | \"table\"\n | \"tablist\"\n | \"tabpanel\"\n | \"term\"\n | \"textbox\"\n | \"timer\"\n | \"toolbar\"\n | \"tooltip\"\n | \"tree\"\n | \"treegrid\"\n | \"treeitem\";\n\nexport type ControlledElementSelector = { isControlledElement?: true };\n\nexport type RoleSelectorOptions = {\n method: RoleSelectorMethod;\n options: Record<string, keyof ByRoleOptions>;\n role: AriaRole | AriaRole[];\n // | \"UNKNOWN\" // This should be a `Symbol`, but it can't because this is ultimately going to be JSON stringified. This type will allow passing a custom role if the component allows it: `Box`.\n};\n\nexport type TextSelectorOptions = {\n method: TextSelectorMethod;\n options: Record<string, keyof SelectorMatcherOptions>;\n text: string;\n};\n\nexport type ElementSelectorValue = RoleSelectorOptions | TextSelectorOptions;\n\nexport type ElementSelector = {\n elementSelector: ElementSelectorValue;\n};\n\nexport type ElementChildSelectorValue = Record<\n string,\n TestSelector & ControlledElementSelector\n>;\n\nexport type ElementChildSelector = {\n children: ElementChildSelectorValue;\n};\n\nexport type AccessibleTextSelectorValue =\n | \"description\"\n | \"errorMessage\"\n | \"label\";\n\nexport type AccessibleTextSelector = {\n /** An \"accessible -> semantic\" name mapping such as \"`description` -> `hint`\" where \"description\" equates to `\"aria-description\"`. */\n accessibleText: Record<string, AccessibleTextSelectorValue>;\n};\n\nexport type TestSelector =\n | ElementChildSelector\n | ElementSelector\n | (ElementChildSelector & ElementSelector)\n | (AccessibleTextSelector & ElementSelector)\n | (ElementChildSelector & AccessibleTextSelector & ElementSelector);\n"],"mappings":""}
@@ -1 +1 @@
1
- {"Callout":{"feature":{"link":{"selector":{"method":"ByRole","options":{"name":"${linkText}"},"role":"link","templateVariableNames":["linkText"]}},"text":{"selector":{"method":"ByText","templateVariableNames":["text"],"text":"${text}"}},"title":{"selector":{"method":"ByText","templateVariableNames":["title"],"text":"${title}"}}},"selector":{"method":"ByRole","options":{"name":"${title}"},"role":"${role}","templateVariableNames":["role","title"]}},"Tabs":{"feature":{"tabItem":{"selector":{"method":"ByRole","options":{"name":"${label}"},"templateVariableNames":["label"],"role":"tab"}}},"selector":{"method":"ByRole","options":{"name":"${ariaLabel}"},"role":"tablist","templateVariableNames":["ariaLabel"]}},"TextField":{"feature":{"description":{"selector":{"method":"ByText","templateVariableNames":["hint"],"text":"${hint}"}},"errorMessage":{"selector":{"method":"ByText","templateVariableNames":["errorMessage"],"text":"${errorMessage}"}},"input":{"selector":{"method":"ByRole","options":{"name":"${label}"},"role":"textbox","templateVariableNames":["label"]}},"label":{"selector":{"method":"ByRole","options":{"name":"${label}"},"role":"LabelText","templateVariableNames":["label"]}},"link":{"selector":{"method":"ByRole","options":{"name":"${label}"},"templateVariableNames":["label"],"role":"link"}}}}}
1
+ {"Autocomplete":{"accessibleText":{"errorMessage":"errorMessage","hint":"description","label":"label"},"children":{"list":{"children":{"listItem":{"elementSelector":{"method":"ByRole","options":{"label":"name"},"role":"option"}}},"isControlledElement":true}},"elementSelector":{"method":"ByRole","options":{"label":"name"},"role":"combobox"}},"Callout":{"accessibleText":{"text":"description","title":"label"},"children":{"link":{"elementSelector":{"method":"ByRole","options":{"linkText":"name"},"role":"link"}}},"elementSelector":{"method":"ByRole","options":{"title":"name"},"role":["alert","status"]}},"Select":{"accessibleText":{"errorMessage":"errorMessage","hint":"description","label":"label"},"children":{"list":{"accessibleText":{"label":"label"},"children":{"listItem":{"accessibleText":{"label":"label"},"elementSelector":{"method":"ByRole","options":{"label":"name"},"role":"option"}}},"isControlledElement":true}},"elementSelector":{"method":"ByRole","options":{"label":"name"},"role":"combobox"}},"Tabs":{"children":{"tabItem":{"elementSelector":{"method":"ByRole","options":{"label":"name"},"role":"tab"}}},"elementSelector":{"method":"ByRole","options":{"label":"name"},"role":"tablist"}},"TextField":{"accessibleText":{"errorMessage":"errorMessage","hint":"description","label":"label"},"children":{"link":{"elementSelector":{"method":"ByRole","options":{"label":"name"},"role":"link"}}},"elementSelector":{"method":"ByRole","options":{"label":"name"},"role":"textbox"}}}
@@ -44,7 +44,8 @@ const drawerSizes = {
44
44
  };
45
45
  export const components = ({
46
46
  odysseyTokens,
47
- shadowDomElement
47
+ shadowDomElement,
48
+ shadowRootElement
48
49
  }) => {
49
50
  return {
50
51
  MuiAccordion: {
@@ -152,29 +153,33 @@ export const components = ({
152
153
  padding: odysseyTokens.Spacing4,
153
154
  gap: odysseyTokens.Spacing4,
154
155
  color: odysseyTokens.TypographyColorBody,
155
- border: 0,
156
+ border: "1px solid",
156
157
  ...(ownerState.severity === "success" && {
157
- backgroundColor: odysseyTokens.HueGreen100,
158
+ backgroundColor: odysseyTokens.HueGreen50,
159
+ borderColor: odysseyTokens.HueGreen200,
158
160
  ...(ownerState.variant === "toast" && {
159
- backgroundColor: odysseyTokens.HueGreen100.concat(odysseyTokens.PaletteAlphaSemi)
161
+ backgroundColor: odysseyTokens.HueGreen50.concat(odysseyTokens.PaletteAlphaSemi)
160
162
  })
161
163
  }),
162
164
  ...(ownerState.severity === "info" && {
163
- backgroundColor: odysseyTokens.HueBlue100,
165
+ backgroundColor: odysseyTokens.HueBlue50,
166
+ borderColor: odysseyTokens.HueBlue200,
164
167
  ...(ownerState.variant === "toast" && {
165
- backgroundColor: odysseyTokens.HueBlue100.concat(odysseyTokens.PaletteAlphaSemi)
168
+ backgroundColor: odysseyTokens.HueBlue50.concat(odysseyTokens.PaletteAlphaSemi)
166
169
  })
167
170
  }),
168
171
  ...(ownerState.severity === "error" && {
169
- backgroundColor: odysseyTokens.HueRed100,
172
+ backgroundColor: odysseyTokens.HueRed50,
173
+ borderColor: odysseyTokens.HueRed200,
170
174
  ...(ownerState.variant === "toast" && {
171
- backgroundColor: odysseyTokens.HueRed100.concat(odysseyTokens.PaletteAlphaSemi)
175
+ backgroundColor: odysseyTokens.HueRed50.concat(odysseyTokens.PaletteAlphaSemi)
172
176
  })
173
177
  }),
174
178
  ...(ownerState.severity === "warning" && {
175
- backgroundColor: odysseyTokens.HueYellow100,
179
+ backgroundColor: odysseyTokens.HueYellow50,
180
+ borderColor: odysseyTokens.HueYellow500,
176
181
  ...(ownerState.variant === "toast" && {
177
- backgroundColor: odysseyTokens.HueYellow100.concat(odysseyTokens.PaletteAlphaSemi)
182
+ backgroundColor: odysseyTokens.HueYellow50.concat(odysseyTokens.PaletteAlphaSemi)
178
183
  })
179
184
  }),
180
185
  [`& .${alertTitleClasses.root}`]: {
@@ -431,7 +436,6 @@ export const components = ({
431
436
  background: "transparent",
432
437
  paddingBlockStart: odysseyTokens.Spacing1,
433
438
  ...(ownerState.ListboxComponent !== undefined && {
434
- height: "100%",
435
439
  maxHeight: "40vh"
436
440
  })
437
441
  }),
@@ -781,73 +785,95 @@ export const components = ({
781
785
  },
782
786
  styleOverrides: {
783
787
  root: ({
788
+ ownerState,
784
789
  theme
785
- }) => ({
786
- width: `${odysseyTokens.TypographyLineHeightUi}em`,
787
- minWidth: `${odysseyTokens.TypographyLineHeightUi}em`,
788
- height: `${odysseyTokens.TypographyLineHeightUi}em`,
789
- borderRadius: odysseyTokens.BorderRadiusTight,
790
- borderWidth: odysseyTokens.BorderWidthMain,
791
- borderStyle: odysseyTokens.BorderStyleMain,
792
- borderColor: odysseyTokens.HueNeutral500,
793
- padding: 0,
794
- boxShadow: `0 0 0 0 transparent`,
795
- transition: theme.transitions.create(["border-color", "background-color", "box-shadow"], {
796
- duration: odysseyTokens.TransitionDurationMain
797
- }),
798
- [`.${svgIconClasses.root}`]: {
799
- color: odysseyTokens.HueNeutralWhite,
800
- transition: theme.transitions.create(["color"], {
790
+ }) => {
791
+ const isReadOnly = ownerState?.inputProps?.readOnly;
792
+ return {
793
+ width: `${odysseyTokens.TypographyLineHeightUi}em`,
794
+ minWidth: `${odysseyTokens.TypographyLineHeightUi}em`,
795
+ height: `${odysseyTokens.TypographyLineHeightUi}em`,
796
+ borderRadius: odysseyTokens.BorderRadiusTight,
797
+ border: `1px solid ${odysseyTokens.HueNeutral500}`,
798
+ padding: 0,
799
+ boxShadow: `0 0 0 0 transparent`,
800
+ transition: theme.transitions.create(["border-color", "background-color", "box-shadow"], {
801
801
  duration: odysseyTokens.TransitionDurationMain
802
- })
803
- },
804
- "&.Mui-checked, &.MuiCheckbox-indeterminate": {
805
- backgroundColor: odysseyTokens.PalettePrimaryMain,
806
- borderColor: odysseyTokens.PalettePrimaryMain,
802
+ }),
803
+ [`.${svgIconClasses.root}`]: {
804
+ color: odysseyTokens.HueNeutralWhite,
805
+ transition: theme.transitions.create(["color"], {
806
+ duration: odysseyTokens.TransitionDurationMain
807
+ })
808
+ },
809
+ "&.Mui-checked, &.MuiCheckbox-indeterminate": {
810
+ backgroundColor: odysseyTokens.PalettePrimaryMain,
811
+ borderColor: odysseyTokens.PalettePrimaryMain,
812
+ [`.${formControlLabelClasses.root}:hover > &`]: {
813
+ backgroundColor: odysseyTokens.PalettePrimaryDark,
814
+ borderColor: odysseyTokens.PalettePrimaryDark
815
+ }
816
+ },
807
817
  [`.${formControlLabelClasses.root}:hover > &`]: {
808
- backgroundColor: odysseyTokens.PalettePrimaryDark,
809
- borderColor: odysseyTokens.PalettePrimaryDark
810
- }
811
- },
812
- [`.${formControlLabelClasses.root}:hover > &`]: {
813
- backgroundColor: "transparent",
814
- borderColor: odysseyTokens.HueNeutral900
815
- },
816
- ".Mui-error:not(.Mui-valid):hover > &": {
817
- borderColor: odysseyTokens.BorderColorDangerDark,
818
- "&.Mui-checked": {
819
- backgroundColor: odysseyTokens.PaletteDangerDark,
820
- borderColor: odysseyTokens.BorderColorDangerDark
821
- }
822
- },
823
- ".Mui-error:not(.Mui-valid) > &": {
824
- borderColor: odysseyTokens.BorderColorDangerControl,
825
- "&.Mui-checked": {
826
- backgroundColor: odysseyTokens.PaletteDangerMain,
827
- borderColor: odysseyTokens.BorderColorDangerControl
818
+ backgroundColor: "transparent",
819
+ borderColor: odysseyTokens.HueNeutral900
820
+ },
821
+ ".Mui-error:not(.Mui-valid):hover > &": {
822
+ borderColor: odysseyTokens.BorderColorDangerDark,
823
+ "&.Mui-checked": {
824
+ backgroundColor: odysseyTokens.PaletteDangerDark,
825
+ borderColor: odysseyTokens.BorderColorDangerDark
826
+ }
828
827
  },
829
- "&.Mui-focusVisible": {
830
- boxShadow: `0 0 0 2px ${odysseyTokens.HueNeutralWhite}, 0 0 0 4px ${odysseyTokens.PaletteDangerMain}`
831
- }
832
- },
833
- "&.Mui-focusVisible": {
834
- borderColor: odysseyTokens.HueNeutral900,
835
- boxShadow: `0 0 0 2px ${odysseyTokens.HueNeutralWhite}, 0 0 0 4px ${odysseyTokens.PalettePrimaryMain}`,
836
- outline: "2px solid transparent",
837
- outlineOffset: "1px"
838
- },
839
- "&.Mui-disabled": {
840
- backgroundColor: odysseyTokens.HueNeutral50,
841
- borderColor: odysseyTokens.HueNeutral300,
842
828
  ".Mui-error:not(.Mui-valid) > &": {
829
+ borderColor: odysseyTokens.BorderColorDangerControl,
830
+ "&.Mui-checked": {
831
+ backgroundColor: odysseyTokens.PaletteDangerMain,
832
+ borderColor: odysseyTokens.BorderColorDangerControl
833
+ },
834
+ "&.Mui-focusVisible": {
835
+ boxShadow: `0 0 0 2px ${odysseyTokens.HueNeutralWhite}, 0 0 0 4px ${odysseyTokens.PaletteDangerMain}`
836
+ }
837
+ },
838
+ "&.Mui-focusVisible": {
839
+ borderColor: odysseyTokens.HueNeutral900,
840
+ boxShadow: `0 0 0 2px ${odysseyTokens.HueNeutralWhite}, 0 0 0 4px ${odysseyTokens.PalettePrimaryMain}`,
841
+ outline: "2px solid transparent",
842
+ outlineOffset: "1px"
843
+ },
844
+ "&.Mui-disabled": {
843
845
  backgroundColor: odysseyTokens.HueNeutral50,
844
- borderColor: odysseyTokens.HueNeutral300
846
+ borderColor: odysseyTokens.HueNeutral300,
847
+ ".Mui-error:not(.Mui-valid) > &": {
848
+ backgroundColor: odysseyTokens.HueNeutral50,
849
+ borderColor: odysseyTokens.HueNeutral300
850
+ },
851
+ [`.${svgIconClasses.root}`]: {
852
+ color: odysseyTokens.HueNeutral300
853
+ }
845
854
  },
846
- [`.${svgIconClasses.root}`]: {
847
- color: odysseyTokens.HueNeutral300
848
- }
849
- }
850
- })
855
+ ...(isReadOnly && {
856
+ backgroundColor: odysseyTokens.HueNeutral100,
857
+ border: `1px solid ${odysseyTokens.HueNeutral300}`,
858
+ cursor: "default",
859
+ "&.Mui-checked, &.MuiCheckbox-indeterminate": {
860
+ backgroundColor: odysseyTokens.HueNeutral100,
861
+ borderColor: odysseyTokens.HueNeutral300,
862
+ [`.${formControlLabelClasses.root}:hover > &`]: {
863
+ backgroundColor: odysseyTokens.HueNeutral100,
864
+ borderColor: odysseyTokens.HueNeutral300
865
+ }
866
+ },
867
+ [`.${formControlLabelClasses.root}:hover > &`]: {
868
+ backgroundColor: odysseyTokens.HueNeutral100,
869
+ borderColor: odysseyTokens.HueNeutral300
870
+ },
871
+ [`.${svgIconClasses.root}`]: {
872
+ color: odysseyTokens.HueNeutral700
873
+ }
874
+ })
875
+ };
876
+ }
851
877
  }
852
878
  },
853
879
  MuiChip: {
@@ -1919,6 +1945,12 @@ export const components = ({
1919
1945
  }
1920
1946
  }
1921
1947
  },
1948
+ "&[data-empty='true']": {
1949
+ "&:after": {
1950
+ content: "'&nbsp;'",
1951
+ visibility: "hidden"
1952
+ }
1953
+ },
1922
1954
  ...(!ownerState.disableGutters && {
1923
1955
  paddingInline: odysseyTokens.Spacing4
1924
1956
  }),
@@ -1953,7 +1985,7 @@ export const components = ({
1953
1985
  },
1954
1986
  MuiModal: {
1955
1987
  defaultProps: {
1956
- container: shadowDomElement
1988
+ container: shadowRootElement || shadowDomElement
1957
1989
  }
1958
1990
  },
1959
1991
  MuiNativeSelect: {
@@ -1988,7 +2020,7 @@ export const components = ({
1988
2020
  },
1989
2021
  MuiPopover: {
1990
2022
  defaultProps: {
1991
- container: shadowDomElement
2023
+ container: shadowRootElement || shadowDomElement
1992
2024
  },
1993
2025
  styleOverrides: {
1994
2026
  paper: {
@@ -2001,7 +2033,7 @@ export const components = ({
2001
2033
  },
2002
2034
  MuiPopper: {
2003
2035
  defaultProps: {
2004
- container: shadowDomElement
2036
+ container: shadowRootElement || shadowDomElement
2005
2037
  }
2006
2038
  },
2007
2039
  MuiRadio: {
@@ -2012,73 +2044,100 @@ export const components = ({
2012
2044
  },
2013
2045
  styleOverrides: {
2014
2046
  root: ({
2047
+ ownerState,
2015
2048
  theme
2016
- }) => ({
2017
- position: "relative",
2018
- insetBlockStart: `${2 / theme.typography.fontSize}rem`,
2019
- width: `${odysseyTokens.TypographyLineHeightUi}em`,
2020
- minWidth: `${odysseyTokens.TypographyLineHeightUi}em`,
2021
- height: `${odysseyTokens.TypographyLineHeightUi}em`,
2022
- borderRadius: `${odysseyTokens.TypographyLineHeightUi}em`,
2023
- borderWidth: odysseyTokens.BorderWidthMain,
2024
- borderStyle: odysseyTokens.BorderStyleMain,
2025
- borderColor: odysseyTokens.HueNeutral500,
2026
- padding: 0,
2027
- boxShadow: `0 0 0 0 transparent`,
2028
- transition: theme.transitions.create(["border-color", "background-color", "box-shadow"], {
2029
- duration: odysseyTokens.TransitionDurationMain
2030
- }),
2031
- "&::before": {
2032
- content: "''",
2033
- position: "absolute",
2034
- width: odysseyTokens.Spacing2,
2035
- height: odysseyTokens.Spacing2,
2036
- borderRadius: "50%",
2037
- backgroundColor: "transparent",
2038
- transition: theme.transitions.create(["background-color"], {
2049
+ }) => {
2050
+ const isReadOnly = ownerState?.inputProps?.readOnly;
2051
+ return {
2052
+ position: "relative",
2053
+ insetBlockStart: `${2 / theme.typography.fontSize}rem`,
2054
+ width: `${odysseyTokens.TypographyLineHeightUi}em`,
2055
+ minWidth: `${odysseyTokens.TypographyLineHeightUi}em`,
2056
+ height: `${odysseyTokens.TypographyLineHeightUi}em`,
2057
+ borderRadius: `${odysseyTokens.TypographyLineHeightUi}em`,
2058
+ borderWidth: odysseyTokens.BorderWidthMain,
2059
+ borderStyle: odysseyTokens.BorderStyleMain,
2060
+ borderColor: odysseyTokens.HueNeutral500,
2061
+ padding: 0,
2062
+ boxShadow: `0 0 0 0 transparent`,
2063
+ transition: theme.transitions.create(["border-color", "background-color", "box-shadow"], {
2039
2064
  duration: odysseyTokens.TransitionDurationMain
2040
- })
2041
- },
2042
- [`.${formControlLabelClasses.root}:hover > &`]: {
2043
- backgroundColor: "transparent",
2044
- borderColor: odysseyTokens.HueNeutral900
2045
- },
2046
- ".Mui-error:hover > &": {
2047
- backgroundColor: "transparent",
2048
- borderColor: odysseyTokens.BorderColorDangerDark,
2065
+ }),
2049
2066
  "&::before": {
2050
- backgroundColor: odysseyTokens.PaletteDangerDark
2051
- }
2052
- },
2053
- ".Mui-error > &": {
2054
- borderColor: odysseyTokens.BorderColorDangerControl,
2067
+ content: "''",
2068
+ position: "absolute",
2069
+ width: odysseyTokens.Spacing2,
2070
+ height: odysseyTokens.Spacing2,
2071
+ borderRadius: "50%",
2072
+ backgroundColor: "transparent",
2073
+ transition: theme.transitions.create(["background-color"], {
2074
+ duration: odysseyTokens.TransitionDurationMain
2075
+ })
2076
+ },
2077
+ [`.${formControlLabelClasses.root}:hover > &`]: {
2078
+ backgroundColor: "transparent",
2079
+ borderColor: odysseyTokens.HueNeutral900
2080
+ },
2081
+ ".Mui-error:hover > &": {
2082
+ backgroundColor: "transparent",
2083
+ borderColor: odysseyTokens.BorderColorDangerDark,
2084
+ "&::before": {
2085
+ backgroundColor: odysseyTokens.PaletteDangerDark
2086
+ }
2087
+ },
2088
+ ".Mui-error > &": {
2089
+ borderColor: odysseyTokens.BorderColorDangerControl,
2090
+ "&.Mui-focusVisible": {
2091
+ boxShadow: `0 0 0 2px ${odysseyTokens.HueNeutralWhite}, 0 0 0 4px ${odysseyTokens.PaletteDangerMain}`
2092
+ }
2093
+ },
2055
2094
  "&.Mui-focusVisible": {
2056
- boxShadow: `0 0 0 2px ${odysseyTokens.HueNeutralWhite}, 0 0 0 4px ${odysseyTokens.PaletteDangerMain}`
2057
- }
2058
- },
2059
- "&.Mui-focusVisible": {
2060
- borderColor: odysseyTokens.HueNeutral900,
2061
- boxShadow: `0 0 0 2px ${odysseyTokens.HueNeutralWhite}, 0 0 0 4px ${odysseyTokens.PalettePrimaryMain}`,
2062
- outline: "2px solid transparent",
2063
- outlineOffset: "1px"
2064
- },
2065
- "&.Mui-checked": {
2066
- position: "relative",
2067
- "&::before": {
2068
- backgroundColor: odysseyTokens.PalettePrimaryMain
2069
- }
2070
- },
2071
- ".Mui-error > &.Mui-checked::before": {
2072
- backgroundColor: odysseyTokens.PaletteDangerMain
2073
- },
2074
- "&.Mui-disabled": {
2075
- backgroundColor: odysseyTokens.HueNeutral50,
2076
- borderColor: odysseyTokens.BorderColorDisabled,
2077
- "&.Mui-checked::before": {
2078
- backgroundColor: odysseyTokens.BorderColorDisabled
2079
- }
2080
- }
2081
- })
2095
+ borderColor: odysseyTokens.HueNeutral900,
2096
+ boxShadow: `0 0 0 2px ${odysseyTokens.HueNeutralWhite}, 0 0 0 4px ${odysseyTokens.PalettePrimaryMain}`,
2097
+ outline: "2px solid transparent",
2098
+ outlineOffset: "1px"
2099
+ },
2100
+ "&.Mui-checked": {
2101
+ position: "relative",
2102
+ "&::before": {
2103
+ backgroundColor: odysseyTokens.PalettePrimaryMain
2104
+ }
2105
+ },
2106
+ ".Mui-error > &.Mui-checked::before": {
2107
+ backgroundColor: odysseyTokens.PaletteDangerMain
2108
+ },
2109
+ "&.Mui-disabled": {
2110
+ backgroundColor: odysseyTokens.HueNeutral50,
2111
+ borderColor: odysseyTokens.BorderColorDisabled,
2112
+ "&.Mui-checked::before": {
2113
+ backgroundColor: odysseyTokens.BorderColorDisabled
2114
+ }
2115
+ },
2116
+ ...(isReadOnly && {
2117
+ backgroundColor: odysseyTokens.HueNeutral100,
2118
+ borderColor: odysseyTokens.HueNeutral300,
2119
+ cursor: "default",
2120
+ "&::before": {
2121
+ content: "''",
2122
+ position: "absolute",
2123
+ width: odysseyTokens.Spacing2,
2124
+ height: odysseyTokens.Spacing2,
2125
+ borderRadius: "50%",
2126
+ backgroundColor: "transparent",
2127
+ transition: theme.transitions.create(["background-color"], {
2128
+ duration: odysseyTokens.TransitionDurationMain
2129
+ })
2130
+ },
2131
+ "&.Mui-checked::before": {
2132
+ backgroundColor: odysseyTokens.HueNeutral700
2133
+ },
2134
+ [`.${formControlLabelClasses.root}:hover > &`]: {
2135
+ backgroundColor: odysseyTokens.HueNeutral100,
2136
+ borderColor: odysseyTokens.HueNeutral300
2137
+ }
2138
+ })
2139
+ };
2140
+ }
2082
2141
  }
2083
2142
  },
2084
2143
  MuiSnackbar: {
@@ -2107,11 +2166,34 @@ export const components = ({
2107
2166
  }
2108
2167
  },
2109
2168
  styleOverrides: {
2110
- select: {
2169
+ root: ({
2170
+ ownerState
2171
+ }) => ({
2172
+ ...(ownerState?.inputProps?.readOnly && {
2173
+ "&.MuiInputBase-root": {
2174
+ backgroundColor: odysseyTokens.HueNeutral50,
2175
+ borderColor: odysseyTokens.HueNeutral200,
2176
+ "&:hover": {
2177
+ backgroundColor: odysseyTokens.HueNeutral50
2178
+ },
2179
+ "&.Mui-focused": {
2180
+ borderColor: odysseyTokens.PalettePrimaryMain
2181
+ }
2182
+ }
2183
+ }),
2184
+ "& .MuiSelect-icon": {
2185
+ right: "unset",
2186
+ insetInlineEnd: odysseyTokens.Spacing3,
2187
+ color: odysseyTokens.TypographyColorSubordinate
2188
+ }
2189
+ }),
2190
+ select: ({
2191
+ ownerState
2192
+ }) => ({
2111
2193
  height: "auto",
2112
2194
  paddingBlock: `calc(${odysseyTokens.Spacing3} - ${odysseyTokens.BorderWidthMain})`,
2113
2195
  paddingInline: odysseyTokens.Spacing3,
2114
- minHeight: 0,
2196
+ minHeight: `${odysseyTokens.TypographyLineHeightUi}em`,
2115
2197
  "&:focus": {
2116
2198
  backgroundColor: "transparent"
2117
2199
  },
@@ -2124,13 +2206,16 @@ export const components = ({
2124
2206
  },
2125
2207
  ["& .MuiListItemSecondaryAction-root"]: {
2126
2208
  display: "none"
2127
- }
2128
- },
2129
- icon: {
2130
- right: "unset",
2131
- insetInlineEnd: odysseyTokens.Spacing3,
2132
- color: odysseyTokens.TypographyColorSubordinate
2133
- }
2209
+ },
2210
+ ...(ownerState?.inputProps?.readOnly && {
2211
+ color: odysseyTokens.HueNeutral700,
2212
+ cursor: "default",
2213
+ "&:focus": {
2214
+ backgroundColor: "transparent",
2215
+ borderColor: odysseyTokens.PalettePrimaryMain
2216
+ }
2217
+ })
2218
+ })
2134
2219
  }
2135
2220
  },
2136
2221
  MuiSvgIcon: {