From 9f5a9eae9a7863412cc5eb433bf15e5ee71da616 Mon Sep 17 00:00:00 2001 From: Danielshe Date: Sun, 3 Nov 2019 14:44:52 +0800 Subject: 3.2.1 --- .../rei/plugin/cooking/DefaultCookingDisplay.java | 84 ++++++++++++++++++++++ 1 file changed, 84 insertions(+) create mode 100644 src/main/java/me/shedaniel/rei/plugin/cooking/DefaultCookingDisplay.java (limited to 'src/main/java/me/shedaniel/rei/plugin/cooking/DefaultCookingDisplay.java') 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> input; + private List output; + + public DefaultCookingDisplay(AbstractCookingRecipe recipe) { + this.recipe = recipe; + this.input = recipe.getPreviewInputs().stream().map(i -> { + List 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 getRecipeLocation() { + return Optional.ofNullable(recipe).map(AbstractCookingRecipe::getId); + } + + @Override + public List> getInputEntries() { + return input; + } + + @Override + public List getOutputEntries() { + return output; + } + + public List getFuel() { + return input.get(1); + } + + @Override + public List> getRequiredEntries() { + return input; + } + + @Deprecated + public Optional getOptionalRecipe() { + return Optional.ofNullable(recipe); + } + + @Override + public int getWidth() { + return 1; + } + + @Override + public int getHeight() { + return 1; + } + + @Override + public List> getOrganisedInput(ContainerInfo containerInfo, Container container) { + return recipe.getPreviewInputs().stream().map(i -> Arrays.asList(i.getStackArray())).collect(Collectors.toList()); + } +} -- cgit