#pagination #page #chunk #web #database

paginate

A framework agnostic pagination crate, that is especially suited for databases, slices and collections. Paginate calculates the range of pages indexes, making it ideal for accessing slices, chunking data and querying databases.

13 stable releases

1.1.11 Apr 11, 2022
1.1.8 Jan 21, 2022
1.0.1 Mar 16, 2020

#363 in Web programming

Download history 408/week @ 2024-07-27 418/week @ 2024-08-03 285/week @ 2024-08-10 250/week @ 2024-08-17 249/week @ 2024-08-24 167/week @ 2024-08-31 157/week @ 2024-09-07 195/week @ 2024-09-14 284/week @ 2024-09-21 408/week @ 2024-09-28 253/week @ 2024-10-05 278/week @ 2024-10-12 286/week @ 2024-10-19 341/week @ 2024-10-26 385/week @ 2024-11-02 379/week @ 2024-11-09

1,436 downloads per month
Used in wanisabi

Apache-2.0

17KB
391 lines

A framework agnostic pagination crate, that is especially suited for databases, slices and collections. Paginate calculates the range of page indexes, making it ideal for accessing slices, chunking data and querying databases.

Project Status

crates.io CI Docs codecov book stars - paginate forks - paginate

Installation

Add the following line to your Cargo.toml file:

paginate = "^1"

Examples

To iterate over each page:

use paginate::Pages;

fn main() {
    let total_items = 100;
    let items_per_page = 5;
    let pages = Pages::new(total_items, items_per_page);
    println!("total pages: {}", pages.page_count());
    for page in pages.into_iter() {
        println!("offset: {}, total: {}, start: {}, end: {}", page.offset, page.length, page.start, page.end);
    }
}

To get the pagination of a specific offset:

use paginate::Pages;

fn main() {
    let total_items = 35;
    let items_per_page = 5;
    let pages = Pages::new(total_items, items_per_page);
    let page = pages.with_offset(3);
    println!("total pages: {}", pages.page_count());
    println!("offset: {}, total: {}, start: {}, end: {}", page.offset, page.length, page.start, page.end);
}

Getting help

Contribute

No runtime deps