Use leagues hiscores for seasonal worlds

This commit is contained in:
Adam
2022-01-05 15:57:00 -05:00
parent 0abe846028
commit 238b35e8f8
5 changed files with 31 additions and 34 deletions

View File

@@ -25,7 +25,9 @@
*/ */
package net.runelite.client.hiscore; package net.runelite.client.hiscore;
import java.util.Set;
import lombok.Getter; import lombok.Getter;
import net.runelite.api.WorldType;
import okhttp3.HttpUrl; import okhttp3.HttpUrl;
@Getter @Getter
@@ -47,4 +49,21 @@ public enum HiscoreEndpoint
this.name = name; this.name = name;
this.hiscoreURL = HttpUrl.get(hiscoreURL); this.hiscoreURL = HttpUrl.get(hiscoreURL);
} }
public static HiscoreEndpoint fromWorldTypes(Set<WorldType> worldTypes)
{
if (worldTypes.contains(WorldType.SEASONAL))
{
// this changes between LEAGUE and TOURNAMENT
return HiscoreEndpoint.LEAGUE;
}
else if (worldTypes.contains(WorldType.DEADMAN))
{
return HiscoreEndpoint.DEADMAN;
}
else
{
return HiscoreEndpoint.NORMAL;
}
}
} }

View File

