clues: highlight the last clue's STASH until items are deposited back

This commit is contained in:
Hydrox6
2021-04-26 13:49:36 +01:00
committed by Adam
parent 94685b6ef4
commit aa44339769
4 changed files with 93 additions and 3 deletions

View File

@@ -217,6 +217,10 @@ public class ClueScrollPlugin extends Plugin
private final TextComponent textComponent = new TextComponent(); private final TextComponent textComponent = new TextComponent();
@Getter
private EmoteClue activeSTASHClue;
private EmoteClue clickedSTASHClue;
@Provides @Provides
ClueScrollConfig getConfig(ConfigManager configManager) ClueScrollConfig getConfig(ConfigManager configManager)
{ {
@@ -264,9 +268,11 @@ public class ClueScrollPlugin extends Plugin
return; return;
} }
String message = event.getMessage();
if (clue instanceof HotColdClue) if (clue instanceof HotColdClue)
{ {
if (((HotColdClue) clue).update(event.getMessage(), this)) if (((HotColdClue) clue).update(message, this))
{ {
worldMapPointsSet = false; worldMapPointsSet = false;
} }
@@ -274,7 +280,7 @@ public class ClueScrollPlugin extends Plugin
if (clue instanceof SkillChallengeClue) if (clue instanceof SkillChallengeClue)
{ {
String text = Text.removeTags(event.getMessage()); String text = Text.removeTags(message);
if (text.equals("Skill challenge completed.") || if (text.equals("Skill challenge completed.") ||
text.equals("You have completed your master level challenge!") || text.equals("You have completed your master level challenge!") ||
text.startsWith("You have completed Charlie's task,") || text.startsWith("You have completed Charlie's task,") ||
@@ -283,6 +289,19 @@ public class ClueScrollPlugin extends Plugin
((SkillChallengeClue) clue).setChallengeCompleted(true); ((SkillChallengeClue) clue).setChallengeCompleted(true);
} }
} }
if (message.endsWith(" the STASH unit."))
{
if (clue instanceof EmoteClue && clickedSTASHClue != null && message.equals("You withdraw your items from the STASH unit."))
{
activeSTASHClue = clickedSTASHClue;
}
else if (message.equals("You deposit your items into the STASH unit."))
{
activeSTASHClue = null;
}
clickedSTASHClue = null;
}
} }
@Subscribe @Subscribe
@@ -300,7 +319,11 @@ public class ClueScrollPlugin extends Plugin
@Subscribe @Subscribe
public void onMenuOptionClicked(final MenuOptionClicked event) public void onMenuOptionClicked(final MenuOptionClicked event)
{ {
if (event.getMenuOption() != null && event.getMenuOption().equals("Read")) if (event.getMenuOption() == null)
{
return;
}
if (event.getMenuOption().equals("Read"))
{ {
final ItemComposition itemComposition = itemManager.getItemComposition(event.getId()); final ItemComposition itemComposition = itemManager.getItemComposition(event.getId());
@@ -310,6 +333,14 @@ public class ClueScrollPlugin extends Plugin
updateClue(MapClue.forItemId(clueItemId)); updateClue(MapClue.forItemId(clueItemId));
} }
} }
else if (event.getMenuOption().equals("Search") && clue instanceof EmoteClue)
{
EmoteClue emoteClue = (EmoteClue) clue;
if (emoteClue.getStashUnit() != null && emoteClue.getStashUnit().getObjectId() == event.getId())
{
clickedSTASHClue = emoteClue;
}
}
} }
@Subscribe @Subscribe

View File

@@ -29,6 +29,7 @@ import java.awt.Dimension;
import java.awt.Graphics2D; import java.awt.Graphics2D;
import javax.inject.Inject; import javax.inject.Inject;
import net.runelite.client.plugins.cluescrolls.clues.ClueScroll; import net.runelite.client.plugins.cluescrolls.clues.ClueScroll;
import net.runelite.client.plugins.cluescrolls.clues.EmoteClue;
import net.runelite.client.ui.overlay.Overlay; import net.runelite.client.ui.overlay.Overlay;
import net.runelite.client.ui.overlay.OverlayLayer; import net.runelite.client.ui.overlay.OverlayLayer;
import net.runelite.client.ui.overlay.OverlayPosition; import net.runelite.client.ui.overlay.OverlayPosition;
@@ -61,6 +62,12 @@ public class ClueScrollWorldOverlay extends Overlay
clue.makeWorldOverlayHint(graphics, plugin); clue.makeWorldOverlayHint(graphics, plugin);
} }
EmoteClue activeSTASHClue = plugin.getActiveSTASHClue();
if (activeSTASHClue != null && activeSTASHClue != clue)
{
activeSTASHClue.makeSTASHOverlay(graphics, plugin);
}
return null; return null;
} }
} }

