From 24d862a65c603de4ea77a2688f5c90effc65be2f Mon Sep 17 00:00:00 2001 From: Michael Muré Date: Wed, 15 Aug 2018 15:30:06 +0200 Subject: webUI: implement pagination on the bug list --- webui/src/ListPage.js | 148 +++++++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 133 insertions(+), 15 deletions(-) (limited to 'webui/src/ListPage.js') diff --git a/webui/src/ListPage.js b/webui/src/ListPage.js index 76350ec5..31f010c0 100644 --- a/webui/src/ListPage.js +++ b/webui/src/ListPage.js @@ -1,7 +1,9 @@ +// @flow import CircularProgress from '@material-ui/core/CircularProgress' import { withStyles } from '@material-ui/core/styles' import Table from '@material-ui/core/Table/Table' import TableBody from '@material-ui/core/TableBody/TableBody' +import TablePagination from '@material-ui/core/TablePagination/TablePagination' import gql from 'graphql-tag' import React from 'react' import { Query } from 'react-apollo' @@ -9,19 +11,27 @@ import { Query } from 'react-apollo' import BugSummary from './BugSummary' const QUERY = gql` - { + query($first: Int = 10, $last: Int, $after: String, $before: String) { defaultRepository { - bugs: allBugs(first: 10) { + bugs: allBugs(first: $first, last: $last, after: $after, before: $before) { + totalCount edges { cursor node { ...BugSummary } } + pageInfo{ + hasNextPage + hasPreviousPage + startCursor + endCursor + } } } } + ${BugSummary.fragment} ` @@ -33,24 +43,132 @@ const styles = theme => ({ } }) -const List = withStyles(styles)(({bugs, classes}) => ( -
- - - {bugs.edges.map(({ cursor, node }) => ( - - ))} - -
-
-)) +const List = withStyles(styles)(class List extends React.Component { + + props: { + bugs: Array, + fetchMore: (any) => any, + classes: any, + } + + state = { + page: 0, + rowsPerPage: 10, + lastQuery: {} + } + + handleChangePage = (event, page) => { + const {bugs, fetchMore} = this.props + const {rowsPerPage} = this.state + const pageInfo = bugs.pageInfo + + if (page === this.state.page + 1) { + if (!pageInfo.hasNextPage) { + return + } + + const variables = { + after: pageInfo.endCursor, + first: rowsPerPage + } + + fetchMore({ + variables, + updateQuery: this.updateQuery, + }) + + this.setState({page, lastQuery: variables}) + return + } + + if (page === this.state.page - 1) { + if (!pageInfo.hasPreviousPage) { + return + } + + const variables = { + before: pageInfo.startCursor, + last: rowsPerPage + } + + fetchMore({ + variables, + updateQuery: this.updateQuery, + }) + + this.setState({page, lastQuery: variables}) + return + } + + throw 'non neighbour page pagination is not supported' + } + + handleChangeRowsPerPage = event => { + const {fetchMore} = this.props + const {lastQuery} = this.state + const rowsPerPage = event.target.value + + const variables = lastQuery + + if (lastQuery.first) { + variables.first = rowsPerPage + } else if (lastQuery.last) { + variables.last = rowsPerPage + } else { + variables.first = rowsPerPage + } + + fetchMore({ + variables, + updateQuery: this.updateQuery, + }) + + this.setState({rowsPerPage, lastQuery: variables}) + } + + updateQuery = (previousResult, {fetchMoreResult}) => { + console.log(fetchMoreResult) + return fetchMoreResult ? fetchMoreResult : previousResult + } + + render() { + const {classes, bugs} = this.props + const {page, rowsPerPage} = this.state + + return ( +
+ + + {bugs.edges.map(({cursor, node}) => ( + + ))} + +
+ +
+ ) + } +}) const ListPage = () => ( - {({loading, error, data}) => { + {({loading, error, data, fetchMore}) => { if (loading) return if (error) return

Error.

- return + return }}
) -- cgit