// Copyright (c) 2018 Dominic Masters
//
// MIT License
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

import React from 'react';
import { CSSTransition, TransitionGroup } from 'react-transition-group';
import { withRouter } from 'react-router';
import PropTypes from 'prop-types'
import { HashRouter, Route, Switch } from 'react-router-dom';

import Header from './../header/Header';
import Footer from './../footer/Footer';

//Pages
import Homepage from './home/Homepage';
import ContactPage from './contact/ContactPage';

import PrivacyPolicyPage from './legal/privacy/PrivacyPolicyPage';

const RouteWrapper = (props) => {
  let newProps = Object.assign({}, props);
  return (
    <Route {...props} render={() => {
        let CustomTag = props.page;
        return (
          <main className="c-main">
            <CustomTag />
            <Footer />
          </main>
        );
    }}/>
  );
};

class Routes extends React.Component {
  constructor(props) {
    super(props);
  }

  render() {
    const { match, location, history } = this.props;

    return (
      <Route>
        <TransitionGroup className="o-page-transition__container">
          <CSSTransition
            key={ location.pathname }
            timeout={1000}
            classNames="o-page-transition"
            mountOnEnter={ true }
            unmountOnExit={ true }
            onEntering={ this.props.onEntering }
          >
            <Switch location={ location }>
              <RouteWrapper exact path="/" page={ Homepage } />
              <RouteWrapper exact path="/contact" page={ ContactPage } />

              <RouteWrapper exact path="/legal/privacy" page={ PrivacyPolicyPage } />
            </Switch>
          </CSSTransition>
        </TransitionGroup>
      </Route>
    );
  }
}

export default withRouter(Routes);