From def24dd1d0ebd6e12a3a459ece05c0fc94aae4de Mon Sep 17 00:00:00 2001 From: Unknown Date: Fri, 11 Jan 2019 12:09:50 +0800 Subject: Tabs & Item Usages --- .../java/me/shedaniel/rei/client/RecipeHelper.java | 27 ++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'src/main/java/me/shedaniel/rei/client/RecipeHelper.java') diff --git a/src/main/java/me/shedaniel/rei/client/RecipeHelper.java b/src/main/java/me/shedaniel/rei/client/RecipeHelper.java index 74780846c..ead30fdfa 100644 --- a/src/main/java/me/shedaniel/rei/client/RecipeHelper.java +++ b/src/main/java/me/shedaniel/rei/client/RecipeHelper.java @@ -86,6 +86,33 @@ public class RecipeHelper implements RecipeSync { return recipeManager; } + public static Map> getUsagesFor(ItemStack stack) { + Map> categoriesMap = new HashMap<>(); + categories.forEach(f -> categoriesMap.put(f.getIdentifier(), new LinkedList<>())); + for(List value : recipeCategoryListMap.values()) + for(IRecipeDisplay recipeDisplay : value) { + boolean found = false; + for(List input : (List>) recipeDisplay.getInput()) { + for(ItemStack itemStack : input) { + if (ItemStack.areEqualIgnoreTags(itemStack, stack)) { + categoriesMap.get(recipeDisplay.getRecipeCategory()).add(recipeDisplay); + if (found) + break; + } + } + if (found) + break; + } + } + categoriesMap.keySet().removeIf(f -> categoriesMap.get(f).isEmpty()); + Map> recipeCategoryListMap = Maps.newHashMap(); + categories.forEach(category -> { + if (categoriesMap.containsKey(category.getIdentifier())) + recipeCategoryListMap.put(category, categoriesMap.get(category.getIdentifier())); + }); + return recipeCategoryListMap; + } + @Override public void recipesLoaded(RecipeManager recipeManager) { this.recipeManager = recipeManager; -- cgit