npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@abhihyder/js-paginator

v1.0.0

Published

A versatile JavaScript pagination utility for simplifying pagination implementation in JavaScript applications. Supports customizable pagination links, first and last page navigation, and easy integration with various JavaScript frameworks.

Downloads

9

Readme

JS Paginator

js-paginator is a lightweight utility for simplifying pagination in JavaScript applications. Whether you're working with APIs or databases, js-paginator provides a straightforward way to generate pagination links and manage pagination logic.

Features

  • Easy Integration: Integrate pagination functionality seamlessly into your JavaScript applications with minimal setup.
  • Flexible Configuration: Customize pagination settings to fit your specific use case, including specifying the current page, limit per page, total number of items, and base URL.
  • Advanced Pagination: Supports both simple and complex pagination scenarios, including scenarios with large datasets and custom query parameters.
  • Concise and Readable: Generates clear and concise pagination links, making it easy for users to navigate through paginated content.
  • Lightweight: Designed to be lightweight and performant, ensuring minimal impact on application performance.

Installation

You can install js-paginator via npm. Navigate to your project directory and run:

npm i @abhihyder/js-paginator

Usage

Basic Usage

const paginator = require("@abhihyder/js-paginator");
// Or
import paginator from "@abhihyder/js-paginator";

// Get pagination data
const pagination = paginator({
  currentPage: 10,
  limit: 10,
  totalItem: 200,
  baseUrl: "https://example.com/api/items",
});

console.log(pagination);

Response

{
  "currentPage": 10,
  "totalPages": 20,
  "from": 91,
  "to": 100,
  "totalItem": 200,
  "links": {
    "first": "https://example.com/api/items?page=1&limit=10",
    "last": "https://example.com/api/items?page=20&limit=10",
    "prev": "https://example.com/api/items?page=9&limit=10",
    "next": "https://example.com/api/items?page=11&limit=10"
  },
  "pagination": [
    {
      "page": 1,
      "url": "https://example.com/api/items?page=1&limit=10"
    },
    {
      "page": 2,
      "url": "https://example.com/api/items?page=2&limit=10"
    },
    {
      "page": "...",
      "url": null
    },
    {
      "page": 9,
      "url": "https://example.com/api/items?page=9&limit=10"
    },
    {
      "page": 10,
      "url": "https://example.com/api/items?page=10&limit=10"
    },
    {
      "page": 11,
      "url": "https://example.com/api/items?page=11&limit=10"
    },
    {
      "page": "...",
      "url": null
    },
    {
      "page": 19,
      "url": "https://example.com/api/items?page=19&limit=10"
    },
    {
      "page": 20,
      "url": "https://example.com/api/items?page=20&limit=10"
    }
  ]
}

Advanced Usage

// Specify custom query parameters
const queryString = {
  name: "javascript",
  category: "books",
};

// Pass custom query parameters
const pagination = paginator(
  {
    currentPage: 10,
    limit: 10,
    totalItem: 200,
    baseUrl: "https://example.com/api/items",
  },
  queryString
);

console.log(pagination);

Response

{
  "currentPage": 10,
  "totalPages": 20,
  "from": 91,
  "to": 100,
  "totalItem": 200,
  "links": {
    "first": "https://example.com/api/items?page=1&limit=10&name=javascript&category=books",
    "last": "https://example.com/api/items?page=20&limit=10&name=javascript&category=books",
    "prev": "https://example.com/api/items?page=9&limit=10&name=javascript&category=books",
    "next": "https://example.com/api/items?page=11&limit=10&name=javascript&category=books"
  },
  "pagination": [
    {
      "page": 1,
      "url": "https://example.com/api/items?page=1&limit=10&name=javascript&category=books"
    },
    {
      "page": 2,
      "url": "https://example.com/api/items?page=2&limit=10&name=javascript&category=books"
    },
    {
      "page": "...",
      "url": null
    },
    {
      "page": 9,
      "url": "https://example.com/api/items?page=9&limit=10&name=javascript&category=books"
    },
    {
      "page": 10,
      "url": "https://example.com/api/items?page=10&limit=10&name=javascript&category=books"
    },
    {
      "page": 11,
      "url": "https://example.com/api/items?page=11&limit=10&name=javascript&category=books"
    },
    {
      "page": "...",
      "url": null
    },
    {
      "page": 19,
      "url": "https://example.com/api/items?page=19&limit=10&name=javascript&category=books"
    },
    {
      "page": 20,
      "url": "https://example.com/api/items?page=20&limit=10&name=javascript&category=books"
    }
  ]
}

License

This project is licensed under the MIT License.