diff options
author | mat <27899617+mat-1@users.noreply.github.com> | 2021-02-14 12:03:01 -0600 |
---|---|---|
committer | mat <27899617+mat-1@users.noreply.github.com> | 2021-02-14 12:03:01 -0600 |
commit | a12f0eaf3349160282bdc9f48cf9f253a154e500 (patch) | |
tree | 4d4ca3578c99ae802df0821bf8c0903799b59a9e /src/cleaners | |
parent | d3c4b954545eae9869f6347e1b6edc580210bfcd (diff) | |
download | skyblock-api-a12f0eaf3349160282bdc9f48cf9f253a154e500.tar.gz skyblock-api-a12f0eaf3349160282bdc9f48cf9f253a154e500.tar.bz2 skyblock-api-a12f0eaf3349160282bdc9f48cf9f253a154e500.zip |
add visited zones
Diffstat (limited to 'src/cleaners')
-rw-r--r-- | src/cleaners/skyblock/inventory.ts | 4 | ||||
-rw-r--r-- | src/cleaners/skyblock/member.ts | 5 | ||||
-rw-r--r-- | src/cleaners/skyblock/zones.ts | 18 |
3 files changed, 25 insertions, 2 deletions
diff --git a/src/cleaners/skyblock/inventory.ts b/src/cleaners/skyblock/inventory.ts index 1b49e95..96cd629 100644 --- a/src/cleaners/skyblock/inventory.ts +++ b/src/cleaners/skyblock/inventory.ts @@ -27,7 +27,9 @@ interface Item { export type Inventory = Item[] function cleanItem(rawItem): Item { - const vanillaId: number = rawItem.id + // if the item doesn't have an id, it isn't an item + if (rawItem.id === undefined) return null + const vanillaId: number = rawItem.id && -1 const itemCount = rawItem.Count const damageValue = rawItem.Damage const itemTag = rawItem.tag diff --git a/src/cleaners/skyblock/member.ts b/src/cleaners/skyblock/member.ts index 6796f7d..e7e6250 100644 --- a/src/cleaners/skyblock/member.ts +++ b/src/cleaners/skyblock/member.ts @@ -9,6 +9,7 @@ import { CleanFullProfile } from './profile' import { Included } from '../../hypixel' import { CleanPlayer } from '../player' import { Bank } from './bank' +import { cleanVisitedZones, Zone } from './zones' export interface CleanBasicMember { uuid: string @@ -25,6 +26,7 @@ export interface CleanMember extends CleanBasicMember { inventories: Inventories objectives: Objective[] skills: Skill[] + visited_zones: Zone[] } export async function cleanSkyBlockProfileMemberResponseBasic(member, included: Included[] = null): Promise<CleanBasicMember> { @@ -53,7 +55,8 @@ export async function cleanSkyBlockProfileMemberResponse(member, included: Inclu fairy_souls: cleanFairySouls(member), inventories: inventoriesIncluded ? await cleanInventories(member) : undefined, objectives: cleanObjectives(member), - skills: cleanSkills(member) + skills: cleanSkills(member), + visited_zones: cleanVisitedZones(member) } } diff --git a/src/cleaners/skyblock/zones.ts b/src/cleaners/skyblock/zones.ts new file mode 100644 index 0000000..87d008d --- /dev/null +++ b/src/cleaners/skyblock/zones.ts @@ -0,0 +1,18 @@ +export interface Zone { + name: string + visited: boolean +} + + +export function cleanVisitedZones(data: any): Zone[] { + const rawZones = data?.visited_zones || [] + // TODO: store all the zones that exist in SkyBlock, add add those to the array with visited being false + const zones: Zone[] = [] + for (const rawZoneName of rawZones) { + zones.push({ + name: rawZoneName, + visited: true + }) + } + return zones +} |