@mui/material 7.3.2 → 7.3.4

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 (282) hide show
  1. package/CHANGELOG.md +86 -0
  2. package/CircularProgress/CircularProgress.d.ts +6 -0
  3. package/CircularProgress/CircularProgress.js +31 -4
  4. package/CircularProgress/circularProgressClasses.d.ts +2 -0
  5. package/CircularProgress/circularProgressClasses.js +1 -1
  6. package/Divider/Divider.js +1 -1
  7. package/MenuItem/MenuItem.js +1 -1
  8. package/SnackbarContent/SnackbarContent.js +1 -1
  9. package/TextField/TextField.js +1 -1
  10. package/esm/CircularProgress/CircularProgress.d.ts +6 -0
  11. package/esm/CircularProgress/CircularProgress.js +32 -5
  12. package/esm/CircularProgress/circularProgressClasses.d.ts +2 -0
  13. package/esm/CircularProgress/circularProgressClasses.js +1 -1
  14. package/esm/Divider/Divider.js +1 -1
  15. package/esm/MenuItem/MenuItem.js +1 -1
  16. package/esm/SnackbarContent/SnackbarContent.js +1 -1
  17. package/esm/TextField/TextField.js +1 -1
  18. package/esm/index.js +1 -1
  19. package/esm/locale/amET.d.ts +2 -0
  20. package/esm/locale/amET.js +73 -0
  21. package/esm/locale/arEG.d.ts +2 -0
  22. package/esm/locale/arEG.js +73 -0
  23. package/esm/locale/arSA.d.ts +2 -0
  24. package/esm/locale/arSA.js +73 -0
  25. package/esm/locale/arSD.d.ts +2 -0
  26. package/esm/locale/arSD.js +73 -0
  27. package/esm/locale/azAZ.d.ts +2 -0
  28. package/esm/locale/azAZ.js +77 -0
  29. package/esm/locale/beBY.d.ts +2 -0
  30. package/esm/locale/beBY.js +85 -0
  31. package/esm/locale/bgBG.d.ts +2 -0
  32. package/esm/locale/bgBG.js +70 -0
  33. package/esm/locale/bnBD.d.ts +2 -0
  34. package/esm/locale/bnBD.js +73 -0
  35. package/esm/locale/caES.d.ts +2 -0
  36. package/esm/locale/caES.js +70 -0
  37. package/esm/locale/csCZ.d.ts +2 -0
  38. package/esm/locale/csCZ.js +81 -0
  39. package/esm/locale/daDK.d.ts +2 -0
  40. package/esm/locale/daDK.js +73 -0
  41. package/esm/locale/deDE.d.ts +2 -0
  42. package/esm/locale/deDE.js +73 -0
  43. package/esm/locale/elGR.d.ts +2 -0
  44. package/esm/locale/elGR.js +75 -0
  45. package/esm/locale/enUS.d.ts +2 -0
  46. package/esm/locale/enUS.js +61 -0
  47. package/esm/locale/esES.d.ts +2 -0
  48. package/esm/locale/esES.js +73 -0
  49. package/esm/locale/etEE.d.ts +2 -0
  50. package/esm/locale/etEE.js +73 -0
  51. package/esm/locale/faIR.d.ts +2 -0
  52. package/esm/locale/faIR.js +78 -0
  53. package/esm/locale/fiFI.d.ts +2 -0
  54. package/esm/locale/fiFI.js +73 -0
  55. package/esm/locale/frFR.d.ts +2 -0
  56. package/esm/locale/frFR.js +73 -0
  57. package/esm/locale/heIL.d.ts +2 -0
  58. package/esm/locale/heIL.js +73 -0
  59. package/esm/locale/hiIN.d.ts +2 -0
  60. package/esm/locale/hiIN.js +73 -0
  61. package/esm/locale/hrHR.d.ts +2 -0
  62. package/esm/locale/hrHR.js +81 -0
  63. package/esm/locale/huHU.d.ts +2 -0
  64. package/esm/locale/huHU.js +70 -0
  65. package/esm/locale/hyAM.d.ts +2 -0
  66. package/esm/locale/hyAM.js +70 -0
  67. package/esm/locale/idID.d.ts +2 -0
  68. package/esm/locale/idID.js +70 -0
  69. package/esm/locale/index.d.ts +60 -82
  70. package/esm/locale/index.js +60 -4327
  71. package/esm/locale/isIS.d.ts +2 -0
  72. package/esm/locale/isIS.js +73 -0
  73. package/esm/locale/itIT.d.ts +2 -0
  74. package/esm/locale/itIT.js +73 -0
  75. package/esm/locale/jaJP.d.ts +2 -0
  76. package/esm/locale/jaJP.js +73 -0
  77. package/esm/locale/khKH.d.ts +2 -0
  78. package/esm/locale/khKH.js +73 -0
  79. package/esm/locale/kkKZ.d.ts +2 -0
  80. package/esm/locale/kkKZ.js +76 -0
  81. package/esm/locale/koKR.d.ts +2 -0
  82. package/esm/locale/koKR.js +73 -0
  83. package/esm/locale/kuCKB.d.ts +2 -0
  84. package/esm/locale/kuCKB.js +73 -0
  85. package/esm/locale/kuLatn.d.ts +2 -0
  86. package/esm/locale/kuLatn.js +73 -0
  87. package/esm/locale/mkMK.d.ts +2 -0
  88. package/esm/locale/mkMK.js +77 -0
  89. package/esm/locale/msMS.d.ts +2 -0
  90. package/esm/locale/msMS.js +77 -0
  91. package/esm/locale/myMY.d.ts +2 -0
  92. package/esm/locale/myMY.js +77 -0
  93. package/esm/locale/nbNO.d.ts +2 -0
  94. package/esm/locale/nbNO.js +73 -0
  95. package/esm/locale/neNP.d.ts +2 -0
  96. package/esm/locale/neNP.js +77 -0
  97. package/esm/locale/nlNL.d.ts +2 -0
  98. package/esm/locale/nlNL.js +73 -0
  99. package/esm/locale/nnNO.d.ts +2 -0
  100. package/esm/locale/nnNO.js +73 -0
  101. package/esm/locale/plPL.d.ts +2 -0
  102. package/esm/locale/plPL.js +82 -0
  103. package/esm/locale/psAF.d.ts +2 -0
  104. package/esm/locale/psAF.js +73 -0
  105. package/esm/locale/ptBR.d.ts +2 -0
  106. package/esm/locale/ptBR.js +73 -0
  107. package/esm/locale/ptPT.d.ts +2 -0
  108. package/esm/locale/ptPT.js +73 -0
  109. package/esm/locale/roRO.d.ts +2 -0
  110. package/esm/locale/roRO.js +73 -0
  111. package/esm/locale/ruRU.d.ts +2 -0
  112. package/esm/locale/ruRU.js +85 -0
  113. package/esm/locale/siLK.d.ts +2 -0
  114. package/esm/locale/siLK.js +73 -0
  115. package/esm/locale/skSK.d.ts +2 -0
  116. package/esm/locale/skSK.js +81 -0
  117. package/esm/locale/srRS.d.ts +2 -0
  118. package/esm/locale/srRS.js +81 -0
  119. package/esm/locale/svSE.d.ts +2 -0
  120. package/esm/locale/svSE.js +73 -0
  121. package/esm/locale/thTH.d.ts +2 -0
  122. package/esm/locale/thTH.js +73 -0
  123. package/esm/locale/tlTL.d.ts +2 -0
  124. package/esm/locale/tlTL.js +74 -0
  125. package/esm/locale/trTR.d.ts +2 -0
  126. package/esm/locale/trTR.js +73 -0
  127. package/esm/locale/ukUA.d.ts +2 -0
  128. package/esm/locale/ukUA.js +82 -0
  129. package/esm/locale/urPK.d.ts +2 -0
  130. package/esm/locale/urPK.js +73 -0
  131. package/esm/locale/utils/LocaleTextApi.d.ts +23 -0
  132. package/esm/locale/utils/LocaleTextApi.js +1 -0
  133. package/esm/locale/viVN.d.ts +2 -0
  134. package/esm/locale/viVN.js +73 -0
  135. package/esm/locale/zhCN.d.ts +2 -0
  136. package/esm/locale/zhCN.js +51 -0
  137. package/esm/locale/zhHK.d.ts +2 -0
  138. package/esm/locale/zhHK.js +51 -0
  139. package/esm/locale/zhTW.d.ts +2 -0
  140. package/esm/locale/zhTW.js +51 -0
  141. package/esm/styles/createColorScheme.js +2 -2
  142. package/esm/styles/createTheme.d.ts +13 -5
  143. package/esm/styles/createTheme.js +2 -2
  144. package/esm/styles/createThemeFoundation.d.ts +277 -0
  145. package/esm/styles/createThemeFoundation.js +37 -0
  146. package/esm/styles/createThemeNoVars.d.ts +1 -1
  147. package/esm/styles/createThemeWithVars.d.ts +23 -306
  148. package/esm/useAutocomplete/useAutocomplete.js +2 -2
  149. package/esm/version/index.js +2 -2
  150. package/index.js +1 -1
  151. package/locale/amET.d.ts +2 -0
  152. package/locale/amET.js +79 -0
  153. package/locale/arEG.d.ts +2 -0
  154. package/locale/arEG.js +79 -0
  155. package/locale/arSA.d.ts +2 -0
  156. package/locale/arSA.js +79 -0
  157. package/locale/arSD.d.ts +2 -0
  158. package/locale/arSD.js +79 -0
  159. package/locale/azAZ.d.ts +2 -0
  160. package/locale/azAZ.js +83 -0
  161. package/locale/beBY.d.ts +2 -0
  162. package/locale/beBY.js +91 -0
  163. package/locale/bgBG.d.ts +2 -0
  164. package/locale/bgBG.js +76 -0
  165. package/locale/bnBD.d.ts +2 -0
  166. package/locale/bnBD.js +79 -0
  167. package/locale/caES.d.ts +2 -0
  168. package/locale/caES.js +76 -0
  169. package/locale/csCZ.d.ts +2 -0
  170. package/locale/csCZ.js +87 -0
  171. package/locale/daDK.d.ts +2 -0
  172. package/locale/daDK.js +79 -0
  173. package/locale/deDE.d.ts +2 -0
  174. package/locale/deDE.js +79 -0
  175. package/locale/elGR.d.ts +2 -0
  176. package/locale/elGR.js +81 -0
  177. package/locale/enUS.d.ts +2 -0
  178. package/locale/enUS.js +67 -0
  179. package/locale/esES.d.ts +2 -0
  180. package/locale/esES.js +79 -0
  181. package/locale/etEE.d.ts +2 -0
  182. package/locale/etEE.js +79 -0
  183. package/locale/faIR.d.ts +2 -0
  184. package/locale/faIR.js +84 -0
  185. package/locale/fiFI.d.ts +2 -0
  186. package/locale/fiFI.js +79 -0
  187. package/locale/frFR.d.ts +2 -0
  188. package/locale/frFR.js +79 -0
  189. package/locale/heIL.d.ts +2 -0
  190. package/locale/heIL.js +79 -0
  191. package/locale/hiIN.d.ts +2 -0
  192. package/locale/hiIN.js +79 -0
  193. package/locale/hrHR.d.ts +2 -0
  194. package/locale/hrHR.js +87 -0
  195. package/locale/huHU.d.ts +2 -0
  196. package/locale/huHU.js +76 -0
  197. package/locale/hyAM.d.ts +2 -0
  198. package/locale/hyAM.js +76 -0
  199. package/locale/idID.d.ts +2 -0
  200. package/locale/idID.js +76 -0
  201. package/locale/index.d.ts +60 -82
  202. package/locale/index.js +660 -4328
  203. package/locale/isIS.d.ts +2 -0
  204. package/locale/isIS.js +79 -0
  205. package/locale/itIT.d.ts +2 -0
  206. package/locale/itIT.js +79 -0
  207. package/locale/jaJP.d.ts +2 -0
  208. package/locale/jaJP.js +79 -0
  209. package/locale/khKH.d.ts +2 -0
  210. package/locale/khKH.js +79 -0
  211. package/locale/kkKZ.d.ts +2 -0
  212. package/locale/kkKZ.js +82 -0
  213. package/locale/koKR.d.ts +2 -0
  214. package/locale/koKR.js +79 -0
  215. package/locale/kuCKB.d.ts +2 -0
  216. package/locale/kuCKB.js +79 -0
  217. package/locale/kuLatn.d.ts +2 -0
  218. package/locale/kuLatn.js +79 -0
  219. package/locale/mkMK.d.ts +2 -0
  220. package/locale/mkMK.js +83 -0
  221. package/locale/msMS.d.ts +2 -0
  222. package/locale/msMS.js +83 -0
  223. package/locale/myMY.d.ts +2 -0
  224. package/locale/myMY.js +83 -0
  225. package/locale/nbNO.d.ts +2 -0
  226. package/locale/nbNO.js +79 -0
  227. package/locale/neNP.d.ts +2 -0
  228. package/locale/neNP.js +83 -0
  229. package/locale/nlNL.d.ts +2 -0
  230. package/locale/nlNL.js +79 -0
  231. package/locale/nnNO.d.ts +2 -0
  232. package/locale/nnNO.js +79 -0
  233. package/locale/plPL.d.ts +2 -0
  234. package/locale/plPL.js +88 -0
  235. package/locale/psAF.d.ts +2 -0
  236. package/locale/psAF.js +79 -0
  237. package/locale/ptBR.d.ts +2 -0
  238. package/locale/ptBR.js +79 -0
  239. package/locale/ptPT.d.ts +2 -0
  240. package/locale/ptPT.js +79 -0
  241. package/locale/roRO.d.ts +2 -0
  242. package/locale/roRO.js +79 -0
  243. package/locale/ruRU.d.ts +2 -0
  244. package/locale/ruRU.js +91 -0
  245. package/locale/siLK.d.ts +2 -0
  246. package/locale/siLK.js +79 -0
  247. package/locale/skSK.d.ts +2 -0
  248. package/locale/skSK.js +87 -0
  249. package/locale/srRS.d.ts +2 -0
  250. package/locale/srRS.js +87 -0
  251. package/locale/svSE.d.ts +2 -0
  252. package/locale/svSE.js +79 -0
  253. package/locale/thTH.d.ts +2 -0
  254. package/locale/thTH.js +79 -0
  255. package/locale/tlTL.d.ts +2 -0
  256. package/locale/tlTL.js +80 -0
  257. package/locale/trTR.d.ts +2 -0
  258. package/locale/trTR.js +79 -0
  259. package/locale/ukUA.d.ts +2 -0
  260. package/locale/ukUA.js +88 -0
  261. package/locale/urPK.d.ts +2 -0
  262. package/locale/urPK.js +79 -0
  263. package/locale/utils/LocaleTextApi.d.ts +23 -0
  264. package/locale/utils/LocaleTextApi.js +5 -0
  265. package/locale/viVN.d.ts +2 -0
  266. package/locale/viVN.js +79 -0
  267. package/locale/zhCN.d.ts +2 -0
  268. package/locale/zhCN.js +57 -0
  269. package/locale/zhHK.d.ts +2 -0
  270. package/locale/zhHK.js +57 -0
  271. package/locale/zhTW.d.ts +2 -0
  272. package/locale/zhTW.js +57 -0
  273. package/package.json +8 -8
  274. package/styles/createColorScheme.js +2 -2
  275. package/styles/createTheme.d.ts +13 -5
  276. package/styles/createTheme.js +2 -2
  277. package/styles/createThemeFoundation.d.ts +277 -0
  278. package/styles/createThemeFoundation.js +5 -0
  279. package/styles/createThemeNoVars.d.ts +1 -1
  280. package/styles/createThemeWithVars.d.ts +23 -306
  281. package/useAutocomplete/useAutocomplete.js +2 -2
  282. package/version/index.js +2 -2
