Built error section, needs to be on a few pages.
This commit is contained in:
@ -36,9 +36,16 @@ export const getUrl = request => {
|
|||||||
return `/api${slash}${r}`;
|
return `/api${slash}${r}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
export const get = async (url, params) => {
|
export const get = async (url, params, test) => {
|
||||||
url = url || "";
|
url = url || "";
|
||||||
|
|
||||||
|
if(process.env.NODE_ENV === 'development') {
|
||||||
|
console.log('testing mode');
|
||||||
|
return await new Promise((resolve,reject) => {
|
||||||
|
setTimeout(e => resolve(test), 1000);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
//Generate URL from query string
|
//Generate URL from query string
|
||||||
let paramString = queryString.stringify(params);
|
let paramString = queryString.stringify(params);
|
||||||
url = getUrl(url);
|
url = getUrl(url);
|
||||||
|
@ -24,6 +24,20 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { get } from '@public/api/api';
|
import { get } from '@public/api/api';
|
||||||
|
|
||||||
|
const TestBlogArticle = id => {
|
||||||
|
return {
|
||||||
|
id, handle: 'test-blog-article', title: 'My Title',
|
||||||
|
image: 'photo.jpg',
|
||||||
|
shortDescription: "Some short description that goes here too so let's write.",
|
||||||
|
description: "This is my longer example description lorem ipsum dolor sit amet."
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const TestBlogs = {
|
||||||
|
pages: 20/7,
|
||||||
|
articles: [...Array(20).keys()].map(TestBlogArticle)
|
||||||
|
}
|
||||||
|
|
||||||
export const withBlogTemplate = WrappedComponent => {
|
export const withBlogTemplate = WrappedComponent => {
|
||||||
return class extends React.Component {
|
return class extends React.Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
@ -43,7 +57,7 @@ export const withBlogTemplate = WrappedComponent => {
|
|||||||
perPage = perPage || 7;
|
perPage = perPage || 7;
|
||||||
|
|
||||||
this.setState({ pending: true, page, perPage });
|
this.setState({ pending: true, page, perPage });
|
||||||
get('blog', { page, perPage }).then(blog => {
|
get('blog', { page, perPage }, TestBlogs).then(blog => {
|
||||||
let { articles, pages } = blog;
|
let { articles, pages } = blog;
|
||||||
|
|
||||||
articles.forEach(article => {
|
articles.forEach(article => {
|
||||||
@ -53,6 +67,7 @@ export const withBlogTemplate = WrappedComponent => {
|
|||||||
|
|
||||||
this.setState({ pending: undefined, error: undefined, articles, pages });
|
this.setState({ pending: undefined, error: undefined, articles, pages });
|
||||||
}).catch(e => {
|
}).catch(e => {
|
||||||
|
console.error(e);
|
||||||
this.setState({ pending: undefined, error: e });
|
this.setState({ pending: undefined, error: e });
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
45
public/components/error/ErrorPanel.jsx
Normal file
45
public/components/error/ErrorPanel.jsx
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
// Copyright (c) 2018 Dominic Masters
|
||||||
|
//
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
// a copy of this software and associated documentation files (the
|
||||||
|
// "Software"), to deal in the Software without restriction, including
|
||||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
// the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be
|
||||||
|
// included in all copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
import React from 'react';
|
||||||
|
import { withLanguage } from '@public/language/Language';
|
||||||
|
|
||||||
|
import Styles from './ErrorPanel.scss';
|
||||||
|
|
||||||
|
export default withLanguage(props => {
|
||||||
|
let { className, error, title, body, lang } = props;
|
||||||
|
|
||||||
|
title = title || error.title || lang.error.title;
|
||||||
|
body = body || error.body || error || lang.error.body;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className={`c-error-panel ${className||""}`}>
|
||||||
|
<div className="c-error-panel__heading">
|
||||||
|
<h2 className="c-error-panel__heading-title">{ title }</h2>
|
||||||
|
</div>
|
||||||
|
<p className="c-error-panel__body">
|
||||||
|
{ body }
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
});
|
25
public/components/error/ErrorPanel.scss
Normal file
25
public/components/error/ErrorPanel.scss
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
@import '~@styles/global';
|
||||||
|
|
||||||
|
$c-error-panel--padding: 1em;
|
||||||
|
|
||||||
|
.c-error-panel {
|
||||||
|
max-width: 750px;
|
||||||
|
border: $s-color--input-default__border;
|
||||||
|
|
||||||
|
&__heading {
|
||||||
|
padding: $c-error-panel--padding;
|
||||||
|
background: $s-color--input-danger__top;
|
||||||
|
border-bottom: $s-color--input-default__border;
|
||||||
|
|
||||||
|
&-title {
|
||||||
|
color: $s-color--input-primary__text;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&__body {
|
||||||
|
margin: 0;
|
||||||
|
background: $s-color--background;
|
||||||
|
padding: $c-error-panel--padding;
|
||||||
|
}
|
||||||
|
}
|
42
public/components/section/error/ErrorSection.jsx
Normal file
42
public/components/section/error/ErrorSection.jsx
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
// Copyright (c) 2018 Dominic Masters
|
||||||
|
//
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
// a copy of this software and associated documentation files (the
|
||||||
|
// "Software"), to deal in the Software without restriction, including
|
||||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
// the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be
|
||||||
|
// included in all copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
import React from 'react';
|
||||||
|
|
||||||
|
import Section from './../Section';
|
||||||
|
import PageBoundary from '@components/page/boundary/PageBoundary';
|
||||||
|
import ErrorPanel from '@components/error/ErrorPanel';
|
||||||
|
|
||||||
|
import Styles from './ErrorSection.scss';
|
||||||
|
|
||||||
|
export default props => {
|
||||||
|
let { className } = props;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Section className={`c-error-section ${className||""}`}>
|
||||||
|
<PageBoundary>
|
||||||
|
<ErrorPanel {...props} className="c-error-section__panel" />
|
||||||
|
</PageBoundary>
|
||||||
|
</Section>
|
||||||
|
);
|
||||||
|
};
|
7
public/components/section/error/ErrorSection.scss
Normal file
7
public/components/section/error/ErrorSection.scss
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
@import '~@styles/global';
|
||||||
|
|
||||||
|
.c-error-section {
|
||||||
|
&__panel {
|
||||||
|
margin: 2em auto;
|
||||||
|
}
|
||||||
|
}
|
@ -25,11 +25,20 @@ export default {
|
|||||||
},
|
},
|
||||||
|
|
||||||
"blog": {
|
"blog": {
|
||||||
|
"error": {
|
||||||
|
"title": "Failed to get the blog",
|
||||||
|
"body": "Failed to get the blogs and articles from the server, please try again later or refresh your browser."
|
||||||
|
},
|
||||||
"article": {
|
"article": {
|
||||||
"readMore": "Read More"
|
"readMore": "Read More"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
"error": {
|
||||||
|
"title": "An error occured.",
|
||||||
|
"body": "An error occured, please try again later."
|
||||||
|
},
|
||||||
|
|
||||||
"pages": {
|
"pages": {
|
||||||
"home": {
|
"home": {
|
||||||
"banner": {
|
"banner": {
|
||||||
|
@ -27,6 +27,7 @@ import { withLanguage } from '@public/language/Language';
|
|||||||
import { withBlogTemplate} from '@public/blog/Blog';
|
import { withBlogTemplate} from '@public/blog/Blog';
|
||||||
import Page, { PageBoundary } from '@components/page/Page';
|
import Page, { PageBoundary } from '@components/page/Page';
|
||||||
|
|
||||||
|
import ErrorSection from '@sections/error/ErrorSection';
|
||||||
import FeaturedArticleSection from '@sections/blog/article/FeaturedArticleSection';
|
import FeaturedArticleSection from '@sections/blog/article/FeaturedArticleSection';
|
||||||
import ArticleGridSection from '@sections/blog/article/ArticleGridSection';
|
import ArticleGridSection from '@sections/blog/article/ArticleGridSection';
|
||||||
import ClearSection from '@sections/layout/ClearSection';
|
import ClearSection from '@sections/layout/ClearSection';
|
||||||
@ -39,11 +40,8 @@ import Styles from './BlogPage.scss';
|
|||||||
export default withBlogTemplate(withLanguage(props => {
|
export default withBlogTemplate(withLanguage(props => {
|
||||||
let { lang, articles, page, pages, pending, error } = props;
|
let { lang, articles, page, pages, pending, error } = props;
|
||||||
|
|
||||||
console.log(props);
|
|
||||||
|
|
||||||
let children;
|
let children;
|
||||||
|
if(error) error = <ErrorSection title={lang.blog.error.title} body={lang.blog.error.body} error={error} />;
|
||||||
if(error) error = "An error occured";
|
|
||||||
if(pending) pending = <Loader />;
|
if(pending) pending = <Loader />;
|
||||||
|
|
||||||
if(articles && articles.length) {
|
if(articles && articles.length) {
|
||||||
@ -56,9 +54,6 @@ export default withBlogTemplate(withLanguage(props => {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
*/
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Page
|
<Page
|
||||||
style="blog-page" className="p-blog-page" title={ lang.pages.blog.title }
|
style="blog-page" className="p-blog-page" title={ lang.pages.blog.title }
|
||||||
|
24
public/pages/blog/article/ArticlePage.jsx
Normal file
24
public/pages/blog/article/ArticlePage.jsx
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
// Copyright (c) 2018 Dominic Masters
|
||||||
|
//
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
// a copy of this software and associated documentation files (the
|
||||||
|
// "Software"), to deal in the Software without restriction, including
|
||||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
// the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be
|
||||||
|
// included in all copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
import React from 'react';
|
0
public/pages/blog/article/ArticlePage.scss
Normal file
0
public/pages/blog/article/ArticlePage.scss
Normal file
@ -25,17 +25,16 @@ import React from 'react';
|
|||||||
import { withLanguage} from '@public/language/Language';
|
import { withLanguage} from '@public/language/Language';
|
||||||
|
|
||||||
import Page, { PageBoundary } from '@components/page/Page';
|
import Page, { PageBoundary } from '@components/page/Page';
|
||||||
import { ClearSection} from '@components/section/Section';
|
import { ClearSection } from '@components/section/Section';
|
||||||
|
import ErrorSection from '@sections/error/ErrorSection';
|
||||||
import { Title } from '@objects/typography/Typography';
|
import { Title } from '@objects/typography/Typography';
|
||||||
|
|
||||||
export default withLanguage(props => {
|
export default withLanguage(props => {
|
||||||
let { className, lang } = props;
|
let { className, error, lang } = props;
|
||||||
return (
|
return (
|
||||||
<Page className={`c-error-page ${className||""}`} title={lang.pages.error.title}>
|
<Page className={`c-error-page ${className||""}`} title={ lang.pages.error.title }>
|
||||||
<ClearSection />
|
<ClearSection />
|
||||||
<PageBoundary>
|
<ErrorSection error={ error || lang.pages.error.body } />
|
||||||
<Title className="u-text-center">{ lang.pages.error.body }</Title>
|
|
||||||
</PageBoundary>
|
|
||||||
<ClearSection />
|
<ClearSection />
|
||||||
</Page>
|
</Page>
|
||||||
);
|
);
|
||||||
|
Reference in New Issue
Block a user