Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[pull] development from Wynntils:development #21

Open
wants to merge 139 commits into
base: development
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
139 commits
Select commit Hold shift + click to select a range
57f597c
vuln-fix: Zip Slip Vulnerability (#570)
JLLeitschuh Sep 9, 2022
f9174d5
Fixes a StringIndexOutOfBounds exception (#567)
byBackfish Sep 9, 2022
63f0224
fix: always sell all button (#573)
byBackfish Sep 9, 2022
a88c1ea
ci: Automatic changelog and deployment to Curseforge and Modrinth
DevScyu Sep 9, 2022
d22c8b2
fix: Some post 2.0 release fixes (#569)
ryanzhoudev Sep 10, 2022
89e7107
fix: Remove shortid fix (#581)
Incompleteusern Sep 16, 2022
6517c27
Add "Additional Comments" for bug_reports (#580)
IngeniousCoder Sep 16, 2022
4d5d68f
feat: add awakening mask progress bar (#576)
byBackfish Sep 18, 2022
9d6431c
feat: click to copy message (#565)
byBackfish Sep 18, 2022
a74594c
fix: old waypoints being invalid when trying to import (#583)
byBackfish Sep 18, 2022
a03ef5f
fix: Fix quick cast keys (#574)
ryanzhoudev Sep 19, 2022
3e97704
feat: Added Arcanist Mana Bank Bar (#578)
paotmb Sep 19, 2022
b755343
ci: rework [skip ci]
DevScyu Sep 19, 2022
15372c3
ci: add target commit to gh release [skip ci]
DevScyu Sep 21, 2022
7b30319
chore: upgrade gradle to 7.5.1 (#591)
ryanzhoudev Sep 21, 2022
878e70f
fix: rework party management gui (#590)
ryanzhoudev Sep 21, 2022
b7a0ec5
feat: add focus bar (#586)
byBackfish Sep 21, 2022
ca0ef1f
feat: custom trade market sell amount buttons (#584)
byBackfish Sep 21, 2022
d4705b8
feat: ability tree navigation using scroll wheel (#582)
byBackfish Sep 21, 2022
4cdd204
feat: add currently active shaman mask display (#577)
byBackfish Sep 21, 2022
b7647cd
ci: update releases (#592)
DevScyu Sep 21, 2022
43a0f87
chore(release): v1.12.1-beta.0 [skip ci]
invalid-email-address Sep 21, 2022
9b7ea7c
ci: fix release names [skip ci]
DevScyu Sep 21, 2022
79936c7
fix: mythic detection & /guild list spam (#594)
byBackfish Sep 23, 2022
36fb1af
chore(release): v1.12.1-beta.1 [skip ci]
invalid-email-address Sep 23, 2022
f821b79
feat: add corrupted bar (#595)
byBackfish Sep 24, 2022
e87436d
chore(release): v1.12.1-beta.2 [skip ci]
invalid-email-address Sep 24, 2022
fe06649
fix: ObjectivesOverlay: Fix patterns (#601)
kristofbolyai Oct 1, 2022
e106fc0
chore(release): v1.12.1-beta.3 [skip ci]
invalid-email-address Oct 1, 2022
34b1409
fix: hide token during registration process (#603)
HighCrit Oct 10, 2022
adebce0
chore(release): v1.12.1-beta.4 [skip ci]
invalid-email-address Oct 10, 2022
7af5f79
refactor: applying minor caching of variables in a few files. (#599)
TheAvonian Oct 10, 2022
f699c8f
chore(release): v1.12.1-beta.5 [skip ci]
invalid-email-address Oct 10, 2022
c3e0de4
fix: Fix log spam (#600)
Incompleteusern Oct 10, 2022
716945d
chore(release): v1.12.1-beta.6 [skip ci]
invalid-email-address Oct 10, 2022
ec88608
chore: enhance devauth integration
DevScyu Oct 11, 2022
7314984
chore(release): v1.12.1-beta.7 [skip ci]
invalid-email-address Oct 12, 2022
b597ad5
fix: emerald pouch message in chest not being sent (#605)
ryanzhoudev Oct 12, 2022
8034ae5
chore(release): v1.12.1-beta.8 [skip ci]
invalid-email-address Oct 12, 2022
b5b5ca8
chore: add codeowners file [skip ci]
DevScyu Oct 12, 2022
73a74fd
fix: resources in dev environment [skip ci]
DevScyu Oct 12, 2022
ead33b0
feat: Auto updater from github builds (#588)
DevScyu Oct 13, 2022
26cfb98
chore(release): v1.12.1-beta.9 [skip ci]
invalid-email-address Oct 13, 2022
996a4cc
chore: add workflow_dispatch to workflow [skip ci]
DevScyu Oct 13, 2022
2f61b71
Merge branch 'production' into development
DevScyu Oct 13, 2022
65e3e56
chore(release): v1.12.1-beta.10 [skip ci]
invalid-email-address Oct 13, 2022
e23d6e9
ci: update release workflow [skip ci]
DevScyu Oct 13, 2022
3dc3811
chore(release): v1.13.0 [skip ci]
invalid-email-address Oct 13, 2022
7f6e390
fix: Changelog and Updater bugfixing (#613)
DevScyu Oct 22, 2022
23ffe9e
chore(release): v1.13.1-beta.0 [skip ci]
invalid-email-address Oct 22, 2022
792dd46
fix: Missing Arrow Bomb cost modifiers (#617)
ryanzhoudev Oct 26, 2022
331677a
chore(release): v1.13.1-beta.1 [skip ci]
invalid-email-address Oct 26, 2022
84b3d20
fix: Guild territory list occasionally causing NPE (#618)
ryanzhoudev Oct 26, 2022
ccf071b
chore(release): v1.13.1-beta.2 [skip ci]
invalid-email-address Oct 26, 2022
a8297f9
chore(release): [RELEASE] v1.13.1 hotfix (#616)
DevScyu Oct 26, 2022
700608a
chore(release): v1.13.1 [skip ci]
invalid-email-address Oct 26, 2022
76e5bdb
feat: Tab list effect parsing (#615)
ryanzhoudev Oct 28, 2022
ce5e5e9
chore(release): v1.13.2-beta.0 [skip ci]
invalid-email-address Oct 28, 2022
312aa90
fix: improve skill point loadouts (#597)
ryanzhoudev Oct 28, 2022
b5ef00e
chore(release): v1.13.2-beta.1 [skip ci]
invalid-email-address Oct 28, 2022
be9986a
ci: update workflows [skip ci]
DevScyu Oct 28, 2022
144a62a
feat: add redirect for ability cooldowns (#624)
P0keDev Oct 29, 2022
87056c6
chore(release): v1.13.2-beta.2 [skip ci]
WynntilsBot Oct 29, 2022
4b18614
fix: Vanish timer missing, regex not detecting cooldowns, DynamicTime…
ryanzhoudev Oct 30, 2022
a180cfb
chore(release): v1.13.2-beta.3 [skip ci]
WynntilsBot Oct 30, 2022
a04e044
ci: Change to mc-publish (#631)
DevScyu Nov 2, 2022
9e86c47
ci: update to upstream action [skip ci]
DevScyu Nov 2, 2022
ab72486
ci: update github output [skip ci]
DevScyu Nov 2, 2022
028f658
chore: add logging to configs (#614)
DevScyu Nov 3, 2022
037207a
chore(release): v1.13.2-beta.4 [skip ci]
WynntilsBot Nov 3, 2022
9bf5191
ci: update github actions [skip ci]
DevScyu Nov 3, 2022
1f771b9
fix: regex for life/mana steal (#637)
ryanzhoudev Nov 14, 2022
967b45d
chore(release): v1.13.2-beta.5 [skip ci]
WynntilsBot Nov 14, 2022
edac71b
docs: update authenticating section (#623) [skip ci]
ryanzhoudev Nov 14, 2022
e5992f3
fix: Update spell cost ID ranges (#636)
P0keDev Nov 14, 2022
64fd918
chore(release): v1.13.2-beta.6 [skip ci]
WynntilsBot Nov 14, 2022
c0f2c83
ci: update github actions [skip ci]
DevScyu Nov 15, 2022
661a15f
fix: remove click to copy chat (#640)
ryanzhoudev Nov 15, 2022
a7d3aba
chore(release): v1.13.2-beta.7 [skip ci]
WynntilsBot Nov 15, 2022
1b3ff87
chore(release): v1.14.0 [skip ci]
WynntilsBot Nov 18, 2022
3d8f5c6
ci: fix workflow [skip ci]
DevScyu Nov 18, 2022
174a40a
chore(release): v1.14.0 [skip ci]
WynntilsBot Nov 18, 2022
7bac3cd
docs: Fix codeblocks not working (#638) [skip ci]
ryanzhoudev Nov 25, 2022
f790f30
feat: Switch to discord-game-sdk4j and Activity Party bug fixes. (#555)
Clashbestie Nov 25, 2022
03c9d08
chore(release): v1.14.1-beta.0 [skip ci]
WynntilsBot Nov 25, 2022
e52246f
fix: Revert feat: Switch to discord-game-sdk4j" (#647)
ryanzhoudev Nov 28, 2022
99a859c
chore(release): v1.14.1-beta.1 [skip ci]
WynntilsBot Nov 28, 2022
6aa0823
fix: Fix various ability bar bugs (#649)
ryanzhoudev Dec 8, 2022
36b2540
chore(release): v1.14.1-beta.2 [skip ci]
WynntilsBot Dec 8, 2022
26555fc
fix: update to match Wynn api (#644)
ryanzhoudev Dec 8, 2022
5739df9
chore(release): v1.14.1-beta.3 [skip ci]
WynntilsBot Dec 8, 2022
d98fd1d
fix: aioob in ChatManager (#643)
ryanzhoudev Dec 8, 2022
9029c6a
chore(release): v1.14.1-beta.4 [skip ci]
WynntilsBot Dec 8, 2022
c9565e1
fix: Powders & pouches not favouriting with Arabic numerals, missing …
ryanzhoudev Dec 8, 2022
4a1180d
chore(release): v1.14.1-beta.5 [skip ci]
WynntilsBot Dec 8, 2022
73bda2e
feat: add config reset button (#607)
ryanzhoudev Dec 8, 2022
10508ad
chore(release): v1.14.1-beta.6 [skip ci]
WynntilsBot Dec 8, 2022
c056dc5
ci: fix workflow [skip ci]
DevScyu Dec 9, 2022
df999ea
fix: Startup crash (#653)
ryanzhoudev Jan 3, 2023
550a9e5
chore(release): v1.14.1-beta.7 [skip ci]
WynntilsBot Jan 3, 2023
37ef9db
fix: Initial guild info message not being detected (#652)
ryanzhoudev Jan 19, 2023
ad73608
chore(release): v1.14.1-beta.8 [skip ci]
WynntilsBot Jan 19, 2023
57384b5
fix: remove bank page confirms (#656)
ryanzhoudev Jan 19, 2023
fa3d93b
chore(release): v1.14.1-beta.9 [skip ci]
WynntilsBot Jan 19, 2023
4bc8bbd
fix: proper icon fix (#655)
ryanzhoudev Jan 19, 2023
6829365
chore(release): v1.14.1-beta.10 [skip ci]
WynntilsBot Jan 19, 2023
b212e7d
fix: Mythic detection fix (#650)
ryanzhoudev Jan 25, 2023
b5f2491
chore(release): v1.14.1-beta.11 [skip ci]
WynntilsBot Jan 25, 2023
9a6c76b
fix: Fix crash on housing island (#663)
kristofbolyai Feb 15, 2023
e01d953
chore(release): v1.14.1-beta.12 [skip ci]
WynntilsBot Feb 15, 2023
374e255
fix: Prevent custom seaskipper menu crash (#664)
P0keDev Feb 17, 2023
a4520df
chore(release): v1.14.1-beta.13 [skip ci]
WynntilsBot Feb 17, 2023
c5b509d
feat: Remove support for stable update stream (#667)
P0keDev Feb 20, 2023
24703b1
chore(release): v1.14.1-beta.14 [skip ci]
WynntilsBot Feb 20, 2023
1a93a1e
chore(release): v1.15.0 [skip ci]
WynntilsBot Feb 21, 2023
f97f5ad
fix: Fix party finder crash on housing island (#669)
ENORMOUZ Apr 1, 2023
d60803c
chore(release): v1.15.1-beta.0 [skip ci]
WynntilsBot Apr 1, 2023
1ea89ce
feat: Add Artemis export button for waypoint manager GUI (#673)
kristofbolyai Apr 1, 2023
bf060a2
chore(release): v1.15.1-beta.1 [skip ci]
WynntilsBot Apr 1, 2023
cc98eb1
fix: The mod can now load Artemis (1.19.3) lootruns (#675)
kristofbolyai Apr 17, 2023
28538a3
chore(release): v1.15.1-beta.2 [skip ci]
WynntilsBot Apr 17, 2023
8a295f0
feat: Add K and M to convertEmeraldPrice (#661)
ENORMOUZ May 16, 2023
ffab244
chore(release): v1.15.1-beta.3 [skip ci]
WynntilsBot May 16, 2023
b9d15f5
chore: Remove broken quest book (#679)
ryanzhoudev Jul 18, 2023
b0e0d5b
chore(release): v1.15.1-beta.4 [skip ci]
WynntilsBot Jul 18, 2023
103a8b8
feat: Export favorites via command (#681)
ryanzhoudev Jul 24, 2023
1677480
chore(release): v1.15.1-beta.5 [skip ci]
WynntilsBot Jul 24, 2023
46408de
fix: Fixed TAB_EFFECT_PATTERN regex (#686)
ENORMOUZ Aug 12, 2023
71bf7fe
chore(release): v1.15.1-beta.6 [skip ci]
WynntilsBot Aug 12, 2023
e5cc971
fix: Fix Guild Map Crashing (#689)
ENORMOUZ Sep 13, 2023
f28c584
chore(release): v1.15.1-beta.7 [skip ci]
WynntilsBot Sep 13, 2023
76ed2da
fix: Fixed chat crash bug (#687)
ENORMOUZ Sep 15, 2023
0228ef2
chore(release): v1.15.1-beta.8 [skip ci]
WynntilsBot Sep 15, 2023
590726f
fix: do not crash with broken chat mention regex (#677)
ryanzhoudev Sep 16, 2023
5da7e73
chore(release): v1.15.1-beta.9 [skip ci]
WynntilsBot Sep 16, 2023
93739e0
Update issue templates
magicus Sep 16, 2023
94ce153
feat: Export favorites and waypoints from main menu (#696)
ShadowCat117 Nov 18, 2023
2f9e05b
chore(release): v1.15.1-beta.10 [skip ci]
WynntilsBot Nov 18, 2023
f22df6d
Update README.md
DevScyu Jan 21, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
feat: add currently active shaman mask display (Wynntils#577)
* feat: add current mask overlay

* fix: refactor, fix location

* fix: mask not resetting correctly if only one mask ability is equipped

* fix: add option to change display text for each mask individually

* fix: implement reviews

* fix: change the tabulation

* fix: simplify mask detection

* fix: add spaces after `ìf`

* fix: save the current shaman mask in `CharacterData.java` instead of in `CurrentMaskOverlay.java`

* fix: extract mask parsing from CurrentMaskOverlay to OverlayEvents

* add empty line at the end of the file

Co-authored-by: byBackfish <maik@bybackifsh.de>
Co-authored-by: Magnus Ihse Bursie <mag@icus.se>
Co-authored-by: Kristof Kovacs <49001742+kristofbolyai@users.noreply.github.com>
Co-authored-by: Ryan <57310593+DonkeyBlaster@users.noreply.github.com>
  • Loading branch information
5 people authored Sep 21, 2022
commit 4cdd204fb6d7800adcb2b7bf2b4fbe014412a7e4
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
import com.wynntils.core.framework.instances.containers.PlayerData;
import com.wynntils.modules.core.CoreModule;
import com.wynntils.modules.core.config.CoreDBConfig;
import com.wynntils.modules.utilities.instances.ShamanMaskType;
import net.minecraft.client.entity.EntityPlayerSP;

import java.text.DecimalFormat;
Expand Down Expand Up @@ -37,6 +38,7 @@ public class CharacterData extends PlayerData {
private int level = -1;
private float experiencePercentage = -1;
private String elementalSpecialString = "";
private ShamanMaskType currentShamanMask = ShamanMaskType.NONE;

int lastLevel = 0;
int lastXp = 0;
Expand Down Expand Up @@ -169,6 +171,8 @@ public boolean isReskinned() {
return reskinned;
}

public ShamanMaskType getCurrentShamanMask() { return currentShamanMask; }

public void setClassId(int id) {
this.classId = id;

Expand Down Expand Up @@ -228,4 +232,7 @@ public void setExperiencePercentage(float experiencePercentage) {
this.experiencePercentage = experiencePercentage;
}

public void setCurrentShamanMask(ShamanMaskType currentShamanMask) {
this.currentShamanMask = currentShamanMask;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@
import com.wynntils.modules.core.overlays.inventories.InventoryReplacer;
import com.wynntils.modules.utilities.UtilitiesModule;
import com.wynntils.modules.utilities.configs.OverlayConfig;
import com.wynntils.modules.utilities.instances.ShamanMaskType;
import com.wynntils.modules.utilities.managers.KillsManager;
import com.wynntils.modules.utilities.managers.LevelingManager;
import com.wynntils.modules.utilities.managers.QuickCastManager;
Expand Down Expand Up @@ -596,6 +597,7 @@ public void onClassChange(WynnClassChangeEvent e) {
// Reset blood pools if class changes
get(CharacterData.class).setMaxBloodPool(-1);
get(CharacterData.class).setBloodPool(-1);
get(CharacterData.class).setCurrentShamanMask(ShamanMaskType.NONE);
get(CharacterData.class).setAwakenedProgress(-1);

// Reset mana bank
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ public class UtilitiesModule extends Module {
private GameUpdateOverlay gameUpdateOverlay;
private ActionBarOverlay actionBarOverlay;
private InfoFormatter infoFormatter;
private CurrentMaskOverlay currentMaskOverlay;

public void onEnable() {
module = this;
Expand Down Expand Up @@ -71,6 +72,7 @@ public void onEnable() {
registerOverlay(new AwakenedProgressBarOverlay(), Priority.NORMAL);
registerOverlay(new FocusBarOverlay(), Priority.NORMAL);
registerOverlay(new ExpBarOverlay(), Priority.NORMAL);
registerOverlay(currentMaskOverlay = new CurrentMaskOverlay(), Priority.NORMAL);
registerOverlay(new LevelingOverlay(), Priority.LOW);
registerOverlay(new BubblesOverlay(), Priority.HIGHEST);
registerOverlay(new DrowningVignetteOverlay(), Priority.HIGHEST);
Expand Down Expand Up @@ -115,6 +117,7 @@ public void onEnable() {
registerSettings(OverlayConfig.BloodPool.class);
registerSettings(OverlayConfig.ManaBank.class);
registerSettings(OverlayConfig.AwakenedProgress.class);
registerSettings(OverlayConfig.MaskOverlay.class);
registerSettings(OverlayConfig.Focus.class);
registerSettings(OverlayConfig.Hotbar.class);
registerSettings(OverlayConfig.ToastsSettings.class);
Expand Down Expand Up @@ -146,6 +149,10 @@ public ActionBarOverlay getActionBarOverlay() {
return actionBarOverlay;
}

public CurrentMaskOverlay getCurrentMaskOverlay() {
return currentMaskOverlay;
}

public InfoFormatter getInfoFormatter() {
return infoFormatter;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -255,6 +255,32 @@ public enum AwakenedProgressTexture {
}
}

@SettingsInfo(name = "current_mask_overlay", displayPath = "Utilities/Overlays/Mask")
public static class MaskOverlay extends SettingsClass {
public static MaskOverlay INSTANCE;

@Setting(displayName = "No mask display string", description = "What text should be displayed if no mask is applied? Color will be automatically applied. Use %mask% to display the mask name.")
public String displayStringNone = "No mask equipped";

@Setting(displayName = "Lunatic display string", description = "What text should be displayed if the Lunatic mask is applied? Color will be automatically applied. Use %mask% to display the mask name.")
public String displayStringLunatic = "%mask% mask equipped";

@Setting(displayName = "Fanatic display string", description = "What text should be displayed if the Fanatic mask is applied? Color will be automatically applied. Use %mask% to display the mask name.")
public String displayStringFanatic = "%mask% mask equipped";

@Setting(displayName = "Coward display string", description = "What text should be displayed if the Coward mask is applied? Color will be automatically applied. Use %mask% to display the mask name.")
public String displayStringCoward = "%mask% mask equipped";

@Setting(displayName = "Awakened display string", description = "What text should be displayed if the Awakened mask is applied? Color will be automatically applied. Use %mask% to display the mask name.")
public String displayStringAwakened = "%mask% mask equipped";

@Setting(displayName = "Hide Default Mask Title", description = "Should the mask switching title be hidden?")
public boolean hideSwitchingTitle = true;

@Setting(displayName = "Text Shadow", description = "What should the text shadow look like?")
public SmartFontRenderer.TextShadow textShadow = SmartFontRenderer.TextShadow.OUTLINE;
}

@SettingsInfo(name = "focus_bar", displayPath = "Utilities/Overlays/Focus")
public static class Focus extends SettingsClass {
public static Focus INSTANCE;
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
package com.wynntils.modules.utilities.instances;

import com.wynntils.modules.utilities.configs.OverlayConfig;
import net.minecraft.util.text.TextFormatting;

import java.util.function.Supplier;

public enum ShamanMaskType {

NONE("None", TextFormatting.GRAY, "None", () -> OverlayConfig.MaskOverlay.INSTANCE.displayStringNone),
LUNATIC("L", TextFormatting.RED, "Lunatic", () -> OverlayConfig.MaskOverlay.INSTANCE.displayStringLunatic),
FANATIC("F", TextFormatting.GOLD, "Fanatic", () -> OverlayConfig.MaskOverlay.INSTANCE.displayStringFanatic),
COWARD("C", TextFormatting.AQUA, "Coward", () -> OverlayConfig.MaskOverlay.INSTANCE.displayStringCoward),
AWAKENED("A", TextFormatting.DARK_PURPLE, "Awakened", () -> OverlayConfig.MaskOverlay.INSTANCE.displayStringAwakened);

private final String alias;
private final TextFormatting color;
private final String name;
private final Supplier<String> display;

ShamanMaskType(String alias, TextFormatting color, String name, Supplier<String> display) {
this.alias = alias;
this.color = color;
this.name = name;
this.display = display;
}

public static ShamanMaskType find(String text) {
for(ShamanMaskType type : values()) {
if (type.alias.equals(text) || type.name.equals(text)) return type;
}
return NONE;
}

public String getText() {
return display.get().replace("%mask%", name).replace("&", "§");
}

public TextFormatting getColor() { return color; }
}
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
import com.wynntils.core.utils.reference.EmeraldSymbols;
import com.wynntils.modules.utilities.UtilitiesModule;
import com.wynntils.modules.utilities.configs.OverlayConfig;
import com.wynntils.modules.utilities.instances.ShamanMaskType;
import com.wynntils.modules.utilities.instances.Toast;
import com.wynntils.modules.utilities.managers.MountHorseManager;
import com.wynntils.modules.utilities.overlays.hud.*;
Expand Down Expand Up @@ -49,6 +50,7 @@ public class OverlayEvents implements Listener {
private static final Pattern CHEST_COOLDOWN_PATTERN = Pattern.compile("§7Please wait an additional ([0-9]+) minutes? before opening this chest.");
private static final Pattern GATHERING_COOLDOWN_PATTERN = Pattern.compile("^You need to wait ([0-9]+) seconds after logging in to gather from this resource!");
private static final Pattern SERVER_RESTART_PATTERN = Pattern.compile("§cThis world will restart in ([0-9]+) (minutes?|seconds?)\\.");
private static final Pattern MASK_PATTERN = Pattern.compile("§cMask of the (Coward|Lunatic|Fanatic)§r");

//private static boolean wynnExpTimestampNotified = false;
private long loginTime;
Expand All @@ -70,7 +72,29 @@ public void onWorldJoin(WynnWorldEvent.Join e) {

@SubscribeEvent
public void onTitle(PacketEvent<SPacketTitle> e) {
if (e.getPacket() == null || e.getPacket().getMessage() == null) return;

WarTimerOverlay.onTitle(e);

String title = e.getPacket().getMessage().getFormattedText();
if (title.contains("Mask of the ") || title.contains("➤")) {
parseMask(title);
if (OverlayConfig.MaskOverlay.INSTANCE.hideSwitchingTitle) e.setCanceled(true);
}
}

private void parseMask(String title) {
Matcher matcher = MASK_PATTERN.matcher(title);

ShamanMaskType currentMask = ShamanMaskType.NONE;
if(title.contains("Awakened")) currentMask = ShamanMaskType.AWAKENED;
else if (title.contains("§cL")) currentMask = ShamanMaskType.LUNATIC;
else if (title.contains("§6F")) currentMask = ShamanMaskType.FANATIC;
else if (title.contains("§bC")) currentMask = ShamanMaskType.COWARD;
else if (title.startsWith("§8")) currentMask = ShamanMaskType.NONE;
else if (matcher.matches()) currentMask = ShamanMaskType.find(matcher.group(1));

PlayerInfo.get(CharacterData.class).setCurrentShamanMask(currentMask);
}

@SubscribeEvent
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
package com.wynntils.modules.utilities.overlays.hud;

import com.wynntils.core.framework.enums.ClassType;
import com.wynntils.core.framework.instances.data.CharacterData;
import com.wynntils.core.framework.overlays.Overlay;
import com.wynntils.core.framework.rendering.SmartFontRenderer;
import com.wynntils.core.framework.rendering.colors.CustomColor;
import com.wynntils.core.framework.settings.annotations.Setting;
import com.wynntils.core.utils.objects.Pair;
import com.wynntils.modules.utilities.configs.OverlayConfig;
import com.wynntils.modules.utilities.instances.ShamanMaskType;
import net.minecraftforge.client.event.RenderGameOverlayEvent;

public class CurrentMaskOverlay extends Overlay {
public CurrentMaskOverlay() {
super("Current Shaman Mask Display", 66, 10, true, 0.66f, 1f, -10, -38, OverlayGrowFrom.BOTTOM_RIGHT);
}

@Setting(displayName = "Text Position", description = "The position offset of the text")
public Pair<Integer, Integer> textPositionOffset = new Pair<>(-40, -10);

@Override
public void render(RenderGameOverlayEvent.Pre event) {
if (!visible) return;
if (get(CharacterData.class).getCurrentClass() != ClassType.SHAMAN) return;
ShamanMaskType currentMask = get(CharacterData.class).getCurrentShamanMask();
String text = currentMask.getText();
drawString(text, textPositionOffset.a, textPositionOffset.b, CustomColor.fromTextFormatting(currentMask.getColor()), SmartFontRenderer.TextAlignment.MIDDLE, OverlayConfig.MaskOverlay.INSTANCE.textShadow);
}

}