finish kerosene migration
This commit is contained in:
parent
dc5e13f88c
commit
34e23e5fcb
40 changed files with 201 additions and 2585 deletions
|
@ -9,7 +9,7 @@ org.gradle.jvmargs=-Xmx1G
|
||||||
|
|
||||||
# Mod Properties
|
# Mod Properties
|
||||||
mod_version = 0.1.5-SNAPSHOT
|
mod_version = 0.1.5-SNAPSHOT
|
||||||
kerosene_version = 0.1.6-SNAPSHOT
|
kerosene_version = 0.1.6
|
||||||
maven_group = pm.j4
|
maven_group = pm.j4
|
||||||
archives_base_name = petroleum
|
archives_base_name = petroleum
|
||||||
|
|
||||||
|
|
|
@ -1,26 +1,16 @@
|
||||||
package pm.j4.petroleum;
|
package pm.j4.petroleum;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import net.fabricmc.api.ModInitializer;
|
import net.fabricmc.api.ModInitializer;
|
||||||
import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientTickEvents;
|
|
||||||
import net.fabricmc.loader.api.FabricLoader;
|
import net.fabricmc.loader.api.FabricLoader;
|
||||||
import net.fabricmc.loader.api.ModContainer;
|
import net.fabricmc.loader.api.ModContainer;
|
||||||
import net.fabricmc.loader.api.metadata.ModMetadata;
|
import net.fabricmc.loader.api.metadata.ModMetadata;
|
||||||
import net.minecraft.client.MinecraftClient;
|
import pm.j4.kerosene.util.config.Module;
|
||||||
import net.minecraft.client.options.KeyBinding;
|
|
||||||
import net.minecraft.server.integrated.IntegratedServer;
|
|
||||||
import pm.j4.petroleum.modules.ExampleModule;
|
|
||||||
import pm.j4.petroleum.modules.bindings.BindingManager;
|
|
||||||
import pm.j4.petroleum.modules.list.ModList;
|
import pm.j4.petroleum.modules.list.ModList;
|
||||||
import pm.j4.petroleum.modules.menu.ModMenu;
|
import pm.j4.petroleum.modules.menu.ModMenu;
|
||||||
import pm.j4.petroleum.modules.splash.SplashText;
|
import pm.j4.petroleum.modules.splash.SplashText;
|
||||||
import pm.j4.petroleum.modules.xray.Xray;
|
import pm.j4.petroleum.modules.xray.Xray;
|
||||||
import pm.j4.petroleum.util.config.ConfigHolder;
|
import pm.j4.kerosene.util.config.ConfigManager;
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
|
|
||||||
//TODO:
|
//TODO:
|
||||||
|
@ -34,135 +24,35 @@ import pm.j4.petroleum.util.module.ModuleBase;
|
||||||
// [ ] elytra bhop
|
// [ ] elytra bhop
|
||||||
// [ ] boatfly
|
// [ ] boatfly
|
||||||
// [ ] anti anti cheat
|
// [ ] anti anti cheat
|
||||||
|
// [ ] held (not toggled) keybinds (impl in kerosene)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type Petroleum mod.
|
* The type Petroleum mod.
|
||||||
*/
|
*/
|
||||||
|
@Module(SplashText.class)
|
||||||
|
@Module(ModMenu.class)
|
||||||
|
@Module(ModList.class)
|
||||||
|
@Module(Xray.class)
|
||||||
public class PetroleumMod implements ModInitializer {
|
public class PetroleumMod implements ModInitializer {
|
||||||
/**
|
/**
|
||||||
* The Mod data.
|
* The Mod data.
|
||||||
*/
|
*/
|
||||||
public static ModMetadata modData = null;
|
public static ModMetadata modData = null;
|
||||||
/**
|
|
||||||
* The constant client.
|
|
||||||
*/
|
|
||||||
private static MinecraftClient client;
|
|
||||||
/**
|
|
||||||
* The constant activeMods.
|
|
||||||
*/
|
|
||||||
private static final List<ModuleBase> activeMods = Arrays.asList(
|
|
||||||
new SplashText(),
|
|
||||||
new ModMenu(),
|
|
||||||
new ModList(),
|
|
||||||
new BindingManager(),
|
|
||||||
new ExampleModule(),
|
|
||||||
new Xray()
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Is active boolean.
|
|
||||||
*
|
|
||||||
* @param modName the mod name
|
|
||||||
* @return the boolean
|
|
||||||
*/
|
|
||||||
public static boolean isActive(String modName) {
|
|
||||||
return activeMods.stream().anyMatch(mod -> mod.getModuleName().equals(modName));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets mod.
|
|
||||||
*
|
|
||||||
* @param modName the mod name
|
|
||||||
* @return the mod
|
|
||||||
*/
|
|
||||||
public static Optional<ModuleBase> getMod(String modName) {
|
|
||||||
return activeMods.stream().filter(mod -> mod.getModuleName().equals(modName)).findFirst();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets active mods.
|
|
||||||
*
|
|
||||||
* @return the active mods
|
|
||||||
*/
|
|
||||||
public static List<ModuleBase> getActiveMods() {
|
|
||||||
return activeMods;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The constant registeredBinds.
|
|
||||||
*/
|
|
||||||
private static final List<KeyBinding> registeredBinds = new ArrayList<>();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add bind.
|
|
||||||
*
|
|
||||||
* @param b the b
|
|
||||||
*/
|
|
||||||
public static void addBind(KeyBinding b) {
|
|
||||||
registeredBinds.add(b);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Remove bind.
|
|
||||||
*
|
|
||||||
* @param b the b
|
|
||||||
*/
|
|
||||||
public static void removeBind(KeyBinding b) {
|
|
||||||
registeredBinds.remove(b);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets active keybinds.
|
|
||||||
*
|
|
||||||
* @return the active keybinds
|
|
||||||
*/
|
|
||||||
public static List<KeyBinding> getActiveKeybinds() {
|
|
||||||
return registeredBinds;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets server address.
|
|
||||||
*
|
|
||||||
* @return the server address
|
|
||||||
*/
|
|
||||||
public static String getServerAddress() {
|
|
||||||
if (client != null && client.getServer() != null) {
|
|
||||||
IntegratedServer server = client.getServer();
|
|
||||||
if (!server.isRemote()) {
|
|
||||||
return "localhost";
|
|
||||||
}
|
|
||||||
if (server.isRemote() && !server.getServerIp().isEmpty()) {
|
|
||||||
return server.getServerIp();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onInitialize() {
|
public void onInitialize() {
|
||||||
|
|
||||||
ConfigManager.initConfig();
|
ConfigManager.initConfig("petroleum", PetroleumMod.class);
|
||||||
|
|
||||||
// always update mod data
|
// always update mod data
|
||||||
Optional<ModContainer> modContainer = FabricLoader.getInstance().getModContainer("petroleum");
|
Optional<ModContainer> modContainer = FabricLoader.getInstance().getModContainer("petroleum");
|
||||||
modContainer.ifPresent(container -> modData = container.getMetadata());
|
modContainer.ifPresent(container -> modData = container.getMetadata());
|
||||||
|
|
||||||
Optional<ConfigHolder> conf = ConfigManager.getConfig();
|
try {
|
||||||
|
//register mods
|
||||||
|
|
||||||
//initialize any keybinds, data, etc.
|
|
||||||
activeMods.forEach(ModuleBase::init);
|
|
||||||
|
|
||||||
//initialize keybind handler
|
|
||||||
conf.ifPresent(configHolder -> ClientTickEvents.END_CLIENT_TICK.register(client -> {
|
|
||||||
if (PetroleumMod.client != client) {
|
|
||||||
PetroleumMod.client = client;
|
|
||||||
}
|
}
|
||||||
for (KeyBinding b : PetroleumMod.getActiveKeybinds()) {
|
catch (Exception e) {
|
||||||
while (b.wasPressed()) {
|
System.out.println(e);
|
||||||
configHolder.globalConfig.bindings.get(b).activate(client);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,16 +2,18 @@ package pm.j4.petroleum.gui;
|
||||||
|
|
||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
import com.mojang.blaze3d.systems.RenderSystem;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
import net.minecraft.client.gui.screen.Screen;
|
import net.minecraft.client.gui.screen.Screen;
|
||||||
import net.minecraft.client.render.BufferBuilder;
|
import net.minecraft.client.render.BufferBuilder;
|
||||||
import net.minecraft.client.render.Tessellator;
|
import net.minecraft.client.render.Tessellator;
|
||||||
import net.minecraft.client.render.VertexFormats;
|
import net.minecraft.client.render.VertexFormats;
|
||||||
import net.minecraft.client.util.math.MatrixStack;
|
import net.minecraft.client.util.math.MatrixStack;
|
||||||
import net.minecraft.text.TranslatableText;
|
import net.minecraft.text.TranslatableText;
|
||||||
|
import pm.j4.kerosene.util.config.ConfigHolder;
|
||||||
|
import pm.j4.kerosene.util.data.Category;
|
||||||
import pm.j4.petroleum.modules.menu.ModMenu;
|
import pm.j4.petroleum.modules.menu.ModMenu;
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
import pm.j4.kerosene.util.config.ConfigManager;
|
||||||
import pm.j4.petroleum.util.data.ButtonInformation;
|
import pm.j4.petroleum.util.data.ButtonInformation;
|
||||||
import pm.j4.petroleum.util.data.Category;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type P mod menu screen.
|
* The type P mod menu screen.
|
||||||
|
@ -45,10 +47,11 @@ public class PModMenuScreen extends Screen {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onClose() {
|
public void onClose() {
|
||||||
if (ConfigManager.getConfig().isPresent()) {
|
Optional<ConfigHolder> config = ConfigManager.getConfig("petroleum");
|
||||||
ConfigManager.getConfig().get().disableModule("petroleum.modmenu");
|
if (config.isPresent()) {
|
||||||
|
config.get().disableModule("petroleum.modmenu");
|
||||||
this.buttons.forEach(button -> ((PMovableButton) button).updateCoordinate());
|
this.buttons.forEach(button -> ((PMovableButton) button).updateCoordinate());
|
||||||
ConfigManager.saveGlobalConfig();
|
ConfigManager.saveGlobalConfig("petroleum");
|
||||||
}
|
}
|
||||||
super.onClose();
|
super.onClose();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,194 +0,0 @@
|
||||||
package pm.j4.petroleum.gui;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Optional;
|
|
||||||
import net.minecraft.client.MinecraftClient;
|
|
||||||
import net.minecraft.client.gui.Element;
|
|
||||||
import net.minecraft.client.gui.widget.AbstractButtonWidget;
|
|
||||||
import net.minecraft.client.gui.widget.ButtonWidget;
|
|
||||||
import net.minecraft.client.gui.widget.ElementListWidget;
|
|
||||||
import net.minecraft.client.options.KeyBinding;
|
|
||||||
import net.minecraft.client.util.math.MatrixStack;
|
|
||||||
import net.minecraft.text.LiteralText;
|
|
||||||
import net.minecraft.text.Text;
|
|
||||||
import pm.j4.petroleum.util.config.ConfigHolder;
|
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
|
||||||
import pm.j4.petroleum.util.module.option.BooleanOption;
|
|
||||||
import pm.j4.petroleum.util.module.option.ConfigurationOption;
|
|
||||||
import pm.j4.petroleum.util.module.option.KeybindOption;
|
|
||||||
import pm.j4.petroleum.util.module.option.ListOption;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type P module config entry.
|
|
||||||
*/
|
|
||||||
public class PModuleConfigEntry extends ElementListWidget.Entry<PModuleConfigEntry> {
|
|
||||||
/**
|
|
||||||
* The Option.
|
|
||||||
*/
|
|
||||||
protected ConfigurationOption option;
|
|
||||||
/**
|
|
||||||
* The Display text.
|
|
||||||
*/
|
|
||||||
protected final Text displayText;
|
|
||||||
|
|
||||||
private PModuleConfigPane parent;
|
|
||||||
|
|
||||||
private List<Element> elements = new ArrayList<>();
|
|
||||||
|
|
||||||
private String trueValue;
|
|
||||||
private String falseValue;
|
|
||||||
|
|
||||||
private Element selected;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new P module config entry.
|
|
||||||
*
|
|
||||||
* @param option the option
|
|
||||||
* @param text the text
|
|
||||||
*/
|
|
||||||
public PModuleConfigEntry(ConfigurationOption option, Text text, PModuleConfigPane parent) {
|
|
||||||
this.option = option;
|
|
||||||
this.displayText = text;
|
|
||||||
this.parent = parent;
|
|
||||||
this.trueValue = "Yes";
|
|
||||||
this.falseValue = "No";
|
|
||||||
}
|
|
||||||
|
|
||||||
public PModuleConfigEntry(ConfigurationOption option, Text text, PModuleConfigPane parent, String trueValue, String falseValue) {
|
|
||||||
this.option = option;
|
|
||||||
this.displayText = text;
|
|
||||||
this.parent = parent;
|
|
||||||
this.trueValue = trueValue;
|
|
||||||
this.falseValue = falseValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<? extends Element> children() {
|
|
||||||
return elements;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean mouseClicked(double mouseX, double mouseY, int button) {
|
|
||||||
if (this.isMouseOver(mouseX, mouseY)) {
|
|
||||||
this.parent.setSelected(this);
|
|
||||||
System.out.println(displayText.getString() + " clicked");
|
|
||||||
String className = option.getClass().toString();
|
|
||||||
elements.forEach((widget) -> {
|
|
||||||
if (widget.mouseClicked(mouseX, mouseY, button)) {
|
|
||||||
System.out.println("Button clicked");
|
|
||||||
selected = widget;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean mouseReleased(double mouseX, double mouseY, int button) {
|
|
||||||
return this.isMouseOver(mouseX, mouseY);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean keyPressed(int keyCode, int scanCode, int modifiers) {
|
|
||||||
if(this.selected != null) {
|
|
||||||
return this.selected.keyPressed(keyCode, scanCode, modifiers);
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean keyReleased(int keyCode, int scanCode, int modifiers) {
|
|
||||||
if(this.selected != null) {
|
|
||||||
return this.selected.keyReleased(keyCode, scanCode, modifiers);
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void render(MatrixStack matrices, int index, int y, int x, int entryWidth, int entryHeight, int mouseX, int mouseY, boolean hovered, float tickDelta) {
|
|
||||||
if (this.displayText != null) {
|
|
||||||
MinecraftClient.getInstance().textRenderer.drawWithShadow(matrices, displayText, x, y, 0xAAAAAA);
|
|
||||||
}
|
|
||||||
System.out.println(option);
|
|
||||||
if (this.option != null) {
|
|
||||||
//TODO option text box (?)
|
|
||||||
// option should be centered or otherwise offset
|
|
||||||
// but not extend past the side of the pane
|
|
||||||
int fontHeight = MinecraftClient.getInstance().textRenderer.fontHeight;
|
|
||||||
//TODO use TranslatableText instead of LiteralText
|
|
||||||
MinecraftClient.getInstance().textRenderer.drawWithShadow(matrices, new LiteralText(option.getDescription() + " " + option.getStringValue()), x, y + fontHeight + 4, 0xFFFFFF);
|
|
||||||
|
|
||||||
System.out.println(elements.size());
|
|
||||||
if(elements.size() == 0) {
|
|
||||||
String className = option.getClass().toString();
|
|
||||||
System.out.println(className);
|
|
||||||
if (className.equals(BooleanOption.class.toString())) {
|
|
||||||
System.out.println("boolean");
|
|
||||||
elements.add(new ButtonWidget(x, y + (int)(fontHeight * 2.5),
|
|
||||||
entryWidth,
|
|
||||||
fontHeight * 2,
|
|
||||||
new LiteralText(((BooleanOption)option).getValue() ? this.trueValue : this.falseValue), (button) -> {
|
|
||||||
button.setMessage(new LiteralText((!((BooleanOption)option).getValue()) ? this.trueValue : this.falseValue));
|
|
||||||
BooleanOption newValue = new BooleanOption(option.getConfigKey(), option.getDescription(), option.getParent());
|
|
||||||
newValue.setValue((!((BooleanOption)option).getValue()));
|
|
||||||
option.getParent().updateConfigOption(newValue.getConfigKey(), newValue);
|
|
||||||
this.option = newValue;
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
else if (className.equals(ListOption.class.toString())) {
|
|
||||||
// TODO: determine whether list options are viable,
|
|
||||||
// considering that it would be easier to split lists into multiple PModuleConfigEntries
|
|
||||||
System.out.println("list");
|
|
||||||
}
|
|
||||||
else if (className.equals(KeybindOption.class.toString())) {
|
|
||||||
System.out.println("keybind");
|
|
||||||
ButtonWidget bindButton = new ButtonWidget(x, y + (int)(fontHeight * 2.5),
|
|
||||||
entryWidth,
|
|
||||||
fontHeight * 2,
|
|
||||||
new LiteralText(option.getStringValue().toUpperCase()), (button) -> {
|
|
||||||
button.setMessage(new LiteralText("Press any key..."));
|
|
||||||
}) {
|
|
||||||
@Override
|
|
||||||
public boolean keyPressed(int keyCode, int scanCode, int modifiers) {
|
|
||||||
if (this.active && this.visible) {
|
|
||||||
//TODO
|
|
||||||
if (keyCode != 257 && keyCode != 32 && keyCode != 335) {
|
|
||||||
KeybindOption newValue = new KeybindOption(option.getConfigKey(), option.getDescription(), option.getParent());
|
|
||||||
KeyBinding bind = new KeyBinding(((KeybindOption)option).getTranslationKey(), keyCode, "category.petroleum");
|
|
||||||
newValue.fromKeybind(bind, option.getParent());
|
|
||||||
Optional<ConfigHolder> config = ConfigManager.getConfig();
|
|
||||||
assert config.isPresent();
|
|
||||||
config.get().globalConfig.setBinding(bind, option.getParent());
|
|
||||||
option = newValue;
|
|
||||||
this.setMessage(new LiteralText(option.getStringValue().toUpperCase()));
|
|
||||||
selected = null;
|
|
||||||
return false;
|
|
||||||
} else {
|
|
||||||
this.playDownSound(MinecraftClient.getInstance().getSoundManager());
|
|
||||||
this.onPress();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
elements.add(bindButton);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
System.out.println("other/string");
|
|
||||||
//TODO
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
elements.forEach((widget) -> {
|
|
||||||
if (widget instanceof AbstractButtonWidget) {
|
|
||||||
((AbstractButtonWidget)widget).render(matrices, mouseX, mouseY, tickDelta);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,120 +0,0 @@
|
||||||
package pm.j4.petroleum.gui;
|
|
||||||
|
|
||||||
import com.mojang.blaze3d.platform.GlStateManager;
|
|
||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
|
||||||
import net.minecraft.client.MinecraftClient;
|
|
||||||
import net.minecraft.client.font.TextRenderer;
|
|
||||||
import net.minecraft.client.gui.widget.ElementListWidget;
|
|
||||||
import net.minecraft.client.gui.widget.EntryListWidget;
|
|
||||||
import net.minecraft.client.render.BufferBuilder;
|
|
||||||
import net.minecraft.client.render.Tessellator;
|
|
||||||
import net.minecraft.client.render.VertexFormats;
|
|
||||||
import net.minecraft.client.util.math.MatrixStack;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type P module config pane.
|
|
||||||
*/
|
|
||||||
public class PModuleConfigPane extends ElementListWidget<PModuleConfigEntry> {
|
|
||||||
/**
|
|
||||||
* The Parent.
|
|
||||||
*/
|
|
||||||
private final POptionsScreen parent;
|
|
||||||
/**
|
|
||||||
* The Last selected.
|
|
||||||
*/
|
|
||||||
private POptionEntry lastSelected;
|
|
||||||
|
|
||||||
private PModuleConfigEntry selectedConfigEntry;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new P module config pane.
|
|
||||||
*
|
|
||||||
* @param client the client
|
|
||||||
* @param width the width
|
|
||||||
* @param height the height
|
|
||||||
* @param top the top
|
|
||||||
* @param bottom the bottom
|
|
||||||
* @param entryHeight the entry height
|
|
||||||
* @param screen the screen
|
|
||||||
*/
|
|
||||||
public PModuleConfigPane(MinecraftClient client, int width, int height, int top, int bottom, int entryHeight, POptionsScreen screen) {
|
|
||||||
super(client, width, height, top, bottom, entryHeight);
|
|
||||||
this.parent = screen;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSelected(PModuleConfigEntry entry) {
|
|
||||||
selectedConfigEntry = entry;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public PModuleConfigEntry getSelected() {
|
|
||||||
return selectedConfigEntry;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getRowWidth() {
|
|
||||||
return this.width - 10;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected int getScrollbarPositionX() {
|
|
||||||
return this.width - 6 + left;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void render(MatrixStack matrices, int mouseX, int mouseY, float delta) {
|
|
||||||
POptionEntry selectedEntry = parent.getSelected();
|
|
||||||
if (selectedEntry != lastSelected) {
|
|
||||||
lastSelected = selectedEntry;
|
|
||||||
clearEntries();
|
|
||||||
setScrollAmount(-Double.MAX_VALUE);
|
|
||||||
String id = lastSelected.getModId();
|
|
||||||
if (lastSelected != null && id != null && !id.isEmpty()) {
|
|
||||||
children().addAll(lastSelected.module.getConfigEntries(this));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Tessellator t_1 = Tessellator.getInstance();
|
|
||||||
BufferBuilder buffer = t_1.getBuffer();
|
|
||||||
|
|
||||||
RenderSystem.depthFunc(515);
|
|
||||||
RenderSystem.disableDepthTest();
|
|
||||||
RenderSystem.enableBlend();
|
|
||||||
RenderSystem.blendFuncSeparate(GlStateManager.SrcFactor.SRC_ALPHA,
|
|
||||||
GlStateManager.DstFactor.ONE_MINUS_DST_ALPHA,
|
|
||||||
GlStateManager.SrcFactor.ZERO,
|
|
||||||
GlStateManager.DstFactor.ONE);
|
|
||||||
RenderSystem.disableAlphaTest();
|
|
||||||
RenderSystem.shadeModel(7425);
|
|
||||||
RenderSystem.disableTexture();
|
|
||||||
|
|
||||||
// darken config pane area
|
|
||||||
|
|
||||||
buffer.begin(7, VertexFormats.POSITION_COLOR_TEXTURE);
|
|
||||||
buffer.vertex(this.left, (this.top + 4), 0.0D).color(0, 0, 0, 0).texture(0.0F, 1.0F).next();
|
|
||||||
buffer.vertex(this.right, (this.top + 4), 0.0D).color(0, 0, 0, 0).texture(1.0F, 1.0F).next();
|
|
||||||
buffer.vertex(this.right, this.top, 0.0D).color(0, 0, 0, 255).texture(1.0F, 0.0F).next();
|
|
||||||
buffer.vertex(this.left, this.top, 0.0D).color(0, 0, 0, 255).texture(0.0F, 0.0F).next();
|
|
||||||
buffer.vertex(this.left, this.bottom, 0.0D).color(0, 0, 0, 255).texture(0.0F, 1.0F).next();
|
|
||||||
buffer.vertex(this.right, this.bottom, 0.0D).color(0, 0, 0, 255).texture(1.0F, 1.0F).next();
|
|
||||||
buffer.vertex(this.right, (this.bottom - 4), 0.0D).color(0, 0, 0, 0).texture(1.0F, 0.0F).next();
|
|
||||||
buffer.vertex(this.left, (this.bottom - 4), 0.0D).color(0, 0, 0, 0).texture(0.0F, 0.0F).next();
|
|
||||||
t_1.draw();
|
|
||||||
|
|
||||||
buffer.begin(7, VertexFormats.POSITION_COLOR);
|
|
||||||
buffer.vertex(this.left, this.bottom, 0.0D).color(0, 0, 0, 128).next();
|
|
||||||
buffer.vertex(this.right, this.bottom, 0.0D).color(0, 0, 0, 128).next();
|
|
||||||
buffer.vertex(this.right, this.top, 0.0D).color(0, 0, 0, 128).next();
|
|
||||||
buffer.vertex(this.left, this.top, 0.0D).color(0, 0, 0, 128).next();
|
|
||||||
t_1.draw();
|
|
||||||
|
|
||||||
int rl = this.getRowLeft();
|
|
||||||
int sc = this.top + 4 - (int) this.getScrollAmount();
|
|
||||||
this.renderList(matrices, rl, sc, mouseX, mouseY, delta);
|
|
||||||
|
|
||||||
RenderSystem.enableTexture();
|
|
||||||
RenderSystem.shadeModel(7424);
|
|
||||||
RenderSystem.enableAlphaTest();
|
|
||||||
RenderSystem.disableBlend();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,281 +0,0 @@
|
||||||
package pm.j4.petroleum.gui;
|
|
||||||
|
|
||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.Set;
|
|
||||||
import net.minecraft.client.MinecraftClient;
|
|
||||||
import net.minecraft.client.gui.widget.AlwaysSelectedEntryListWidget;
|
|
||||||
import net.minecraft.client.render.BufferBuilder;
|
|
||||||
import net.minecraft.client.render.Tessellator;
|
|
||||||
import net.minecraft.client.render.VertexFormats;
|
|
||||||
import net.minecraft.client.util.math.MatrixStack;
|
|
||||||
import net.minecraft.util.math.MathHelper;
|
|
||||||
import net.minecraft.util.math.Matrix4f;
|
|
||||||
import pm.j4.petroleum.mixin.EntryListWidgetAccessor;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type P module configuration widget.
|
|
||||||
*/
|
|
||||||
public class PModuleConfigurationWidget extends AlwaysSelectedEntryListWidget<POptionEntry> {
|
|
||||||
/**
|
|
||||||
* The Parent.
|
|
||||||
*/
|
|
||||||
private final POptionsScreen parent;
|
|
||||||
/**
|
|
||||||
* The Module id.
|
|
||||||
*/
|
|
||||||
private String moduleId = null;
|
|
||||||
/**
|
|
||||||
* The Mods.
|
|
||||||
*/
|
|
||||||
private List<ModuleBase> mods;
|
|
||||||
/**
|
|
||||||
* The Extra mods.
|
|
||||||
*/
|
|
||||||
private final Set<ModuleBase> extraMods = new HashSet<>();
|
|
||||||
/**
|
|
||||||
* The Scrolling.
|
|
||||||
*/
|
|
||||||
private boolean scrolling = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new P module configuration widget.
|
|
||||||
*
|
|
||||||
* @param client the client
|
|
||||||
* @param width the width
|
|
||||||
* @param height the height
|
|
||||||
* @param y1 the y 1
|
|
||||||
* @param y2 the y 2
|
|
||||||
* @param entryHeight the entry height
|
|
||||||
* @param list the list
|
|
||||||
* @param parent the parent
|
|
||||||
*/
|
|
||||||
public PModuleConfigurationWidget(MinecraftClient client, int width, int height, int y1, int y2, int entryHeight, PModuleConfigurationWidget list, POptionsScreen parent) {
|
|
||||||
super(client, width, height, y1, y2, entryHeight);
|
|
||||||
this.parent = parent;
|
|
||||||
if (list != null) {
|
|
||||||
mods = list.mods;
|
|
||||||
}
|
|
||||||
setScrollAmount(parent.getScrollPercent() * Math.max(0, this.getMaxPosition() - (this.bottom - this.top - 4)));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setScrollAmount(double amount) {
|
|
||||||
super.setScrollAmount(amount);
|
|
||||||
int denominator = Math.max(0, this.getMaxPosition() - (this.bottom - this.top - 4));
|
|
||||||
if (denominator <= 0) {
|
|
||||||
parent.updateScrollPercent(0);
|
|
||||||
} else {
|
|
||||||
parent.updateScrollPercent(getScrollAmount() / Math.max(0, this.getMaxPosition() - (this.bottom - this.top - 4)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected boolean isFocused() {
|
|
||||||
return parent.getFocused() == this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Select.
|
|
||||||
*
|
|
||||||
* @param entry the entry
|
|
||||||
*/
|
|
||||||
public void select(POptionEntry entry) {
|
|
||||||
this.setSelected(entry);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setSelected(POptionEntry entry) {
|
|
||||||
super.setSelected(entry);
|
|
||||||
moduleId = entry.getModId();
|
|
||||||
parent.updateSelected(entry);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected boolean isSelectedItem(int index) {
|
|
||||||
return super.isSelectedItem(index);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int addEntry(POptionEntry entry) {
|
|
||||||
if (extraMods.contains(entry.module)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
extraMods.add(entry.module);
|
|
||||||
int i = super.addEntry(entry);
|
|
||||||
if (entry.getModId().equals(moduleId)) {
|
|
||||||
setSelected(entry);
|
|
||||||
}
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected boolean removeEntry(POptionEntry entry) {
|
|
||||||
extraMods.remove(entry.module);
|
|
||||||
return super.removeEntry(entry);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected POptionEntry remove(int index) {
|
|
||||||
extraMods.remove(getEntry(index).module);
|
|
||||||
return super.remove(index);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void renderList(MatrixStack matrices, int x, int y, int mouseX, int mouseY, float delta) {
|
|
||||||
int itemCount = this.getItemCount();
|
|
||||||
Tessellator t_1 = Tessellator.getInstance();
|
|
||||||
BufferBuilder buffer = t_1.getBuffer();
|
|
||||||
|
|
||||||
for (int index = 0; index < itemCount; ++index) {
|
|
||||||
int entryTop = this.getRowTop(index);
|
|
||||||
int entryBottom = this.getRowTop(index) + this.itemHeight;
|
|
||||||
if (entryBottom >= this.top && entryTop <= this.bottom) {
|
|
||||||
int entryHeight = this.itemHeight - 4;
|
|
||||||
POptionEntry entry = this.getEntry(index);
|
|
||||||
int rowWidth = this.getRowWidth();
|
|
||||||
int entryLeft;
|
|
||||||
if (((EntryListWidgetAccessor) this).isRenderSelection() && this.isSelectedItem(index)) {
|
|
||||||
entryLeft = getRowLeft() - 2 + entry.getXOffset();
|
|
||||||
int selectionRight = x + rowWidth + 2;
|
|
||||||
RenderSystem.disableTexture();
|
|
||||||
float brightness = this.isFocused() ? 1.0F : 0.5F;
|
|
||||||
RenderSystem.color4f(brightness, brightness, brightness, 1.0F);
|
|
||||||
Matrix4f matrix = matrices.peek().getModel();
|
|
||||||
buffer.begin(7, VertexFormats.POSITION);
|
|
||||||
buffer.vertex(matrix, entryLeft, entryTop + entryHeight + 2, 0.0F).next();
|
|
||||||
buffer.vertex(matrix, selectionRight, entryTop + entryHeight + 2, 0.0F).next();
|
|
||||||
buffer.vertex(matrix, selectionRight, entryTop - 2, 0.0F).next();
|
|
||||||
buffer.vertex(matrix, entryLeft, entryTop - 2, 0.0F).next();
|
|
||||||
t_1.draw();
|
|
||||||
RenderSystem.color4f(0.0F, 0.0F, 0.0F, 1.0F);
|
|
||||||
buffer.begin(7, VertexFormats.POSITION);
|
|
||||||
buffer.vertex(matrix, entryLeft + 1, entryTop + entryHeight + 1, 0.0F).next();
|
|
||||||
buffer.vertex(matrix, selectionRight, entryTop + entryHeight + 1, 0.0F).next();
|
|
||||||
buffer.vertex(matrix, selectionRight, entryTop - 1, 0.0F).next();
|
|
||||||
buffer.vertex(matrix, entryLeft + 1, entryTop - 1, 0.0F).next();
|
|
||||||
t_1.draw();
|
|
||||||
RenderSystem.enableTexture();
|
|
||||||
}
|
|
||||||
|
|
||||||
entryLeft = this.getRowLeft();
|
|
||||||
entry.render(matrices,
|
|
||||||
index,
|
|
||||||
entryTop,
|
|
||||||
entryLeft,
|
|
||||||
rowWidth,
|
|
||||||
entryHeight,
|
|
||||||
mouseX,
|
|
||||||
mouseY,
|
|
||||||
this.isMouseOver(mouseX, mouseY) && Objects.equals(this.getEntryAtPos(mouseX, mouseY), entry),
|
|
||||||
delta);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void updateScrollingState(double mouseX, double mouseY, int button) {
|
|
||||||
super.updateScrollingState(mouseX, mouseY, button);
|
|
||||||
this.scrolling = button == 0 &&
|
|
||||||
mouseX >= (double) this.getScrollbarPositionX() &&
|
|
||||||
mouseX < (double) (this.getScrollbarPositionX() + 6);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean mouseClicked(double mouseX, double mouseY, int button) {
|
|
||||||
this.updateScrollingState(mouseX, mouseY, button);
|
|
||||||
if (!this.isMouseOver(mouseX, mouseY)) {
|
|
||||||
return false;
|
|
||||||
} else {
|
|
||||||
POptionEntry entry = this.getEntryAtPos(mouseX, mouseY);
|
|
||||||
if (entry != null) {
|
|
||||||
if (entry.mouseClicked(mouseX, mouseY, button)) {
|
|
||||||
this.setFocused(entry);
|
|
||||||
this.setDragging(true);
|
|
||||||
return true;
|
|
||||||
} else if (button == 0) {
|
|
||||||
this.clickedHeader((int) (mouseX - (double) (this.left + this.width / 2 - this.getRowWidth() / 2)),
|
|
||||||
(int) (mouseY - (double) this.top) + (int) this.getScrollAmount() - 4);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return this.scrolling;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets entry at pos.
|
|
||||||
*
|
|
||||||
* @param x the x
|
|
||||||
* @param y the y
|
|
||||||
* @return the entry at pos
|
|
||||||
*/
|
|
||||||
public final POptionEntry getEntryAtPos(double x, double y) {
|
|
||||||
int i = MathHelper.floor(y - (double) this.top) - this.headerHeight + (int) this.getScrollAmount() - 4;
|
|
||||||
int index = i / this.itemHeight;
|
|
||||||
return x < (double) this.getScrollbarPositionX() &&
|
|
||||||
x >= (double) getRowLeft() &&
|
|
||||||
x <= (double) (getRowLeft() + getRowWidth()) &&
|
|
||||||
index >= 0 && i >= 0 &&
|
|
||||||
index < this.getItemCount() ? this.children().get(index) : null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected int getScrollbarPositionX() {
|
|
||||||
return this.width - 6;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getRowWidth() {
|
|
||||||
return this.width - (Math.max(0, this.getMaxPosition() - (this.bottom - this.top - 4)) > 0 ? 18 : 12);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getRowLeft() {
|
|
||||||
return left + 6;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets width.
|
|
||||||
*
|
|
||||||
* @return the width
|
|
||||||
*/
|
|
||||||
public int getWidth() {
|
|
||||||
return width;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets top.
|
|
||||||
*
|
|
||||||
* @return the top
|
|
||||||
*/
|
|
||||||
public int getTop() {
|
|
||||||
return this.top;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets parent.
|
|
||||||
*
|
|
||||||
* @return the parent
|
|
||||||
*/
|
|
||||||
public POptionsScreen getParent() {
|
|
||||||
return parent;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected int getMaxPosition() {
|
|
||||||
return super.getMaxPosition() + 4;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets displayed count.
|
|
||||||
*
|
|
||||||
* @return the displayed count
|
|
||||||
*/
|
|
||||||
public int getDisplayedCount() {
|
|
||||||
return children().size();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -13,9 +13,9 @@ import net.minecraft.text.LiteralText;
|
||||||
import net.minecraft.text.TranslatableText;
|
import net.minecraft.text.TranslatableText;
|
||||||
import net.minecraft.util.math.MathHelper;
|
import net.minecraft.util.math.MathHelper;
|
||||||
import net.minecraft.util.math.Matrix4f;
|
import net.minecraft.util.math.Matrix4f;
|
||||||
|
import pm.j4.kerosene.util.module.ModuleBase;
|
||||||
import pm.j4.petroleum.modules.menu.ModMenu;
|
import pm.j4.petroleum.modules.menu.ModMenu;
|
||||||
import pm.j4.petroleum.util.data.ButtonInformation;
|
import pm.j4.petroleum.util.data.ButtonInformation;
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type P movable button.
|
* The type P movable button.
|
||||||
|
|
|
@ -1,94 +0,0 @@
|
||||||
package pm.j4.petroleum.gui;
|
|
||||||
|
|
||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
|
||||||
import net.minecraft.client.MinecraftClient;
|
|
||||||
import net.minecraft.client.font.TextRenderer;
|
|
||||||
import net.minecraft.client.gui.widget.AlwaysSelectedEntryListWidget;
|
|
||||||
import net.minecraft.client.util.math.MatrixStack;
|
|
||||||
import net.minecraft.text.StringVisitable;
|
|
||||||
import net.minecraft.text.Text;
|
|
||||||
import net.minecraft.text.TranslatableText;
|
|
||||||
import net.minecraft.util.Language;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type P option entry.
|
|
||||||
*/
|
|
||||||
public class POptionEntry extends AlwaysSelectedEntryListWidget.Entry<POptionEntry> {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Module.
|
|
||||||
*/
|
|
||||||
protected final ModuleBase module;
|
|
||||||
/**
|
|
||||||
* The Client.
|
|
||||||
*/
|
|
||||||
protected final MinecraftClient client;
|
|
||||||
/**
|
|
||||||
* The List.
|
|
||||||
*/
|
|
||||||
private final PModuleConfigurationWidget list;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new P option entry.
|
|
||||||
*
|
|
||||||
* @param mod the mod
|
|
||||||
* @param list the list
|
|
||||||
*/
|
|
||||||
public POptionEntry(ModuleBase mod, PModuleConfigurationWidget list) {
|
|
||||||
this.module = mod;
|
|
||||||
this.client = MinecraftClient.getInstance();
|
|
||||||
this.list = list;
|
|
||||||
}
|
|
||||||
|
|
||||||
//TODO TEST move text to be centered
|
|
||||||
@Override
|
|
||||||
public void render(MatrixStack matrices, int index, int y, int x, int entryWidth, int entryHeight, int mouseX, int mouseY, boolean hovered, float tickDelta) {
|
|
||||||
x += getXOffset();
|
|
||||||
entryWidth -= getXOffset();
|
|
||||||
RenderSystem.color4f(1.0F, 1.0F, 1.0F, 1.0F);
|
|
||||||
Text name = this.getModName();
|
|
||||||
StringVisitable nameString = name;
|
|
||||||
int maxNameWidth = entryWidth - 32 - 3;
|
|
||||||
TextRenderer font = this.client.textRenderer;
|
|
||||||
if (font.getWidth(name) > maxNameWidth) {
|
|
||||||
StringVisitable ellipse = StringVisitable.plain("...");
|
|
||||||
nameString = StringVisitable.concat(font.trimToWidth(nameString, maxNameWidth - font.getWidth(ellipse)), ellipse);
|
|
||||||
}
|
|
||||||
|
|
||||||
font.draw(matrices, Language.getInstance().reorder(nameString), x + 32 + 3, y + (entryHeight / 2), 0xFFFFFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean mouseClicked(double x, double y, int b) {
|
|
||||||
this.list.select(this);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets mod id.
|
|
||||||
*
|
|
||||||
* @return the mod id
|
|
||||||
*/
|
|
||||||
public String getModId() {
|
|
||||||
return module.getModuleName();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets mod name.
|
|
||||||
*
|
|
||||||
* @return the mod name
|
|
||||||
*/
|
|
||||||
public TranslatableText getModName() {
|
|
||||||
return module.getReadableName();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets x offset.
|
|
||||||
*
|
|
||||||
* @return the x offset
|
|
||||||
*/
|
|
||||||
public int getXOffset() {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,222 +0,0 @@
|
||||||
package pm.j4.petroleum.gui;
|
|
||||||
|
|
||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
import net.minecraft.client.MinecraftClient;
|
|
||||||
import net.minecraft.client.gui.DrawableHelper;
|
|
||||||
import net.minecraft.client.gui.screen.Screen;
|
|
||||||
import net.minecraft.client.gui.screen.ScreenTexts;
|
|
||||||
import net.minecraft.client.gui.widget.ButtonWidget;
|
|
||||||
import net.minecraft.client.render.BufferBuilder;
|
|
||||||
import net.minecraft.client.render.Tessellator;
|
|
||||||
import net.minecraft.client.render.VertexFormats;
|
|
||||||
import net.minecraft.client.util.math.MatrixStack;
|
|
||||||
import net.minecraft.text.*;
|
|
||||||
import pm.j4.petroleum.PetroleumMod;
|
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type P options screen.
|
|
||||||
*/
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public class POptionsScreen extends Screen {
|
|
||||||
/**
|
|
||||||
* The Previous screen.
|
|
||||||
*/
|
|
||||||
private final Screen previousScreen;
|
|
||||||
/**
|
|
||||||
* The Scroll percent.
|
|
||||||
*/
|
|
||||||
private double scrollPercent = 0;
|
|
||||||
/**
|
|
||||||
* The Modules.
|
|
||||||
*/
|
|
||||||
private PModuleConfigurationWidget modules;
|
|
||||||
/**
|
|
||||||
* The Config pane.
|
|
||||||
*/
|
|
||||||
private PModuleConfigPane configPane;
|
|
||||||
/**
|
|
||||||
* The Selected.
|
|
||||||
*/
|
|
||||||
private POptionEntry selected;
|
|
||||||
/**
|
|
||||||
* The Tooltip.
|
|
||||||
*/
|
|
||||||
private Text tooltip;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Pane y.
|
|
||||||
*/
|
|
||||||
private int paneY;
|
|
||||||
/**
|
|
||||||
* The Right pane x.
|
|
||||||
*/
|
|
||||||
private int rightPaneX;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new P options screen.
|
|
||||||
*
|
|
||||||
* @param previousScreen the previous screen
|
|
||||||
*/
|
|
||||||
public POptionsScreen(Screen previousScreen) {
|
|
||||||
super(new TranslatableText("petroleum.options"));
|
|
||||||
this.previousScreen = previousScreen;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onClose() {
|
|
||||||
super.onClose();
|
|
||||||
assert this.client != null;
|
|
||||||
this.client.openScreen(previousScreen);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void init() {
|
|
||||||
paneY = 48;
|
|
||||||
int paneWidth = this.width / 2 - 8;
|
|
||||||
rightPaneX = width - paneWidth;
|
|
||||||
this.modules = new PModuleConfigurationWidget(this.client,
|
|
||||||
this.width - paneWidth,
|
|
||||||
this.height,
|
|
||||||
paneY + 19,
|
|
||||||
this.height - 36,
|
|
||||||
36,
|
|
||||||
this.modules,
|
|
||||||
this);
|
|
||||||
this.modules.setLeftPos(0);
|
|
||||||
this.children.add(this.modules);
|
|
||||||
this.configPane = new PModuleConfigPane(this.client,
|
|
||||||
paneWidth,
|
|
||||||
this.height,
|
|
||||||
paneY + 19,
|
|
||||||
this.height - 36,
|
|
||||||
48,
|
|
||||||
this);
|
|
||||||
this.configPane.setLeftPos(paneWidth);
|
|
||||||
this.children.add(this.configPane);
|
|
||||||
List<ModuleBase> configurableModules = new ArrayList<>();
|
|
||||||
if (ConfigManager.getConfig().isPresent()) {
|
|
||||||
configurableModules.addAll(PetroleumMod.getActiveMods()
|
|
||||||
.stream().filter(ModuleBase::configurable)
|
|
||||||
.collect(Collectors.toList()));
|
|
||||||
}
|
|
||||||
configurableModules.forEach(module -> this.modules.addEntry(new POptionEntry(module, this.modules)));
|
|
||||||
this.addButton(new ButtonWidget(this.width / 2 - 75, this.height - 30, 150, 20, ScreenTexts.DONE, (buttonWidget) -> {
|
|
||||||
ConfigManager.saveAllModules();
|
|
||||||
assert this.client != null;
|
|
||||||
this.client.openScreen(this.previousScreen);
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void render(MatrixStack matrices, int mouseX, int mouseY, float delta) {
|
|
||||||
this.renderBackground(matrices);
|
|
||||||
|
|
||||||
this.modules.render(matrices, mouseX, mouseY, delta);
|
|
||||||
if (selected != null) {
|
|
||||||
this.configPane.render(matrices, mouseX, mouseY, delta);
|
|
||||||
}
|
|
||||||
RenderSystem.disableBlend();
|
|
||||||
drawTextWithShadow(matrices, this.textRenderer, this.title, this.modules.getWidth() / 2, 8, 16777215);
|
|
||||||
super.render(matrices, mouseX, mouseY, delta);
|
|
||||||
|
|
||||||
if (selected != null) {
|
|
||||||
int offset = 36;
|
|
||||||
int x = rightPaneX;
|
|
||||||
int maxNameWidth = this.width - (x + offset);
|
|
||||||
int lineSpacing = textRenderer.fontHeight + 1;
|
|
||||||
Text name = selected.getModName();
|
|
||||||
|
|
||||||
StringVisitable trimmedName = name;
|
|
||||||
|
|
||||||
if (textRenderer.getWidth(name) > maxNameWidth) {
|
|
||||||
StringVisitable ellipsis = StringVisitable.plain("...");
|
|
||||||
trimmedName = StringVisitable.concat(textRenderer.trimToWidth(name, maxNameWidth - textRenderer.getWidth(ellipsis)), ellipsis);
|
|
||||||
}
|
|
||||||
if (mouseX > x + offset && mouseY > paneY + 1 && mouseY < paneY + 1 + textRenderer.fontHeight && mouseX < x + offset + textRenderer.getWidth(trimmedName)) {
|
|
||||||
//TODO tooltop
|
|
||||||
//selected.getModName()
|
|
||||||
}
|
|
||||||
textRenderer.draw(matrices, selected.getModName(), x + offset, paneY + 2 + lineSpacing, 0x808080);
|
|
||||||
|
|
||||||
if (this.tooltip != null) {
|
|
||||||
this.renderOrderedTooltip(matrices, textRenderer.wrapLines(this.tooltip, Integer.MAX_VALUE), mouseX, mouseY);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets tooltip.
|
|
||||||
*
|
|
||||||
* @param tooltip the tooltip
|
|
||||||
*/
|
|
||||||
private void setTooltip(Text tooltip) {
|
|
||||||
this.tooltip = tooltip;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void renderBackground(MatrixStack matrices) {
|
|
||||||
POptionsScreen.overlayBackground(this.width, this.height);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Overlay background.
|
|
||||||
*
|
|
||||||
* @param x2 the x 2
|
|
||||||
* @param y2 the y 2
|
|
||||||
*/
|
|
||||||
static void overlayBackground(int x2, int y2) {
|
|
||||||
Tessellator t_1 = Tessellator.getInstance();
|
|
||||||
BufferBuilder buffer = t_1.getBuffer();
|
|
||||||
Objects.requireNonNull(MinecraftClient.getInstance()).getTextureManager().bindTexture(DrawableHelper.OPTIONS_BACKGROUND_TEXTURE);
|
|
||||||
RenderSystem.color4f(1.0F, 1.0F, 1.0F, 1.0F);
|
|
||||||
buffer.begin(7, VertexFormats.POSITION_TEXTURE_COLOR);
|
|
||||||
buffer.vertex(0, y2, 0.0D).texture(0 / 32.0F, y2 / 32.0F).color(64, 64, 64, 255).next();
|
|
||||||
buffer.vertex(x2, y2, 0.0D).texture(x2 / 32.0F, y2 / 32.0F).color(64, 64, 64, 255).next();
|
|
||||||
buffer.vertex(x2, 0, 0.0D).texture(x2 / 32.0F, 0 / 32.0F).color(64, 64, 64, 255).next();
|
|
||||||
buffer.vertex(0, 0, 0.0D).texture(0 / 32.0F, 0 / 32.0F).color(64, 64, 64, 255).next();
|
|
||||||
t_1.draw();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets scroll percent.
|
|
||||||
*
|
|
||||||
* @return the scroll percent
|
|
||||||
*/
|
|
||||||
double getScrollPercent() {
|
|
||||||
return scrollPercent;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Update scroll percent.
|
|
||||||
*
|
|
||||||
* @param scrollPercent the scroll percent
|
|
||||||
*/
|
|
||||||
void updateScrollPercent(double scrollPercent) {
|
|
||||||
this.scrollPercent = scrollPercent;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets selected.
|
|
||||||
*
|
|
||||||
* @return the selected
|
|
||||||
*/
|
|
||||||
POptionEntry getSelected() {
|
|
||||||
return selected;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Update selected.
|
|
||||||
*
|
|
||||||
* @param entry the entry
|
|
||||||
*/
|
|
||||||
void updateSelected(POptionEntry entry) {
|
|
||||||
if (entry != null) {
|
|
||||||
this.selected = entry;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -9,9 +9,13 @@ import org.spongepowered.asm.mixin.injection.At;
|
||||||
import org.spongepowered.asm.mixin.injection.Inject;
|
import org.spongepowered.asm.mixin.injection.Inject;
|
||||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
||||||
import org.spongepowered.asm.mixin.injection.callback.LocalCapture;
|
import org.spongepowered.asm.mixin.injection.callback.LocalCapture;
|
||||||
|
import pm.j4.kerosene.util.data.ModInfoProvider;
|
||||||
|
import pm.j4.kerosene.util.module.ModuleBase;
|
||||||
|
import pm.j4.kerosene.util.module.option.BooleanOption;
|
||||||
|
import pm.j4.kerosene.util.module.option.ConfigurationOption;
|
||||||
import pm.j4.petroleum.modules.splash.SplashText;
|
import pm.j4.petroleum.modules.splash.SplashText;
|
||||||
import pm.j4.petroleum.util.config.ConfigHolder;
|
import pm.j4.kerosene.util.config.ConfigHolder;
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
import pm.j4.kerosene.util.config.ConfigManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type Debug hud mixin.
|
* The type Debug hud mixin.
|
||||||
|
@ -29,10 +33,15 @@ public class DebugHudMixin {
|
||||||
at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/client/gui/hud/DebugHud;getLeftText()Ljava/util/List;"),
|
at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/client/gui/hud/DebugHud;getLeftText()Ljava/util/List;"),
|
||||||
locals = LocalCapture.CAPTURE_FAILSOFT)
|
locals = LocalCapture.CAPTURE_FAILSOFT)
|
||||||
protected void renderTextRight(MatrixStack matrices, CallbackInfo ci, List<String> list) {
|
protected void renderTextRight(MatrixStack matrices, CallbackInfo ci, List<String> list) {
|
||||||
Optional<ConfigHolder> config = ConfigManager.getConfig();
|
Optional<ConfigHolder> config = ConfigManager.getConfig("petroleum");
|
||||||
if (config.isPresent() && config.get().isModuleEnabled("petroleum.splashtext")) {
|
Optional<ModuleBase> splashText = ModInfoProvider.getMod("petroleum.splashtext");
|
||||||
|
if (config.isPresent() && config.get().isModuleEnabled("petroleum.splashtext")
|
||||||
|
&& splashText.isPresent()) {
|
||||||
|
Optional<ConfigurationOption> isActive = splashText.get().getConfigOption("petroleum.splashtext.active");
|
||||||
|
if(isActive.isPresent() && ((BooleanOption)isActive.get()).getValue()) {
|
||||||
list.add("[Petroleum] " + SplashText.get() + " loaded");
|
list.add("[Petroleum] " + SplashText.get() + " loaded");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,19 +0,0 @@
|
||||||
package pm.j4.petroleum.mixin;
|
|
||||||
|
|
||||||
import net.minecraft.client.gui.widget.EntryListWidget;
|
|
||||||
import org.spongepowered.asm.mixin.Mixin;
|
|
||||||
import org.spongepowered.asm.mixin.gen.Accessor;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The interface Entry list widget accessor.
|
|
||||||
*/
|
|
||||||
@Mixin(EntryListWidget.class)
|
|
||||||
public interface EntryListWidgetAccessor {
|
|
||||||
/**
|
|
||||||
* Is render selection boolean.
|
|
||||||
*
|
|
||||||
* @return the boolean
|
|
||||||
*/
|
|
||||||
@Accessor("renderSelection")
|
|
||||||
boolean isRenderSelection();
|
|
||||||
}
|
|
|
@ -16,9 +16,9 @@ import org.spongepowered.asm.mixin.injection.At;
|
||||||
import org.spongepowered.asm.mixin.injection.Inject;
|
import org.spongepowered.asm.mixin.injection.Inject;
|
||||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
||||||
import pm.j4.petroleum.modules.list.ModList;
|
import pm.j4.petroleum.modules.list.ModList;
|
||||||
import pm.j4.petroleum.util.config.ConfigHolder;
|
import pm.j4.kerosene.util.config.ConfigHolder;
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
import pm.j4.kerosene.util.config.ConfigManager;
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
import pm.j4.kerosene.util.module.ModuleBase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type Mod list mixin.
|
* The type Mod list mixin.
|
||||||
|
@ -63,7 +63,7 @@ public abstract class ModListMixin extends DrawableHelper {
|
||||||
@Inject(method = "render(Lnet/minecraft/client/util/math/MatrixStack;F)V",
|
@Inject(method = "render(Lnet/minecraft/client/util/math/MatrixStack;F)V",
|
||||||
at = @At("HEAD"))
|
at = @At("HEAD"))
|
||||||
public void render(MatrixStack matrices, float tickDelta, CallbackInfo ci) {
|
public void render(MatrixStack matrices, float tickDelta, CallbackInfo ci) {
|
||||||
Optional<ConfigHolder> config = ConfigManager.getConfig();
|
Optional<ConfigHolder> config = ConfigManager.getConfig("petroleum");
|
||||||
if (config.isPresent() &&
|
if (config.isPresent() &&
|
||||||
config.get().isModuleEnabled("petroleum.modlist") &&
|
config.get().isModuleEnabled("petroleum.modlist") &&
|
||||||
!this.client.options.hudHidden &&
|
!this.client.options.hudHidden &&
|
||||||
|
|
|
@ -1,42 +0,0 @@
|
||||||
package pm.j4.petroleum.mixin;
|
|
||||||
|
|
||||||
import net.minecraft.client.gui.screen.Screen;
|
|
||||||
import net.minecraft.client.gui.screen.options.OptionsScreen;
|
|
||||||
import net.minecraft.client.gui.widget.ButtonWidget;
|
|
||||||
import net.minecraft.text.Text;
|
|
||||||
import net.minecraft.text.TranslatableText;
|
|
||||||
import org.spongepowered.asm.mixin.Mixin;
|
|
||||||
import org.spongepowered.asm.mixin.injection.At;
|
|
||||||
import org.spongepowered.asm.mixin.injection.Inject;
|
|
||||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
|
||||||
import pm.j4.petroleum.gui.POptionsScreen;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Options menu mixin.
|
|
||||||
*/
|
|
||||||
@Mixin(OptionsScreen.class)
|
|
||||||
public class OptionsMenuMixin extends Screen {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new Options menu mixin.
|
|
||||||
*
|
|
||||||
* @param title the title
|
|
||||||
*/
|
|
||||||
protected OptionsMenuMixin(Text title) {
|
|
||||||
super(title);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Init.
|
|
||||||
*
|
|
||||||
* @param ci the ci
|
|
||||||
*/
|
|
||||||
@Inject(at = @At(value = "TAIL"),
|
|
||||||
method = "init()V")
|
|
||||||
protected void init(CallbackInfo ci) {
|
|
||||||
this.addButton(new ButtonWidget(this.width / 2 - 75, this.height / 6 + 140, 150, 20, new TranslatableText("petroleum.options"), (buttonWidget) -> {
|
|
||||||
assert this.client != null;
|
|
||||||
this.client.openScreen(new POptionsScreen(this));
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -10,13 +10,15 @@ import org.spongepowered.asm.mixin.injection.At;
|
||||||
import org.spongepowered.asm.mixin.injection.Inject;
|
import org.spongepowered.asm.mixin.injection.Inject;
|
||||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
||||||
import org.spongepowered.asm.mixin.injection.callback.LocalCapture;
|
import org.spongepowered.asm.mixin.injection.callback.LocalCapture;
|
||||||
|
import pm.j4.kerosene.KeroseneMod;
|
||||||
|
import pm.j4.kerosene.util.data.ModInfoProvider;
|
||||||
import pm.j4.petroleum.PetroleumMod;
|
import pm.j4.petroleum.PetroleumMod;
|
||||||
import pm.j4.petroleum.modules.splash.SplashText;
|
import pm.j4.petroleum.modules.splash.SplashText;
|
||||||
import pm.j4.petroleum.util.config.ConfigHolder;
|
import pm.j4.kerosene.util.config.ConfigHolder;
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
import pm.j4.kerosene.util.config.ConfigManager;
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
import pm.j4.kerosene.util.module.ModuleBase;
|
||||||
import pm.j4.petroleum.util.module.option.BooleanOption;
|
import pm.j4.kerosene.util.module.option.BooleanOption;
|
||||||
import pm.j4.petroleum.util.module.option.ConfigurationOption;
|
import pm.j4.kerosene.util.module.option.ConfigurationOption;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -74,8 +76,8 @@ public class TitleScreenMixin extends Screen {
|
||||||
ordinal = 0),
|
ordinal = 0),
|
||||||
locals = LocalCapture.CAPTURE_FAILSOFT)
|
locals = LocalCapture.CAPTURE_FAILSOFT)
|
||||||
private void render(MatrixStack matrices, int mouseX, int mouseY, float delta, CallbackInfo ci, float f, int i, int j, float g, int l) {
|
private void render(MatrixStack matrices, int mouseX, int mouseY, float delta, CallbackInfo ci, float f, int i, int j, float g, int l) {
|
||||||
Optional<ConfigHolder> config = ConfigManager.getConfig();
|
Optional<ConfigHolder> config = ConfigManager.getConfig("petroleum");
|
||||||
Optional<ModuleBase> splashText = PetroleumMod.getMod("petroleum.splashtext");
|
Optional<ModuleBase> splashText = ModInfoProvider.getMod("petroleum.splashtext");
|
||||||
if (config.isPresent() && config.get().isModuleEnabled("petroleum.splashtext")
|
if (config.isPresent() && config.get().isModuleEnabled("petroleum.splashtext")
|
||||||
&& splashText.isPresent()) {
|
&& splashText.isPresent()) {
|
||||||
Optional<ConfigurationOption> isActive = splashText.get().getConfigOption("petroleum.splashtext.active");
|
Optional<ConfigurationOption> isActive = splashText.get().getConfigOption("petroleum.splashtext.active");
|
||||||
|
|
|
@ -1,42 +0,0 @@
|
||||||
package pm.j4.petroleum.modules;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import net.minecraft.client.MinecraftClient;
|
|
||||||
import net.minecraft.text.LiteralText;
|
|
||||||
import pm.j4.petroleum.gui.PModuleConfigEntry;
|
|
||||||
import pm.j4.petroleum.gui.PModuleConfigPane;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
import pm.j4.petroleum.util.module.option.BooleanOption;
|
|
||||||
import pm.j4.petroleum.util.module.option.ConfigurationOption;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Example module.
|
|
||||||
*/
|
|
||||||
public class ExampleModule extends ModuleBase {
|
|
||||||
/**
|
|
||||||
* example mod
|
|
||||||
*/
|
|
||||||
public ExampleModule() {
|
|
||||||
super("petroleum.example",
|
|
||||||
"petroleum.misc",
|
|
||||||
true,
|
|
||||||
false,
|
|
||||||
true);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<ConfigurationOption> getDefaultConfig() {
|
|
||||||
List<ConfigurationOption> options = new ArrayList<>();
|
|
||||||
options.add(new BooleanOption("petroleum.example.b_one","example", this));
|
|
||||||
options.add(new BooleanOption("petroleum.example.b_two","example", this));
|
|
||||||
return options;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void activate(MinecraftClient client) {
|
|
||||||
System.out.println("Example Mod Keybind Activate");
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,30 +0,0 @@
|
||||||
package pm.j4.petroleum.modules.bindings;
|
|
||||||
|
|
||||||
import net.minecraft.client.util.InputUtil;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Binding info.
|
|
||||||
*/
|
|
||||||
public class BindingInfo {
|
|
||||||
/**
|
|
||||||
* The Translation key.
|
|
||||||
*/
|
|
||||||
public String translationKey;
|
|
||||||
/**
|
|
||||||
* The Type.
|
|
||||||
*/
|
|
||||||
public InputUtil.Type type;
|
|
||||||
/**
|
|
||||||
* The Key.
|
|
||||||
*/
|
|
||||||
public int key;
|
|
||||||
/**
|
|
||||||
* The Category.
|
|
||||||
*/
|
|
||||||
public String category;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Attached function id.
|
|
||||||
*/
|
|
||||||
public String attachedModuleName;
|
|
||||||
}
|
|
|
@ -1,89 +0,0 @@
|
||||||
package pm.j4.petroleum.modules.bindings;
|
|
||||||
|
|
||||||
import java.util.*;
|
|
||||||
import net.minecraft.client.MinecraftClient;
|
|
||||||
import net.minecraft.client.options.KeyBinding;
|
|
||||||
import net.minecraft.client.util.InputUtil;
|
|
||||||
import net.minecraft.client.util.math.MatrixStack;
|
|
||||||
import net.minecraft.text.TranslatableText;
|
|
||||||
import org.lwjgl.glfw.GLFW;
|
|
||||||
import pm.j4.petroleum.PetroleumMod;
|
|
||||||
import pm.j4.petroleum.gui.PModuleConfigEntry;
|
|
||||||
import pm.j4.petroleum.gui.PModuleConfigPane;
|
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
|
||||||
import pm.j4.petroleum.util.config.GlobalConfig;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
import pm.j4.petroleum.util.module.option.ConfigurationOption;
|
|
||||||
import pm.j4.petroleum.util.module.option.KeybindOption;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Binding manager.
|
|
||||||
*/
|
|
||||||
public class BindingManager extends ModuleBase {
|
|
||||||
/**
|
|
||||||
* Instantiates a new Module base.
|
|
||||||
* Parameters should be constant across restarts.
|
|
||||||
*/
|
|
||||||
public BindingManager() {
|
|
||||||
super("petroleum.bindings",
|
|
||||||
"petroleum.misc",
|
|
||||||
false,
|
|
||||||
true,
|
|
||||||
true);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void init() {
|
|
||||||
registerBindings();
|
|
||||||
super.init();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<PModuleConfigEntry> getConfigEntries(PModuleConfigPane sourcePane) {
|
|
||||||
|
|
||||||
//TODO multiple binds per module
|
|
||||||
// thoughts: have modules include a list of module triggers/functions
|
|
||||||
// which replace the ModuleBase in bindings?
|
|
||||||
List<PModuleConfigEntry> entries = new ArrayList<>();
|
|
||||||
|
|
||||||
Map<KeybindOption, ModuleBase> mapped = new HashMap<>();
|
|
||||||
if (ConfigManager.getConfig().isPresent()) {
|
|
||||||
Map<KeyBinding, ModuleBase> binds = ConfigManager.getConfig().get().globalConfig.bindings;
|
|
||||||
|
|
||||||
binds.forEach((key, func) -> {
|
|
||||||
KeybindOption option = new KeybindOption(func.getModuleName() + " " + func.getCategory(), func.getModuleName() + " " + func.getCategory(), func);
|
|
||||||
option.fromKeybind(key, func);
|
|
||||||
mapped.put(option, func);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
mapped.forEach((configEntry, module) -> {
|
|
||||||
PModuleConfigEntry entry = new PModuleConfigEntry(configEntry, new TranslatableText(module.getModuleName()), sourcePane);
|
|
||||||
entries.add(entry);
|
|
||||||
});
|
|
||||||
return entries;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Register bindings.
|
|
||||||
*/
|
|
||||||
private void registerBindings() {
|
|
||||||
if (!ConfigManager.getConfig().isPresent()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
GlobalConfig c = ConfigManager.getConfig().get().globalConfig;
|
|
||||||
Optional<ModuleBase> mod = PetroleumMod.getMod("petroleum.modmenu");
|
|
||||||
if (mod.isPresent() && !c.isBound(mod.get())) {
|
|
||||||
//TODO
|
|
||||||
// the only explicit keybinding (for now.)
|
|
||||||
// once the binding manager has been completed,
|
|
||||||
// this should be migrated there, as a default binding
|
|
||||||
KeyBinding binding = new KeyBinding(
|
|
||||||
"key.petroleum.togglemodmenu",
|
|
||||||
InputUtil.Type.KEYSYM,
|
|
||||||
GLFW.GLFW_KEY_RIGHT_CONTROL,
|
|
||||||
"category.petroleum"
|
|
||||||
);
|
|
||||||
ConfigManager.getConfig().get().globalConfig.setBinding(binding, mod.get());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -3,9 +3,9 @@ package pm.j4.petroleum.modules.list;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import pm.j4.petroleum.util.config.ConfigHolder;
|
import pm.j4.kerosene.util.config.ConfigHolder;
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
import pm.j4.kerosene.util.config.ConfigManager;
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
import pm.j4.kerosene.util.module.ModuleBase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type Mod list.
|
* The type Mod list.
|
||||||
|
@ -15,7 +15,8 @@ public class ModList extends ModuleBase {
|
||||||
* Instantiates a new Mod list.
|
* Instantiates a new Mod list.
|
||||||
*/
|
*/
|
||||||
public ModList() {
|
public ModList() {
|
||||||
super("petroleum.modlist",
|
super("petroleum",
|
||||||
|
"petroleum.modlist",
|
||||||
"petroleum.misc",
|
"petroleum.misc",
|
||||||
true,
|
true,
|
||||||
true,
|
true,
|
||||||
|
@ -29,7 +30,7 @@ public class ModList extends ModuleBase {
|
||||||
*/
|
*/
|
||||||
public static List<ModuleBase> getActive() {
|
public static List<ModuleBase> getActive() {
|
||||||
List<ModuleBase> result = new ArrayList<>();
|
List<ModuleBase> result = new ArrayList<>();
|
||||||
Optional<ConfigHolder> config = ConfigManager.getConfig();
|
Optional<ConfigHolder> config = ConfigManager.getConfig("petroleum");
|
||||||
config.ifPresent(configHolder -> configHolder.getEnabledModules().forEach((mod) -> {
|
config.ifPresent(configHolder -> configHolder.getEnabledModules().forEach((mod) -> {
|
||||||
if (!mod.isHidden()) {
|
if (!mod.isHidden()) {
|
||||||
result.add(mod);
|
result.add(mod);
|
||||||
|
|
|
@ -1,14 +1,21 @@
|
||||||
package pm.j4.petroleum.modules.menu;
|
package pm.j4.petroleum.modules.menu;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.*;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import net.minecraft.client.MinecraftClient;
|
import net.minecraft.client.MinecraftClient;
|
||||||
|
import net.minecraft.client.options.KeyBinding;
|
||||||
|
import net.minecraft.client.util.InputUtil;
|
||||||
|
import org.lwjgl.glfw.GLFW;
|
||||||
|
import pm.j4.kerosene.util.config.ConfigHolder;
|
||||||
|
import pm.j4.kerosene.util.config.Module;
|
||||||
|
import pm.j4.kerosene.util.data.ModInfoProvider;
|
||||||
|
import pm.j4.kerosene.util.module.ModuleFunction;
|
||||||
|
import pm.j4.kerosene.util.module.option.ConfigurationOption;
|
||||||
import pm.j4.petroleum.gui.PModMenuScreen;
|
import pm.j4.petroleum.gui.PModMenuScreen;
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
import pm.j4.kerosene.util.config.ConfigManager;
|
||||||
|
import pm.j4.petroleum.util.config.ButtonPositionConfiguration;
|
||||||
import pm.j4.petroleum.util.data.ButtonInformation;
|
import pm.j4.petroleum.util.data.ButtonInformation;
|
||||||
import pm.j4.petroleum.util.data.Category;
|
import pm.j4.kerosene.util.data.Category;
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
import pm.j4.kerosene.util.module.ModuleBase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type Mod menu.
|
* The type Mod menu.
|
||||||
|
@ -24,30 +31,41 @@ public class ModMenu extends ModuleBase {
|
||||||
* Instantiates a new Mod menu.
|
* Instantiates a new Mod menu.
|
||||||
*/
|
*/
|
||||||
public ModMenu() {
|
public ModMenu() {
|
||||||
super("petroleum.modmenu",
|
super("petroleum",
|
||||||
|
"petroleum.modmenu",
|
||||||
"petroleum.misc",
|
"petroleum.misc",
|
||||||
true,
|
true,
|
||||||
true,
|
true,
|
||||||
true);
|
false);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO figure out resizing
|
// TODO figure out resizing
|
||||||
// the number itself changes, so it should just be probably like some onResize bullshit in PModMenuScreen
|
// the number itself changes, so it should just be probably like some onResize bullshit in PModMenuScreen
|
||||||
@Override
|
@Override
|
||||||
public void init() {
|
public void init() {
|
||||||
|
Optional<ConfigHolder> config = ConfigManager.getConfig(this.getParent());
|
||||||
Map<String, List<ModuleBase>> categories = Category.getCategoryMap();
|
Map<String, List<ModuleBase>> categories = Category.getCategoryMap();
|
||||||
final double[] h = {.1};
|
final double[] h = {.1};
|
||||||
|
Optional<ConfigurationOption> buttonOption = this.getConfigOption("petroleum.modmenu.buttons");
|
||||||
categories.forEach((category, moduleList) -> {
|
categories.forEach((category, moduleList) -> {
|
||||||
ButtonInformation conf = ConfigManager.getConfig().isPresent() ?
|
ButtonInformation conf = buttonOption.isPresent() ?
|
||||||
ConfigManager.getConfig().get().globalConfig.getButton(category) :
|
((ButtonPositionConfiguration)buttonOption.get()).getButton(category) :
|
||||||
null;
|
null;
|
||||||
ButtonInformation coord = conf != null ? conf : new ButtonInformation(.1, h[0], false);
|
ButtonInformation coord = conf != null ? conf : new ButtonInformation(.1, h[0], false);
|
||||||
h[0] += .01;
|
h[0] += .01;
|
||||||
coordinates.put(category, coord);
|
coordinates.put(category, coord);
|
||||||
if (ConfigManager.getConfig().isPresent()) {
|
if (buttonOption.isPresent()) {
|
||||||
ConfigManager.getConfig().get().globalConfig.setButton(category, coord);
|
((ButtonPositionConfiguration)buttonOption.get()).setButton(category, coord);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
super.init();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<ConfigurationOption> getDefaultConfig() {
|
||||||
|
List<ConfigurationOption> options = new ArrayList<>();
|
||||||
|
options.add(new ButtonPositionConfiguration("petroleum.modmenu.buttons", "positions of mod menu buttons", this));
|
||||||
|
return options;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -71,8 +89,12 @@ public class ModMenu extends ModuleBase {
|
||||||
}
|
}
|
||||||
if (coordinates.containsKey(b)) {
|
if (coordinates.containsKey(b)) {
|
||||||
coordinates.replace(b, c);
|
coordinates.replace(b, c);
|
||||||
if (ConfigManager.getConfig().isPresent()) {
|
Optional<ModuleBase> modmenu = ModInfoProvider.getMod("petroleum.modmenu");
|
||||||
ConfigManager.getConfig().get().globalConfig.setButton(b, c);
|
if (modmenu.isPresent()) {
|
||||||
|
Optional<ConfigurationOption> buttonOption = modmenu.get().getConfigOption("petroleum.modmenu.buttons");
|
||||||
|
if (buttonOption.isPresent()) {
|
||||||
|
((ButtonPositionConfiguration)buttonOption.get()).setButton(b, c);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -80,13 +102,29 @@ public class ModMenu extends ModuleBase {
|
||||||
@Override
|
@Override
|
||||||
public void activate(MinecraftClient client) {
|
public void activate(MinecraftClient client) {
|
||||||
this.toggle();
|
this.toggle();
|
||||||
if (ConfigManager.getConfig().get().isModuleEnabled(this.getModuleName())) {
|
if (ConfigManager.getConfig(this.getParent()).get().isModuleEnabled(this.getModuleName())) {
|
||||||
client.openScreen(new PModMenuScreen());
|
client.openScreen(new PModMenuScreen());
|
||||||
} else {
|
} else {
|
||||||
|
this.toggle(); //turn off again (hopefully)
|
||||||
client.openScreen(null);
|
client.openScreen(null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<KeyBinding, ModuleFunction> getDefaultBindings() {
|
||||||
|
Map<KeyBinding, ModuleFunction> binds = new HashMap<>();
|
||||||
|
|
||||||
|
KeyBinding openMenu = new KeyBinding(
|
||||||
|
"key.petroleum.togglemodmenu",
|
||||||
|
InputUtil.Type.KEYSYM,
|
||||||
|
GLFW.GLFW_KEY_RIGHT_CONTROL,
|
||||||
|
"category.petroleum"
|
||||||
|
);
|
||||||
|
binds.put(openMenu, new ModuleFunction("petroleum.modmenu.toggle", this));
|
||||||
|
|
||||||
|
return binds;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets buttons.
|
* Gets buttons.
|
||||||
*
|
*
|
||||||
|
|
|
@ -2,13 +2,12 @@ package pm.j4.petroleum.modules.splash;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import net.minecraft.text.LiteralText;
|
import pm.j4.kerosene.util.module.ModuleBase;
|
||||||
|
import pm.j4.kerosene.util.module.option.ConfigurationOption;
|
||||||
import pm.j4.petroleum.PetroleumMod;
|
import pm.j4.petroleum.PetroleumMod;
|
||||||
import pm.j4.petroleum.gui.PModuleConfigEntry;
|
import pm.j4.kerosene.util.module.ModuleBase;
|
||||||
import pm.j4.petroleum.gui.PModuleConfigPane;
|
import pm.j4.kerosene.util.module.option.BooleanOption;
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
import pm.j4.kerosene.util.module.option.ConfigurationOption;
|
||||||
import pm.j4.petroleum.util.module.option.BooleanOption;
|
|
||||||
import pm.j4.petroleum.util.module.option.ConfigurationOption;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type Splash text.
|
* The type Splash text.
|
||||||
|
@ -18,7 +17,8 @@ public class SplashText extends ModuleBase {
|
||||||
* Instantiates a new Splash text.
|
* Instantiates a new Splash text.
|
||||||
*/
|
*/
|
||||||
public SplashText() {
|
public SplashText() {
|
||||||
super("petroleum.splashtext",
|
super("petroleum",
|
||||||
|
"petroleum.splashtext",
|
||||||
"petroleum.misc",
|
"petroleum.misc",
|
||||||
false,
|
false,
|
||||||
true,
|
true,
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
package pm.j4.petroleum.modules.xray;
|
package pm.j4.petroleum.modules.xray;
|
||||||
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
import pm.j4.kerosene.util.module.ModuleBase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type Xray.
|
* The type Xray.
|
||||||
|
@ -10,7 +10,8 @@ public class Xray extends ModuleBase {
|
||||||
* Instantiates a new Xray.
|
* Instantiates a new Xray.
|
||||||
*/
|
*/
|
||||||
public Xray() {
|
public Xray() {
|
||||||
super("petroleum.xray",
|
super("petroleum",
|
||||||
|
"petroleum.xray",
|
||||||
"petroleum.render",
|
"petroleum.render",
|
||||||
true,
|
true,
|
||||||
false,
|
false,
|
||||||
|
|
|
@ -0,0 +1,81 @@
|
||||||
|
package pm.j4.petroleum.util.config;
|
||||||
|
|
||||||
|
import com.google.gson.JsonElement;
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import pm.j4.kerosene.util.config.ConfigManager;
|
||||||
|
import pm.j4.kerosene.util.config.GlobalConfig;
|
||||||
|
import pm.j4.kerosene.util.module.ModuleBase;
|
||||||
|
import pm.j4.kerosene.util.module.option.ConfigurationOption;
|
||||||
|
import pm.j4.petroleum.util.data.ButtonInformation;
|
||||||
|
|
||||||
|
public class ButtonPositionConfiguration extends ConfigurationOption {
|
||||||
|
/**
|
||||||
|
* The Button locations.
|
||||||
|
*/
|
||||||
|
private final Map<String, ButtonInformation> buttonLocations = new HashMap<>();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Instantiates a new Configuration option.
|
||||||
|
*
|
||||||
|
* @param key the key
|
||||||
|
* @param description the description
|
||||||
|
* @param parent the parent
|
||||||
|
*/
|
||||||
|
public ButtonPositionConfiguration(String key, String description, ModuleBase parent) {
|
||||||
|
super(key, description, parent);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets button.
|
||||||
|
*
|
||||||
|
* @param category the category
|
||||||
|
* @param buttonInformation the button information
|
||||||
|
*/
|
||||||
|
public void setButton(String category, ButtonInformation buttonInformation) {
|
||||||
|
if (buttonLocations.containsKey(category)) {
|
||||||
|
buttonLocations.replace(category, buttonInformation);
|
||||||
|
} else {
|
||||||
|
buttonLocations.put(category, buttonInformation);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets button.
|
||||||
|
*
|
||||||
|
* @param category the category
|
||||||
|
* @return the button
|
||||||
|
*/
|
||||||
|
public ButtonInformation getButton(String category) {
|
||||||
|
if (buttonLocations.containsKey(category)) {
|
||||||
|
return buttonLocations.get(category);
|
||||||
|
}
|
||||||
|
System.out.println("Could not find button of category " + category);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getStringValue() {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void fromJson(JsonElement e) {
|
||||||
|
JsonObject obj = e.getAsJsonObject();
|
||||||
|
obj.entrySet().forEach(entry -> {
|
||||||
|
ButtonInformation button = ConfigManager.deserializeElement(entry.getValue(), ButtonInformation.class);
|
||||||
|
buttonLocations.put(entry.getKey(), button);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public JsonElement toJson() {
|
||||||
|
JsonObject obj = new JsonObject();
|
||||||
|
buttonLocations.forEach((key, value) -> {
|
||||||
|
JsonElement element = ConfigManager.serializeElement(value);
|
||||||
|
obj.add(key, element);
|
||||||
|
});
|
||||||
|
return obj;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,59 +0,0 @@
|
||||||
package pm.j4.petroleum.util.config;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import pm.j4.petroleum.PetroleumMod;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Config.
|
|
||||||
*/
|
|
||||||
public abstract class Config {
|
|
||||||
/**
|
|
||||||
* The Enabled modules.
|
|
||||||
*/
|
|
||||||
public List<String> enabledModules = new ArrayList<>();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Is enabled boolean.
|
|
||||||
*
|
|
||||||
* @param mod the mod
|
|
||||||
* @return the boolean
|
|
||||||
*/
|
|
||||||
public boolean isEnabled(String mod) {
|
|
||||||
return enabledModules.contains(mod);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Disable module.
|
|
||||||
*
|
|
||||||
* @param mod the mod
|
|
||||||
*/
|
|
||||||
public void disableModule(String mod) {
|
|
||||||
if (isEnabled(mod) && PetroleumMod.isActive(mod) && PetroleumMod.getMod(mod).isPresent()) {
|
|
||||||
ModuleBase moduleInfo = PetroleumMod.getMod(mod).get();
|
|
||||||
if (moduleInfo.isActivatable()) {
|
|
||||||
enabledModules.remove(mod);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Toggle module.
|
|
||||||
*
|
|
||||||
* @param mod the mod
|
|
||||||
*/
|
|
||||||
public void toggleModule(String mod) {
|
|
||||||
if (PetroleumMod.isActive(mod) && PetroleumMod.getMod(mod).isPresent()) {
|
|
||||||
ModuleBase moduleInfo = PetroleumMod.getMod(mod).get();
|
|
||||||
if (moduleInfo.isActivatable()) {
|
|
||||||
if (isEnabled(mod)) {
|
|
||||||
enabledModules.remove(mod);
|
|
||||||
} else {
|
|
||||||
enabledModules.add(mod);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,94 +0,0 @@
|
||||||
package pm.j4.petroleum.util.config;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
import pm.j4.petroleum.PetroleumMod;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Config holder.
|
|
||||||
*/
|
|
||||||
public class ConfigHolder {
|
|
||||||
/**
|
|
||||||
* The Global config.
|
|
||||||
*/
|
|
||||||
public GlobalConfig globalConfig;
|
|
||||||
/**
|
|
||||||
* The Server configs.
|
|
||||||
*/
|
|
||||||
public Map<String, ServerConfig> serverConfigs;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Is module enabled boolean.
|
|
||||||
*
|
|
||||||
* @param module the module
|
|
||||||
* @return the boolean
|
|
||||||
*/
|
|
||||||
public boolean isModuleEnabled(String module) {
|
|
||||||
|
|
||||||
if (!PetroleumMod.isActive(module)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (globalConfig.isEnabled(module)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
String server = this.getServer();
|
|
||||||
if (serverConfigs.containsKey(server)) {
|
|
||||||
return serverConfigs.get(server).isEnabled(module);
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets enabled modules.
|
|
||||||
*
|
|
||||||
* @return the enabled modules
|
|
||||||
*/
|
|
||||||
public List<ModuleBase> getEnabledModules() {
|
|
||||||
List<ModuleBase> modules = PetroleumMod.getActiveMods();
|
|
||||||
return modules.stream().filter(module ->
|
|
||||||
isModuleEnabled(module.getModuleName())
|
|
||||||
).collect(Collectors.toList());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets server.
|
|
||||||
*
|
|
||||||
* @return the server
|
|
||||||
*/
|
|
||||||
public String getServer() {
|
|
||||||
return PetroleumMod.getServerAddress();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Toggle module.
|
|
||||||
*
|
|
||||||
* @param module the module
|
|
||||||
*/
|
|
||||||
public void toggleModule(String module) {
|
|
||||||
String server = this.getServer();
|
|
||||||
if (serverConfigs.containsKey(server)) {
|
|
||||||
System.out.println("Toggling module " + module + " on server " + server);
|
|
||||||
serverConfigs.get(server).toggleModule(module);
|
|
||||||
} else {
|
|
||||||
globalConfig.toggleModule(module);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Disable module.
|
|
||||||
*
|
|
||||||
* @param module the module
|
|
||||||
*/
|
|
||||||
public void disableModule(String module) {
|
|
||||||
String server = this.getServer();
|
|
||||||
if (serverConfigs.containsKey(server)) {
|
|
||||||
System.out.println("disabling module " + module + " on server " + server);
|
|
||||||
serverConfigs.get(server).disableModule(module);
|
|
||||||
} else {
|
|
||||||
globalConfig.disableModule(module);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,270 +0,0 @@
|
||||||
package pm.j4.petroleum.util.config;
|
|
||||||
|
|
||||||
import com.google.common.reflect.TypeToken;
|
|
||||||
import com.google.gson.*;
|
|
||||||
import java.io.*;
|
|
||||||
import java.lang.reflect.Type;
|
|
||||||
import java.util.*;
|
|
||||||
import net.fabricmc.loader.api.FabricLoader;
|
|
||||||
import pm.j4.petroleum.PetroleumMod;
|
|
||||||
import pm.j4.petroleum.modules.bindings.BindingInfo;
|
|
||||||
import pm.j4.petroleum.modules.menu.ModMenu;
|
|
||||||
import pm.j4.petroleum.util.data.ButtonInformation;
|
|
||||||
import pm.j4.petroleum.util.data.ModuleConfig;
|
|
||||||
import pm.j4.petroleum.util.data.OptionSerializiable;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Config manager.
|
|
||||||
*/
|
|
||||||
public class ConfigManager {
|
|
||||||
/**
|
|
||||||
* The constant GSON.
|
|
||||||
*/
|
|
||||||
public static final Gson GSON = new GsonBuilder()
|
|
||||||
.registerTypeAdapter(GlobalConfig.class, SerializationHelper.getGlobalSerializer())
|
|
||||||
.registerTypeAdapter(GlobalConfig.class, SerializationHelper.getGlobalDeserializer())
|
|
||||||
.setFieldNamingPolicy(FieldNamingPolicy.LOWER_CASE_WITH_UNDERSCORES).setPrettyPrinting().create();
|
|
||||||
/**
|
|
||||||
* The constant config.
|
|
||||||
*/
|
|
||||||
private static ConfigHolder config;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Prepare config file.
|
|
||||||
*
|
|
||||||
* @param path the path
|
|
||||||
* @param filename the filename
|
|
||||||
* @return the file
|
|
||||||
*/
|
|
||||||
private static File prepareConfigFile(String path, String filename) {
|
|
||||||
if (path != "") {
|
|
||||||
File directory = new File(FabricLoader.getInstance().getConfigDir().toString(), path);
|
|
||||||
if (!directory.exists()) directory.mkdir();
|
|
||||||
}
|
|
||||||
return new File(FabricLoader.getInstance().getConfigDir().toString(), path + filename);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Init config.
|
|
||||||
*/
|
|
||||||
public static void initConfig() {
|
|
||||||
if (config != null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
config = new ConfigHolder();
|
|
||||||
config.globalConfig = new DefaultConfig();
|
|
||||||
config.serverConfigs = new HashMap<>();
|
|
||||||
|
|
||||||
config = load("petroleum/", "petroleum.json", ConfigHolder.class);
|
|
||||||
initModules();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Init modules.
|
|
||||||
*/
|
|
||||||
public static void initModules() {
|
|
||||||
PetroleumMod.getActiveMods().forEach(module -> {
|
|
||||||
ModuleConfig options = load("petroleum/modules/", module.getModuleName() + ".json", ModuleConfig.class);
|
|
||||||
if (options != null && options.options != null) {
|
|
||||||
options.options.forEach((key, option) -> {
|
|
||||||
if (module.hasOption(option.key)) {
|
|
||||||
module.setConfigOption(option.key, option.value);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load.
|
|
||||||
*
|
|
||||||
* @param <T> the type parameter
|
|
||||||
* @param path the path
|
|
||||||
* @param filename the filename
|
|
||||||
* @param tClass the t class
|
|
||||||
* @return the t
|
|
||||||
*/
|
|
||||||
private static <T> T load(String path, String filename, Class<T> tClass) {
|
|
||||||
File file = prepareConfigFile(path, filename);
|
|
||||||
|
|
||||||
try {
|
|
||||||
if (!file.exists()) {
|
|
||||||
save(path, filename, tClass.newInstance());
|
|
||||||
}
|
|
||||||
if (file.exists()) {
|
|
||||||
BufferedReader reader = new BufferedReader(new FileReader(file));
|
|
||||||
T parsedConfig = null;
|
|
||||||
try {
|
|
||||||
parsedConfig = GSON.fromJson(reader, tClass);
|
|
||||||
} catch (Exception e) {
|
|
||||||
System.out.println("Couldn't parse config file");
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
if (parsedConfig != null) {
|
|
||||||
return parsedConfig;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (FileNotFoundException | InstantiationException | IllegalAccessException e) {
|
|
||||||
System.out.println("Couldn't load configuration file at " + path);
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Deserialize element t.
|
|
||||||
*
|
|
||||||
* @param <T> the type parameter
|
|
||||||
* @param element the element
|
|
||||||
* @param tClass the t class
|
|
||||||
* @return the t
|
|
||||||
*/
|
|
||||||
public static <T> T deserializeElement(JsonElement element, Class<T> tClass) {
|
|
||||||
return GSON.fromJson(element, tClass);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Save.
|
|
||||||
*
|
|
||||||
* @param <T> the type parameter
|
|
||||||
* @param path the path
|
|
||||||
* @param filename the filename
|
|
||||||
* @param data the data
|
|
||||||
*/
|
|
||||||
private static <T> void save(String path, String filename, T data) {
|
|
||||||
File file = prepareConfigFile(path, filename);
|
|
||||||
|
|
||||||
String json = GSON.toJson(data);
|
|
||||||
try (FileWriter fileWriter = new FileWriter(file)) {
|
|
||||||
fileWriter.write(json);
|
|
||||||
} catch (IOException e) {
|
|
||||||
System.out.println("Couldn't save configuration file at " + path);
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Save module.
|
|
||||||
*
|
|
||||||
* @param b the b
|
|
||||||
*/
|
|
||||||
public static void saveModule(ModuleBase b) {
|
|
||||||
ModuleConfig c = new ModuleConfig();
|
|
||||||
c.options = GlobalConfig.serializeModuleConfiguration(b);
|
|
||||||
save("petroleum/modules/", b.getModuleName() + ".json", c);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Save all modules.
|
|
||||||
*/
|
|
||||||
public static void saveAllModules() {
|
|
||||||
List<ModuleBase> mods = PetroleumMod.getActiveMods();
|
|
||||||
mods.forEach(ConfigManager::saveModule);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Save global config.
|
|
||||||
*/
|
|
||||||
public static void saveGlobalConfig() {
|
|
||||||
save("petroleum/", "petroleum.json", config);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets config.
|
|
||||||
*
|
|
||||||
* @return the config
|
|
||||||
*/
|
|
||||||
public static Optional<ConfigHolder> getConfig() {
|
|
||||||
if (config == null) {
|
|
||||||
return Optional.empty();
|
|
||||||
}
|
|
||||||
return Optional.of(config);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Serialization helper.
|
|
||||||
*/
|
|
||||||
class SerializationHelper {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The constant s.
|
|
||||||
*/
|
|
||||||
private static final JsonSerializer<GlobalConfig> GLOBAL_CONFIG_JSON_SERIALIZER = (src, typeOfSrc, ctx) -> {
|
|
||||||
JsonObject jsonConfig = new JsonObject();
|
|
||||||
|
|
||||||
JsonArray bindings = ctx.serialize(src.serializeBindings()).getAsJsonArray();
|
|
||||||
jsonConfig.add("bindings", bindings);
|
|
||||||
|
|
||||||
JsonArray modules = ctx.serialize(src.enabledModules).getAsJsonArray();
|
|
||||||
jsonConfig.add("enabled_modules", modules);
|
|
||||||
|
|
||||||
JsonObject tabCoordinates = new JsonObject();
|
|
||||||
ModMenu.getButtons().forEach((category, coordinates) -> {
|
|
||||||
tabCoordinates.add(category, ctx.serialize(coordinates));
|
|
||||||
});
|
|
||||||
jsonConfig.add("button_coordinates", tabCoordinates);
|
|
||||||
|
|
||||||
return jsonConfig;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The constant ds.
|
|
||||||
*/
|
|
||||||
private static final JsonDeserializer<GlobalConfig> GLOBAL_CONFIG_JSON_DESERIALIZER = ((json, typeOfT, ctx) -> {
|
|
||||||
JsonObject obj = json.getAsJsonObject();
|
|
||||||
|
|
||||||
List<BindingInfo> bindings = new ArrayList<>();
|
|
||||||
if (obj.has("bindings")) {
|
|
||||||
obj.get("bindings").getAsJsonArray().forEach(b -> bindings.add(ctx.deserialize(b, BindingInfo.class)));
|
|
||||||
}
|
|
||||||
List<String> modules = new ArrayList<>();
|
|
||||||
if (obj.has("enabled_modules")) {
|
|
||||||
obj.get("enabled_modules").getAsJsonArray().forEach(m -> modules.add(m.getAsString()));
|
|
||||||
}
|
|
||||||
GlobalConfig cfg = new GlobalConfig();
|
|
||||||
Map<String, List<OptionSerializiable>> options;
|
|
||||||
Type type = new TypeToken<Map<String, List<OptionSerializiable>>>() {
|
|
||||||
}.getType();
|
|
||||||
if (obj.has("module_configuration")) {
|
|
||||||
options = ctx.deserialize(obj.get("module_configuration"), type);
|
|
||||||
} else {
|
|
||||||
options = new HashMap<>();
|
|
||||||
}
|
|
||||||
if (obj.has("button_coordinates")) {
|
|
||||||
obj.get("button_coordinates").getAsJsonObject().entrySet().forEach(
|
|
||||||
value -> {
|
|
||||||
cfg.setButton(value.getKey(), ctx.deserialize(value.getValue(), ButtonInformation.class));
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
PetroleumMod.getActiveMods().forEach(module -> {
|
|
||||||
if (options.containsKey(module.getModuleName())) {
|
|
||||||
cfg.deserializeModuleConfiguration(options.get(module.getModuleName()), module);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
cfg.deserializeBindings(bindings);
|
|
||||||
cfg.enabledModules = modules;
|
|
||||||
return cfg;
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets serializer.
|
|
||||||
*
|
|
||||||
* @return the serializer
|
|
||||||
*/
|
|
||||||
public static JsonSerializer<GlobalConfig> getGlobalSerializer() {
|
|
||||||
return GLOBAL_CONFIG_JSON_SERIALIZER;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets deserializer.
|
|
||||||
*
|
|
||||||
* @return the deserializer
|
|
||||||
*/
|
|
||||||
public static JsonDeserializer<GlobalConfig> getGlobalDeserializer() {
|
|
||||||
return GLOBAL_CONFIG_JSON_DESERIALIZER;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,15 +0,0 @@
|
||||||
package pm.j4.petroleum.util.config;
|
|
||||||
|
|
||||||
import java.util.Collections;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Default config.
|
|
||||||
*/
|
|
||||||
public class DefaultConfig extends GlobalConfig {
|
|
||||||
/**
|
|
||||||
* Instantiates a new Default config.
|
|
||||||
*/
|
|
||||||
public DefaultConfig() {
|
|
||||||
this.enabledModules = Collections.singletonList("petroleum.splashtext");
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,195 +0,0 @@
|
||||||
package pm.j4.petroleum.util.config;
|
|
||||||
|
|
||||||
import java.util.*;
|
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
|
||||||
import net.minecraft.client.options.KeyBinding;
|
|
||||||
import net.minecraft.client.util.InputUtil;
|
|
||||||
import pm.j4.petroleum.PetroleumMod;
|
|
||||||
import pm.j4.petroleum.modules.bindings.BindingInfo;
|
|
||||||
import pm.j4.petroleum.util.data.ButtonInformation;
|
|
||||||
import pm.j4.petroleum.util.data.OptionSerializiable;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
import pm.j4.petroleum.util.module.option.ConfigurationOption;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Global config.
|
|
||||||
*/
|
|
||||||
public class GlobalConfig extends Config {
|
|
||||||
/**
|
|
||||||
* The Bindings.
|
|
||||||
*/
|
|
||||||
public final Map<KeyBinding, ModuleBase> bindings = new HashMap<>();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Is bound boolean.
|
|
||||||
*
|
|
||||||
* @param func the func
|
|
||||||
* @return the boolean
|
|
||||||
*/
|
|
||||||
public boolean isBound(ModuleBase func) {
|
|
||||||
AtomicBoolean found = new AtomicBoolean(false);
|
|
||||||
bindings.forEach((key, binding) -> {
|
|
||||||
if (binding.equals(func)) {
|
|
||||||
found.set(true);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return found.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets binding.
|
|
||||||
*
|
|
||||||
* @param bind the bind
|
|
||||||
* @param func the func
|
|
||||||
*/
|
|
||||||
public void setBinding(KeyBinding bind, ModuleBase func) {
|
|
||||||
AtomicReference<KeyBinding> match = new AtomicReference<>();
|
|
||||||
if (bindings.containsValue(func)) {
|
|
||||||
bindings.forEach((key, binding) -> {
|
|
||||||
if (binding.equals(func)) {
|
|
||||||
PetroleumMod.removeBind(key);
|
|
||||||
match.set(key);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (match.get() != null) {
|
|
||||||
bindings.remove(match.get());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (PetroleumMod.isActive(func.getModuleName())) {
|
|
||||||
PetroleumMod.addBind(bind);
|
|
||||||
bindings.put(bind, func);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Convert binding.
|
|
||||||
*
|
|
||||||
* @param info the info
|
|
||||||
*/
|
|
||||||
private void convertBinding(BindingInfo info) {
|
|
||||||
Optional<ModuleBase> match = PetroleumMod.getMod(info.attachedModuleName);
|
|
||||||
match.ifPresent(moduleBase -> setBinding(reconstructBinding(info),
|
|
||||||
moduleBase));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Reconstruct binding key binding.
|
|
||||||
*
|
|
||||||
* @param info the info
|
|
||||||
* @return the key binding
|
|
||||||
*/
|
|
||||||
public static KeyBinding reconstructBinding(BindingInfo info) {
|
|
||||||
return new KeyBinding(
|
|
||||||
info.translationKey,
|
|
||||||
info.type,
|
|
||||||
info.key,
|
|
||||||
info.category
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Extract binding info.
|
|
||||||
*
|
|
||||||
* @param b the b
|
|
||||||
* @param f the f
|
|
||||||
* @return the binding info
|
|
||||||
*/
|
|
||||||
public static BindingInfo extractBinding(KeyBinding b, ModuleBase f) {
|
|
||||||
BindingInfo res = new BindingInfo();
|
|
||||||
res.attachedModuleName = f.getModuleName();
|
|
||||||
|
|
||||||
res.translationKey = b.getTranslationKey();
|
|
||||||
InputUtil.Key k = b.getDefaultKey();
|
|
||||||
res.type = k.getCategory();
|
|
||||||
res.key = k.getCode();
|
|
||||||
res.category = b.getCategory();
|
|
||||||
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Serialize bindings list.
|
|
||||||
*
|
|
||||||
* @return the list
|
|
||||||
*/
|
|
||||||
public List<BindingInfo> serializeBindings() {
|
|
||||||
List<BindingInfo> b = new ArrayList<>();
|
|
||||||
bindings.forEach((k, f) -> b.add(extractBinding(k, f)));
|
|
||||||
return b;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Deserialize bindings.
|
|
||||||
*
|
|
||||||
* @param info the info
|
|
||||||
*/
|
|
||||||
public void deserializeBindings(List<BindingInfo> info) {
|
|
||||||
info.forEach(this::convertBinding);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Serialize module configuration list.
|
|
||||||
*
|
|
||||||
* @param module the module
|
|
||||||
* @return the list
|
|
||||||
*/
|
|
||||||
public static Map<String, OptionSerializiable> serializeModuleConfiguration(ModuleBase module) {
|
|
||||||
Map<String, OptionSerializiable> opts = new HashMap<>();
|
|
||||||
Map<String, ConfigurationOption> configuration = module.getModuleConfiguration();
|
|
||||||
configuration.forEach((key, value) -> {
|
|
||||||
opts.put(key, new OptionSerializiable(key, value.toJson()));
|
|
||||||
});
|
|
||||||
return opts;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Deserialize module configuration.
|
|
||||||
*
|
|
||||||
* @param opts the opts
|
|
||||||
* @param module the module
|
|
||||||
*/
|
|
||||||
public void deserializeModuleConfiguration(List<OptionSerializiable> opts, ModuleBase module) {
|
|
||||||
opts.forEach(option -> {
|
|
||||||
if (module.hasOption(option.key)) {
|
|
||||||
module.setConfigOption(option.key, option.value);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Button locations.
|
|
||||||
*/
|
|
||||||
private final Map<String, ButtonInformation> buttonLocations = new HashMap<>();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets button.
|
|
||||||
*
|
|
||||||
* @param category the category
|
|
||||||
* @param buttonInformation the button information
|
|
||||||
*/
|
|
||||||
public void setButton(String category, ButtonInformation buttonInformation) {
|
|
||||||
if (buttonLocations.containsKey(category)) {
|
|
||||||
buttonLocations.replace(category, buttonInformation);
|
|
||||||
} else {
|
|
||||||
buttonLocations.put(category, buttonInformation);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets button.
|
|
||||||
*
|
|
||||||
* @param category the category
|
|
||||||
* @return the button
|
|
||||||
*/
|
|
||||||
public ButtonInformation getButton(String category) {
|
|
||||||
if (buttonLocations.containsKey(category)) {
|
|
||||||
return buttonLocations.get(category);
|
|
||||||
}
|
|
||||||
System.out.println("Could not find button of category " + category);
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,11 +0,0 @@
|
||||||
package pm.j4.petroleum.util.config;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Server config.
|
|
||||||
*/
|
|
||||||
public class ServerConfig extends Config {
|
|
||||||
/**
|
|
||||||
* The Address.
|
|
||||||
*/
|
|
||||||
public String address = "";
|
|
||||||
}
|
|
|
@ -1,8 +1,5 @@
|
||||||
package pm.j4.petroleum.util.data;
|
package pm.j4.petroleum.util.data;
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Button information.
|
|
||||||
*/
|
|
||||||
public class ButtonInformation {
|
public class ButtonInformation {
|
||||||
/**
|
/**
|
||||||
* The X.
|
* The X.
|
||||||
|
|
|
@ -1,47 +0,0 @@
|
||||||
package pm.j4.petroleum.util.data;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import pm.j4.petroleum.PetroleumMod;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Category.
|
|
||||||
*/
|
|
||||||
public class Category {
|
|
||||||
/**
|
|
||||||
* Gets category map.
|
|
||||||
*
|
|
||||||
* @return the category map
|
|
||||||
*/
|
|
||||||
public static Map<String, List<ModuleBase>> getCategoryMap() {
|
|
||||||
List<ModuleBase> modules = PetroleumMod.getActiveMods();
|
|
||||||
Map<String, List<ModuleBase>> categoryMap = new HashMap<>();
|
|
||||||
modules.forEach(module -> {
|
|
||||||
if (!categoryMap.containsKey(module.getCategory())) {
|
|
||||||
List<ModuleBase> m = new ArrayList<>();
|
|
||||||
m.add(module);
|
|
||||||
categoryMap.put(module.getCategory(), m);
|
|
||||||
} else {
|
|
||||||
List<ModuleBase> m = categoryMap.get(module.getCategory());
|
|
||||||
List<ModuleBase> nm = new ArrayList<>();
|
|
||||||
nm.addAll(m);
|
|
||||||
nm.add(module);
|
|
||||||
categoryMap.replace(module.getCategory(), nm);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return categoryMap;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets by category.
|
|
||||||
*
|
|
||||||
* @param category the category
|
|
||||||
* @return the by category
|
|
||||||
*/
|
|
||||||
public static List<ModuleBase> getByCategory(String category) {
|
|
||||||
return getCategoryMap().containsKey(category) ? getCategoryMap().get(category) : new ArrayList<>();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,13 +0,0 @@
|
||||||
package pm.j4.petroleum.util.data;
|
|
||||||
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Module config.
|
|
||||||
*/
|
|
||||||
public class ModuleConfig {
|
|
||||||
/**
|
|
||||||
* The Options.
|
|
||||||
*/
|
|
||||||
public Map<String, OptionSerializiable> options;
|
|
||||||
}
|
|
|
@ -1,28 +0,0 @@
|
||||||
package pm.j4.petroleum.util.data;
|
|
||||||
|
|
||||||
import com.google.gson.JsonElement;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Option serializiable.
|
|
||||||
*/
|
|
||||||
public class OptionSerializiable {
|
|
||||||
/**
|
|
||||||
* Instantiates a new Option serializiable.
|
|
||||||
*
|
|
||||||
* @param key the key
|
|
||||||
* @param value the value
|
|
||||||
*/
|
|
||||||
public OptionSerializiable(String key, JsonElement value) {
|
|
||||||
this.value = value;
|
|
||||||
this.key = key;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Value.
|
|
||||||
*/
|
|
||||||
public final JsonElement value;
|
|
||||||
/**
|
|
||||||
* The Key.
|
|
||||||
*/
|
|
||||||
public final String key;
|
|
||||||
}
|
|
|
@ -1,248 +0,0 @@
|
||||||
package pm.j4.petroleum.util.module;
|
|
||||||
|
|
||||||
import com.google.gson.JsonElement;
|
|
||||||
import java.util.*;
|
|
||||||
import net.minecraft.client.MinecraftClient;
|
|
||||||
import net.minecraft.text.TranslatableText;
|
|
||||||
import pm.j4.petroleum.gui.PModuleConfigEntry;
|
|
||||||
import pm.j4.petroleum.gui.PModuleConfigPane;
|
|
||||||
import pm.j4.petroleum.util.config.ConfigHolder;
|
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
|
||||||
import pm.j4.petroleum.util.module.option.ConfigurationOption;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Basis for all mods, used so that modules all have a common activation point and settings.
|
|
||||||
*/
|
|
||||||
public abstract class ModuleBase {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new Module base.
|
|
||||||
* Parameters should be constant across restarts.
|
|
||||||
*
|
|
||||||
* @param name The name of the module
|
|
||||||
* @param category the category
|
|
||||||
* @param activatable Whether a module can be activated, or if it will remain in the state it was upon startup
|
|
||||||
* @param hidden Whether the module will show up in @link pm.j4.petroleum.modules.menu.ModMenu or the active module list
|
|
||||||
* @param hasConfigMenu whether a button in the configuration menu will show
|
|
||||||
*/
|
|
||||||
public ModuleBase(String name, String category, boolean activatable, boolean hidden, boolean hasConfigMenu) {
|
|
||||||
this.moduleName = name;
|
|
||||||
this.category = category;
|
|
||||||
this.readableName = new TranslatableText(name);
|
|
||||||
this.activatable = activatable;
|
|
||||||
this.hidden = hidden;
|
|
||||||
this.hasConfigMenu = hasConfigMenu;
|
|
||||||
this.moduleOptions = this.convertDefaultConfig();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Init.
|
|
||||||
*/
|
|
||||||
public void init() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Activate. Should be overridden.
|
|
||||||
*
|
|
||||||
* @param client the client
|
|
||||||
*/
|
|
||||||
public void activate(MinecraftClient client) {
|
|
||||||
this.toggle();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Toggle mod.
|
|
||||||
*/
|
|
||||||
public void toggle() {
|
|
||||||
Optional<ConfigHolder> config = ConfigManager.getConfig();
|
|
||||||
config.ifPresent(configHolder -> configHolder.toggleModule(this.moduleName));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Module's name.
|
|
||||||
*/
|
|
||||||
private final String moduleName;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets module name.
|
|
||||||
*
|
|
||||||
* @return the module name
|
|
||||||
*/
|
|
||||||
public String getModuleName() {
|
|
||||||
return this.moduleName;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Category.
|
|
||||||
*/
|
|
||||||
private final String category;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets category.
|
|
||||||
*
|
|
||||||
* @return the category
|
|
||||||
*/
|
|
||||||
public String getCategory() {
|
|
||||||
return this.category;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Readable name.
|
|
||||||
*/
|
|
||||||
private final TranslatableText readableName;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets readable name.
|
|
||||||
*
|
|
||||||
* @return the readable name
|
|
||||||
*/
|
|
||||||
public TranslatableText getReadableName() {
|
|
||||||
return this.readableName;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Activatable.
|
|
||||||
*/
|
|
||||||
private final boolean activatable;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Is activatable boolean.
|
|
||||||
*
|
|
||||||
* @return the boolean
|
|
||||||
*/
|
|
||||||
public boolean isActivatable() {
|
|
||||||
return activatable;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Hidden.
|
|
||||||
*/
|
|
||||||
private final boolean hidden;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Is hidden boolean.
|
|
||||||
*
|
|
||||||
* @return the boolean
|
|
||||||
*/
|
|
||||||
public boolean isHidden() {
|
|
||||||
return hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Has config menu.
|
|
||||||
*/
|
|
||||||
private final boolean hasConfigMenu;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Configurable boolean.
|
|
||||||
*
|
|
||||||
* @return the boolean
|
|
||||||
*/
|
|
||||||
public boolean configurable() {
|
|
||||||
return hasConfigMenu;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Module options.
|
|
||||||
*/
|
|
||||||
private final Map<String, ConfigurationOption> moduleOptions;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets module configuration.
|
|
||||||
*
|
|
||||||
* @return the module configuration
|
|
||||||
*/
|
|
||||||
public Map<String, ConfigurationOption> getModuleConfiguration() {
|
|
||||||
return moduleOptions;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets config option.
|
|
||||||
* This will fail if the option is not already present in a module.
|
|
||||||
* <p>
|
|
||||||
*
|
|
||||||
* @param key the key
|
|
||||||
* @param value the value
|
|
||||||
* @return whether the operation was successful.
|
|
||||||
*/
|
|
||||||
public boolean setConfigOption(String key, JsonElement value) {
|
|
||||||
if (moduleOptions.containsKey(key)) {
|
|
||||||
moduleOptions.get(key).fromJson(value);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void updateConfigOption(String key, ConfigurationOption option) {
|
|
||||||
System.out.println("update config option" + key + option.getStringValue());
|
|
||||||
System.out.println(moduleOptions.keySet());
|
|
||||||
if(moduleOptions.containsKey(key)) {
|
|
||||||
System.out.println("matched");
|
|
||||||
moduleOptions.replace(key, option);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Has option boolean.
|
|
||||||
*
|
|
||||||
* @param key the key
|
|
||||||
* @return the boolean
|
|
||||||
*/
|
|
||||||
public boolean hasOption(String key) {
|
|
||||||
return moduleOptions.containsKey(key);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets default config.
|
|
||||||
*
|
|
||||||
* @return the default config
|
|
||||||
*/
|
|
||||||
protected List<ConfigurationOption> getDefaultConfig() {
|
|
||||||
return new ArrayList<>();
|
|
||||||
}
|
|
||||||
|
|
||||||
private Map<String, ConfigurationOption> convertDefaultConfig() {
|
|
||||||
List<ConfigurationOption> options = this.getDefaultConfig();
|
|
||||||
Map<String, ConfigurationOption> mapped = new HashMap<>();
|
|
||||||
options.forEach((option) -> {
|
|
||||||
mapped.put(option.getConfigKey(), option);
|
|
||||||
});
|
|
||||||
return mapped;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets config option.
|
|
||||||
*
|
|
||||||
* @param key the key
|
|
||||||
* @return the config option
|
|
||||||
*/
|
|
||||||
public Optional<ConfigurationOption> getConfigOption(String key) {
|
|
||||||
if (moduleOptions.containsKey(key)) {
|
|
||||||
return Optional.of(moduleOptions.get(key));
|
|
||||||
}
|
|
||||||
return Optional.empty();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets config entries.
|
|
||||||
*
|
|
||||||
* @return the config entries
|
|
||||||
*/
|
|
||||||
public List<PModuleConfigEntry> getConfigEntries(PModuleConfigPane sourcePane) {
|
|
||||||
List<PModuleConfigEntry> entries = new ArrayList<>();
|
|
||||||
this.getModuleConfiguration().forEach((name, option) -> entries.add(new PModuleConfigEntry(option, new TranslatableText(name), sourcePane)));
|
|
||||||
return entries;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Equals boolean.
|
|
||||||
*
|
|
||||||
* @param other the other
|
|
||||||
* @return the boolean
|
|
||||||
*/
|
|
||||||
public boolean equals(ModuleBase other) {
|
|
||||||
return Objects.equals(this.moduleName, other.getModuleName());
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,45 +0,0 @@
|
||||||
package pm.j4.petroleum.util.module.option;
|
|
||||||
|
|
||||||
import com.google.gson.JsonElement;
|
|
||||||
import com.google.gson.JsonPrimitive;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Boolean value.
|
|
||||||
*/
|
|
||||||
public class BooleanOption extends ConfigurationOption {
|
|
||||||
/**
|
|
||||||
* The Value.
|
|
||||||
*/
|
|
||||||
private boolean value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new Configuration option.
|
|
||||||
*
|
|
||||||
* @param key
|
|
||||||
* @param description the description
|
|
||||||
*/
|
|
||||||
public BooleanOption(String key, String description, ModuleBase parent) {
|
|
||||||
super(key, description, parent);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
public void setValue(boolean value) { this.value = value; }
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getStringValue() {
|
|
||||||
return Boolean.toString(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void fromJson(JsonElement e) {
|
|
||||||
this.value = e.getAsBoolean();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public JsonElement toJson() {
|
|
||||||
return new JsonPrimitive(value);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,59 +0,0 @@
|
||||||
package pm.j4.petroleum.util.module.option;
|
|
||||||
|
|
||||||
import com.google.gson.JsonElement;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Configuration option.
|
|
||||||
*/
|
|
||||||
public abstract class ConfigurationOption {
|
|
||||||
/**
|
|
||||||
* The Description.
|
|
||||||
*/
|
|
||||||
private final String description;
|
|
||||||
private final String key;
|
|
||||||
private final ModuleBase parent;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new Configuration option.
|
|
||||||
*
|
|
||||||
* @param description the description
|
|
||||||
*/
|
|
||||||
public ConfigurationOption(String key, String description, ModuleBase parent) {
|
|
||||||
this.description = description;
|
|
||||||
this.key = key;
|
|
||||||
this.parent = parent;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* Gets description.
|
|
||||||
*
|
|
||||||
* @return the description
|
|
||||||
*/
|
|
||||||
public final String getDescription() {
|
|
||||||
return this.description;
|
|
||||||
}
|
|
||||||
public final String getConfigKey() { return key; }
|
|
||||||
public final ModuleBase getParent() { return parent; }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets string value.
|
|
||||||
*
|
|
||||||
* @return the string value
|
|
||||||
*/
|
|
||||||
public abstract String getStringValue();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* From json.
|
|
||||||
*
|
|
||||||
* @param e the e
|
|
||||||
*/
|
|
||||||
public abstract void fromJson(JsonElement e);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To json json element.
|
|
||||||
*
|
|
||||||
* @return the json element
|
|
||||||
*/
|
|
||||||
public abstract JsonElement toJson();
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,42 +0,0 @@
|
||||||
package pm.j4.petroleum.util.module.option;
|
|
||||||
|
|
||||||
import com.google.gson.JsonElement;
|
|
||||||
import com.google.gson.JsonPrimitive;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Integer value.
|
|
||||||
*/
|
|
||||||
public class IntegerOption extends ConfigurationOption {
|
|
||||||
/**
|
|
||||||
* The Value.
|
|
||||||
*/
|
|
||||||
private int value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new Configuration option.
|
|
||||||
*
|
|
||||||
* @param key
|
|
||||||
* @param description the description
|
|
||||||
* @param parent
|
|
||||||
*/
|
|
||||||
public IntegerOption(String key, String description, ModuleBase parent) {
|
|
||||||
super(key, description, parent);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getStringValue() {
|
|
||||||
return Integer.toString(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void fromJson(JsonElement e) {
|
|
||||||
this.value = e.getAsInt();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public JsonElement toJson() {
|
|
||||||
return new JsonPrimitive(value);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,66 +0,0 @@
|
||||||
package pm.j4.petroleum.util.module.option;
|
|
||||||
|
|
||||||
import com.google.gson.JsonElement;
|
|
||||||
import net.minecraft.client.options.KeyBinding;
|
|
||||||
import pm.j4.petroleum.modules.bindings.BindingInfo;
|
|
||||||
import pm.j4.petroleum.util.config.ConfigManager;
|
|
||||||
import pm.j4.petroleum.util.config.GlobalConfig;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type Keybind value.
|
|
||||||
*/
|
|
||||||
public class KeybindOption extends ConfigurationOption {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Value.
|
|
||||||
*/
|
|
||||||
private KeyBinding value;
|
|
||||||
/**
|
|
||||||
* The Converted value.
|
|
||||||
*/
|
|
||||||
private BindingInfo convertedValue;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new Configuration option.
|
|
||||||
*
|
|
||||||
* @param key
|
|
||||||
* @param description the description
|
|
||||||
* @param parent
|
|
||||||
*/
|
|
||||||
public KeybindOption(String key, String description, ModuleBase parent) {
|
|
||||||
super(key, description, parent);
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getTranslationKey() {
|
|
||||||
return value.getTranslationKey();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getStringValue() {
|
|
||||||
return value.getDefaultKey().getLocalizedText().getString();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void fromJson(JsonElement e) {
|
|
||||||
BindingInfo bindingInfo = ConfigManager.deserializeElement(e, BindingInfo.class);
|
|
||||||
this.convertedValue = bindingInfo;
|
|
||||||
this.value = GlobalConfig.reconstructBinding(bindingInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public JsonElement toJson() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* From keybind.
|
|
||||||
*
|
|
||||||
* @param bind the bind
|
|
||||||
* @param base the base
|
|
||||||
*/
|
|
||||||
public void fromKeybind(KeyBinding bind, ModuleBase base) {
|
|
||||||
this.value = bind;
|
|
||||||
this.convertedValue = GlobalConfig.extractBinding(bind, base);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,37 +0,0 @@
|
||||||
package pm.j4.petroleum.util.module.option;
|
|
||||||
|
|
||||||
import com.google.gson.JsonElement;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type List option.
|
|
||||||
*/
|
|
||||||
public class ListOption extends ConfigurationOption {
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new Configuration option.
|
|
||||||
*
|
|
||||||
* @param key
|
|
||||||
* @param description the description
|
|
||||||
* @param parent
|
|
||||||
*/
|
|
||||||
public ListOption(String key, String description, ModuleBase parent) {
|
|
||||||
super(key, description, parent);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getStringValue() {
|
|
||||||
return "ListObject";
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void fromJson(JsonElement e) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public JsonElement toJson() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,42 +0,0 @@
|
||||||
package pm.j4.petroleum.util.module.option;
|
|
||||||
|
|
||||||
import com.google.gson.JsonElement;
|
|
||||||
import com.google.gson.JsonPrimitive;
|
|
||||||
import pm.j4.petroleum.util.module.ModuleBase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type String value.
|
|
||||||
*/
|
|
||||||
public class StringOption extends ConfigurationOption {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Value.
|
|
||||||
*/
|
|
||||||
private String value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instantiates a new Configuration option.
|
|
||||||
*
|
|
||||||
* @param key
|
|
||||||
* @param description the description
|
|
||||||
* @param parent
|
|
||||||
*/
|
|
||||||
public StringOption(String key, String description, ModuleBase parent) {
|
|
||||||
super(key, description, parent);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public String getStringValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void fromJson(JsonElement e) {
|
|
||||||
this.value = e.getAsString();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public JsonElement toJson() {
|
|
||||||
return new JsonPrimitive(value);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -7,9 +7,7 @@
|
||||||
],
|
],
|
||||||
"client": [
|
"client": [
|
||||||
"DebugHudMixin",
|
"DebugHudMixin",
|
||||||
"EntryListWidgetAccessor",
|
|
||||||
"ModListMixin",
|
"ModListMixin",
|
||||||
"OptionsMenuMixin",
|
|
||||||
"TitleScreenMixin"
|
"TitleScreenMixin"
|
||||||
],
|
],
|
||||||
"injectors": {
|
"injectors": {
|
||||||
|
|
Loading…
Reference in a new issue