@@ -0,0 +1,51 @@
1
+ export const zhTW = {
2
+ components: {
3
+ MuiBreadcrumbs: {
4
+ defaultProps: {
5
+ expandText: '展開'
6
+ }
7
+ },
8
+ MuiTablePagination: {
9
+ defaultProps: {
10
+ getItemAriaLabel: type => {
11
+ if (type === 'first') {
12
+ return '第一頁';
13
+ }
14
+ if (type === 'last') {
15
+ return '最後一頁';
16
+ }
17
+ if (type === 'next') {
18
+ return '下一頁';
19
+ }
20
+ return '上一頁';
21
+ },
22
+ labelRowsPerPage: '每頁數量:',
23
+ labelDisplayedRows: ({
24
+ from,
25
+ to,
26
+ count
27
+ }) => `${from} ~ ${to} / ${count !== -1 ? count : `${to} 以上`}`
28
+ }
29
+ },
30
+ MuiRating: {
31
+ defaultProps: {
32
+ getLabelText: value => `${value} 顆星`,
33
+ emptyLabelText: '無標籤'
34
+ }
35
+ },
36
+ MuiAutocomplete: {
37
+ defaultProps: {
38
+ clearText: '清空',
39
+ closeText: '關閉',
40
+ loadingText: '載入中…',
41
+ noOptionsText: '沒有可用選項',
42
+ openText: '打開'
43
+ }
44
+ },
45
+ MuiAlert: {
46
+ defaultProps: {
47
+ closeText: '關閉'
48
+ }
49
+ }
50
+ }
51
+ };
@@ -27,7 +27,7 @@ export default function createColorScheme(options) {
27
27
  opacity,
28
28
  overlays,
29
29
  colorSpace,
30
- ...rest
30
+ ...other
31
31
  } = options;
