From 7b7d13ede25aa3022cfbd03763ca9ee82ca12656 Mon Sep 17 00:00:00 2001 From: syeyoung Date: Sat, 18 Dec 2021 17:02:41 +0900 Subject: - Suggestion 353 --- .../features/impl/party/FeaturePartyReady.java | 48 ++++++++++++++++------ 1 file changed, 36 insertions(+), 12 deletions(-) (limited to 'src/main/java/kr/syeyoung') diff --git a/src/main/java/kr/syeyoung/dungeonsguide/features/impl/party/FeaturePartyReady.java b/src/main/java/kr/syeyoung/dungeonsguide/features/impl/party/FeaturePartyReady.java index 526ca37a..51285ed9 100644 --- a/src/main/java/kr/syeyoung/dungeonsguide/features/impl/party/FeaturePartyReady.java +++ b/src/main/java/kr/syeyoung/dungeonsguide/features/impl/party/FeaturePartyReady.java @@ -39,7 +39,8 @@ public class FeaturePartyReady extends TextHUDFeature implements ChatListener, D getStyles().add(new TextStyle("player", new AColor(0x00, 0xAA,0xAA,255), new AColor(0, 0,0,0), false)); getStyles().add(new TextStyle("separator", new AColor(0x55, 0x55,0x55,255), new AColor(0, 0,0,0), false)); getStyles().add(new TextStyle("ready", new AColor(0x55, 0xFF,0xFF,255), new AColor(0, 0,0,0), false)); - getStyles().add(new TextStyle("notready", new AColor(0x55, 0xFF,0xFF,255), new AColor(0, 0,0,0), false)); + getStyles().add(new TextStyle("notready", new AColor(0xFF, 0x55,0x55,255), new AColor(0, 0,0,0), false)); + getStyles().add(new TextStyle("terminal", new AColor(0x55, 0xFF,0xFF,255), new AColor(0, 0,0,0), false)); setEnabled(true); } @@ -50,7 +51,7 @@ public class FeaturePartyReady extends TextHUDFeature implements ChatListener, D @Override public List getUsedTextStyle() { - return Arrays.asList("name" ,"separator", "player", "allinvite"); + return Arrays.asList("separator", "player", "ready", "notready", "terminal"); } private static final List dummyText = new ArrayList(); @@ -58,18 +59,23 @@ public class FeaturePartyReady extends TextHUDFeature implements ChatListener, D dummyText.add(new StyledText("syeyoung","player")); dummyText.add(new StyledText(": ","separator")); dummyText.add(new StyledText("Ready","ready")); + dummyText.add(new StyledText(" 4","terminal")); dummyText.add(new StyledText("\nrioho","player")); dummyText.add(new StyledText(": ","separator")); dummyText.add(new StyledText("Ready","ready")); + dummyText.add(new StyledText(" 3","terminal")); dummyText.add(new StyledText("\nRaidShadowLegends","player")); dummyText.add(new StyledText(": ","separator")); dummyText.add(new StyledText("Not Ready","notready")); + dummyText.add(new StyledText(" 2t","terminal")); dummyText.add(new StyledText("\nTricked","player")); dummyText.add(new StyledText(": ","separator")); dummyText.add(new StyledText("Ready","ready")); + dummyText.add(new StyledText(" ss","terminal")); dummyText.add(new StyledText("\nMr. Penguin","player")); dummyText.add(new StyledText(": ","separator")); dummyText.add(new StyledText("Not Ready","notready")); + dummyText.add(new StyledText(" 2b","terminal")); } @Override @@ -83,6 +89,7 @@ public class FeaturePartyReady extends TextHUDFeature implements ChatListener, D } private Set ready = new TreeSet<>(String.CASE_INSENSITIVE_ORDER); + private Map terminal = new TreeMap<>(String.CASE_INSENSITIVE_ORDER); @Override public List getText() { @@ -96,6 +103,9 @@ public class FeaturePartyReady extends TextHUDFeature implements ChatListener, D text.add(new StyledText("Ready","ready")); else text.add(new StyledText("Not Ready","notready")); + if (terminal.get(partyRawMember) != null) { + text.add(new StyledText(" "+ terminal.get(partyRawMember), "terminal")); + } first =false; } return text; @@ -103,6 +113,7 @@ public class FeaturePartyReady extends TextHUDFeature implements ChatListener, D private static final List readyPhrase = Arrays.asList("r", "rdy", "ready"); private static final List negator = Arrays.asList("not ", "not", "n", "n "); + private static final List terminalPhrase = Arrays.asList("ss", "s1", "1", "2b", "2t", "3", "4", "s3", "s4", "s2", "2"); private static final Map readynessIndicator = new HashMap<>(); static { readyPhrase.forEach(val -> readynessIndicator.put(val, true)); @@ -125,6 +136,18 @@ public class FeaturePartyReady extends TextHUDFeature implements ChatListener, D String chat = TextUtils.stripColor(txt.substring(txt.indexOf(":")+1)).trim().toLowerCase(); + + + String usernamearea = TextUtils.stripColor(txt.substring(13, txt.indexOf(":"))); + String username = null; + for (String s : usernamearea.split(" ")) { + if (s.isEmpty()) continue; + if (s.startsWith("[")) continue; + username = s; + break; + } + + Boolean status = null; String longestMatch = ""; for (Map.Entry stringBooleanEntry : readynessIndicator.entrySet()) { @@ -135,23 +158,24 @@ public class FeaturePartyReady extends TextHUDFeature implements ChatListener, D } } } - if (status == null) return; + if (status == null); + else if (status) ready.add(username); + else ready.remove(username); - String usernamearea = TextUtils.stripColor(txt.substring(13, txt.indexOf(":"))); - String username = null; - for (String s : usernamearea.split(" ")) { - if (s.isEmpty()) continue; - if (s.startsWith("[")) continue; - username = s; - break; + String term = ""; + for (String s : terminalPhrase) { + if (chat.equals(s) || chat.startsWith(s+" ") || chat.endsWith(" "+s) || chat.contains(" "+s+" ")) { + term += s+" "; + } } - if (status) ready.add(username); - else ready.remove(username); + if (!term.isEmpty()) + terminal.put(username, term); } @Override public void onDungeonStart() { ready.clear(); + terminal.clear(); } } -- cgit