pleroma/app/soapbox/features/public_layout/index.js
2020-05-28 17:56:55 -05:00

39 lines
1.1 KiB
JavaScript

import React from 'react';
import { connect } from 'react-redux';
import ImmutablePureComponent from 'react-immutable-pure-component';
import { Switch, Route } from 'react-router-dom';
import NotificationsContainer from 'soapbox/features/ui/containers/notifications_container';
import Header from './components/header';
import Footer from './components/footer';
import LandingPage from '../landing_page';
import AboutPage from '../about';
const mapStateToProps = (state, props) => ({
instance: state.get('instance'),
soapbox: state.get('soapbox'),
});
class PublicLayout extends ImmutablePureComponent {
render() {
const { instance } = this.props;
if (instance.isEmpty()) return null;
return (
<div className='public-layout'>
<Header />
<div className='container'>
<Switch>
<Route exact path='/' component={LandingPage} />
<Route exact path='/about/:slug?' component={AboutPage} />
</Switch>
</div>
<Footer />
<NotificationsContainer />
</div>
);
}
}
export default connect(mapStateToProps)(PublicLayout);