pleroma/app/gabsocial/features/public_layout/index.js

40 lines
1.1 KiB
JavaScript
Raw Normal View History

2020-04-25 15:26:47 -07:00
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 'gabsocial/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);