Components: [Paginator] Add jump-to-page functionality

Created on 7 Oct 2017  路  24Comments  路  Source: angular/components

Bug, feature request, or proposal:

Feature request

What is the expected behavior?

To be able to jump to a specific page using a dropdown populated with page numbers. The dropdown should be next in line after the Items per page dropdown, so you can choose the page size and then the page number you want to go to.

Don't know if the following part is smart, but in use cases where the page number is large, a step input can be implemented. If the total number of pages is 500, and the step is 5, the Page number dropdown would hold only pages 1, 5, 10, 15, 20 .... so the user can get to the desired page in as little scrolling and as few clicks as possible.

What is the current behavior?

To get to a specific page you have to go page by page

What is the use-case or motivation for changing an existing behavior?

In my case, I have a 100 item per page list, that has 3500 total items sorted by date and the users land at the last page. If the users wants to check the items that were added at the beginning of the year, they know that they should be looking at items from 1 to at least 300, so that is 32 clicks to get to the desired items. As the total page count gets bigger, the harder it is to get to the last pages (first pages in my case).

P4 materiapaginator feature

Most helpful comment

Extending the current paginator isn't a problem, the thing is that a paginator should have a jump to page functionality.

All 24 comments

Maybe something like this will help in the mean time

https://stackblitz.com/edit/material2-beta12-fpf2ka?file=app%2Fapp.component.ts

I have a working component that wraps around the paginator, adds the dropdown and all the events are bound to the same function so you don't need to have separate event handlers.

A paginator component should let you get to a specific page easily. I'd make a PR if the idea is considered acceptable.

@andrewseguin will this get in on the next beta?

@dushkostanoeski We haven't started work on something like this, especially since its out of the spec and we'd have to really consider how the UX would play out here

button for firstPage and lastPage is also needed, should I create a new ticket? Couldn't find a ticket until now for such functionality.

I think it's possible using the existing API. You can try like this...

 this.paginator.pageIndex = pageNumber, // number of the page you want to jump.
 this.paginator.page.next({      
      pageIndex: pageNumber,
      pageSize: this.paginator.pageSize,
      length: this.paginator.length
    });

where this.paginator is

@Input()
paginator: MatPaginator;

For jumping to a specific page you can add an input box or select box and execute that piece of code and for jumping to previous or last page two button could be added which could use that too.

Extending the current paginator isn't a problem, the thing is that a paginator should have a jump to page functionality.

@dushkostanoeski yes you're right. It would've been a useful functionality.

@andrewseguin I can make a PR about this, if that's OK

You're welcome to open a PR but it may be worth discussing what the UX would look like. Do you have suggestions on how the UI would appear?

The field would be optional and I was thinking of adding it after the Items per page field. The label would say Jump to page: followed by a dropdown populated with the page numbers. That way the user can choose the page size and then jump to the desired page.

What would the select options text be? Page numbers or item ranges? Configurable via MatPaginatorIntl?

The Jump to page label makes you think of page numbers, but being able to choose between item ranges and page numbers, or even both, something like Jump to page: 2 (11 - 20) is even better.

Should the label change depending on what the dropdown is populated with?

Can it look the same like in https://github.com/daniel-nagy/md-data-table

That's pretty much the idea

How about converting the .mat-paginator-range-label to a mat-select so a user can choose the range directly.

Would look like this:
image

hii

https://stackoverflow.com/questions/51542796/table-angular-material-pagination-does-not-work-as-expected

was this solved at all? can some check this thread related to this too ?

+1 this would be super useful

+1

How about a UI like something like what @shlomiassaf has in his table demos? It feels very natural to put the current page index between the next and prev buttons.

image

How about a UI like something like what @shlomiassaf has in his table demos? It feels very natural to put the current page index between the next and prev buttons.

image

Could please provide a link to this demo? Thank you!

Any chances this gets implemented this year? Doesn't look like the suggestions took traction.

I have created a mat-paginator-goto component over mat-paginator, this works same as original mat-paginator but also has option of goTo/jumpTo specific page.

The list of available pages for goTo have been calculated based on length and pageSize.

To Integrate in your angular/material project follow below steps

Step 1: Goto mat-paginator-with-goto (Stackblitz)

Step 2: Copy folder(mat-paginator-goto) and paste into you project

Step 3: Import in your module

import { MatPaginatorGotoComponent } from './mat-paginator-goto/mat-paginator-goto.component';

@NgModule({
  declarations: [ ...MatPaginatorGotoComponent ],
})

Step 4: Use it same as original mat-paginator

<mat-paginator-goto [length]="100" [pageSize]="10" [pageSizeOptions]="[5, 10, 25, 100]"
        (page)="paginationChange($event)"></mat-paginator-goto>

Note: Update import paths and styles accordingly

Was this page helpful?
0 / 5 - 0 ratings

Related issues

vitaly-t picture vitaly-t  路  3Comments

theunreal picture theunreal  路  3Comments

RoxKilly picture RoxKilly  路  3Comments

crutchcorn picture crutchcorn  路  3Comments

LoganDupont picture LoganDupont  路  3Comments