From f50e045c1ce75acd026ab760891cd5bf57234fd3 Mon Sep 17 00:00:00 2001 From: Lena Morita Date: Tue, 30 Jul 2024 02:08:46 +0900 Subject: [PATCH] FormToggle, ToggleControl: Fix docgen in Storybook (#64065) * ToggleControl: Fix docgen in Storybook * FormToggle: Fix docgen in Storybook Co-authored-by: mirka <0mirka00@git.wordpress.org> Co-authored-by: tyxla --- packages/components/src/form-toggle/index.tsx | 44 +++++++++--------- .../components/src/toggle-control/index.tsx | 46 ++++++++++--------- 2 files changed, 47 insertions(+), 43 deletions(-) diff --git a/packages/components/src/form-toggle/index.tsx b/packages/components/src/form-toggle/index.tsx index f0f800514a411f..8a90fe4561bff4 100644 --- a/packages/components/src/form-toggle/index.tsx +++ b/packages/components/src/form-toggle/index.tsx @@ -17,26 +17,7 @@ import type { WordPressComponentProps } from '../context'; export const noop = () => {}; -/** - * FormToggle switches a single setting on or off. - * - * ```jsx - * import { FormToggle } from '@wordpress/components'; - * import { useState } from '@wordpress/element'; - * - * const MyFormToggle = () => { - * const [ isChecked, setChecked ] = useState( true ); - * - * return ( - * setChecked( ( state ) => ! state ) } - * /> - * ); - * }; - * ``` - */ -export function FormToggle( +function UnforwardedFormToggle( props: WordPressComponentProps< FormToggleProps, 'input', false >, ref: ForwardedRef< HTMLInputElement > ) { @@ -71,4 +52,25 @@ export function FormToggle( ); } -export default forwardRef( FormToggle ); +/** + * FormToggle switches a single setting on or off. + * + * ```jsx + * import { FormToggle } from '@wordpress/components'; + * import { useState } from '@wordpress/element'; + * + * const MyFormToggle = () => { + * const [ isChecked, setChecked ] = useState( true ); + * + * return ( + * setChecked( ( state ) => ! state ) } + * /> + * ); + * }; + * ``` + */ +export const FormToggle = forwardRef( UnforwardedFormToggle ); + +export default FormToggle; diff --git a/packages/components/src/toggle-control/index.tsx b/packages/components/src/toggle-control/index.tsx index 89ef34f6d6e5e6..2c405352ab215f 100644 --- a/packages/components/src/toggle-control/index.tsx +++ b/packages/components/src/toggle-control/index.tsx @@ -23,27 +23,7 @@ import { HStack } from '../h-stack'; import { useCx } from '../utils'; import { space } from '../utils/space'; -/** - * ToggleControl is used to generate a toggle user interface. - * - * ```jsx - * import { ToggleControl } from '@wordpress/components'; - * import { useState } from '@wordpress/element'; - * - * const MyToggleControl = () => { - * const [ value, setValue ] = useState( false ); - * - * return ( - * setValue( ( state ) => ! state ) } - * /> - * ); - * }; - * ``` - */ -export function ToggleControl( +function UnforwardedToggleControl( { __nextHasNoMarginBottom, label, @@ -121,4 +101,26 @@ export function ToggleControl( ); } -export default forwardRef( ToggleControl ); +/** + * ToggleControl is used to generate a toggle user interface. + * + * ```jsx + * import { ToggleControl } from '@wordpress/components'; + * import { useState } from '@wordpress/element'; + * + * const MyToggleControl = () => { + * const [ value, setValue ] = useState( false ); + * + * return ( + * setValue( ( state ) => ! state ) } + * /> + * ); + * }; + * ``` + */ +export const ToggleControl = forwardRef( UnforwardedToggleControl ); + +export default ToggleControl;