diff options
Diffstat (limited to 'src/main/java/me/shedaniel/rei/plugin/blasting/DefaultBlastingDisplay.java')
| -rw-r--r-- | src/main/java/me/shedaniel/rei/plugin/blasting/DefaultBlastingDisplay.java | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/src/main/java/me/shedaniel/rei/plugin/blasting/DefaultBlastingDisplay.java b/src/main/java/me/shedaniel/rei/plugin/blasting/DefaultBlastingDisplay.java new file mode 100644 index 000000000..d64e1315d --- /dev/null +++ b/src/main/java/me/shedaniel/rei/plugin/blasting/DefaultBlastingDisplay.java @@ -0,0 +1,65 @@ +/* + * Roughly Enough Items by Danielshe. + * Licensed under the MIT License. + */ + +package me.shedaniel.rei.plugin.blasting; + +import me.shedaniel.rei.api.RecipeDisplay; +import me.shedaniel.rei.plugin.DefaultPlugin; +import net.minecraft.block.entity.FurnaceBlockEntity; +import net.minecraft.item.Item; +import net.minecraft.item.ItemStack; +import net.minecraft.recipe.AbstractCookingRecipe; +import net.minecraft.recipe.BlastingRecipe; +import net.minecraft.util.Identifier; + +import java.util.Arrays; +import java.util.Collections; +import java.util.List; +import java.util.Optional; +import java.util.stream.Collectors; + +public class DefaultBlastingDisplay implements RecipeDisplay<BlastingRecipe> { + + private BlastingRecipe display; + private List<List<ItemStack>> input; + private List<ItemStack> output; + + public DefaultBlastingDisplay(BlastingRecipe recipe) { + this.display = recipe; + this.input = recipe.getPreviewInputs().stream().map(i -> Arrays.asList(i.getStackArray())).collect(Collectors.toList()); + this.input.add(FurnaceBlockEntity.createFuelTimeMap().keySet().stream().map(Item::getDefaultStack).collect(Collectors.toList())); + this.output = Collections.singletonList(recipe.getOutput()); + } + + @Override + public Optional<Identifier> getRecipeLocation() { + return Optional.ofNullable(display).map(AbstractCookingRecipe::getId); + } + + @Override + public List<List<ItemStack>> getInput() { + return input; + } + + public List<ItemStack> getFuel() { + return input.get(1); + } + + @Override + public List<ItemStack> getOutput() { + return output; + } + + @Override + public Identifier getRecipeCategory() { + return DefaultPlugin.BLASTING; + } + + @Override + public List<List<ItemStack>> getRequiredItems() { + return input; + } + +} |
