aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/io/polyfrost/oneconfig/gui/pages
diff options
context:
space:
mode:
authornextdaydelivery <79922345+nxtdaydelivery@users.noreply.github.com>2022-05-01 12:36:56 +0100
committernextdaydelivery <79922345+nxtdaydelivery@users.noreply.github.com>2022-05-01 12:36:56 +0100
commit9694fd2bf0aa538652b9c65472c5f2017efce195 (patch)
treea8c9dba6e4dd5359dd01942cba47fd54c84d452b /src/main/java/io/polyfrost/oneconfig/gui/pages
parent60f1c29872465a25be4f2c4ca8c5eb1abf69f988 (diff)
parentfb9d2f2633c185faba162d85e4ae71c2a347fbb5 (diff)
downloadOneConfig-9694fd2bf0aa538652b9c65472c5f2017efce195.tar.gz
OneConfig-9694fd2bf0aa538652b9c65472c5f2017efce195.tar.bz2
OneConfig-9694fd2bf0aa538652b9c65472c5f2017efce195.zip
Merge remote-tracking branch 'origin/master'
Diffstat (limited to 'src/main/java/io/polyfrost/oneconfig/gui/pages')
-rw-r--r--src/main/java/io/polyfrost/oneconfig/gui/pages/ModConfigPage.java128
1 files changed, 83 insertions, 45 deletions
diff --git a/src/main/java/io/polyfrost/oneconfig/gui/pages/ModConfigPage.java b/src/main/java/io/polyfrost/oneconfig/gui/pages/ModConfigPage.java
index f3224b5..4839c61 100644
--- a/src/main/java/io/polyfrost/oneconfig/gui/pages/ModConfigPage.java
+++ b/src/main/java/io/polyfrost/oneconfig/gui/pages/ModConfigPage.java
@@ -3,25 +3,49 @@ package io.polyfrost.oneconfig.gui.pages;
import io.polyfrost.oneconfig.config.OneConfigConfig;
import io.polyfrost.oneconfig.config.data.OptionPage;
import io.polyfrost.oneconfig.config.interfaces.BasicOption;
+import io.polyfrost.oneconfig.gui.elements.BasicButton;
import io.polyfrost.oneconfig.gui.elements.config.ConfigPageButton;
import io.polyfrost.oneconfig.lwjgl.RenderManager;
import io.polyfrost.oneconfig.lwjgl.font.Fonts;
+import java.util.ArrayList;
+
public class ModConfigPage extends Page {
private final OptionPage page;
+ private final ArrayList<BasicButton> categories = new ArrayList<>();
+ private String selectedCategory;
public ModConfigPage(OptionPage page) {
super("Mod: " + page.mod.name);
this.page = page;
+ if (page.categories.size() == 0) return;
+ for (String category : page.categories.keySet()) {
+ selectedCategory = category;
+ break;
+ }
+ if (page.categories.size() < 2) return;
+ for (String category : page.categories.keySet()) {
+ BasicButton button = new BasicButton(0, 32, category, null, null, 0, BasicButton.ALIGNMENT_CENTER, true, () -> switchCategory(category));
+ if (category.equals(selectedCategory)) button.setToggled(true);
+ categories.add(button);
+ }
}
@Override
public void draw(long vg, int x, int y) {
if (page.categories.size() == 0) return;
- String selectedCategory = page.categories.keySet().stream().findFirst().get();
int optionX = x + 30;
int optionY = y + (page.categories.size() == 1 ? 16 : 64);
+ // Category buttons
+ int buttonX = x + 16;
+ for (BasicButton button : categories) {
+ if (button.getWidth() == 0)
+ button.setWidth((int) (Math.ceil(RenderManager.getTextWidth(vg, button.getText(), 14f, Fonts.INTER_MEDIUM) / 8f) * 8 + 16));
+ button.draw(vg, buttonX, y + 16);
+ buttonX += button.getWidth() + 16;
+ }
+
// Top page buttons
for (ConfigPageButton page : page.categories.get(selectedCategory).topPages) {
page.draw(vg, optionX, optionY);
@@ -29,46 +53,50 @@ public class ModConfigPage extends Page {
}
// Background
- int backgroundSize = 48;
- for (String subCategory : page.categories.get(selectedCategory).subcategories.keySet()) {
- backgroundSize += 32;
- for (int i = 0; i < page.categories.get(selectedCategory).subcategories.get(subCategory).size(); i++) {
- BasicOption option = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i);
- if (i + 1 < page.categories.get(selectedCategory).subcategories.get(subCategory).size()) {
- BasicOption nextOption = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i + 1);
- if (option.size == 1 && option.hasHalfSize() && nextOption.size == 1 && nextOption.hasHalfSize()) {
- backgroundSize += Math.max(option.getHeight(), nextOption.getHeight()) + 16;
- i++;
- continue;
+ if (page.categories.get(selectedCategory).subcategories.keySet().size() > 0) {
+ int backgroundSize = 16;
+ for (String subCategory : page.categories.get(selectedCategory).subcategories.keySet()) {
+ backgroundSize += 48;
+ for (int i = 0; i < page.categories.get(selectedCategory).subcategories.get(subCategory).size(); i++) {
+ BasicOption option = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i);
+ if (i + 1 < page.categories.get(selectedCategory).subcategories.get(subCategory).size()) {
+ BasicOption nextOption = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i + 1);
+ if (option.size == 1 && option.hasHalfSize() && nextOption.size == 1 && nextOption.hasHalfSize()) {
+ backgroundSize += Math.max(option.getHeight(), nextOption.getHeight()) + 16;
+ i++;
+ continue;
+ }
}
+ backgroundSize += option.getHeight() + 16;
}
- backgroundSize += option.getHeight() + 16;
}
+ RenderManager.drawRoundedRect(vg, x + 14, optionY, 1024, backgroundSize, OneConfigConfig.GRAY_900, 20);
}
- RenderManager.drawRoundedRect(vg, x + 14, optionY, 1024, backgroundSize, OneConfigConfig.GRAY_900, 20);
// draw options
- optionY += 16;
- int optionLastY = optionX;
- for (String subCategory : page.categories.get(selectedCategory).subcategories.keySet()) {
- RenderManager.drawString(vg, subCategory, optionX, optionY + 16, OneConfigConfig.WHITE_90, 24f, Fonts.INTER_MEDIUM);
- optionY += 48;
- for (int i = 0; i < page.categories.get(selectedCategory).subcategories.get(subCategory).size(); i++) {
- BasicOption option = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i);
- option.draw(vg, optionX, optionY);
- if (i + 1 < page.categories.get(selectedCategory).subcategories.get(subCategory).size()) {
- BasicOption nextOption = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i + 1);
- if (option.size == 1 && option.hasHalfSize() && nextOption.size == 1 && nextOption.hasHalfSize()) {
- nextOption.draw(vg, optionX + 512, optionY);
- optionY += Math.max(option.getHeight(), nextOption.getHeight()) + 16;
- i++;
- continue;
+ int optionLastY = optionY + 16;
+ if (page.categories.get(selectedCategory).subcategories.keySet().size() > 0) {
+ optionY += 16;
+ for (String subCategory : page.categories.get(selectedCategory).subcategories.keySet()) {
+ RenderManager.drawString(vg, subCategory, optionX, optionY + 16, OneConfigConfig.WHITE_90, 24f, Fonts.INTER_MEDIUM);
+ optionY += 48;
+ for (int i = 0; i < page.categories.get(selectedCategory).subcategories.get(subCategory).size(); i++) {
+ BasicOption option = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i);
+ option.draw(vg, optionX, optionY);
+ if (i + 1 < page.categories.get(selectedCategory).subcategories.get(subCategory).size()) {
+ BasicOption nextOption = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i + 1);
+ if (option.size == 1 && option.hasHalfSize() && nextOption.size == 1 && nextOption.hasHalfSize()) {
+ nextOption.draw(vg, optionX + 512, optionY);
+ optionY += Math.max(option.getHeight(), nextOption.getHeight()) + 16;
+ i++;
+ continue;
+ }
}
+ optionY += option.getHeight() + 16;
}
- optionY += option.getHeight() + 16;
}
+ optionY += 16;
}
- optionY += 16;
// Bottom page buttons
for (ConfigPageButton page : page.categories.get(selectedCategory).bottomPages) {
@@ -77,21 +105,23 @@ public class ModConfigPage extends Page {
}
// Draw last options
- for (String subCategory : page.categories.get(selectedCategory).subcategories.keySet()) {
- optionLastY += 48;
- for (int i = 0; i < page.categories.get(selectedCategory).subcategories.get(subCategory).size(); i++) {
- BasicOption option = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i);
- option.drawLast(vg, optionX, optionLastY);
- if (i + 1 < page.categories.get(selectedCategory).subcategories.get(subCategory).size()) {
- BasicOption nextOption = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i + 1);
- if (option.size == 1 && option.hasHalfSize() && nextOption.size == 1 && nextOption.hasHalfSize()) {
- nextOption.drawLast(vg, optionX + 512, optionLastY);
- optionLastY += Math.max(option.getHeight(), nextOption.getHeight()) + 16;
- i++;
- continue;
+ if (page.categories.get(selectedCategory).subcategories.keySet().size() > 0) {
+ for (String subCategory : page.categories.get(selectedCategory).subcategories.keySet()) {
+ optionLastY += 48;
+ for (int i = 0; i < page.categories.get(selectedCategory).subcategories.get(subCategory).size(); i++) {
+ BasicOption option = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i);
+ option.drawLast(vg, optionX, optionLastY);
+ if (i + 1 < page.categories.get(selectedCategory).subcategories.get(subCategory).size()) {
+ BasicOption nextOption = page.categories.get(selectedCategory).subcategories.get(subCategory).get(i + 1);
+ if (option.size == 1 && option.hasHalfSize() && nextOption.size == 1 && nextOption.hasHalfSize()) {
+ nextOption.drawLast(vg, optionX + 512, optionLastY);
+ optionLastY += Math.max(option.getHeight(), nextOption.getHeight()) + 16;
+ i++;
+ continue;
+ }
}
+ optionLastY += option.getHeight() + 16;
}
- optionLastY += option.getHeight() + 16;
}
}
}
@@ -104,11 +134,19 @@ public class ModConfigPage extends Page {
@Override
public void keyTyped(char key, int keyCode) {
if (page.categories.size() == 0) return;
- String selectedCategory = page.categories.keySet().stream().findFirst().get();
for (String subCategory : page.categories.get(selectedCategory).subcategories.keySet()) {
for (int i = 0; i < page.categories.get(selectedCategory).subcategories.get(subCategory).size(); i++) {
page.categories.get(selectedCategory).subcategories.get(subCategory).get(i).keyTyped(key, keyCode);
}
}
}
+
+ public void switchCategory(String newCategory) {
+ if (!page.categories.containsKey(newCategory)) return;
+ selectedCategory = newCategory;
+ for (BasicButton button : categories) {
+ if (button.getText().equals(newCategory)) continue;
+ button.setToggled(false);
+ }
+ }
}