From c08adc2a474b2ce2714957fc1df43e4eef52be2d Mon Sep 17 00:00:00 2001 From: Daishi Kato Date: Sun, 15 Sep 2024 11:19:05 +0900 Subject: [PATCH] revert useShallow refactor in #2701 (#2703) --- src/react.ts | 12 +++--------- src/react/shallow.ts | 20 +++++--------------- src/traditional.ts | 10 ++-------- 3 files changed, 10 insertions(+), 32 deletions(-) diff --git a/src/react.ts b/src/react.ts index 4f13d6e99d..a8a58cfe22 100644 --- a/src/react.ts +++ b/src/react.ts @@ -1,8 +1,4 @@ -// import { useDebugValue, useSyncExternalStore } from 'react' -// That doesn't work in ESM, because React libs are CJS only. -// See: https://github.com/pmndrs/valtio/issues/452 -// The following is a workaround until ESM is supported. -import ReactExports from 'react' +import React from 'react' import { createStore } from './vanilla.ts' import type { Mutate, @@ -11,8 +7,6 @@ import type { StoreMutatorIdentifier, } from './vanilla.ts' -const { useDebugValue, useSyncExternalStore } = ReactExports - type ExtractState = S extends { getState: () => infer T } ? T : never type ReadonlyStoreApi = Pick< @@ -34,12 +28,12 @@ export function useStore( api: ReadonlyStoreApi, selector: (state: TState) => StateSlice = identity as any, ) { - const slice = useSyncExternalStore( + const slice = React.useSyncExternalStore( api.subscribe, () => selector(api.getState()), () => selector(api.getInitialState()), ) - useDebugValue(slice) + React.useDebugValue(slice) return slice } diff --git a/src/react/shallow.ts b/src/react/shallow.ts index 0816f370f7..3f461d4119 100644 --- a/src/react/shallow.ts +++ b/src/react/shallow.ts @@ -1,22 +1,12 @@ -// import { useRef } from 'react' -// That doesnt work in ESM, because React libs are CJS only. -// The following is a workaround until ESM is supported. -import ReactExports from 'react' +import React from 'react' import { shallow } from '../vanilla/shallow.ts' -const { useRef } = ReactExports - -const sliceCache = new WeakMap() - export function useShallow(selector: (state: S) => U): (state: S) => U { - const key = useRef({}).current + const prev = React.useRef() return (state) => { - const prev = sliceCache.get(key) as U | undefined const next = selector(state) - if (shallow(prev, next)) { - return prev as U - } - sliceCache.set(key, next) - return next + return shallow(prev.current, next) + ? (prev.current as U) + : (prev.current = next) } } diff --git a/src/traditional.ts b/src/traditional.ts index e09a69fbbc..0241596e43 100644 --- a/src/traditional.ts +++ b/src/traditional.ts @@ -1,9 +1,4 @@ -// import { useDebugValue } from 'react' -// import { useSyncExternalStoreWithSelector } from 'use-sync-external-store/shim/with-selector' -// Those don't work in ESM, because React libs are CJS only. -// See: https://github.com/pmndrs/valtio/issues/452 -// The following is a workaround until ESM is supported. -import ReactExports from 'react' +import React from 'react' // eslint-disable-next-line import/extensions import useSyncExternalStoreExports from 'use-sync-external-store/shim/with-selector' import { createStore } from './vanilla.ts' @@ -14,7 +9,6 @@ import type { StoreMutatorIdentifier, } from './vanilla.ts' -const { useDebugValue } = ReactExports const { useSyncExternalStoreWithSelector } = useSyncExternalStoreExports type ExtractState = S extends { getState: () => infer T } ? T : never @@ -48,7 +42,7 @@ export function useStoreWithEqualityFn( selector, equalityFn, ) - useDebugValue(slice) + React.useDebugValue(slice) return slice }