pleroma/app/gabsocial/features/about/index.js
2020-04-25 16:10:01 -05:00

41 lines
1 KiB
JavaScript

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);