mirror of
https://github.com/woocommerce/woocommerce-paypal-payments.git
synced 2025-09-06 10:55:00 +08:00
43 lines
1.1 KiB
JavaScript
43 lines
1.1 KiB
JavaScript
import { useState } from '@wordpress/element';
|
|
import { ToggleControl } from '@wordpress/components';
|
|
|
|
const SettingsToggleBlock = ( props ) => {
|
|
const [ isToggled, setToggled ] = useState( false );
|
|
|
|
return (
|
|
<div className="ppcp-r-toggle-block">
|
|
<div className="ppcp-r-toggle-block__wrapper">
|
|
<div className="ppcp-r-toggle-block__content">
|
|
{ props?.label && (
|
|
<span className="ppcp-r-toggle-block__content-label">
|
|
{ props.label }
|
|
</span>
|
|
) }
|
|
{ props?.description && (
|
|
<p
|
|
className="ppcp-r-toggle-block__content-description"
|
|
dangerouslySetInnerHTML={ {
|
|
__html: props.description,
|
|
} }
|
|
></p>
|
|
) }
|
|
</div>
|
|
<div className="ppcp-r-toggle-block__switch">
|
|
<ToggleControl
|
|
checked={ isToggled }
|
|
onChange={ ( newValue ) => {
|
|
setToggled( newValue );
|
|
} }
|
|
/>
|
|
</div>
|
|
</div>
|
|
{ props.children && isToggled && (
|
|
<div className="ppcp-r-toggle-block__toggled-content">
|
|
{ props.children }
|
|
</div>
|
|
) }
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default SettingsToggleBlock;
|