1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.countUniqueMinions = exports.combineMinionArrays = exports.cleanMinions = void 0;
const hypixel_1 = require("../../hypixel");
const constants = __importStar(require("../../constants"));
/**
* Clean the minions provided by Hypixel
* @param minionsRaw The minion data provided by the Hypixel API
*/
async function cleanMinions(member) {
var _a;
const minions = [];
const processedMinionNames = new Set();
for (const minionRaw of (_a = member === null || member === void 0 ? void 0 : member.crafted_generators) !== null && _a !== void 0 ? _a : []) {
// 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(hypixel_1.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;
processedMinionNames.add(minionName);
}
const allMinionNames = new Set(await constants.fetchMinions());
for (const minionName of processedMinionNames) {
if (!allMinionNames.has(minionName)) {
constants.addMinions(Array.from(processedMinionNames));
break;
}
}
for (const minionName of allMinionNames) {
if (!processedMinionNames.has(minionName)) {
processedMinionNames.add(minionName);
minions.push({
name: minionName,
levels: new Array(hypixel_1.maxMinion).fill(false)
});
}
}
return minions.sort((a, b) => a.name > b.name ? 1 : (a.name < b.name ? -1 : 0));
}
exports.cleanMinions = cleanMinions;
/**
* Combine multiple arrays of minions into one, useful when getting the minions for members
* @param minions An array of arrays of minions
*/
function combineMinionArrays(minions) {
const resultMinions = [];
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(false);
for (let i = 0; i < minion.levels.length; i++) {
if (minion.levels[i])
matchingMinionReference.levels[i] = true;
}
}
}
}
return resultMinions;
}
exports.combineMinionArrays = combineMinionArrays;
function countUniqueMinions(minions) {
let uniqueMinions = 0;
for (const minion of minions) {
// find the number of times `true` is in the list and add it to uniqueMinions
uniqueMinions += minion.levels.filter(x => x).length;
}
return uniqueMinions;
}
exports.countUniqueMinions = countUniqueMinions;
|