Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bramus/js-pagination-sequence
Generate a sequence of numbers for use in a pagination system, the clever way.
https://github.com/bramus/js-pagination-sequence
Last synced: 3 days ago
JSON representation
Generate a sequence of numbers for use in a pagination system, the clever way.
- Host: GitHub
- URL: https://github.com/bramus/js-pagination-sequence
- Owner: bramus
- License: mit
- Created: 2021-12-05T22:58:32.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2023-07-18T20:10:02.000Z (over 1 year ago)
- Last Synced: 2024-05-01T23:16:08.335Z (8 months ago)
- Language: JavaScript
- Size: 143 KB
- Stars: 140
- Watchers: 4
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![JavaScript Pagination Sequence Generator](./screenshots/js-pagination-sequence.png)](https://codepen.io/bramus/pen/NWaxNKQ)
# JavaScript Pagination Sequence Generator
Generate a sequence of numbers for use in a Pagination Component, the clever way.
## Installation
```bash
npm i @bramus/pagination-sequence
```## Usage / Example
This library comes as an ES Module and exposes a function/algorithm to generate an array of pagination entries.
```js
import { generate } from '@bramus/pagination-sequence';const sequence = generate(67, 74);
// ~> [1, 2, 'β¦', 65, 66, 67, 68, 69, 'β¦', 73, 74]
```Alternatively you can use `generateFromObj` which accepts a configuration Object as an argument:
```js
import { generateFromObj } from '@bramus/pagination-sequence';const sequence = generateFromObj({
curPage: 67,
numPages: 74,
});
// ~> [1, 2, 'β¦', 65, 66, 67, 68, 69, 'β¦', 73, 74]
```Note that this is a Framework Agnostic library: the generated array is not rendered in any way but, instead, must be fed into your own Pagination Component for rendering.
π‘ Looking for some Pagination Component inspiration? See [Integration Examples](#integration-examples) below to see how to use this with the JavaScript Framework Du Jourβ’.
## API
### `generate()`
The exposed `generate` function has the following API:
```js
generate(curPage, numPages, numPagesAtEdges = 2, numPagesAroundCurrent = 2, glue = 'β¦');
```Parameters:
- `curPage`: The current active page
- `numPages`: The total number of pages
- `numPagesAtEdges` _(default: 2)_: Number of pages to show on the outer edges.
- `numPagesAroundCurrent` _(default: 2)_: Number of pages to show around the active page.
- `glue` _(default: 'β¦')_: The string to show when there's a gap### `generateFromObj()`
The `generateFromObj` function accepts one single `opts` object. Its members are all of the parameters described above. Default values are set where possible.
```js
const {
curPage = 1,
numPages = 1,
numPagesAtEdges = 2,
numPagesAroundCurrent = 2,
glue = 'β¦',
} = opts;
```## Principles
The algorithm is opinionated and follows these principles:
- **Stable Output**
When generating a sequence, it will always generate the same amount of entries, for any `curPage` value. When viewing a page at the edge of a series, this can result in `numPagesAtEdges` being ignored.
For example: Instead of having `generate(2, 12, 1, 1)` return `01-[02]-03-..-12` _(5 entries)_, it will return `01-[02]-03-04-05-..-12` _(7 entries)_. This is a deliberate choice because `generate(7, 12, 1, 1)` will also return 7 entries: `01-..-06-[07]-08-..-12`.
With a stable amount of entries being generated, the output will also be visually stable when rendered on screen.
- **Always include links to the edges**
The algorithm will always include links to the first and last page.
For Example: when looking at page 25 of 50, the algorithm will include a link to page 1 and page 50.
- **No unnecessary gaps**
When the algorithm detects a gap that's only β1 item wideβ, it will replace that gap with the actual number.
For Example: A foolish take on `generate(4, 9, 1, 1)`, would generate `01-..-03-[04]-05-..-09`. The algorithm corrects the first gap to `02` and will return `01-02-03-[04]-05-..-09` instead.
## Integration Examples
### React
π Try it online: [https://codepen.io/bramus/pen/NWaxNKQ](https://codepen.io/bramus/pen/NWaxNKQ)
```jsx
import React from "react";
import ReactDOM from "react-dom";
import { generate } from "@bramus/pagination-sequence";const BASE_URL = '#';
const PaginationEntry = ({ value, onEntryClick = null, label = null, title = null, isCurrent = false, isDisabled = false, ...props }) => {
label ??= value;
title ??= `Go to page ${value}`;const onClick = (e) => {
e.stopPropagation();
e.preventDefault();
e.target.blur();
if (onEntryClick) {
onEntryClick(value);
}
}
if (value == 'β¦') {
return (
);
}
if (isDisabled) {
return (
);
}
if (isCurrent) {
props['data-pagination-current'] = true;
}
return (
{label}
);
}
const Pagination = ({ curPage, numPages, numPagesAtEdges = 2, numPagesAroundCurrent = 2, onEntryClick = null }) => {
const sequence = generate(curPage, numPages, numPagesAtEdges, numPagesAroundCurrent);
// console.log(sequence);
return (
{sequence.map((val, idx) =>
)}
);
}
ReactDOM.render(
{ console.log(val)}} />,
document.getElementById('root')
);
```
## License
`@bramus/pagination-sequence` is released under the MIT public license. See the enclosed `LICENSE` for details.
## Other Language Implementations
Looking for an implementation in another programming language?
- PHP: [https://gist.github.com/bramus/5d8f2e0269e57dff5136](https://gist.github.com/bramus/5d8f2e0269e57dff5136) _(The original, from 2014)_
- _(submit a PR to add your own)_