aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me/shedaniel/rei/plugin/cooking/DefaultCookingDisplay.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/me/shedaniel/rei/plugin/cooking/DefaultCookingDisplay.java')
-rw-r--r--src/main/java/me/shedaniel/rei/plugin/cooking/DefaultCookingDisplay.java84
1 files changed, 84 insertions, 0 deletions
diff --git a/src/main/java/me/shedaniel/rei/plugin/cooking/DefaultCookingDisplay.java b/src/main/java/me/shedaniel/rei/plugin/cooking/DefaultCookingDisplay.java
new file mode 100644
index 000000000..6de7700a1
--- /dev/null
+++ b/src/main/java/me/shedaniel/rei/plugin/cooking/DefaultCookingDisplay.java
@@ -0,0 +1,84 @@
+/*
+ * Roughly Enough Items by Danielshe.
+ * Licensed under the MIT License.
+ */
+
+package me.shedaniel.rei.plugin.cooking;
+
+import me.shedaniel.rei.api.EntryStack;
+import me.shedaniel.rei.api.TransferRecipeDisplay;
+import me.shedaniel.rei.server.ContainerInfo;
+import net.minecraft.block.entity.FurnaceBlockEntity;
+import net.minecraft.client.resource.language.I18n;
+import net.minecraft.container.Container;
+import net.minecraft.item.Item;
+import net.minecraft.item.ItemStack;
+import net.minecraft.recipe.AbstractCookingRecipe;
+import net.minecraft.util.Formatting;
+import net.minecraft.util.Identifier;
+
+import java.util.*;
+import java.util.stream.Collectors;
+
+public abstract class DefaultCookingDisplay implements TransferRecipeDisplay {
+ private AbstractCookingRecipe recipe;
+ private List<List<EntryStack>> input;
+ private List<EntryStack> output;
+
+ public DefaultCookingDisplay(AbstractCookingRecipe recipe) {
+ this.recipe = recipe;
+ this.input = recipe.getPreviewInputs().stream().map(i -> {
+ List<EntryStack> entries = new ArrayList<>();
+ for (ItemStack stack : i.getStackArray()) {
+ entries.add(EntryStack.create(stack));
+ }
+ return entries;
+ }).collect(Collectors.toList());
+ this.input.add(FurnaceBlockEntity.createFuelTimeMap().keySet().stream().map(Item::getStackForRender).map(EntryStack::create).map(e -> e.setting(EntryStack.Settings.TOOLTIP_APPEND_EXTRA, stack -> Collections.singletonList(Formatting.YELLOW.toString() + I18n.translate("category.rei.smelting.fuel")))).collect(Collectors.toList()));
+ this.output = Collections.singletonList(EntryStack.create(recipe.getOutput()));
+ }
+
+ @Override
+ public Optional<Identifier> getRecipeLocation() {
+ return Optional.ofNullable(recipe).map(AbstractCookingRecipe::getId);
+ }
+
+ @Override
+ public List<List<EntryStack>> getInputEntries() {
+ return input;
+ }
+
+ @Override
+ public List<EntryStack> getOutputEntries() {
+ return output;
+ }
+
+ public List<EntryStack> getFuel() {
+ return input.get(1);
+ }
+
+ @Override
+ public List<List<EntryStack>> getRequiredEntries() {
+ return input;
+ }
+
+ @Deprecated
+ public Optional<AbstractCookingRecipe> getOptionalRecipe() {
+ return Optional.ofNullable(recipe);
+ }
+
+ @Override
+ public int getWidth() {
+ return 1;
+ }
+
+ @Override
+ public int getHeight() {
+ return 1;
+ }
+
+ @Override
+ public List<List<ItemStack>> getOrganisedInput(ContainerInfo<Container> containerInfo, Container container) {
+ return recipe.getPreviewInputs().stream().map(i -> Arrays.asList(i.getStackArray())).collect(Collectors.toList());
+ }
+}