View File

@@ -311,6 +311,11 @@ public class EmoteClue extends ClueScroll implements TextClueScroll, LocationClu
OverlayUtil.renderTileOverlay(plugin.getClient(), graphics, localPoint, plugin.getEmoteImage(), Color.ORANGE); OverlayUtil.renderTileOverlay(plugin.getClient(), graphics, localPoint, plugin.getEmoteImage(), Color.ORANGE);
} }
makeSTASHOverlay(graphics, plugin);
}
public void makeSTASHOverlay(Graphics2D graphics, ClueScrollPlugin plugin)
{
if (stashUnit != null) if (stashUnit != null)
{ {
final WorldPoint[] worldPoints = stashUnit.getWorldPoints(); final WorldPoint[] worldPoints = stashUnit.getWorldPoints();

View File

@@ -33,10 +33,12 @@ import com.google.inject.testing.fieldbinder.BoundFieldModule;
import net.runelite.api.ChatMessageType; import net.runelite.api.ChatMessageType;
import net.runelite.api.Client; import net.runelite.api.Client;
import net.runelite.api.NPC; import net.runelite.api.NPC;
import net.runelite.api.NullObjectID;
import net.runelite.api.Player; import net.runelite.api.Player;
import net.runelite.api.coords.WorldPoint; import net.runelite.api.coords.WorldPoint;
import net.runelite.api.events.ChatMessage; import net.runelite.api.events.ChatMessage;
import net.runelite.api.events.GameTick; import net.runelite.api.events.GameTick;
import net.runelite.api.events.MenuOptionClicked;
import net.runelite.api.widgets.Widget; import net.runelite.api.widgets.Widget;
import net.runelite.api.widgets.WidgetInfo; import net.runelite.api.widgets.WidgetInfo;
import net.runelite.client.game.ItemManager; import net.runelite.client.game.ItemManager;
@@ -45,6 +47,8 @@ import net.runelite.client.plugins.cluescrolls.clues.hotcold.HotColdLocation;
import net.runelite.client.ui.overlay.OverlayManager; import net.runelite.client.ui.overlay.OverlayManager;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotEquals; import static org.junit.Assert.assertNotEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
@@ -168,4 +172,47 @@ public class ClueScrollPluginTest
verify(client, times(++clueSetupHintArrowClears)).clearHintArrow(); verify(client, times(++clueSetupHintArrowClears)).clearHintArrow();
verify(client, times(1)).setHintArrow(any(WorldPoint.class)); verify(client, times(1)).setHintArrow(any(WorldPoint.class));
} }
@Test
public void testSTASHMarkerPersistence()
{
when(client.getCachedNPCs()).thenReturn(new NPC[] {});
// Set up emote clue
final Widget clueWidget = mock(Widget.class);
when(clueWidget.getText()).thenReturn("Spin in the Varrock Castle courtyard. Equip a black axe, a coif and a ruby ring.");
when(client.getWidget(WidgetInfo.CLUE_SCROLL_TEXT)).thenReturn(clueWidget);
plugin.onGameTick(new GameTick());
// Simulate clicking on the STASH
MenuOptionClicked menuOptionClicked = new MenuOptionClicked();
menuOptionClicked.setMenuOption("Search");
menuOptionClicked.setMenuTarget("<col=ffff>STASH unit (easy)");
menuOptionClicked.setId(NullObjectID.NULL_28983);
plugin.onMenuOptionClicked(menuOptionClicked);
// Check that the STASH is stored after withdrawing
ChatMessage withdrawMessage = new ChatMessage();
withdrawMessage.setType(ChatMessageType.GAMEMESSAGE);
withdrawMessage.setMessage("You withdraw your items from the STASH unit.");
plugin.onChatMessage(withdrawMessage);
assertNotNull(plugin.getActiveSTASHClue());
// Complete the step and get a new step, check that the clue is stored for rendering
when(clueWidget.getText()).thenReturn("Talk to the bartender of the Rusty Anchor in Port Sarim.");
plugin.onGameTick(new GameTick());
assertNotNull(plugin.getActiveSTASHClue());
// Simulate depositing the emote items, make sure it's cleared the stored clue
ChatMessage depositMessage = new ChatMessage();
depositMessage.setType(ChatMessageType.GAMEMESSAGE);
depositMessage.setMessage("You deposit your items into the STASH unit.");
plugin.onChatMessage(depositMessage);
assertNull(plugin.getActiveSTASHClue());
// Make sure that the STASH won't get re-marked if it's not part of the active clue.
plugin.onMenuOptionClicked(menuOptionClicked);
plugin.onChatMessage(withdrawMessage);
assertNull(plugin.getActiveSTASHClue());
}
} }