@@ -1740,9 +1740,10 @@ public class ChatCommandsPlugin extends Plugin
if (chatMessage.getType() == ChatMessageType.PUBLICCHAT || chatMessage.getType() == ChatMessageType.MODCHAT) if (chatMessage.getType() == ChatMessageType.PUBLICCHAT || chatMessage.getType() == ChatMessageType.MODCHAT)
{ {
// Public chat on a seasonal world is always seasonal or tournament hiscores, regardless of icon // Public chat on a seasonal world is always seasonal or tournament hiscores, regardless of icon
if (client.getWorldType().contains(WorldType.SEASONAL)) HiscoreEndpoint endpoint = HiscoreEndpoint.fromWorldTypes(client.getWorldType());
if (endpoint != HiscoreEndpoint.NORMAL)
{ {
return new HiscoreLookup(player, HiscoreEndpoint.TOURNAMENT); return new HiscoreLookup(player, endpoint);
} }
} }
@@ -1788,9 +1789,11 @@ public class ChatCommandsPlugin extends Plugin
private HiscoreEndpoint getLocalHiscoreEndpointType() private HiscoreEndpoint getLocalHiscoreEndpointType()
{ {
EnumSet<WorldType> worldType = client.getWorldType(); EnumSet<WorldType> worldType = client.getWorldType();
if (worldType.contains(WorldType.SEASONAL)) HiscoreEndpoint endpoint = HiscoreEndpoint.fromWorldTypes(worldType);
if (endpoint != HiscoreEndpoint.NORMAL)
{ {
return HiscoreEndpoint.TOURNAMENT; // leagues/dmmt or dmm
return endpoint;
} }
return toEndPoint(client.getAccountType()); return toEndPoint(client.getAccountType());

View File

@@ -26,7 +26,6 @@ package net.runelite.client.plugins.hiscore;
import com.google.inject.Provides; import com.google.inject.Provides;
import java.awt.image.BufferedImage; import java.awt.image.BufferedImage;
import java.util.EnumSet;
import java.util.regex.Matcher; import java.util.regex.Matcher;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import javax.annotation.Nullable; import javax.annotation.Nullable;
@@ -39,7 +38,6 @@ import net.runelite.api.Client;
import net.runelite.api.IconID; import net.runelite.api.IconID;
import net.runelite.api.MenuAction; import net.runelite.api.MenuAction;
import net.runelite.api.Player; import net.runelite.api.Player;
import net.runelite.api.WorldType;
import net.runelite.api.events.ChatMessage; import net.runelite.api.events.ChatMessage;
import net.runelite.api.events.MenuEntryAdded; import net.runelite.api.events.MenuEntryAdded;
import net.runelite.api.events.MenuOptionClicked; import net.runelite.api.events.MenuOptionClicked;
@@ -49,6 +47,7 @@ import net.runelite.api.widgets.WidgetInfo;
import net.runelite.client.config.ConfigManager; import net.runelite.client.config.ConfigManager;
import net.runelite.client.eventbus.Subscribe; import net.runelite.client.eventbus.Subscribe;
import net.runelite.client.events.ConfigChanged; import net.runelite.client.events.ConfigChanged;
import net.runelite.client.hiscore.HiscoreEndpoint;
import net.runelite.client.menus.MenuManager; import net.runelite.client.menus.MenuManager;
import net.runelite.client.plugins.Plugin; import net.runelite.client.plugins.Plugin;
import net.runelite.client.plugins.PluginDescriptor; import net.runelite.client.plugins.PluginDescriptor;
@@ -56,7 +55,6 @@ import net.runelite.client.ui.ClientToolbar;
import net.runelite.client.ui.NavigationButton; import net.runelite.client.ui.NavigationButton;
import net.runelite.client.util.ImageUtil; import net.runelite.client.util.ImageUtil;
import net.runelite.client.util.Text; import net.runelite.client.util.Text;
import net.runelite.client.hiscore.HiscoreEndpoint;
@PluginDescriptor( @PluginDescriptor(
name = "HiScore", name = "HiScore",
@@ -240,16 +238,7 @@ public class HiscorePlugin extends Plugin
{ {
if (client != null) if (client != null)
{ {
EnumSet<WorldType> wTypes = client.getWorldType(); return HiscoreEndpoint.fromWorldTypes(client.getWorldType());
if (wTypes.contains(WorldType.SEASONAL))
{
return HiscoreEndpoint.TOURNAMENT;
}
else if (wTypes.contains(WorldType.DEADMAN))
{
return HiscoreEndpoint.DEADMAN;
}
} }
return HiscoreEndpoint.NORMAL; return HiscoreEndpoint.NORMAL;
} }

View File

@@ -487,7 +487,7 @@ public class LootTrackerPlugin extends Plugin
private Integer getLootWorldId() private Integer getLootWorldId()
{ {
// For the wiki to determine drop rates based on dmm brackets // For the wiki to determine drop rates based on dmm brackets / identify leagues drops
return client.getWorldType().contains(WorldType.SEASONAL) ? client.getWorld() : null; return client.getWorldType().contains(WorldType.SEASONAL) ? client.getWorld() : null;
} }

View File

@@ -29,7 +29,6 @@ import com.google.common.annotations.VisibleForTesting;
import com.google.inject.Provides; import com.google.inject.Provides;
import java.time.Duration; import java.time.Duration;
import java.time.Instant; import java.time.Instant;
import java.util.EnumSet;
import javax.inject.Inject; import javax.inject.Inject;
import lombok.AccessLevel; import lombok.AccessLevel;
import lombok.Getter; import lombok.Getter;
@@ -39,17 +38,16 @@ import net.runelite.api.GameState;
import net.runelite.api.MenuAction; import net.runelite.api.MenuAction;
import net.runelite.api.MenuEntry; import net.runelite.api.MenuEntry;
import net.runelite.api.NPC; import net.runelite.api.NPC;
import net.runelite.api.WorldType;
import net.runelite.api.events.GameStateChanged; import net.runelite.api.events.GameStateChanged;
import net.runelite.api.events.GameTick; import net.runelite.api.events.GameTick;
import net.runelite.api.events.InteractingChanged; import net.runelite.api.events.InteractingChanged;
import net.runelite.api.events.MenuEntryAdded; import net.runelite.api.events.MenuEntryAdded;
import net.runelite.client.config.ConfigManager; import net.runelite.client.config.ConfigManager;
import net.runelite.client.eventbus.Subscribe; import net.runelite.client.eventbus.Subscribe;
import net.runelite.client.hiscore.HiscoreEndpoint;
import net.runelite.client.plugins.Plugin; import net.runelite.client.plugins.Plugin;
import net.runelite.client.plugins.PluginDescriptor; import net.runelite.client.plugins.PluginDescriptor;
import net.runelite.client.ui.overlay.OverlayManager; import net.runelite.client.ui.overlay.OverlayManager;
import net.runelite.client.hiscore.HiscoreEndpoint;
@PluginDescriptor( @PluginDescriptor(
name = "Opponent Information", name = "Opponent Information",
@@ -115,19 +113,7 @@ public class OpponentInfoPlugin extends Plugin
return; return;
} }
final EnumSet<WorldType> worldType = client.getWorldType(); hiscoreEndpoint = HiscoreEndpoint.fromWorldTypes(client.getWorldType());
if (worldType.contains(WorldType.SEASONAL))
{
hiscoreEndpoint = HiscoreEndpoint.TOURNAMENT;
}
else if (worldType.contains(WorldType.DEADMAN))
{
hiscoreEndpoint = HiscoreEndpoint.DEADMAN;
}
else
{
hiscoreEndpoint = HiscoreEndpoint.NORMAL;
}
} }
@Subscribe @Subscribe