From 50210e5405b1f03b0f7fdb8682d15b4bed2e595a Mon Sep 17 00:00:00 2001 From: Vasily Strelyaev Date: Fri, 3 Jan 2025 16:35:02 +0200 Subject: [PATCH] refix react 19 compatibility --- .../src/core/component-base.tsx | 58 +++++++++---------- .../src/core/use-option-scanning.ts | 9 +-- 2 files changed, 29 insertions(+), 38 deletions(-) diff --git a/packages/devextreme-react/src/core/component-base.tsx b/packages/devextreme-react/src/core/component-base.tsx index 3d25f0d4ec10..2edd84c8ccd7 100644 --- a/packages/devextreme-react/src/core/component-base.tsx +++ b/packages/devextreme-react/src/core/component-base.tsx @@ -9,8 +9,8 @@ import { useLayoutEffect, useCallback, useState, - useMemo, ReactElement, + useMemo, } from 'react'; import { requestAnimationFrame } from 'devextreme/animation/frame'; @@ -98,6 +98,31 @@ const ComponentBase = forwardRef( let widgetConfig: IConfigNode; + const templateContainer = useMemo(() => document.createElement('div'), []); + + const elementDescriptor: IOptionElement = { + type: ElementType.Option, + descriptor: { + name: '', + isCollection: false, + templates: templateProps, + initialValuesProps: defaults, + predefinedValuesProps: {}, + expectedChildren, + }, + props, + }; + + const options = useOptionScanning( + elementDescriptor, + props.children, + templateContainer, + Symbol('initial update token'), + ); + + [widgetConfig] = options; + const [, context] = options; + const restoreTree = useCallback(() => { if (childElementsDetached.current && childNodes.current?.length && element.current) { element.current.append(...childNodes.current); @@ -249,6 +274,7 @@ const ComponentBase = forwardRef( instance.current, subscribableOptions, independentEvents, + widgetConfig, ]); const onTemplatesRendered = useCallback(() => { @@ -279,6 +305,7 @@ const ComponentBase = forwardRef( scheduleTemplatesUpdate, updateCssClasses, props, + widgetConfig, ]); const onComponentMounted = useCallback(() => { @@ -339,35 +366,6 @@ const ComponentBase = forwardRef( shouldRestoreFocus.current, ]); - const templateContainer = useMemo(() => document.createElement('div'), []); - - const elementDescriptor: IOptionElement = useMemo(() => ({ - type: ElementType.Option, - descriptor: { - name: '', - isCollection: false, - templates: templateProps, - initialValuesProps: defaults, - predefinedValuesProps: {}, - expectedChildren, - }, - props, - }), [ - templateProps, - defaults, - props, - ]); - - const options = useOptionScanning( - elementDescriptor, - props.children, - templateContainer, - Symbol('initial update token'), - ); - - [widgetConfig] = options; - const [, context] = options; - useLayoutEffect(() => { onComponentMounted(); diff --git a/packages/devextreme-react/src/core/use-option-scanning.ts b/packages/devextreme-react/src/core/use-option-scanning.ts index 3c36b225578a..6da9395a6717 100644 --- a/packages/devextreme-react/src/core/use-option-scanning.ts +++ b/packages/devextreme-react/src/core/use-option-scanning.ts @@ -5,7 +5,6 @@ import { useContext, useRef, useLayoutEffect, - useMemo, } from 'react'; import { ElementType, getElementType, IOptionElement } from './configuration/react/element'; @@ -32,13 +31,7 @@ export function useOptionScanning( const updateToken = Symbol('update token'); - const configBuilder = useMemo( - () => createConfigBuilder(optionElement, parentFullName), - [ - optionElement, - parentFullName, - ], - ); + const configBuilder = createConfigBuilder(optionElement, parentFullName); Children.forEach( children,