@mitodl/smoot-design 0.0.0-0a23f44

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 (325) hide show
  1. package/LICENSE +28 -0
  2. package/README.md +35 -0
  3. package/dist/bundles/aiDrawerManager.es.js +38832 -0
  4. package/dist/bundles/aiDrawerManager.es.js.map +1 -0
  5. package/dist/bundles/aiDrawerManager.umd.js +245 -0
  6. package/dist/bundles/aiDrawerManager.umd.js.map +1 -0
  7. package/dist/bundles/remoteTutorDrawer.es.js +38832 -0
  8. package/dist/bundles/remoteTutorDrawer.es.js.map +1 -0
  9. package/dist/bundles/remoteTutorDrawer.umd.js +245 -0
  10. package/dist/bundles/remoteTutorDrawer.umd.js.map +1 -0
  11. package/dist/cjs/VERSION.d.ts +12 -0
  12. package/dist/cjs/VERSION.js +15 -0
  13. package/dist/cjs/ai.d.ts +3 -0
  14. package/dist/cjs/ai.js +9 -0
  15. package/dist/cjs/bundles/AiDrawer/AiDrawer.d.ts +55 -0
  16. package/dist/cjs/bundles/AiDrawer/AiDrawer.js +262 -0
  17. package/dist/cjs/bundles/AiDrawer/AiDrawer.stories.d.ts +17 -0
  18. package/dist/cjs/bundles/AiDrawer/AiDrawer.stories.js +264 -0
  19. package/dist/cjs/bundles/AiDrawer/AiDrawerManager.d.ts +12 -0
  20. package/dist/cjs/bundles/AiDrawer/AiDrawerManager.js +51 -0
  21. package/dist/cjs/bundles/AiDrawer/AiDrawerManager.stories.d.ts +6 -0
  22. package/dist/cjs/bundles/AiDrawer/AiDrawerManager.stories.js +267 -0
  23. package/dist/cjs/bundles/AiDrawer/AiDrawerManager.test.d.ts +1 -0
  24. package/dist/cjs/bundles/AiDrawer/AiDrawerManager.test.js +245 -0
  25. package/dist/cjs/bundles/AiDrawer/FlashcardsScreen.d.ts +9 -0
  26. package/dist/cjs/bundles/AiDrawer/FlashcardsScreen.js +87 -0
  27. package/dist/cjs/bundles/aiDrawerManager.d.ts +6 -0
  28. package/dist/cjs/bundles/aiDrawerManager.js +44 -0
  29. package/dist/cjs/components/AiChat/AiChat.d.ts +5 -0
  30. package/dist/cjs/components/AiChat/AiChat.js +267 -0
  31. package/dist/cjs/components/AiChat/AiChat.stories.d.ts +17 -0
  32. package/dist/cjs/components/AiChat/AiChat.stories.js +194 -0
  33. package/dist/cjs/components/AiChat/AiChat.test.d.ts +1 -0
  34. package/dist/cjs/components/AiChat/AiChat.test.js +211 -0
  35. package/dist/cjs/components/AiChat/AiChatContext.d.ts +26 -0
  36. package/dist/cjs/components/AiChat/AiChatContext.js +106 -0
  37. package/dist/cjs/components/AiChat/AiChatContext.stories.d.ts +14 -0
  38. package/dist/cjs/components/AiChat/AiChatContext.stories.js +75 -0
  39. package/dist/cjs/components/AiChat/AiChatMarkdown.stories.d.ts +15 -0
  40. package/dist/cjs/components/AiChat/AiChatMarkdown.stories.js +282 -0
  41. package/dist/cjs/components/AiChat/ChatTitle.d.ts +8 -0
  42. package/dist/cjs/components/AiChat/ChatTitle.js +43 -0
  43. package/dist/cjs/components/AiChat/EllipsisIcon.d.ts +6 -0
  44. package/dist/cjs/components/AiChat/EllipsisIcon.js +17 -0
  45. package/dist/cjs/components/AiChat/EntryScreen.d.ts +11 -0
  46. package/dist/cjs/components/AiChat/EntryScreen.js +123 -0
  47. package/dist/cjs/components/AiChat/Markdown.d.ts +7 -0
  48. package/dist/cjs/components/AiChat/Markdown.js +14 -0
  49. package/dist/cjs/components/AiChat/TimLogo.d.ts +5 -0
  50. package/dist/cjs/components/AiChat/TimLogo.js +15 -0
  51. package/dist/cjs/components/AiChat/test-utils/api.d.ts +2 -0
  52. package/dist/cjs/components/AiChat/test-utils/api.js +164 -0
  53. package/dist/cjs/components/AiChat/types.d.ts +96 -0
  54. package/dist/cjs/components/AiChat/types.js +3 -0
  55. package/dist/cjs/components/AiChat/utils.d.ts +9 -0
  56. package/dist/cjs/components/AiChat/utils.js +41 -0
  57. package/dist/cjs/components/Alert/Alert.d.ts +15 -0
  58. package/dist/cjs/components/Alert/Alert.js +62 -0
  59. package/dist/cjs/components/Alert/Alert.stories.d.ts +8 -0
  60. package/dist/cjs/components/Alert/Alert.stories.js +53 -0
  61. package/dist/cjs/components/Button/ActionButton.d.ts +30 -0
  62. package/dist/cjs/components/Button/ActionButton.js +73 -0
  63. package/dist/cjs/components/Button/ActionButton.stories.d.ts +15 -0
  64. package/dist/cjs/components/Button/ActionButton.stories.js +113 -0
  65. package/dist/cjs/components/Button/Button.d.ts +58 -0
  66. package/dist/cjs/components/Button/Button.js +261 -0
  67. package/dist/cjs/components/Button/Button.stories.d.ts +18 -0
  68. package/dist/cjs/components/Button/Button.stories.js +148 -0
  69. package/dist/cjs/components/Button/Button.test.d.ts +1 -0
  70. package/dist/cjs/components/Button/Button.test.js +46 -0
  71. package/dist/cjs/components/Checkbox/Checkbox.d.ts +20 -0
  72. package/dist/cjs/components/Checkbox/Checkbox.js +85 -0
  73. package/dist/cjs/components/Checkbox/Checkbox.stories.d.ts +8 -0
  74. package/dist/cjs/components/Checkbox/Checkbox.stories.js +33 -0
  75. package/dist/cjs/components/CheckboxChoiceField/CheckboxChoiceField.d.ts +21 -0
  76. package/dist/cjs/components/CheckboxChoiceField/CheckboxChoiceField.js +43 -0
  77. package/dist/cjs/components/CheckboxChoiceField/CheckboxChoiceField.stories.d.ts +8 -0
  78. package/dist/cjs/components/CheckboxChoiceField/CheckboxChoiceField.stories.js +50 -0
  79. package/dist/cjs/components/CheckboxChoiceField/CheckboxChoiceField.test.d.ts +1 -0
  80. package/dist/cjs/components/CheckboxChoiceField/CheckboxChoiceField.test.js +52 -0
  81. package/dist/cjs/components/ImageAdapter/ImageAdapter.d.ts +23 -0
  82. package/dist/cjs/components/ImageAdapter/ImageAdapter.js +30 -0
  83. package/dist/cjs/components/Input/Input.d.ts +116 -0
  84. package/dist/cjs/components/Input/Input.js +237 -0
  85. package/dist/cjs/components/Input/Input.stories.d.ts +19 -0
  86. package/dist/cjs/components/Input/Input.stories.js +135 -0
  87. package/dist/cjs/components/Input/Input.test.d.ts +1 -0
  88. package/dist/cjs/components/Input/Input.test.js +32 -0
  89. package/dist/cjs/components/LinkAdapter/LinkAdapter.d.ts +23 -0
  90. package/dist/cjs/components/LinkAdapter/LinkAdapter.js +34 -0
  91. package/dist/cjs/components/RadioChoiceField/BooleanRadioChoiceField.stories.d.ts +6 -0
  92. package/dist/cjs/components/RadioChoiceField/BooleanRadioChoiceField.stories.js +47 -0
  93. package/dist/cjs/components/RadioChoiceField/RadioChoiceField.d.ts +45 -0
  94. package/dist/cjs/components/RadioChoiceField/RadioChoiceField.js +69 -0
  95. package/dist/cjs/components/RadioChoiceField/RadioChoiceField.stories.d.ts +6 -0
  96. package/dist/cjs/components/RadioChoiceField/RadioChoiceField.stories.js +55 -0
  97. package/dist/cjs/components/RadioChoiceField/RadioChoiceField.test.d.ts +1 -0
  98. package/dist/cjs/components/RadioChoiceField/RadioChoiceField.test.js +53 -0
  99. package/dist/cjs/components/ScrollSnap/ScrollSnap.d.ts +19 -0
  100. package/dist/cjs/components/ScrollSnap/ScrollSnap.js +59 -0
  101. package/dist/cjs/components/ScrollSnap/ScrollSnap.stories.d.ts +6 -0
  102. package/dist/cjs/components/ScrollSnap/ScrollSnap.stories.js +43 -0
  103. package/dist/cjs/components/ScrollSnap/useScrollSnap.d.ts +6 -0
  104. package/dist/cjs/components/ScrollSnap/useScrollSnap.js +36 -0
  105. package/dist/cjs/components/SrAnnouncer/SrAnnouncer.d.ts +25 -0
  106. package/dist/cjs/components/SrAnnouncer/SrAnnouncer.js +43 -0
  107. package/dist/cjs/components/SrAnnouncer/SrAnnouncer.stories.d.ts +6 -0
  108. package/dist/cjs/components/SrAnnouncer/SrAnnouncer.stories.js +44 -0
  109. package/dist/cjs/components/SrAnnouncer/SrAnnouncer.test.d.ts +1 -0
  110. package/dist/cjs/components/SrAnnouncer/SrAnnouncer.test.js +62 -0
  111. package/dist/cjs/components/TabButtons/TabButtonList.d.ts +25 -0
  112. package/dist/cjs/components/TabButtons/TabButtonList.js +97 -0
  113. package/dist/cjs/components/TabButtons/TabButtonList.stories.d.ts +24 -0
  114. package/dist/cjs/components/TabButtons/TabButtonList.stories.js +139 -0
  115. package/dist/cjs/components/TextField/TextField.d.ts +29 -0
  116. package/dist/cjs/components/TextField/TextField.js +33 -0
  117. package/dist/cjs/components/TextField/TextField.stories.d.ts +10 -0
  118. package/dist/cjs/components/TextField/TextField.stories.js +136 -0
  119. package/dist/cjs/components/TextField/TextField.test.d.ts +1 -0
  120. package/dist/cjs/components/TextField/TextField.test.js +77 -0
  121. package/dist/cjs/components/ThemeProvider/ThemeProvider.d.ts +21 -0
  122. package/dist/cjs/components/ThemeProvider/ThemeProvider.js +86 -0
  123. package/dist/cjs/components/ThemeProvider/ThemeProvider.stories.d.ts +63 -0
  124. package/dist/cjs/components/ThemeProvider/ThemeProvider.stories.js +102 -0
  125. package/dist/cjs/components/ThemeProvider/Typography.stories.d.ts +39 -0
  126. package/dist/cjs/components/ThemeProvider/Typography.stories.js +65 -0
  127. package/dist/cjs/components/ThemeProvider/breakpoints.d.ts +4 -0
  128. package/dist/cjs/components/ThemeProvider/breakpoints.js +19 -0
  129. package/dist/cjs/components/ThemeProvider/buttons.d.ts +7 -0
  130. package/dist/cjs/components/ThemeProvider/buttons.js +20 -0
  131. package/dist/cjs/components/ThemeProvider/chips.d.ts +3 -0
  132. package/dist/cjs/components/ThemeProvider/chips.js +154 -0
  133. package/dist/cjs/components/ThemeProvider/colors.d.ts +32 -0
  134. package/dist/cjs/components/ThemeProvider/colors.js +35 -0
  135. package/dist/cjs/components/ThemeProvider/typography.d.ts +18 -0
  136. package/dist/cjs/components/ThemeProvider/typography.js +173 -0
  137. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.d.ts +24 -0
  138. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.js +33 -0
  139. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.stories.d.ts +6 -0
  140. package/dist/cjs/components/VisuallyHidden/VisuallyHidden.stories.js +13 -0
  141. package/dist/cjs/components/internal/FormHelpers/FormHelpers.d.ts +39 -0
  142. package/dist/cjs/components/internal/FormHelpers/FormHelpers.js +78 -0
  143. package/dist/cjs/components/internal/FormHelpers/FormHelpers.test.d.ts +1 -0
  144. package/dist/cjs/components/internal/FormHelpers/FormHelpers.test.js +93 -0
  145. package/dist/cjs/index.d.ts +25 -0
  146. package/dist/cjs/index.js +44 -0
  147. package/dist/cjs/jest-setup.d.ts +1 -0
  148. package/dist/cjs/jest-setup.js +18 -0
  149. package/dist/cjs/jsdom-extended.d.ts +6 -0
  150. package/dist/cjs/jsdom-extended.js +14 -0
  151. package/dist/cjs/story-utils/index.d.ts +6 -0
  152. package/dist/cjs/story-utils/index.js +17 -0
  153. package/dist/cjs/utils/composeRefs.d.ts +7 -0
  154. package/dist/cjs/utils/composeRefs.js +20 -0
  155. package/dist/cjs/utils/composeRefs.test.d.ts +1 -0
  156. package/dist/cjs/utils/composeRefs.test.js +19 -0
  157. package/dist/cjs/utils/retryingFetch.d.ts +19 -0
  158. package/dist/cjs/utils/retryingFetch.js +98 -0
  159. package/dist/cjs/utils/retryingFetch.test.d.ts +1 -0
  160. package/dist/cjs/utils/retryingFetch.test.js +48 -0
  161. package/dist/cjs/utils/useDevCheckStable.d.ts +8 -0
  162. package/dist/cjs/utils/useDevCheckStable.js +29 -0
  163. package/dist/cjs/utils/useInterval.d.ts +7 -0
  164. package/dist/cjs/utils/useInterval.js +25 -0
  165. package/dist/esm/VERSION.d.ts +12 -0
  166. package/dist/esm/VERSION.js +12 -0
  167. package/dist/esm/ai.d.ts +3 -0
  168. package/dist/esm/ai.js +2 -0
  169. package/dist/esm/bundles/AiDrawer/AiDrawer.d.ts +55 -0
  170. package/dist/esm/bundles/AiDrawer/AiDrawer.js +259 -0
  171. package/dist/esm/bundles/AiDrawer/AiDrawer.stories.d.ts +17 -0
  172. package/dist/esm/bundles/AiDrawer/AiDrawer.stories.js +261 -0
  173. package/dist/esm/bundles/AiDrawer/AiDrawerManager.d.ts +12 -0
  174. package/dist/esm/bundles/AiDrawer/AiDrawerManager.js +48 -0
  175. package/dist/esm/bundles/AiDrawer/AiDrawerManager.stories.d.ts +6 -0
  176. package/dist/esm/bundles/AiDrawer/AiDrawerManager.stories.js +264 -0
  177. package/dist/esm/bundles/AiDrawer/AiDrawerManager.test.d.ts +1 -0
  178. package/dist/esm/bundles/AiDrawer/AiDrawerManager.test.js +243 -0
  179. package/dist/esm/bundles/AiDrawer/FlashcardsScreen.d.ts +9 -0
  180. package/dist/esm/bundles/AiDrawer/FlashcardsScreen.js +83 -0
  181. package/dist/esm/bundles/aiDrawerManager.d.ts +6 -0
  182. package/dist/esm/bundles/aiDrawerManager.js +41 -0
  183. package/dist/esm/components/AiChat/AiChat.d.ts +5 -0
  184. package/dist/esm/components/AiChat/AiChat.js +263 -0
  185. package/dist/esm/components/AiChat/AiChat.stories.d.ts +17 -0
  186. package/dist/esm/components/AiChat/AiChat.stories.js +191 -0
  187. package/dist/esm/components/AiChat/AiChat.test.d.ts +1 -0
  188. package/dist/esm/components/AiChat/AiChat.test.js +209 -0
  189. package/dist/esm/components/AiChat/AiChatContext.d.ts +26 -0
  190. package/dist/esm/components/AiChat/AiChatContext.js +102 -0
  191. package/dist/esm/components/AiChat/AiChatContext.stories.d.ts +14 -0
  192. package/dist/esm/components/AiChat/AiChatContext.stories.js +72 -0
  193. package/dist/esm/components/AiChat/AiChatMarkdown.stories.d.ts +15 -0
  194. package/dist/esm/components/AiChat/AiChatMarkdown.stories.js +279 -0
  195. package/dist/esm/components/AiChat/ChatTitle.d.ts +8 -0
  196. package/dist/esm/components/AiChat/ChatTitle.js +40 -0
  197. package/dist/esm/components/AiChat/EllipsisIcon.d.ts +6 -0
  198. package/dist/esm/components/AiChat/EllipsisIcon.js +15 -0
  199. package/dist/esm/components/AiChat/EntryScreen.d.ts +11 -0
  200. package/dist/esm/components/AiChat/EntryScreen.js +120 -0
  201. package/dist/esm/components/AiChat/Markdown.d.ts +7 -0
  202. package/dist/esm/components/AiChat/Markdown.js +12 -0
  203. package/dist/esm/components/AiChat/TimLogo.d.ts +5 -0
  204. package/dist/esm/components/AiChat/TimLogo.js +13 -0
  205. package/dist/esm/components/AiChat/test-utils/api.d.ts +2 -0
  206. package/dist/esm/components/AiChat/test-utils/api.js +161 -0
  207. package/dist/esm/components/AiChat/types.d.ts +96 -0
  208. package/dist/esm/components/AiChat/types.js +2 -0
  209. package/dist/esm/components/AiChat/utils.d.ts +9 -0
  210. package/dist/esm/components/AiChat/utils.js +38 -0
  211. package/dist/esm/components/Alert/Alert.d.ts +15 -0
  212. package/dist/esm/components/Alert/Alert.js +59 -0
  213. package/dist/esm/components/Alert/Alert.stories.d.ts +8 -0
  214. package/dist/esm/components/Alert/Alert.stories.js +50 -0
  215. package/dist/esm/components/Button/ActionButton.d.ts +30 -0
  216. package/dist/esm/components/Button/ActionButton.js +68 -0
  217. package/dist/esm/components/Button/ActionButton.stories.d.ts +15 -0
  218. package/dist/esm/components/Button/ActionButton.stories.js +110 -0
  219. package/dist/esm/components/Button/Button.d.ts +58 -0
  220. package/dist/esm/components/Button/Button.js +252 -0
  221. package/dist/esm/components/Button/Button.stories.d.ts +18 -0
  222. package/dist/esm/components/Button/Button.stories.js +145 -0
  223. package/dist/esm/components/Button/Button.test.d.ts +1 -0
  224. package/dist/esm/components/Button/Button.test.js +44 -0
  225. package/dist/esm/components/Checkbox/Checkbox.d.ts +20 -0
  226. package/dist/esm/components/Checkbox/Checkbox.js +81 -0
  227. package/dist/esm/components/Checkbox/Checkbox.stories.d.ts +8 -0
  228. package/dist/esm/components/Checkbox/Checkbox.stories.js +30 -0
  229. package/dist/esm/components/CheckboxChoiceField/CheckboxChoiceField.d.ts +21 -0
  230. package/dist/esm/components/CheckboxChoiceField/CheckboxChoiceField.js +40 -0
  231. package/dist/esm/components/CheckboxChoiceField/CheckboxChoiceField.stories.d.ts +8 -0
  232. package/dist/esm/components/CheckboxChoiceField/CheckboxChoiceField.stories.js +47 -0
  233. package/dist/esm/components/CheckboxChoiceField/CheckboxChoiceField.test.d.ts +1 -0
  234. package/dist/esm/components/CheckboxChoiceField/CheckboxChoiceField.test.js +50 -0
  235. package/dist/esm/components/ImageAdapter/ImageAdapter.d.ts +23 -0
  236. package/dist/esm/components/ImageAdapter/ImageAdapter.js +27 -0
  237. package/dist/esm/components/Input/Input.d.ts +116 -0
  238. package/dist/esm/components/Input/Input.js +232 -0
  239. package/dist/esm/components/Input/Input.stories.d.ts +19 -0
  240. package/dist/esm/components/Input/Input.stories.js +132 -0
  241. package/dist/esm/components/Input/Input.test.d.ts +1 -0
  242. package/dist/esm/components/Input/Input.test.js +30 -0
  243. package/dist/esm/components/LinkAdapter/LinkAdapter.d.ts +23 -0
  244. package/dist/esm/components/LinkAdapter/LinkAdapter.js +31 -0
  245. package/dist/esm/components/RadioChoiceField/BooleanRadioChoiceField.stories.d.ts +6 -0
  246. package/dist/esm/components/RadioChoiceField/BooleanRadioChoiceField.stories.js +44 -0
  247. package/dist/esm/components/RadioChoiceField/RadioChoiceField.d.ts +45 -0
  248. package/dist/esm/components/RadioChoiceField/RadioChoiceField.js +65 -0
  249. package/dist/esm/components/RadioChoiceField/RadioChoiceField.stories.d.ts +6 -0
  250. package/dist/esm/components/RadioChoiceField/RadioChoiceField.stories.js +52 -0
  251. package/dist/esm/components/RadioChoiceField/RadioChoiceField.test.d.ts +1 -0
  252. package/dist/esm/components/RadioChoiceField/RadioChoiceField.test.js +51 -0
  253. package/dist/esm/components/ScrollSnap/ScrollSnap.d.ts +19 -0
  254. package/dist/esm/components/ScrollSnap/ScrollSnap.js +56 -0
  255. package/dist/esm/components/ScrollSnap/ScrollSnap.stories.d.ts +6 -0
  256. package/dist/esm/components/ScrollSnap/ScrollSnap.stories.js +40 -0
  257. package/dist/esm/components/ScrollSnap/useScrollSnap.d.ts +6 -0
  258. package/dist/esm/components/ScrollSnap/useScrollSnap.js +33 -0
  259. package/dist/esm/components/SrAnnouncer/SrAnnouncer.d.ts +25 -0
  260. package/dist/esm/components/SrAnnouncer/SrAnnouncer.js +40 -0
  261. package/dist/esm/components/SrAnnouncer/SrAnnouncer.stories.d.ts +6 -0
  262. package/dist/esm/components/SrAnnouncer/SrAnnouncer.stories.js +41 -0
  263. package/dist/esm/components/SrAnnouncer/SrAnnouncer.test.d.ts +1 -0
  264. package/dist/esm/components/SrAnnouncer/SrAnnouncer.test.js +60 -0
  265. package/dist/esm/components/TabButtons/TabButtonList.d.ts +25 -0
  266. package/dist/esm/components/TabButtons/TabButtonList.js +92 -0
  267. package/dist/esm/components/TabButtons/TabButtonList.stories.d.ts +24 -0
  268. package/dist/esm/components/TabButtons/TabButtonList.stories.js +136 -0
  269. package/dist/esm/components/TextField/TextField.d.ts +29 -0
  270. package/dist/esm/components/TextField/TextField.js +30 -0
  271. package/dist/esm/components/TextField/TextField.stories.d.ts +10 -0
  272. package/dist/esm/components/TextField/TextField.stories.js +133 -0
  273. package/dist/esm/components/TextField/TextField.test.d.ts +1 -0
  274. package/dist/esm/components/TextField/TextField.test.js +75 -0
  275. package/dist/esm/components/ThemeProvider/ThemeProvider.d.ts +21 -0
  276. package/dist/esm/components/ThemeProvider/ThemeProvider.js +82 -0
  277. package/dist/esm/components/ThemeProvider/ThemeProvider.stories.d.ts +63 -0
  278. package/dist/esm/components/ThemeProvider/ThemeProvider.stories.js +99 -0
  279. package/dist/esm/components/ThemeProvider/Typography.stories.d.ts +39 -0
  280. package/dist/esm/components/ThemeProvider/Typography.stories.js +62 -0
  281. package/dist/esm/components/ThemeProvider/breakpoints.d.ts +4 -0
  282. package/dist/esm/components/ThemeProvider/breakpoints.js +15 -0
  283. package/dist/esm/components/ThemeProvider/buttons.d.ts +7 -0
  284. package/dist/esm/components/ThemeProvider/buttons.js +17 -0
  285. package/dist/esm/components/ThemeProvider/chips.d.ts +3 -0
  286. package/dist/esm/components/ThemeProvider/chips.js +151 -0
  287. package/dist/esm/components/ThemeProvider/colors.d.ts +32 -0
  288. package/dist/esm/components/ThemeProvider/colors.js +32 -0
  289. package/dist/esm/components/ThemeProvider/typography.d.ts +18 -0
  290. package/dist/esm/components/ThemeProvider/typography.js +167 -0
  291. package/dist/esm/components/VisuallyHidden/VisuallyHidden.d.ts +24 -0
  292. package/dist/esm/components/VisuallyHidden/VisuallyHidden.js +30 -0
  293. package/dist/esm/components/VisuallyHidden/VisuallyHidden.stories.d.ts +6 -0
  294. package/dist/esm/components/VisuallyHidden/VisuallyHidden.stories.js +10 -0
  295. package/dist/esm/components/internal/FormHelpers/FormHelpers.d.ts +39 -0
  296. package/dist/esm/components/internal/FormHelpers/FormHelpers.js +73 -0
  297. package/dist/esm/components/internal/FormHelpers/FormHelpers.test.d.ts +1 -0
  298. package/dist/esm/components/internal/FormHelpers/FormHelpers.test.js +91 -0
  299. package/dist/esm/index.d.ts +25 -0
  300. package/dist/esm/index.js +16 -0
  301. package/dist/esm/jest-setup.d.ts +1 -0
  302. package/dist/esm/jest-setup.js +16 -0
  303. package/dist/esm/jsdom-extended.d.ts +6 -0
  304. package/dist/esm/jsdom-extended.js +12 -0
  305. package/dist/esm/story-utils/index.d.ts +6 -0
  306. package/dist/esm/story-utils/index.js +13 -0
  307. package/dist/esm/utils/composeRefs.d.ts +7 -0
  308. package/dist/esm/utils/composeRefs.js +17 -0
  309. package/dist/esm/utils/composeRefs.test.d.ts +1 -0
  310. package/dist/esm/utils/composeRefs.test.js +17 -0
  311. package/dist/esm/utils/retryingFetch.d.ts +19 -0
  312. package/dist/esm/utils/retryingFetch.js +96 -0
  313. package/dist/esm/utils/retryingFetch.test.d.ts +1 -0
  314. package/dist/esm/utils/retryingFetch.test.js +46 -0
  315. package/dist/esm/utils/useDevCheckStable.d.ts +8 -0
  316. package/dist/esm/utils/useDevCheckStable.js +26 -0
  317. package/dist/esm/utils/useInterval.d.ts +7 -0
  318. package/dist/esm/utils/useInterval.js +22 -0
  319. package/dist/tsconfig.tsbuildinfo +1 -0
  320. package/dist/type-augmentation/TypescriptDocs.mdx +17 -0
  321. package/dist/type-augmentation/imports.d.ts +3 -0
  322. package/dist/type-augmentation/index.d.ts +3 -0
  323. package/dist/type-augmentation/theme.d.ts +105 -0
  324. package/dist/type-augmentation/typography.d.ts +54 -0
  325. package/package.json +159 -0
