This is a JavaScript ES6 port of the Legends of Runeterra deck encoder/decoder. The goal of this project is to keep up-to-date with Riot's Implementation, stay as close to the original result schema as possible, and use minimal runtime dependencies (instead of testing).
The package require Node.js min version 22.x, because we using Object.groupBy and Map.groupBy. Use the package manager yarn to install this package.
Like:
yarn add lor-deck-encoder@https://github.com/chrysomallos/lor-deck-encoder.git
The following headlines will describe the Deck class interface.
Example:
import createDeck from 'lor-deck-encoder';
const deck = createDeck('CEBQEBADAIIQGAIFAMJC6BABAMCBGFJUAIAQCAZYAQAQKFQ4DUXAEAIEAUIQEBADAEHQ');
import createDeck, {Deck} from 'lor-deck-encoder';
const deck = createDeck('CEBQGAIFAMJC6BABAMCBGFJUAICAGAQRAICACBIWDQOS4AIBAM4AEAIEAUIQEBADAEHQ');
/*
deck = Deck {
cards: [
Card {
set: 1,
id: 3,
faction: Faction {
id: 5,
version: 1,
code: 'SI',
name: 'Shadow Isles',
},
count: 3,
},
{...},
Card {
set: 4,
id: 15,
faction: Faction {
id: 3,
version: 1,
code: 'NX',
name: 'Noxus',
},
count: 1,
},
],
allCodeAndCount: [
{
code: '01SI003',
count: 3,
},
{...},
{
code: '04NX015',
count: 1,
},
],
code: 'CEBQIAIDAQJRKNADAECQGERPAICAGAQRAIAQCAZYAQAQKFQ4DUXAEAQEAMAQ6AIEAUIQ',
list: [
'01SI003:3',
...,
'04NX015:1',
],
version: 1
}
*/
console.log(Deck.fromCode('CEAAECABAQJRWHBIFU2DOOYIAEBAMCIMCINCILJZAICACBANE4VCYBABAILR2HRL').list);
/*
Expected result:
[
'01PZ019:2', '01PZ027:2',
'01PZ028:2', '01PZ040:2',
'01PZ045:2', '01PZ052:2',
'01PZ055:2', '01PZ059:2',
'01IO006:2', '01IO009:2',
'01IO012:2', '01IO018:2',
'01IO026:2', '01IO036:2',
'01IO045:2', '01IO057:2',
'01PZ013:1', '01PZ039:1',
'01PZ042:1', '01PZ044:1',
'01IO023:1', '01IO029:1',
'01IO030:1', '01IO043:1'
]
*/
Use yarn cli <code>
to show code output, with --out-file
you can write additional deck information from Data Dragon into a file (html or json), optional you can change the --language
(default is en_us
).
Example yarn cli CEAAECABAIDASDASDISC2OIIAECBGGY4FAWTINZ3AICACAQXDUPCWBABAQGSOKRM --out-file test.hml
.
To call the test first check out project and run yarn install
.
Included code tests: