reformat code & config screens
This commit is contained in:
@@ -1,16 +1,12 @@
|
|||||||
package com.github.sebseb7.autotrade;
|
package com.github.sebseb7.autotrade;
|
||||||
|
|
||||||
|
import net.fabricmc.api.ModInitializer;
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
import fi.dy.masa.malilib.event.InitializationHandler;
|
|
||||||
import net.fabricmc.api.ModInitializer;
|
|
||||||
|
|
||||||
public class AutoTrade implements ModInitializer
|
public class AutoTrade implements ModInitializer {
|
||||||
{
|
public static final Logger logger = LogManager.getLogger(Reference.MOD_ID);
|
||||||
public static final Logger logger = LogManager.getLogger(Reference.MOD_ID);
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onInitialize()
|
public void onInitialize() {}
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,9 +2,8 @@ package com.github.sebseb7.autotrade;
|
|||||||
|
|
||||||
import fi.dy.masa.malilib.util.StringUtils;
|
import fi.dy.masa.malilib.util.StringUtils;
|
||||||
|
|
||||||
public class Reference
|
public class Reference {
|
||||||
{
|
public static final String MOD_ID = "autotrade";
|
||||||
public static final String MOD_ID = "autotrade";
|
public static final String MOD_NAME = "Auto Trade";
|
||||||
public static final String MOD_NAME = "Auto Trade";
|
public static final String MOD_VERSION = StringUtils.getModVersionString(MOD_ID);
|
||||||
public static final String MOD_VERSION = StringUtils.getModVersionString(MOD_ID);
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,18 +1,16 @@
|
|||||||
package com.github.sebseb7.autotrade.compat.modmenu;
|
package com.github.sebseb7.autotrade.compat.modmenu;
|
||||||
|
|
||||||
|
import com.github.sebseb7.autotrade.gui.GuiConfigs;
|
||||||
import com.terraformersmc.modmenu.api.ConfigScreenFactory;
|
import com.terraformersmc.modmenu.api.ConfigScreenFactory;
|
||||||
import com.terraformersmc.modmenu.api.ModMenuApi;
|
import com.terraformersmc.modmenu.api.ModMenuApi;
|
||||||
import com.github.sebseb7.autotrade.gui.GuiConfigs;
|
|
||||||
|
|
||||||
public class ModMenuImpl implements ModMenuApi
|
public class ModMenuImpl implements ModMenuApi {
|
||||||
{
|
@Override
|
||||||
@Override
|
public ConfigScreenFactory<?> getModConfigScreenFactory() {
|
||||||
public ConfigScreenFactory<?> getModConfigScreenFactory()
|
return (screen) -> {
|
||||||
{
|
GuiConfigs gui = new GuiConfigs();
|
||||||
return (screen) -> {
|
gui.setParent(screen);
|
||||||
GuiConfigs gui = new GuiConfigs();
|
return gui;
|
||||||
gui.setParent(screen);
|
};
|
||||||
return gui;
|
}
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,10 +1,7 @@
|
|||||||
package com.github.sebseb7.autotrade.config;
|
package com.github.sebseb7.autotrade.config;
|
||||||
|
|
||||||
import java.io.File;
|
import com.github.sebseb7.autotrade.Reference;
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
import com.google.common.collect.ImmutableList;
|
import com.google.common.collect.ImmutableList;
|
||||||
import com.google.gson.JsonArray;
|
|
||||||
import com.google.gson.JsonElement;
|
import com.google.gson.JsonElement;
|
||||||
import com.google.gson.JsonObject;
|
import com.google.gson.JsonObject;
|
||||||
import fi.dy.masa.malilib.config.ConfigUtils;
|
import fi.dy.masa.malilib.config.ConfigUtils;
|
||||||
@@ -12,111 +9,111 @@ import fi.dy.masa.malilib.config.IConfigHandler;
|
|||||||
import fi.dy.masa.malilib.config.IConfigValue;
|
import fi.dy.masa.malilib.config.IConfigValue;
|
||||||
import fi.dy.masa.malilib.config.options.ConfigBoolean;
|
import fi.dy.masa.malilib.config.options.ConfigBoolean;
|
||||||
import fi.dy.masa.malilib.config.options.ConfigInteger;
|
import fi.dy.masa.malilib.config.options.ConfigInteger;
|
||||||
|
import fi.dy.masa.malilib.config.options.ConfigString;
|
||||||
import fi.dy.masa.malilib.util.FileUtils;
|
import fi.dy.masa.malilib.util.FileUtils;
|
||||||
import fi.dy.masa.malilib.util.JsonUtils;
|
import fi.dy.masa.malilib.util.JsonUtils;
|
||||||
import com.github.sebseb7.autotrade.Reference;
|
import java.io.File;
|
||||||
|
|
||||||
public class Configs implements IConfigHandler
|
public class Configs implements IConfigHandler {
|
||||||
{
|
private static final String CONFIG_FILE_NAME = Reference.MOD_ID + ".json";
|
||||||
private static final String CONFIG_FILE_NAME = Reference.MOD_ID + ".json";
|
|
||||||
|
|
||||||
public static class Generic
|
public static class Generic {
|
||||||
{
|
public static final ConfigBoolean ENABLED =
|
||||||
public static final ImmutableList<IConfigValue> OPTIONS = ImmutableList.of(
|
new ConfigBoolean("enabled", false, "Do auto trading with villagers in range");
|
||||||
);
|
public static final ConfigBoolean ENABLE_SELL =
|
||||||
|
new ConfigBoolean(
|
||||||
|
"enableSell",
|
||||||
|
false,
|
||||||
|
"Enable buying (if disabled emeralds from the emerald container are taken instead)");
|
||||||
|
public static final ConfigString BUY_ITEM =
|
||||||
|
new ConfigString("buyItem", "minecraft:gold_ingot", "The item to sell for emerald.");
|
||||||
|
public static final ConfigBoolean ENABLE_BUY =
|
||||||
|
new ConfigBoolean(
|
||||||
|
"enableBuy",
|
||||||
|
false,
|
||||||
|
"Enable selling (if disabled emeralds are placed in the emerald container)");
|
||||||
|
public static final ConfigString SELL_ITEM =
|
||||||
|
new ConfigString("sellItem", "minecraft:redstone", "The item to buy using emerald.");
|
||||||
|
public static final ConfigInteger MAX_INPUT_ITEMS =
|
||||||
|
new ConfigInteger(
|
||||||
|
"maxInputStacks",
|
||||||
|
9,
|
||||||
|
1,
|
||||||
|
35,
|
||||||
|
"stacks to take from input container (or emerald container in buy-only mode)");
|
||||||
|
public static final ConfigInteger INPUT_CONTAINER_X =
|
||||||
|
new ConfigInteger("inputContainerX", 0, -3000000, 30000000, "Input container X");
|
||||||
|
public static final ConfigInteger INPUT_CONTAINER_Y =
|
||||||
|
new ConfigInteger("inputContainerY", 0, -64, 320, "Input container Y");
|
||||||
|
public static final ConfigInteger INPUT_CONTAINER_Z =
|
||||||
|
new ConfigInteger("outputContainerZ", 0, -30000000, 30000000, "Input container Z");
|
||||||
|
public static final ConfigInteger OUTPUT_CONTAINER_X =
|
||||||
|
new ConfigInteger("outputContainerX", 0, -3000000, 30000000, "Output container X");
|
||||||
|
public static final ConfigInteger OUTPUT_CONTAINER_Y =
|
||||||
|
new ConfigInteger("outputContainerY", 0, -64, 320, "Output container Y");
|
||||||
|
public static final ConfigInteger OUTPUT_CONTAINER_Z =
|
||||||
|
new ConfigInteger("outputContainerZ", 0, -30000000, 30000000, "Output container Z");
|
||||||
|
public static final ConfigInteger EMERALD_CONTAINER_X =
|
||||||
|
new ConfigInteger("emeraldContainerX", 0, -3000000, 30000000, "Emerald container X");
|
||||||
|
public static final ConfigInteger EMERALD_CONTAINER_Y =
|
||||||
|
new ConfigInteger("emeraldContainerY", 0, -64, 320, "Emerald container Y");
|
||||||
|
public static final ConfigInteger EMERALD_CONTAINER_Z =
|
||||||
|
new ConfigInteger("emeraldContainerZ", 0, -30000000, 30000000, "Emerald container Z");
|
||||||
|
|
||||||
|
public static final ImmutableList<IConfigValue> OPTIONS =
|
||||||
|
ImmutableList.of(
|
||||||
|
ENABLED,
|
||||||
|
ENABLE_BUY,
|
||||||
|
BUY_ITEM,
|
||||||
|
ENABLE_SELL,
|
||||||
|
SELL_ITEM,
|
||||||
|
MAX_INPUT_ITEMS,
|
||||||
|
INPUT_CONTAINER_X,
|
||||||
|
INPUT_CONTAINER_Y,
|
||||||
|
INPUT_CONTAINER_Z,
|
||||||
|
OUTPUT_CONTAINER_X,
|
||||||
|
OUTPUT_CONTAINER_Y,
|
||||||
|
OUTPUT_CONTAINER_Z,
|
||||||
|
EMERALD_CONTAINER_X,
|
||||||
|
EMERALD_CONTAINER_Y,
|
||||||
|
EMERALD_CONTAINER_Z);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void loadFromFile() {
|
||||||
|
File configFile = new File(FileUtils.getConfigDirectory(), CONFIG_FILE_NAME);
|
||||||
|
|
||||||
|
if (configFile.exists() && configFile.isFile() && configFile.canRead()) {
|
||||||
|
JsonElement element = JsonUtils.parseJsonFile(configFile);
|
||||||
|
|
||||||
|
if (element != null && element.isJsonObject()) {
|
||||||
|
JsonObject root = element.getAsJsonObject();
|
||||||
|
|
||||||
|
ConfigUtils.readConfigBase(root, "Generic", Generic.OPTIONS);
|
||||||
|
ConfigUtils.readConfigBase(root, "Hotkeys", Hotkeys.HOTKEY_LIST);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static class Toggles
|
public static void saveToFile() {
|
||||||
{
|
File dir = FileUtils.getConfigDirectory();
|
||||||
public static final ImmutableList<IConfigValue> OPTIONS = ImmutableList.of(
|
|
||||||
);
|
if ((dir.exists() && dir.isDirectory()) || dir.mkdirs()) {
|
||||||
|
JsonObject root = new JsonObject();
|
||||||
|
|
||||||
|
ConfigUtils.writeConfigBase(root, "Generic", Generic.OPTIONS);
|
||||||
|
ConfigUtils.writeConfigBase(root, "Hotkeys", Hotkeys.HOTKEY_LIST);
|
||||||
|
|
||||||
|
JsonUtils.writeJsonToFile(root, new File(dir, CONFIG_FILE_NAME));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static final Set<String> GUI_BLACKLIST = new HashSet<>();
|
@Override
|
||||||
public static final Set<String> SLOT_BLACKLIST = new HashSet<>();
|
public void load() {
|
||||||
|
loadFromFile();
|
||||||
|
}
|
||||||
|
|
||||||
public static void loadFromFile()
|
@Override
|
||||||
{
|
public void save() {
|
||||||
File configFile = new File(FileUtils.getConfigDirectory(), CONFIG_FILE_NAME);
|
saveToFile();
|
||||||
|
}
|
||||||
if (configFile.exists() && configFile.isFile() && configFile.canRead())
|
|
||||||
{
|
|
||||||
JsonElement element = JsonUtils.parseJsonFile(configFile);
|
|
||||||
|
|
||||||
if (element != null && element.isJsonObject())
|
|
||||||
{
|
|
||||||
JsonObject root = element.getAsJsonObject();
|
|
||||||
|
|
||||||
ConfigUtils.readConfigBase(root, "Generic", Generic.OPTIONS);
|
|
||||||
ConfigUtils.readConfigBase(root, "Hotkeys", Hotkeys.HOTKEY_LIST);
|
|
||||||
ConfigUtils.readConfigBase(root, "Toggles", Toggles.OPTIONS);
|
|
||||||
|
|
||||||
getStrings(root, GUI_BLACKLIST, "guiBlacklist");
|
|
||||||
getStrings(root, SLOT_BLACKLIST, "slotBlacklist");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void saveToFile()
|
|
||||||
{
|
|
||||||
File dir = FileUtils.getConfigDirectory();
|
|
||||||
|
|
||||||
if ((dir.exists() && dir.isDirectory()) || dir.mkdirs())
|
|
||||||
{
|
|
||||||
JsonObject root = new JsonObject();
|
|
||||||
|
|
||||||
ConfigUtils.writeConfigBase(root, "Generic", Generic.OPTIONS);
|
|
||||||
ConfigUtils.writeConfigBase(root, "Hotkeys", Hotkeys.HOTKEY_LIST);
|
|
||||||
ConfigUtils.writeConfigBase(root, "Toggles", Toggles.OPTIONS);
|
|
||||||
|
|
||||||
writeStrings(root, GUI_BLACKLIST, "guiBlacklist");
|
|
||||||
writeStrings(root, SLOT_BLACKLIST, "slotBlacklist");
|
|
||||||
|
|
||||||
JsonUtils.writeJsonToFile(root, new File(dir, CONFIG_FILE_NAME));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void load()
|
|
||||||
{
|
|
||||||
loadFromFile();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void save()
|
|
||||||
{
|
|
||||||
saveToFile();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void getStrings(JsonObject obj, Set<String> outputSet, String arrayName)
|
|
||||||
{
|
|
||||||
outputSet.clear();
|
|
||||||
|
|
||||||
if (JsonUtils.hasArray(obj, arrayName))
|
|
||||||
{
|
|
||||||
JsonArray arr = obj.getAsJsonArray(arrayName);
|
|
||||||
final int size = arr.size();
|
|
||||||
|
|
||||||
for (int i = 0; i < size; i++)
|
|
||||||
{
|
|
||||||
outputSet.add(arr.get(i).getAsString());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void writeStrings(JsonObject obj, Set<String> inputSet, String arrayName)
|
|
||||||
{
|
|
||||||
if (inputSet.isEmpty() == false)
|
|
||||||
{
|
|
||||||
JsonArray arr = new JsonArray();
|
|
||||||
|
|
||||||
for (String str : inputSet)
|
|
||||||
{
|
|
||||||
arr.add(str);
|
|
||||||
}
|
|
||||||
|
|
||||||
obj.add(arrayName, arr);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,13 +1,22 @@
|
|||||||
package com.github.sebseb7.autotrade.config;
|
package com.github.sebseb7.autotrade.config;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import com.google.common.collect.ImmutableList;
|
import com.google.common.collect.ImmutableList;
|
||||||
import fi.dy.masa.malilib.config.options.ConfigHotkey;
|
import fi.dy.masa.malilib.config.options.ConfigHotkey;
|
||||||
import fi.dy.masa.malilib.hotkeys.KeyAction;
|
import java.util.List;
|
||||||
import fi.dy.masa.malilib.hotkeys.KeybindSettings;
|
|
||||||
|
|
||||||
public class Hotkeys
|
public class Hotkeys {
|
||||||
{
|
public static final ConfigHotkey TOGGLE_KEY =
|
||||||
public static final List<ConfigHotkey> HOTKEY_LIST = ImmutableList.of(
|
new ConfigHotkey("toggleTrading", "", "Enables / disables auto trading");
|
||||||
);
|
public static final ConfigHotkey SET_INPUT_KEY =
|
||||||
|
new ConfigHotkey("setInputContainer", "", "Sets the input (item to sell) container");
|
||||||
|
public static final ConfigHotkey SET_OUTPUT_KEY =
|
||||||
|
new ConfigHotkey("setOutputContainer", "", "Sets the output (item bought) container");
|
||||||
|
public static final ConfigHotkey SET_EMERALD_KEY =
|
||||||
|
new ConfigHotkey("setEmeraldContainer", "", "Set the emerald container");
|
||||||
|
public static final ConfigHotkey OPEN_GUI_SETTINGS =
|
||||||
|
new ConfigHotkey("openGuiSettings", "", "Open the Config GUI");
|
||||||
|
|
||||||
|
public static final List<ConfigHotkey> HOTKEY_LIST =
|
||||||
|
ImmutableList.of(
|
||||||
|
TOGGLE_KEY, SET_INPUT_KEY, SET_OUTPUT_KEY, SET_EMERALD_KEY, OPEN_GUI_SETTINGS);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,130 +1,106 @@
|
|||||||
package com.github.sebseb7.autotrade.gui;
|
package com.github.sebseb7.autotrade.gui;
|
||||||
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
|
||||||
import com.google.common.collect.ImmutableList;
|
|
||||||
import com.github.sebseb7.autotrade.Reference;
|
import com.github.sebseb7.autotrade.Reference;
|
||||||
import com.github.sebseb7.autotrade.config.Configs;
|
import com.github.sebseb7.autotrade.config.Configs;
|
||||||
import com.github.sebseb7.autotrade.config.Hotkeys;
|
import com.github.sebseb7.autotrade.config.Hotkeys;
|
||||||
|
import com.google.common.collect.ImmutableList;
|
||||||
import fi.dy.masa.malilib.config.IConfigBase;
|
import fi.dy.masa.malilib.config.IConfigBase;
|
||||||
import fi.dy.masa.malilib.gui.GuiConfigsBase;
|
import fi.dy.masa.malilib.gui.GuiConfigsBase;
|
||||||
import fi.dy.masa.malilib.gui.button.ButtonBase;
|
import fi.dy.masa.malilib.gui.button.ButtonBase;
|
||||||
import fi.dy.masa.malilib.gui.button.ButtonGeneric;
|
import fi.dy.masa.malilib.gui.button.ButtonGeneric;
|
||||||
import fi.dy.masa.malilib.gui.button.IButtonActionListener;
|
import fi.dy.masa.malilib.gui.button.IButtonActionListener;
|
||||||
import fi.dy.masa.malilib.util.StringUtils;
|
import fi.dy.masa.malilib.util.StringUtils;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public class GuiConfigs extends GuiConfigsBase
|
public class GuiConfigs extends GuiConfigsBase {
|
||||||
{
|
private static ConfigGuiTab tab = ConfigGuiTab.GENERIC;
|
||||||
private static ConfigGuiTab tab = ConfigGuiTab.GENERIC;
|
|
||||||
|
|
||||||
public GuiConfigs()
|
public GuiConfigs() {
|
||||||
{
|
super(10, 50, Reference.MOD_ID, null, "autotrade.gui.title.configs");
|
||||||
super(10, 50, Reference.MOD_ID, null, "autotrade.gui.title.configs");
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void initGui() {
|
||||||
|
super.initGui();
|
||||||
|
this.clearOptions();
|
||||||
|
|
||||||
|
int x = 10;
|
||||||
|
int y = 26;
|
||||||
|
|
||||||
|
for (ConfigGuiTab tab : ConfigGuiTab.VALUES) {
|
||||||
|
x += this.createButton(x, y, -1, tab);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private int createButton(int x, int y, int width, ConfigGuiTab tab) {
|
||||||
|
ButtonGeneric button = new ButtonGeneric(x, y, width, 20, tab.getDisplayName());
|
||||||
|
button.setEnabled(GuiConfigs.tab != tab);
|
||||||
|
this.addButton(button, new ButtonListener(tab, this));
|
||||||
|
|
||||||
|
return button.getWidth() + 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected int getConfigWidth() {
|
||||||
|
ConfigGuiTab tab = GuiConfigs.tab;
|
||||||
|
|
||||||
|
if (tab == ConfigGuiTab.GENERIC) {
|
||||||
|
return 200;
|
||||||
|
}
|
||||||
|
|
||||||
|
return super.getConfigWidth();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<ConfigOptionWrapper> getConfigs() {
|
||||||
|
List<? extends IConfigBase> configs;
|
||||||
|
ConfigGuiTab tab = GuiConfigs.tab;
|
||||||
|
|
||||||
|
if (tab == ConfigGuiTab.GENERIC) {
|
||||||
|
configs = Configs.Generic.OPTIONS;
|
||||||
|
} else if (tab == ConfigGuiTab.HOTKEYS) {
|
||||||
|
configs = Hotkeys.HOTKEY_LIST;
|
||||||
|
} else {
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
|
||||||
|
return ConfigOptionWrapper.createFor(configs);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class ButtonListener implements IButtonActionListener {
|
||||||
|
private final GuiConfigs parent;
|
||||||
|
private final ConfigGuiTab tab;
|
||||||
|
|
||||||
|
public ButtonListener(ConfigGuiTab tab, GuiConfigs parent) {
|
||||||
|
this.tab = tab;
|
||||||
|
this.parent = parent;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void initGui()
|
public void actionPerformedWithButton(ButtonBase button, int mouseButton) {
|
||||||
{
|
GuiConfigs.tab = this.tab;
|
||||||
super.initGui();
|
|
||||||
this.clearOptions();
|
|
||||||
|
|
||||||
int x = 10;
|
this.parent.reCreateListWidget(); // apply the new config width
|
||||||
int y = 26;
|
this.parent.getListWidget().resetScrollbarPosition();
|
||||||
|
this.parent.initGui();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
for (ConfigGuiTab tab : ConfigGuiTab.VALUES)
|
public enum ConfigGuiTab {
|
||||||
{
|
GENERIC("autotrade.gui.button.config_gui.generic"),
|
||||||
x += this.createButton(x, y, -1, tab);
|
HOTKEYS("autotrade.gui.button.config_gui.hotkeys");
|
||||||
}
|
|
||||||
|
private final String translationKey;
|
||||||
|
|
||||||
|
public static final ImmutableList<ConfigGuiTab> VALUES = ImmutableList.copyOf(values());
|
||||||
|
|
||||||
|
ConfigGuiTab(String translationKey) {
|
||||||
|
this.translationKey = translationKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
private int createButton(int x, int y, int width, ConfigGuiTab tab)
|
public String getDisplayName() {
|
||||||
{
|
return StringUtils.translate(this.translationKey);
|
||||||
ButtonGeneric button = new ButtonGeneric(x, y, width, 20, tab.getDisplayName());
|
|
||||||
button.setEnabled(GuiConfigs.tab != tab);
|
|
||||||
this.addButton(button, new ButtonListener(tab, this));
|
|
||||||
|
|
||||||
return button.getWidth() + 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected int getConfigWidth()
|
|
||||||
{
|
|
||||||
ConfigGuiTab tab = GuiConfigs.tab;
|
|
||||||
|
|
||||||
if (tab == ConfigGuiTab.GENERIC || tab == ConfigGuiTab.TOGGLES)
|
|
||||||
{
|
|
||||||
return 100;
|
|
||||||
}
|
|
||||||
|
|
||||||
return super.getConfigWidth();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<ConfigOptionWrapper> getConfigs()
|
|
||||||
{
|
|
||||||
List<? extends IConfigBase> configs;
|
|
||||||
ConfigGuiTab tab = GuiConfigs.tab;
|
|
||||||
|
|
||||||
if (tab == ConfigGuiTab.GENERIC)
|
|
||||||
{
|
|
||||||
configs = Configs.Generic.OPTIONS;
|
|
||||||
}
|
|
||||||
else if (tab == ConfigGuiTab.TOGGLES)
|
|
||||||
{
|
|
||||||
configs = Configs.Toggles.OPTIONS;
|
|
||||||
}
|
|
||||||
else if (tab == ConfigGuiTab.HOTKEYS)
|
|
||||||
{
|
|
||||||
configs = Hotkeys.HOTKEY_LIST;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return Collections.emptyList();
|
|
||||||
}
|
|
||||||
|
|
||||||
return ConfigOptionWrapper.createFor(configs);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static class ButtonListener implements IButtonActionListener
|
|
||||||
{
|
|
||||||
private final GuiConfigs parent;
|
|
||||||
private final ConfigGuiTab tab;
|
|
||||||
|
|
||||||
public ButtonListener(ConfigGuiTab tab, GuiConfigs parent)
|
|
||||||
{
|
|
||||||
this.tab = tab;
|
|
||||||
this.parent = parent;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void actionPerformedWithButton(ButtonBase button, int mouseButton)
|
|
||||||
{
|
|
||||||
GuiConfigs.tab = this.tab;
|
|
||||||
|
|
||||||
this.parent.reCreateListWidget(); // apply the new config width
|
|
||||||
this.parent.getListWidget().resetScrollbarPosition();
|
|
||||||
this.parent.initGui();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public enum ConfigGuiTab
|
|
||||||
{
|
|
||||||
GENERIC ("autotrade.gui.button.config_gui.generic"),
|
|
||||||
TOGGLES ("autotrade.gui.button.config_gui.toggles"),
|
|
||||||
HOTKEYS ("autotrade.gui.button.config_gui.hotkeys");
|
|
||||||
|
|
||||||
private final String translationKey;
|
|
||||||
|
|
||||||
public static final ImmutableList<ConfigGuiTab> VALUES = ImmutableList.copyOf(values());
|
|
||||||
|
|
||||||
ConfigGuiTab(String translationKey)
|
|
||||||
{
|
|
||||||
this.translationKey = translationKey;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getDisplayName()
|
|
||||||
{
|
|
||||||
return StringUtils.translate(this.translationKey);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user