@@ -0,0 +1,139 @@
1
+ "use strict";
2
+ var __rest = (this && this.__rest) || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
+ t[p] = s[p];
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
+ t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.LinkTabs = exports.ManyButtonTabs = exports.ButtonTabsChatVariant = exports.ButtonTabs = void 0;
15
+ /* eslint-disable react-hooks/rules-of-hooks */
16
+ const React = require("react");
17
+ const react_1 = require("react");
18
+ const TabButtonList_1 = require("./TabButtonList");
19
+ const TabContext_1 = require("@mui/lab/TabContext");
20
+ const Button_1 = require("../Button/Button");
21
+ const Stack_1 = require("@mui/material/Stack");
22
+ const TabPanel_1 = require("@mui/lab/TabPanel");
23
+ const Typography_1 = require("@mui/material/Typography");
24
+ const en_1 = require("@faker-js/faker/locale/en");
25
+ const Container_1 = require("@mui/material/Container");
26
+ const meta = {
27
+ title: "smoot-design/TabButtons",
28
+ argTypes: {
29
+ variant: {
30
+ options: ["scrollable", "fullWidth", "standard"],
31
+ control: { type: "radio" },
32
+ },
33
+ styleVariant: {
34
+ options: ["default", "chat"],
35
+ control: { type: "radio" },
36
+ defaultValue: "default",
37
+ },
38
+ scrollButtons: {
39
+ options: ["auto", true, false],
40
+ control: { type: "radio" },
41
+ },
42
+ },
43
+ args: {
44
+ count: 4,
45
+ variant: "scrollable",
46
+ allowScrollButtonsMobile: true,
47
+ scrollButtons: "auto",
48
+ },
49
+ render: (_a) => {
50
+ var { count } = _a, others = __rest(_a, ["count"]);
51
+ const [value, setValue] = React.useState("tab1");
52
+ return (React.createElement(Container_1.default, { maxWidth: "sm" },
53
+ React.createElement(TabContext_1.default, { value: value },
54
+ React.createElement(Stack_1.default, { direction: "row" },
55
+ React.createElement(TabButtonList_1.TabButtonList, Object.assign({}, others, { onChange: (_event, val) => setValue(val) }), Array(count)
56
+ .fill(null)
57
+ .map((_, i) => (React.createElement(TabButtonList_1.TabButton, { key: `tab-${i}`, value: `tab${i + 1}`, label: `Tab ${i + 1}` })))),
58
+ React.createElement(Stack_1.default, { direction: "row", justifyContent: "end", sx: { paddingLeft: "16px" } },
59
+ React.createElement(Button_1.Button, null, "Other UI"))),
60
+ Array(count)
61
+ .fill(null)
62
+ .map((_, i) => (React.createElement(TabPanel_1.default, { key: `tab-${i}`, value: `tab${i + 1}` },
63
+ React.createElement(Typography_1.default, { variant: "h4", component: "h4" },
64
+ "Header ",
65
+ i + 1),
66
+ en_1.faker.lorem.paragraphs(2)))))));
67
+ },
68
+ };
69
+ exports.default = meta;
70
+ /**
71
+ * Use `TabButtonList` and `TabButton` to render a list of tabs styled as our tertiary buttons:
72
+ */
73
+ exports.ButtonTabs = {};
74
+ /**
75
+ * `TabButtonList` chat style variant:
76
+ */
77
+ exports.ButtonTabsChatVariant = {
78
+ args: {
79
+ styleVariant: "chat",
80
+ variant: "fullWidth",
81
+ visibleScrollbar: false,
82
+ },
83
+ render: (_a) => {
84
+ var { count } = _a, others = __rest(_a, ["count"]);
85
+ const [value, setValue] = React.useState("tab1");
86
+ return (React.createElement(Container_1.default, { maxWidth: "sm" },
87
+ React.createElement(TabContext_1.default, { value: value },
88
+ React.createElement(Stack_1.default, { direction: "row" },
89
+ React.createElement(TabButtonList_1.TabButtonList, Object.assign({}, others, { onChange: (_event, val) => setValue(val) }), Array(count)
90
+ .fill(null)
91
+ .map((_, i) => (React.createElement(TabButtonList_1.TabButton, { key: `tab-${i}`, value: `tab${i + 1}`, label: `Tab ${i + 1}` }))))),
92
+ Array(count)
93
+ .fill(null)
94
+ .map((_, i) => (React.createElement(TabPanel_1.default, { key: `tab-${i}`, value: `tab${i + 1}` },
95
+ React.createElement(Typography_1.default, { variant: "h4", component: "h4" },
96
+ "Header ",
97
+ i + 1),
98
+ en_1.faker.lorem.paragraphs(2)))))));
99
+ },
100
+ };
101
+ /**
102
+ * By default, the tabs will be scrollable if there are too many to fit in the container:
103
+ */
104
+ exports.ManyButtonTabs = {
105
+ args: {
106
+ count: 12,
107
+ },
108
+ };
109
+ /**
110
+ * Use `TabButtonLink` for tabs that should affect the URL:
111
+ */
112
+ exports.LinkTabs = {
113
+ parameters: {
114
+ nextjs: {
115
+ appDirectory: true,
116
+ navigation: {
117
+ pathname: "/#link2",
118
+ },
119
+ },
120
+ },
121
+ render: () => {
122
+ const [hash, setHash] = (0, react_1.useState)(() => window.location.hash);
123
+ React.useEffect(() => {
124
+ const handler = () => setHash(window.location.hash);
125
+ window.addEventListener("hashchange", handler);
126
+ return () => {
127
+ window.removeEventListener("hashchange", handler);
128
+ };
129
+ }, []);
130
+ return (React.createElement("div", null,
131
+ "Current Location:",
132
+ React.createElement("pre", null, hash),
133
+ React.createElement(TabContext_1.default, { value: hash },
134
+ React.createElement(TabButtonList_1.TabButtonList, null,
135
+ React.createElement(TabButtonList_1.TabButtonLink, { value: "#link1", href: "#link1", label: "Tab 1" }),
136
+ React.createElement(TabButtonList_1.TabButtonLink, { value: "#link2", href: "#link2", label: "Tab 2" }),
137
+ React.createElement(TabButtonList_1.TabButtonLink, { value: "#link3", href: "#link3", label: "Tab 3" })))));
138
+ },
139
+ };
@@ -0,0 +1,29 @@
1
+ import * as React from "react";
2
+ import type { InputProps } from "../Input/Input";
3
+ import type { FormFieldWrapperProps } from "../internal/FormHelpers/FormHelpers";
4
+ type TextFieldProps = Omit<FormFieldWrapperProps, "children"> & {
5
+ name: string;
6
+ disabled?: boolean;
7
+ value?: string | null;
8
+ size?: InputProps["size"];
9
+ placeholder?: string;
10
+ onChange?: React.ChangeEventHandler<HTMLInputElement>;
11
+ onBlur?: React.FocusEventHandler<HTMLInputElement>;
12
+ fullWidth?: boolean;
13
+ /**
14
+ * Props forwarded to root of `<Input />`
15
+ */
16
+ InputProps?: InputProps;
17
+ } & Pick<InputProps, "type" | "startAdornment" | "endAdornment" | "multiline" | "required" | "minRows" | "inputProps">;
18
+ /**
19
+ * A form field for text input. Supports labels, help text, error text, and
20
+ * start/end adornments. Add `multiline` for a text area.
21
+ *
22
+ * - [TextField Documentation](https://mitodl.github.io/smoot-design/https://mitodl.github.io/smoot-design/)
23
+ *
24
+ * **Note:** This component shares a name a purpose with MUI's TextField, but
25
+ * does not share its entire API.
26
+ */
27
+ declare const TextField: React.FC<TextFieldProps>;
28
+ export { TextField };
29
+ export type { TextFieldProps };
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ var __rest = (this && this.__rest) || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
+ t[p] = s[p];
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
+ t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.TextField = void 0;
15
+ const React = require("react");
16
+ const Input_1 = require("../Input/Input");
17
+ const FormHelpers_1 = require("../internal/FormHelpers/FormHelpers");
18
+ /**
19
+ * A form field for text input. Supports labels, help text, error text, and
20
+ * start/end adornments. Add `multiline` for a text area.
21
+ *
22
+ * - [TextField Documentation](https://mitodl.github.io/smoot-design/https://mitodl.github.io/smoot-design/)
23
+ *
24
+ * **Note:** This component shares a name a purpose with MUI's TextField, but
25
+ * does not share its entire API.
26
+ */
27
+ const TextField = ({ label, size, value, name, placeholder, helpText, errorText, error, required, disabled, onChange, onBlur, multiline, type, startAdornment, endAdornment, minRows, className, id, InputProps, inputProps, fullWidth, }) => {
28
+ return (React.createElement(FormHelpers_1.FormFieldWrapper, { id: id, label: label, required: required, helpText: helpText, error: error, errorText: errorText, className: className, fullWidth: fullWidth }, (_a) => {
29
+ var { labelId } = _a, childProps = __rest(_a, ["labelId"]);
30
+ return (React.createElement(Input_1.Input, Object.assign({ size: size, value: value, name: name, placeholder: placeholder, onChange: onChange, onBlur: onBlur, multiline: multiline, type: type, startAdornment: startAdornment, endAdornment: endAdornment, minRows: minRows, disabled: disabled, inputProps: inputProps }, InputProps, childProps)));
31
+ }));
32
+ };
33
+ exports.TextField = TextField;
@@ -0,0 +1,10 @@
1
+ import type { Meta, StoryObj } from "@storybook/react";
2
+ import { TextField } from "./TextField";
3
+ declare const meta: Meta<typeof TextField>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof TextField>;
6
+ export declare const Simple: Story;
7
+ export declare const Sizes: Story;
8
+ export declare const Widths: Story;
9
+ export declare const Adornments: Story;
10
+ export declare const States: Story;
@@ -0,0 +1,136 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.States = exports.Adornments = exports.Widths = exports.Sizes = exports.Simple = void 0;
4
+ const React = require("react");
5
+ const TextField_1 = require("./TextField");
6
+ const Input_1 = require("../Input/Input");
7
+ const Stack_1 = require("@mui/material/Stack");
8
+ const Grid_1 = require("@mui/material/Grid");
9
+ const react_1 = require("@remixicon/react");
10
+ const test_1 = require("@storybook/test");
11
+ const story_utils_1 = require("../../story-utils");
12
+ const SIZES = (0, story_utils_1.enumValues)({
13
+ small: true,
14
+ medium: true,
15
+ large: true,
16
+ chat: true,
17
+ hero: true,
18
+ });
19
+ const ADORNMENTS = {
20
+ None: undefined,
21
+ SearchIcon: (React.createElement(Input_1.AdornmentButton, null,
22
+ React.createElement(react_1.RiSearchLine, null))),
23
+ CalendarTodayIcon: (React.createElement(Input_1.AdornmentButton, null,
24
+ React.createElement(react_1.RiCalendarLine, null))),
25
+ CloseIcon: (React.createElement(Input_1.AdornmentButton, null,
26
+ React.createElement(react_1.RiCloseLine, null))),
27
+ "Close and Calendar": (React.createElement(React.Fragment, null,
28
+ React.createElement(Input_1.AdornmentButton, null,
29
+ React.createElement(react_1.RiCloseLine, null)),
30
+ React.createElement(Input_1.AdornmentButton, null,
31
+ React.createElement(react_1.RiCalendarLine, null)))),
32
+ };
33
+ const meta = {
34
+ title: "smoot-design/TextField",
35
+ component: TextField_1.TextField,
36
+ argTypes: {
37
+ size: {
38
+ options: SIZES,
39
+ control: { type: "select" },
40
+ },
41
+ startAdornment: {
42
+ options: Object.keys(ADORNMENTS),
43
+ mapping: ADORNMENTS,
44
+ control: { type: "select" },
45
+ },
46
+ endAdornment: {
47
+ options: Object.keys(ADORNMENTS),
48
+ mapping: ADORNMENTS,
49
+ control: { type: "select" },
50
+ },
51
+ },
52
+ args: {
53
+ onChange: (0, test_1.fn)(),
54
+ multiline: false,
55
+ disabled: false,
56
+ value: "some value",
57
+ placeholder: "placeholder",
58
+ label: "Label",
59
+ helpText: "Help text the quick brown fox jumps over the lazy dog",
60
+ errorText: "Error text the quick brown fox jumps over the lazy dog",
61
+ },
62
+ };
63
+ exports.default = meta;
64
+ exports.Simple = {
65
+ render: (args) => {
66
+ return React.createElement(TextField_1.TextField, Object.assign({}, args));
67
+ },
68
+ };
69
+ exports.Sizes = {
70
+ render: (args) => {
71
+ return (React.createElement(Stack_1.default, { direction: "row", gap: 1 },
72
+ React.createElement(TextField_1.TextField, Object.assign({}, args, { size: "small" })),
73
+ React.createElement(TextField_1.TextField, Object.assign({}, args, { size: "medium" })),
74
+ React.createElement(TextField_1.TextField, Object.assign({}, args, { size: "large" })),
75
+ React.createElement(TextField_1.TextField, Object.assign({}, args, { size: "hero" }))));
76
+ },
77
+ argTypes: { size: { table: { disable: true } } },
78
+ };
79
+ exports.Widths = {
80
+ render: (args) => {
81
+ return (React.createElement(Stack_1.default, { direction: "column", gap: 1 },
82
+ React.createElement(TextField_1.TextField, Object.assign({}, args, { label: "default" })),
83
+ React.createElement(TextField_1.TextField, Object.assign({}, args, { label: "fullWidth", fullWidth: true }))));
84
+ },
85
+ argTypes: { fullWidth: { table: { disable: true } } },
86
+ };
87
+ exports.Adornments = {
88
+ render: (args) => {
89
+ const adornments = [
90
+ { startAdornment: ADORNMENTS.SearchIcon },
91
+ { endAdornment: ADORNMENTS.CloseIcon },
92
+ {
93
+ startAdornment: ADORNMENTS.SearchIcon,
94
+ endAdornment: ADORNMENTS["Close and Calendar"],
95
+ },
96
+ ];
97
+ return (React.createElement(Grid_1.default, { container: true, maxWidth: "600px", spacing: 2 }, Object.values(adornments).flatMap((props, i) => SIZES.map((size) => {
98
+ return (React.createElement(Grid_1.default, { item: true, xs: 6, key: `${i}-${size}` },
99
+ React.createElement(TextField_1.TextField, Object.assign({}, args, { size: size }, props))));
100
+ }))));
101
+ },
102
+ argTypes: {
103
+ startAdornment: { table: { disable: true } },
104
+ endAdornment: { table: { disable: true } },
105
+ },
106
+ };
107
+ exports.States = {
108
+ render: (args) => {
109
+ return (React.createElement(Grid_1.default, { container: true, spacing: 2, alignItems: "top", maxWidth: "400px" },
110
+ React.createElement(Grid_1.default, { item: true, xs: 4 }, "Placeholder"),
111
+ React.createElement(Grid_1.default, { item: true, xs: 8 },
112
+ React.createElement(TextField_1.TextField, Object.assign({}, args, { value: "" }))),
113
+ React.createElement(Grid_1.default, { item: true, xs: 4 }, "Default"),
114
+ React.createElement(Grid_1.default, { item: true, xs: 8 },
115
+ React.createElement(TextField_1.TextField, Object.assign({}, args))),
116
+ React.createElement(Grid_1.default, { item: true, xs: 4 }, "Required"),
117
+ React.createElement(Grid_1.default, { item: true, xs: 8 },
118
+ React.createElement(TextField_1.TextField, Object.assign({ required: true }, args))),
119
+ React.createElement(Grid_1.default, { item: true, xs: 4 }, "Error"),
120
+ React.createElement(Grid_1.default, { item: true, xs: 8 },
121
+ React.createElement(TextField_1.TextField, Object.assign({}, args, { error: true }))),
122
+ React.createElement(Grid_1.default, { item: true, xs: 4 }, "Disabled"),
123
+ React.createElement(Grid_1.default, { item: true, xs: 8 },
124
+ React.createElement(TextField_1.TextField, Object.assign({}, args, { disabled: true })))));
125
+ },
126
+ args: {
127
+ placeholder: "This is placeholder text.",
128
+ value: "Some value",
129
+ },
130
+ argTypes: {
131
+ placeholder: { table: { disable: true } },
132
+ value: { table: { disable: true } },
133
+ error: { table: { disable: true } },
134
+ disabled: { table: { disable: true } },
135
+ },
136
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const React = require("react");
13
+ const react_1 = require("@testing-library/react");
14
+ const user_event_1 = require("@testing-library/user-event");
15
+ const TextField_1 = require("./TextField");
16
+ const ThemeProvider_1 = require("../ThemeProvider/ThemeProvider");
17
+ const en_1 = require("@faker-js/faker/locale/en");
18
+ describe("TextField", () => {
19
+ const setup = (props) => {
20
+ const defaults = {
21
+ name: "test-name",
22
+ value: "test-value",
23
+ label: "test-label",
24
+ };
25
+ const { rerender: _rerender } = (0, react_1.render)(React.createElement(TextField_1.TextField, Object.assign({}, defaults, props)), {
26
+ wrapper: ThemeProvider_1.ThemeProvider,
27
+ });
28
+ const rerender = (newProps) => {
29
+ _rerender(React.createElement(TextField_1.TextField, Object.assign({}, defaults, newProps)));
30
+ };
31
+ return { rerender };
32
+ };
33
+ it("Has a label", () => {
34
+ const label = en_1.faker.lorem.words();
35
+ setup({ label });
36
+ const input = react_1.screen.getByRole("textbox", { name: label });
37
+ expect(input).toBeInstanceOf(HTMLInputElement);
38
+ });
39
+ it("Marks the input as required if required", () => {
40
+ const label = en_1.faker.lorem.words();
41
+ setup({ label, required: true });
42
+ const input = react_1.screen.getByRole("textbox", { name: label });
43
+ expect(input).toBeRequired();
44
+ });
45
+ it("Emits the correct value on change", () => __awaiter(void 0, void 0, void 0, function* () {
46
+ const name = en_1.faker.lorem.word();
47
+ const value = en_1.faker.lorem.words();
48
+ const onChange = jest.fn();
49
+ setup({ name, onChange, value });
50
+ const input = react_1.screen.getByRole("textbox");
51
+ yield user_event_1.default.type(input, "x");
52
+ expect(onChange).toHaveBeenCalledTimes(1);
53
+ expect(onChange).toHaveBeenCalledWith(expect.objectContaining({
54
+ target: expect.objectContaining({ name }),
55
+ }));
56
+ }));
57
+ it("Forwards inputProps and InputProps", () => {
58
+ /**
59
+ * NOTE: This behavior is important for integrating easily with MUI's
60
+ * Autocomplete component
61
+ */
62
+ const inputRef = jest.fn();
63
+ const InputRef = jest.fn();
64
+ setup({
65
+ inputProps: {
66
+ ref: inputRef,
67
+ },
68
+ InputProps: {
69
+ ref: InputRef,
70
+ },
71
+ });
72
+ expect(inputRef).toHaveBeenCalledTimes(1);
73
+ expect(inputRef).toHaveBeenCalledWith(expect.any(HTMLInputElement));
74
+ expect(InputRef).toHaveBeenCalledTimes(1);
75
+ expect(InputRef).toHaveBeenCalledWith(expect.any(HTMLDivElement));
76
+ });
77
+ });
@@ -0,0 +1,21 @@
1
+ import * as React from "react";
2
+ import type { ThemeOptions, Theme } from "@mui/material/styles";
3
+ /**
4
+ * Create a customized Smoot Design theme for use with `ThemeProvider`.
5
+ *
6
+ * See [ThemeProvider Docs](https://mitodl.github.io/smoot-design/?path=/docs/smoot-design-themeprovider--docs#further-customized-theme-with-createtheme)
7
+ * for more.
8
+ */
9
+ declare const createTheme: (options?: ThemeOptions) => Theme;
10
+ type ThemeProviderProps = {
11
+ children?: React.ReactNode;
12
+ theme?: Theme;
13
+ };
14
+ /**
15
+ *
16
+ * @param param0
17
+ * @returns
18
+ */
19
+ declare const ThemeProvider: React.FC<ThemeProviderProps>;
20
+ export { ThemeProvider, createTheme };
21
+ export type { ThemeProviderProps, Theme };
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createTheme = exports.ThemeProvider = void 0;
4
+ const React = require("react");
5
+ const styles_1 = require("@mui/material/styles");
6
+ const typography = require("./typography");
7
+ const buttons = require("./buttons");
8
+ const chips = require("./chips");
9
+ const colors_1 = require("./colors");
10
+ const deepmerge_1 = require("@mui/utils/deepmerge");
11
+ const custom = {
12
+ colors: colors_1.colors,
13
+ dimensions: {
14
+ headerHeight: "72px",
15
+ headerHeightSm: "60px",
16
+ },
17
+ };
18
+ const BREAKPOINTS = {
19
+ values: {
20
+ xs: 0,
21
+ sm: 600,
22
+ md: 900,
23
+ lg: 1272 + 48,
24
+ xl: 1536,
25
+ },
26
+ };
27
+ const defaultThemeOptions = {
28
+ custom: custom,
29
+ palette: {
30
+ primary: {
31
+ main: colors_1.colors.mitRed,
32
+ light: colors_1.colors.lightRed,
33
+ active: colors_1.colors.red,
34
+ contrastText: colors_1.colors.white,
35
+ },
36
+ secondary: {
37
+ light: colors_1.colors.darkGray2,
38
+ active: colors_1.colors.silverGrayDark,
39
+ main: colors_1.colors.black,
40
+ contrastText: colors_1.colors.white,
41
+ },
42
+ },
43
+ shape: {
44
+ borderRadius: 8,
45
+ },
46
+ spacing: 8,
47
+ typography: typography.globalSettings,
48
+ breakpoints: BREAKPOINTS,
49
+ components: {
50
+ MuiButtonBase: buttons.buttonBaseComponent,
51
+ MuiTypography: typography.component,
52
+ MuiMenu: {
53
+ styleOverrides: { paper: { borderRadius: "4px" } },
54
+ },
55
+ MuiAutocomplete: {
56
+ styleOverrides: {
57
+ paper: { borderRadius: "4px" },
58
+ // Mui puts paddingRight: 2px, marginRight: -2px on the popupIndicator,
59
+ // which causes the browser to show a horizontal scrollbar on overflow
60
+ // containers when a scrollbar isn't really necessary.
61
+ popupIndicator: { paddingRight: 0, marginRight: 0 },
62
+ },
63
+ },
64
+ MuiChip: chips.chipComponent,
65
+ },
66
+ };
67
+ /**
68
+ * Create a customized Smoot Design theme for use with `ThemeProvider`.
69
+ *
70
+ * See [ThemeProvider Docs](https://mitodl.github.io/smoot-design/?path=/docs/smoot-design-themeprovider--docs#further-customized-theme-with-createtheme)
71
+ * for more.
72
+ */
73
+ const createTheme = (options) => {
74
+ return (0, styles_1.createTheme)((0, deepmerge_1.default)(defaultThemeOptions, options));
75
+ };
76
+ exports.createTheme = createTheme;
77
+ const defaultTheme = createTheme();
78
+ /**
79
+ *
80
+ * @param param0
81
+ * @returns
82
+ */
83
+ const ThemeProvider = ({ children, theme = defaultTheme, }) => {
84
+ return React.createElement(styles_1.ThemeProvider, { theme: theme }, children);
85
+ };
86
+ exports.ThemeProvider = ThemeProvider;
@@ -0,0 +1,63 @@
1
+ import type { Meta, StoryObj } from "@storybook/react";
2
+ import { ThemeProvider } from "./ThemeProvider";
3
+ declare const meta: Meta<typeof ThemeProvider>;
4
+ type Story = StoryObj<typeof ThemeProvider>;
5
+ /**
6
+ * `ThemeProvider` must wrap all components from `smoot`-design, and allows
7
+ * styling any component via [`styled`](https://emotion.sh/docs/styled).
8
+ *
9
+ * In general, most useful theme properties are exposed on `theme.custom`. (Root
10
+ * `theme` properties are used internally by MUI.) See typescript definitions
11
+ * for more information about `theme.custom`.
12
+ *
13
+ * ## Further Customized Theme with `createTheme`
14
+ * Consuming applications can customize `smoot-design`'s default theme by creating
15
+ * a theme instance with `createTheme` and passing it to `ThemeProvider`:
16
+ *
17
+ * ```tsx
18
+ * const customTheme = createTheme({...})
19
+ *
20
+ * <ThemeProvider theme={customTheme}>
21
+ * {children}
22
+ * </ThemeProvider>
23
+ * ```
24
+ *
25
+ * ### Custom Link Adapter
26
+ * One particularly notable property is `theme.custom.LinkAdapter`. Some `smoot-design`
27
+ * components render links. These links are native anchor tags by default. In
28
+ * order to use these components with custom routing libraries (e.g. `react-router`
29
+ * or `next/link`), you can provide a custom link adapter.
30
+ *
31
+ * Components such as `ButtonLink` will:
32
+ * - use `Component` on `ButtonLink` if specified (`<ButtonLink Component={Link} />`)
33
+ * - else, use `theme.custom.LinkAdapter` if specified,
34
+ * - else, use `a` tag.
35
+ *
36
+ * For example, to use `next/link` as the default link implementation:
37
+ *
38
+ * ```tsx
39
+ * import Link from "next/link"
40
+ * const theme = createTheme({ LinkAdapter: Link })
41
+ * ```
42
+ *
43
+ * You can use [module augmentation](https://www.typescriptlang.org/docs/handbook/declaration-merging.html#module-augmentation)
44
+ * to add the custom props to relevant components. For example, to expose
45
+ * `next/link`'s `scroll` prop on `ButtonLink`:
46
+ *
47
+ * ```ts
48
+ * // Add scroll prop to all components using LinkAdapter
49
+ * declare module "@mitodl/smoot-design" {
50
+ * interface LinkAdapterPropsOverrides {
51
+ * scroll?: boolean
52
+ * }
53
+ * }
54
+ * ```
55
+ *
56
+ * ### ImageAdapter
57
+ * Similarly, `theme.custom.ImageAdapter` can be used to customize the image
58
+ * component used by `smoot-design`. By default, `ImageAdapter` uses a simple `img`
59
+ * tag. Interface `ImageAdapterPropsOverrides` is similarly available for
60
+ * augmentation.
61
+ */
62
+ export declare const LinkAdapterOverride: Story;
63
+ export default meta;