File "PostMetaControl.js"

Full path: /home/webcknlt/admissiontell.com/wp-content/plugins/generateblocks/src/extend/dynamic-content/inspector-controls/PostMetaControl.js
File size: 1.69 B
MIME-type: text/x-java
Charset: utf-8

Download   Open   Edit   Advanced Editor &nnbsp; Back

import usePostRecord from '../hooks/usePostRecord';
import { __ } from '@wordpress/i18n';
import AdvancedSelect from '../../../components/advanced-select';
import { applyFilters } from '@wordpress/hooks';

export default function PostMetaControl( props ) {
	const {
		isActive = false,
		metaFieldKey = 'metaFieldName',
		postType,
		postId,
		metaFieldName,
		setAttributes,
	} = props;

	const { record, isLoading } = usePostRecord( postType, postId );
	const value = !! metaFieldName ? { value: metaFieldName, label: metaFieldName } : undefined;

	let options = !! value ? [ value ] : [];

	if ( record && record.meta ) {
		options = options.concat( Object
			.keys( record.meta )
			.filter( ( metaKey ) => ( metaKey !== metaFieldName ) )
			.map( ( metaKey ) => ( { value: metaKey, label: metaKey } ) )
		);
	}

	const afterComponent = applyFilters(
		'generateblocks.editor.dynamicContent.PostMetaControl.afterComponent',
		undefined,
		props,
		record,
	);

	return (
		<>
			{ isActive &&
				<>
					<AdvancedSelect
						id={ 'gblocks-select-post-meta-control' }
						label={ __( 'Post meta field', 'generateblocks' ) }
						help={ __( 'Live preview is only available to meta exposed to the REST API.', 'generateblocks' ) }
						placeholder={ __( 'Choose or add meta key', 'generateblocks' ) }
						options={ options }
						value={ value }
						isSearchable
						isCreatable
						isClearable
						formatCreateLabel={ ( input ) => ( `Add "${ input }"` ) }
						isLoading={ isLoading }
						onChange={ ( option ) => {
							setAttributes( { [ metaFieldKey ]: option?.value || undefined } );
						} }
					/>

					{ afterComponent }
				</>
			}
		</>
	);
}

PostMetaControl.displayName = 'PostMetaControl';