Skip to content

Commit

Permalink
fix(PaginationInfinity): ensure the load button does not appear when …
Browse files Browse the repository at this point in the history
…current_page decreases
  • Loading branch information
tujoworker committed Nov 23, 2021
1 parent 1866a3c commit 4bcc963
Show file tree
Hide file tree
Showing 4 changed files with 65 additions and 51 deletions.
2 changes: 0 additions & 2 deletions packages/dnb-eufemia/src/components/pagination/Pagination.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@ import InfinityScroller from './PaginationInfinity'
import PaginationBar from './PaginationBar'

const paginationPropTypes = {
debug: PropTypes.bool,
startup_page: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
current_page: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
page_count: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
Expand Down Expand Up @@ -110,7 +109,6 @@ const paginationPropTypes = {
}

const paginationDefaultProps = {
debug: null,
startup_page: null,
current_page: null,
page_count: null,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -195,35 +195,17 @@ export default class InfinityScroller extends React.PureComponent {
parallelLoadCount,

// our props
debug,
current_page,
fallback_element,
marker_element,
indicator_element,
} = this.context.pagination

if (debug) {
console.info('PaginationInfinity.render', {
current_page,
lowerPage,
upperPage,
currentPage,
pageCount,
})
}

const Marker = () => (
<InteractionMarker
debug={debug}
pageNumber={upperPage}
markerElement={marker_element || fallback_element}
onVisible={(pageNumber) => {
if (debug) {
console.info('PaginationInfinity.onVisible', {
pageNumber,
})
}

let newPageNo
// load several pages at once
for (let i = 0; i < parallelLoadCount; ++i) {
Expand Down Expand Up @@ -425,7 +407,6 @@ export default class InfinityScroller extends React.PureComponent {

class InteractionMarker extends React.PureComponent {
static propTypes = {
debug: PropTypes.bool,
pageNumber: PropTypes.number.isRequired,
onVisible: PropTypes.func.isRequired,
markerElement: PropTypes.oneOfType([
Expand All @@ -436,7 +417,6 @@ class InteractionMarker extends React.PureComponent {
]),
}
static defaultProps = {
debug: null,
markerElement: null,
}
state = { isConnected: false }
Expand All @@ -453,18 +433,12 @@ class InteractionMarker extends React.PureComponent {
this._ref = React.createRef()

if (typeof IntersectionObserver !== 'undefined') {
this.intersectionObserver = new IntersectionObserver(
(entries) => {
const [{ isIntersecting }] = entries
if (isIntersecting) {
this.callReady()
}
this.intersectionObserver = new IntersectionObserver((entries) => {
const [{ isIntersecting }] = entries
if (isIntersecting) {
this.callReady()
}
// {
// threshold: 1,
// rootMargin: '0px 0px -80% 0px'
// }
)
})
} else {
warn('Pagination is missing IntersectionObserver supported!')
}
Expand All @@ -475,11 +449,6 @@ class InteractionMarker extends React.PureComponent {
this._isMounted = true
this.intersectionObserver?.observe(this._ref.current)
}

if (this.props.debug) {
const height = this.getContentHeight()
console.info('PaginationInfinity.getContentHeight', height)
}
}

componentWillUnmount() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -98,34 +98,28 @@ export default class PaginationProvider extends React.PureComponent {
)

// reset pagination, like the resetInfinity method
if (
props.useMarkerOnly &&
props.reset_pagination_handler !== null &&
isTrue(props.reset_pagination_handler)
) {
if (props.useMarkerOnly && isTrue(props.reset_pagination_handler)) {
state.lowerPage = undefined
state.upperPage = undefined
}

// only used by handleInfinityMarker
if (props.useMarkerOnly) {
if (
typeof state.lowerPage === 'undefined' &&
parseFloat(props.current_page) > 0
) {
if (typeof state.lowerPage === 'undefined') {
state.lowerPage = state.startupPage
}
const cur = parseFloat(props.current_page)
if (!isNaN(cur) && cur < state.lowerPage) {
state.lowerPage = cur
}
if (typeof state.upperPage === 'undefined') {
state.upperPage =
state.startupPage + parseFloat(props.startup_count) - 1
}
}

// reset content, like the resetContent method
if (
props.reset_content_handler !== null &&
isTrue(props.reset_content_handler)
) {
if (isTrue(props.reset_content_handler)) {
state.items = []
state.pageCount = parseFloat(props.page_count) || 1
}
Expand All @@ -135,6 +129,7 @@ export default class PaginationProvider extends React.PureComponent {
} else if (Array.isArray(props.items)) {
state.items = props.items
}

return state
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -435,6 +435,58 @@ describe('Infinity scroller', () => {
expect(Comp.find('div.page-item').last().text()).toBe('page-30')
})

it('should handle re-render with decreasing current_page and not show the loadbar', async () => {
const perPageCount = 10

const tableItems = []
for (let i = 1; i <= 60; i++) {
tableItems.push({
ssn: i,
content: <PageItem key={i}>page-{i}</PageItem>,
})
}

const localStack = { current: {} }

const MyComponent = () => {
const [{ InfinityMarker }] = React.useState(createPagination)

// 1. Start with 2
const [currentPage, setCurrentPage] = React.useState(2)

tableItems
.filter((cur, idx) => {
const floor = (currentPage - 1) * perPageCount
const ceil = floor + perPageCount
return idx >= floor && idx < ceil
})
.forEach((item) => {
localStack.current[item.ssn] = item.content
})
const items = Object.values(localStack.current)

// 2. And set it back to 1
React.useEffect(() => {
setCurrentPage(1)
}, [])

return (
<InfinityMarker min_wait_time={0} current_page={currentPage}>
{items}
</InfinityMarker>
)
}

const Comp = mount(<MyComponent />)

await rerenderComponent(Comp)

expect(Comp.find('div.page-item').length).toBe(20)
expect(Comp.find('div.page-item').at(0).text()).toBe('page-1')
expect(Comp.find('div.page-item').last().text()).toBe('page-20')
expect(Comp.find('div.dnb-pagination__loadbar').exists()).toBe(false)
})

it('should load pages with load more button (before)', async () => {
const action = ({ pageNumber, setContent }) => {
setContent(pageNumber, <PageItem>{pageNumber}</PageItem>)
Expand Down

0 comments on commit 4bcc963

Please sign in to comment.