From 606ebaf9145b32f63cdeb330f16496df6a68ec2f Mon Sep 17 00:00:00 2001 From: shedaniel Date: Tue, 3 Aug 2021 18:29:21 +0800 Subject: Introduce CategoryVisibilityPredicate, update JEI api --- .../registry/category/CategoryRegistryImpl.java | 31 ++++++++++++++++++++++ .../registry/display/DisplayRegistryImpl.java | 4 ++- .../shedaniel/rei/impl/client/view/ViewsImpl.java | 9 ++++--- 3 files changed, 40 insertions(+), 4 deletions(-) (limited to 'runtime/src/main/java/me/shedaniel') diff --git a/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/category/CategoryRegistryImpl.java b/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/category/CategoryRegistryImpl.java index c9fd3b925..1e03b2ce7 100644 --- a/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/category/CategoryRegistryImpl.java +++ b/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/category/CategoryRegistryImpl.java @@ -23,9 +23,12 @@ package me.shedaniel.rei.impl.client.registry.category; +import dev.architectury.event.EventResult; +import me.shedaniel.rei.RoughlyEnoughItemsCore; import me.shedaniel.rei.api.client.plugins.REIClientPlugin; import me.shedaniel.rei.api.client.registry.category.ButtonArea; import me.shedaniel.rei.api.client.registry.category.CategoryRegistry; +import me.shedaniel.rei.api.client.registry.category.visibility.CategoryVisibilityPredicate; import me.shedaniel.rei.api.client.registry.display.DisplayCategory; import me.shedaniel.rei.api.common.category.CategoryIdentifier; import me.shedaniel.rei.api.common.display.Display; @@ -39,6 +42,7 @@ import java.util.function.Consumer; public class CategoryRegistryImpl implements CategoryRegistry { private final Map, Configuration> categories = new LinkedHashMap<>(); private final Map, List>>> listeners = new HashMap<>(); + private final List visibilityPredicates = new ArrayList<>(); @Override public void acceptPlugin(REIClientPlugin plugin) { @@ -90,6 +94,33 @@ public class CategoryRegistryImpl implements CategoryRegistry { return categories.size(); } + @Override + public void registerVisibilityPredicate(CategoryVisibilityPredicate predicate) { + visibilityPredicates.add(predicate); + visibilityPredicates.sort(Comparator.reverseOrder()); + } + + @Override + public boolean isCategoryVisible(DisplayCategory category) { + for (CategoryVisibilityPredicate predicate : visibilityPredicates) { + try { + EventResult result = predicate.handleCategory(category); + if (result.interruptsFurtherEvaluation()) { + return result.isEmpty() || result.isTrue(); + } + } catch (Throwable throwable) { + RoughlyEnoughItemsCore.LOGGER.error("Failed to check if the category is visible!", throwable); + } + } + + return true; + } + + @Override + public List getVisibilityPredicates() { + return Collections.unmodifiableList(visibilityPredicates); + } + private static class Configuration implements CategoryConfiguration { private final DisplayCategory category; private final List workstations = Collections.synchronizedList(new ArrayList<>()); diff --git a/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/display/DisplayRegistryImpl.java b/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/display/DisplayRegistryImpl.java index 5d5c70789..4d57df4e6 100644 --- a/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/display/DisplayRegistryImpl.java +++ b/runtime/src/main/java/me/shedaniel/rei/impl/client/registry/display/DisplayRegistryImpl.java @@ -23,6 +23,7 @@ package me.shedaniel.rei.impl.client.registry.display; +import com.google.common.base.Preconditions; import dev.architectury.event.EventResult; import me.shedaniel.rei.RoughlyEnoughItemsCore; import me.shedaniel.rei.api.client.plugins.REIClientPlugin; @@ -119,6 +120,7 @@ public class DisplayRegistryImpl extends RecipeManagerContextImpl category = (DisplayCategory) CategoryRegistry.getInstance().get(display.getCategoryIdentifier()).getCategory(); + Preconditions.checkNotNull(category, "Failed to resolve category: " + display.getCategoryIdentifier()); for (DisplayVisibilityPredicate predicate : visibilityPredicates) { try { EventResult result = predicate.handleDisplay(category, display); @@ -126,7 +128,7 @@ public class DisplayRegistryImpl extends RecipeManagerContextImpl, List> result = Maps.newLinkedHashMap(); for (CategoryRegistry.CategoryConfiguration categoryConfiguration : CategoryRegistry.getInstance()) { DisplayCategory category = categoryConfiguration.getCategory(); + if (CategoryRegistry.getInstance().isCategoryInvisible(category)) continue; CategoryIdentifier categoryId = categoryConfiguration.getCategoryIdentifier(); List allRecipesFromCategory = displayRegistry.get((CategoryIdentifier) categoryId); @@ -126,15 +127,17 @@ public class ViewsImpl implements Views { for (Map.Entry, List>> entry : displayRegistry.getCategoryDisplayGenerators().entrySet()) { CategoryIdentifier categoryId = entry.getKey(); + DisplayCategory category = CategoryRegistry.getInstance().get(categoryId).getCategory(); + if (CategoryRegistry.getInstance().isCategoryInvisible(category)) continue; Set set = new LinkedHashSet<>(); generatorsCount += entry.getValue().size(); - + for (DynamicDisplayGenerator generator : (List>) (List>) entry.getValue()) { generateLiveDisplays(displayRegistry, generator, builder, set::add); } - + if (!set.isEmpty()) { - CollectionUtils.getOrPutEmptyList(result, CategoryRegistry.getInstance().get(categoryId).getCategory()).addAll(set); + CollectionUtils.getOrPutEmptyList(result, category).addAll(set); } } -- cgit