// Copyright 2018 Red Hat, Inc // // Licensed under the Apache License, Version 2.0 (the "License"); you may // not use this file except in compliance with the License. You may obtain // a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the // License for the specific language governing permissions and limitations // under the License. // The App is the parent component of every pages. Each page content is // rendered by the Route object according to the current location. import React from 'react' import PropTypes from 'prop-types' import { matchPath, withRouter } from 'react-router' import { Link, Redirect, Route, Switch } from 'react-router-dom' import { connect } from 'react-redux' import { Masthead } from 'patternfly-react' import logo from './images/logo.png' import { routes } from './routes' import { setTenantAction } from './reducers' class App extends React.Component { static propTypes = { info: PropTypes.object, tenant: PropTypes.object, location: PropTypes.object, dispatch: PropTypes.func } state = { menuCollapsed: true } onNavToggleClick = () => { this.setState({ menuCollapsed: !this.state.menuCollapsed }) } onNavClick = () => { this.setState({ menuCollapsed: true }) } constructor() { super() this.menu = routes() } renderMenu() { const { location } = this.props const activeItem = this.menu.find( item => location.pathname === item.to ) return (