/** * External dependencies */ import { __ } from '@wordpress/i18n'; import classnames from 'classnames'; import PropTypes from 'prop-types'; import { InspectorControls, PlainText } from '@wordpress/block-editor'; import { PanelBody, ToggleControl, TextControl } from '@wordpress/components'; import { withInstanceId } from '@wordpress/compose'; import { useEffect } from '@wordpress/element'; /** * Internal dependencies */ import './editor.scss'; import './style.scss'; /** * Component displaying a product search form. * * @param {Object} props Incoming props for the component. * @param {Object} props.attributes Incoming block attributes. * @param {string} props.attributes.label * @param {string} props.attributes.placeholder * @param {string} props.attributes.formId * @param {string} props.attributes.className * @param {boolean} props.attributes.hasLabel * @param {string} props.attributes.align * @param {string} props.instanceId * @param {function(any):any} props.setAttributes Setter for block attributes. */ const Edit = ( { attributes: { label, placeholder, formId, className, hasLabel, align }, instanceId, setAttributes, } ) => { const classes = classnames( 'wc-block-product-search', align ? 'align' + align : '', className ); useEffect( () => { if ( ! formId ) { setAttributes( { formId: `wc-block-product-search-${ instanceId }`, } ); } }, [ formId, setAttributes, instanceId ] ); return ( <> setAttributes( { hasLabel: ! hasLabel } ) } />
{ !! hasLabel && ( <> setAttributes( { label: value } ) } /> </> ) } <div className="wc-block-product-search__fields"> <TextControl className="wc-block-product-search__field input-control" value={ placeholder } onChange={ ( value ) => setAttributes( { placeholder: value } ) } /> <button type="submit" className="wc-block-product-search__button" label={ __( 'Search', 'woo-gutenberg-products-block' ) } onClick={ ( e ) => e.preventDefault() } tabIndex="-1" > <svg aria-hidden="true" role="img" focusable="false" className="dashicon dashicons-arrow-right-alt2" xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20" > <path d="M6 15l5-5-5-5 1-2 7 7-7 7z" /> </svg> </button> </div> </div> </> ); }; Edit.propTypes = { /** * The attributes for this block. */ attributes: PropTypes.object.isRequired, /** * A unique ID for identifying the label for the select dropdown. */ instanceId: PropTypes.number, /** * Whether it's in the editor or frontend display. */ isEditor: PropTypes.bool, /** * A callback to update attributes. */ setAttributes: PropTypes.func, }; export default withInstanceId( Edit );