ground items: add Notify >= Tier

This commit is contained in:
Hydrox6
2020-05-06 11:36:45 +01:00
committed by Tomas Slusny
parent b95b30f606
commit 9f26bb67c1
3 changed files with 109 additions and 31 deletions

View File

@@ -30,6 +30,7 @@ import net.runelite.client.config.Config;
import net.runelite.client.config.ConfigGroup; import net.runelite.client.config.ConfigGroup;
import net.runelite.client.config.ConfigItem; import net.runelite.client.config.ConfigItem;
import net.runelite.client.config.Units; import net.runelite.client.config.Units;
import net.runelite.client.plugins.grounditems.config.HighlightTier;
import net.runelite.client.plugins.grounditems.config.ItemHighlightMode; import net.runelite.client.plugins.grounditems.config.ItemHighlightMode;
import net.runelite.client.plugins.grounditems.config.MenuHighlightMode; import net.runelite.client.plugins.grounditems.config.MenuHighlightMode;
import net.runelite.client.plugins.grounditems.config.PriceDisplayMode; import net.runelite.client.plugins.grounditems.config.PriceDisplayMode;
@@ -140,11 +141,22 @@ public interface GroundItemsConfig extends Config
return false; return false;
} }
@ConfigItem(
keyName = "notifyTier",
name = "Notify >= Tier",
description = "Configures what tier of highlight will cause a drop",
position = 8
)
default HighlightTier notifyTier()
{
return HighlightTier.OFF;
}
@ConfigItem( @ConfigItem(
keyName = "priceDisplayMode", keyName = "priceDisplayMode",
name = "Price Display Mode", name = "Price Display Mode",
description = "Configures what price types are shown alongside of ground item name", description = "Configures what price types are shown alongside of ground item name",
position = 8 position = 9
) )
default PriceDisplayMode priceDisplayMode() default PriceDisplayMode priceDisplayMode()
{ {
@@ -155,7 +167,7 @@ public interface GroundItemsConfig extends Config
keyName = "itemHighlightMode", keyName = "itemHighlightMode",
name = "Item Highlight Mode", name = "Item Highlight Mode",
description = "Configures how ground items will be highlighted", description = "Configures how ground items will be highlighted",
position = 9 position = 10
) )
default ItemHighlightMode itemHighlightMode() default ItemHighlightMode itemHighlightMode()
{ {
@@ -166,7 +178,7 @@ public interface GroundItemsConfig extends Config
keyName = "menuHighlightMode", keyName = "menuHighlightMode",
name = "Menu Highlight Mode", name = "Menu Highlight Mode",
description = "Configures what to highlight in right-click menu", description = "Configures what to highlight in right-click menu",
position = 10 position = 11
) )
default MenuHighlightMode menuHighlightMode() default MenuHighlightMode menuHighlightMode()
{ {
@@ -177,7 +189,7 @@ public interface GroundItemsConfig extends Config
keyName = "highlightValueCalculation", keyName = "highlightValueCalculation",
name = "Highlight Value Calculation", name = "Highlight Value Calculation",
description = "Configures which coin value is used to determine highlight color", description = "Configures which coin value is used to determine highlight color",
position = 11 position = 12
) )
default ValueCalculationMode valueCalculationMode() default ValueCalculationMode valueCalculationMode()
{ {

View File

@@ -32,6 +32,7 @@ import com.google.common.collect.ImmutableList;
import com.google.inject.Provides; import com.google.inject.Provides;
import java.awt.Color; import java.awt.Color;
import java.awt.Rectangle; import java.awt.Rectangle;
import static java.lang.Boolean.FALSE;
import static java.lang.Boolean.TRUE; import static java.lang.Boolean.TRUE;
import java.time.Instant; import java.time.Instant;
import java.util.ArrayList; import java.util.ArrayList;
@@ -80,12 +81,12 @@ import net.runelite.client.input.KeyManager;
import net.runelite.client.input.MouseManager; import net.runelite.client.input.MouseManager;
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.plugins.grounditems.config.HighlightTier;
import static net.runelite.client.plugins.grounditems.config.ItemHighlightMode.OVERLAY; import static net.runelite.client.plugins.grounditems.config.ItemHighlightMode.OVERLAY;
import net.runelite.client.plugins.grounditems.config.MenuHighlightMode; import net.runelite.client.plugins.grounditems.config.MenuHighlightMode;
import static net.runelite.client.plugins.grounditems.config.MenuHighlightMode.BOTH; import static net.runelite.client.plugins.grounditems.config.MenuHighlightMode.BOTH;
import static net.runelite.client.plugins.grounditems.config.MenuHighlightMode.NAME; import static net.runelite.client.plugins.grounditems.config.MenuHighlightMode.NAME;
import static net.runelite.client.plugins.grounditems.config.MenuHighlightMode.OPTION; import static net.runelite.client.plugins.grounditems.config.MenuHighlightMode.OPTION;
import net.runelite.client.plugins.grounditems.config.ValueCalculationMode;
import net.runelite.client.ui.overlay.OverlayManager; import net.runelite.client.ui.overlay.OverlayManager;
import net.runelite.client.util.ColorUtil; import net.runelite.client.util.ColorUtil;
import net.runelite.client.util.QuantityFormatter; import net.runelite.client.util.QuantityFormatter;
@@ -562,29 +563,12 @@ public class GroundItemsPlugin extends Plugin
return null; return null;
} }
ValueCalculationMode mode = config.valueCalculationMode(); final int price = getValueByMode(gePrice, haPrice);
for (PriceHighlight highlight : priceChecks) for (PriceHighlight highlight : priceChecks)
{ {
switch (mode) if (price > highlight.getPrice())
{ {
case GE: return highlight.getColor();
if (gePrice > highlight.getPrice())
{
return highlight.getColor();
}
break;
case HA:
if (haPrice > highlight.getPrice())
{
return highlight.getColor();
}
break;
default: // case HIGHEST
if (gePrice > highlight.getPrice() || haPrice > highlight.getPrice())
{
return highlight.getColor();
}
break;
} }
} }
@@ -631,12 +615,26 @@ public class GroundItemsPlugin extends Plugin
private void notifyHighlightedItem(GroundItem item) private void notifyHighlightedItem(GroundItem item)
{ {
boolean shouldNotifyHighlighted = config.highlightedColor().equals(getHighlighted( final boolean shouldNotifyHighlighted = config.notifyHighlightedDrops() &&
new NamedQuantity(item), config.highlightedColor().equals(getHighlighted(
item.getGePrice(), new NamedQuantity(item),
item.getHaPrice())); item.getGePrice(),
item.getHaPrice()));
if (!config.notifyHighlightedDrops() || !shouldNotifyHighlighted) final boolean shouldNotifyTier = config.notifyTier() != HighlightTier.OFF &&
getValueByMode(item.getGePrice(), item.getHaPrice()) > config.notifyTier().getValueFromTier(config) &&
FALSE.equals(hiddenItems.getUnchecked(new NamedQuantity(item)));
final String dropType;
if (shouldNotifyHighlighted)
{
dropType = "highlighted";
}
else if (shouldNotifyTier)
{
dropType = "valuable";
}
else
{ {
return; return;
} }
@@ -645,7 +643,9 @@ public class GroundItemsPlugin extends Plugin
final StringBuilder notificationStringBuilder = new StringBuilder() final StringBuilder notificationStringBuilder = new StringBuilder()
.append("[") .append("[")
.append(local.getName()) .append(local.getName())
.append("] received a highlighted drop: ") .append("] received a ")
.append(dropType)
.append(" drop: ")
.append(item.getName()); .append(item.getName());
if (item.getQuantity() > 1) if (item.getQuantity() > 1)
@@ -669,6 +669,19 @@ public class GroundItemsPlugin extends Plugin
notifier.notify(notificationStringBuilder.toString()); notifier.notify(notificationStringBuilder.toString());
} }
private int getValueByMode(int gePrice, int haPrice)
{
switch (config.valueCalculationMode())
{
case GE:
return gePrice;
case HA:
return haPrice;
default: // Highest
return Math.max(gePrice, haPrice);
}
}
@Subscribe @Subscribe
public void onMenuOptionClicked(MenuOptionClicked menuOptionClicked) public void onMenuOptionClicked(MenuOptionClicked menuOptionClicked)
{ {

View File

@@ -0,0 +1,53 @@
/*
* Copyright (c) 2020, Hydrox6 <ikada@protonmail.ch>
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package net.runelite.client.plugins.grounditems.config;
import net.runelite.client.plugins.grounditems.GroundItemsConfig;
public enum HighlightTier
{
OFF,
LOW,
MEDIUM,
HIGH,
INSANE;
public int getValueFromTier(GroundItemsConfig config)
{
switch (this)
{
case LOW:
return config.lowValuePrice();
case MEDIUM:
return config.mediumValuePrice();
case HIGH:
return config.highValuePrice();
case INSANE:
return config.insaneValuePrice();
default:
throw new UnsupportedOperationException();
}
}
}