docusaurus/packages/docusaurus-1.x/lib/core/BlogPageLayout.js

84 lines
2.5 KiB
JavaScript
Raw Normal View History

2017-07-07 13:28:29 -04:00
/**
* Copyright (c) Facebook, Inc. and its affiliates.
2017-07-07 13:28:29 -04:00
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
2017-07-07 13:28:29 -04:00
*/
const React = require('react');
const BlogPost = require('./BlogPost.js');
const BlogSidebar = require('./BlogSidebar.js');
const Container = require('./Container.js');
const MetadataBlog = require('./MetadataBlog.js');
const MetadataPublicBlog =
process.env.NODE_ENV === 'development'
? MetadataBlog
: MetadataBlog.filter((item) => !item.unlisted);
const Site = require('./Site.js');
const utils = require('./utils.js');
2017-07-07 13:28:29 -04:00
2017-08-15 19:55:38 -04:00
// used to generate entire blog pages, i.e. collection of truncated blog posts
class BlogPageLayout extends React.Component {
2017-07-07 13:28:29 -04:00
getPageURL(page) {
let url = `${this.props.config.baseUrl}blog/`;
2017-07-07 13:28:29 -04:00
if (page > 0) {
url += `page${page + 1}/`;
2017-07-07 13:28:29 -04:00
}
return url;
2017-10-26 19:29:14 -04:00
}
2017-07-07 13:28:29 -04:00
render() {
const perPage = this.props.metadata.perPage;
const page = this.props.metadata.page;
return (
<Site
title="Blog"
language="en"
config={this.props.config}
className="blog"
metadata={{blog: true, blogListing: true}}>
2017-07-07 13:28:29 -04:00
<div className="docMainWrapper wrapper">
2017-07-10 19:38:35 -04:00
<BlogSidebar
language={this.props.language}
config={this.props.config}
/>
<Container className="mainContainer postContainer blogContainer">
2017-07-07 13:28:29 -04:00
<div className="posts">
{MetadataPublicBlog.slice(
page * perPage,
(page + 1) * perPage,
).map((post) => (
<BlogPost
post={post}
content={post.content}
truncate
key={
utils.getPath(post.path, this.props.config.cleanUrl) +
post.title
}
config={this.props.config}
/>
))}
2017-07-07 13:28:29 -04:00
<div className="docs-prevnext">
{page > 0 && (
2017-07-07 13:28:29 -04:00
<a className="docs-prev" href={this.getPageURL(page - 1)}>
Prev
</a>
)}
{MetadataPublicBlog.length > (page + 1) * perPage && (
2017-07-07 13:28:29 -04:00
<a className="docs-next" href={this.getPageURL(page + 1)}>
Next
</a>
)}
2017-07-07 13:28:29 -04:00
</div>
</div>
</Container>
</div>
</Site>
);
2017-07-10 19:38:35 -04:00
}
}
2017-07-07 13:28:29 -04:00
module.exports = BlogPageLayout;