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];
};