From 546d0b945a98c61cafd4cd9330db3936eee286d1 Mon Sep 17 00:00:00 2001 From: Wide-Cat <74723656+Wide-Cat@users.noreply.github.com> Date: Fri, 14 Jun 2024 21:21:09 +0100 Subject: [PATCH] Abstract shared code in prompts (#4641) --- .../utils/render/prompts/OkPrompt.java | 101 ++------------- .../utils/render/prompts/Prompt.java | 98 +++++++++++++++ .../utils/render/prompts/YesNoPrompt.java | 116 +++--------------- 3 files changed, 127 insertions(+), 188 deletions(-) create mode 100644 src/main/java/meteordevelopment/meteorclient/utils/render/prompts/Prompt.java diff --git a/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/OkPrompt.java b/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/OkPrompt.java index 6ec2986500..9f909773e2 100644 --- a/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/OkPrompt.java +++ b/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/OkPrompt.java @@ -5,120 +5,41 @@ package meteordevelopment.meteorclient.utils.render.prompts; -import com.mojang.blaze3d.systems.RenderSystem; import meteordevelopment.meteorclient.gui.GuiTheme; import meteordevelopment.meteorclient.gui.GuiThemes; -import meteordevelopment.meteorclient.gui.WindowScreen; -import meteordevelopment.meteorclient.gui.widgets.containers.WHorizontalList; import meteordevelopment.meteorclient.gui.widgets.pressable.WButton; -import meteordevelopment.meteorclient.gui.widgets.pressable.WCheckbox; import meteordevelopment.meteorclient.systems.config.Config; import net.minecraft.client.gui.screen.Screen; -import java.util.ArrayList; -import java.util.List; - import static meteordevelopment.meteorclient.MeteorClient.mc; -public class OkPrompt { - private final GuiTheme theme; - private final Screen parent; - - private String title = ""; - private final List messages = new ArrayList<>(); - private boolean dontShowAgainCheckboxVisible = true; - private String id = null; - +public class OkPrompt extends Prompt { private Runnable onOk = () -> {}; - private OkPrompt() { - this(GuiThemes.get(), mc.currentScreen); - } - private OkPrompt(GuiTheme theme, Screen parent) { - this.theme = theme; - this.parent = parent; + super(theme, parent); } public static OkPrompt create() { - return new OkPrompt(); + return new OkPrompt(GuiThemes.get(), mc.currentScreen); } public static OkPrompt create(GuiTheme theme, Screen parent) { return new OkPrompt(theme, parent); } - public OkPrompt title(String title) { - this.title = title; - return this; - } - - public OkPrompt message(String message) { - this.messages.add(message); - return this; - } - - public OkPrompt message(String message, Object... args) { - this.messages.add(String.format(message, args)); - return this; - } - - public OkPrompt dontShowAgainCheckboxVisible(boolean visible) { - this.dontShowAgainCheckboxVisible = visible; - return this; - } - - public OkPrompt id(String from) { - this.id = from; - return this; - } - public OkPrompt onOk(Runnable action) { this.onOk = action; return this; } - public boolean show() { - if (id == null) this.id(this.title); - if (Config.get().dontShowAgainPrompts.contains(id)) return false; - - if (!RenderSystem.isOnRenderThread()) { - RenderSystem.recordRenderCall(() -> mc.setScreen(new PromptScreen(theme))); - } - else { - mc.setScreen(new PromptScreen(theme)); - } - - return true; - } - - private class PromptScreen extends WindowScreen { - public PromptScreen(GuiTheme theme) { - super(theme, OkPrompt.this.title); - - this.parent = OkPrompt.this.parent; - } - - @Override - public void initWidgets() { - for (String line : messages) add(theme.label(line)).expandX(); - add(theme.horizontalSeparator()).expandX(); - - WCheckbox dontShowAgainCheckbox; - - if (dontShowAgainCheckboxVisible) { - WHorizontalList checkboxContainer = add(theme.horizontalList()).expandX().widget(); - dontShowAgainCheckbox = checkboxContainer.add(theme.checkbox(false)).widget(); - checkboxContainer.add(theme.label("Don't show this again.")).expandX(); - } else dontShowAgainCheckbox = null; - - WHorizontalList list = add(theme.horizontalList()).expandX().widget(); - WButton okButton = list.add(theme.button("Ok")).expandX().widget(); - okButton.action = () -> { - if (dontShowAgainCheckbox != null && dontShowAgainCheckbox.checked) Config.get().dontShowAgainPrompts.add(id); - onOk.run(); - close(); - }; - } + @Override + protected void initialiseWidgets(PromptScreen screen) { + WButton okButton = screen.list.add(theme.button("Ok")).expandX().widget(); + okButton.action = () -> { + if (screen.dontShowAgainCheckbox != null && screen.dontShowAgainCheckbox.checked) Config.get().dontShowAgainPrompts.add(id); + onOk.run(); + screen.close(); + }; } } diff --git a/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/Prompt.java b/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/Prompt.java new file mode 100644 index 0000000000..da8372968b --- /dev/null +++ b/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/Prompt.java @@ -0,0 +1,98 @@ +package meteordevelopment.meteorclient.utils.render.prompts; + +import com.mojang.blaze3d.systems.RenderSystem; +import meteordevelopment.meteorclient.gui.GuiTheme; +import meteordevelopment.meteorclient.gui.WindowScreen; +import meteordevelopment.meteorclient.gui.widgets.containers.WHorizontalList; +import meteordevelopment.meteorclient.gui.widgets.pressable.WCheckbox; +import meteordevelopment.meteorclient.systems.config.Config; +import net.minecraft.client.gui.screen.Screen; + +import java.util.ArrayList; +import java.util.List; + +import static meteordevelopment.meteorclient.MeteorClient.mc; + +@SuppressWarnings("unchecked") // cant instantiate a Prompt directly so this is fine +public abstract class Prompt { + final GuiTheme theme; + final Screen parent; + + String title = ""; + final List messages = new ArrayList<>(); + boolean dontShowAgainCheckboxVisible = true; + String id = null; + + protected Prompt(GuiTheme theme, Screen parent) { + this.theme = theme; + this.parent = parent; + } + + public T title(String title) { + this.title = title; + return (T) this; + } + + public T message(String message) { + this.messages.add(message); + return (T) this; + } + + public T message(String message, Object... args) { + this.messages.add(String.format(message, args)); + return (T) this; + } + + public T dontShowAgainCheckboxVisible(boolean visible) { + this.dontShowAgainCheckboxVisible = visible; + return (T) this; + } + + public T id(String from) { + this.id = from; + return (T) this; + } + + public boolean show() { + if (id == null) this.id(this.title); + if (Config.get().dontShowAgainPrompts.contains(id)) return false; + + if (!RenderSystem.isOnRenderThread()) { + RenderSystem.recordRenderCall(() -> mc.setScreen(new PromptScreen(theme))); + } + else { + mc.setScreen(new PromptScreen(theme)); + } + + return true; + } + + abstract void initialiseWidgets(PromptScreen screen); + + protected class PromptScreen extends WindowScreen { + WCheckbox dontShowAgainCheckbox; + WHorizontalList list; + + public PromptScreen(GuiTheme theme) { + super(theme, Prompt.this.title); + + this.parent = Prompt.this.parent; + } + + @Override + public void initWidgets() { + for (String line : messages) add(theme.label(line)).expandX(); + add(theme.horizontalSeparator()).expandX(); + + if (dontShowAgainCheckboxVisible) { + WHorizontalList checkboxContainer = add(theme.horizontalList()).expandX().widget(); + dontShowAgainCheckbox = checkboxContainer.add(theme.checkbox(false)).widget(); + checkboxContainer.add(theme.label("Don't show this again.")).expandX(); + } else dontShowAgainCheckbox = null; + + list = add(theme.horizontalList()).expandX().widget(); + + initialiseWidgets(this); + } + } +} diff --git a/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/YesNoPrompt.java b/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/YesNoPrompt.java index edf8d4e9fb..ccb1a4d250 100644 --- a/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/YesNoPrompt.java +++ b/src/main/java/meteordevelopment/meteorclient/utils/render/prompts/YesNoPrompt.java @@ -5,75 +5,30 @@ package meteordevelopment.meteorclient.utils.render.prompts; -import com.mojang.blaze3d.systems.RenderSystem; import meteordevelopment.meteorclient.gui.GuiTheme; import meteordevelopment.meteorclient.gui.GuiThemes; -import meteordevelopment.meteorclient.gui.WindowScreen; -import meteordevelopment.meteorclient.gui.widgets.containers.WHorizontalList; import meteordevelopment.meteorclient.gui.widgets.pressable.WButton; -import meteordevelopment.meteorclient.gui.widgets.pressable.WCheckbox; import meteordevelopment.meteorclient.systems.config.Config; import net.minecraft.client.gui.screen.Screen; -import java.util.ArrayList; -import java.util.List; - import static meteordevelopment.meteorclient.MeteorClient.mc; -public class YesNoPrompt { - private final GuiTheme theme; - private final Screen parent; - - private String title = ""; - private final List messages = new ArrayList<>(); - private boolean dontShowAgainCheckboxVisible = true; - private String id = null; - +public class YesNoPrompt extends Prompt { private Runnable onYes = () -> {}; private Runnable onNo = () -> {}; - private YesNoPrompt() { - this(GuiThemes.get(), mc.currentScreen); - } - private YesNoPrompt(GuiTheme theme, Screen parent) { - this.theme = theme; - this.parent = parent; + super(theme, parent); } public static YesNoPrompt create() { - return new YesNoPrompt(); + return new YesNoPrompt(GuiThemes.get(), mc.currentScreen); } public static YesNoPrompt create(GuiTheme theme, Screen parent) { return new YesNoPrompt(theme, parent); } - public YesNoPrompt title(String title) { - this.title = title; - return this; - } - - public YesNoPrompt message(String message) { - this.messages.add(message); - return this; - } - - public YesNoPrompt message(String message, Object... args) { - this.messages.add(String.format(message, args)); - return this; - } - - public YesNoPrompt dontShowAgainCheckboxVisible(boolean visible) { - this.dontShowAgainCheckboxVisible = visible; - return this; - } - - public YesNoPrompt id(String from) { - this.id = from; - return this; - } - public YesNoPrompt onYes(Runnable action) { this.onYes = action; return this; @@ -84,55 +39,20 @@ public YesNoPrompt onNo(Runnable action) { return this; } - public boolean show() { - if (id == null) this.id(this.title); - if (Config.get().dontShowAgainPrompts.contains(id)) return false; - - if (!RenderSystem.isOnRenderThread()) { - RenderSystem.recordRenderCall(() -> mc.setScreen(new PromptScreen(theme))); - } - else { - mc.setScreen(new PromptScreen(theme)); - } - - return true; - } - - private class PromptScreen extends WindowScreen { - public PromptScreen(GuiTheme theme) { - super(theme, YesNoPrompt.this.title); - - this.parent = YesNoPrompt.this.parent; - } - - @Override - public void initWidgets() { - for (String line : messages) add(theme.label(line)).expandX(); - add(theme.horizontalSeparator()).expandX(); - - WCheckbox dontShowAgainCheckbox; - - if (dontShowAgainCheckboxVisible) { - WHorizontalList checkboxContainer = add(theme.horizontalList()).expandX().widget(); - dontShowAgainCheckbox = checkboxContainer.add(theme.checkbox(false)).widget(); - checkboxContainer.add(theme.label("Don't show this again.")).expandX(); - } else dontShowAgainCheckbox = null; - - WHorizontalList list = add(theme.horizontalList()).expandX().widget(); - - WButton yesButton = list.add(theme.button("Yes")).expandX().widget(); - yesButton.action = () -> { - if (dontShowAgainCheckbox != null && dontShowAgainCheckbox.checked) Config.get().dontShowAgainPrompts.add(id); - onYes.run(); - close(); - }; - - WButton noButton = list.add(theme.button("No")).expandX().widget(); - noButton.action = () -> { - if (dontShowAgainCheckbox != null && dontShowAgainCheckbox.checked) Config.get().dontShowAgainPrompts.add(id); - onNo.run(); - close(); - }; - } + @Override + protected void initialiseWidgets(PromptScreen screen) { + WButton yesButton = screen.list.add(theme.button("Yes")).expandX().widget(); + yesButton.action = () -> { + if (screen.dontShowAgainCheckbox != null && screen.dontShowAgainCheckbox.checked) Config.get().dontShowAgainPrompts.add(id); + onYes.run(); + screen.close(); + }; + + WButton noButton = screen.list.add(theme.button("No")).expandX().widget(); + noButton.action = () -> { + if (screen.dontShowAgainCheckbox != null && screen.dontShowAgainCheckbox.checked) Config.get().dontShowAgainPrompts.add(id); + onNo.run(); + screen.close(); + }; } }