import PropTypes from 'prop-types'; import React from 'react'; import InlineSVG from 'react-inlinesvg'; import { browserHistory } from 'react-router'; const exitUrl = require('../../../images/exit.svg'); class Overlay extends React.Component { constructor(props) { super(props); this.close = this.close.bind(this); this.handleClick = this.handleClick.bind(this); this.handleClickOutside = this.handleClickOutside.bind(this); this.keyPressHandle = this.keyPressHandle.bind(this); } componentWillMount() { document.addEventListener('mousedown', this.handleClick, false); document.addEventListener('keydown', this.keyPressHandle); } componentDidMount() { this.node.focus(); } componentWillUnmount() { document.removeEventListener('mousedown', this.handleClick, false); document.removeEventListener('keydown', this.keyPressHandle); } handleClick(e) { if (this.node.contains(e.target)) { return; } this.handleClickOutside(e); } handleClickOutside() { this.close(); } keyPressHandle(e) { // escape key code = 27. // So here we are checking if the key pressed was Escape key. if (e.keyCode === 27) { this.close(); } } close() { // Only close if it is the last (and therefore the topmost overlay) const overlays = document.getElementsByClassName('overlay'); if (this.node.parentElement.parentElement !== overlays[overlays.length - 1]) return; if (!this.props.closeOverlay) { browserHistory.push(this.props.previousPath); } else { this.props.closeOverlay(); } } render() { const { ariaLabel, title, children } = this.props; return (