diff --git a/embark-ui/src/components/Blocks.js b/embark-ui/src/components/Blocks.js
index ba27fbd0f..405fa0fcb 100644
--- a/embark-ui/src/components/Blocks.js
+++ b/embark-ui/src/components/Blocks.js
@@ -2,11 +2,11 @@ import React from 'react';
import {Link} from "react-router-dom";
import {Row, Col, Card, CardHeader, CardBody} from 'reactstrap';
import PropTypes from 'prop-types';
+import Pages from './Pagination';
import CardTitleIdenticon from './CardTitleIdenticon';
-import LoadMore from "./LoadMore";
-const Blocks = ({blocks, showLoadMore, loadMore}) => (
+const Blocks = ({blocks, changePage, currentPage}) => (
@@ -37,7 +37,7 @@ const Blocks = ({blocks, showLoadMore, loadMore}) => (
))}
- {showLoadMore && loadMore()}/>}
+
@@ -46,8 +46,8 @@ const Blocks = ({blocks, showLoadMore, loadMore}) => (
Blocks.propTypes = {
blocks: PropTypes.arrayOf(PropTypes.object),
- showLoadMore: PropTypes.bool,
- loadMore: PropTypes.func
+ changePage: PropTypes.func,
+ currentPage: PropTypes.number
};
export default Blocks;
diff --git a/embark-ui/src/components/Layout.js b/embark-ui/src/components/Layout.js
index 37d5e6b7e..f7ba5b299 100644
--- a/embark-ui/src/components/Layout.js
+++ b/embark-ui/src/components/Layout.js
@@ -129,7 +129,7 @@ class Layout extends React.Component {
-
+
{HEADER_NAV_ITEMS.map((item) => (
diff --git a/embark-ui/src/components/Pagination.js b/embark-ui/src/components/Pagination.js
new file mode 100644
index 000000000..bc3ed83ff
--- /dev/null
+++ b/embark-ui/src/components/Pagination.js
@@ -0,0 +1,37 @@
+import React from 'react';
+import {Pagination, PaginationItem, PaginationLink} from 'reactstrap';
+import PropTypes from 'prop-types';
+
+const Pages = ({currentPage, numberOfPages, changePage}) => {
+ const paginationItems = [];
+ for (let i = 1; i <= numberOfPages; i++) {
+ paginationItems.push(
+ {
+ e.preventDefault();
+ changePage(i);
+ }}>
+ {i}
+
+ );
+ }
+
+ return (
+
+
+
+
+ {paginationItems}
+
+
+
+
+ );
+};
+
+Pages.propTypes = {
+ numberOfPages: PropTypes.number,
+ currentPage: PropTypes.number,
+ changePage: PropTypes.func
+};
+
+export default Pages;
diff --git a/embark-ui/src/containers/BlocksContainer.js b/embark-ui/src/containers/BlocksContainer.js
index 1163214f5..c5038dab1 100644
--- a/embark-ui/src/containers/BlocksContainer.js
+++ b/embark-ui/src/containers/BlocksContainer.js
@@ -8,6 +8,12 @@ import DataWrapper from "../components/DataWrapper";
import {getBlocks} from "../reducers/selectors";
class BlocksContainer extends Component {
+ constructor(props) {
+ super(props);
+
+ this.state = {currentPage: 1};
+ }
+
componentDidMount() {
this.props.fetchBlocks();
this.props.initBlockHeader();
@@ -29,11 +35,16 @@ class BlocksContainer extends Component {
return blocks[blocks.length - 1].number - 1;
}
+ changePage(newPage) {
+ this.setState({currentPage: newPage});
+ }
+
render() {
return (
0} {...this.props} render={({blocks}) => (
- = 0)} loadMore={() => this.loadMore()} />
+ = 0)}
+ changePage={(newPage) => this.changePage(newPage)} currentPage={this.state.currentPage} />
)} />
);