Current File : /home/digitaw/www/wp-content/plugins/event-tickets/src/modules/elements/container-panel/element.js
/**
 * External dependencies
 */
import React, { Fragment } from 'react';
import PropTypes from 'prop-types';
import classNames from 'classnames';

/**
 * Internal dependencies
 */
import './style.pcss';

export const LAYOUT = {
	rsvp: 'rsvp',
	ticket: 'ticket',
};

const ContainerPanel = ( { className, content, header, layout } ) => {
	const headerAndContent = (
		<Fragment>
			<div className="tribe-editor__container-panel__header">{ header }</div>
			{ content && <div className="tribe-editor__container-panel__content">{ content }</div> }
		</Fragment>
	);

	const getHeaderAndContent = () =>
		layout === LAYOUT.ticket ? (
			headerAndContent
		) : (
			<div className="tribe-editor__container-panel__header-content-wrapper">{ headerAndContent }</div>
		);

	return (
		<div
			className={ classNames(
				'tribe-editor__container-panel',
				`tribe-editor__container-panel--${ layout }`,
				className
			) }
		>
			{ getHeaderAndContent() }
		</div>
	);
};

ContainerPanel.propTypes = {
	className: PropTypes.string,
	content: PropTypes.node,
	header: PropTypes.node,
	layout: PropTypes.oneOf( Object.keys( LAYOUT ) ).isRequired,
};

export default ContainerPanel;