diff options
author | mat <27899617+mat-1@users.noreply.github.com> | 2021-02-13 14:13:42 -0600 |
---|---|---|
committer | mat <27899617+mat-1@users.noreply.github.com> | 2021-02-13 14:13:42 -0600 |
commit | 52e38809212133ef673d11bfa96ba3bb43c3644c (patch) | |
tree | f54408afd41cc64b64d5e82a3ad814b1bb55d4a7 /cleaners/skyblock/minions.ts | |
parent | a23103ec24128f2e24b93ad101ade6dfdd4758c3 (diff) | |
download | skyblock-api-52e38809212133ef673d11bfa96ba3bb43c3644c.tar.gz skyblock-api-52e38809212133ef673d11bfa96ba3bb43c3644c.tar.bz2 skyblock-api-52e38809212133ef673d11bfa96ba3bb43c3644c.zip |
move stuff into src folder
Diffstat (limited to 'cleaners/skyblock/minions.ts')
-rw-r--r-- | cleaners/skyblock/minions.ts | 70 |
1 files changed, 0 insertions, 70 deletions
diff --git a/cleaners/skyblock/minions.ts b/cleaners/skyblock/minions.ts deleted file mode 100644 index da69634..0000000 --- a/cleaners/skyblock/minions.ts +++ /dev/null @@ -1,70 +0,0 @@ -import { maxMinion } from '../../hypixel' - -export interface CleanMinion { - name: string, - levels: boolean[] -} - - -/** - * Clean the minions provided by Hypixel - * @param minionsRaw The minion data provided by the Hypixel API - */ -export function cleanMinions(minionsRaw: string[]): CleanMinion[] { - const minions: CleanMinion[] = [] - for (const minionRaw of minionsRaw ?? []) { - // do some regex magic to get the minion name and level - // examples of potential minion names: CLAY_11, PIG_1, MAGMA_CUBE_4 - const minionName = minionRaw.split(/_\d/)[0].toLowerCase() - const minionLevel = parseInt(minionRaw.split(/\D*_/)[1]) - let matchingMinion = minions.find(m => m.name === minionName) - if (!matchingMinion) { - // if the minion doesnt already exist in the minions array, then create it - matchingMinion = { - name: minionName, - levels: new Array(maxMinion).fill(false) - } - minions.push(matchingMinion) - } - while (minionLevel > matchingMinion.levels.length) - // if hypixel increases the minion level, this will increase with it - matchingMinion.levels.push(false) - - // set the minion at that level to true - matchingMinion.levels[minionLevel - 1] = true - } - return minions -} - -/** - * Combine multiple arrays of minions into one, useful when getting the minions for members - * @param minions An array of arrays of minions - */ -export function combineMinionArrays(minions: CleanMinion[][]): CleanMinion[] { - const resultMinions: CleanMinion[] = [] - - for (const memberMinions of minions) { - for (const minion of memberMinions) { - // this is a reference, so we can directly modify the attributes for matchingMinionReference - // and they'll be in the resultMinions array - const matchingMinionReference = resultMinions.find(m => m.name === minion.name) - if (!matchingMinionReference) { - // if the minion name isn't already in the array, add it! - resultMinions.push(minion) - } else { - - // This should never happen, but in case the length of `minion.levels` is longer than - // `matchingMinionReference.levels`, then it should be extended to be equal length - while (matchingMinionReference.levels.length < minion.levels.length) - matchingMinionReference.levels.push(null) - - for (let i = 0; i < minion.levels.length; i++) { - if (minion.levels[i]) - matchingMinionReference.levels[i] = true - } - } - } - } - - return resultMinions -}
\ No newline at end of file |