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

65 lines
2.1 KiB
JavaScript
Raw Normal View History

2020-04-25 15:26:47 -07:00
import React from 'react';
import ImmutablePureComponent from 'react-immutable-pure-component';
import { connect } from 'react-redux';
import { Switch, Route, Redirect } from 'react-router-dom';
import { getSoapboxConfig } from 'soapbox/actions/soapbox';
2022-01-10 14:01:24 -08:00
import BundleContainer from 'soapbox/features/ui/containers/bundle_container';
2021-09-18 18:01:04 -07:00
import {
NotificationsContainer,
ModalContainer,
} from 'soapbox/features/ui/util/async-components';
import { isStandalone } from 'soapbox/utils/state';
2022-01-10 14:01:24 -08:00
import AboutPage from '../about';
import LandingPage from '../landing_page';
2022-01-10 14:01:24 -08:00
import Footer from './components/footer';
import Header from './components/header';
2020-04-25 15:26:47 -07:00
const mapStateToProps = (state, props) => ({
soapbox: getSoapboxConfig(state),
standalone: isStandalone(state),
2020-04-25 15:26:47 -07:00
});
2020-06-01 21:24:36 -07:00
const wave = (
2020-06-04 19:13:38 -07:00
<svg className='wave' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 889' width='1440px' height='889px' preserveAspectRatio='none'>
2020-06-01 21:24:36 -07:00
<path d='M 0 0 L 0 851.82031 C 115.03104 776.54213 236.097 723.10606 363.20703 691.54492 C 640.06491 622.80164 852.93698 468.14039 954.31055 358.01367 C 1092.1151 208.31032 1206.0509 47.69868 1365.3828 13.457031 C 1391.8162 7.7762737 1416.6827 3.2957237 1440 0.001953125 L 1440 0 L 0 0 z' fill='var(--background-color)' />
</svg>
);
2020-04-25 15:26:47 -07:00
class PublicLayout extends ImmutablePureComponent {
render() {
const { standalone } = this.props;
if (standalone) {
return <Redirect to='/auth/external' />;
}
2020-04-25 15:26:47 -07:00
return (
<div className='public-layout'>
2020-06-01 21:24:36 -07:00
<div className='public-layout__top'>
{wave}
<Header />
<div className='container'>
<Switch>
<Route exact path='/' component={LandingPage} />
<Route exact path='/about/:slug?' component={AboutPage} />
</Switch>
</div>
2020-04-25 15:26:47 -07:00
</div>
<Footer />
2021-09-18 18:01:04 -07:00
<BundleContainer fetchComponent={NotificationsContainer}>
{Component => <Component />}
</BundleContainer>
<BundleContainer fetchComponent={ModalContainer}>
{Component => <Component />}
</BundleContainer>
2020-04-25 15:26:47 -07:00
</div>
);
}
}
export default connect(mapStateToProps)(PublicLayout);