loottracker: stack clue scrolls in the ui instead of at loot receive time
This commit is contained in:
@@ -201,18 +201,22 @@ class LootTrackerBox extends JPanel
|
|||||||
outer:
|
outer:
|
||||||
for (LootTrackerItem item : record.getItems())
|
for (LootTrackerItem item : record.getItems())
|
||||||
{
|
{
|
||||||
|
final int mappedItemId = LootTrackerMapping.map(item.getId(), item.getName());
|
||||||
// Combine it into an existing item if one already exists
|
// Combine it into an existing item if one already exists
|
||||||
for (int idx = 0; idx < items.size(); ++idx)
|
for (int idx = 0; idx < items.size(); ++idx)
|
||||||
{
|
{
|
||||||
LootTrackerItem i = items.get(idx);
|
LootTrackerItem i = items.get(idx);
|
||||||
if (item.getId() == i.getId())
|
if (mappedItemId == i.getId())
|
||||||
{
|
{
|
||||||
items.set(idx, new LootTrackerItem(i.getId(), i.getName(), i.getQuantity() + item.getQuantity(), i.getGePrice(), i.getHaPrice(), i.isIgnored()));
|
items.set(idx, new LootTrackerItem(i.getId(), i.getName(), i.getQuantity() + item.getQuantity(), i.getGePrice(), i.getHaPrice(), i.isIgnored()));
|
||||||
continue outer;
|
continue outer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
items.add(item);
|
final LootTrackerItem mappedItem = mappedItemId == item.getId()
|
||||||
|
? item // reuse existing item
|
||||||
|
: new LootTrackerItem(mappedItemId, item.getName(), item.getQuantity(), item.getGePrice(), item.getHaPrice(), item.isIgnored());
|
||||||
|
items.add(mappedItem);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -25,11 +25,13 @@
|
|||||||
package net.runelite.client.plugins.loottracker;
|
package net.runelite.client.plugins.loottracker;
|
||||||
|
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
|
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@Getter
|
@Getter
|
||||||
|
@EqualsAndHashCode
|
||||||
class LootTrackerItem
|
class LootTrackerItem
|
||||||
{
|
{
|
||||||
private final int id;
|
private final int id;
|
||||||
|
|||||||
@@ -24,13 +24,9 @@
|
|||||||
*/
|
*/
|
||||||
package net.runelite.client.plugins.loottracker;
|
package net.runelite.client.plugins.loottracker;
|
||||||
|
|
||||||
import com.google.common.base.Strings;
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import net.runelite.api.ItemComposition;
|
|
||||||
import net.runelite.api.ItemID;
|
import net.runelite.api.ItemID;
|
||||||
import net.runelite.client.game.ItemManager;
|
|
||||||
import net.runelite.client.game.ItemStack;
|
|
||||||
|
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
enum LootTrackerMapping
|
enum LootTrackerMapping
|
||||||
@@ -57,25 +53,8 @@ enum LootTrackerMapping
|
|||||||
MAPPINGS = map.build();
|
MAPPINGS = map.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static int map(int itemId, ItemManager itemManager)
|
static int map(int itemId, String name)
|
||||||
{
|
{
|
||||||
ItemComposition itemComp = itemManager.getItemComposition(itemId);
|
return MAPPINGS.getOrDefault(name, itemId);
|
||||||
if (Strings.isNullOrEmpty(itemComp.getName()))
|
|
||||||
{
|
|
||||||
return itemId;
|
|
||||||
}
|
|
||||||
|
|
||||||
return MAPPINGS.getOrDefault(itemComp.getName(), itemId);
|
|
||||||
}
|
|
||||||
|
|
||||||
static ItemStack map(ItemStack item, ItemManager itemManager)
|
|
||||||
{
|
|
||||||
int baseId = map(item.getId(), itemManager);
|
|
||||||
if (baseId == item.getId())
|
|
||||||
{
|
|
||||||
return item;
|
|
||||||
}
|
|
||||||
|
|
||||||
return new ItemStack(baseId, item.getQuantity(), item.getLocation());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -215,14 +215,12 @@ public class LootTrackerPlugin extends Plugin
|
|||||||
private LootTrackerClient lootTrackerClient;
|
private LootTrackerClient lootTrackerClient;
|
||||||
private final List<LootRecord> queuedLoots = new ArrayList<>();
|
private final List<LootRecord> queuedLoots = new ArrayList<>();
|
||||||
|
|
||||||
@VisibleForTesting
|
private static Collection<ItemStack> stack(Collection<ItemStack> items)
|
||||||
Collection<ItemStack> stack(Collection<ItemStack> items)
|
|
||||||
{
|
{
|
||||||
final List<ItemStack> list = new ArrayList<>();
|
final List<ItemStack> list = new ArrayList<>();
|
||||||
|
|
||||||
for (ItemStack item : items)
|
for (final ItemStack item : items)
|
||||||
{
|
{
|
||||||
item = LootTrackerMapping.map(item, itemManager);
|
|
||||||
int quantity = 0;
|
int quantity = 0;
|
||||||
for (final ItemStack i : list)
|
for (final ItemStack i : list)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -0,0 +1,71 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2020, Adam <Adam@sigterm.info>
|
||||||
|
* 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.loottracker;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import net.runelite.api.ItemID;
|
||||||
|
import net.runelite.client.game.ItemManager;
|
||||||
|
import net.runelite.http.api.loottracker.LootRecordType;
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import org.junit.Test;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
|
||||||
|
public class LootTrackerBoxTest
|
||||||
|
{
|
||||||
|
@Test
|
||||||
|
public void testAddKill()
|
||||||
|
{
|
||||||
|
LootTrackerBox lootTrackerBox = new LootTrackerBox(
|
||||||
|
mock(ItemManager.class),
|
||||||
|
"Theatre of Blood",
|
||||||
|
LootRecordType.EVENT,
|
||||||
|
null,
|
||||||
|
false,
|
||||||
|
LootTrackerPriceType.GRAND_EXCHANGE,
|
||||||
|
false,
|
||||||
|
null, null,
|
||||||
|
false);
|
||||||
|
|
||||||
|
LootTrackerItem[] items = new LootTrackerItem[]{
|
||||||
|
new LootTrackerItem(ItemID.CLUE_SCROLL_MEDIUM, "Clue scroll (medium)", 1, 0, 0, false),
|
||||||
|
new LootTrackerItem(ItemID.CLUE_SCROLL_MEDIUM_3602, "Clue scroll (medium)", 1, 0, 0, false),
|
||||||
|
new LootTrackerItem(ItemID.GRACEFUL_HOOD_13579, "Graceful hood", 1, 0, 0, false),
|
||||||
|
};
|
||||||
|
LootTrackerRecord lootTrackerRecord = new LootTrackerRecord(
|
||||||
|
"Theatre of Blood",
|
||||||
|
null,
|
||||||
|
LootRecordType.EVENT,
|
||||||
|
items,
|
||||||
|
42
|
||||||
|
);
|
||||||
|
|
||||||
|
lootTrackerBox.addKill(lootTrackerRecord);
|
||||||
|
|
||||||
|
assertEquals(Arrays.asList(
|
||||||
|
new LootTrackerItem(ItemID.CLUE_SCROLL_MEDIUM, "Clue scroll (medium)", 2, 0, 0, false),
|
||||||
|
new LootTrackerItem(ItemID.GRACEFUL_HOOD_13579, "Graceful hood", 1, 0, 0, false)
|
||||||
|
), lootTrackerBox.getItems());
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -158,25 +158,6 @@ public class LootTrackerPluginTest
|
|||||||
return itemComposition;
|
return itemComposition;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testClueStacks()
|
|
||||||
{
|
|
||||||
when(itemManager.getItemComposition(ItemID.CLUE_SCROLL_MEDIUM)).thenAnswer(invocation -> mockItem("Clue scroll (medium)"));
|
|
||||||
when(itemManager.getItemComposition(ItemID.CLUE_SCROLL_MEDIUM_3602)).thenAnswer(invocation -> mockItem("Clue scroll (medium)"));
|
|
||||||
when(itemManager.getItemComposition(ItemID.GRACEFUL_HOOD_13579)).thenAnswer(invocation -> mockItem("Graceful hood"));
|
|
||||||
Collection<ItemStack> stack = lootTrackerPlugin.stack(
|
|
||||||
Arrays.asList(
|
|
||||||
new ItemStack(ItemID.CLUE_SCROLL_MEDIUM, 1, null),
|
|
||||||
new ItemStack(ItemID.CLUE_SCROLL_MEDIUM_3602, 1, null),
|
|
||||||
new ItemStack(ItemID.GRACEFUL_HOOD_13579, 1, null)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
assertEquals(Arrays.asList(
|
|
||||||
new ItemStack(ItemID.CLUE_SCROLL_MEDIUM, 2, null),
|
|
||||||
new ItemStack(ItemID.GRACEFUL_HOOD_13579, 1, null)
|
|
||||||
), stack);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testHerbiboarHerbSack()
|
public void testHerbiboarHerbSack()
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user