From d3cafb48b0f9412d96720c5bb9467f1c5d79b323 Mon Sep 17 00:00:00 2001 From: Jarda Snajdr Date: Wed, 20 Nov 2024 12:52:23 +0100 Subject: [PATCH] Implement rerender with useReducer --- .../components/src/slot-fill/bubbles-virtually/fill.tsx | 4 ++-- packages/components/src/slot-fill/slot.tsx | 4 ++-- packages/components/src/slot-fill/use-force-update.ts | 9 --------- 3 files changed, 4 insertions(+), 13 deletions(-) delete mode 100644 packages/components/src/slot-fill/use-force-update.ts diff --git a/packages/components/src/slot-fill/bubbles-virtually/fill.tsx b/packages/components/src/slot-fill/bubbles-virtually/fill.tsx index cff1bf060da219..d5287adfab4178 100644 --- a/packages/components/src/slot-fill/bubbles-virtually/fill.tsx +++ b/packages/components/src/slot-fill/bubbles-virtually/fill.tsx @@ -4,6 +4,7 @@ import { useObservableValue } from '@wordpress/compose'; import { useContext, + useReducer, useRef, useEffect, createPortal, @@ -14,13 +15,12 @@ import { */ import SlotFillContext from './slot-fill-context'; import StyleProvider from '../../style-provider'; -import useForceUpdate from '../use-force-update'; import type { FillComponentProps } from '../types'; export default function Fill( { name, children }: FillComponentProps ) { const registry = useContext( SlotFillContext ); const slot = useObservableValue( registry.slots, name ); - const rerender = useForceUpdate(); + const [ , rerender ] = useReducer( () => [], [] ); const ref = useRef( { rerender } ); useEffect( () => { diff --git a/packages/components/src/slot-fill/slot.tsx b/packages/components/src/slot-fill/slot.tsx index 9281032542df99..fe4a741ddbfbad 100644 --- a/packages/components/src/slot-fill/slot.tsx +++ b/packages/components/src/slot-fill/slot.tsx @@ -9,6 +9,7 @@ import type { ReactElement, ReactNode, Key } from 'react'; import { useContext, useEffect, + useReducer, useRef, Children, cloneElement, @@ -20,7 +21,6 @@ import { */ import SlotFillContext from './context'; import type { SlotComponentProps } from './types'; -import useForceUpdate from './use-force-update'; /** * Whether the argument is a function. @@ -34,7 +34,7 @@ function isFunction( maybeFunc: any ): maybeFunc is Function { function Slot( props: Omit< SlotComponentProps, 'bubblesVirtually' > ) { const registry = useContext( SlotFillContext ); - const rerender = useForceUpdate(); + const [ , rerender ] = useReducer( () => [], [] ); const ref = useRef( { rerender } ); const { name, children, fillProps = {} } = props; diff --git a/packages/components/src/slot-fill/use-force-update.ts b/packages/components/src/slot-fill/use-force-update.ts deleted file mode 100644 index aa038d833fba50..00000000000000 --- a/packages/components/src/slot-fill/use-force-update.ts +++ /dev/null @@ -1,9 +0,0 @@ -/** - * WordPress dependencies - */ -import { useCallback, useState } from '@wordpress/element'; - -export default function useForceUpdate() { - const [ , setState ] = useState( {} ); - return useCallback( () => setState( {} ), [] ); -}