/** * External dependencies */ import { __ } from '@wordpress/i18n'; import classnames from 'classnames'; import { useState, useEffect } from '@wordpress/element'; import { CheckboxControl } from '@woocommerce/blocks-checkout'; import { useCheckoutSubmit } from '@woocommerce/base-context/hooks'; import { withInstanceId } from '@wordpress/compose'; import { useDispatch, useSelect } from '@wordpress/data'; import { VALIDATION_STORE_KEY } from '@woocommerce/block-data'; /** * Internal dependencies */ import { termsConsentDefaultText, termsCheckboxDefaultText } from './constants'; import './style.scss'; const FrontendBlock = ( { text, checkbox, instanceId, className, }: { text: string; checkbox: boolean; instanceId: string; className?: string; } ): JSX.Element => { const [ checked, setChecked ] = useState( false ); const { isDisabled } = useCheckoutSubmit(); const validationErrorId = 'terms-and-conditions-' + instanceId; const { setValidationErrors, clearValidationError } = useDispatch( VALIDATION_STORE_KEY ); const error = useSelect( ( select ) => { return select( VALIDATION_STORE_KEY ).getValidationError( validationErrorId ); } ); const hasError = !! ( error?.message && ! error?.hidden ); // Track validation errors for this input. useEffect( () => { if ( ! checkbox ) { return; } if ( checked ) { clearValidationError( validationErrorId ); } else { setValidationErrors( { [ validationErrorId ]: { message: __( 'Please read and accept the terms and conditions.', 'woo-gutenberg-products-block' ), hidden: true, }, } ); } return () => { clearValidationError( validationErrorId ); }; }, [ checkbox, checked, validationErrorId, clearValidationError, setValidationErrors, ] ); return (