32
32
  // need to cast because `colorSpace` is considered internal at the moment.
33
33
  const palette = createPalette({
@@ -41,6 +41,6 @@ export default function createColorScheme(options) {
41
41
  ...opacity
42
42
  },
43
43
  overlays: overlays || getOverlays(palette.mode),
44
- ...rest
44
+ ...other
45
45
  };
46
46
  }
@@ -1,14 +1,22 @@
1
+ import { PaletteOptions } from "./createPalette.js";
2
+ import { ColorSystemOptions } from "./createThemeFoundation.js";
1
3
  import { CssVarsThemeOptions } from "./createThemeWithVars.js";
2
- import { Theme, ThemeOptions } from "./createThemeNoVars.js";
3
- export type { ThemeOptions, Theme, CssThemeVariables } from "./createThemeNoVars.js";
4
+ import { Theme, CssThemeVariables } from "./createThemeNoVars.js";
5
+ export type { Theme, CssThemeVariables } from "./createThemeNoVars.js";
6
+ type CssVarsOptions = CssThemeVariables extends {
7
+ enabled: true;
8
+ } ? ColorSystemOptions : {};
9
+ type CssVarsConfigList = 'colorSchemeSelector' | 'rootSelector' | 'disableCssColorScheme' | 'cssVarPrefix' | 'shouldSkipGeneratingVar' | 'nativeColor';
10
+ export interface ThemeOptions extends CssVarsOptions, Omit<CssVarsThemeOptions, CssVarsConfigList> {
11
+ cssVariables?: boolean | Pick<CssVarsThemeOptions, CssVarsConfigList>;
12
+ palette?: PaletteOptions;
13
+ }
4
14
  /**
5
15
  * Generate a theme base on the options received.
6
16
  * @param options Takes an incomplete theme object and adds the missing parts.
7
17
  * @param args Deep merge the arguments with the about to be returned theme.
8
18
  * @returns A complete, ready-to-use theme object.
9
19
  */
