Adding Load more
This commit is contained in:
parent
9a6712082f
commit
044cb874f6
|
@ -49,9 +49,10 @@ export function receiveProcessesError() {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export function fetchBlocks() {
|
export function fetchBlocks(from) {
|
||||||
return {
|
return {
|
||||||
type: FETCH_BLOCKS
|
type: FETCH_BLOCKS,
|
||||||
|
from
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,8 +6,8 @@ export function fetchAccounts() {
|
||||||
return axios.get(`${BASE_URL}/blockchain/accounts`);
|
return axios.get(`${BASE_URL}/blockchain/accounts`);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function fetchBlocks() {
|
export function fetchBlocks(from) {
|
||||||
return axios.get(`${BASE_URL}/blockchain/blocks`);
|
return axios.get(`${BASE_URL}/blockchain/blocks`, {params: {from}});
|
||||||
}
|
}
|
||||||
|
|
||||||
export function fetchProcesses() {
|
export function fetchProcesses() {
|
||||||
|
|
|
@ -0,0 +1,17 @@
|
||||||
|
import React from 'react';
|
||||||
|
import {Grid, Button} from 'tabler-react';
|
||||||
|
import PropTypes from 'prop-types';
|
||||||
|
|
||||||
|
const LoadMore = ({loadMore}) => (
|
||||||
|
<Grid.Row className="my-3">
|
||||||
|
<Grid.Col className="text-center">
|
||||||
|
<Button onClick={loadMore} icon="plus" outline color="primary">Load More</Button>
|
||||||
|
</Grid.Col>
|
||||||
|
</Grid.Row>
|
||||||
|
);
|
||||||
|
|
||||||
|
LoadMore.propTypes = {
|
||||||
|
loadMore: PropTypes.func
|
||||||
|
};
|
||||||
|
|
||||||
|
export default LoadMore;
|
|
@ -5,12 +5,28 @@ import PropTypes from 'prop-types';
|
||||||
import {fetchBlocks} from '../actions';
|
import {fetchBlocks} from '../actions';
|
||||||
import Blocks from '../components/Blocks';
|
import Blocks from '../components/Blocks';
|
||||||
import Loading from '../components/Loading';
|
import Loading from '../components/Loading';
|
||||||
|
import LoadMore from '../components/LoadMore';
|
||||||
|
|
||||||
class BlocksContainer extends Component {
|
class BlocksContainer extends Component {
|
||||||
|
|
||||||
|
constructor(props) {
|
||||||
|
super(props);
|
||||||
|
this.loadMore = this.loadMore.bind(this);
|
||||||
|
}
|
||||||
|
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
this.props.fetchBlocks();
|
this.props.fetchBlocks();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
loadMore() {
|
||||||
|
this.props.fetchBlocks(this.loadMoreFrom());
|
||||||
|
}
|
||||||
|
|
||||||
|
loadMoreFrom() {
|
||||||
|
let blocks = this.props.blocks.data;
|
||||||
|
return blocks[blocks.length - 1].number - 1;
|
||||||
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const {blocks} = this.props;
|
const {blocks} = this.props;
|
||||||
if (!blocks.data) {
|
if (!blocks.data) {
|
||||||
|
@ -26,7 +42,10 @@ class BlocksContainer extends Component {
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Blocks blocks={blocks.data} />
|
<React.Fragment>
|
||||||
|
<Blocks blocks={blocks.data}/>
|
||||||
|
{(this.loadMoreFrom() >= 0) ? <LoadMore loadMore={this.loadMore} /> : <React.Fragment />}
|
||||||
|
</React.Fragment>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
import {RECEIVE_BLOCKS, RECEIVE_BLOCKS_ERROR} from "../actions";
|
import {RECEIVE_BLOCKS, RECEIVE_BLOCKS_ERROR} from "../actions";
|
||||||
|
|
||||||
export default function accounts(state = {}, action) {
|
export default function blocks(state = {}, action) {
|
||||||
switch (action.type) {
|
switch (action.type) {
|
||||||
case RECEIVE_BLOCKS:
|
case RECEIVE_BLOCKS:
|
||||||
return Object.assign({}, state, {data: action.blocks.data});
|
return Object.assign({}, state, {data: [...state.data || [], ...action.blocks.data]});
|
||||||
case RECEIVE_BLOCKS_ERROR:
|
case RECEIVE_BLOCKS_ERROR:
|
||||||
return Object.assign({}, state, {error: true});
|
return Object.assign({}, state, {error: true});
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -2,9 +2,9 @@ import * as actions from '../actions';
|
||||||
import * as api from '../api';
|
import * as api from '../api';
|
||||||
import {all, call, fork, put, takeEvery} from 'redux-saga/effects';
|
import {all, call, fork, put, takeEvery} from 'redux-saga/effects';
|
||||||
|
|
||||||
export function *fetchBlocks() {
|
export function *fetchBlocks(payload) {
|
||||||
try {
|
try {
|
||||||
const blocks = yield call(api.fetchBlocks);
|
const blocks = yield call(api.fetchBlocks, payload.from);
|
||||||
yield put(actions.receiveBlocks(blocks));
|
yield put(actions.receiveBlocks(blocks));
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
yield put(actions.receiveBlocksError());
|
yield put(actions.receiveBlocksError());
|
||||||
|
|
|
@ -216,12 +216,12 @@ class BlockchainConnector {
|
||||||
'get',
|
'get',
|
||||||
'/embark-api/blockchain/blocks',
|
'/embark-api/blockchain/blocks',
|
||||||
(req, res) => {
|
(req, res) => {
|
||||||
let from = req.query.from;
|
let from = parseInt(req.query.from, 10);
|
||||||
let limit = req.query.limit || 10;
|
let limit = req.query.limit || 10;
|
||||||
let results = [];
|
let results = [];
|
||||||
async.waterfall([
|
async.waterfall([
|
||||||
function(callback) {
|
function(callback) {
|
||||||
if (from) {
|
if (!isNaN(from)) {
|
||||||
return callback();
|
return callback();
|
||||||
}
|
}
|
||||||
self.getBlockNumber((err, blockNumber) => {
|
self.getBlockNumber((err, blockNumber) => {
|
||||||
|
|
Loading…
Reference in New Issue