diff --git a/docs/custom-components/custom-providers.mdx b/docs/custom-components/custom-providers.mdx index d3e5321622..26abe74fd1 100644 --- a/docs/custom-components/custom-providers.mdx +++ b/docs/custom-components/custom-providers.mdx @@ -27,19 +27,19 @@ Then build your Custom Provider as follows: ```tsx 'use client' -import React, { createContext, useContext } from 'react' +import React, { createContext, use } from 'react' const MyCustomContext = React.createContext(myCustomValue) export function MyProvider({ children }: { children: React.ReactNode }) { return ( - + {children} - + ) } -export const useMyCustomContext = () => useContext(MyCustomContext) +export const useMyCustomContext = () => use(MyCustomContext) ``` _For details on how to build Custom Components, see [Building Custom Components](./overview#building-custom-components)._ diff --git a/examples/auth/src/app/(app)/_providers/Auth/index.tsx b/examples/auth/src/app/(app)/_providers/Auth/index.tsx index 6083705c58..78da1ea569 100644 --- a/examples/auth/src/app/(app)/_providers/Auth/index.tsx +++ b/examples/auth/src/app/(app)/_providers/Auth/index.tsx @@ -2,7 +2,7 @@ import type { Permissions } from 'payload/auth' -import React, { createContext, useCallback, useContext, useEffect, useState } from 'react' +import React, { createContext, useCallback, use, useEffect, useState } from 'react' import type { User } from '../../../../payload-types' import type { AuthContext, Create, ForgotPassword, Login, Logout, ResetPassword } from './types' @@ -163,7 +163,7 @@ export const AuthProvider: React.FC<{ api?: 'gql' | 'rest'; children: React.Reac ) return ( - {children} - + ) } -type UseAuth = () => AuthContext +type UseAuth = () => AuthContext -export const useAuth: UseAuth = () => useContext(Context) +export const useAuth: UseAuth = () => use(Context) diff --git a/examples/localization/src/providers/HeaderTheme/index.tsx b/examples/localization/src/providers/HeaderTheme/index.tsx index 76666f1017..1d0255787c 100644 --- a/examples/localization/src/providers/HeaderTheme/index.tsx +++ b/examples/localization/src/providers/HeaderTheme/index.tsx @@ -2,7 +2,7 @@ import type { Theme } from '@/providers/Theme/types' -import React, { createContext, useCallback, useContext, useState } from 'react' +import React, { createContext, useCallback, use, useState } from 'react' import canUseDOM from '@/utilities/canUseDOM' @@ -27,11 +27,7 @@ export const HeaderThemeProvider = ({ children }: { children: React.ReactNode }) setThemeState(themeToSet) }, []) - return ( - - {children} - - ) + return {children} } -export const useHeaderTheme = (): ContextType => useContext(HeaderThemeContext) +export const useHeaderTheme = (): ContextType => use(HeaderThemeContext) diff --git a/examples/localization/src/providers/Theme/index.tsx b/examples/localization/src/providers/Theme/index.tsx index 882d8318d4..60dcedca40 100644 --- a/examples/localization/src/providers/Theme/index.tsx +++ b/examples/localization/src/providers/Theme/index.tsx @@ -1,6 +1,6 @@ 'use client' -import React, { createContext, useCallback, useContext, useEffect, useState } from 'react' +import React, { createContext, useCallback, use, useEffect, useState } from 'react' import type { Theme, ThemeContextType } from './types' @@ -51,7 +51,7 @@ export const ThemeProvider = ({ children }: { children: React.ReactNode }) => { setThemeState(themeToSet) }, []) - return {children} + return {children} } -export const useTheme = (): ThemeContextType => useContext(ThemeContext) +export const useTheme = (): ThemeContextType => use(ThemeContext) diff --git a/packages/next/src/views/LivePreview/Context/context.ts b/packages/next/src/views/LivePreview/Context/context.ts index 236bc419ae..a35d6dbe7d 100644 --- a/packages/next/src/views/LivePreview/Context/context.ts +++ b/packages/next/src/views/LivePreview/Context/context.ts @@ -4,7 +4,7 @@ import type { fieldSchemaToJSON } from 'payload/shared' import type { Dispatch } from 'react' import type React from 'react' -import { createContext, useContext } from 'react' +import { createContext, use } from 'react' import type { usePopupWindow } from '../usePopupWindow.js' import type { SizeReducerAction } from './sizeReducer.js' @@ -83,4 +83,4 @@ export const LivePreviewContext = createContext({ zoom: 1, }) -export const useLivePreviewContext = () => useContext(LivePreviewContext) +export const useLivePreviewContext = () => use(LivePreviewContext) diff --git a/packages/next/src/views/LivePreview/Context/index.tsx b/packages/next/src/views/LivePreview/Context/index.tsx index 3ea06d3cb2..7878d3c441 100644 --- a/packages/next/src/views/LivePreview/Context/index.tsx +++ b/packages/next/src/views/LivePreview/Context/index.tsx @@ -166,7 +166,7 @@ export const LivePreviewProvider: React.FC = ({ }, [previewWindowType, isPopupOpen, handleWindowChange]) return ( - = ({ {listeningForMessages && children} - + ) } diff --git a/packages/next/src/views/Version/Default/SelectedLocalesContext.tsx b/packages/next/src/views/Version/Default/SelectedLocalesContext.tsx index 484b6a64d4..2913b82a64 100644 --- a/packages/next/src/views/Version/Default/SelectedLocalesContext.tsx +++ b/packages/next/src/views/Version/Default/SelectedLocalesContext.tsx @@ -1,6 +1,6 @@ 'use client' -import React, { createContext } from 'react' +import { createContext, use } from 'react' type SelectedLocalesContextType = { selectedLocales: string[] @@ -10,4 +10,4 @@ export const SelectedLocalesContext = createContext( selectedLocales: [], }) -export const useSelectedLocales = () => React.useContext(SelectedLocalesContext) +export const useSelectedLocales = () => use(SelectedLocalesContext) diff --git a/packages/next/src/views/Version/Default/index.tsx b/packages/next/src/views/Version/Default/index.tsx index d25dfb9261..034243c3d0 100644 --- a/packages/next/src/views/Version/Default/index.tsx +++ b/packages/next/src/views/Version/Default/index.tsx @@ -182,11 +182,11 @@ export const DefaultVersionView: React.FC = ({ /> )} - locale.value) }} > {doc?.version && RenderedDiff} - + ) diff --git a/packages/plugin-import-export/src/components/ImportExportProvider/index.tsx b/packages/plugin-import-export/src/components/ImportExportProvider/index.tsx index fc4c4d03f4..185708f8f8 100644 --- a/packages/plugin-import-export/src/components/ImportExportProvider/index.tsx +++ b/packages/plugin-import-export/src/components/ImportExportProvider/index.tsx @@ -1,5 +1,5 @@ 'use client' -import React, { createContext, useCallback, useContext, useState } from 'react' +import React, { createContext, use, useCallback, useState } from 'react' type ImportExportContext = { collection: string @@ -16,15 +16,15 @@ export const ImportExportProvider: React.FC<{ children: React.ReactNode }> = ({ }, []) return ( - {children} - + ) } -export const useImportExport = (): ImportExportContext => useContext(ImportExportContext) +export const useImportExport = (): ImportExportContext => use(ImportExportContext) diff --git a/packages/richtext-lexical/src/features/blocks/client/component/BlockContent.tsx b/packages/richtext-lexical/src/features/blocks/client/component/BlockContent.tsx index 471bd137e5..5f25764d1e 100644 --- a/packages/richtext-lexical/src/features/blocks/client/component/BlockContent.tsx +++ b/packages/richtext-lexical/src/features/blocks/client/component/BlockContent.tsx @@ -49,7 +49,7 @@ const BlockComponentContext = createContext({ initialState: false, }) -export const useBlockComponentContext = () => React.useContext(BlockComponentContext) +export const useBlockComponentContext = () => React.use(BlockComponentContext) /** * The actual content of the Block. This should be INSIDE a Form component, @@ -99,7 +99,7 @@ export const BlockContent: React.FC = (props) => { ) return CustomBlock ? ( - = (props) => { > {CustomBlock} - + ) : ( React.useContext(InlineBlockComponentContext) +export const useInlineBlockComponentContext = () => React.use(InlineBlockComponentContext) export const InlineBlockComponent: React.FC = (props) => { const { cacheBuster, formData, nodeKey } = props @@ -426,7 +426,7 @@ export const InlineBlockComponent: React.FC = (props) => { {CustomBlock ? ( - = (props) => { }} > {CustomBlock} - + ) : ( {initialState ?