10
- export default function createTheme(options?: Omit<ThemeOptions, 'components'> & Pick<CssVarsThemeOptions, 'defaultColorScheme' | 'colorSchemes' | 'components'> & {
11
- cssVariables?: boolean | Pick<CssVarsThemeOptions, 'colorSchemeSelector' | 'rootSelector' | 'disableCssColorScheme' | 'cssVarPrefix' | 'shouldSkipGeneratingVar' | 'nativeColor'>;
12
- },
20
+ export default function createTheme(options?: ThemeOptions,
13
21
  // cast type to skip module augmentation test
14
22
  ...args: object[]): Theme;
@@ -33,7 +33,7 @@ export default function createTheme(options = {},
33
33
  light: true
34
34
  } : undefined,
35
35
  defaultColorScheme: initialDefaultColorScheme = palette?.mode,
36
- ...rest
36
+ ...other
37
37
  } = options;
38
38
  const defaultColorSchemeInput = initialDefaultColorScheme || 'light';
39
39
  const defaultScheme = initialColorSchemes?.[defaultColorSchemeInput];
@@ -90,7 +90,7 @@ export default function createTheme(options = {},
90
90
  colorSchemesInput.light = true;
91
91
  }
92
92
  return createThemeWithVars({
93
- ...rest,
93
+ ...other,
94
94
  colorSchemes: colorSchemesInput,
95
95
  defaultColorScheme: defaultColorSchemeInput,
96
96
  ...(typeof cssVariables !== 'boolean' && cssVariables)
@@ -0,0 +1,277 @@
1
+ import { OverridableStringUnion } from '@mui/types';
2
+ import { SxConfig, SxProps, CSSObject, ApplyStyles, Theme as SystemTheme } from '@mui/system';
3
+ import { ExtractTypographyTokens } from '@mui/system/cssVars';
4
+ import { Palette, PaletteOptions } from "./createPalette.js";
5
+ import { Shadows } from "./shadows.js";
6
+ import { Transitions } from "./createTransitions.js";
7
+ import { Mixins } from "./createMixins.js";
8
+ import { TypographyVariants } from "./createTypography.js";
9
+ import { ZIndex } from "./zIndex.js";
10
+ /**
11
+ * default MD color-schemes
12
+ */
13
+ export type DefaultColorScheme = 'light' | 'dark';
14
+ /**
15
+ * The application can add more color-scheme by extending this interface via module augmentation
16
+ *
17
+ * Ex.
18
+ * declare module @mui/material/styles {
19
+ * interface ColorSchemeOverrides {
20
+ * foo: true;
21
+ * }
22
+ * }
23
+ *
24
+ * // SupportedColorScheme = 'light' | 'dark' | 'foo';
25
+ */
26
+ export interface ColorSchemeOverrides {}
27
+ export type ExtendedColorScheme = OverridableStringUnion<never, ColorSchemeOverrides>;
28
+ /**
29
+ * All color-schemes that the application has
30
+ */
31
+ export type SupportedColorScheme = DefaultColorScheme | ExtendedColorScheme;
32
+ export interface Opacity {
33
+ inputPlaceholder: number;
34
+ inputUnderline: number;
35
+ switchTrackDisabled: number;
36
+ switchTrack: number;
37
+ }
38
+ export type Overlays = [string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined, string | undefined];
39
+ export interface PaletteBackgroundChannel {
40
+ defaultChannel: string;
41
+ paperChannel: string;
42
+ }
43
+ export interface PaletteCommonChannel {
44
+ background: string;
45
+ backgroundChannel: string;
46
+ onBackground: string;
47
+ onBackgroundChannel: string;
48
+ }
49
+ export interface PaletteColorChannel {
50
+ mainChannel: string;
51
+ lightChannel: string;
52
+ darkChannel: string;
53
+ contrastTextChannel: string;
54
+ }
55
+ export interface PaletteActionChannel {
56
+ activeChannel: string;
57
+ selectedChannel: string;
58
+ }
59
+ export interface PaletteTextChannel {
60
+ primaryChannel: string;
61
+ secondaryChannel: string;
62
+ }
63
+ export interface PaletteAlert {
64
+ errorColor: string;
65
+ infoColor: string;
66
+ successColor: string;
67
+ warningColor: string;
68
+ errorFilledBg: string;
69
+ infoFilledBg: string;
70
+ successFilledBg: string;
71
+ warningFilledBg: string;
72
+ errorFilledColor: string;
73
+ infoFilledColor: string;
74
+ successFilledColor: string;
75
+ warningFilledColor: string;
76
+ errorStandardBg: string;
77
+ infoStandardBg: string;
78
+ successStandardBg: string;
79
+ warningStandardBg: string;
80
+ errorIconColor: string;
81
+ infoIconColor: string;
82
+ successIconColor: string;
83
+ warningIconColor: string;
84
+ }
85
+ export interface PaletteAppBar {
86
+ defaultBg: string;
87
+ darkBg: string;
88
+ darkColor: string;
89
+ }
90
+ export interface PaletteAvatar {
91
+ defaultBg: string;
92
+ }
93
+ export interface PaletteButton {
94
+ inheritContainedBg: string;
95
+ inheritContainedHoverBg: string;
96
+ }
97
+ export interface PaletteChip {
98
+ defaultBorder: string;
99
+ defaultAvatarColor: string;
100
+ defaultIconColor: string;
101
+ }
102
+ export interface PaletteFilledInput {
103
+ bg: string;
104
+ hoverBg: string;
105
+ disabledBg: string;
106
+ }
107
+ export interface PaletteLinearProgress {
108
+ primaryBg: string;
109
+ secondaryBg: string;
110
+ errorBg: string;
111
+ infoBg: string;
112
+ successBg: string;
113
+ warningBg: string;
114
+ }
115
+ export interface PaletteSkeleton {
116
+ bg: string;
117
+ }
118
+ export interface PaletteSlider {
119
+ primaryTrack: string;
120
+ secondaryTrack: string;
121
+ errorTrack: string;
122
+ infoTrack: string;
123
+ successTrack: string;
124
+ warningTrack: string;
125
+ }
126
+ export interface PaletteSnackbarContent {
127
+ bg: string;
128
+ color: string;
129
+ }
130
+ export interface PaletteSpeedDialAction {
131
+ fabHoverBg: string;
132
+ }
133
+ export interface PaletteStepConnector {
134
+ border: string;
135
+ }
136
+ export interface PaletteStepContent {
137
+ border: string;
138
+ }
139
+ export interface PaletteSwitch {
140
+ defaultColor: string;
141
+ defaultDisabledColor: string;
142
+ primaryDisabledColor: string;
143
+ secondaryDisabledColor: string;
144
+ errorDisabledColor: string;
145
+ infoDisabledColor: string;
146
+ successDisabledColor: string;
147
+ warningDisabledColor: string;
148
+ }
149
+ export interface PaletteTableCell {
150
+ border: string;
151
+ }
152
+ export interface PaletteTooltip {
153
+ bg: string;
154
+ }
155
+ export interface ColorSystemOptions {
156
+ palette?: PaletteOptions & {
157
+ background?: Partial<PaletteBackgroundChannel>;
158
+ common?: Partial<PaletteCommonChannel>;
159
+ primary?: Partial<PaletteColorChannel>;
160
+ secondary?: Partial<PaletteColorChannel>;
161
+ error?: Partial<PaletteColorChannel>;
162
+ info?: Partial<PaletteColorChannel>;
163
+ success?: Partial<PaletteColorChannel>;
164
+ text?: Partial<PaletteTextChannel>;
165
+ dividerChannel?: Partial<string>;
166
+ action?: Partial<PaletteActionChannel>;
167
+ Alert?: Partial<PaletteAlert>;
168
+ AppBar?: Partial<PaletteAppBar>;
169
+ Avatar?: Partial<PaletteAvatar>;
170
+ Button?: Partial<PaletteButton>;
171
+ Chip?: Partial<PaletteChip>;
172
+ FilledInput?: Partial<PaletteFilledInput>;
173
+ LinearProgress?: Partial<PaletteLinearProgress>;
174
+ Skeleton?: Partial<PaletteSkeleton>;
175
+ Slider?: Partial<PaletteSlider>;
176
+ SnackbarContent?: Partial<PaletteSnackbarContent>;
177
+ SpeedDialAction?: Partial<PaletteSpeedDialAction>;
178
+ StepConnector?: Partial<PaletteStepConnector>;
179
+ StepContent?: Partial<PaletteStepContent>;
180
+ Switch?: Partial<PaletteSwitch>;
181
+ TableCell?: Partial<PaletteTableCell>;
182
+ Tooltip?: Partial<PaletteTooltip>;
183
+ };
184
+ opacity?: Partial<Opacity>;
185
+ overlays?: Overlays;
186
+ }
187
+ export interface CssVarsPalette {
188
+ common: PaletteCommonChannel;
189
+ primary: PaletteColorChannel;
190
+ secondary: PaletteColorChannel;
191
+ error: PaletteColorChannel;
192
+ info: PaletteColorChannel;
193
+ success: PaletteColorChannel;
194
+ warning: PaletteColorChannel;
195
+ text: PaletteTextChannel;
196
+ background: PaletteBackgroundChannel;
197
+ dividerChannel: string;
198
+ action: PaletteActionChannel;
199
+ Alert: PaletteAlert;
200
+ AppBar: PaletteAppBar;
201
+ Avatar: PaletteAvatar;
202
+ Button: PaletteButton;
203
+ Chip: PaletteChip;
204
+ FilledInput: PaletteFilledInput;
205
+ LinearProgress: PaletteLinearProgress;
206
+ Skeleton: PaletteSkeleton;
207
+ Slider: PaletteSlider;
208
+ SnackbarContent: PaletteSnackbarContent;
209
+ SpeedDialAction: PaletteSpeedDialAction;
210
+ StepConnector: PaletteStepConnector;
211
+ StepContent: PaletteStepContent;
212
+ Switch: PaletteSwitch;
213
+ TableCell: PaletteTableCell;
214
+ Tooltip: PaletteTooltip;
215
+ }
216
+ export interface ColorSystem {
217
+ palette: Palette & CssVarsPalette;
218
+ opacity: Opacity;
219
+ overlays: Overlays;
220
+ }
221
+ export interface ThemeVars {
222
+ font: ExtractTypographyTokens<TypographyVariants>;
223
+ palette: Omit<ColorSystem['palette'], 'colorScheme' | 'mode' | 'contrastThreshold' | 'tonalOffset' | 'getContrastText' | 'augmentColor'>;
224
+ opacity: Opacity;
225
+ overlays: Overlays;
226
+ shadows: Shadows;
227
+ shape: SystemTheme['shape'];
228
+ spacing: string;
229
+ zIndex: ZIndex;
230
+ }
231
+ type Split<T, K extends keyof T = keyof T> = K extends string | number ? { [k in K]: Exclude<T[K], undefined> } : never;
232
+ type ConcatDeep<T> = T extends Record<string | number, infer V> ? keyof T extends string | number ? V extends string | number ? keyof T : keyof V extends string | number ? `${keyof T}-${ConcatDeep<Split<V>>}` : never : never : never;
233
+ /**
234
+ * Does not work for these cases:
235
+ * - { borderRadius: string | number } // the value can't be a union
236
+ * - { shadows: [string, string, ..., string] } // the value can't be an array
237
+ */
238
+ type NormalizeVars<T> = ConcatDeep<Split<T>>;
239
+ export {};
240
+ export interface ThemeCssVarOverrides {}
241
+ export type ThemeCssVar = OverridableStringUnion<NormalizeVars<Omit<ThemeVars, 'overlays' | 'shadows' | 'shape'>> | 'shape-borderRadius' | 'shadows-0' | 'shadows-1' | 'shadows-2' | 'shadows-3' | 'shadows-4' | 'shadows-5' | 'shadows-6' | 'shadows-7' | 'shadows-8' | 'shadows-9' | 'shadows-10' | 'shadows-11' | 'shadows-12' | 'shadows-13' | 'shadows-14' | 'shadows-15' | 'shadows-16' | 'shadows-17' | 'shadows-18' | 'shadows-19' | 'shadows-20' | 'shadows-21' | 'shadows-22' | 'shadows-23' | 'shadows-24' | 'overlays-0' | 'overlays-1' | 'overlays-2' | 'overlays-3' | 'overlays-4' | 'overlays-5' | 'overlays-6' | 'overlays-7' | 'overlays-8' | 'overlays-9' | 'overlays-10' | 'overlays-11' | 'overlays-12' | 'overlays-13' | 'overlays-14' | 'overlays-15' | 'overlays-16' | 'overlays-17' | 'overlays-18' | 'overlays-19' | 'overlays-20' | 'overlays-21' | 'overlays-22' | 'overlays-23' | 'overlays-24', ThemeCssVarOverrides>;
242
+ /**
243
+ * Theme properties generated by extendTheme and CssVarsProvider
244
+ */
245
+ export interface CssVarsTheme extends ColorSystem {
246
+ colorSchemes: Partial<Record<SupportedColorScheme, ColorSystem>>;
247
+ rootSelector: string;
248
+ colorSchemeSelector: 'media' | 'class' | 'data' | string;
249
+ cssVarPrefix: string;
250
+ defaultColorScheme: SupportedColorScheme;
251
+ vars: ThemeVars;
252
+ getCssVar: (field: ThemeCssVar, ...vars: ThemeCssVar[]) => string;
253
+ getColorSchemeSelector: (colorScheme: SupportedColorScheme) => string;
254
+ generateThemeVars: () => ThemeVars;
255
+ generateStyleSheets: () => Array<Record<string, any>>;
256
+ generateSpacing: () => SystemTheme['spacing'];
257
+ spacing: SystemTheme['spacing'];
258
+ breakpoints: SystemTheme['breakpoints'];
259
+ shape: SystemTheme['shape'];
260
+ typography: TypographyVariants;
261
+ transitions: Transitions;
262
+ shadows: Shadows;
263
+ mixins: Mixins;
264
+ zIndex: ZIndex;
265
+ direction: SystemTheme['direction'];
266
+ /**
267
+ * A function to determine if the key, value should be attached as CSS Variable
268
+ * `keys` is an array that represents the object path keys.
269
+ * Ex, if the theme is { foo: { bar: 'var(--test)' } }
270
+ * then, keys = ['foo', 'bar']
271
+ * value = 'var(--test)'
272
+ */
273
+ shouldSkipGeneratingVar: (keys: string[], value: string | number) => boolean;
274
+ unstable_sxConfig: SxConfig;
275
+ unstable_sx: (props: SxProps<CssVarsTheme>) => CSSObject;
276
+ applyStyles: ApplyStyles<SupportedColorScheme>;
277
+ }
@@ -0,0 +1,37 @@
1
+ /**
2
+ * default MD color-schemes
3
+ */
4
+
5
+ /**
6
+ * The application can add more color-scheme by extending this interface via module augmentation
7
+ *
8
+ * Ex.
9
+ * declare module @mui/material/styles {
10
+ * interface ColorSchemeOverrides {
11
+ * foo: true;
12
+ * }
13
+ * }
14
+ *
15
+ * // SupportedColorScheme = 'light' | 'dark' | 'foo';
16
+ */
17
+
18
+ /**
19
+ * All color-schemes that the application has
20
+ */
21
+
22
+ // The Palette should be sync with `../themeCssVarsAugmentation/index.d.ts`
23
+
24
+ // should not include keys defined in `shouldSkipGeneratingVar` and have value typeof function
25
+
26
+ /**
27
+ * Does not work for these cases:
28
+ * - { borderRadius: string | number } // the value can't be a union
29
+ * - { shadows: [string, string, ..., string] } // the value can't be an array
30
+ */
31
+
32
+ // shut off automatic exporting for the Generics above
33
+ export {};
34
+
35
+ /**
36
+ * Theme properties generated by extendTheme and CssVarsProvider
37
+ */
@@ -6,7 +6,7 @@ import { Shadows } from "./shadows.js";
6
6
  import { Transitions, TransitionsOptions } from "./createTransitions.js";
7
7
  import { ZIndex, ZIndexOptions } from "./zIndex.js";
8
8
  import { Components } from "./components.js";
9
- import { CssVarsTheme, CssVarsPalette, ColorSystemOptions } from "./createThemeWithVars.js";
9
+ import { CssVarsTheme, CssVarsPalette, ColorSystemOptions } from "./createThemeFoundation.js";
10
10
 
11
11
  /**
12
12
  * To disable custom properties, use module augmentation