From f76be0a80bbe10bb6dc43892e6f876ad46c4c95f Mon Sep 17 00:00:00 2001 From: Alexandr Isaev Date: Fri, 19 Apr 2024 19:36:41 +0300 Subject: [PATCH 1/2] fix(ThemeProvider): changed theme to config prop name --- .../layout/LayoutProvider/LayoutProvider.tsx | 17 +++++++++++++---- src/components/theme/ThemeProvider.tsx | 4 ++-- 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/src/components/layout/LayoutProvider/LayoutProvider.tsx b/src/components/layout/LayoutProvider/LayoutProvider.tsx index 2df3977a0d..37cc58fa07 100644 --- a/src/components/layout/LayoutProvider/LayoutProvider.tsx +++ b/src/components/layout/LayoutProvider/LayoutProvider.tsx @@ -6,8 +6,8 @@ import {useCurrentActiveMediaQuery} from '../hooks/useCurrentActiveMediaQuery'; import type {LayoutTheme, MediaType, RecursivePartial} from '../types'; import {makeLayoutDefaultTheme} from '../utils/makeLayoutDefaultTheme'; -export interface LayoutProviderProps { - theme?: RecursivePartial; +export interface PrivateLayoutProviderProps { + config?: RecursivePartial; /** * During ssr you can override default (`s`) media screen size if needed */ @@ -17,9 +17,9 @@ export interface LayoutProviderProps { export function PrivateLayoutProvider({ children, - theme: override, + config: override, initialMediaQuery, -}: LayoutProviderProps) { +}: PrivateLayoutProviderProps) { const theme = React.useMemo(() => makeLayoutDefaultTheme({override}), [override]); const activeMediaQuery = useCurrentActiveMediaQuery(theme.breakpoints, initialMediaQuery); @@ -35,6 +35,15 @@ export function PrivateLayoutProvider({ ); } +interface LayoutProviderProps { + theme?: RecursivePartial; + /** + * During ssr you can override default (`s`) media screen size if needed + */ + initialMediaQuery?: MediaType; + children: React.ReactNode; +} + /** * @deprecated - already used as part of ThemeProvider. To override layout theme use `layout` prop * diff --git a/src/components/theme/ThemeProvider.tsx b/src/components/theme/ThemeProvider.tsx index 53ba935a54..c982e03c1c 100644 --- a/src/components/theme/ThemeProvider.tsx +++ b/src/components/theme/ThemeProvider.tsx @@ -1,7 +1,7 @@ import React from 'react'; import {PrivateLayoutProvider} from '../layout/LayoutProvider/LayoutProvider'; -import type {LayoutProviderProps} from '../layout/LayoutProvider/LayoutProvider'; +import type {PrivateLayoutProviderProps} from '../layout/LayoutProvider/LayoutProvider'; import {block} from '../utils/cn'; import {ThemeContext} from './ThemeContext'; @@ -28,7 +28,7 @@ export interface ThemeProviderProps extends React.PropsWithChildren<{}> { nativeScrollbar?: boolean; scoped?: boolean; rootClassName?: string; - layout?: Omit; + layout?: Omit; } export function ThemeProvider({ From 9c3b0d935a2e66a642620ea356a80343b159e8a7 Mon Sep 17 00:00:00 2001 From: Alexandr Isaev Date: Fri, 19 Apr 2024 19:41:48 +0300 Subject: [PATCH 2/2] fix: typecheck --- .../layout/demo/LayoutPresenter/LayoutPresenter.tsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/layout/demo/LayoutPresenter/LayoutPresenter.tsx b/src/components/layout/demo/LayoutPresenter/LayoutPresenter.tsx index 48f9c70944..d53ff07ee2 100644 --- a/src/components/layout/demo/LayoutPresenter/LayoutPresenter.tsx +++ b/src/components/layout/demo/LayoutPresenter/LayoutPresenter.tsx @@ -33,9 +33,9 @@ function Title({title}: {title?: string}) { ); } -export const LayoutPresenter = ({children, title, theme}: LayoutPresenterProps) => { +export const LayoutPresenter = ({children, title, theme: config}: LayoutPresenterProps) => { return ( - + <div style={{