aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me/shedaniel/rei/plugin/autocrafting/AutoSmokerBookHandler.java
diff options
context:
space:
mode:
authorUnknown <shekwancheung0528@gmail.com>2019-08-06 22:35:12 +0800
committerUnknown <shekwancheung0528@gmail.com>2019-08-06 22:35:12 +0800
commit70417f41613ae30582cd48708fe43ce9a3e6ae86 (patch)
tree7a0b8286005568237e894662a9c40bfdb42550d7 /src/main/java/me/shedaniel/rei/plugin/autocrafting/AutoSmokerBookHandler.java
parentcbf03f9c2625b0f336ae86a916fe77db2ee4a420 (diff)
downloadRoughlyEnoughItems-70417f41613ae30582cd48708fe43ce9a3e6ae86.tar.gz
RoughlyEnoughItems-70417f41613ae30582cd48708fe43ce9a3e6ae86.tar.bz2
RoughlyEnoughItems-70417f41613ae30582cd48708fe43ce9a3e6ae86.zip
These days are great days to completely scrap an api
Diffstat (limited to 'src/main/java/me/shedaniel/rei/plugin/autocrafting/AutoSmokerBookHandler.java')
-rw-r--r--src/main/java/me/shedaniel/rei/plugin/autocrafting/AutoSmokerBookHandler.java34
1 files changed, 15 insertions, 19 deletions
diff --git a/src/main/java/me/shedaniel/rei/plugin/autocrafting/AutoSmokerBookHandler.java b/src/main/java/me/shedaniel/rei/plugin/autocrafting/AutoSmokerBookHandler.java
index 2c768ab3a..6a1ff6b23 100644
--- a/src/main/java/me/shedaniel/rei/plugin/autocrafting/AutoSmokerBookHandler.java
+++ b/src/main/java/me/shedaniel/rei/plugin/autocrafting/AutoSmokerBookHandler.java
@@ -5,35 +5,31 @@
package me.shedaniel.rei.plugin.autocrafting;
-import me.shedaniel.rei.api.AutoCraftingHandler;
-import me.shedaniel.rei.api.RecipeDisplay;
+import me.shedaniel.rei.api.AutoTransferHandler;
import me.shedaniel.rei.client.ScreenHelper;
-import me.shedaniel.rei.gui.ContainerScreenOverlay;
import me.shedaniel.rei.listeners.RecipeBookGuiHooks;
import me.shedaniel.rei.plugin.smoking.DefaultSmokingDisplay;
-import net.minecraft.client.MinecraftClient;
import net.minecraft.client.gui.screen.Screen;
-import net.minecraft.client.gui.screen.ingame.AbstractContainerScreen;
import net.minecraft.client.gui.screen.ingame.SmokerScreen;
import net.minecraft.container.SmokerContainer;
-import java.util.function.Supplier;
-
-public class AutoSmokerBookHandler implements AutoCraftingHandler {
+public class AutoSmokerBookHandler implements AutoTransferHandler {
@Override
- public boolean handle(Supplier<RecipeDisplay> displaySupplier, MinecraftClient minecraft, Screen recipeViewingScreen, AbstractContainerScreen<?> parentScreen, ContainerScreenOverlay overlay) {
- DefaultSmokingDisplay display = (DefaultSmokingDisplay) displaySupplier.get();
- SmokerScreen smokerScreen = (SmokerScreen) parentScreen;
- minecraft.openScreen(smokerScreen);
+ public Result handle(Context context) {
+ if (!(context.getContainerScreen() instanceof SmokerScreen) || !(context.getRecipe() instanceof DefaultSmokingDisplay))
+ return Result.createNotApplicable();
+ if (!((DefaultSmokingDisplay) context.getRecipe()).getOptionalRecipe().isPresent() || !context.getMinecraft().player.getRecipeBook().contains(((DefaultSmokingDisplay) context.getRecipe()).getOptionalRecipe().get()))
+ return Result.createNotApplicable();
+ if (!context.isActuallyCrafting())
+ return Result.createSuccessful();
+
+ DefaultSmokingDisplay display = (DefaultSmokingDisplay) context.getRecipe();
+ SmokerScreen smokerScreen = (SmokerScreen) context.getContainerScreen();
+ context.getMinecraft().openScreen(smokerScreen);
((RecipeBookGuiHooks) smokerScreen.getRecipeBookGui()).rei_getGhostSlots().reset();
SmokerContainer container = smokerScreen.getContainer();
- minecraft.interactionManager.clickRecipe(container.syncId, display.getOptionalRecipe().get(), Screen.hasShiftDown());
+ context.getMinecraft().interactionManager.clickRecipe(container.syncId, display.getOptionalRecipe().get(), Screen.hasShiftDown());
ScreenHelper.getLastOverlay().init();
- return true;
- }
-
- @Override
- public boolean canHandle(Supplier<RecipeDisplay> displaySupplier, MinecraftClient minecraft, Screen recipeViewingScreen, AbstractContainerScreen<?> parentScreen, ContainerScreenOverlay overlay) {
- return parentScreen instanceof SmokerScreen && displaySupplier.get() instanceof DefaultSmokingDisplay && ((DefaultSmokingDisplay) displaySupplier.get()).getOptionalRecipe().isPresent() && minecraft.player.getRecipeBook().contains(((DefaultSmokingDisplay) displaySupplier.get()).getOptionalRecipe().get());
+ return Result.createSuccessful();
}
}