aboutsummaryrefslogtreecommitdiff
path: root/cleaners/skyblock/minions.ts
diff options
context:
space:
mode:
authormat <27899617+mat-1@users.noreply.github.com>2021-02-13 14:13:42 -0600
committermat <27899617+mat-1@users.noreply.github.com>2021-02-13 14:13:42 -0600
commit52e38809212133ef673d11bfa96ba3bb43c3644c (patch)
treef54408afd41cc64b64d5e82a3ad814b1bb55d4a7 /cleaners/skyblock/minions.ts
parenta23103ec24128f2e24b93ad101ade6dfdd4758c3 (diff)
downloadskyblock-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.ts70
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