You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
18 lines
458 B
TypeScript
18 lines
458 B
TypeScript
export {};
|
|
|
|
interface ThemeWithProps<Components> {
|
|
components?: { [K in keyof Components]: { defaultProps?: Partial<Components[K]> } };
|
|
}
|
|
|
|
type ThemedProps<Theme, Name extends keyof any> = Theme extends {
|
|
components: Record<Name, { defaultProps: infer Props }>;
|
|
}
|
|
? Props
|
|
: {};
|
|
|
|
export default function getThemeProps<Theme, Props, Name extends keyof any>(params: {
|
|
props: Props;
|
|
name: Name;
|
|
theme?: Theme;
|
|
}): Props & ThemedProps<Theme, Name>;
|