From f0f60a0ed79f05ec2f5c2ef1a3eeb13e8e533e61 Mon Sep 17 00:00:00 2001 From: Cheton Wu <447801+cheton@users.noreply.github.com> Date: Sun, 15 Oct 2023 19:07:12 +0800 Subject: [PATCH] feat: enhance the memoization of the setter function in `useColorMode` and `useColorStyle` Hooks (#803) * feat: enhance the memoization of the setter function in `useColorMode` and `useColorStyle` Hooks * docs: update `useColorMode` and `useColorStyle` pages * docs: update color-mode and color-style pages --- packages/react-docs/components/CodeBlock.js | 2 +- .../pages/components/color-mode/dark-mode.js | 32 +++++++ .../components/color-mode/dark-mode.page.mdx | 24 +---- .../color-mode/inverted-mode-tooltip.js | 25 ++++++ .../components/color-mode/inverted-mode.js | 32 +++++++ .../color-mode/inverted-mode.page.mdx | 38 +------- .../pages/components/color-mode/light-mode.js | 32 +++++++ .../components/color-mode/light-mode.page.mdx | 24 +---- .../{color-mode.js => useColorMode.js} | 0 .../color-mode/useColorMode.page.mdx | 2 +- .../components/color-style/useColorStyle.js | 88 +++++++++++++++++++ .../color-style/useColorStyle.page.mdx | 80 +---------------- packages/react/src/color-mode/useColorMode.js | 6 +- .../react/src/color-style/useColorStyle.js | 6 +- 14 files changed, 222 insertions(+), 169 deletions(-) create mode 100644 packages/react-docs/pages/components/color-mode/dark-mode.js create mode 100644 packages/react-docs/pages/components/color-mode/inverted-mode-tooltip.js create mode 100644 packages/react-docs/pages/components/color-mode/inverted-mode.js create mode 100644 packages/react-docs/pages/components/color-mode/light-mode.js rename packages/react-docs/pages/components/color-mode/{color-mode.js => useColorMode.js} (100%) create mode 100644 packages/react-docs/pages/components/color-style/useColorStyle.js diff --git a/packages/react-docs/components/CodeBlock.js b/packages/react-docs/components/CodeBlock.js index c06479b30c..5e0c6361ad 100644 --- a/packages/react-docs/components/CodeBlock.js +++ b/packages/react-docs/components/CodeBlock.js @@ -119,7 +119,7 @@ const CodeBlock = ({ }, []); const language = React.isValidElement(children) ? ensureString(children.props.className).replace(/language-/, '') - : null; + : ''; noInline = boolean(noInline); diff --git a/packages/react-docs/pages/components/color-mode/dark-mode.js b/packages/react-docs/pages/components/color-mode/dark-mode.js new file mode 100644 index 0000000000..e65f10cb1d --- /dev/null +++ b/packages/react-docs/pages/components/color-mode/dark-mode.js @@ -0,0 +1,32 @@ +import { + Box, + DarkMode, + Text, + useColorMode, + useColorStyle, +} from '@tonic-ui/react'; +import React from 'react'; + +const Component = () => { + const [colorMode] = useColorMode(); + const [colorStyle] = useColorStyle({ colorMode }); + + return ( + + + The color mode is set to {colorMode} + + + ); +}; + +const App = () => ( + + + +); + +export default App; diff --git a/packages/react-docs/pages/components/color-mode/dark-mode.page.mdx b/packages/react-docs/pages/components/color-mode/dark-mode.page.mdx index c1eb9d22d6..a5ae6cf9db 100644 --- a/packages/react-docs/pages/components/color-mode/dark-mode.page.mdx +++ b/packages/react-docs/pages/components/color-mode/dark-mode.page.mdx @@ -10,29 +10,7 @@ import { DarkMode } from '@tonic-ui/react'; ## Usage -```jsx noInline -function Example() { - const [colorMode] = useColorMode(); - const [colorStyle] = useColorStyle({ colorMode }); - - return ( - - - The color mode is set to {colorMode} - - - ); -} - -render( - - - -); -``` +{render('./dark-mode')} ## Props diff --git a/packages/react-docs/pages/components/color-mode/inverted-mode-tooltip.js b/packages/react-docs/pages/components/color-mode/inverted-mode-tooltip.js new file mode 100644 index 0000000000..a0ff5e4faa --- /dev/null +++ b/packages/react-docs/pages/components/color-mode/inverted-mode-tooltip.js @@ -0,0 +1,25 @@ +import { + Divider, + InvertedMode, + Text, + Tooltip, +} from '@tonic-ui/react'; +import React from 'react'; + +const App = () => { + return ( + + Title + + Content + + )} + > + Hover Me + + ); +}; + +export default App; diff --git a/packages/react-docs/pages/components/color-mode/inverted-mode.js b/packages/react-docs/pages/components/color-mode/inverted-mode.js new file mode 100644 index 0000000000..395296ee07 --- /dev/null +++ b/packages/react-docs/pages/components/color-mode/inverted-mode.js @@ -0,0 +1,32 @@ +import { + Box, + InvertedMode, + Text, + useColorMode, + useColorStyle, +} from '@tonic-ui/react'; +import React from 'react'; + +const Component = () => { + const [colorMode] = useColorMode(); + const [colorStyle] = useColorStyle({ colorMode }); + + return ( + + + The current color mode is inverted to {colorMode} mode + + + ); +}; + +const App = () => ( + + + +); + +export default App; diff --git a/packages/react-docs/pages/components/color-mode/inverted-mode.page.mdx b/packages/react-docs/pages/components/color-mode/inverted-mode.page.mdx index a4937133cc..087927da30 100644 --- a/packages/react-docs/pages/components/color-mode/inverted-mode.page.mdx +++ b/packages/react-docs/pages/components/color-mode/inverted-mode.page.mdx @@ -10,47 +10,13 @@ import { InvertedMode } from '@tonic-ui/react'; ## Usage -```jsx noInline -function Example() { - const [colorMode] = useColorMode(); - const [colorStyle] = useColorStyle({ colorMode }); - - return ( - - - The current color mode is inverted to {colorMode} mode - - - ); -} - -render( - - - -); -``` +{render('./inverted-mode')} ### Rendering tooltip label The `InvertedMode` component is useful when you want to render a tooltip label in inverted mode. -```jsx - - Title - - Content - - )} -> - Hover Me - -``` +{render('./inverted-mode-tooltip')} ## Props diff --git a/packages/react-docs/pages/components/color-mode/light-mode.js b/packages/react-docs/pages/components/color-mode/light-mode.js new file mode 100644 index 0000000000..081bbd1287 --- /dev/null +++ b/packages/react-docs/pages/components/color-mode/light-mode.js @@ -0,0 +1,32 @@ +import { + Box, + LightMode, + Text, + useColorMode, + useColorStyle, +} from '@tonic-ui/react'; +import React from 'react'; + +const Component = () => { + const [colorMode] = useColorMode(); + const [colorStyle] = useColorStyle({ colorMode }); + + return ( + + + The color mode is set to {colorMode} + + + ); +}; + +const App = () => ( + + + +); + +export default App; diff --git a/packages/react-docs/pages/components/color-mode/light-mode.page.mdx b/packages/react-docs/pages/components/color-mode/light-mode.page.mdx index 55428d2d97..a8bdd58a16 100644 --- a/packages/react-docs/pages/components/color-mode/light-mode.page.mdx +++ b/packages/react-docs/pages/components/color-mode/light-mode.page.mdx @@ -10,29 +10,7 @@ import { LightMode } from '@tonic-ui/react'; ## Usage -```jsx noInline -function Example() { - const [colorMode] = useColorMode(); - const [colorStyle] = useColorStyle({ colorMode }); - - return ( - - - The color mode is set to {colorMode} - - - ); -} - -render( - - - -); -``` +{render('./light-mode')} ## Props diff --git a/packages/react-docs/pages/components/color-mode/color-mode.js b/packages/react-docs/pages/components/color-mode/useColorMode.js similarity index 100% rename from packages/react-docs/pages/components/color-mode/color-mode.js rename to packages/react-docs/pages/components/color-mode/useColorMode.js diff --git a/packages/react-docs/pages/components/color-mode/useColorMode.page.mdx b/packages/react-docs/pages/components/color-mode/useColorMode.page.mdx index 43f3340e32..6043ee0588 100644 --- a/packages/react-docs/pages/components/color-mode/useColorMode.page.mdx +++ b/packages/react-docs/pages/components/color-mode/useColorMode.page.mdx @@ -53,4 +53,4 @@ Returns an array with the current color mode and a function to change the color ## Demos -{render('./color-mode')} +{render('./useColorMode')} diff --git a/packages/react-docs/pages/components/color-style/useColorStyle.js b/packages/react-docs/pages/components/color-style/useColorStyle.js new file mode 100644 index 0000000000..d558d694d8 --- /dev/null +++ b/packages/react-docs/pages/components/color-style/useColorStyle.js @@ -0,0 +1,88 @@ +import { + Box, + Divider, + Stack, + useColorMode, + useColorStyle, +} from '@tonic-ui/react'; +import React from 'react'; + +const App = () => { + const [colorMode] = useColorMode(); + const [colorStyle] = useColorStyle({ colorMode }); + const invertedPrimaryColor = { + dark: 'black:primary', + light: 'white:primary', + }[colorMode]; + + return ( + + Background + *': { + px: '3x', + py: '2x', + }, + }} + > + + colorStyle.background.primary + + + colorStyle.background.secondary + + + colorStyle.background.tertiary + + + colorStyle.background.inverted + + + colorStyle.background.highlighted + + + colorStyle.background.selected + + + + *': { + px: '3x', + }, + '> *:not(:last-child)': { + pb: '2x', + }, + }} + > + + colorStyle.color.primary + + + colorStyle.color.secondary + + + colorStyle.color.tertiary + + + colorStyle.color.disabled + + + colorStyle.color.success + + + colorStyle.color.info + + + colorStyle.color.warning + + + colorStyle.color.error + + + + ); +}; + +export default App; diff --git a/packages/react-docs/pages/components/color-style/useColorStyle.page.mdx b/packages/react-docs/pages/components/color-style/useColorStyle.page.mdx index 23d813988f..fae1ff775d 100644 --- a/packages/react-docs/pages/components/color-style/useColorStyle.page.mdx +++ b/packages/react-docs/pages/components/color-style/useColorStyle.page.mdx @@ -42,82 +42,4 @@ Returns an array with the color style object and a function to set the color sty ## Demos -```jsx -function Example() { - const [colorMode] = useColorMode(); - const [colorStyle, setColorStyle] = useColorStyle({ colorMode }); - const invertedPrimaryColor = { - dark: 'black:primary', - light: 'white:primary', - }[colorMode]; - - return ( - - Background - *': { - px: '3x', - py: '2x', - }, - }} - > - - colorStyle.background.primary - - - colorStyle.background.secondary - - - colorStyle.background.tertiary - - - colorStyle.background.inverted - - - colorStyle.background.highlighted - - - colorStyle.background.selected - - - - *': { - px: '3x', - }, - '> *:not(:last-child)': { - pb: '2x', - }, - }} - > - - colorStyle.color.primary - - - colorStyle.color.secondary - - - colorStyle.color.tertiary - - - colorStyle.color.disabled - - - colorStyle.color.success - - - colorStyle.color.info - - - colorStyle.color.warning - - - colorStyle.color.error - - - - ); -} -``` +{render('./useColorStyle')} diff --git a/packages/react/src/color-mode/useColorMode.js b/packages/react/src/color-mode/useColorMode.js index e9432deb5e..48165d12e6 100644 --- a/packages/react/src/color-mode/useColorMode.js +++ b/packages/react/src/color-mode/useColorMode.js @@ -1,5 +1,5 @@ import { ensurePlainObject } from 'ensure-type'; -import { useContext } from 'react'; +import { useCallback, useContext } from 'react'; import { ColorModeContext } from './context'; const useColorMode = () => { @@ -15,14 +15,14 @@ const useColorMode = () => { const { colorMode, onChange } = ensurePlainObject(context); const getter = colorMode; - const setter = (value) => { + const setter = useCallback((value) => { if (typeof value === 'function') { value = value(colorMode); } const nextColorMode = value; onChange(nextColorMode); - }; + }, [colorMode, onChange]); return [getter, setter]; }; diff --git a/packages/react/src/color-style/useColorStyle.js b/packages/react/src/color-style/useColorStyle.js index f981e47829..fbd544bf2f 100644 --- a/packages/react/src/color-style/useColorStyle.js +++ b/packages/react/src/color-style/useColorStyle.js @@ -1,5 +1,5 @@ import { ensurePlainObject } from 'ensure-type'; -import { useContext } from 'react'; +import { useCallback, useContext } from 'react'; import { ColorModeContext } from '../color-mode/context'; import { ColorStyleContext } from './context'; @@ -23,7 +23,7 @@ const useColorStyle = (options) => { } const getter = ensurePlainObject(colorStyle[colorMode]); - const setter = (value) => { + const setter = useCallback((value) => { if (typeof value === 'function') { value = value(colorStyle); } @@ -33,7 +33,7 @@ const useColorStyle = (options) => { [colorMode]: ensurePlainObject(value), }; onChange(nextColorStyle); - }; + }, [colorMode, colorStyle, onChange]); return [getter, setter]; };