mirror of
				https://github.com/maxswa/osrs-json-hiscores.git
				synced 2025-10-15 10:19:04 +00:00 
			
		
		
		
	Compare commits
	
		
			12 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 6d000df717 | ||
|   | 5575a83039 | ||
|   | 86d9bcb2e7 | ||
|   | 79c067152c | ||
|   | e51e7bc32e | ||
|   | 7d7c7f9b08 | ||
|   | fd24890f67 | ||
|   | 3ba434978a | ||
|   | 44ecdf5434 | ||
|   | 99fc97f05e | ||
|   | b3fc5846f3 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1deed9f450 | 
							
								
								
									
										27
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								README.md
									
									
									
									
									
								
							| @@ -92,17 +92,18 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | |||||||
|  |  | ||||||
| ### Minigames | ### Minigames | ||||||
|  |  | ||||||
| | Minigame                        |       Param       | | | Minigame                        |        Param        | | ||||||
| | ------------------------------- | :---------------: | | | ------------------------------- | :-----------------: | | ||||||
| | Bounty Hunter (Legacy - Rogue)  |     `rogueBH`     | | | Bounty Hunter (Legacy - Rogue)  |      `rogueBH`      | | ||||||
| | Bounty Hunter (Legacy - Hunter) |    `hunterBH`     | | | Bounty Hunter (Legacy - Hunter) |     `hunterBH`      | | ||||||
| | Bounty Hunter (Rogue)           |    `rogueBHV2`    | | | Bounty Hunter (Rogue)           |     `rogueBHV2`     | | ||||||
| | Bounty Hunter (Hunter)          |   `hunterBHV2`    | | | Bounty Hunter (Hunter)          |    `hunterBHV2`     | | ||||||
| | LMS - Rank                      | `lastManStanding` | | | LMS - Rank                      |  `lastManStanding`  | | ||||||
| | PvP Arena - Rank                |    `pvpArena`     | | | PvP Arena - Rank                |     `pvpArena`      | | ||||||
| | Soul Wars Zeal                  |  `soulWarsZeal`   | | | Soul Wars Zeal                  |   `soulWarsZeal`    | | ||||||
| | Rifts closed                    |   `riftsClosed`   | | | Rifts closed                    |    `riftsClosed`    | | ||||||
| | Colosseum Glory                 | `colosseumGlory`  | | | Colosseum Glory                 |  `colosseumGlory`   | | ||||||
|  | | Collections Logged              | `collectionsLogged` | | ||||||
|  |  | ||||||
| ### Points | ### Points | ||||||
|  |  | ||||||
| @@ -164,6 +165,7 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | |||||||
| | The Corrupted Gauntlet            |      `corruptedGauntlet`       | | | The Corrupted Gauntlet            |      `corruptedGauntlet`       | | ||||||
| | The Hueycoatl                     |          `hueycoatl`           | | | The Hueycoatl                     |          `hueycoatl`           | | ||||||
| | The Leviathan                     |          `leviathan`           | | | The Leviathan                     |          `leviathan`           | | ||||||
|  | | The Royal Titans                  |         `royalTitans`          | | ||||||
| | The Whisperer                     |          `whisperer`           | | | The Whisperer                     |          `whisperer`           | | ||||||
| | Theatre Of Blood                  |        `theatreOfBlood`        | | | Theatre Of Blood                  |        `theatreOfBlood`        | | ||||||
| | Theatre Of Blood: Hard Mode       |    `theatreOfBloodHardMode`    | | | Theatre Of Blood: Hard Mode       |    `theatreOfBloodHardMode`    | | ||||||
| @@ -177,6 +179,7 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | |||||||
| | Vetion                            |            `vetion`            | | | Vetion                            |            `vetion`            | | ||||||
| | Vorkath                           |           `vorkath`            | | | Vorkath                           |           `vorkath`            | | ||||||
| | Wintertodt                        |          `wintertodt`          | | | Wintertodt                        |          `wintertodt`          | | ||||||
|  | | Yama                              |             `yama`             | | ||||||
| | Zalcano                           |           `zalcano`            | | | Zalcano                           |           `zalcano`            | | ||||||
| | Zulrah                            |            `zulrah`            | | | Zulrah                            |            `zulrah`            | | ||||||
|  |  | ||||||
| @@ -205,6 +208,8 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | |||||||
|     pvpArena: {}, |     pvpArena: {}, | ||||||
|     soulWarsZeal: {}, |     soulWarsZeal: {}, | ||||||
|     riftsClosed: {}, |     riftsClosed: {}, | ||||||
|  |     colosseumGlory: {}, | ||||||
|  |     collectionsLogged: {}, | ||||||
|     bosses: {} |     bosses: {} | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,106 +1,109 @@ | |||||||
| 2130,2277,1102428578 | 2210,2277,1150073045 | ||||||
| 22624,99,32956104 | 23988,99,33320012 | ||||||
| 3574,99,47147957 | 3114,99,51215128 | ||||||
| 1226,99,200000000 | 1203,99,200000000 | ||||||
| 1454,99,180249986 | 1372,99,196290925 | ||||||
| 3112,99,155438899 | 3458,99,159426771 | ||||||
| 2533,99,17520811 | 2746,99,17744970 | ||||||
| 2078,99,84629930 | 2031,99,91566360 | ||||||
| 150276,99,13378420 | 161852,99,13386665 | ||||||
| 23833,99,19182079 | 25801,99,19461878 | ||||||
| 61715,99,13456926 | 64826,99,13473417 | ||||||
| 24604,99,16672148 | 26528,99,16672481 | ||||||
| 19900,99,19161337 | 20829,99,19483653 | ||||||
| 53450,99,14082613 | 58378,99,14103220 | ||||||
| 12063,99,16553015 | 13188,99,16573909 | ||||||
| 32871,99,14985851 | 36283,99,15061037 | ||||||
| 39747,99,13346314 | 17137,99,14670565 | ||||||
| 8390,99,15771711 | 8751,99,16169665 | ||||||
| 55848,99,14322777 | 60803,99,14390315 | ||||||
| 1723,99,52832158 | 1718,99,57850681 | ||||||
| 2107,99,101923913 | 2117,99,110369178 | ||||||
| 5301,99,22739376 | 5540,99,22739567 | ||||||
| 20087,99,18044758 | 22326,99,18052465 | ||||||
| 1301,99,18031495 | 1467,99,18050183 | ||||||
| -1,-1 | -1,-1 | ||||||
| -1,-1 | -1,-1 | ||||||
| 32847,10 | 38135,10 | ||||||
| 16567,3 | 19368,3 | ||||||
| 147262,8 | 146220,8 | ||||||
| 101823,7 | 100923,7 | ||||||
| 382,9739 | 433,9802 | ||||||
| 1265,825 | 1542,825 | ||||||
| 131,6000 | 158,6000 | ||||||
| 2401,1606 | 2572,1606 | ||||||
| 43386,311 | 47979,311 | ||||||
| 799,460 | 1081,460 | ||||||
| 945,537 | 880,600 | ||||||
| 5531,5516 | 4258,6785 | ||||||
| -1,-1 | -1,-1 | ||||||
| 7538,14780 | 7596,14780 | ||||||
| 6781,1060 | 8124,1060 | ||||||
| 6880,43487 | 10438,43487 | ||||||
| 3193,2192 | 1114,1155 | ||||||
| 2932,4796 | 3497,2192 | ||||||
| 123,6789 | 3204,4796 | ||||||
| 37,111 | 1087,984 | ||||||
| 44605,143 | 2230,2328 | ||||||
| 4023,1830 | 51533,143 | ||||||
| 238149,5 | 4243,1830 | ||||||
| 47139,293 | 256985,5 | ||||||
| 98811,58 | 54424,293 | ||||||
| 10766,2657 | 114691,58 | ||||||
| 200557,34 | 11700,2657 | ||||||
| 1735,692 | 211708,34 | ||||||
| 23548,215 | 1779,736 | ||||||
| 43337,116 | 24958,215 | ||||||
| 61439,287 | 46504,116 | ||||||
| 2859,2000 | 66096,287 | ||||||
| 53841,106 | 3133,2000 | ||||||
| 18420,1078 | 26682,198 | ||||||
| 23824,1062 | 19337,1078 | ||||||
| 18418,1088 | 25021,1062 | ||||||
| 85908,25 | 19290,1088 | ||||||
| 6077,1320 | 89474,25 | ||||||
| 21980,1228 | 7535,1320 | ||||||
| 76561,477 | 23251,1228 | ||||||
| 774,3642 | 82016,477 | ||||||
| 7917,281 | 876,3642 | ||||||
| 2313,2046 | 7073,310 | ||||||
| 52832,580 | 2476,2046 | ||||||
| 64296,2899 | 55411,580 | ||||||
| 4205,1740 | 68801,2899 | ||||||
| 2681,1444 | 4608,1740 | ||||||
| 3424,324 | 3079,1444 | ||||||
| 523,48 | 8344,324 | ||||||
| 35420,626 | 540,53 | ||||||
| 4162,749 | 38395,626 | ||||||
| 5046,500 | 4176,749 | ||||||
| 1218,217 | 5519,500 | ||||||
| 21243,379 | 1394,217 | ||||||
| 40733,249 | 26127,379 | ||||||
| 53931,91 | 49730,249 | ||||||
| 4870,1245 | 57206,91 | ||||||
| 174877,29 | 6106,1245 | ||||||
| 2122,49 | 185920,29 | ||||||
| 3471,1569 | 3232,49 | ||||||
| 50947,273 | 4276,1569 | ||||||
| 236110,7 | 57314,273 | ||||||
| 102423,201 | 256794,7 | ||||||
| 2344,21039 | 113862,201 | ||||||
| 10174,666 | 1969,538 | ||||||
| 665,2072 | 12346,671 | ||||||
| 23177,310 | 5606,149 | ||||||
| 1967,419 | 550,2450 | ||||||
| 8495,3066 | 25557,310 | ||||||
| 122123,37 | 1391,538 | ||||||
| 240,1537 | 9325,3066 | ||||||
| 7756,7 | 131996,37 | ||||||
| 140561,8 | 214,1720 | ||||||
| 4736,2113 | 8902,7 | ||||||
| 249,7096 | 148385,8 | ||||||
| 89194,51 | 6120,2113 | ||||||
| 15067,2780 | 287,7096 | ||||||
| 975929,62 | 97368,51 | ||||||
| 196393,25 | 15591,2780 | ||||||
| 227062,340 | 1000405,67 | ||||||
|  | 19722,173 | ||||||
|  | 213696,25 | ||||||
|  | 240082,340 | ||||||
| Can't render this file because it has a wrong number of fields in line 25. | 
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -15,7 +15,10 @@ import { | |||||||
|   InvalidFormatError, |   InvalidFormatError, | ||||||
|   BH_MODES, |   BH_MODES, | ||||||
|   parseJsonStats, |   parseJsonStats, | ||||||
|   HiscoresResponse |   HiscoresResponse, | ||||||
|  |   InvalidRSNError, | ||||||
|  |   PlayerNotFoundError, | ||||||
|  |   HiScoresError | ||||||
| } from '../src/index'; | } from '../src/index'; | ||||||
|  |  | ||||||
| const B0ATY_NAME = 'B0ATY'; | const B0ATY_NAME = 'B0ATY'; | ||||||
| @@ -24,6 +27,8 @@ const LYNX_TITAN_SPACE_NAME = 'lYnX tiTaN'; | |||||||
| const LYNX_TITAN_UNDERSCORE_NAME = 'lYnX_tiTaN'; | const LYNX_TITAN_UNDERSCORE_NAME = 'lYnX_tiTaN'; | ||||||
| const LYNX_TITAN_HYPHEN_NAME = 'lYnX-tiTaN'; | const LYNX_TITAN_HYPHEN_NAME = 'lYnX-tiTaN'; | ||||||
| const LYNX_TITAN_FORMATTED_NAME = 'Lynx Titan'; | const LYNX_TITAN_FORMATTED_NAME = 'Lynx Titan'; | ||||||
|  | const NON_EXISTENT_NAME = 'nonExistent'; | ||||||
|  | const ERROR_NAME = 'errorName'; | ||||||
|  |  | ||||||
| const attackTopPage = readFileSync(`${__dirname}/attackTopPage.html`, 'utf8'); | const attackTopPage = readFileSync(`${__dirname}/attackTopPage.html`, 'utf8'); | ||||||
| const b0atyNamePage = readFileSync(`${__dirname}/b0atyNamePage.html`, 'utf8'); | const b0atyNamePage = readFileSync(`${__dirname}/b0atyNamePage.html`, 'utf8'); | ||||||
| @@ -57,6 +62,12 @@ jest.spyOn(axios, 'get').mockImplementation((url) => { | |||||||
|   if (getStatsURL('main', LYNX_TITAN_FORMATTED_NAME, true) === url) { |   if (getStatsURL('main', LYNX_TITAN_FORMATTED_NAME, true) === url) { | ||||||
|     return Promise.resolve({ status: 200, data: lynxTitanStats }); |     return Promise.resolve({ status: 200, data: lynxTitanStats }); | ||||||
|   } |   } | ||||||
|  |   if (getPlayerTableURL('main', NON_EXISTENT_NAME) === url) { | ||||||
|  |     return Promise.resolve({ data: '<html></html>' }); | ||||||
|  |   } | ||||||
|  |   if (getPlayerTableURL('main', ERROR_NAME)) { | ||||||
|  |     return Promise.reject(); | ||||||
|  |   } | ||||||
|   throw new Error(`No mock response for URL: ${url}`); |   throw new Error(`No mock response for URL: ${url}`); | ||||||
| }); | }); | ||||||
|  |  | ||||||
| @@ -103,6 +114,7 @@ test('Parse CSV to json', () => { | |||||||
|   37,225 |   37,225 | ||||||
|   25,1110 |   25,1110 | ||||||
|   7827,43249 |   7827,43249 | ||||||
|  |   1114,1155 | ||||||
|   382,2780 |   382,2780 | ||||||
|   944,3000 |   944,3000 | ||||||
|   561,398429 |   561,398429 | ||||||
| @@ -152,6 +164,7 @@ test('Parse CSV to json', () => { | |||||||
|   2870,6 |   2870,6 | ||||||
|   891,9102 |   891,9102 | ||||||
|   2871,7 |   2871,7 | ||||||
|  |   5606,149 | ||||||
|   2872,8 |   2872,8 | ||||||
|   6984,138 |   6984,138 | ||||||
|   23,923141 |   23,923141 | ||||||
| @@ -165,6 +178,7 @@ test('Parse CSV to json', () => { | |||||||
|   1940,272 |   1940,272 | ||||||
|   8623,1340 |   8623,1340 | ||||||
|   605,1694 |   605,1694 | ||||||
|  |   15233,245 | ||||||
|   -1,-1 |   -1,-1 | ||||||
|   3867,4583`; |   3867,4583`; | ||||||
|  |  | ||||||
| @@ -208,6 +222,7 @@ test('Parse CSV to json', () => { | |||||||
|     soulWarsZeal: { rank: 37, score: 225 }, |     soulWarsZeal: { rank: 37, score: 225 }, | ||||||
|     riftsClosed: { rank: 25, score: 1110 }, |     riftsClosed: { rank: 25, score: 1110 }, | ||||||
|     colosseumGlory: { rank: 7827, score: 43249 }, |     colosseumGlory: { rank: 7827, score: 43249 }, | ||||||
|  |     collectionsLogged: { rank: 1114, score: 1155 }, | ||||||
|     clues: { |     clues: { | ||||||
|       all: { rank: 32, score: 12148 }, |       all: { rank: 32, score: 12148 }, | ||||||
|       beginner: { rank: 3105, score: 76 }, |       beginner: { rank: 3105, score: 76 }, | ||||||
| @@ -267,6 +282,7 @@ test('Parse CSV to json', () => { | |||||||
|       corruptedGauntlet: { rank: 2870, score: 6 }, |       corruptedGauntlet: { rank: 2870, score: 6 }, | ||||||
|       hueycoatl: { rank: 891, score: 9102 }, |       hueycoatl: { rank: 891, score: 9102 }, | ||||||
|       leviathan: { rank: 2871, score: 7 }, |       leviathan: { rank: 2871, score: 7 }, | ||||||
|  |       royalTitans: { rank: 5606, score: 149 }, | ||||||
|       whisperer: { rank: 2872, score: 8 }, |       whisperer: { rank: 2872, score: 8 }, | ||||||
|       theatreOfBlood: { rank: 6984, score: 138 }, |       theatreOfBlood: { rank: 6984, score: 138 }, | ||||||
|       theatreOfBloodHardMode: { rank: 23, score: 923141 }, |       theatreOfBloodHardMode: { rank: 23, score: 923141 }, | ||||||
| @@ -280,6 +296,7 @@ test('Parse CSV to json', () => { | |||||||
|       vetion: { rank: 1940, score: 272 }, |       vetion: { rank: 1940, score: 272 }, | ||||||
|       vorkath: { rank: 8623, score: 1340 }, |       vorkath: { rank: 8623, score: 1340 }, | ||||||
|       wintertodt: { rank: 605, score: 1694 }, |       wintertodt: { rank: 605, score: 1694 }, | ||||||
|  |       yama: { rank: 15233, score: 245 }, | ||||||
|       zalcano: { rank: -1, score: -1 }, |       zalcano: { rank: -1, score: -1 }, | ||||||
|       zulrah: { rank: 3867, score: 4583 } |       zulrah: { rank: 3867, score: 4583 } | ||||||
|     } |     } | ||||||
| @@ -318,7 +335,15 @@ describe('Get name format', () => { | |||||||
|     expect(data).toBe(B0ATY_FORMATTED_NAME); |     expect(data).toBe(B0ATY_FORMATTED_NAME); | ||||||
|   }); |   }); | ||||||
|   it('throws an error for a name with invalid characters', async () => { |   it('throws an error for a name with invalid characters', async () => { | ||||||
|     await expect(getRSNFormat('b&aty')).rejects.toBeTruthy(); |     await expect(getRSNFormat('b&aty')).rejects.toThrow(InvalidRSNError); | ||||||
|  |   }); | ||||||
|  |   it('throws an error for a non-existent player', async () => { | ||||||
|  |     await expect(getRSNFormat(NON_EXISTENT_NAME)).rejects.toThrow( | ||||||
|  |       PlayerNotFoundError | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('throws an error for a hiscores issue', async () => { | ||||||
|  |     await expect(getRSNFormat(ERROR_NAME)).rejects.toThrow(HiScoresError); | ||||||
|   }); |   }); | ||||||
| }); | }); | ||||||
|  |  | ||||||
| @@ -505,7 +530,7 @@ test('Get attack top page', async () => { | |||||||
|  |  | ||||||
| test('Get non-existent player', async () => { | test('Get non-existent player', async () => { | ||||||
|   getStats('fishy').catch((err) => { |   getStats('fishy').catch((err) => { | ||||||
|     if (err.response) { |     if (err?.response) { | ||||||
|       expect(err.response.status).toBe(404); |       expect(err.response.status).toBe(404); | ||||||
|     } |     } | ||||||
|   }); |   }); | ||||||
|   | |||||||
| @@ -59,7 +59,7 @@ | |||||||
|     { |     { | ||||||
|       "id": 8, |       "id": 8, | ||||||
|       "name": "Cooking", |       "name": "Cooking", | ||||||
|       "rank": 154, |       "rank": 149, | ||||||
|       "level": 99, |       "level": 99, | ||||||
|       "xp": 200000000 |       "xp": 200000000 | ||||||
|     }, |     }, | ||||||
| @@ -108,7 +108,7 @@ | |||||||
|     { |     { | ||||||
|       "id": 15, |       "id": 15, | ||||||
|       "name": "Mining", |       "name": "Mining", | ||||||
|       "rank": 24, |       "rank": 23, | ||||||
|       "level": 99, |       "level": 99, | ||||||
|       "xp": 200000000 |       "xp": 200000000 | ||||||
|     }, |     }, | ||||||
| @@ -157,7 +157,7 @@ | |||||||
|     { |     { | ||||||
|       "id": 22, |       "id": 22, | ||||||
|       "name": "Hunter", |       "name": "Hunter", | ||||||
|       "rank": 4, |       "rank": 3, | ||||||
|       "level": 99, |       "level": 99, | ||||||
|       "xp": 200000000 |       "xp": 200000000 | ||||||
|     }, |     }, | ||||||
| @@ -209,7 +209,7 @@ | |||||||
|     { |     { | ||||||
|       "id": 6, |       "id": 6, | ||||||
|       "name": "Clue Scrolls (all)", |       "name": "Clue Scrolls (all)", | ||||||
|       "rank": 832420, |       "rank": 937868, | ||||||
|       "score": 22 |       "score": 22 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
| @@ -233,7 +233,7 @@ | |||||||
|     { |     { | ||||||
|       "id": 10, |       "id": 10, | ||||||
|       "name": "Clue Scrolls (hard)", |       "name": "Clue Scrolls (hard)", | ||||||
|       "rank": 517091, |       "rank": 578038, | ||||||
|       "score": 22 |       "score": 22 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
| @@ -280,384 +280,396 @@ | |||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 18, |       "id": 18, | ||||||
|       "name": "Abyssal Sire", |       "name": "Collections Logged", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 19, |       "id": 19, | ||||||
|       "name": "Alchemical Hydra", |       "name": "Abyssal Sire", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 20, |       "id": 20, | ||||||
|       "name": "Amoxliatl", |       "name": "Alchemical Hydra", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 21, |       "id": 21, | ||||||
|       "name": "Araxxor", |       "name": "Amoxliatl", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 22, |       "id": 22, | ||||||
|       "name": "Artio", |       "name": "Araxxor", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 23, |       "id": 23, | ||||||
|       "name": "Barrows Chests", |       "name": "Artio", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 24, |       "id": 24, | ||||||
|       "name": "Bryophyta", |       "name": "Barrows Chests", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 25, |       "id": 25, | ||||||
|       "name": "Callisto", |       "name": "Bryophyta", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 26, |       "id": 26, | ||||||
|       "name": "Calvar'ion", |       "name": "Callisto", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 27, |       "id": 27, | ||||||
|       "name": "Cerberus", |       "name": "Calvar'ion", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 28, |       "id": 28, | ||||||
|       "name": "Chambers of Xeric", |       "name": "Cerberus", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 29, |       "id": 29, | ||||||
|       "name": "Chambers of Xeric: Challenge Mode", |       "name": "Chambers of Xeric", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 30, |       "id": 30, | ||||||
|       "name": "Chaos Elemental", |       "name": "Chambers of Xeric: Challenge Mode", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 31, |       "id": 31, | ||||||
|       "name": "Chaos Fanatic", |       "name": "Chaos Elemental", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 32, |       "id": 32, | ||||||
|       "name": "Commander Zilyana", |       "name": "Chaos Fanatic", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 33, |       "id": 33, | ||||||
|       "name": "Corporeal Beast", |       "name": "Commander Zilyana", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 34, |       "id": 34, | ||||||
|       "name": "Crazy Archaeologist", |       "name": "Corporeal Beast", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 35, |       "id": 35, | ||||||
|       "name": "Dagannoth Prime", |       "name": "Crazy Archaeologist", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 36, |       "id": 36, | ||||||
|       "name": "Dagannoth Rex", |       "name": "Dagannoth Prime", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 37, |       "id": 37, | ||||||
|       "name": "Dagannoth Supreme", |       "name": "Dagannoth Rex", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 38, |       "id": 38, | ||||||
|       "name": "Deranged Archaeologist", |       "name": "Dagannoth Supreme", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 39, |       "id": 39, | ||||||
|       "name": "Duke Sucellus", |       "name": "Deranged Archaeologist", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 40, |       "id": 40, | ||||||
|       "name": "General Graardor", |       "name": "Duke Sucellus", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 41, |       "id": 41, | ||||||
|       "name": "Giant Mole", |       "name": "General Graardor", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 42, |       "id": 42, | ||||||
|       "name": "Grotesque Guardians", |       "name": "Giant Mole", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 43, |       "id": 43, | ||||||
|       "name": "Hespori", |       "name": "Grotesque Guardians", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 44, |       "id": 44, | ||||||
|       "name": "Kalphite Queen", |       "name": "Hespori", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 45, |       "id": 45, | ||||||
|       "name": "King Black Dragon", |       "name": "Kalphite Queen", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 46, |       "id": 46, | ||||||
|       "name": "Kraken", |       "name": "King Black Dragon", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 47, |       "id": 47, | ||||||
|       "name": "Kree'Arra", |       "name": "Kraken", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 48, |       "id": 48, | ||||||
|       "name": "K'ril Tsutsaroth", |       "name": "Kree'Arra", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 49, |       "id": 49, | ||||||
|       "name": "Lunar Chests", |       "name": "K'ril Tsutsaroth", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 50, |       "id": 50, | ||||||
|       "name": "Mimic", |       "name": "Lunar Chests", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 51, |       "id": 51, | ||||||
|       "name": "Nex", |       "name": "Mimic", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 52, |       "id": 52, | ||||||
|       "name": "Nightmare", |       "name": "Nex", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 53, |       "id": 53, | ||||||
|       "name": "Phosani's Nightmare", |       "name": "Nightmare", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 54, |       "id": 54, | ||||||
|       "name": "Obor", |       "name": "Phosani's Nightmare", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 55, |       "id": 55, | ||||||
|       "name": "Phantom Muspah", |       "name": "Obor", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 56, |       "id": 56, | ||||||
|       "name": "Sarachnis", |       "name": "Phantom Muspah", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 57, |       "id": 57, | ||||||
|       "name": "Scorpia", |       "name": "Sarachnis", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 58, |       "id": 58, | ||||||
|       "name": "Scurrius", |       "name": "Scorpia", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 59, |       "id": 59, | ||||||
|       "name": "Skotizo", |       "name": "Scurrius", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 60, |       "id": 60, | ||||||
|       "name": "Sol Heredit", |       "name": "Skotizo", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 61, |       "id": 61, | ||||||
|       "name": "Spindel", |       "name": "Sol Heredit", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 62, |       "id": 62, | ||||||
|       "name": "Tempoross", |       "name": "Spindel", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 63, |       "id": 63, | ||||||
|       "name": "The Gauntlet", |       "name": "Tempoross", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 64, |       "id": 64, | ||||||
|       "name": "The Corrupted Gauntlet", |       "name": "The Gauntlet", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 65, |       "id": 65, | ||||||
|       "name": "The Hueycoatl", |       "name": "The Corrupted Gauntlet", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 66, |       "id": 66, | ||||||
|       "name": "The Leviathan", |       "name": "The Hueycoatl", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 67, |       "id": 67, | ||||||
|       "name": "The Whisperer", |       "name": "The Leviathan", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 68, |       "id": 68, | ||||||
|       "name": "Theatre of Blood", |       "name": "The Royal Titans", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 69, |       "id": 69, | ||||||
|       "name": "Theatre of Blood: Hard Mode", |       "name": "The Whisperer", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 70, |       "id": 70, | ||||||
|       "name": "Thermonuclear Smoke Devil", |       "name": "Theatre of Blood", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 71, |       "id": 71, | ||||||
|       "name": "Tombs of Amascut", |       "name": "Theatre of Blood: Hard Mode", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 72, |       "id": 72, | ||||||
|       "name": "Tombs of Amascut: Expert Mode", |       "name": "Thermonuclear Smoke Devil", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 73, |       "id": 73, | ||||||
|       "name": "TzKal-Zuk", |       "name": "Tombs of Amascut", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 74, |       "id": 74, | ||||||
|       "name": "TzTok-Jad", |       "name": "Tombs of Amascut: Expert Mode", | ||||||
|       "rank": 251, |       "rank": -1, | ||||||
|       "score": 186 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 75, |       "id": 75, | ||||||
|       "name": "Vardorvis", |       "name": "TzKal-Zuk", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 76, |       "id": 76, | ||||||
|       "name": "Venenatis", |       "name": "TzTok-Jad", | ||||||
|       "rank": -1, |       "rank": 317, | ||||||
|       "score": -1 |       "score": 186 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 77, |       "id": 77, | ||||||
|       "name": "Vet'ion", |       "name": "Vardorvis", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 78, |       "id": 78, | ||||||
|       "name": "Vorkath", |       "name": "Venenatis", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 79, |       "id": 79, | ||||||
|       "name": "Wintertodt", |       "name": "Vet'ion", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 80, |       "id": 80, | ||||||
|       "name": "Zalcano", |       "name": "Vorkath", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": 81, |       "id": 81, | ||||||
|  |       "name": "Wintertodt", | ||||||
|  |       "rank": -1, | ||||||
|  |       "score": -1 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "id": 82, | ||||||
|  |       "name": "Zalcano", | ||||||
|  |       "rank": -1, | ||||||
|  |       "score": -1 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "id": 83, | ||||||
|       "name": "Zulrah", |       "name": "Zulrah", | ||||||
|       "rank": -1, |       "rank": -1, | ||||||
|       "score": -1 |       "score": -1 | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "osrs-json-hiscores", |   "name": "osrs-json-hiscores", | ||||||
|   "version": "2.20.0", |   "version": "2.22.0", | ||||||
|   "description": "The Old School Runescape API wrapper that does more!", |   "description": "The Old School Runescape API wrapper that does more!", | ||||||
|   "main": "lib/index.js", |   "main": "lib/index.js", | ||||||
|   "types": "lib/index.d.ts", |   "types": "lib/index.d.ts", | ||||||
|   | |||||||
| @@ -45,7 +45,8 @@ import { | |||||||
|   FORMATTED_SOUL_WARS, |   FORMATTED_SOUL_WARS, | ||||||
|   FORMATTED_RIFTS_CLOSED, |   FORMATTED_RIFTS_CLOSED, | ||||||
|   FORMATTED_DEADMAN_POINTS, |   FORMATTED_DEADMAN_POINTS, | ||||||
|   FORMATTED_COLOSSEUM_GLORY |   FORMATTED_COLOSSEUM_GLORY, | ||||||
|  |   FORMATTED_COLLECTIONS_LOGGED | ||||||
| } from './utils'; | } from './utils'; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -85,11 +86,12 @@ export async function getOfficialStats( | |||||||
|  */ |  */ | ||||||
| export async function getRSNFormat( | export async function getRSNFormat( | ||||||
|   rsn: string, |   rsn: string, | ||||||
|   config?: AxiosRequestConfig |   config?: AxiosRequestConfig, | ||||||
|  |   mode: Gamemode = 'main' | ||||||
| ): Promise<string> { | ): Promise<string> { | ||||||
|   validateRSN(rsn); |   validateRSN(rsn); | ||||||
|  |  | ||||||
|   const url = getPlayerTableURL('main', rsn); |   const url = getPlayerTableURL(mode, rsn); | ||||||
|   try { |   try { | ||||||
|     const response = await httpGet<string | Buffer | BinaryData | undefined>( |     const response = await httpGet<string | Buffer | BinaryData | undefined>( | ||||||
|       url, |       url, | ||||||
| @@ -102,10 +104,10 @@ export async function getRSNFormat( | |||||||
|     if (anchor) { |     if (anchor) { | ||||||
|       return rsnFromElement(anchor); |       return rsnFromElement(anchor); | ||||||
|     } |     } | ||||||
|     throw new PlayerNotFoundError(); |  | ||||||
|   } catch { |   } catch { | ||||||
|     throw new HiScoresError(); |     throw new HiScoresError(); | ||||||
|   } |   } | ||||||
|  |   throw new PlayerNotFoundError(); | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -164,6 +166,7 @@ export function parseJsonStats(json: HiscoresResponse): Stats { | |||||||
|   const soulWarsZeal = getActivity(FORMATTED_SOUL_WARS); |   const soulWarsZeal = getActivity(FORMATTED_SOUL_WARS); | ||||||
|   const riftsClosed = getActivity(FORMATTED_RIFTS_CLOSED); |   const riftsClosed = getActivity(FORMATTED_RIFTS_CLOSED); | ||||||
|   const colosseumGlory = getActivity(FORMATTED_COLOSSEUM_GLORY); |   const colosseumGlory = getActivity(FORMATTED_COLOSSEUM_GLORY); | ||||||
|  |   const collectionsLogged = getActivity(FORMATTED_COLLECTIONS_LOGGED); | ||||||
|  |  | ||||||
|   const stats: Stats = { |   const stats: Stats = { | ||||||
|     skills, |     skills, | ||||||
| @@ -175,6 +178,7 @@ export function parseJsonStats(json: HiscoresResponse): Stats { | |||||||
|     soulWarsZeal, |     soulWarsZeal, | ||||||
|     riftsClosed, |     riftsClosed, | ||||||
|     colosseumGlory, |     colosseumGlory, | ||||||
|  |     collectionsLogged, | ||||||
|     clues, |     clues, | ||||||
|     bosses |     bosses | ||||||
|   }; |   }; | ||||||
| @@ -224,8 +228,14 @@ export function parseStats(csv: string): Stats { | |||||||
|   const [leaguePoints, deadmanPoints] = activityObjects.splice(0, 2); |   const [leaguePoints, deadmanPoints] = activityObjects.splice(0, 2); | ||||||
|   const bhObjects = activityObjects.splice(0, BH_MODES.length); |   const bhObjects = activityObjects.splice(0, BH_MODES.length); | ||||||
|   const clueObjects = activityObjects.splice(0, CLUES.length); |   const clueObjects = activityObjects.splice(0, CLUES.length); | ||||||
|   const [lastManStanding, pvpArena, soulWarsZeal, riftsClosed, colosseumGlory] = |   const [ | ||||||
|     activityObjects.splice(0, 5); |     lastManStanding, | ||||||
|  |     pvpArena, | ||||||
|  |     soulWarsZeal, | ||||||
|  |     riftsClosed, | ||||||
|  |     colosseumGlory, | ||||||
|  |     collectionsLogged | ||||||
|  |   ] = activityObjects.splice(0, 6); | ||||||
|   const bossObjects = activityObjects.splice(0, BOSSES.length); |   const bossObjects = activityObjects.splice(0, BOSSES.length); | ||||||
|  |  | ||||||
|   const skills: Skills = skillObjects.reduce<Skills>((prev, curr, index) => { |   const skills: Skills = skillObjects.reduce<Skills>((prev, curr, index) => { | ||||||
| @@ -262,6 +272,7 @@ export function parseStats(csv: string): Stats { | |||||||
|     soulWarsZeal, |     soulWarsZeal, | ||||||
|     riftsClosed, |     riftsClosed, | ||||||
|     colosseumGlory, |     colosseumGlory, | ||||||
|  |     collectionsLogged, | ||||||
|     clues, |     clues, | ||||||
|     bosses |     bosses | ||||||
|   }; |   }; | ||||||
|   | |||||||
| @@ -116,6 +116,7 @@ export type Boss = | |||||||
|   | 'corruptedGauntlet' |   | 'corruptedGauntlet' | ||||||
|   | 'hueycoatl' |   | 'hueycoatl' | ||||||
|   | 'leviathan' |   | 'leviathan' | ||||||
|  |   | 'royalTitans' | ||||||
|   | 'whisperer' |   | 'whisperer' | ||||||
|   | 'theatreOfBlood' |   | 'theatreOfBlood' | ||||||
|   | 'theatreOfBloodHardMode' |   | 'theatreOfBloodHardMode' | ||||||
| @@ -129,6 +130,7 @@ export type Boss = | |||||||
|   | 'vetion' |   | 'vetion' | ||||||
|   | 'vorkath' |   | 'vorkath' | ||||||
|   | 'wintertodt' |   | 'wintertodt' | ||||||
|  |   | 'yama' | ||||||
|   | 'zalcano' |   | 'zalcano' | ||||||
|   | 'zulrah'; |   | 'zulrah'; | ||||||
|  |  | ||||||
| @@ -153,6 +155,7 @@ export type ActivityName = | |||||||
|   | 'eliteClues' |   | 'eliteClues' | ||||||
|   | 'masterClues' |   | 'masterClues' | ||||||
|   | 'colosseumGlory' |   | 'colosseumGlory' | ||||||
|  |   | 'collectionsLogged' | ||||||
|   | Boss; |   | Boss; | ||||||
|  |  | ||||||
| export interface Stats { | export interface Stats { | ||||||
| @@ -172,6 +175,7 @@ export interface Stats { | |||||||
|   soulWarsZeal: Activity; |   soulWarsZeal: Activity; | ||||||
|   riftsClosed: Activity; |   riftsClosed: Activity; | ||||||
|   colosseumGlory: Activity; |   colosseumGlory: Activity; | ||||||
|  |   collectionsLogged: Activity; | ||||||
|   bosses: Bosses; |   bosses: Bosses; | ||||||
| } | } | ||||||
| export type Modes = { [M in Gamemode]?: Stats }; | export type Modes = { [M in Gamemode]?: Stats }; | ||||||
|   | |||||||
| @@ -123,6 +123,7 @@ export const BOSSES: Boss[] = [ | |||||||
|   'corruptedGauntlet', |   'corruptedGauntlet', | ||||||
|   'hueycoatl', |   'hueycoatl', | ||||||
|   'leviathan', |   'leviathan', | ||||||
|  |   'royalTitans', | ||||||
|   'whisperer', |   'whisperer', | ||||||
|   'theatreOfBlood', |   'theatreOfBlood', | ||||||
|   'theatreOfBloodHardMode', |   'theatreOfBloodHardMode', | ||||||
| @@ -136,6 +137,7 @@ export const BOSSES: Boss[] = [ | |||||||
|   'vetion', |   'vetion', | ||||||
|   'vorkath', |   'vorkath', | ||||||
|   'wintertodt', |   'wintertodt', | ||||||
|  |   'yama', | ||||||
|   'zalcano', |   'zalcano', | ||||||
|   'zulrah' |   'zulrah' | ||||||
| ]; | ]; | ||||||
| @@ -158,6 +160,7 @@ export const ACTIVITIES: ActivityName[] = [ | |||||||
|   'soulWarsZeal', |   'soulWarsZeal', | ||||||
|   'riftsClosed', |   'riftsClosed', | ||||||
|   'colosseumGlory', |   'colosseumGlory', | ||||||
|  |   'collectionsLogged', | ||||||
|   ...BOSSES |   ...BOSSES | ||||||
| ]; | ]; | ||||||
|  |  | ||||||
| @@ -215,6 +218,7 @@ export const FORMATTED_BOSS_NAMES: FormattedBossNames = { | |||||||
|   corruptedGauntlet: 'The Corrupted Gauntlet', |   corruptedGauntlet: 'The Corrupted Gauntlet', | ||||||
|   hueycoatl: 'The Hueycoatl', |   hueycoatl: 'The Hueycoatl', | ||||||
|   leviathan: 'The Leviathan', |   leviathan: 'The Leviathan', | ||||||
|  |   royalTitans: 'The Royal Titans', | ||||||
|   whisperer: 'The Whisperer', |   whisperer: 'The Whisperer', | ||||||
|   theatreOfBlood: 'Theatre of Blood', |   theatreOfBlood: 'Theatre of Blood', | ||||||
|   theatreOfBloodHardMode: 'Theatre of Blood: Hard Mode', |   theatreOfBloodHardMode: 'Theatre of Blood: Hard Mode', | ||||||
| @@ -228,6 +232,7 @@ export const FORMATTED_BOSS_NAMES: FormattedBossNames = { | |||||||
|   vetion: "Vet'ion", |   vetion: "Vet'ion", | ||||||
|   vorkath: 'Vorkath', |   vorkath: 'Vorkath', | ||||||
|   wintertodt: 'Wintertodt', |   wintertodt: 'Wintertodt', | ||||||
|  |   yama: 'Yama', | ||||||
|   zalcano: 'Zalcano', |   zalcano: 'Zalcano', | ||||||
|   zulrah: 'Zulrah' |   zulrah: 'Zulrah' | ||||||
| }; | }; | ||||||
| @@ -295,6 +300,7 @@ export const FORMATTED_LEAGUE_POINTS = 'League Points'; | |||||||
| export const FORMATTED_DEADMAN_POINTS = 'Deadman Points'; | export const FORMATTED_DEADMAN_POINTS = 'Deadman Points'; | ||||||
| export const FORMATTED_RIFTS_CLOSED = 'Rifts closed'; | export const FORMATTED_RIFTS_CLOSED = 'Rifts closed'; | ||||||
| export const FORMATTED_COLOSSEUM_GLORY = 'Colosseum Glory'; | export const FORMATTED_COLOSSEUM_GLORY = 'Colosseum Glory'; | ||||||
|  | export const FORMATTED_COLLECTIONS_LOGGED = 'Collections Logged'; | ||||||
|  |  | ||||||
| export const INVALID_FORMAT_ERROR = 'Invalid hiscores format'; | export const INVALID_FORMAT_ERROR = 'Invalid hiscores format'; | ||||||
| export const PLAYER_NOT_FOUND_ERROR = 'Player not found'; | export const PLAYER_NOT_FOUND_ERROR = 'Player not found'; | ||||||
|   | |||||||
| @@ -1729,9 +1729,9 @@ cosmiconfig@^7.0.0: | |||||||
|     yaml "^1.10.0" |     yaml "^1.10.0" | ||||||
|  |  | ||||||
| cross-spawn@^7.0.2, cross-spawn@^7.0.3: | cross-spawn@^7.0.2, cross-spawn@^7.0.3: | ||||||
|   version "7.0.3" |   version "7.0.6" | ||||||
|   resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" |   resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.6.tgz#8a58fe78f00dcd70c370451759dfbfaf03e8ee9f" | ||||||
|   integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== |   integrity sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA== | ||||||
|   dependencies: |   dependencies: | ||||||
|     path-key "^3.1.0" |     path-key "^3.1.0" | ||||||
|     shebang-command "^2.0.0" |     shebang-command "^2.0.0" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user