@dalet-oss/lexorank
Version:
A reference implementation of a list ordering system like JIRA's Lexorank algorithm
85 lines (61 loc) • 2.07 kB
Markdown
# LexoRank on Typescript
A reference implementation of a list ordering system like [JIRA's Lexorank algorithm](https://www.youtube.com/watch?v=OjQv9xMoFbg).
[](https://badge.fury.io/js/@dalet-oss%2Flexorank)
This was forked from [https://github.com/kvandake/lexorank-ts](https://github.com/kvandake/lexorank-ts) in October 2024
because, unfortunately, the maintainer appears to have abandoned their project.
## Getting Started
Npm
```sh
npm install @dalet-oss/lexorank
```
Yarn
```sh
yarn add @dalet-oss/lexorank
```
## Storyboard
[See examples](https://630e298cd63179cde4d8775c-bensuqejhp.chromatic.com/?path=/story/dnd-kit--dnd-kit-list-story)
## Using
### Static methods
```typescript
import { LexoRank } from '@dalet-oss/lexorank';
// min
const minLexoRank = LexoRank.min();
// max
const maxLexoRank = LexoRank.max();
// middle
const middleLexoRank = LexoRank.middle();
// parse
const parsedLexoRank = LexoRank.parse('0|0i0000:');
```
### Public methods
```typescript
import { LexoRank } from '@dalet-oss/lexorank';
// any lexoRank
const lexoRank = LexoRank.middle();
// generate next lexorank
const nextLexoRank = lexoRank.genNext();
// generate previous lexorank
const prevLexoRank = lexoRank.genPrev();
// toString
const lexoRankStr = lexoRank.toString();
```
### Calculate LexoRank
LexRank calculation based on existing LexoRanks.
```typescript
import { LexoRank } from '@dalet-oss/lexorank';
// any lexorank
const any1LexoRank = LexoRank.min();
// another lexorank
const any2LexoRank = any1LexoRank.genNext().genNext();
// calculate between
const betweenLexoRank = any1LexoRank.between(any2LexoRank);
// calculate between lexoRanks
const betweenLexoRanks = any1LexoRank.multipleBetween(any2LexoRank, 5);
```
## Related projects
- [LexoRank on C#](https://github.com/kvandake/lexorank-dotnet)
## Licence
MIT
---
**I have not found information about the license of the algorithm LexoRank.
If the rights are violated, please contact me to correct the current license.**