diff options
author | Soopyboo32 <49228220+Soopyboo32@users.noreply.github.com> | 2022-09-07 19:49:54 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-09-07 19:49:54 +0800 |
commit | f404f4f94a4394328b3d1f94b012e7d9cc0aa0d2 (patch) | |
tree | a327a09fae90b15652d849954074378ef5105756 /features/dungeonSolvers | |
parent | 440138a8c05cb5cfbe28c5e77387e049b1db7108 (diff) | |
parent | cd7b714f5e344359b7606c57282376f834084e99 (diff) | |
download | SoopyV2-f404f4f94a4394328b3d1f94b012e7d9cc0aa0d2.tar.gz SoopyV2-f404f4f94a4394328b3d1f94b012e7d9cc0aa0d2.tar.bz2 SoopyV2-f404f4f94a4394328b3d1f94b012e7d9cc0aa0d2.zip |
Merge pull request #60 from Soopyboo32/terminal-solvers
Terminal solvers
Diffstat (limited to 'features/dungeonSolvers')
-rw-r--r-- | features/dungeonSolvers/index.js | 71 |
1 files changed, 68 insertions, 3 deletions
diff --git a/features/dungeonSolvers/index.js b/features/dungeonSolvers/index.js index 83faf41..144951a 100644 --- a/features/dungeonSolvers/index.js +++ b/features/dungeonSolvers/index.js @@ -24,6 +24,13 @@ try { } catch (e) { //player doesent have translate (using english default) } +let wrongColorList = { + "light grey": "silver", + "wool": "white wool", + "ink": "black ink", + "lapis": "blue lapis", + "cocoa": "brown cocoa" +} class DungeonSolvers extends Feature { constructor() { @@ -168,17 +175,17 @@ class DungeonSolvers extends Feature { let timerText = "" if (this.spiritMaskOutsideDungeon.getValue() ? true : !this.eraseBonzoTimer) { if (this.spiritMask.getValue()) { - let timer1 = Math.round((this.spiritMaskTimer - Date.now())/100)/10 + let timer1 = Math.round((this.spiritMaskTimer - Date.now()) / 100) / 10 timerText += "&5Spirit Mask: " + (timer1 > 0 ? "&c" + timer1 + "&6s" : "&6READY") + "\n" } } if (!this.eraseBonzoTimer) { if (this.normalBonzoMask.getValue()) { - let timer2 = Math.round((this.bonzoMaskTimer - Date.now())/100)/10 + let timer2 = Math.round((this.bonzoMaskTimer - Date.now()) / 100) / 10 timerText += "&9Bonzo's Mask: " + (timer2 > 0 ? "&c" + timer2 + "&6s" : "&6READY") + "\n" } if (this.fraggedBonzoMask.getValue()) { - let timer3 = Math.round((this.fraggedBonzoMaskTimer - Date.now())/100)/10 + let timer3 = Math.round((this.fraggedBonzoMaskTimer - Date.now()) / 100) / 10 timerText += "&9⚚ Bonzo's Mask: " + (timer3 > 0 ? "&c" + timer3 + "&6s" : "&6READY") } } @@ -815,6 +822,64 @@ class DungeonSolvers extends Feature { } } + /** + * TODO: This is code from old soopyaddons, needs almost complete recode. + * TODO: Also needs support for the new terminals, namely click at time + * TODO: Make click on time scan even when terminal is throttled (update on chat msg) + * TODO: Make all terminal solvers track when the server will accept the click and update on that + */ + findNeededClicks() { + let itemsHighlight = [] + if (ChatLib.removeFormatting(Player.getContainer().getName()).startsWith("What starts with: '") && ChatLib.removeFormatting(Player.getContainer().getName()).endsWith("'?")) { + let letter = ChatLib.removeFormatting(Player.getContainer().getName()).substr(19, 1).toLowerCase() + let i = 0; + Player.getContainer().getItems().forEach((item) => { + if (ChatLib.removeFormatting(item.getName()).toLowerCase().startsWith(letter) && !item.isEnchanted()) { + itemsHighlight.push(i) + } + i++ + }) + } + if (ChatLib.removeFormatting(Player.getContainer().getName()).startsWith("Select all the ") && ChatLib.removeFormatting(Player.getContainer().getName()).endsWith(" items!")) { + let color = ChatLib.removeFormatting(Player.getContainer().getName()).substr(15).replace(" items!", "").toLowerCase() + let i = 0;//silver -> light grey die, white -> wool-- + Player.getContainer().getItems().forEach((item) => { + let name = ChatLib.removeFormatting(item.getName()).toLowerCase() + Object.entries(wrongColorList).forEach(([from, to]) => { + name.replace(from, to) + }) + if (name.replace("wool", "white wool").includes(color) && !item.isEnchanted()) { + itemsHighlight.push(i) + } + i++ + }) + } + if (ChatLib.removeFormatting(Player.getContainer().getName()) === "Click in order!") { + let i = 0;//silver -> light grey die, white -> wool-- + let number = 100; + Player.getContainer().getItems().forEach((item, i) => { + if (parseInt(ChatLib.removeFormatting(item.getName())) < number && item.getMetadata() === 14) { + number = parseInt(ChatLib.removeFormatting(item.getName())) + } + i++ + }) + i = 0 + Player.getContainer().getItems().forEach((item) => { + if (parseInt(ChatLib.removeFormatting(item.getName())) === number) { + itemsHighlight.push(i) + } + i++ + }) + i = 0 + Player.getContainer().getItems().forEach((item) => { + if (parseInt(ChatLib.removeFormatting(item.getName())) === number + 1) { + itemsHighlight2.push(i) + } + i++ + }) + } + } + onWorldLoad() { this.lastWorldload = Date.now() this.goneInBonus = false; |