diff --git a/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/JStockpileTable.java b/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/JStockpileTable.java index b0af4e0e5..c6828268a 100644 --- a/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/JStockpileTable.java +++ b/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/JStockpileTable.java @@ -129,8 +129,7 @@ public Component prepareRenderer(final TableCellRenderer renderer, final int row } else if (object instanceof SubpileItem) { //Total if (!stockpileItem.isEditable() && columnName.equals(StockpileTableFormat.COUNT_MINIMUM.getColumnName())) { ColorSettings.configCell(component, ColorEntry.GLOBAL_GRAND_TOTAL, isSelected); - } - if (columnName.equals(StockpileTableFormat.TAGS.getColumnName())) { + } else if (columnName.equals(StockpileTableFormat.TAGS.getColumnName())) { ColorSettings.configCell(component, ColorEntry.GLOBAL_GRAND_TOTAL, isSelected); } } else if (object instanceof StockpileTotal) { //Total @@ -145,8 +144,7 @@ public Component prepareRenderer(final TableCellRenderer renderer, final int row int jLabelWidth = jLabel.getMaximumSize().width + 1; jLabel.setIconTextGap(Math.max(0, columnWidth - jLabelWidth)); } - } - if (columnName.equals(StockpileTableFormat.NAME.getColumnName())) { + } else if (columnName.equals(StockpileTableFormat.NAME.getColumnName())) { if (Settings.get().isStockpileHalfColors()) { if (stockpileItem.getPercentNeeded() >= (Settings.get().getStockpileColorGroup3() / 100.0) ) { //Group 3 @@ -167,45 +165,35 @@ public Component prepareRenderer(final TableCellRenderer renderer, final int row ColorSettings.configCell(component, ColorEntry.STOCKPILE_TABLE_BELOW_THRESHOLD, isSelected); } } + } else if (stockpileItem.isIgnoreMultiplier() && columnName.equals(StockpileTableFormat.COUNT_MINIMUM_MULTIPLIED.getColumnName())) { + ColorSettings.configCell(component, ColorEntry.GLOBAL_GRAND_TOTAL, isSelected); } //Foreground if (columnName.equals(StockpileTableFormat.COUNT_NOW_INVENTORY.getColumnName()) && !stockpileItem.getStockpile().isAssets()) { component.setForeground(component.getBackground()); - } - if (columnName.equals(StockpileTableFormat.COUNT_NOW_BUY_ORDERS.getColumnName()) && (!stockpileItem.getStockpile().isBuyOrders() || stockpileItem.isRuns())) { + } else if (columnName.equals(StockpileTableFormat.COUNT_NOW_BUY_ORDERS.getColumnName()) && (!stockpileItem.getStockpile().isBuyOrders() || stockpileItem.isRuns())) { component.setForeground(component.getBackground()); - } - if (columnName.equals(StockpileTableFormat.COUNT_NOW_SELL_ORDERS.getColumnName()) && (!stockpileItem.getStockpile().isSellOrders() || stockpileItem.isRuns())) { + } else if (columnName.equals(StockpileTableFormat.COUNT_NOW_SELL_ORDERS.getColumnName()) && (!stockpileItem.getStockpile().isSellOrders() || stockpileItem.isRuns())) { component.setForeground(component.getBackground()); - } - if (columnName.equals(StockpileTableFormat.COUNT_NOW_BUY_TRANSACTIONS.getColumnName()) && (!stockpileItem.getStockpile().isBuyTransactions() || stockpileItem.isRuns())) { + } else if (columnName.equals(StockpileTableFormat.COUNT_NOW_BUY_TRANSACTIONS.getColumnName()) && (!stockpileItem.getStockpile().isBuyTransactions() || stockpileItem.isRuns())) { component.setForeground(component.getBackground()); - } - if (columnName.equals(StockpileTableFormat.COUNT_NOW_SELL_TRANSACTIONS.getColumnName()) && (!stockpileItem.getStockpile().isSellTransactions() || stockpileItem.isRuns())) { + } else if (columnName.equals(StockpileTableFormat.COUNT_NOW_SELL_TRANSACTIONS.getColumnName()) && (!stockpileItem.getStockpile().isSellTransactions() || stockpileItem.isRuns())) { component.setForeground(component.getBackground()); - } - if (columnName.equals(StockpileTableFormat.COUNT_NOW_JOBS.getColumnName()) && !stockpileItem.getStockpile().isJobs()) { + } else if (columnName.equals(StockpileTableFormat.COUNT_NOW_JOBS.getColumnName()) && !stockpileItem.getStockpile().isJobs()) { component.setForeground(component.getBackground()); - } - if (columnName.equals(StockpileTableFormat.COUNT_NOW_SELLING_CONTRACTS.getColumnName()) && (!stockpileItem.getStockpile().isSellingContracts() || stockpileItem.isRuns())) { + } else if (columnName.equals(StockpileTableFormat.COUNT_NOW_SELLING_CONTRACTS.getColumnName()) && (!stockpileItem.getStockpile().isSellingContracts() || stockpileItem.isRuns())) { component.setForeground(component.getBackground()); - } - if (columnName.equals(StockpileTableFormat.COUNT_NOW_SOLD_CONTRACTS.getColumnName()) && (!stockpileItem.getStockpile().isSoldContracts() || stockpileItem.isRuns())) { + } else if (columnName.equals(StockpileTableFormat.COUNT_NOW_SOLD_CONTRACTS.getColumnName()) && (!stockpileItem.getStockpile().isSoldContracts() || stockpileItem.isRuns())) { component.setForeground(component.getBackground()); - } - if (columnName.equals(StockpileTableFormat.COUNT_NOW_BUYING_CONTRACTS.getColumnName()) && (!stockpileItem.getStockpile().isBuyingContracts() || stockpileItem.isRuns())) { + } else if (columnName.equals(StockpileTableFormat.COUNT_NOW_BUYING_CONTRACTS.getColumnName()) && (!stockpileItem.getStockpile().isBuyingContracts() || stockpileItem.isRuns())) { component.setForeground(component.getBackground()); - } - if (columnName.equals(StockpileTableFormat.COUNT_NOW_BOUGHT_CONTRACTS.getColumnName()) && (!stockpileItem.getStockpile().isBoughtContracts() || stockpileItem.isRuns())) { + } else if (columnName.equals(StockpileTableFormat.COUNT_NOW_BOUGHT_CONTRACTS.getColumnName()) && (!stockpileItem.getStockpile().isBoughtContracts() || stockpileItem.isRuns())) { component.setForeground(component.getBackground()); - } - if (columnName.equals(StockpileTableFormat.COUNT_NEEDED.getColumnName()) && stockpileItem.getCountNeeded() < 0) { + } else if (columnName.equals(StockpileTableFormat.COUNT_NEEDED.getColumnName()) && stockpileItem.getCountNeeded() < 0) { ColorSettings.configCell(component, ColorEntry.GLOBAL_VALUE_NEGATIVE, isSelected); - } - if (columnName.equals(StockpileTableFormat.VALUE_NEEDED.getColumnName()) && stockpileItem.getValueNeeded() < 0) { + } else if (columnName.equals(StockpileTableFormat.VALUE_NEEDED.getColumnName()) && stockpileItem.getValueNeeded() < 0) { ColorSettings.configCell(component, ColorEntry.GLOBAL_VALUE_NEGATIVE, isSelected); - } - if (columnName.equals(StockpileTableFormat.VOLUME_NEEDED.getColumnName()) && stockpileItem.getVolumeNeeded() < 0) { + } else if (columnName.equals(StockpileTableFormat.VOLUME_NEEDED.getColumnName()) && stockpileItem.getVolumeNeeded() < 0) { ColorSettings.configCell(component, ColorEntry.GLOBAL_VALUE_NEGATIVE, isSelected); } } diff --git a/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/Stockpile.java b/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/Stockpile.java index 398ad9ea3..49a308189 100644 --- a/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/Stockpile.java +++ b/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/Stockpile.java @@ -555,6 +555,7 @@ public static class StockpileItem implements Comparable, Location private int typeID; private double countMinimum; private boolean runs; + private boolean ignoreMultiplier; //soft init protected JButton jButton; @@ -585,20 +586,26 @@ public StockpileItem(final Stockpile stockpile, final StockpileItem stockpileIte stockpileItem.item, stockpileItem.typeID, stockpileItem.countMinimum, - stockpileItem.runs + stockpileItem.runs, + stockpileItem.ignoreMultiplier ); } public StockpileItem(final Stockpile stockpile, final Item item, final int typeID, final double countMinimum, final boolean runs) { - this(stockpile, item, typeID, countMinimum, runs, getNewID()); + this(stockpile, item, typeID, countMinimum, runs, false, getNewID()); } - public StockpileItem(final Stockpile stockpile, final Item item, final int typeID, final double countMinimum, final boolean runs, final long id) { + public StockpileItem(final Stockpile stockpile, final Item item, final int typeID, final double countMinimum, final boolean runs, boolean ignoreMultiplier) { + this(stockpile, item, typeID, countMinimum, runs, ignoreMultiplier, getNewID()); + } + + public StockpileItem(final Stockpile stockpile, final Item item, final int typeID, final double countMinimum, final boolean runs, boolean ignoreMultiplier, final long id) { this.stockpile = stockpile; this.item = item; this.typeID = typeID; this.countMinimum = countMinimum; this.runs = runs; + this.ignoreMultiplier = ignoreMultiplier; this.id = id; } @@ -608,6 +615,7 @@ void update(StockpileItem stockpileItem) { this.typeID = stockpileItem.typeID; this.countMinimum = stockpileItem.countMinimum; this.runs = stockpileItem.runs; + this.ignoreMultiplier = stockpileItem.ignoreMultiplier; } @Override @@ -626,6 +634,14 @@ public boolean isEditable() { return true; } + public boolean isIgnoreMultiplier() { + return ignoreMultiplier; + } + + public void setIgnoreMultiplier(boolean ignoreMultiplier) { + this.ignoreMultiplier = ignoreMultiplier; + } + private void reset() { inventoryCountNow = 0; sellOrdersCountNow = 0; @@ -1163,7 +1179,11 @@ public double getCountMinimum() { } public long getCountMinimumMultiplied() { - return (long) Math.ceil(stockpile.getMultiplier() * countMinimum); + if (isIgnoreMultiplier()) { + return (long) Math.ceil(countMinimum); + } else { + return (long) Math.ceil(stockpile.getMultiplier() * countMinimum); + } } public long getCountNow() { @@ -1428,7 +1448,7 @@ public static class StockpileTotal extends StockpileItem { private double volumeNeeded = 0; public StockpileTotal(final Stockpile stockpile) { - super(stockpile, new Item(0), 0, 0, false, 0); + super(stockpile, new Item(0), 0, 0, false, false, 0); } private void reset() { @@ -1876,7 +1896,7 @@ public static class SubpileItem extends StockpileItem { private int level; public SubpileItem(Stockpile stockpile, StockpileItem parentItem, SubpileStock subpileStock, int level, String path) { - super(stockpile, parentItem); + super(stockpile, parentItem.getItem(), parentItem.getItemTypeID(), parentItem.getCountMinimum(), parentItem.isRuns(), false); itemLinks.add(new SubpileItemLinks(parentItem, subpileStock)); setLevel(level); this.path = path; @@ -1950,12 +1970,13 @@ public String getName() { @Override public double getCountMinimum() { double countMinimum = 0; - for (SubpileItemLinks item : itemLinks) { - SubpileStock stock = item.getSubpileStock(); - if (stock != null) { - countMinimum = + countMinimum + (item.getStockpileItem().getCountMinimum() * item.getSubpileStock().getSubMultiplier()); + for (SubpileItemLinks link : itemLinks) { + SubpileStock stock = link.getSubpileStock(); + StockpileItem item = link.getStockpileItem(); + if (item.isIgnoreMultiplier() || stock == null) { + countMinimum = countMinimum + item.getCountMinimum(); } else { - countMinimum = + countMinimum + item.getStockpileItem().getCountMinimum(); + countMinimum = countMinimum + (item.getCountMinimum() * stock.getSubMultiplier()); } } return countMinimum; @@ -1963,7 +1984,19 @@ public double getCountMinimum() { @Override public long getCountMinimumMultiplied() { - return (long) Math.ceil(getStockpile().getMultiplier() * getCountMinimum()); + double countMinimum = 0; + for (SubpileItemLinks link : itemLinks) { + SubpileStock stock = link.getSubpileStock(); + StockpileItem item = link.getStockpileItem(); + if (item.isIgnoreMultiplier()) { + countMinimum = countMinimum + item.getCountMinimum(); + } else if (stock != null) { + countMinimum = countMinimum + (item.getCountMinimum() * stock.getSubMultiplier() * getStockpile().getMultiplier()); + } else { + countMinimum = countMinimum + (item.getCountMinimum() * getStockpile().getMultiplier()); + } + } + return (long) Math.ceil(countMinimum); } private static class SubpileItemLinks { diff --git a/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/StockpileItemDialog.java b/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/StockpileItemDialog.java index 55a65b65a..f9ab85300 100644 --- a/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/StockpileItemDialog.java +++ b/src/main/java/net/nikr/eve/jeveasset/gui/tabs/stockpile/StockpileItemDialog.java @@ -35,6 +35,7 @@ import javax.swing.DefaultComboBoxModel; import javax.swing.GroupLayout; import javax.swing.JButton; +import javax.swing.JCheckBox; import javax.swing.JComboBox; import javax.swing.JComponent; import javax.swing.JLabel; @@ -102,11 +103,14 @@ public String toString() { private final JComboBox jItems; private final JLabel jSubpile; private JTextField jCountMinimum; + private final JLabel jBlueprintTypeLabel; private final JComboBox jBlueprintType; private final JComboBox jMe; private final JComboBox jFacility; private final JComboBox jRigs; private final JComboBox jSecurity; + private final JLabel jIgnoreMultiplierLabel; + private final JCheckBox jIgnoreMultiplier; private final List manufacturingComponents = new ArrayList<>(); private final EventList items = EventListManager.create(); @@ -139,7 +143,10 @@ public void focusGained(final FocusEvent e) { }); jCountMinimum.addCaretListener(listener); - JLabel jBlueprintTypeLabel = new JLabel(TabsStockpile.get().blueprintType()); + jIgnoreMultiplierLabel = new JLabel(TabsStockpile.get().multiplier()); + jIgnoreMultiplier = new JCheckBox(TabsStockpile.get().multiplierIgnore()); + + jBlueprintTypeLabel = new JLabel(TabsStockpile.get().blueprintType()); jBlueprintType = new JComboBox<>(BlueprintAddType.values()); jBlueprintType.setActionCommand(StockpileItemAction.TYPE_CHANGE.name()); jBlueprintType.addActionListener(listener); @@ -206,21 +213,23 @@ public void actionPerformed(ActionEvent e) { .addGroup(layout.createParallelGroup() .addComponent(jItemsLabel) .addComponent(jBlueprintTypeLabel) - .addComponent(jCountMinimumLabel) .addComponent(jMeLabel) .addComponent(jFacilityLabel) .addComponent(jRigsLabel) .addComponent(jSecurityLabel) + .addComponent(jIgnoreMultiplierLabel) + .addComponent(jCountMinimumLabel) ) .addGroup(layout.createParallelGroup() .addComponent(jItems, 300, 300, 300) .addComponent(jSubpile, 300, 300, 300) .addComponent(jBlueprintType, 300, 300, 300) - .addComponent(jCountMinimum, 300, 300, 300) .addComponent(jMe, 300, 300, 300) .addComponent(jFacility, 300, 300, 300) .addComponent(jRigs, 300, 300, 300) .addComponent(jSecurity, 300, 300, 300) + .addComponent(jIgnoreMultiplier, 300, 300, 300) + .addComponent(jCountMinimum, 300, 300, 300) ) ) .addGroup(layout.createSequentialGroup() @@ -255,6 +264,10 @@ public void actionPerformed(ActionEvent e) { .addComponent(jSecurityLabel, Program.getButtonsHeight(), Program.getButtonsHeight(), Program.getButtonsHeight()) .addComponent(jSecurity, Program.getButtonsHeight(), Program.getButtonsHeight(), Program.getButtonsHeight()) ) + .addGroup(layout.createParallelGroup() + .addComponent(jIgnoreMultiplierLabel, Program.getButtonsHeight(), Program.getButtonsHeight(), Program.getButtonsHeight()) + .addComponent(jIgnoreMultiplier, Program.getButtonsHeight(), Program.getButtonsHeight(), Program.getButtonsHeight()) + ) .addGroup(layout.createParallelGroup() .addComponent(jCountMinimumLabel, Program.getButtonsHeight(), Program.getButtonsHeight(), Program.getButtonsHeight()) .addComponent(jCountMinimum, Program.getButtonsHeight(), Program.getButtonsHeight(), Program.getButtonsHeight()) @@ -274,10 +287,18 @@ protected StockpileItem showEdit(final StockpileItem editStockpileItem) { if (editStockpileItem instanceof SubpileStock) { jSubpile.setText(editStockpileItem.getName()); jSubpile.setVisible(true); + jBlueprintTypeLabel.setVisible(false); + jBlueprintType.setVisible(false); + jIgnoreMultiplierLabel.setVisible(false); + jIgnoreMultiplier.setVisible(false); jItems.setVisible(false); } else { jItems.setSelectedItem(item); jSubpile.setVisible(false); + jBlueprintTypeLabel.setVisible(true); + jBlueprintType.setVisible(true); + jIgnoreMultiplierLabel.setVisible(true); + jIgnoreMultiplier.setVisible(true); jItems.setVisible(true); } if (item.isBlueprint()) { @@ -332,6 +353,7 @@ private void updateData() { jItems.setVisible(true); jItems.setSelectedIndex(0); jCountMinimum.setText(""); + jIgnoreMultiplier.setSelected(false); } private void show() { @@ -366,7 +388,8 @@ private StockpileItem getStockpileItem() { } else { typeID = item.getTypeID(); } - return new StockpileItem(getStockpile(), item, typeID, countMinimum, runs); + boolean ignoreMultiplier = jIgnoreMultiplier.isSelected(); + return new StockpileItem(getStockpile(), item, typeID, countMinimum, runs, ignoreMultiplier); } private List getStockpileItems() { @@ -378,6 +401,7 @@ private List getStockpileItems() { } catch (NumberFormatException ex) { countMinimum = 0; } + boolean ignoreMultiplier = jIgnoreMultiplier.isSelected(); Integer me = jMe.getItemAt(jMe.getSelectedIndex()); ManufacturingFacility facility = jFacility.getItemAt(jFacility.getSelectedIndex()); ManufacturingRigs rigs = jRigs.getItemAt(jRigs.getSelectedIndex()); @@ -387,14 +411,14 @@ private List getStockpileItems() { for (IndustryMaterial material : item.getManufacturingMaterials()) { Item materialItem = ApiIdConverter.getItem(material.getTypeID()); double count = ApiIdConverter.getManufacturingQuantity(material.getQuantity(), me, facility, rigs, security, countMinimum, false); - itemsMaterial.add(new StockpileItem(getStockpile(), materialItem, material.getTypeID(), count, false)); + itemsMaterial.add(new StockpileItem(getStockpile(), materialItem, material.getTypeID(), count, false, ignoreMultiplier)); } } else if (jBlueprintType.isEnabled() && jBlueprintType.getItemAt(jBlueprintType.getSelectedIndex()) == BlueprintAddType.REACTION_MATERIALS) { //Reaction Materials for (IndustryMaterial material : item.getReactionMaterials()) { Item materialItem = ApiIdConverter.getItem(material.getTypeID()); double count = ApiIdConverter.getManufacturingQuantity(material.getQuantity(), me, facility, rigs, security, countMinimum, false); - itemsMaterial.add(new StockpileItem(getStockpile(), materialItem, material.getTypeID(), count, false)); + itemsMaterial.add(new StockpileItem(getStockpile(), materialItem, material.getTypeID(), count, false, ignoreMultiplier)); } } else { return null; @@ -519,6 +543,7 @@ public void run() { boolean oldUpdateValue = updating; updating = true; jCountMinimum.setText(String.valueOf(item.getCountMinimum())); + jIgnoreMultiplier.setSelected(item.isIgnoreMultiplier()); updating = oldUpdateValue; } }); diff --git a/src/main/java/net/nikr/eve/jeveasset/i18n/TabsStockpile.java b/src/main/java/net/nikr/eve/jeveasset/i18n/TabsStockpile.java index 6415f9daf..fc55f6fc7 100644 --- a/src/main/java/net/nikr/eve/jeveasset/i18n/TabsStockpile.java +++ b/src/main/java/net/nikr/eve/jeveasset/i18n/TabsStockpile.java @@ -178,6 +178,7 @@ public TabsStockpile(final Locale locale) { public abstract String me(); public abstract String multiple(); public abstract String multiplier(); + public abstract String multiplierIgnore(); public abstract String multiplierSign(); public abstract String myLocations(); public abstract String name(); diff --git a/src/main/java/net/nikr/eve/jeveasset/io/local/SettingsReader.java b/src/main/java/net/nikr/eve/jeveasset/io/local/SettingsReader.java index b8eaeb3ca..a849e5573 100644 --- a/src/main/java/net/nikr/eve/jeveasset/io/local/SettingsReader.java +++ b/src/main/java/net/nikr/eve/jeveasset/io/local/SettingsReader.java @@ -847,10 +847,11 @@ private void parseStockpiles(final Element stockpilesElement, final List stockp setAttribute(itemNode, "typeid", item.getItemTypeID()); setAttribute(itemNode, "minimum", item.getCountMinimum()); setAttribute(itemNode, "runs", item.isRuns()); + setAttribute(itemNode, "ignoremultiplier", item.isIgnoreMultiplier()); stockpileNode.appendChild(itemNode); } //SUBPILES diff --git a/src/main/java/net/nikr/eve/jeveasset/io/local/StockpileDataReader.java b/src/main/java/net/nikr/eve/jeveasset/io/local/StockpileDataReader.java index 4dfb1bf57..a0672b620 100644 --- a/src/main/java/net/nikr/eve/jeveasset/io/local/StockpileDataReader.java +++ b/src/main/java/net/nikr/eve/jeveasset/io/local/StockpileDataReader.java @@ -171,7 +171,12 @@ public Stockpile deserialize(JsonElement json, Type typeOfT, JsonDeserialization int itemTypeID = itemObject.get("i").getAsInt(); double countMinimum = itemObject.get("m").getAsDouble(); boolean runs = itemObject.get("r").getAsBoolean(); - stockpile.add(new StockpileItem(stockpile, ApiIdConverter.getItem(Math.abs(itemTypeID)), itemTypeID, countMinimum, runs)); + JsonElement element = itemObject.get("im"); + boolean ignoreMultiplier = false; + if (element != null) { + ignoreMultiplier = element.getAsBoolean(); + } + stockpile.add(new StockpileItem(stockpile, ApiIdConverter.getItem(Math.abs(itemTypeID)), itemTypeID, countMinimum, runs, ignoreMultiplier)); } return stockpile; } diff --git a/src/main/java/net/nikr/eve/jeveasset/io/local/StockpileDataWriter.java b/src/main/java/net/nikr/eve/jeveasset/io/local/StockpileDataWriter.java index d0898c2b9..8e3869e37 100644 --- a/src/main/java/net/nikr/eve/jeveasset/io/local/StockpileDataWriter.java +++ b/src/main/java/net/nikr/eve/jeveasset/io/local/StockpileDataWriter.java @@ -148,6 +148,7 @@ public JsonElement serialize(Stockpile stockpile, Type typeOfSrc, JsonSerializat item.addProperty("i", stockpileItem.getItemTypeID()); item.addProperty("m", stockpileItem.getCountMinimum()); item.addProperty("r", stockpileItem.isRuns()); + item.addProperty("im", stockpileItem.isIgnoreMultiplier()); items.add(item); } diff --git a/src/main/resources/net/nikr/eve/jeveasset/i18n/TabsStockpile.properties b/src/main/resources/net/nikr/eve/jeveasset/i18n/TabsStockpile.properties index 3649705f6..6d8cb0591 100644 --- a/src/main/resources/net/nikr/eve/jeveasset/i18n/TabsStockpile.properties +++ b/src/main/resources/net/nikr/eve/jeveasset/i18n/TabsStockpile.properties @@ -141,6 +141,7 @@ materialsReaction=Reaction Materials me=ME multiple=Multiple multiplier=Multiplier +multiplierIgnore=Ignore stockpile/subpile multiplier multiplierSign=\u00d7 myLocations=Only show my locations name=Name