ground items: add Notify >= Tier
This commit is contained in:
@@ -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()
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -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)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -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();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user