Reorganized Imports/Packages
This commit is contained in:
parent
a8beba9196
commit
770a5b4046
854 changed files with 42775 additions and 41811 deletions
|
@ -0,0 +1,53 @@
|
|||
package org.betterx.betterend.recipe;
|
||||
|
||||
import net.minecraft.world.item.Items;
|
||||
import net.minecraft.world.level.block.Blocks;
|
||||
|
||||
import org.betterx.betterend.recipe.builders.AlloyingRecipe;
|
||||
import org.betterx.betterend.registry.EndBlocks;
|
||||
import org.betterx.betterend.registry.EndItems;
|
||||
import org.betterx.betterend.registry.EndTags;
|
||||
|
||||
public class AlloyingRecipes {
|
||||
public static void register() {
|
||||
AlloyingRecipe.Builder.create("additional_iron")
|
||||
.setInput(EndTags.ALLOYING_IRON, EndTags.ALLOYING_IRON)
|
||||
.setOutput(Items.IRON_INGOT, 3)
|
||||
.setExpiriense(2.1F)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("additional_gold")
|
||||
.setInput(EndTags.ALLOYING_GOLD, EndTags.ALLOYING_GOLD)
|
||||
.setOutput(Items.GOLD_INGOT, 3)
|
||||
.setExpiriense(3F)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("additional_copper")
|
||||
.setInput(EndTags.ALLOYING_COPPER, EndTags.ALLOYING_COPPER)
|
||||
.setOutput(Items.COPPER_INGOT, 3)
|
||||
.setExpiriense(3F)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("additional_netherite")
|
||||
.setInput(Blocks.ANCIENT_DEBRIS, Blocks.ANCIENT_DEBRIS)
|
||||
.setOutput(Items.NETHERITE_SCRAP, 3)
|
||||
.setExpiriense(6F)
|
||||
.setSmeltTime(1000)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("terminite_ingot")
|
||||
.setInput(Items.IRON_INGOT, EndItems.ENDER_DUST)
|
||||
.setOutput(EndBlocks.TERMINITE.ingot, 1)
|
||||
.setExpiriense(2.5F)
|
||||
.setSmeltTime(450)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("aeternium_ingot")
|
||||
.setInput(EndBlocks.TERMINITE.ingot, Items.NETHERITE_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_INGOT, 1)
|
||||
.setExpiriense(4.5F)
|
||||
.setSmeltTime(850)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("terminite_ingot_thallasium")
|
||||
.setInput(EndBlocks.THALLASIUM.ingot, EndItems.ENDER_DUST)
|
||||
.setOutput(EndBlocks.TERMINITE.ingot, 1)
|
||||
.setExpiriense(2.5F)
|
||||
.setSmeltTime(450)
|
||||
.build();
|
||||
}
|
||||
}
|
85
src/main/java/org/betterx/betterend/recipe/AnvilRecipes.java
Normal file
85
src/main/java/org/betterx/betterend/recipe/AnvilRecipes.java
Normal file
|
@ -0,0 +1,85 @@
|
|||
package org.betterx.betterend.recipe;
|
||||
|
||||
import net.minecraft.world.item.Items;
|
||||
|
||||
import org.betterx.bclib.recipes.AnvilRecipe;
|
||||
import org.betterx.betterend.config.Configs;
|
||||
import org.betterx.betterend.item.material.EndToolMaterial;
|
||||
import org.betterx.betterend.registry.EndItems;
|
||||
|
||||
public class AnvilRecipes {
|
||||
public static void register() {
|
||||
AnvilRecipe.create("ender_pearl_to_dust")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setInput(Items.ENDER_PEARL)
|
||||
.setOutput(EndItems.ENDER_DUST)
|
||||
.setToolLevel(4)
|
||||
.setDamage(5)
|
||||
.build();
|
||||
AnvilRecipe.create("ender_shard_to_dust")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setInput(EndItems.ENDER_SHARD)
|
||||
.setOutput(EndItems.ENDER_DUST)
|
||||
.setToolLevel(0)
|
||||
.setDamage(3)
|
||||
.build();
|
||||
|
||||
int anvilLevel = EndToolMaterial.AETERNIUM.getLevel();
|
||||
AnvilRecipe.create("aeternium_axe_head")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_AXE_HEAD)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(anvilLevel)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.create("aeternium_pickaxe_head")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_PICKAXE_HEAD)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(anvilLevel)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.create("aeternium_shovel_head")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_SHOVEL_HEAD)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(anvilLevel)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.create("aeternium_hoe_head")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_HOE_HEAD)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(anvilLevel)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.create("aeternium_hammer_head")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_HAMMER_HEAD)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(EndToolMaterial.THALLASIUM.getLevel())
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.create("aeternium_sword_blade")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_SWORD_BLADE)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(anvilLevel)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.create("aeternium_forged_plate")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_FORGED_PLATE)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(anvilLevel)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
}
|
||||
}
|
484
src/main/java/org/betterx/betterend/recipe/CraftingRecipes.java
Normal file
484
src/main/java/org/betterx/betterend/recipe/CraftingRecipes.java
Normal file
|
@ -0,0 +1,484 @@
|
|||
package org.betterx.betterend.recipe;
|
||||
|
||||
import net.minecraft.world.item.Item;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.Items;
|
||||
import net.minecraft.world.item.alchemy.PotionUtils;
|
||||
import net.minecraft.world.item.alchemy.Potions;
|
||||
import net.minecraft.world.level.block.Block;
|
||||
import net.minecraft.world.level.block.Blocks;
|
||||
|
||||
import org.betterx.bclib.api.tag.CommonItemTags;
|
||||
import org.betterx.bclib.recipes.GridRecipe;
|
||||
import org.betterx.betterend.BetterEnd;
|
||||
import org.betterx.betterend.config.Configs;
|
||||
import org.betterx.betterend.registry.EndBlocks;
|
||||
import org.betterx.betterend.registry.EndItems;
|
||||
|
||||
public class CraftingRecipes {
|
||||
|
||||
public static void register() {
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "ender_perl_to_block", EndBlocks.ENDER_BLOCK)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("OO", "OO")
|
||||
.addMaterial('O', Items.ENDER_PEARL)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "ender_block_to_perl", Items.ENDER_PEARL)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.addMaterial('#', EndBlocks.ENDER_BLOCK)
|
||||
.setOutputCount(4)
|
||||
.setList("#")
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "end_stone_smelter", EndBlocks.END_STONE_SMELTER)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("T#T", "V V", "T#T")
|
||||
.addMaterial('#', Blocks.END_STONE_BRICKS)
|
||||
.addMaterial('T', EndBlocks.THALLASIUM.ingot)
|
||||
.addMaterial('V', CommonItemTags.FURNACES)
|
||||
.build();
|
||||
|
||||
registerPedestal(
|
||||
"andesite_pedestal",
|
||||
EndBlocks.ANDESITE_PEDESTAL,
|
||||
Blocks.POLISHED_ANDESITE_SLAB,
|
||||
Blocks.POLISHED_ANDESITE
|
||||
);
|
||||
registerPedestal(
|
||||
"diorite_pedestal",
|
||||
EndBlocks.DIORITE_PEDESTAL,
|
||||
Blocks.POLISHED_DIORITE_SLAB,
|
||||
Blocks.POLISHED_DIORITE
|
||||
);
|
||||
registerPedestal(
|
||||
"granite_pedestal",
|
||||
EndBlocks.GRANITE_PEDESTAL,
|
||||
Blocks.POLISHED_GRANITE_SLAB,
|
||||
Blocks.POLISHED_GRANITE
|
||||
);
|
||||
registerPedestal("quartz_pedestal", EndBlocks.QUARTZ_PEDESTAL, Blocks.QUARTZ_SLAB, Blocks.QUARTZ_PILLAR);
|
||||
registerPedestal("purpur_pedestal", EndBlocks.PURPUR_PEDESTAL, Blocks.PURPUR_SLAB, Blocks.PURPUR_PILLAR);
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "infusion_pedestal", EndBlocks.INFUSION_PEDESTAL)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape(" Y ", "O#O", " # ")
|
||||
.addMaterial('O', Items.ENDER_PEARL)
|
||||
.addMaterial('Y', Items.ENDER_EYE)
|
||||
.addMaterial('#', Blocks.OBSIDIAN)
|
||||
.build();
|
||||
|
||||
String material = "aeternium";
|
||||
GridRecipe.make(BetterEnd.MOD_ID, material + "_block", EndBlocks.AETERNIUM_BLOCK)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("III", "III", "III")
|
||||
.addMaterial('I', EndItems.AETERNIUM_INGOT)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, material + "_block_to_ingot", EndItems.AETERNIUM_INGOT)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.addMaterial('#', EndBlocks.AETERNIUM_BLOCK)
|
||||
.setOutputCount(9)
|
||||
.setList("#")
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "blue_vine_seed_dye", Items.BLUE_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.BLUE_VINE_SEED)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "creeping_moss_dye", Items.CYAN_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.CREEPING_MOSS)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "umbrella_moss_dye", Items.YELLOW_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.UMBRELLA_MOSS)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "umbrella_moss_tall_dye", Items.YELLOW_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setOutputCount(2)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.UMBRELLA_MOSS_TALL)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "shadow_plant_dye", Items.BLACK_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.SHADOW_PLANT)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "paper", Items.PAPER)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("###")
|
||||
.addMaterial('#', EndItems.END_LILY_LEAF_DRIED)
|
||||
.setOutputCount(3)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "aurora_block", EndBlocks.AURORA_CRYSTAL)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("##", "##")
|
||||
.addMaterial('#', EndItems.CRYSTAL_SHARDS)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "lotus_block", EndBlocks.END_LOTUS.getLog())
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("##", "##")
|
||||
.addMaterial('#', EndBlocks.END_LOTUS_STEM)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "needlegrass_stick", Items.STICK)
|
||||
.setList("#")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setOutputCount(2)
|
||||
.addMaterial('#', EndBlocks.NEEDLEGRASS)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "shadow_berry_seeds", EndBlocks.SHADOW_BERRY)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.setOutputCount(4)
|
||||
.addMaterial('#', EndItems.SHADOW_BERRY_RAW)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "purple_polypore_dye", Items.PURPLE_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.PURPLE_POLYPORE)
|
||||
.build();
|
||||
|
||||
registerLantern("end_stone_lantern", EndBlocks.END_STONE_LANTERN, Blocks.END_STONE_BRICK_SLAB);
|
||||
registerLantern("andesite_lantern", EndBlocks.ANDESITE_LANTERN, Blocks.ANDESITE_SLAB);
|
||||
registerLantern("diorite_lantern", EndBlocks.DIORITE_LANTERN, Blocks.DIORITE_SLAB);
|
||||
registerLantern("granite_lantern", EndBlocks.GRANITE_LANTERN, Blocks.GRANITE_SLAB);
|
||||
registerLantern("quartz_lantern", EndBlocks.QUARTZ_LANTERN, Blocks.QUARTZ_SLAB);
|
||||
registerLantern("purpur_lantern", EndBlocks.PURPUR_LANTERN, Blocks.PURPUR_SLAB);
|
||||
registerLantern("blackstone_lantern", EndBlocks.BLACKSTONE_LANTERN, Blocks.BLACKSTONE_SLAB);
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "amber_gem", EndItems.AMBER_GEM)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("##", "##")
|
||||
.addMaterial('#', EndItems.RAW_AMBER)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "amber_block", EndBlocks.AMBER_BLOCK)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("##", "##")
|
||||
.addMaterial('#', EndItems.AMBER_GEM)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "amber_gem_block", EndItems.AMBER_GEM)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setOutputCount(4)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.AMBER_BLOCK)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "iron_bulb_lantern", EndBlocks.IRON_BULB_LANTERN)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("C", "I", "#")
|
||||
.addMaterial('C', Items.CHAIN)
|
||||
.addMaterial('I', Items.IRON_INGOT)
|
||||
.addMaterial('#', EndItems.GLOWING_BULB)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "twisted_moss_dye", Items.PINK_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.TWISTED_MOSS)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "byshy_grass_dye", Items.MAGENTA_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.BUSHY_GRASS)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "tail_moss_dye", Items.GRAY_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.TAIL_MOSS)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "petal_block", EndBlocks.HYDRALUX_PETAL_BLOCK)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("##", "##")
|
||||
.addMaterial('#', EndItems.HYDRALUX_PETAL)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "petal_white_dye", Items.WHITE_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndItems.HYDRALUX_PETAL)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "sweet_berry_jelly", EndItems.SWEET_BERRY_JELLY)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("JWSB")
|
||||
.addMaterial('J', EndItems.GELATINE)
|
||||
.addMaterial('W', PotionUtils.setPotion(new ItemStack(Items.POTION), Potions.WATER))
|
||||
.addMaterial('S', Items.SUGAR)
|
||||
.addMaterial('B', Items.SWEET_BERRIES)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "shadow_berry_jelly", EndItems.SHADOW_BERRY_JELLY)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("JWSB")
|
||||
.addMaterial('J', EndItems.GELATINE)
|
||||
.addMaterial('W', PotionUtils.setPotion(new ItemStack(Items.POTION), Potions.WATER))
|
||||
.addMaterial('S', Items.SUGAR)
|
||||
.addMaterial('B', EndItems.SHADOW_BERRY_COOKED)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "shadow_berry_jelly", EndItems.BLOSSOM_BERRY_JELLY)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("JWSB")
|
||||
.addMaterial('J', EndItems.GELATINE)
|
||||
.addMaterial('W', PotionUtils.setPotion(new ItemStack(Items.POTION), Potions.WATER))
|
||||
.addMaterial('S', Items.SUGAR)
|
||||
.addMaterial('B', EndItems.BLOSSOM_BERRY)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "sulphur_gunpowder", Items.GUNPOWDER)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("SCB")
|
||||
.addMaterial('S', EndItems.CRYSTALLINE_SULPHUR)
|
||||
.addMaterial('C', Items.COAL, Items.CHARCOAL)
|
||||
.addMaterial('B', Items.BONE_MEAL)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "dense_emerald_ice", EndBlocks.DENSE_EMERALD_ICE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("##", "##")
|
||||
.addMaterial('#', EndBlocks.EMERALD_ICE)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "ancient_emerald_ice", EndBlocks.ANCIENT_EMERALD_ICE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("###", "###", "###")
|
||||
.addMaterial('#', EndBlocks.DENSE_EMERALD_ICE)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "charnia_cyan_dye", Items.CYAN_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.CHARNIA_CYAN)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "charnia_green_dye", Items.GREEN_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.CHARNIA_GREEN)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "charnia_light_blue_dye", Items.LIGHT_BLUE_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.CHARNIA_LIGHT_BLUE)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "charnia_orange_dye", Items.ORANGE_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.CHARNIA_ORANGE)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "charnia_purple_dye", Items.PURPLE_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.CHARNIA_PURPLE)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "charnia_red_dye", Items.RED_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.CHARNIA_RED)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "respawn_obelisk", EndBlocks.RESPAWN_OBELISK)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("CSC", "CSC", "AAA")
|
||||
.addMaterial('C', EndBlocks.AURORA_CRYSTAL)
|
||||
.addMaterial('S', EndItems.ETERNAL_CRYSTAL)
|
||||
.addMaterial('A', EndBlocks.AMBER_BLOCK)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "twisted_umbrella_moss_dye", Items.PURPLE_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.TWISTED_UMBRELLA_MOSS)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "twisted_umbrella_moss_dye_tall", Items.PURPLE_DYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setOutputCount(2)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.TWISTED_UMBRELLA_MOSS_TALL)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "leather_to_stripes", EndItems.LEATHER_STRIPE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("L")
|
||||
.addMaterial('L', Items.LEATHER)
|
||||
.setOutputCount(3)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "stripes_to_leather", Items.LEATHER)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("SSS")
|
||||
.addMaterial('S', EndItems.LEATHER_STRIPE)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "leather_wrapped_stick", EndItems.LEATHER_WRAPPED_STICK)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("SL")
|
||||
.addMaterial('S', Items.STICK)
|
||||
.addMaterial('L', EndItems.LEATHER_STRIPE)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "fiber_string", Items.STRING)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setOutputCount(6)
|
||||
.setShape("#", "#", "#")
|
||||
.addMaterial('#', EndItems.SILK_FIBER)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "ender_eye_amber", Items.ENDER_EYE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("SAS", "APA", "SAS")
|
||||
.addMaterial('S', EndItems.CRYSTAL_SHARDS)
|
||||
.addMaterial('A', EndItems.AMBER_GEM)
|
||||
.addMaterial('P', Items.ENDER_PEARL)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "iron_chandelier", EndBlocks.IRON_CHANDELIER)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("I#I", " # ")
|
||||
.addMaterial('#', Items.IRON_INGOT)
|
||||
.addMaterial('I', EndItems.LUMECORN_ROD)
|
||||
.setGroup("end_metal_chandelier")
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "gold_chandelier", EndBlocks.GOLD_CHANDELIER)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("I#I", " # ")
|
||||
.addMaterial('#', Items.GOLD_INGOT)
|
||||
.addMaterial('I', EndItems.LUMECORN_ROD)
|
||||
.setGroup("end_metal_chandelier")
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "missing_tile", EndBlocks.MISSING_TILE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setOutputCount(4)
|
||||
.setShape("#P", "P#")
|
||||
.addMaterial('#', EndBlocks.VIOLECITE.stone, EndBlocks.VIOLECITE.bricks, EndBlocks.VIOLECITE.tiles)
|
||||
.addMaterial('P', Blocks.PURPUR_BLOCK)
|
||||
.build();
|
||||
|
||||
registerHammer("iron", Items.IRON_INGOT, EndItems.IRON_HAMMER);
|
||||
registerHammer("golden", Items.GOLD_INGOT, EndItems.GOLDEN_HAMMER);
|
||||
registerHammer("diamond", Items.DIAMOND, EndItems.DIAMOND_HAMMER);
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "charcoal_block", EndBlocks.CHARCOAL_BLOCK)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("###", "###", "###")
|
||||
.addMaterial('#', Items.CHARCOAL)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "charcoal_from_block", Items.CHARCOAL)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setOutputCount(9)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.CHARCOAL_BLOCK)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "end_stone_furnace", EndBlocks.END_STONE_FURNACE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("###", "# #", "###")
|
||||
.addMaterial('#', Blocks.END_STONE)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "filalux_lantern", EndBlocks.FILALUX_LANTERN)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("###", "###", "###")
|
||||
.addMaterial('#', EndBlocks.FILALUX)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "silk_moth_hive", EndBlocks.SILK_MOTH_HIVE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("#L#", "LML", "#L#")
|
||||
.addMaterial('#', EndBlocks.TENANEA.getBlock("planks"))
|
||||
.addMaterial('L', EndBlocks.TENANEA_LEAVES)
|
||||
.addMaterial('M', EndItems.SILK_MOTH_MATRIX)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "cave_pumpkin_pie", EndItems.CAVE_PUMPKIN_PIE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("SBS", "BPB", "SBS")
|
||||
.addMaterial('P', EndBlocks.CAVE_PUMPKIN)
|
||||
.addMaterial('B', EndItems.BLOSSOM_BERRY, EndItems.SHADOW_BERRY_RAW)
|
||||
.addMaterial('S', Items.SUGAR)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "cave_pumpkin_seeds", EndBlocks.CAVE_PUMPKIN_SEED)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setOutputCount(4)
|
||||
.setList("#")
|
||||
.addMaterial('#', EndBlocks.CAVE_PUMPKIN)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "neon_cactus_block", EndBlocks.NEON_CACTUS_BLOCK)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("##", "##")
|
||||
.addMaterial('#', EndBlocks.NEON_CACTUS)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "neon_cactus_block_slab", EndBlocks.NEON_CACTUS_BLOCK_SLAB)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("###")
|
||||
.setOutputCount(6)
|
||||
.addMaterial('#', EndBlocks.NEON_CACTUS_BLOCK)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "neon_cactus_block_stairs", EndBlocks.NEON_CACTUS_BLOCK_STAIRS)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("# ", "## ", "###")
|
||||
.setOutputCount(4)
|
||||
.addMaterial('#', EndBlocks.NEON_CACTUS_BLOCK)
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "sugar_from_root", Items.SUGAR)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setList("###")
|
||||
.addMaterial('#', EndItems.AMBER_ROOT_RAW)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "endstone_flower_pot", EndBlocks.ENDSTONE_FLOWER_POT)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setOutputCount(3)
|
||||
.setShape("# #", " # ")
|
||||
.addMaterial('#', Blocks.END_STONE_BRICKS)
|
||||
.setGroup("end_pots")
|
||||
.build();
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "dragon_bone_block", EndBlocks.DRAGON_BONE_BLOCK)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setOutputCount(8)
|
||||
.setShape("###", "#D#", "###")
|
||||
.addMaterial('#', Blocks.BONE_BLOCK)
|
||||
.addMaterial('D', Items.DRAGON_BREATH)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "dragon_bone_slab", EndBlocks.DRAGON_BONE_SLAB)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("###")
|
||||
.setOutputCount(6)
|
||||
.addMaterial('#', EndBlocks.DRAGON_BONE_BLOCK)
|
||||
.build();
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "dragon_bone_stairs", EndBlocks.DRAGON_BONE_STAIRS)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("# ", "## ", "###")
|
||||
.setOutputCount(4)
|
||||
.addMaterial('#', EndBlocks.DRAGON_BONE_BLOCK)
|
||||
.build();
|
||||
}
|
||||
|
||||
private static void registerLantern(String name, Block lantern, Block slab) {
|
||||
GridRecipe.make(BetterEnd.MOD_ID, name, lantern)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("S", "#", "S")
|
||||
.addMaterial('#', EndItems.CRYSTAL_SHARDS)
|
||||
.addMaterial('S', slab)
|
||||
.setGroup("end_stone_lanterns")
|
||||
.build();
|
||||
}
|
||||
|
||||
public static void registerPedestal(String name, Block pedestal, Block slab, Block pillar) {
|
||||
GridRecipe.make(BetterEnd.MOD_ID, name, pedestal)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("S", "#", "S")
|
||||
.addMaterial('S', slab)
|
||||
.addMaterial('#', pillar)
|
||||
.setOutputCount(2)
|
||||
.build();
|
||||
}
|
||||
|
||||
private static void registerHammer(String name, Item material, Item result) {
|
||||
GridRecipe.make(BetterEnd.MOD_ID, name + "_hammer", result)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("I I", "I#I", " # ")
|
||||
.addMaterial('I', material)
|
||||
.addMaterial('#', Items.STICK)
|
||||
.build();
|
||||
}
|
||||
}
|
|
@ -0,0 +1,45 @@
|
|||
package org.betterx.betterend.recipe;
|
||||
|
||||
import net.minecraft.world.item.Items;
|
||||
import net.minecraft.world.level.block.Blocks;
|
||||
|
||||
import org.betterx.bclib.recipes.FurnaceRecipe;
|
||||
import org.betterx.betterend.BetterEnd;
|
||||
import org.betterx.betterend.config.Configs;
|
||||
import org.betterx.betterend.registry.EndBlocks;
|
||||
import org.betterx.betterend.registry.EndItems;
|
||||
|
||||
public class FurnaceRecipes {
|
||||
public static void register() {
|
||||
FurnaceRecipe.make(
|
||||
BetterEnd.MOD_ID,
|
||||
"end_lily_leaf_dried",
|
||||
EndItems.END_LILY_LEAF,
|
||||
EndItems.END_LILY_LEAF_DRIED
|
||||
).checkConfig(Configs.RECIPE_CONFIG).build();
|
||||
FurnaceRecipe.make(BetterEnd.MOD_ID, "end_glass", EndBlocks.ENDSTONE_DUST, Blocks.GLASS)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.build();
|
||||
FurnaceRecipe.make(BetterEnd.MOD_ID, "end_berry", EndItems.SHADOW_BERRY_RAW, EndItems.SHADOW_BERRY_COOKED)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.buildFoodlike();
|
||||
FurnaceRecipe.make(BetterEnd.MOD_ID, "end_fish", EndItems.END_FISH_RAW, EndItems.END_FISH_COOKED)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.buildFoodlike();
|
||||
FurnaceRecipe.make(BetterEnd.MOD_ID, "slime_ball", EndBlocks.JELLYSHROOM_CAP_PURPLE, Items.SLIME_BALL)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.build();
|
||||
FurnaceRecipe.make(BetterEnd.MOD_ID, "menger_sponge", EndBlocks.MENGER_SPONGE_WET, EndBlocks.MENGER_SPONGE)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.build();
|
||||
FurnaceRecipe.make(
|
||||
BetterEnd.MOD_ID,
|
||||
"chorus_mushroom",
|
||||
EndItems.CHORUS_MUSHROOM_RAW,
|
||||
EndItems.CHORUS_MUSHROOM_COOKED
|
||||
).checkConfig(Configs.RECIPE_CONFIG).buildFoodlike();
|
||||
FurnaceRecipe.make(BetterEnd.MOD_ID, "bolux_mushroom", EndBlocks.BOLUX_MUSHROOM, EndItems.BOLUX_MUSHROOM_COOKED)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.buildFoodlike();
|
||||
}
|
||||
}
|
615
src/main/java/org/betterx/betterend/recipe/InfusionRecipes.java
Normal file
615
src/main/java/org/betterx/betterend/recipe/InfusionRecipes.java
Normal file
|
@ -0,0 +1,615 @@
|
|||
package org.betterx.betterend.recipe;
|
||||
|
||||
import net.minecraft.world.item.EnchantedBookItem;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.Items;
|
||||
import net.minecraft.world.item.enchantment.Enchantment;
|
||||
import net.minecraft.world.item.enchantment.EnchantmentInstance;
|
||||
import net.minecraft.world.item.enchantment.Enchantments;
|
||||
import net.minecraft.world.level.block.Blocks;
|
||||
|
||||
import org.betterx.betterend.recipe.builders.InfusionRecipe;
|
||||
import org.betterx.betterend.registry.EndBlocks;
|
||||
import org.betterx.betterend.registry.EndItems;
|
||||
|
||||
public class InfusionRecipes {
|
||||
public static void register() {
|
||||
InfusionRecipe.Builder.create("runed_flavolite")
|
||||
.setInput(EndBlocks.FLAVOLITE.polished)
|
||||
.setOutput(EndBlocks.FLAVOLITE_RUNED)
|
||||
.addCatalyst(0, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(100)
|
||||
.build();
|
||||
|
||||
InfusionRecipe.Builder.create("eternal_crystal")
|
||||
.setInput(Items.END_CRYSTAL)
|
||||
.setOutput(EndItems.ETERNAL_CRYSTAL)
|
||||
.addCatalyst(0, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(1, EndItems.ENDER_SHARD)
|
||||
.addCatalyst(3, EndItems.ENDER_SHARD)
|
||||
.addCatalyst(5, EndItems.ENDER_SHARD)
|
||||
.addCatalyst(7, EndItems.ENDER_SHARD)
|
||||
.setTime(250)
|
||||
.build();
|
||||
|
||||
InfusionRecipe.Builder.create("crystalite_helmet")
|
||||
.setInput(EndBlocks.TERMINITE.helmet)
|
||||
.setOutput(EndItems.CRYSTALITE_HELMET)
|
||||
.addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(150)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("crystalite_chestplate")
|
||||
.setInput(EndBlocks.TERMINITE.chestplate)
|
||||
.setOutput(EndItems.CRYSTALITE_CHESTPLATE)
|
||||
.addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(1, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(3, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(5, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(7, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("crystalite_leggings")
|
||||
.setInput(EndBlocks.TERMINITE.leggings)
|
||||
.setOutput(EndItems.CRYSTALITE_LEGGINGS)
|
||||
.addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(225)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("crystalite_boots")
|
||||
.setInput(EndBlocks.TERMINITE.boots)
|
||||
.setOutput(EndItems.CRYSTALITE_BOOTS)
|
||||
.addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(150)
|
||||
.build();
|
||||
|
||||
InfusionRecipe.Builder.create("crystalite_elytra")
|
||||
.setInput(Items.ELYTRA)
|
||||
.setOutput(EndItems.CRYSTALITE_ELYTRA)
|
||||
.addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(1, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(2, EndItems.ENCHANTED_MEMBRANE)
|
||||
.addCatalyst(3, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.ENCHANTED_MEMBRANE)
|
||||
.addCatalyst(5, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.ENCHANTED_MEMBRANE)
|
||||
.addCatalyst(7, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(500)
|
||||
.build();
|
||||
|
||||
InfusionRecipe.Builder.create("enchanted_petal")
|
||||
.setInput(EndItems.HYDRALUX_PETAL)
|
||||
.setOutput(EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(0, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(75)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("enchanted_membrane")
|
||||
.setInput(Items.PHANTOM_MEMBRANE)
|
||||
.setOutput(EndItems.ENCHANTED_MEMBRANE)
|
||||
.addCatalyst(0, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(75)
|
||||
.build();
|
||||
|
||||
InfusionRecipe.Builder.create("protection_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.ALL_DAMAGE_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(4, Items.TURTLE_HELMET)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("fire_protection_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FIRE_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.BLAZE_ROD)
|
||||
.addCatalyst(4, Items.BLAZE_ROD)
|
||||
.addCatalyst(6, Items.BLAZE_ROD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("feather_falling_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FALL_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.FEATHER)
|
||||
.addCatalyst(4, Items.FEATHER)
|
||||
.addCatalyst(6, Items.FEATHER)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("blast_protection_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.BLAST_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.OBSIDIAN)
|
||||
.addCatalyst(4, Blocks.OBSIDIAN)
|
||||
.addCatalyst(6, Blocks.OBSIDIAN)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("projectile_protection_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PROJECTILE_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.SCUTE)
|
||||
.addCatalyst(4, Items.SHIELD)
|
||||
.addCatalyst(6, Items.SCUTE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("respiration_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.RESPIRATION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.NAUTILUS_SHELL)
|
||||
.addCatalyst(4, Items.NAUTILUS_SHELL)
|
||||
.addCatalyst(6, Items.NAUTILUS_SHELL)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("aqua_affinity_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.AQUA_AFFINITY, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.PRISMARINE_CRYSTALS)
|
||||
.addCatalyst(4, Items.PRISMARINE_CRYSTALS)
|
||||
.addCatalyst(6, Items.PRISMARINE_CRYSTALS)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("thorns_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.THORNS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.CACTUS)
|
||||
.addCatalyst(4, Blocks.CACTUS)
|
||||
.addCatalyst(6, Blocks.CACTUS)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("depth_strider_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.DEPTH_STRIDER, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.LILY_PAD)
|
||||
.addCatalyst(4, EndBlocks.END_LILY_SEED)
|
||||
.addCatalyst(6, Blocks.LILY_PAD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("frost_walker_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FROST_WALKER, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(4, EndBlocks.ANCIENT_EMERALD_ICE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("soul_speed_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SOUL_SPEED, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.SOUL_SAND, Blocks.SOUL_SOIL)
|
||||
.addCatalyst(4, Blocks.SOUL_SAND, Blocks.SOUL_SOIL)
|
||||
.addCatalyst(6, Blocks.SOUL_SAND, Blocks.SOUL_SOIL)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("sharpness_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SHARPNESS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(4, Items.NETHERITE_SCRAP)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("smite_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SMITE, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.SUNFLOWER)
|
||||
.addCatalyst(4, Items.GOLD_INGOT)
|
||||
.addCatalyst(6, Blocks.SUNFLOWER)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("bane_of_arthropods_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.BANE_OF_ARTHROPODS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.FERMENTED_SPIDER_EYE)
|
||||
.addCatalyst(4, Items.IRON_INGOT)
|
||||
.addCatalyst(6, Items.FERMENTED_SPIDER_EYE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("knockback_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.KNOCKBACK, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.REDSTONE)
|
||||
.addCatalyst(4, Blocks.PISTON)
|
||||
.addCatalyst(6, Items.REDSTONE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("fire_aspect_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FIRE_ASPECT, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.BLAZE_POWDER)
|
||||
.addCatalyst(4, Items.MAGMA_CREAM)
|
||||
.addCatalyst(6, Items.BLAZE_POWDER)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("looting_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.MOB_LOOTING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EMERALD)
|
||||
.addCatalyst(4, Items.GOLD_INGOT)
|
||||
.addCatalyst(6, Items.EMERALD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("sweeping_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SWEEPING_EDGE, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.GOLDEN_SWORD)
|
||||
.addCatalyst(4, Items.IRON_SWORD)
|
||||
.addCatalyst(6, Items.GOLDEN_SWORD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("efficiency_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.BLOCK_EFFICIENCY, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, EndItems.AMBER_GEM)
|
||||
.addCatalyst(4, EndItems.AMBER_GEM)
|
||||
.addCatalyst(6, EndItems.AMBER_GEM)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("silk_touch_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SILK_TOUCH, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.COBWEB)
|
||||
.addCatalyst(4, EndItems.ETERNAL_CRYSTAL)
|
||||
.addCatalyst(6, Blocks.COBWEB)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("unbreaking_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.UNBREAKING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.DIAMOND)
|
||||
.addCatalyst(4, Items.DIAMOND)
|
||||
.addCatalyst(6, Items.DIAMOND)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("fortune_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.BLOCK_FORTUNE, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EMERALD)
|
||||
.addCatalyst(4, Items.RABBIT_FOOT)
|
||||
.addCatalyst(6, Items.EMERALD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("power_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.POWER_ARROWS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, EndItems.AMBER_GEM)
|
||||
.addCatalyst(4, Items.DIAMOND_SWORD)
|
||||
.addCatalyst(6, EndItems.AMBER_GEM)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("punch_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PUNCH_ARROWS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.POPPED_CHORUS_FRUIT)
|
||||
.addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.POPPED_CHORUS_FRUIT)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("flame_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FLAMING_ARROWS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.BLAZE_POWDER)
|
||||
.addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.BLAZE_POWDER)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("infinity_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.INFINITY_ARROWS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(4, EndItems.ETERNAL_CRYSTAL)
|
||||
.addCatalyst(6, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("luck_of_sea_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FISHING_LUCK, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EMERALD)
|
||||
.addCatalyst(4, Items.FISHING_ROD)
|
||||
.addCatalyst(6, Items.EMERALD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("lure_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FISHING_SPEED, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.GOLD_NUGGET)
|
||||
.addCatalyst(4, Items.FISHING_ROD)
|
||||
.addCatalyst(6, Items.GOLD_NUGGET)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("loyalty_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.LOYALTY, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.ENDER_EYE)
|
||||
.addCatalyst(4, Items.HEART_OF_THE_SEA)
|
||||
.addCatalyst(6, Items.ENDER_EYE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("impaling_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.IMPALING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.PRISMARINE_SHARD)
|
||||
.addCatalyst(4, Items.IRON_SWORD)
|
||||
.addCatalyst(6, Items.PRISMARINE_SHARD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("riptide_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.RIPTIDE, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.LEAD)
|
||||
.addCatalyst(4, Items.HEART_OF_THE_SEA)
|
||||
.addCatalyst(6, Items.LEAD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("channeling_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.CHANNELING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.CHAIN)
|
||||
.addCatalyst(4, Items.HEART_OF_THE_SEA)
|
||||
.addCatalyst(6, Items.CHAIN)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("multishot_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.MULTISHOT, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.ARROW)
|
||||
.addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.ARROW)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("quick_charge_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.QUICK_CHARGE, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.QUARTZ)
|
||||
.addCatalyst(4, Items.GLOWSTONE_DUST)
|
||||
.addCatalyst(6, Items.QUARTZ)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("piercing_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PIERCING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.GLOWSTONE_DUST)
|
||||
.addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.GLOWSTONE_DUST)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("mending_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.MENDING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EXPERIENCE_BOTTLE)
|
||||
.addCatalyst(4, Blocks.ANVIL)
|
||||
.addCatalyst(6, Items.EXPERIENCE_BOTTLE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
}
|
||||
|
||||
private static ItemStack createEnchantedBook(Enchantment enchantment, int level) {
|
||||
ItemStack book = new ItemStack(Items.ENCHANTED_BOOK);
|
||||
EnchantedBookItem.addEnchantment(book, new EnchantmentInstance(enchantment, level));
|
||||
return book;
|
||||
}
|
||||
}
|
110
src/main/java/org/betterx/betterend/recipe/SmithingRecipes.java
Normal file
110
src/main/java/org/betterx/betterend/recipe/SmithingRecipes.java
Normal file
|
@ -0,0 +1,110 @@
|
|||
package org.betterx.betterend.recipe;
|
||||
|
||||
import net.minecraft.world.item.Items;
|
||||
|
||||
import org.betterx.bclib.recipes.SmithingTableRecipe;
|
||||
import org.betterx.betterend.BetterEnd;
|
||||
import org.betterx.betterend.config.Configs;
|
||||
import org.betterx.betterend.registry.EndBlocks;
|
||||
import org.betterx.betterend.registry.EndItems;
|
||||
|
||||
public class SmithingRecipes {
|
||||
|
||||
public static void register() {
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_sword_handle")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_SWORD_HANDLE)
|
||||
.setBase(EndBlocks.TERMINITE.ingot)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_sword")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_SWORD)
|
||||
.setBase(EndItems.AETERNIUM_SWORD_BLADE)
|
||||
.setAddition(EndItems.AETERNIUM_SWORD_HANDLE)
|
||||
.build();
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_pickaxe")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_PICKAXE)
|
||||
.setBase(EndItems.AETERNIUM_PICKAXE_HEAD)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_axe")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_AXE)
|
||||
.setBase(EndItems.AETERNIUM_AXE_HEAD)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_shovel")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_SHOVEL)
|
||||
.setBase(EndItems.AETERNIUM_SHOVEL_HEAD)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_hoe")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_HOE)
|
||||
.setBase(EndItems.AETERNIUM_HOE_HEAD)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_hammer")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_HAMMER)
|
||||
.setBase(EndItems.AETERNIUM_HAMMER_HEAD)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "netherite_hammer")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.NETHERITE_HAMMER)
|
||||
.setBase(EndItems.DIAMOND_HAMMER)
|
||||
.setAddition(Items.NETHERITE_INGOT)
|
||||
.build();
|
||||
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_helmet")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_HELMET)
|
||||
.setBase(EndBlocks.TERMINITE.helmet)
|
||||
.setAddition(EndItems.AETERNIUM_FORGED_PLATE)
|
||||
.build();
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_chestplate")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_CHESTPLATE)
|
||||
.setBase(EndBlocks.TERMINITE.chestplate)
|
||||
.setAddition(EndItems.AETERNIUM_FORGED_PLATE)
|
||||
.build();
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_leggings")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_LEGGINGS)
|
||||
.setBase(EndBlocks.TERMINITE.leggings)
|
||||
.setAddition(EndItems.AETERNIUM_FORGED_PLATE)
|
||||
.build();
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "aeternium_boots")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.AETERNIUM_BOOTS)
|
||||
.setBase(EndBlocks.TERMINITE.boots)
|
||||
.setAddition(EndItems.AETERNIUM_FORGED_PLATE)
|
||||
.build();
|
||||
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "thallasium_anvil_updrade")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndBlocks.TERMINITE.anvilBlock.asItem())
|
||||
.setBase(EndBlocks.THALLASIUM.anvilBlock.asItem())
|
||||
.setAddition(EndBlocks.TERMINITE.block)
|
||||
.build();
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "terminite_anvil_updrade")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndBlocks.AETERNIUM_ANVIL.asItem())
|
||||
.setBase(EndBlocks.TERMINITE.anvilBlock.asItem())
|
||||
.setAddition(EndItems.AETERNIUM_INGOT)
|
||||
.build();
|
||||
|
||||
SmithingTableRecipe.create(BetterEnd.MOD_ID, "armored_elytra")
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setResult(EndItems.ARMORED_ELYTRA)
|
||||
.setBase(Items.ELYTRA)
|
||||
.setAddition(EndItems.AETERNIUM_INGOT)
|
||||
.build();
|
||||
}
|
||||
}
|
|
@ -0,0 +1,298 @@
|
|||
package org.betterx.betterend.recipe.builders;
|
||||
|
||||
import net.minecraft.core.NonNullList;
|
||||
import net.minecraft.network.FriendlyByteBuf;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraft.tags.TagKey;
|
||||
import net.minecraft.util.GsonHelper;
|
||||
import net.minecraft.world.Container;
|
||||
import net.minecraft.world.item.Item;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.crafting.Ingredient;
|
||||
import net.minecraft.world.item.crafting.Recipe;
|
||||
import net.minecraft.world.item.crafting.RecipeSerializer;
|
||||
import net.minecraft.world.item.crafting.RecipeType;
|
||||
import net.minecraft.world.level.ItemLike;
|
||||
import net.minecraft.world.level.Level;
|
||||
|
||||
import net.fabricmc.api.EnvType;
|
||||
import net.fabricmc.api.Environment;
|
||||
|
||||
import com.google.gson.JsonArray;
|
||||
import com.google.gson.JsonObject;
|
||||
import org.betterx.bclib.interfaces.UnknownReceipBookCategory;
|
||||
import org.betterx.bclib.recipes.BCLRecipeManager;
|
||||
import org.betterx.bclib.util.ItemUtil;
|
||||
import org.betterx.bclib.util.RecipeHelper;
|
||||
import org.betterx.betterend.BetterEnd;
|
||||
import org.betterx.betterend.config.Configs;
|
||||
import org.betterx.betterend.registry.EndBlocks;
|
||||
|
||||
public class AlloyingRecipe implements Recipe<Container>, UnknownReceipBookCategory {
|
||||
public final static String GROUP = "alloying";
|
||||
public final static RecipeType<AlloyingRecipe> TYPE = BCLRecipeManager.registerType(BetterEnd.MOD_ID, GROUP);
|
||||
public final static Serializer SERIALIZER = BCLRecipeManager.registerSerializer(
|
||||
BetterEnd.MOD_ID,
|
||||
GROUP,
|
||||
new Serializer()
|
||||
);
|
||||
|
||||
protected final RecipeType<?> type;
|
||||
protected final ResourceLocation id;
|
||||
protected final Ingredient primaryInput;
|
||||
protected final Ingredient secondaryInput;
|
||||
protected final ItemStack output;
|
||||
protected final String group;
|
||||
protected final float experience;
|
||||
protected final int smeltTime;
|
||||
|
||||
public AlloyingRecipe(ResourceLocation id,
|
||||
String group,
|
||||
Ingredient primaryInput,
|
||||
Ingredient secondaryInput,
|
||||
ItemStack output,
|
||||
float experience,
|
||||
int smeltTime) {
|
||||
this.group = group;
|
||||
this.id = id;
|
||||
this.primaryInput = primaryInput;
|
||||
this.secondaryInput = secondaryInput;
|
||||
this.output = output;
|
||||
this.experience = experience;
|
||||
this.smeltTime = smeltTime;
|
||||
this.type = TYPE;
|
||||
}
|
||||
|
||||
public float getExperience() {
|
||||
return this.experience;
|
||||
}
|
||||
|
||||
public int getSmeltTime() {
|
||||
return this.smeltTime;
|
||||
}
|
||||
|
||||
@Override
|
||||
public NonNullList<Ingredient> getIngredients() {
|
||||
NonNullList<Ingredient> defaultedList = NonNullList.create();
|
||||
defaultedList.add(primaryInput);
|
||||
defaultedList.add(secondaryInput);
|
||||
|
||||
return defaultedList;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean matches(Container inv, Level world) {
|
||||
return this.primaryInput.test(inv.getItem(0)) && this.secondaryInput.test(inv.getItem(1)) || this.primaryInput.test(
|
||||
inv.getItem(1)) && this.secondaryInput.test(inv.getItem(0));
|
||||
}
|
||||
|
||||
@Override
|
||||
public ItemStack assemble(Container inv) {
|
||||
return this.output.copy();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean canCraftInDimensions(int width, int height) {
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ItemStack getResultItem() {
|
||||
return this.output;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ResourceLocation getId() {
|
||||
return this.id;
|
||||
}
|
||||
|
||||
@Override
|
||||
public RecipeSerializer<?> getSerializer() {
|
||||
return SERIALIZER;
|
||||
}
|
||||
|
||||
@Override
|
||||
public RecipeType<?> getType() {
|
||||
return this.type;
|
||||
}
|
||||
|
||||
@Override
|
||||
@Environment(EnvType.CLIENT)
|
||||
public String getGroup() {
|
||||
return this.group;
|
||||
}
|
||||
|
||||
@Environment(EnvType.CLIENT)
|
||||
public ItemStack getToastSymbol() {
|
||||
return new ItemStack(EndBlocks.END_STONE_SMELTER);
|
||||
}
|
||||
|
||||
public static class Builder {
|
||||
private final static Builder INSTANCE = new Builder();
|
||||
private static boolean exist;
|
||||
|
||||
public static Builder create(ResourceLocation id) {
|
||||
INSTANCE.id = id;
|
||||
INSTANCE.group = String.format("%s_%s", GROUP, id);
|
||||
INSTANCE.primaryInput = null;
|
||||
INSTANCE.secondaryInput = null;
|
||||
INSTANCE.output = null;
|
||||
INSTANCE.experience = 0.0F;
|
||||
INSTANCE.smeltTime = 350;
|
||||
exist = Configs.RECIPE_CONFIG.getBoolean("alloying", id.getPath(), true);
|
||||
|
||||
return INSTANCE;
|
||||
}
|
||||
|
||||
public static Builder create(String id) {
|
||||
return create(BetterEnd.makeID(id));
|
||||
}
|
||||
|
||||
private ResourceLocation id;
|
||||
private Ingredient primaryInput;
|
||||
private Ingredient secondaryInput;
|
||||
private ItemStack output;
|
||||
private String group;
|
||||
private float experience;
|
||||
private int smeltTime;
|
||||
private boolean alright = true;
|
||||
|
||||
private Builder() {
|
||||
}
|
||||
|
||||
public Builder setGroup(String group) {
|
||||
this.group = group;
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setPrimaryInput(ItemLike... inputs) {
|
||||
for (ItemLike item : inputs) {
|
||||
this.alright &= RecipeHelper.exists(item);
|
||||
}
|
||||
this.primaryInput = Ingredient.of(inputs);
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setSecondaryInput(ItemLike... inputs) {
|
||||
for (ItemLike item : inputs) {
|
||||
this.alright &= RecipeHelper.exists(item);
|
||||
}
|
||||
this.secondaryInput = Ingredient.of(inputs);
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setPrimaryInput(TagKey<Item> input) {
|
||||
this.primaryInput = Ingredient.of(input);
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setSecondaryInput(TagKey<Item> input) {
|
||||
this.secondaryInput = Ingredient.of(input);
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setInput(ItemLike primaryInput, ItemLike secondaryInput) {
|
||||
this.setPrimaryInput(primaryInput);
|
||||
this.setSecondaryInput(secondaryInput);
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setInput(TagKey<Item> primaryInput, TagKey<Item> secondaryInput) {
|
||||
this.setPrimaryInput(primaryInput);
|
||||
this.setSecondaryInput(secondaryInput);
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setOutput(ItemLike output, int amount) {
|
||||
this.alright &= RecipeHelper.exists(output);
|
||||
this.output = new ItemStack(output, amount);
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setExpiriense(float amount) {
|
||||
this.experience = amount;
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setSmeltTime(int time) {
|
||||
this.smeltTime = time;
|
||||
return this;
|
||||
}
|
||||
|
||||
public void build() {
|
||||
if (exist) {
|
||||
if (primaryInput == null) {
|
||||
BetterEnd.LOGGER.warning(
|
||||
"Primary input for Alloying recipe can't be 'null', recipe {} will be ignored!",
|
||||
id
|
||||
);
|
||||
return;
|
||||
}
|
||||
if (secondaryInput == null) {
|
||||
BetterEnd.LOGGER.warning(
|
||||
"Secondary input for Alloying can't be 'null', recipe {} will be ignored!",
|
||||
id
|
||||
);
|
||||
return;
|
||||
}
|
||||
if (output == null) {
|
||||
BetterEnd.LOGGER.warning("Output for Alloying can't be 'null', recipe {} will be ignored!", id);
|
||||
return;
|
||||
}
|
||||
if (BCLRecipeManager.getRecipe(TYPE, id) != null) {
|
||||
BetterEnd.LOGGER.warning("Can't add Alloying recipe! Id {} already exists!", id);
|
||||
return;
|
||||
}
|
||||
if (!alright) {
|
||||
BetterEnd.LOGGER.debug("Can't add Alloying recipe {}! Ingeredient or output not exists.", id);
|
||||
return;
|
||||
}
|
||||
BCLRecipeManager.addRecipe(
|
||||
TYPE,
|
||||
new AlloyingRecipe(id, group, primaryInput, secondaryInput, output, experience, smeltTime)
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static class Serializer implements RecipeSerializer<AlloyingRecipe> {
|
||||
@Override
|
||||
public AlloyingRecipe fromJson(ResourceLocation id, JsonObject json) {
|
||||
JsonArray ingredients = GsonHelper.getAsJsonArray(json, "ingredients");
|
||||
Ingredient primaryInput = Ingredient.fromJson(ingredients.get(0));
|
||||
Ingredient secondaryInput = Ingredient.fromJson(ingredients.get(1));
|
||||
String group = GsonHelper.getAsString(json, "group", "");
|
||||
JsonObject result = GsonHelper.getAsJsonObject(json, "result");
|
||||
ItemStack output = ItemUtil.fromJsonRecipe(result);
|
||||
if (output == null) {
|
||||
throw new IllegalStateException("Output item does not exists!");
|
||||
}
|
||||
float experience = GsonHelper.getAsFloat(json, "experience", 0.0F);
|
||||
int smeltTime = GsonHelper.getAsInt(json, "smelttime", 350);
|
||||
|
||||
return new AlloyingRecipe(id, group, primaryInput, secondaryInput, output, experience, smeltTime);
|
||||
}
|
||||
|
||||
@Override
|
||||
public AlloyingRecipe fromNetwork(ResourceLocation id, FriendlyByteBuf packetBuffer) {
|
||||
String group = packetBuffer.readUtf(32767);
|
||||
Ingredient primary = Ingredient.fromNetwork(packetBuffer);
|
||||
Ingredient secondary = Ingredient.fromNetwork(packetBuffer);
|
||||
ItemStack output = packetBuffer.readItem();
|
||||
float experience = packetBuffer.readFloat();
|
||||
int smeltTime = packetBuffer.readVarInt();
|
||||
|
||||
return new AlloyingRecipe(id, group, primary, secondary, output, experience, smeltTime);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void toNetwork(FriendlyByteBuf packetBuffer, AlloyingRecipe recipe) {
|
||||
packetBuffer.writeUtf(recipe.group);
|
||||
recipe.primaryInput.toNetwork(packetBuffer);
|
||||
recipe.secondaryInput.toNetwork(packetBuffer);
|
||||
packetBuffer.writeItem(recipe.output);
|
||||
packetBuffer.writeFloat(recipe.experience);
|
||||
packetBuffer.writeVarInt(recipe.smeltTime);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,297 @@
|
|||
package org.betterx.betterend.recipe.builders;
|
||||
|
||||
import net.minecraft.core.NonNullList;
|
||||
import net.minecraft.nbt.CompoundTag;
|
||||
import net.minecraft.nbt.TagParser;
|
||||
import net.minecraft.network.FriendlyByteBuf;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraft.util.GsonHelper;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.crafting.Ingredient;
|
||||
import net.minecraft.world.item.crafting.Recipe;
|
||||
import net.minecraft.world.item.crafting.RecipeSerializer;
|
||||
import net.minecraft.world.item.crafting.RecipeType;
|
||||
import net.minecraft.world.level.ItemLike;
|
||||
import net.minecraft.world.level.Level;
|
||||
|
||||
import net.fabricmc.api.EnvType;
|
||||
import net.fabricmc.api.Environment;
|
||||
|
||||
import com.google.gson.JsonObject;
|
||||
import com.mojang.brigadier.exceptions.CommandSyntaxException;
|
||||
import org.betterx.bclib.interfaces.UnknownReceipBookCategory;
|
||||
import org.betterx.bclib.recipes.BCLRecipeManager;
|
||||
import org.betterx.bclib.util.ItemUtil;
|
||||
import org.betterx.betterend.BetterEnd;
|
||||
import org.betterx.betterend.config.Configs;
|
||||
import org.betterx.betterend.rituals.InfusionRitual;
|
||||
|
||||
import java.util.Arrays;
|
||||
|
||||
public class InfusionRecipe implements Recipe<InfusionRitual>, UnknownReceipBookCategory {
|
||||
public final static String GROUP = "infusion";
|
||||
public final static RecipeType<InfusionRecipe> TYPE = BCLRecipeManager.registerType(BetterEnd.MOD_ID, GROUP);
|
||||
public final static Serializer SERIALIZER = BCLRecipeManager.registerSerializer(
|
||||
BetterEnd.MOD_ID,
|
||||
GROUP,
|
||||
new Serializer()
|
||||
);
|
||||
|
||||
private final ResourceLocation id;
|
||||
private final Ingredient[] catalysts;
|
||||
private Ingredient input;
|
||||
private ItemStack output;
|
||||
private int time = 1;
|
||||
private String group;
|
||||
|
||||
private InfusionRecipe(ResourceLocation id) {
|
||||
this(id, null, null);
|
||||
}
|
||||
|
||||
private InfusionRecipe(ResourceLocation id, Ingredient input, ItemStack output) {
|
||||
this.id = id;
|
||||
this.input = input;
|
||||
this.output = output;
|
||||
this.catalysts = new Ingredient[8];
|
||||
Arrays.fill(catalysts, Ingredient.EMPTY);
|
||||
}
|
||||
|
||||
public int getInfusionTime() {
|
||||
return this.time;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean matches(InfusionRitual inv, Level world) {
|
||||
boolean valid = this.input.test(inv.getItem(0));
|
||||
if (!valid) return false;
|
||||
for (int i = 0; i < 8; i++) {
|
||||
valid &= this.catalysts[i].test(inv.getItem(i + 1));
|
||||
}
|
||||
return valid;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ItemStack assemble(InfusionRitual ritual) {
|
||||
return output.copy();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean canCraftInDimensions(int width, int height) {
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public NonNullList<Ingredient> getIngredients() {
|
||||
NonNullList<Ingredient> defaultedList = NonNullList.create();
|
||||
defaultedList.add(input);
|
||||
defaultedList.addAll(Arrays.asList(catalysts));
|
||||
return defaultedList;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ItemStack getResultItem() {
|
||||
return this.output;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ResourceLocation getId() {
|
||||
return this.id;
|
||||
}
|
||||
|
||||
@Override
|
||||
@Environment(EnvType.CLIENT)
|
||||
public String getGroup() {
|
||||
return this.group;
|
||||
}
|
||||
|
||||
@Override
|
||||
public RecipeSerializer<?> getSerializer() {
|
||||
return SERIALIZER;
|
||||
}
|
||||
|
||||
@Override
|
||||
public RecipeType<?> getType() {
|
||||
return TYPE;
|
||||
}
|
||||
|
||||
public static class Builder {
|
||||
private final static Builder INSTANCE = new Builder();
|
||||
private static boolean exist;
|
||||
|
||||
public static Builder create(String id) {
|
||||
return create(BetterEnd.makeID(id));
|
||||
}
|
||||
|
||||
public static Builder create(ResourceLocation id) {
|
||||
INSTANCE.id = id;
|
||||
INSTANCE.input = null;
|
||||
INSTANCE.output = null;
|
||||
INSTANCE.time = 1;
|
||||
exist = Configs.RECIPE_CONFIG.getBoolean("infusion", id.getPath(), true);
|
||||
|
||||
Arrays.fill(INSTANCE.catalysts, Ingredient.EMPTY);
|
||||
|
||||
return INSTANCE;
|
||||
}
|
||||
|
||||
private final Ingredient[] catalysts = new Ingredient[8];
|
||||
private ResourceLocation id;
|
||||
private Ingredient input;
|
||||
private ItemStack output;
|
||||
private String group;
|
||||
private int time = 1;
|
||||
|
||||
private Builder() {
|
||||
Arrays.fill(catalysts, Ingredient.EMPTY);
|
||||
}
|
||||
|
||||
public Builder setGroup(String group) {
|
||||
this.group = group;
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setInput(ItemLike input) {
|
||||
this.input = Ingredient.of(input);
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setOutput(ItemLike output) {
|
||||
this.output = new ItemStack(output);
|
||||
this.output.setCount(1);
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setOutput(ItemStack output) {
|
||||
this.output = output;
|
||||
this.output.setCount(1);
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder setTime(int time) {
|
||||
this.time = time;
|
||||
return this;
|
||||
}
|
||||
|
||||
public Builder addCatalyst(int slot, ItemLike... items) {
|
||||
if (slot > 7) return this;
|
||||
this.catalysts[slot] = Ingredient.of(items);
|
||||
return this;
|
||||
}
|
||||
|
||||
public void build() {
|
||||
if (exist) {
|
||||
if (input == null) {
|
||||
BetterEnd.LOGGER.warning(
|
||||
"Input for Infusion recipe can't be 'null', recipe {} will be ignored!",
|
||||
id
|
||||
);
|
||||
return;
|
||||
}
|
||||
if (output == null) {
|
||||
BetterEnd.LOGGER.warning(
|
||||
"Output for Infusion recipe can't be 'null', recipe {} will be ignored!",
|
||||
id
|
||||
);
|
||||
return;
|
||||
}
|
||||
InfusionRecipe recipe = new InfusionRecipe(id, input, output);
|
||||
recipe.group = group != null ? group : GROUP;
|
||||
recipe.time = time;
|
||||
int empty = 0;
|
||||
for (int i = 0; i < catalysts.length; i++) {
|
||||
if (catalysts[i].isEmpty()) empty++;
|
||||
else recipe.catalysts[i] = catalysts[i];
|
||||
}
|
||||
if (empty == catalysts.length) {
|
||||
BetterEnd.LOGGER.warning("At least one catalyst must be non empty, recipe {} will be ignored!", id);
|
||||
return;
|
||||
}
|
||||
BCLRecipeManager.addRecipe(TYPE, recipe);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static class Serializer implements RecipeSerializer<InfusionRecipe> {
|
||||
@Override
|
||||
public InfusionRecipe fromJson(ResourceLocation id, JsonObject json) {
|
||||
InfusionRecipe recipe = new InfusionRecipe(id);
|
||||
recipe.input = Ingredient.fromJson(json.get("input"));
|
||||
JsonObject result = GsonHelper.getAsJsonObject(json, "result");
|
||||
recipe.output = ItemUtil.fromJsonRecipe(result);
|
||||
if (recipe.output == null) {
|
||||
throw new IllegalStateException("Output item does not exists!");
|
||||
}
|
||||
if (result.has("nbt")) {
|
||||
try {
|
||||
String nbtData = GsonHelper.getAsString(result, "nbt");
|
||||
CompoundTag nbt = TagParser.parseTag(nbtData);
|
||||
recipe.output.setTag(nbt);
|
||||
} catch (CommandSyntaxException ex) {
|
||||
BetterEnd.LOGGER.warning("Error parse nbt data for output.", ex);
|
||||
}
|
||||
}
|
||||
recipe.group = GsonHelper.getAsString(json, "group", GROUP);
|
||||
recipe.time = GsonHelper.getAsInt(json, "time", 1);
|
||||
|
||||
JsonObject catalysts = GsonHelper.getAsJsonObject(json, "catalysts");
|
||||
ItemStack catalyst = ItemUtil.fromStackString(GsonHelper.getAsString(catalysts, "north", ""));
|
||||
recipe.catalysts[0] = (catalyst != null && !catalyst.isEmpty())
|
||||
? Ingredient.of(catalyst.getItem())
|
||||
: Ingredient.EMPTY;
|
||||
catalyst = ItemUtil.fromStackString(GsonHelper.getAsString(catalysts, "north_east", ""));
|
||||
recipe.catalysts[1] = (catalyst != null && !catalyst.isEmpty())
|
||||
? Ingredient.of(catalyst.getItem())
|
||||
: Ingredient.EMPTY;
|
||||
catalyst = ItemUtil.fromStackString(GsonHelper.getAsString(catalysts, "east", ""));
|
||||
recipe.catalysts[2] = (catalyst != null && !catalyst.isEmpty())
|
||||
? Ingredient.of(catalyst.getItem())
|
||||
: Ingredient.EMPTY;
|
||||
catalyst = ItemUtil.fromStackString(GsonHelper.getAsString(catalysts, "south_east", ""));
|
||||
recipe.catalysts[3] = (catalyst != null && !catalyst.isEmpty())
|
||||
? Ingredient.of(catalyst.getItem())
|
||||
: Ingredient.EMPTY;
|
||||
catalyst = ItemUtil.fromStackString(GsonHelper.getAsString(catalysts, "south", ""));
|
||||
recipe.catalysts[4] = (catalyst != null && !catalyst.isEmpty())
|
||||
? Ingredient.of(catalyst.getItem())
|
||||
: Ingredient.EMPTY;
|
||||
catalyst = ItemUtil.fromStackString(GsonHelper.getAsString(catalysts, "south_west", ""));
|
||||
recipe.catalysts[5] = (catalyst != null && !catalyst.isEmpty())
|
||||
? Ingredient.of(catalyst.getItem())
|
||||
: Ingredient.EMPTY;
|
||||
catalyst = ItemUtil.fromStackString(GsonHelper.getAsString(catalysts, "west", ""));
|
||||
recipe.catalysts[6] = (catalyst != null && !catalyst.isEmpty())
|
||||
? Ingredient.of(catalyst.getItem())
|
||||
: Ingredient.EMPTY;
|
||||
catalyst = ItemUtil.fromStackString(GsonHelper.getAsString(catalysts, "north_west", ""));
|
||||
recipe.catalysts[7] = (catalyst != null && !catalyst.isEmpty())
|
||||
? Ingredient.of(catalyst.getItem())
|
||||
: Ingredient.EMPTY;
|
||||
|
||||
return recipe;
|
||||
}
|
||||
|
||||
@Override
|
||||
public InfusionRecipe fromNetwork(ResourceLocation id, FriendlyByteBuf buffer) {
|
||||
InfusionRecipe recipe = new InfusionRecipe(id);
|
||||
recipe.input = Ingredient.fromNetwork(buffer);
|
||||
recipe.output = buffer.readItem();
|
||||
recipe.group = buffer.readUtf();
|
||||
recipe.time = buffer.readVarInt();
|
||||
for (int i = 0; i < 8; i++) {
|
||||
recipe.catalysts[i] = Ingredient.fromNetwork(buffer);
|
||||
}
|
||||
return recipe;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void toNetwork(FriendlyByteBuf buffer, InfusionRecipe recipe) {
|
||||
recipe.input.toNetwork(buffer);
|
||||
buffer.writeItem(recipe.output);
|
||||
buffer.writeUtf(recipe.group);
|
||||
buffer.writeVarInt(recipe.time);
|
||||
for (int i = 0; i < 8; i++) {
|
||||
recipe.catalysts[i].toNetwork(buffer);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue