File "menu.js"

Full Path: /home/warrior1/public_html/wp-content/plugins/elementor/app/assets/js/ui/menu/menu.js
File size: 1.44 KB
MIME-type: text/x-java
Charset: utf-8

import './menu.scss';
import Button from '../molecules/button';
import router from '@elementor/router';
import { Match, LocationProvider } from '@reach/router';

export default function Menu( props ) {
	const ActionButton = ( itemProps ) => {
		if ( ! props.actionButton ) {
			return '';
		}

		return props.actionButton( itemProps );
	};

	if ( props.promotion ) {
		return (
			<nav className="eps-menu">
				{ props.children }
				<ul>
					{ props.menuItems.map( ( item ) => (
						<li key={ item.type } className="eps-menu-item">
							<Button text={ item.title } className="eps-menu-item__link" { ...item } />
							<ActionButton { ...item } />
						</li>
					) ) }
				</ul>
			</nav>
		);
	}

	return (
		<LocationProvider history={ router.appHistory }>
			<nav className="eps-menu">
				{ props.children }
				<ul>
					{ (
					props.menuItems.map( ( item ) => (
						<Match key={ item.type } path={ item.url }>
							{ ( { match } ) => {
								return (
									<li key={ item.type } className={ `eps-menu-item${ match ? ' eps-menu-item--active' : '' }` }>
										<Button text={ item.title } className="eps-menu-item__link" { ...item } />
										<ActionButton { ...item } />
									</li>
								);
							} }
						</Match>
					) )
				) }
				</ul>
			</nav>
		</LocationProvider>
	);
}

Menu.propTypes = {
	menuItems: PropTypes.arrayOf( PropTypes.object ),
	children: PropTypes.any,
	actionButton: PropTypes.func,
	promotion: PropTypes.bool,
};