Feature request
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.
To get to a specific page you have to go page by page
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).
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:
hii
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.
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.
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
Most helpful comment
Extending the current paginator isn't a problem, the thing is that a paginator should have a
jump to page
functionality.