About Page support

This commit is contained in:
Alex Gleason 2020-04-25 16:10:01 -05:00
parent 6c698acef0
commit 6813f512e6
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
7 changed files with 61 additions and 1 deletions

2
.gitignore vendored
View file

@ -5,5 +5,5 @@
/coverage/
/.eslintcache
/.env
/public/soapbox/soapbox.json
/public/soapbox
/deploy.sh

View file

@ -0,0 +1,13 @@
import api from '../api';
export const FETCH_ABOUT_PAGE_REQUEST = 'FETCH_ABOUT_PAGE_REQUEST';
export const FETCH_ABOUT_PAGE_FAIL = 'FETCH_ABOUT_PAGE_FAIL';
export function fetchAboutPage(slug = 'index') {
return (dispatch, getState) => {
dispatch({ type: FETCH_ABOUT_PAGE_REQUEST, slug });
return api(getState).get(`/soapbox/about/${slug}.html`).catch(error => {
dispatch({ type: FETCH_ABOUT_PAGE_FAIL, slug });
});
};
}

View file

@ -21,6 +21,7 @@ import { fetchInstance } from 'gabsocial/actions/instance';
import { fetchSoapboxConfig } from 'gabsocial/actions/soapbox';
import { fetchMe } from 'gabsocial/actions/me';
import LandingPage from 'gabsocial/features/landing_page';
import AboutPage from 'gabsocial/features/about';
const { localeData, messages } = getLocale();
addLocaleData(localeData);
@ -92,6 +93,7 @@ class GabSocialMount extends React.PureComponent {
<ScrollContext>
<Switch>
{!me && <Route exact path='/' component={LandingPage} />}
<Route exact path='/about/:slug?' component={AboutPage} />
<Route path='/' component={UI} />
</Switch>
</ScrollContext>

View file

@ -0,0 +1,41 @@
import React from 'react';
import { connect } from 'react-redux';
import ImmutablePureComponent from 'react-immutable-pure-component';
import { fetchAboutPage } from 'gabsocial/actions/about';
class AboutPage extends ImmutablePureComponent {
state = {
pageHtml: '',
}
loadPageHtml = () => {
const { dispatch, match } = this.props;
const { slug } = match.params;
dispatch(fetchAboutPage(slug)).then(response => {
this.setState({ pageHtml: response.data });
}).catch(error => {
// TODO: Better error handling. 404 page?
this.setState({ pageHtml: '<h1>Page not found</h1>' });
});
}
componentWillMount() {
this.loadPageHtml();
}
componentDidUpdate(prevProps, prevState) {
const { slug } = this.props.match.params;
const { slug: prevSlug } = prevProps.match.params;
if (slug !== prevSlug) this.loadPageHtml();
}
render() {
return (
<div dangerouslySetInnerHTML={{ __html: this.state.pageHtml }} />
);
}
}
export default connect()(AboutPage);

View file

@ -192,6 +192,7 @@
.public-layout {
.container {
width: 100%;
max-width: 960px;
@media screen and (max-width: $no-gap-breakpoint) {

View file

@ -0,0 +1,3 @@
<h1>Hello world!</h1>
<p>You made it.</p>

View file