woocommerce/plugins/woocommerce-blocks/assets/js/blocks/checkout/order-notes/index.tsx

64 lines
1.7 KiB
TypeScript
Raw Normal View History

/**
* External dependencies
*/
import { __ } from '@wordpress/i18n';
import { useState } from '@wordpress/element';
import { CheckboxControl, Textarea } from '@woocommerce/blocks-components';
interface CheckoutOrderNotesProps {
disabled: boolean;
onChange: ( orderNotes: string ) => void;
placeholder: string;
value: string;
}
const CheckoutOrderNotes = ( {
disabled,
onChange,
placeholder,
value,
}: CheckoutOrderNotesProps ): JSX.Element => {
const [ withOrderNotes, setWithOrderNotes ] = useState( false );
// Store order notes when the textarea is hidden. This allows us to recover
// text entered previously by the user when the checkbox is re-enabled
// while keeping the context clean if the checkbox is disabled.
const [ hiddenOrderNotesText, setHiddenOrderNotesText ] = useState( '' );
return (
<div className="wc-block-checkout__add-note">
<CheckboxControl
disabled={ disabled }
2023-12-12 23:05:20 +00:00
label={ __( 'Add a note to your order', 'woocommerce' ) }
checked={ withOrderNotes }
onChange={ ( isChecked ) => {
setWithOrderNotes( isChecked );
if ( isChecked ) {
// When re-enabling the checkbox, store in context the
// order notes value previously stored in the component
// state.
if ( value !== hiddenOrderNotesText ) {
onChange( hiddenOrderNotesText );
}
} else {
// When un-checking the checkbox, clear the order notes
// value in the context but store it in the component
// state.
onChange( '' );
setHiddenOrderNotesText( value );
}
} }
/>
{ withOrderNotes && (
<Textarea
disabled={ disabled }
onTextChange={ onChange }
placeholder={ placeholder }
value={ value }
/>
) }
</div>
);
};
export default CheckoutOrderNotes;