From 2b145f5b9a84d30d85807d693a1062a1d497065b Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 28 Sep 2023 13:21:50 +0100 Subject: [PATCH 01/51] Added Ingot Fusion toll enhancer Added impurim sword and pickaxe --- .gitignore | 1 + .../59eb3dbb5f86130e09b3c62d89b9525ee01cf52d | 3 +- .../9cedfe5b9b9b8fb51ee0cbcde6ee21cf9da7c57c | 4 +- .../9f61bb65fbe4cfb8a15e0d3253c99409d3dd169b | 6 +- .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 7 +- .../b051adeca7b8303d1a7d46afb7c4eaf8cfa3a7f5 | 3 +- .../c622617f6fabf890a00b9275cd5f643584a8a2c8 | 4 +- .../assets/armourandtoolsmod/lang/en_us.json | 7 + .../models/item/imperium.json | 6 + .../models/item/imperium_pickaxe.json | 6 + .../models/item/imperium_sword.json | 6 + .../models/item/magma_strike_pickaxe.json | 6 + .../recipes/tools/imperium_pickaxe.json | 33 +++ .../recipes/tools/imperium_sword.json | 33 +++ .../blocks/ingot_fusion_toll_enhancer.json | 21 ++ .../recipes/imperium_pickaxe.json | 20 ++ .../recipes/imperium_sword.json | 20 ++ .../recipes/magma_strike_pickaxe.json | 13 ++ .../forge/tags/items/ingots/imperium.json | 5 + .../tags/blocks/mineable/pickaxe.json | 1 + .../blocks/IngotFusionTollEnhancer.java | 165 +++++++++++++ .../CustomArmourCraftingTableScreen.java | 5 +- .../fusion/IngotFusionTollEnhancerScreen.java | 63 +++++ .../tool/CustomToolCraftingTableScreen.java | 5 +- .../core/init/BlockEntityTypeInit.java | 20 ++ .../armourandtoolsmod/ArmourAndToolsMod.kt | 2 + .../IngotFusionTollEnhancerBlockEntity.kt | 216 ++++++++++++++++++ .../fusion/IngotFusionTollEnhancerMenu.kt | 130 +++++++++++ .../fusion/OutputSlotItemHandler.kt} | 13 +- .../armourandtoolsmod/client/ClientSetup.kt | 10 +- .../armourandtoolsmod/core/init/BlockInit.kt | 7 +- .../armourandtoolsmod/core/init/ItemInit.kt | 29 +++ .../core/init/JEIRecipeTypes.kt | 7 + .../core/init/MenuTypeInit.kt | 11 + .../core/init/RecipeSerializerInit.kt | 7 + .../core/init/RecipeTypeInit.kt | 7 + .../armourandtoolsmod/core/init/StatsInit.kt | 47 ++++ .../armourandtoolsmod/core/init/TagsInit.kt | 5 + .../core/material/CustomToolMaterial.kt | 5 +- .../datagen/lang/ModEnLangProvider.kt | 7 + .../datagen/loot/ModBlockLootTables.kt | 1 + .../datagen/recipe/MainModRecipeProvider.kt | 1 + .../IngotFusionTollEnhancerRecipeBuilder.kt | 160 +++++++++++++ .../IngotFusionTollEnhancerRecipeProvider.kt | 44 ++++ .../ToolCraftingTableRecipeProvider.kt | 25 ++ .../datagen/tags/ModItemTagsProvider.kt | 1 + .../datagen/texture/ModItemStateProvider.kt | 5 + .../integration/ArmourAndToolsModJEIPlugin.kt | 15 +- ...ngotFusionTollEnhancerJEIRecipeCategory.kt | 120 ++++++++++ ...ustomToolCraftingTableJEIRecipeCategory.kt | 2 +- .../fusion/IIngotFusionTollEnhancerRecipe.kt | 37 +++ .../fusion/IngotFusionTollEnhancerRecipe.kt | 127 ++++++++++ .../container/ingot_fusion_toll_enhancer.png | Bin 0 -> 1128 bytes .../ingot_fusion_toll_enhancer_jei.png | Bin 0 -> 1130 bytes ..._upgraded.png => magma_strike_pickaxe.png} | Bin 55 files changed, 1483 insertions(+), 21 deletions(-) create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/item/imperium.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/item/imperium_pickaxe.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/item/imperium_sword.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/item/magma_strike_pickaxe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/imperium_pickaxe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/imperium_sword.json create mode 100644 src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/ingot_fusion_toll_enhancer.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/imperium_pickaxe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/imperium_sword.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json create mode 100644 src/generated/resources/data/forge/tags/items/ingots/imperium.json create mode 100644 src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java create mode 100644 src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java create mode 100644 src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt rename src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/{core/init/EntityRenderersInit.kt => blocks/fusion/OutputSlotItemHandler.kt} (61%) create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/StatsInit.kt create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IIngotFusionTollEnhancerRecipe.kt create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt create mode 100644 src/main/resources/assets/armourandtoolsmod/textures/gui/container/ingot_fusion_toll_enhancer.png create mode 100644 src/main/resources/assets/armourandtoolsmod/textures/gui/container/ingot_fusion_toll_enhancer_jei.png rename src/main/resources/assets/armourandtoolsmod/textures/item/{imperium_pickaxe_upgraded.png => magma_strike_pickaxe.png} (100%) diff --git a/.gitignore b/.gitignore index 8f81c1b6..2ff9efb8 100644 --- a/.gitignore +++ b/.gitignore @@ -4,6 +4,7 @@ ### ForgeGradle ### # Minecraft client/server files run/ +run-data/ ### Intellij+all ### # Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio, WebStorm and Rider diff --git a/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d b/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d index d4cfbde3..40adfdee 100644 --- a/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d +++ b/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d @@ -1,4 +1,4 @@ -// 1.20.1 2023-08-28T05:16:02.6192725 Loot Tables +// 1.20.1 2023-09-30T23:22:14.944242 Loot Tables 2898515efda3fb01ac7eb6337875f6310869a683 data/armourandtoolsmod/loot_tables/blocks/aqumarine_block.json 1efb52b906488da11f7948ed6a21285c1ae085c5 data/armourandtoolsmod/loot_tables/blocks/aqumarine_ore.json 0f854404a05c040106f826bf3e6eb1debb2b8513 data/armourandtoolsmod/loot_tables/blocks/custom_armour_crafting_table.json @@ -12,6 +12,7 @@ ee3c7cea455b43662bb85c65ba097a66fad15e2b data/armourandtoolsmod/loot_tables/bloc 0a1baaef0c26d8186cfebd9b5f7e8a319d14187d data/armourandtoolsmod/loot_tables/blocks/enderite_ore.json baf5c9934dbe9336e2362956ea6223cd4f067fd5 data/armourandtoolsmod/loot_tables/blocks/graphite_block.json 4e4d7f9e13f901fe3ae5ca406313f683dda24fbb data/armourandtoolsmod/loot_tables/blocks/graphite_ore.json +e71ceb5931a3484e4792e6c73a0f9ff13d769c6f data/armourandtoolsmod/loot_tables/blocks/ingot_fusion_toll_enhancer.json be352efe18892a6d569480eb2c34423ab7e8f199 data/armourandtoolsmod/loot_tables/blocks/rainbow_block.json 8c9c9a72eb8e8424e527174afee3bee8f54a6c0d data/armourandtoolsmod/loot_tables/blocks/rainbow_ore.json 1b4f1728a73c79f1834e8d896bd7af391a8782ac data/armourandtoolsmod/loot_tables/blocks/ruby_block.json diff --git a/src/generated/resources/.cache/9cedfe5b9b9b8fb51ee0cbcde6ee21cf9da7c57c b/src/generated/resources/.cache/9cedfe5b9b9b8fb51ee0cbcde6ee21cf9da7c57c index 646b505c..e4c8ca1a 100644 --- a/src/generated/resources/.cache/9cedfe5b9b9b8fb51ee0cbcde6ee21cf9da7c57c +++ b/src/generated/resources/.cache/9cedfe5b9b9b8fb51ee0cbcde6ee21cf9da7c57c @@ -1,4 +1,4 @@ -// 1.20.1 2023-08-28T05:16:02.6122709 Tags for minecraft:block mod id armourandtoolsmod +// 1.20.1 2023-09-30T23:22:14.940764 Tags for minecraft:block mod id armourandtoolsmod f4e0d28b203a60fd241885a727654636c8762650 data/forge/tags/blocks/deepslate_ores/aqumarine_ores.json 186e50e522fb2ae91c6e315a523523796b105b56 data/forge/tags/blocks/deepslate_ores/graphite_ores.json d66c065dfb98375b77835223afe692a26c7be84b data/forge/tags/blocks/deepslate_ores/rainbow_ores.json @@ -17,7 +17,7 @@ b4f0641534858a5001fc966241f11ffc58353dea data/forge/tags/blocks/storage_blocks/a 55c124f845d639b73cb5bffcdcc94bcfd8967966 data/forge/tags/blocks/storage_blocks/rainbow.json bc5ebfcaf115155b63f0817517bdc3efc0934364 data/forge/tags/blocks/storage_blocks/ruby.json 2e755598d83145bf0d52488c9d8e3c41331dccc3 data/forge/tags/blocks/storage_blocks/sapphire.json -e02f0a033c0eb74be90322606c5f21845d302cf1 data/minecraft/tags/blocks/mineable/pickaxe.json +ab8d7b5abe400a808fae17129487aaea1824bebf data/minecraft/tags/blocks/mineable/pickaxe.json 98eed05f65788348c30e906407f790c6a4d70f32 data/minecraft/tags/blocks/needs_diamond_tool.json 305db57c519bc4cfa07a662c8beeffec12ffac38 data/minecraft/tags/blocks/needs_iron_tool.json a9b03e3b99a673d01bb7413cc6092c7a9b5be634 data/minecraft/tags/blocks/needs_stone_tool.json diff --git a/src/generated/resources/.cache/9f61bb65fbe4cfb8a15e0d3253c99409d3dd169b b/src/generated/resources/.cache/9f61bb65fbe4cfb8a15e0d3253c99409d3dd169b index 2c26027e..47d04f44 100644 --- a/src/generated/resources/.cache/9f61bb65fbe4cfb8a15e0d3253c99409d3dd169b +++ b/src/generated/resources/.cache/9f61bb65fbe4cfb8a15e0d3253c99409d3dd169b @@ -1,4 +1,4 @@ -// 1.20.1 2023-09-24T20:24:31.0315422 Item Models: armourandtoolsmod +// 1.20.1 2023-10-01T16:57:43.5762063 Item Models: armourandtoolsmod 6fdab53e9321f76ef7edd0a135b6879656abdad7 assets/armourandtoolsmod/models/item/amethyst_axe.json f523d3f594a0d1a51fb553f028ab2b20eee793dd assets/armourandtoolsmod/models/item/amethyst_boots.json 8377e984c59ebdaa220b7d1c0973dfd4653e52fb assets/armourandtoolsmod/models/item/amethyst_chestplate.json @@ -34,6 +34,10 @@ a999cd10ee1b427640b86cb303e4b33cbd82cfa8 assets/armourandtoolsmod/models/item/gr 7f03d28ac4363abcd78d60dee0823ebcbdbe4848 assets/armourandtoolsmod/models/item/graphite_leggings.json 2aecba55504a8f58919a7ed564db44ac4a46cf40 assets/armourandtoolsmod/models/item/graphite_shield.json 6bd7890815727bba27c0471942890c4044023bf4 assets/armourandtoolsmod/models/item/graphite_shield_blocking.json +c689e4209f0c9c5d72a90efb880fda6fa5de4119 assets/armourandtoolsmod/models/item/imperium.json +b9bf414d688bbea27c22d22470fb3119ab3820c0 assets/armourandtoolsmod/models/item/imperium_pickaxe.json +205f8bdfd7249defd6d60e27deed940842c6650b assets/armourandtoolsmod/models/item/imperium_sword.json +585fa6ddfbf0355703c29b0cb9c14b985f3fe6cd assets/armourandtoolsmod/models/item/magma_strike_pickaxe.json 62517ca368679b6de05f59df5cf0ba2be1600829 assets/armourandtoolsmod/models/item/rainbow.json e7a2dce51d378c49e596294d6ea2bf6f8d5bf6a2 assets/armourandtoolsmod/models/item/rainbow_boots.json 790e68bc582401a2289e8be785368d04c946185c assets/armourandtoolsmod/models/item/rainbow_chestplate.json diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index e28b98f8..d0acb9c0 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-09-24T20:24:31.0366423 Recipes +// 1.20.1 2023-10-01T16:50:26.142413 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -172,6 +172,8 @@ bf51aa0688586b63f984c9d439054c995048cc22 data/armourandtoolsmod/advancements/rec 6a977849effd37c6e745b3a04fdac602e51c2320 data/armourandtoolsmod/advancements/recipes/tools/enderite_shovel.json 1257c4ee51ccdd562a046dd492053f53887f9703 data/armourandtoolsmod/advancements/recipes/tools/enderite_sword.json d20438d6632aaa0e31ae4ad6ee9af2595dfd2bf8 data/armourandtoolsmod/advancements/recipes/tools/graphite_shield.json +768bf0e682d50ab6265661a6b5dc5e53218a9c24 data/armourandtoolsmod/advancements/recipes/tools/imperium_pickaxe.json +23056e96123073ccd762a7d763afabf93bf99724 data/armourandtoolsmod/advancements/recipes/tools/imperium_sword.json aa1edd9262dfc43253edef429a1dda3be6705e24 data/armourandtoolsmod/advancements/recipes/tools/rainbow_shield.json cb4451ef3aafb1a17926203b75bc3bb85c156667 data/armourandtoolsmod/advancements/recipes/tools/ruby_axe.json d7395d76ae997531eb308841d393de9cb4062585 data/armourandtoolsmod/advancements/recipes/tools/ruby_hoe.json @@ -275,6 +277,9 @@ a5933be44721356f09a3aca47deb959b77260ddc data/armourandtoolsmod/recipes/graphite adf63b0d9c8b2e333a5e4769a2fc0183f483544e data/armourandtoolsmod/recipes/graphite_helmet.json 2e3deec619c89fe5e2f3df072bbb7174c36b877b data/armourandtoolsmod/recipes/graphite_leggings.json b790592cbe2e046b1e8169e2fb4a8da1483a8dfb data/armourandtoolsmod/recipes/graphite_shield.json +aa31085980f2c7c3e8bad8a4dccb79315eac0102 data/armourandtoolsmod/recipes/imperium_pickaxe.json +9d9c3b5485306909e7c17e86c42d4afe8125c648 data/armourandtoolsmod/recipes/imperium_sword.json +eafd7e41a6ffe2b38a3296d6bcf2cf014115ed78 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json 0399917d7fdda6f9af410c709805dfb149b2451c data/armourandtoolsmod/recipes/rainbow_block_recipe.json 5caa6184a7c066fac3bbc8e3869ae712171fe202 data/armourandtoolsmod/recipes/rainbow_boots.json cc01dc105a026c1a42db2e4a7bea9ca208ef22e2 data/armourandtoolsmod/recipes/rainbow_chestplate.json diff --git a/src/generated/resources/.cache/b051adeca7b8303d1a7d46afb7c4eaf8cfa3a7f5 b/src/generated/resources/.cache/b051adeca7b8303d1a7d46afb7c4eaf8cfa3a7f5 index 26bac2ea..3a1bb944 100644 --- a/src/generated/resources/.cache/b051adeca7b8303d1a7d46afb7c4eaf8cfa3a7f5 +++ b/src/generated/resources/.cache/b051adeca7b8303d1a7d46afb7c4eaf8cfa3a7f5 @@ -1,4 +1,4 @@ -// 1.20.1 2023-08-28T05:16:02.6162711 Tags for minecraft:item mod id armourandtoolsmod +// 1.20.1 2023-10-01T16:50:26.1358975 Tags for minecraft:item mod id armourandtoolsmod f4e0d28b203a60fd241885a727654636c8762650 data/forge/tags/items/deepslate_ores/aqumarine_ores.json 186e50e522fb2ae91c6e315a523523796b105b56 data/forge/tags/items/deepslate_ores/graphite_ores.json d66c065dfb98375b77835223afe692a26c7be84b data/forge/tags/items/deepslate_ores/rainbow_ores.json @@ -7,6 +7,7 @@ cd94fb683ebafe1cbde0ba3a30280d57b587fc34 data/forge/tags/items/deepslate_ores/ru 04d29499ff85f8124c50ef07269cf25db07ae07d data/forge/tags/items/ingots/aqumarine.json dc53c8e250d79a891fb7b091453ddbf4a97be9c8 data/forge/tags/items/ingots/enderite.json c963a5fc1309d90f803cfdfbf05f02ace6abb49b data/forge/tags/items/ingots/graphite.json +fcffdb7f1440f079493fd4add5abc1c711efbabe data/forge/tags/items/ingots/imperium.json 264adb63393b61bea724cadd9fe78dee27f9b867 data/forge/tags/items/ingots/rainbow.json a9e8b31cf275be39ab498638115ee072f1c88065 data/forge/tags/items/ingots/ruby.json 5e8b8285fff705424cf2afb6d0df6e0fdab067ea data/forge/tags/items/ingots/sapphire.json diff --git a/src/generated/resources/.cache/c622617f6fabf890a00b9275cd5f643584a8a2c8 b/src/generated/resources/.cache/c622617f6fabf890a00b9275cd5f643584a8a2c8 index 847f03ef..901e3eac 100644 --- a/src/generated/resources/.cache/c622617f6fabf890a00b9275cd5f643584a8a2c8 +++ b/src/generated/resources/.cache/c622617f6fabf890a00b9275cd5f643584a8a2c8 @@ -1,2 +1,2 @@ -// 1.20.1 2023-09-24T20:32:12.0083899 Languages: en_us -4510074163c2f4204899bc6c5c71c9b0d4a9c0fc assets/armourandtoolsmod/lang/en_us.json +// 1.20.1 2023-10-01T16:50:26.1493981 Languages: en_us +f9cb5563ca127b800a6e4df334e07f3117045ab9 assets/armourandtoolsmod/lang/en_us.json diff --git a/src/generated/resources/assets/armourandtoolsmod/lang/en_us.json b/src/generated/resources/assets/armourandtoolsmod/lang/en_us.json index 38cbe84c..74a267c4 100644 --- a/src/generated/resources/assets/armourandtoolsmod/lang/en_us.json +++ b/src/generated/resources/assets/armourandtoolsmod/lang/en_us.json @@ -74,6 +74,7 @@ "block.armourandtoolsmod.enderite_ore": "Enderite Ore", "block.armourandtoolsmod.graphite_block": "Graphite Block", "block.armourandtoolsmod.graphite_ore": "Graphite Ore", + "block.armourandtoolsmod.ingot_fusion_toll_enhancer": "Ingot Fusion Toll Enhancer", "block.armourandtoolsmod.rainbow_block": "Rainbow Block", "block.armourandtoolsmod.rainbow_ore": "Rainbow Ore", "block.armourandtoolsmod.ruby_block": "Ruby Block", @@ -84,6 +85,8 @@ "container.custom_armour_crafting_table.description": "Craft your own custom armour!", "container.custom_tool_crafting_table": "Tool Crafting Table", "container.custom_tool_crafting_table.description": "Craft your own custom tools!", + "container.ingot_fusion_toll_enhancer": "Ingot Fusion Toll Enhancer", + "container.ingot_fusion_toll_enhancer.description": "Enhance your tools and armour!", "creativetab.armourandtoolsmod": "Armour and Item Mod", "item.armourandtoolsmod.amethyst_axe": "Amethyst Axe", "item.armourandtoolsmod.amethyst_boots": "Amethyst Boots", @@ -116,6 +119,10 @@ "item.armourandtoolsmod.graphite_helmet": "Graphite Helmet", "item.armourandtoolsmod.graphite_leggings": "Graphite Leggings", "item.armourandtoolsmod.graphite_shield": "Graphite Shield", + "item.armourandtoolsmod.imperium": "Imperium", + "item.armourandtoolsmod.imperium_pickaxe": "Imperium Pickaxe", + "item.armourandtoolsmod.imperium_sword": "Imperium Sword", + "item.armourandtoolsmod.magma_strike_pickaxe": "Magma Strike Pickaxe", "item.armourandtoolsmod.rainbow": "Rainbow Ingot", "item.armourandtoolsmod.rainbow_boots": "Rainbow Boots", "item.armourandtoolsmod.rainbow_chestplate": "Rainbow Chestplate", diff --git a/src/generated/resources/assets/armourandtoolsmod/models/item/imperium.json b/src/generated/resources/assets/armourandtoolsmod/models/item/imperium.json new file mode 100644 index 00000000..56b07484 --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/item/imperium.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "armourandtoolsmod:item/imperium" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/models/item/imperium_pickaxe.json b/src/generated/resources/assets/armourandtoolsmod/models/item/imperium_pickaxe.json new file mode 100644 index 00000000..7a5b2bc8 --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/item/imperium_pickaxe.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "armourandtoolsmod:item/imperium_pickaxe" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/models/item/imperium_sword.json b/src/generated/resources/assets/armourandtoolsmod/models/item/imperium_sword.json new file mode 100644 index 00000000..9aa145d7 --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/item/imperium_sword.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "armourandtoolsmod:item/imperium_sword" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/models/item/magma_strike_pickaxe.json b/src/generated/resources/assets/armourandtoolsmod/models/item/magma_strike_pickaxe.json new file mode 100644 index 00000000..9ddd9220 --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/item/magma_strike_pickaxe.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "armourandtoolsmod:item/magma_strike_pickaxe" + } +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/imperium_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/imperium_pickaxe.json new file mode 100644 index 00000000..258d75c4 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/imperium_pickaxe.json @@ -0,0 +1,33 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "tag": "forge:ingots/imperium" + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:imperium_pickaxe" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:imperium_pickaxe" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/imperium_sword.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/imperium_sword.json new file mode 100644 index 00000000..b65a977e --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/imperium_sword.json @@ -0,0 +1,33 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "tag": "forge:ingots/imperium" + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:imperium_sword" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:imperium_sword" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/ingot_fusion_toll_enhancer.json b/src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/ingot_fusion_toll_enhancer.json new file mode 100644 index 00000000..8a25045a --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/ingot_fusion_toll_enhancer.json @@ -0,0 +1,21 @@ +{ + "type": "minecraft:block", + "pools": [ + { + "bonus_rolls": 0.0, + "conditions": [ + { + "condition": "minecraft:survives_explosion" + } + ], + "entries": [ + { + "type": "minecraft:item", + "name": "armourandtoolsmod:ingot_fusion_toll_enhancer" + } + ], + "rolls": 1.0 + } + ], + "random_sequence": "armourandtoolsmod:blocks/ingot_fusion_toll_enhancer" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/imperium_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/imperium_pickaxe.json new file mode 100644 index 00000000..31b827c4 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/imperium_pickaxe.json @@ -0,0 +1,20 @@ +{ + "type": "armourandtoolsmod:custom_tool_crafter", + "category": "pickaxe", + "key": { + "A": { + "tag": "forge:ingots/imperium" + }, + "S": { + "item": "minecraft:stick" + } + }, + "pattern": [ + "AAA", + " S ", + " S " + ], + "result": { + "item": "armourandtoolsmod:imperium_pickaxe" + } +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/imperium_sword.json b/src/generated/resources/data/armourandtoolsmod/recipes/imperium_sword.json new file mode 100644 index 00000000..a8ede2c1 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/imperium_sword.json @@ -0,0 +1,20 @@ +{ + "type": "armourandtoolsmod:custom_tool_crafter", + "category": "sword", + "key": { + "A": { + "tag": "forge:ingots/imperium" + }, + "S": { + "item": "minecraft:stick" + } + }, + "pattern": [ + " A ", + " A ", + " S " + ], + "result": { + "item": "armourandtoolsmod:imperium_sword" + } +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json new file mode 100644 index 00000000..295c7f0e --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json @@ -0,0 +1,13 @@ +{ + "type": "armourandtoolsmod:ingot_fusion_toll_enhancer_recipe", + "input1": { + "tag": "forge:ingots/imperium" + }, + "input2": { + "item": "armourandtoolsmod:imperium_pickaxe" + }, + "input3": { + "tag": "forge:ingots/imperium" + }, + "result": "armourandtoolsmod:magma_strike_pickaxe" +} \ No newline at end of file diff --git a/src/generated/resources/data/forge/tags/items/ingots/imperium.json b/src/generated/resources/data/forge/tags/items/ingots/imperium.json new file mode 100644 index 00000000..1e14f19d --- /dev/null +++ b/src/generated/resources/data/forge/tags/items/ingots/imperium.json @@ -0,0 +1,5 @@ +{ + "values": [ + "armourandtoolsmod:imperium" + ] +} \ No newline at end of file diff --git a/src/generated/resources/data/minecraft/tags/blocks/mineable/pickaxe.json b/src/generated/resources/data/minecraft/tags/blocks/mineable/pickaxe.json index 173de125..d1e31e21 100644 --- a/src/generated/resources/data/minecraft/tags/blocks/mineable/pickaxe.json +++ b/src/generated/resources/data/minecraft/tags/blocks/mineable/pickaxe.json @@ -19,6 +19,7 @@ "armourandtoolsmod:deepslate_aqumarine_ore", "armourandtoolsmod:custom_armour_crafting_table", "armourandtoolsmod:custom_tool_crafting_table", + "armourandtoolsmod:ingot_fusion_toll_enhancer", "armourandtoolsmod:custom_armour_crafting_table" ] } \ No newline at end of file diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java new file mode 100644 index 00000000..e992c4bb --- /dev/null +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java @@ -0,0 +1,165 @@ +package io.github.realyusufismail.armourandtoolsmod.blocks; + +import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; +import io.github.realyusufismail.armourandtoolsmod.blocks.fusion.IngotFusionTollEnhancerBlockEntity; +import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit; +import io.github.realyusufismail.armourandtoolsmod.core.init.StatsInit; +import net.minecraft.core.BlockPos; +import net.minecraft.core.Direction; +import net.minecraft.network.chat.Component; +import net.minecraft.server.level.ServerLevel; +import net.minecraft.server.level.ServerPlayer; +import net.minecraft.world.*; +import net.minecraft.world.entity.player.Player; +import net.minecraft.world.item.ItemStack; +import net.minecraft.world.item.TooltipFlag; +import net.minecraft.world.item.context.BlockPlaceContext; +import net.minecraft.world.level.BlockGetter; +import net.minecraft.world.level.Level; +import net.minecraft.world.level.block.*; +import net.minecraft.world.level.block.entity.BlockEntity; +import net.minecraft.world.level.block.entity.BlockEntityTicker; +import net.minecraft.world.level.block.entity.BlockEntityType; +import net.minecraft.world.level.block.state.BlockBehaviour; +import net.minecraft.world.level.block.state.BlockState; +import net.minecraft.world.level.block.state.StateDefinition; +import net.minecraft.world.level.block.state.properties.BlockStateProperties; +import net.minecraft.world.level.block.state.properties.BooleanProperty; +import net.minecraft.world.level.block.state.properties.DirectionProperty; +import net.minecraft.world.level.material.MapColor; +import net.minecraft.world.phys.BlockHitResult; +import net.minecraftforge.network.NetworkHooks; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; + +import java.util.List; +import java.util.Objects; + +/** + * @see net.minecraft.world.level.block.FurnaceBlock + */ +public class IngotFusionTollEnhancer extends BaseEntityBlock { + public static final BooleanProperty LIT = BlockStateProperties.LIT; + private static final DirectionProperty FACING = HorizontalDirectionalBlock.FACING; + + public IngotFusionTollEnhancer() { + super(BlockBehaviour.Properties.of() + .strength(5.0F, 6.0F) + .sound(SoundType.METAL) + .mapColor(MapColor.DIAMOND)); + this.registerDefaultState(defaultBlockState().setValue(FACING, Direction.NORTH).setValue(LIT, false)); + } + + @Override + public @NotNull InteractionResult use(@NotNull BlockState blockState, @NotNull Level level, @NotNull BlockPos blockPos, @NotNull Player player, + @NotNull InteractionHand interactionHand, @NotNull BlockHitResult blockHitResult) { + if (!level.isClientSide) { + BlockEntity blockEntity = level.getBlockEntity(blockPos); + if (blockEntity instanceof IngotFusionTollEnhancerBlockEntity) { + try { + Objects.requireNonNull(player, "Player is null"); + Objects.requireNonNull(blockEntity, "BlockEntity is null"); + + NetworkHooks.openScreen((ServerPlayer) player, (IngotFusionTollEnhancerBlockEntity) blockEntity, blockPos); + } catch (Exception e) { + throw new RuntimeException("Failed to open screen." + e); + } + } + } + return InteractionResult.sidedSuccess(level.isClientSide); + } + + @Override + public void onRemove(BlockState oldState, Level level, BlockPos blockPos, BlockState newState, boolean movedByPiston) { + if (!oldState.is(newState.getBlock())) { + BlockEntity blockEntity = level.getBlockEntity(blockPos); + if (blockEntity instanceof IngotFusionTollEnhancerBlockEntity) { + if (level instanceof ServerLevel) { + Containers.dropContents(level, blockPos, (Container) blockEntity); + level.updateNeighbourForOutputSignal(blockPos, this); + } + level.updateNeighbourForOutputSignal(blockPos, this); + } + super.onRemove(oldState, level, blockPos, newState, movedByPiston); + } + } + + @Nullable + @Override + public BlockEntity newBlockEntity(BlockPos pPos, BlockState pState) { + return new IngotFusionTollEnhancerBlockEntity(pPos, pState); + } + + @Override + public BlockState getStateForPlacement(BlockPlaceContext context) { + return this.defaultBlockState().setValue(FACING, context.getHorizontalDirection().getOpposite()); + } + + @Override + protected void createBlockStateDefinition(StateDefinition.Builder builder) { + builder.add(FACING, LIT); + } + + @Override + public boolean hasDynamicShape() { + return true; + } + + /** + * @deprecated call via {@link + * net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#hasAnalogOutputSignal} whenever possible. + * Implementing/overriding is fine. + */ + @Override + public boolean hasAnalogOutputSignal(BlockState pState) { + return true; + } + + /** + * The type of render function called. MODEL for mixed tesr and static model, MODELBLOCK_ANIMATED for TESR-only, + * LIQUID for vanilla liquids, INVISIBLE to skip all rendering + * + * @deprecated call via {@link net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#getRenderShape} + * whenever possible. Implementing/overriding is fine. + */ + public @NotNull RenderShape getRenderShape(BlockState pState) { + return RenderShape.MODEL; + } + + /** + * Returns the blockstate with the given rotation from the passed blockstate. If inapplicable, returns the passed + * blockstate. + * + * @deprecated call via {@link net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#rotate} whenever + * possible. Implementing/overriding is fine. + */ + @Override + public BlockState rotate(BlockState pState, Rotation pRotation) { + return pState.setValue(FACING, pRotation.rotate(pState.getValue(FACING))); + } + + /** + * Returns the blockstate with the given mirror of the passed blockstate. If inapplicable, returns the passed + * blockstate. + * + * @deprecated call via {@link net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#mirror} whenever + * possible. Implementing/overriding is fine. + */ + @Override + public @NotNull BlockState mirror(BlockState pState, Mirror pMirror) { + return pState.rotate(pMirror.getRotation(pState.getValue(FACING))); + } + + public static @NotNull Component getContainerTitle() { + return Component.translatable("container.ingot_fusion_toll_enhancer"); + } + + public static Component getContainerDescription() { + return Component.translatable("container.ingot_fusion_toll_enhancer.description"); + } + + @Override + public void appendHoverText(ItemStack pStack, @Nullable BlockGetter pLevel, List pTooltip, TooltipFlag pFlag) { + pTooltip.add(getContainerDescription()); + } +} diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java index 711207c3..6ae652fb 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java @@ -56,9 +56,10 @@ public void containerTick() { /** * Renders the graphical user interface (GUI) element. + * * @param pGuiGraphics the GuiGraphics object used for rendering. - * @param pMouseX the x-coordinate of the mouse cursor. - * @param pMouseY the y-coordinate of the mouse cursor. + * @param pMouseX the x-coordinate of the mouse cursor. + * @param pMouseY the y-coordinate of the mouse cursor. * @param pPartialTick the partial tick time. */ public void render(GuiGraphics pGuiGraphics, int pMouseX, int pMouseY, float pPartialTick) { diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java new file mode 100644 index 00000000..873ece24 --- /dev/null +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java @@ -0,0 +1,63 @@ +package io.github.realyusufismail.armourandtoolsmod.blocks.fusion; + +import com.mojang.blaze3d.systems.RenderSystem; +import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; +import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; +import net.minecraft.client.gui.Font; +import net.minecraft.client.gui.GuiGraphics; +import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; +import net.minecraft.client.gui.screens.inventory.ContainerScreen; +import net.minecraft.network.chat.Component; +import net.minecraft.resources.ResourceLocation; +import net.minecraft.world.entity.player.Inventory; +import net.minecraft.world.inventory.ChestMenu; +import org.jetbrains.annotations.NotNull; + +import java.util.Objects; + +/** + * @see net.minecraft.client.gui.screens.inventory.FurnaceScreen + */ +public class IngotFusionTollEnhancerScreen extends AbstractContainerScreen { + public static final ResourceLocation SCREEN_ID = ArmourAndToolsMod.ArmorAndToolsMod.getModIdAndName("textures/gui/container/ingot_fusion_toll_enhancer.png"); + + public IngotFusionTollEnhancerScreen(IngotFusionTollEnhancerMenu pMenu, Inventory pPlayerInventory, Component pTitle) { + super(pMenu, pPlayerInventory, pTitle); + } + + @Override + protected void renderBg(@NotNull GuiGraphics pGuiGraphics, float pPartialTick, int pMouseX, int pMouseY) { + try { + RenderSystem.setShaderColor(1.0F, 1.0F, 1.0F, 1.0F); + Objects.requireNonNull(minecraft, "Minecraft Instance is null").getTextureManager().bindForSetup(SCREEN_ID); + + int i = this.leftPos; + int j = this.topPos; + pGuiGraphics.blit(SCREEN_ID, i, j, 0, 0, 176, 179); + pGuiGraphics.blit(SCREEN_ID, i + 97, j + 38, 179, 25, menu.getLitProgress() + 1, 17); + } catch (NullPointerException e) { + throw new NullPointerException("Minecraft Instance is null"); + } + } + + @Override + public void render(@NotNull GuiGraphics pGuiGraphics, int pMouseX, int pMouseY, float pPartialTick) { + try { + this.renderBackground(pGuiGraphics); + this.renderTooltip(pGuiGraphics, pMouseX, pMouseY); + super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + } catch (NullPointerException e) { + throw new NullPointerException("Render method called before Minecraft Instance is set"); + } + } + + @Override + public void renderLabels(@NotNull GuiGraphics pGuiGraphics, int pMouseX, int pMouseY) { + try { + pGuiGraphics.drawString(this.font, this.playerInventoryTitle, 7, 81, 4210752, false); + pGuiGraphics.drawString(this.font, IngotFusionTollEnhancer.getContainerTitle(), 5, 10, 4210752, false); + } catch (NullPointerException e) { + throw new NullPointerException("Unable to render labels"); + } + } +} diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java index fc8ac2b8..1a09d1c8 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java @@ -59,9 +59,10 @@ public void containerTick() { /** * Renders the graphical user interface (GUI) element. + * * @param pGuiGraphics the GuiGraphics object used for rendering. - * @param pMouseX the x-coordinate of the mouse cursor. - * @param pMouseY the y-coordinate of the mouse cursor. + * @param pMouseX the x-coordinate of the mouse cursor. + * @param pMouseY the y-coordinate of the mouse cursor. * @param pPartialTick the partial tick time. */ public void render(GuiGraphics pGuiGraphics, int pMouseX, int pMouseY, float pPartialTick) { diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java new file mode 100644 index 00000000..e7df3bf2 --- /dev/null +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java @@ -0,0 +1,20 @@ +package io.github.realyusufismail.armourandtoolsmod.core.init; + +import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; +import io.github.realyusufismail.armourandtoolsmod.blocks.fusion.IngotFusionTollEnhancerBlockEntity; +import net.minecraft.world.level.block.entity.BlockEntity; +import net.minecraft.world.level.block.entity.BlockEntityType; +import net.minecraftforge.registries.DeferredRegister; +import net.minecraftforge.registries.ForgeRegistries; +import net.minecraftforge.registries.RegistryObject; + +public class BlockEntityTypeInit { + + public static DeferredRegister> BLOCK_ENTITY_TYPES = + DeferredRegister.create(ForgeRegistries.BLOCK_ENTITY_TYPES, ArmourAndToolsMod.MOD_ID); + + public static RegistryObject> INGOT_FUSION_TOLL_ENHANCER = + BLOCK_ENTITY_TYPES.register("ingot_fusion_toll_enhancer", + () -> BlockEntityType.Builder.of(IngotFusionTollEnhancerBlockEntity::new, + BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()).build(null)); +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/ArmourAndToolsMod.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/ArmourAndToolsMod.kt index a80f0afd..ddcab5b5 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/ArmourAndToolsMod.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/ArmourAndToolsMod.kt @@ -42,7 +42,9 @@ class ArmourAndToolsMod { RecipeSerializerInit.SERIALIZERS.register(bus) RecipeTypeInit.RECIPE_TYPES.register(bus) EntityTypeInit.ENTITY_TYPES.register(bus) + BlockEntityTypeInit.BLOCK_ENTITY_TYPES.register(bus) CreativeModeTabInit.CREATIVE_MODE_TAB.register(bus) + StatsInit.STATS.register(bus) // Register ourselves for server and other game events we are interested in // Register the data generators diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt new file mode 100644 index 00000000..129045d5 --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt @@ -0,0 +1,216 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.blocks.fusion + +import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer +import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe +import net.minecraft.core.BlockPos +import net.minecraft.core.NonNullList +import net.minecraft.network.FriendlyByteBuf +import net.minecraft.network.chat.Component +import net.minecraft.world.entity.player.Inventory +import net.minecraft.world.inventory.AbstractContainerMenu +import net.minecraft.world.inventory.ContainerData +import net.minecraft.world.item.ItemStack +import net.minecraft.world.level.Level +import net.minecraft.world.level.block.entity.BlockEntityTicker +import net.minecraft.world.level.block.entity.FurnaceBlockEntity +import net.minecraft.world.level.block.entity.RandomizableContainerBlockEntity +import net.minecraft.world.level.block.state.BlockState + +const val NUMBER_OF_SLOTS = 4 + +/** @see FurnaceBlockEntity */ +open class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState) : + RandomizableContainerBlockEntity( + BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), pPos, pBlockState), + BlockEntityTicker { + private val maxTick = 200 + private var currentTick: Int = 0 + private var itemStack: NonNullList = + NonNullList.withSize(NUMBER_OF_SLOTS, ItemStack.EMPTY) + + val data: ContainerData = + object : ContainerData { + override fun get(pIndex: Int): Int { + return when (pIndex) { + 0 -> currentTick + 1 -> maxTick + else -> + throw ArrayIndexOutOfBoundsException("ContainerData index out of bounds") + } + } + + override fun set(pIndex: Int, pValue: Int) { + throw UnsupportedOperationException("ContainerData cannot be changed") + } + + override fun getCount(): Int { + return 2 + } + } + + override fun tick( + pLevel: Level, + pPos: BlockPos, + pState: BlockState, + pBlockEntity: IngotFusionTollEnhancerBlockEntity + ) { + try { + if (!level!!.isClientSide) { + val input1 = items[0] + val input2 = items[1] + val input3 = items[2] + if (empty(input1) && empty(input2) && empty(input3)) { + val recipe: IngotFusionTollEnhancerRecipe = + getRecipe() ?: throw NullPointerException("Recipe is null") + if (canProcessFromRecipe(recipe)) { + currentTick++ + level!!.setBlock( + worldPosition, + level!! + .getBlockState(worldPosition) + .setValue( + IngotFusionTollEnhancer.LIT, java.lang.Boolean.TRUE), + 3) + if (currentTick >= maxTick) { + processing(recipe) + currentTick = 0 + } + } else { + level!!.setBlock( + worldPosition, + level!! + .getBlockState(worldPosition) + .setValue( + IngotFusionTollEnhancer.LIT, java.lang.Boolean.FALSE), + 3) + currentTick = 0 + setChanged() + return + } + } else { + level!!.setBlock( + worldPosition, + level!! + .getBlockState(worldPosition) + .setValue( + IngotFusionTollEnhancer.LIT, java.lang.Boolean.FALSE), + 3) + currentTick = 0 + setChanged() + return + } + } + setChanged() + } catch (e: NullPointerException) { + throw NullPointerException("Tick failed") + } + } + + private fun processing(recipe: IngotFusionTollEnhancerRecipe) { + if (canProcessFromRecipe(recipe)) { + val input1 = items[0] + val input2 = items[1] + val input3 = items[2] + val result: ItemStack = recipe.result + val outputSlot = items[3] + if (outputSlot.isEmpty) { + items[3] = result.copy() + } else if (outputSlot.item === result.item) { + outputSlot.grow(1) + } + input1.shrink(1) + input2.shrink(1) + input3.shrink(1) + setChanged() + } + } + + private fun canProcessFromRecipe(recipe: IngotFusionTollEnhancerRecipe): Boolean { + return if (empty(items[0]) && empty(items[1]) && empty(items[2])) { + val stack: ItemStack = recipe.result + if (stack.isEmpty) { + false + } else { + val resultSlot = items[3] + if (resultSlot.isEmpty) { + true + } else if (!ItemStack.isSameItem(resultSlot, stack)) { + false + } else if (resultSlot.count + stack.count <= 64 && + resultSlot.count + stack.count <= resultSlot.maxStackSize) { + true + } else { + resultSlot.count + stack.count <= stack.maxStackSize + } + } + } else false + } + + fun encodeExtraData(buffer: FriendlyByteBuf) { + buffer.writeByte(items.size) + buffer.writeByte(data.count) + } + + override fun setItems(p_199721_1_: NonNullList) { + itemStack = p_199721_1_ + } + + override fun getItems(): NonNullList { + return itemStack + } + + override fun getContainerSize(): Int { + return NUMBER_OF_SLOTS + } + + /** Returns the stack in the given slot. */ + override fun getItem(pSlot: Int): ItemStack { + return items[pSlot] + } + + private fun empty(stack: ItemStack): Boolean { + return !stack.isEmpty + } + + override fun createMenu(pContainerId: Int, pInventory: Inventory): AbstractContainerMenu { + return IngotFusionTollEnhancerMenu(pContainerId, pInventory, this, data) + } + + override fun getDefaultName(): Component { + return IngotFusionTollEnhancer.getContainerTitle() + } + + private fun getRecipe(): IngotFusionTollEnhancerRecipe? { + return if (items[0].isEmpty || items[1].isEmpty || items[2].isEmpty) { + null + } else { + level!! + .recipeManager + .getRecipeFor( + RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), + this, + this.level ?: throw NullPointerException("Level is null")) + .orElse(null) as IngotFusionTollEnhancerRecipe? + } + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt new file mode 100644 index 00000000..11c56adf --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt @@ -0,0 +1,130 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.blocks.fusion + +import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit +import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit +import net.minecraft.network.FriendlyByteBuf +import net.minecraft.world.entity.player.Inventory +import net.minecraft.world.entity.player.Player +import net.minecraft.world.inventory.* +import net.minecraft.world.item.ItemStack +import net.minecraft.world.level.Level +import net.minecraft.world.level.block.entity.BlockEntity +import net.minecraftforge.common.capabilities.ForgeCapabilities +import net.minecraftforge.items.SlotItemHandler + +/** @see FurnaceMenu */ +class IngotFusionTollEnhancerMenu( + pContainerId: Int, + private val inventory: Inventory, + private val blockEntity: BlockEntity, + private val data: ContainerData, + private val player: Player = inventory.player, +) : AbstractContainerMenu(MenuTypeInit.INGOT_FUSION_TOLL_ENHANCER_MENU.get(), pContainerId) { + private var level: Level = inventory.player.level() + + constructor( + pContainerId: Int, + inventory: Inventory, + data: FriendlyByteBuf + ) : this( + pContainerId, + inventory, + inventory.player.level().getBlockEntity(data.readBlockPos()) + ?: throw IllegalStateException("Block is null"), + SimpleContainerData(2)) + + init { + + try { + checkContainerSize(inventory, NUMBER_OF_SLOTS) + + addPlayerInventory(inventory) + addPlayerHotbar(inventory) + + blockEntity.getCapability(ForgeCapabilities.ITEM_HANDLER).ifPresent { it -> + addSlot(SlotItemHandler(it, 0, 16, 40)) + addSlot(SlotItemHandler(it, 1, 43, 40)) + addSlot(SlotItemHandler(it, 2, 70, 40)) + + addSlot(OutputSlotItemHandler(it)) + } + + addDataSlots(data) + } catch (e: Exception) { + throw NullPointerException("Container cannot be null") + } + } + + override fun quickMoveStack(pPlayer: Player, index: Int): ItemStack { + var itemstack = ItemStack.EMPTY + val slot = slots[index] + if (slot.hasItem()) { + val stack1 = slot.item + itemstack = stack1.copy() + if (index < NUMBER_OF_SLOTS && + !moveItemStackTo(stack1, NUMBER_OF_SLOTS, slots.size, true)) { + return ItemStack.EMPTY + } + if (!moveItemStackTo(stack1, 0, NUMBER_OF_SLOTS, false)) { + return ItemStack.EMPTY + } + if (stack1.isEmpty) { + slot.set(ItemStack.EMPTY) + } else { + slot.setChanged() + } + } + return itemstack + } + + /** Determines whether supplied player can use this container */ + override fun stillValid(pPlayer: Player): Boolean { + return stillValid( + ContainerLevelAccess.create(level, blockEntity.blockPos), + player, + BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()) + } + + fun getLitProgress(): Int { + val process = data[0] + val maxTick = data[1] + return if (maxTick != 0 && process != 0) process * 24 / maxTick else 0 + } + + private fun addPlayerInventory(playerInventory: Inventory) { + for (row in 0..2) { + for (col in 0..8) { + addSlot( + Slot( + playerInventory, + col + row * 9 + 9, + 8 + col * 18, + 166 - (4 - row) * 18 - 10 + 13)) + } + } + } + + private fun addPlayerHotbar(playerInventory: Inventory) { + for (col in 0..8) { + addSlot(Slot(playerInventory, col, 8 + col * 18, 142 + 13)) + } + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/EntityRenderersInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/OutputSlotItemHandler.kt similarity index 61% rename from src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/EntityRenderersInit.kt rename to src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/OutputSlotItemHandler.kt index 962d2ce6..ff77e219 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/EntityRenderersInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/OutputSlotItemHandler.kt @@ -16,6 +16,15 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package io.github.realyusufismail.armourandtoolsmod.core.init +package io.github.realyusufismail.armourandtoolsmod.blocks.fusion -object EntityRenderersInit +import net.minecraft.world.item.ItemStack +import net.minecraftforge.items.IItemHandler +import net.minecraftforge.items.SlotItemHandler + +class OutputSlotItemHandler(itemHandler: IItemHandler) : SlotItemHandler(itemHandler, 3, 138, 40) { + + override fun mayPlace(stack: ItemStack): Boolean { + return false + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt index 4c7535e2..9eab7acd 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt @@ -19,11 +19,10 @@ package io.github.realyusufismail.armourandtoolsmod.client import io.github.realyusufismail.armourandtoolsmod.blocks.armour.CustomArmourCraftingTableScreen +import io.github.realyusufismail.armourandtoolsmod.blocks.fusion.IngotFusionTollEnhancerScreen import io.github.realyusufismail.armourandtoolsmod.blocks.tool.CustomToolCraftingTableScreen import io.github.realyusufismail.armourandtoolsmod.client.renderer.trident.AqumarineTridentItemRenderer -import io.github.realyusufismail.armourandtoolsmod.core.init.EntityTypeInit -import io.github.realyusufismail.armourandtoolsmod.core.init.ItemInit -import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit +import io.github.realyusufismail.armourandtoolsmod.core.init.* import net.minecraft.client.gui.screens.MenuScreens import net.minecraft.client.multiplayer.ClientLevel import net.minecraft.client.renderer.item.ItemProperties @@ -39,6 +38,8 @@ object ClientSetup { event.enqueueWork { registerScreens() } event.enqueueWork { + StatsInit.init() + ItemProperties.register(ItemInit.RUBY_SHIELD.get(), ResourceLocation("blocking")) { stack: ItemStack, _: ClientLevel?, @@ -99,6 +100,9 @@ object ClientSetup { MenuScreens.register( MenuTypeInit.CUSTOM_TOOL_CRAFTING_TABLE_MENU.get(), ::CustomToolCraftingTableScreen) + + MenuScreens.register( + MenuTypeInit.INGOT_FUSION_TOLL_ENHANCER_MENU.get(), ::IngotFusionTollEnhancerScreen) } fun registerEntityRenders(event: EntityRenderersEvent.RegisterRenderers) { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/BlockInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/BlockInit.kt index cb05ed3a..e9e19211 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/BlockInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/BlockInit.kt @@ -21,6 +21,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod.ArmorAndToolsMod.MOD_ID import io.github.realyusufismail.armourandtoolsmod.blocks.CustomArmourCraftingTable import io.github.realyusufismail.armourandtoolsmod.blocks.CustomToolCraftingTable +import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer import io.github.realyusufismail.armourandtoolsmod.blocks.lit.RainbowLitBlock import io.github.realyusufismail.armourandtoolsmod.blocks.lit.RubyLitBlock import net.minecraft.world.item.BlockItem @@ -165,13 +166,17 @@ object BlockInit { BlockBehaviour.Properties.copy(Blocks.DIAMOND_BLOCK).requiresCorrectToolForDrops(), MinableBlockType.DIAMOND_PICKAXE) - // custom crafting table + // custom recipe tables val CUSTOM_ARMOUR_CRAFTING_TABLE = registerSpecial("custom_armour_crafting_table", ::CustomArmourCraftingTable) val CUSTOM_TOOL_CRAFTING_TABLE = registerSpecial("custom_tool_crafting_table", ::CustomToolCraftingTable) + @JvmField + val INGOT_FUSION_TOLL_ENHANCER = + registerSpecial("ingot_fusion_toll_enhancer", ::IngotFusionTollEnhancer) + private fun registerSpecial( name: String, supplier: () -> T, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt index 891f88d9..bb983099 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt @@ -50,6 +50,8 @@ object ItemInit { ITEMS.registerObject("rainbow") { Item(Item.Properties()) } val ENDERITE: ObjectHolderDelegate = ITEMS.registerObject("enderite") { Item(Item.Properties()) } + val IMPERIUM: ObjectHolderDelegate = + ITEMS.registerObject("imperium") { Item(Item.Properties()) } // raw ores val RAW_RUBY: ObjectHolderDelegate = @@ -249,6 +251,15 @@ object ItemInit { Item.Properties().stacksTo(1).durability(800)) } + val IMPERIUM_SWORD: ObjectHolderDelegate = + ITEMS.registerObject("imperium_sword") { + CustomSwordItem( + CustomToolMaterial.IMPERIUM_SWORD, + 10, + -2.7f, + Item.Properties().stacksTo(1).durability(800)) + } + // Pickaxes val RUBY_PICKAXE: ObjectHolderDelegate = ITEMS.registerSmeltableObject("ruby_pickaxe", RUBY) { @@ -286,6 +297,24 @@ object ItemInit { Item.Properties().stacksTo(1).durability(800)) } + val IMPERIUM_PICKAXE: ObjectHolderDelegate = + ITEMS.registerObject("imperium_pickaxe") { + PickaxeItem( + CustomToolMaterial.IMPERIUM_PICKAXE, + 7, + -2.9f, + Item.Properties().stacksTo(1).durability(800)) + } + + val MAGMA_STRIKE_PICKAXE: ObjectHolderDelegate = + ITEMS.registerObject("magma_strike_pickaxe") { + PickaxeItem( + CustomToolMaterial.MAGMA_STRIKE_PICKAXE, + 9, + -3.0f, + Item.Properties().stacksTo(1).durability(1000)) + } + // Axes val RUBY_AXE: ObjectHolderDelegate = ITEMS.registerSmeltableObject("ruby_axe", RUBY) { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt index 2386baa8..c2d938f8 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt @@ -20,6 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import mezz.jei.api.recipe.RecipeType @@ -35,4 +36,10 @@ object JEIRecipeTypes { ArmourAndToolsMod.MOD_ID, "custom_armour_crafting_table", CustomArmourCraftingTableRecipe::class.java) + + val ingotFusionTollEnhancer = + RecipeType.create( + ArmourAndToolsMod.MOD_ID, + "ingot_fusion_toll_enhancer", + IngotFusionTollEnhancerRecipe::class.java) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt index a0cf073c..b6bd114d 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt @@ -20,12 +20,14 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod.ArmorAndToolsMod.MOD_ID import io.github.realyusufismail.armourandtoolsmod.blocks.armour.CustomArmourCraftingTableMenu +import io.github.realyusufismail.armourandtoolsmod.blocks.fusion.IngotFusionTollEnhancerMenu import io.github.realyusufismail.armourandtoolsmod.blocks.tool.CustomToolCraftingTableMenu import net.minecraft.world.flag.FeatureFlagSet import net.minecraft.world.flag.FeatureFlags import net.minecraft.world.inventory.AbstractContainerMenu import net.minecraft.world.inventory.MenuType import net.minecraft.world.inventory.MenuType.MenuSupplier +import net.minecraftforge.common.extensions.IForgeMenuType import net.minecraftforge.registries.DeferredRegister import net.minecraftforge.registries.ForgeRegistries import thedarkcolour.kotlinforforge.forge.ObjectHolderDelegate @@ -43,6 +45,15 @@ object MenuTypeInit { ObjectHolderDelegate> = register("custom_tool_crafting_table", ::CustomToolCraftingTableMenu) + val INGOT_FUSION_TOLL_ENHANCER_MENU: + ObjectHolderDelegate> = + MENU.registerObject("ingot_fusion_toll_enhancer") { + IForgeMenuType.create { pContainerId, pInventory, pData -> + IngotFusionTollEnhancerMenu(pContainerId, pInventory, pData) + } + } + .setGuiTitle("container.ingot_fusion_toll_enhancer") + private fun register( name: String, pFactory: MenuSupplier, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt index 381a3b78..eec4846b 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt @@ -20,6 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod.ArmorAndToolsMod.MOD_ID import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableShapedRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableShapedRecipe import net.minecraft.world.item.crafting.Recipe import net.minecraft.world.item.crafting.RecipeSerializer @@ -40,6 +41,12 @@ object RecipeSerializerInit { ObjectHolderDelegate> = register("custom_tool_crafter", CustomToolCraftingTableShapedRecipe.Serializer()) + val INGOT_FUSION_TOLL_ENHANCER_RECIPE: + ObjectHolderDelegate> = + register( + "ingot_fusion_toll_enhancer_recipe", + IngotFusionTollEnhancerRecipe.Companion.Serializer()) + private fun , T : Recipe<*>> register( pKey: String, pRecipeSerializer: S, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt index 72c8bc14..bf01e0bc 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt @@ -20,6 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod.ArmorAndToolsMod.MOD_ID import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IIngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import net.minecraft.resources.ResourceLocation import net.minecraft.world.item.crafting.RecipeType @@ -42,4 +43,10 @@ object RecipeTypeInit { RECIPE_TYPES.registerObject("tool_crafting") { RecipeType.simple(ResourceLocation(MOD_ID, "tool_crafting")) } + + val INGOT_FUSION_TOLL_ENHANCER: + ObjectHolderDelegate> = + RECIPE_TYPES.registerObject("ingot_fusion_toll_enhancer") { + RecipeType.simple(ResourceLocation(MOD_ID, "ingot_fusion_toll_enhancer")) + } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/StatsInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/StatsInit.kt new file mode 100644 index 00000000..877c1f4d --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/StatsInit.kt @@ -0,0 +1,47 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.core.init + +import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod +import net.minecraft.core.registries.Registries +import net.minecraft.resources.ResourceLocation +import net.minecraft.stats.StatFormatter +import net.minecraft.stats.Stats +import net.minecraftforge.registries.DeferredRegister +import net.minecraftforge.registries.RegistryObject + +object StatsInit { + val STATS = + DeferredRegister.create(Registries.CUSTOM_STAT, ArmourAndToolsMod.MOD_ID) + private val STAT_SETUP: MutableList = mutableListOf() + + private fun makeCustomStat(key: String): RegistryObject { + val resourceLocation: ResourceLocation = ArmourAndToolsMod.getModIdAndName(key) + STAT_SETUP.add(Runnable { Stats.CUSTOM.get(resourceLocation, StatFormatter.DEFAULT) }) + return STATS.register(key) { resourceLocation } + } + + @JvmField + val INTERACT_WITH_FUSION_TOLL_ENHANCER: RegistryObject = + makeCustomStat("interact_with_fusion_toll_enhancer") + + fun init() { + STAT_SETUP.forEach(Runnable::run) + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/TagsInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/TagsInit.kt index f2e6ed62..70493c5c 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/TagsInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/TagsInit.kt @@ -227,6 +227,11 @@ object TagsInit { ResourceLocation.tryParse("forge:ingots/enderite") ?: throw Exception("Failed to create tag")) + val INGOTS_IMPERIUM: TagKey = + ItemTags.create( + ResourceLocation.tryParse("forge:ingots/imperium") + ?: throw Exception("Failed to create tag")) + // raw ore scraps val RAW_RUBY: TagKey = ItemTags.create( diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/material/CustomToolMaterial.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/material/CustomToolMaterial.kt index 492014df..75bfc07c 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/material/CustomToolMaterial.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/material/CustomToolMaterial.kt @@ -48,7 +48,10 @@ enum class CustomToolMaterial( SAPPHIRE_PICKAXE(5, 3000, 12, Supplier { Ingredient.of(ItemInit.SAPPHIRE.get()) }), SAPPHIRE_AXE(5, 3000, 12, Supplier { Ingredient.of(ItemInit.SAPPHIRE.get()) }), SAPPHIRE_SHOVEL(5, 3000, 12, Supplier { Ingredient.of(ItemInit.SAPPHIRE.get()) }), - SAPPHIRE_HOE(5, 3000, 12, Supplier { Ingredient.of(ItemInit.SAPPHIRE.get()) }); + SAPPHIRE_HOE(5, 3000, 12, Supplier { Ingredient.of(ItemInit.SAPPHIRE.get()) }), + IMPERIUM_SWORD(6, 4000, 20, Supplier { Ingredient.of(ItemInit.IMPERIUM.get()) }), + IMPERIUM_PICKAXE(6, 4000, 20, Supplier { Ingredient.of(ItemInit.IMPERIUM.get()) }), + MAGMA_STRIKE_PICKAXE(6, 8000, 20, Supplier { Ingredient.of(ItemInit.IMPERIUM.get()) }); private val harvestLevel = 0 private val maxUses = 0 diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/lang/ModEnLangProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/lang/ModEnLangProvider.kt index c1a4eecc..d0ffb9e2 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/lang/ModEnLangProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/lang/ModEnLangProvider.kt @@ -59,6 +59,7 @@ class ModEnLangProvider(gen: DataGenerator) : ModEnLangProviderSupport(gen, MOD_ // custom crafting tables addBlock(BlockInit.CUSTOM_ARMOUR_CRAFTING_TABLE, "Custom Armour Crafting Table") addBlock(BlockInit.CUSTOM_TOOL_CRAFTING_TABLE, "Custom Tool Crafting Table") + addBlock(BlockInit.INGOT_FUSION_TOLL_ENHANCER, "Ingot Fusion Toll Enhancer") // ore ingot addItem(ItemInit.RUBY, "Ruby") @@ -67,6 +68,7 @@ class ModEnLangProvider(gen: DataGenerator) : ModEnLangProviderSupport(gen, MOD_ addItem(ItemInit.RAINBOW, "Rainbow Ingot") addItem(ItemInit.AQUMARINE, "Aqumarine") addItem(ItemInit.ENDERITE, "Enderite") + addItem(ItemInit.IMPERIUM, "Imperium") // raw ores addItem(ItemInit.RAW_RUBY, "Raw Ruby") @@ -126,6 +128,9 @@ class ModEnLangProvider(gen: DataGenerator) : ModEnLangProviderSupport(gen, MOD_ addItem(ItemInit.SAPPHIRE_AXE, "Sapphire Axe") addItem(ItemInit.SAPPHIRE_SHOVEL, "Sapphire Shovel") addItem(ItemInit.SAPPHIRE_HOE, "Sapphire Hoe") + addItem(ItemInit.IMPERIUM_SWORD, "Imperium Sword") + addItem(ItemInit.IMPERIUM_PICKAXE, "Imperium Pickaxe") + addItem(ItemInit.MAGMA_STRIKE_PICKAXE, "Magma Strike Pickaxe") // Shields addItem(ItemInit.RUBY_SHIELD, "Ruby Shield") @@ -143,6 +148,8 @@ class ModEnLangProvider(gen: DataGenerator) : ModEnLangProviderSupport(gen, MOD_ add("container.custom_armour_crafting_table.description", "Craft your own custom armour!") add("container.custom_tool_crafting_table", "Tool Crafting Table") add("container.custom_tool_crafting_table.description", "Craft your own custom tools!") + add("container.ingot_fusion_toll_enhancer", "Ingot Fusion Toll Enhancer") + add("container.ingot_fusion_toll_enhancer.description", "Enhance your tools and armour!") // advancements addAdvancement( diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/loot/ModBlockLootTables.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/loot/ModBlockLootTables.kt index d886cc6d..8082d192 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/loot/ModBlockLootTables.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/loot/ModBlockLootTables.kt @@ -77,6 +77,7 @@ class ModBlockLootTables : BlockLootSubProvider(setOf(), FeatureFlags.REGISTRY.a dropSelf(BlockInit.ENDERITE_BLOCK.get()) dropSelf(BlockInit.CUSTOM_ARMOUR_CRAFTING_TABLE.get()) dropSelf(BlockInit.CUSTOM_TOOL_CRAFTING_TABLE.get()) + dropSelf(BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()) } override fun getKnownBlocks(): Iterable { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/MainModRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/MainModRecipeProvider.kt index a81d170a..fb01fe4e 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/MainModRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/MainModRecipeProvider.kt @@ -38,6 +38,7 @@ open class MainModRecipeProvider(private val generatorIn: DataGenerator) : NormalCraftingTableRecipeProvider(this, pWriter).build() ToolCraftingTableRecipeProvider(this, pWriter).build() NewSmithingTableRecipeProvider(this, pWriter).build() + IngotFusionTollEnhancerRecipeProvider(this, pWriter).build() } open fun modId(path: String): ResourceLocation { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt new file mode 100644 index 00000000..481d4427 --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -0,0 +1,160 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.datagen.recipe.builder + +import com.google.gson.JsonObject +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit +import java.util.* +import java.util.function.Consumer +import net.minecraft.advancements.Advancement +import net.minecraft.advancements.AdvancementRewards +import net.minecraft.advancements.RequirementsStrategy +import net.minecraft.advancements.critereon.InventoryChangeTrigger +import net.minecraft.advancements.critereon.RecipeUnlockedTrigger +import net.minecraft.data.recipes.FinishedRecipe +import net.minecraft.data.recipes.RecipeCategory +import net.minecraft.resources.ResourceLocation +import net.minecraft.tags.TagKey +import net.minecraft.world.item.Item +import net.minecraft.world.item.crafting.Ingredient +import net.minecraft.world.item.crafting.RecipeSerializer +import net.minecraftforge.registries.ForgeRegistries + +class IngotFusionTollEnhancerRecipeBuilder( + private val input1: Ingredient, + private val input2: Ingredient, + private val input3: Ingredient, + private val output: Item, + private var recipeCategory: RecipeCategory +) { + private val advancementBuilder = Advancement.Builder.advancement() + + fun unlockedBy( + criterionId: String, + criterion: InventoryChangeTrigger.TriggerInstance + ): IngotFusionTollEnhancerRecipeBuilder { + advancementBuilder.addCriterion(criterionId, criterion) + return this + } + + fun save(consumer: Consumer, rl: ResourceLocation) { + ensureValid(rl) + if (advancementBuilder.criteria.isNotEmpty()) + advancementBuilder + .parent(ResourceLocation("recipes/root")) + .addCriterion("has_the_recipe", RecipeUnlockedTrigger.unlocked(rl)) + .rewards(AdvancementRewards.Builder.recipe(rl)) + .requirements(RequirementsStrategy.OR) + consumer.accept( + Output( + input1, + input2, + input3, + output, + advancementBuilder, + ResourceLocation( + rl.namespace, ("recipes/" + recipeCategory.folderName) + "/" + rl.path), + rl)) + } + + private fun ensureValid(rl: ResourceLocation) { + check(advancementBuilder.criteria.isNotEmpty()) { "Can not obtain recipe: $rl" } + } + + @JvmRecord + private data class Output( + val input1: Ingredient, + val input2: Ingredient, + val input3: Ingredient, + val output: Item, + val advancementBuilder: Advancement.Builder, + val advancementId: ResourceLocation, + val id: ResourceLocation + ) : FinishedRecipe { + override fun serializeRecipeData(json: JsonObject) { + json.add("input1", input1.toJson()) + json.add("input2", input2.toJson()) + json.add("input3", input3.toJson()) + json.addProperty( + "result", + Objects.requireNonNull(ForgeRegistries.ITEMS.getKey(output), "Item is null") + .toString()) + } + + override fun getId(): ResourceLocation { + return id + } + + override fun getType(): RecipeSerializer<*> { + return RecipeSerializerInit.INGOT_FUSION_TOLL_ENHANCER_RECIPE.get() + } + + override fun serializeAdvancement(): JsonObject? { + return if (advancementBuilder.criteria.isEmpty()) advancementBuilder.serializeToJson() + else null + } + + override fun getAdvancementId(): ResourceLocation? { + return advancementId + } + } + + companion object { + fun builder( + input1: Item, + input2: Item, + input3: Item, + output: Item, + recipeCategory: RecipeCategory + ): IngotFusionTollEnhancerRecipeBuilder { + return IngotFusionTollEnhancerRecipeBuilder( + ingredient(input1), ingredient(input2), ingredient(input3), output, recipeCategory) + } + + fun builder( + input1: TagKey, + input2: TagKey, + input3: TagKey, + output: Item, + recipeCategory: RecipeCategory + ): IngotFusionTollEnhancerRecipeBuilder { + return IngotFusionTollEnhancerRecipeBuilder( + ingredient(input1), ingredient(input2), ingredient(input3), output, recipeCategory) + } + + fun builder( + input1: TagKey, + input2: Item, + input3: TagKey, + output: Item, + recipeCategory: RecipeCategory + ): IngotFusionTollEnhancerRecipeBuilder { + return IngotFusionTollEnhancerRecipeBuilder( + ingredient(input1), ingredient(input2), ingredient(input3), output, recipeCategory) + } + + private fun ingredient(entry: Item): Ingredient { + return Ingredient.of(entry) + } + + private fun ingredient(entry: TagKey): Ingredient { + return Ingredient.of(entry) + } + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt new file mode 100644 index 00000000..2ea501d6 --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt @@ -0,0 +1,44 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.datagen.recipe.provider + +import io.github.realyusufismail.armourandtoolsmod.core.init.ItemInit +import io.github.realyusufismail.armourandtoolsmod.core.init.TagsInit +import io.github.realyusufismail.armourandtoolsmod.datagen.recipe.MainModRecipeProvider +import io.github.realyusufismail.armourandtoolsmod.datagen.recipe.builder.IngotFusionTollEnhancerRecipeBuilder +import java.util.function.Consumer +import net.minecraft.data.recipes.FinishedRecipe +import net.minecraft.data.recipes.RecipeCategory + +class IngotFusionTollEnhancerRecipeProvider( + private val mainModRecipeProvider: MainModRecipeProvider, + private val pWriter: Consumer +) : MainModRecipeProvider(mainModRecipeProvider) { + + fun build() { + IngotFusionTollEnhancerRecipeBuilder.builder( + TagsInit.ItemTagsInit.INGOTS_IMPERIUM, + ItemInit.IMPERIUM_PICKAXE.get(), + TagsInit.ItemTagsInit.INGOTS_IMPERIUM, + ItemInit.MAGMA_STRIKE_PICKAXE.get(), + RecipeCategory.TOOLS) + .unlockedBy("has_imperium_ingot", has(ItemInit.IMPERIUM.get())) + .save(pWriter, modId("magma_strike_pickaxe")) + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt index a5a170d8..cd76ffcf 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt @@ -202,6 +202,31 @@ class ToolCraftingTableRecipeProvider( .unlockedBy(hasItem, has(Items.AMETHYST_SHARD)) .save(consumer, modId("amethyst_shovel")) + // Imperium Tools + CustomToolCraftingTableRecipeBuilder.shaped( + CustomToolsCraftingBookCategory.SWORD, + RecipeCategory.TOOLS, + ItemInit.IMPERIUM_SWORD.get()) + .define('A', TagsInit.ItemTagsInit.INGOTS_IMPERIUM) + .define('S', Items.STICK) + .pattern(" A ") + .pattern(" A ") + .pattern(" S ") + .unlockedBy(hasItem, has(TagsInit.ItemTagsInit.INGOTS_IMPERIUM)) + .save(consumer, modId("imperium_sword")) + + CustomToolCraftingTableRecipeBuilder.shaped( + CustomToolsCraftingBookCategory.PICKAXE, + RecipeCategory.TOOLS, + ItemInit.IMPERIUM_PICKAXE.get()) + .define('A', TagsInit.ItemTagsInit.INGOTS_IMPERIUM) + .define('S', Items.STICK) + .pattern("AAA") + .pattern(" S ") + .pattern(" S ") + .unlockedBy(hasItem, has(TagsInit.ItemTagsInit.INGOTS_IMPERIUM)) + .save(consumer, modId("imperium_pickaxe")) + // TRIEDENTs // TODO : For the trident later make it a drop from a custom mob rather than crafting diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModItemTagsProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModItemTagsProvider.kt index 465cb6d5..f7c54d93 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModItemTagsProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModItemTagsProvider.kt @@ -77,6 +77,7 @@ class ModItemTagsProvider( tag(TagsInit.ItemTagsInit.INGOTS_GRAPHITE).add(ItemInit.GRAPHITE.get()) tag(TagsInit.ItemTagsInit.INGOTS_AQUMARINE).add(ItemInit.AQUMARINE.get()) tag(TagsInit.ItemTagsInit.INGOTS_ENDERITE).add(ItemInit.ENDERITE.get()) + tag(TagsInit.ItemTagsInit.INGOTS_IMPERIUM).add(ItemInit.IMPERIUM.get()) // raw ores tag(TagsInit.ItemTagsInit.RAW_RUBY).add(ItemInit.RAW_RUBY.get()) tag(TagsInit.ItemTagsInit.RAW_RAINBOW).add(ItemInit.RAW_RAINBOW.get()) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModItemStateProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModItemStateProvider.kt index 8268e8fa..edb655d9 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModItemStateProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModItemStateProvider.kt @@ -43,6 +43,7 @@ class ModItemStateProvider(output: PackOutput, exFileHelper: ExistingFileHelper) item(ItemInit.AQUMARINE.get()) item(ItemInit.RAINBOW.get()) item(ItemInit.ENDERITE.get()) + item(ItemInit.IMPERIUM.get()) // raw ores item(ItemInit.RAW_RUBY.get()) @@ -113,6 +114,10 @@ class ModItemStateProvider(output: PackOutput, exFileHelper: ExistingFileHelper) tool(ItemInit.SAPPHIRE_SHOVEL.get()) tool(ItemInit.SAPPHIRE_HOE.get()) + tool(ItemInit.IMPERIUM_SWORD.get()) + tool(ItemInit.IMPERIUM_PICKAXE.get()) + tool(ItemInit.MAGMA_STRIKE_PICKAXE.get()) + // Trident trident(ItemInit.AQUMARINE_TRIDENT.get()) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt index 11d2126d..ae9862fe 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt @@ -23,8 +23,10 @@ import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit import io.github.realyusufismail.armourandtoolsmod.core.init.JEIRecipeTypes import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit import io.github.realyusufismail.armourandtoolsmod.integration.armour.CustomArmourCraftingTableJEIRecipeCategory +import io.github.realyusufismail.armourandtoolsmod.integration.fusion.IngotFusionTollEnhancerJEIRecipeCategory import io.github.realyusufismail.armourandtoolsmod.integration.tool.CustomToolCraftingTableJEIRecipeCategory import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IIngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import mezz.jei.api.IModPlugin import mezz.jei.api.JeiPlugin @@ -42,15 +44,19 @@ class ArmourAndToolsModJEIPlugin : IModPlugin { override fun registerCategories(registration: IRecipeCategoryRegistration) { registration.addRecipeCategories( CustomToolCraftingTableJEIRecipeCategory(registration.jeiHelpers.guiHelper), - CustomArmourCraftingTableJEIRecipeCategory(registration.jeiHelpers.guiHelper)) + CustomArmourCraftingTableJEIRecipeCategory(registration.jeiHelpers.guiHelper), + IngotFusionTollEnhancerJEIRecipeCategory(registration.jeiHelpers.guiHelper)) } override fun registerRecipes(registration: IRecipeRegistration) { val recipeManager = Minecraft.getInstance().level!!.recipeManager val recipesTool = recipeManager.getAllRecipesFor(RecipeTypeInit.TOOL_CRAFTING.get()) val recipesArmour = recipeManager.getAllRecipesFor(RecipeTypeInit.ARMOUR_CRAFTING.get()) + val recipesIngotFusionTollEnhancer = + recipeManager.getAllRecipesFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()) registration.addRecipes(toolCraftingTableRecipeType, recipesTool) registration.addRecipes(armourCraftingTableRecipeType, recipesArmour) + registration.addRecipes(ingotFusionTollEnhancerRecipeType, recipesIngotFusionTollEnhancer) } override fun registerRecipeCatalysts(registration: IRecipeCatalystRegistration) { @@ -58,6 +64,9 @@ class ArmourAndToolsModJEIPlugin : IModPlugin { ItemStack(BlockInit.CUSTOM_TOOL_CRAFTING_TABLE.get()), JEIRecipeTypes.toolCrafting) registration.addRecipeCatalyst( ItemStack(BlockInit.CUSTOM_ARMOUR_CRAFTING_TABLE.get()), JEIRecipeTypes.armourCrafting) + registration.addRecipeCatalyst( + ItemStack(BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()), + JEIRecipeTypes.ingotFusionTollEnhancer) } override fun getPluginUid(): ResourceLocation { @@ -73,5 +82,9 @@ class ArmourAndToolsModJEIPlugin : IModPlugin { RecipeType( CustomToolCraftingTableJEIRecipeCategory.UID, CustomToolCraftingTableRecipe::class.java) + val ingotFusionTollEnhancerRecipeType: RecipeType = + RecipeType( + IngotFusionTollEnhancerJEIRecipeCategory.UID, + IIngotFusionTollEnhancerRecipe::class.java) } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt new file mode 100644 index 00000000..fdb1943d --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt @@ -0,0 +1,120 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.integration.fusion + +import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod +import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer +import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit +import io.github.realyusufismail.armourandtoolsmod.integration.ArmourAndToolsModJEIPlugin +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IIngotFusionTollEnhancerRecipe +import mezz.jei.api.constants.VanillaTypes +import mezz.jei.api.gui.builder.IRecipeLayoutBuilder +import mezz.jei.api.gui.drawable.IDrawable +import mezz.jei.api.helpers.IGuiHelper +import mezz.jei.api.recipe.IFocusGroup +import mezz.jei.api.recipe.RecipeIngredientRole +import mezz.jei.api.recipe.RecipeType +import mezz.jei.api.recipe.category.IRecipeCategory +import net.minecraft.network.chat.Component +import net.minecraft.world.item.ItemStack + +class IngotFusionTollEnhancerJEIRecipeCategory(guiHelper: IGuiHelper) : + IRecipeCategory { + private val fusionJEIGuiLocation = + ArmourAndToolsMod.getModIdAndName( + "textures/gui/container/ingot_fusion_toll_enhancer_jei.png") + private val bg: IDrawable + private val ic: IDrawable + private val w = 175 + private val h = 87 + + init { + // X cordinate is the distance from the left side of the screen to the right side of the gui + // width + // Y cordinate is the distance from the top of the screen to the top of the gui height + bg = guiHelper.createDrawable(fusionJEIGuiLocation, 0, 0, w, h) + ic = + guiHelper.createDrawableIngredient( + VanillaTypes.ITEM_STACK, ItemStack(BlockInit.INGOT_FUSION_TOLL_ENHANCER.get())) + } + + /** + * @return the type of recipe that this category handles. + * @since 9.5.0 + */ + override fun getRecipeType(): RecipeType { + return ArmourAndToolsModJEIPlugin.ingotFusionTollEnhancerRecipeType + } + + /** + * Returns a text component representing the name of this recipe type. Drawn at the top of the + * recipe GUI pages for this category. + * + * @since 7.6.4 + */ + override fun getTitle(): Component { + return IngotFusionTollEnhancer.getContainerTitle() + } + + /** Returns the drawable background for a single recipe in this category. */ + override fun getBackground(): IDrawable { + return bg + } + + /** + * Icon for the category tab. You can use [IGuiHelper.createDrawableIngredient] to create a + * drawable from an ingredient. + * + * @return icon to draw on the category tab, max size is 16x16 pixels. + */ + override fun getIcon(): IDrawable { + return ic + } + + override fun getWidth(): Int { + return w + } + + override fun getHeight(): Int { + return h + } + + /** + * Sets all the recipe's ingredients by filling out an instance of [IRecipeLayoutBuilder]. This + * is used by JEI for lookups, to figure out what ingredients are inputs and outputs for a + * recipe. + * + * @since 9.4.0 + */ + override fun setRecipe( + builder: IRecipeLayoutBuilder, + recipe: IIngotFusionTollEnhancerRecipe, + focuses: IFocusGroup + ) { + builder.addSlot(RecipeIngredientRole.INPUT, 16, 40).addIngredients(recipe.ingredients[0]) + builder.addSlot(RecipeIngredientRole.INPUT, 43, 40).addIngredients(recipe.ingredients[1]) + builder.addSlot(RecipeIngredientRole.INPUT, 70, 40).addIngredients(recipe.ingredients[2]) + + builder.addSlot(RecipeIngredientRole.OUTPUT, 138, 40).addItemStack(recipe.result) + } + + companion object { + val UID = ArmourAndToolsMod.getModIdAndName("ingot_fusion_toll_enhancer_jei") + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt index 7dd53f16..6a04d46a 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt @@ -70,7 +70,7 @@ class CustomToolCraftingTableJEIRecipeCategory(private val guiHelper: IGuiHelper focuses: IFocusGroup ) { builder.addSlot(RecipeIngredientRole.INPUT, 30, 16).addIngredients(recipe.ingredients[0]) - builder.addSlot(RecipeIngredientRole.INPUT, 45, 16).addIngredients(recipe.ingredients[1]) + builder.addSlot(RecipeIngredientRole.INPUT, 47, 16).addIngredients(recipe.ingredients[1]) builder.addSlot(RecipeIngredientRole.INPUT, 65, 16).addIngredients(recipe.ingredients[2]) builder.addSlot(RecipeIngredientRole.INPUT, 30, 34).addIngredients(recipe.ingredients[3]) builder.addSlot(RecipeIngredientRole.INPUT, 48, 34).addIngredients(recipe.ingredients[4]) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IIngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IIngotFusionTollEnhancerRecipe.kt new file mode 100644 index 00000000..a1c252ae --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IIngotFusionTollEnhancerRecipe.kt @@ -0,0 +1,37 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.recipe.fusion + +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit +import net.minecraft.core.NonNullList +import net.minecraft.world.Container +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.RecipeType + +interface IIngotFusionTollEnhancerRecipe : Recipe { + override fun getType(): RecipeType<*> { + return RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get() + } + + override fun getIngredients(): NonNullList + + val result: ItemStack +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt new file mode 100644 index 00000000..f0711c77 --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -0,0 +1,127 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.recipe.fusion + +import com.google.gson.JsonObject +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit +import net.minecraft.core.NonNullList +import net.minecraft.core.RegistryAccess +import net.minecraft.network.FriendlyByteBuf +import net.minecraft.resources.ResourceLocation +import net.minecraft.world.Container +import net.minecraft.world.item.ItemStack +import net.minecraft.world.item.crafting.Ingredient +import net.minecraft.world.item.crafting.RecipeSerializer +import net.minecraft.world.item.crafting.ShapedRecipe +import net.minecraft.world.level.Level +import net.minecraftforge.registries.ForgeRegistries + +class IngotFusionTollEnhancerRecipe( + private val input1: Ingredient, + private val input2: Ingredient, + private val input3: Ingredient, + override val result: ItemStack, + private val recipeId: ResourceLocation +) : IIngotFusionTollEnhancerRecipe { + + /** Used to check if a recipe matches current crafting inventory */ + override fun matches(pContainer: Container, pLevel: Level): Boolean { + return input1.test(pContainer.getItem(0)) && + input2.test(pContainer.getItem(1)) && + input3.test(pContainer.getItem(2)) + } + + override fun assemble(pContainer: Container, pRegistryAccess: RegistryAccess): ItemStack { + return result.copy() + } + + /** Used to determine if this recipe can fit in a grid of the given width/height */ + override fun canCraftInDimensions(pWidth: Int, pHeight: Int): Boolean { + return true + } + + override fun getResultItem(pRegistryAccess: RegistryAccess): ItemStack { + return result + } + + override fun getId(): ResourceLocation { + return recipeId + } + + override fun getSerializer(): RecipeSerializer<*> { + return RecipeSerializerInit.INGOT_FUSION_TOLL_ENHANCER_RECIPE.registryObject.orElseThrow { + IllegalStateException("No serializer for recipe type INGOT_FUSION_TOLL_ENHANCER_RECIPE") + } + } + + override fun getIngredients(): NonNullList { + val ingredients = NonNullList.create() + ingredients.add(input1) + ingredients.add(input2) + ingredients.add(input3) + return ingredients + } + + companion object { + + class Serializer : RecipeSerializer { + override fun fromJson( + pRecipeId: ResourceLocation, + json: JsonObject + ): IngotFusionTollEnhancerRecipe { + val input1 = Ingredient.fromJson(json.get("input1")) + val input2 = Ingredient.fromJson(json.get("input2")) + val input3 = Ingredient.fromJson(json.get("input3")) + + val result: ItemStack = + if (json["result"].isJsonObject) + ItemStack(ShapedRecipe.itemFromJson(json["result"].getAsJsonObject())) + else + ItemStack( + ForgeRegistries.ITEMS.getValue( + ResourceLocation(json["result"].asString)) + ?: throw IllegalStateException( + "Item: " + json["result"].asString + " does not exist")) + + return IngotFusionTollEnhancerRecipe(input1, input2, input3, result, pRecipeId) + } + + override fun fromNetwork( + pRecipeId: ResourceLocation, + pBuffer: FriendlyByteBuf + ): IngotFusionTollEnhancerRecipe { + val input1 = Ingredient.fromNetwork(pBuffer) + val input2 = Ingredient.fromNetwork(pBuffer) + val input3 = Ingredient.fromNetwork(pBuffer) + val result = pBuffer.readItem() + return IngotFusionTollEnhancerRecipe(input1, input2, input3, result, pRecipeId) + } + + override fun toNetwork( + pBuffer: FriendlyByteBuf, + pRecipe: IngotFusionTollEnhancerRecipe + ) { + pRecipe.input1.toNetwork(pBuffer) + pRecipe.input2.toNetwork(pBuffer) + pRecipe.input3.toNetwork(pBuffer) + pBuffer.writeItem(pRecipe.result) + } + } + } +} diff --git a/src/main/resources/assets/armourandtoolsmod/textures/gui/container/ingot_fusion_toll_enhancer.png b/src/main/resources/assets/armourandtoolsmod/textures/gui/container/ingot_fusion_toll_enhancer.png new file mode 100644 index 0000000000000000000000000000000000000000..b1576d1f441c9349c5024fea8badc1c275f428af GIT binary patch literal 1128 zcmeAS@N?(olHy`uVBq!ia0y~yU<5K58911MRQ8&P5D>38$lZxy-8q?;Kn_c~qpu?a z!^VE@KZ&eBzFdG$h%1o(|NsB7W5+^6L#HV-ba!{}GUw08$S^lI2THYuzbFGzTqQw% z!9ZmYz_96z&Uv6HXMsm#F#`kNeh_A~U=3DbU|`Eakt5%>1?!?IZpBCd%%3pL;W zKP39>z=BD7YBK}%)8E@)cSzcK-zcqh+g*#YLaEo+d+)0Hc|Le-e|COAka*_*)5mod z#Fo#Vu9eAlL41FGtv%<9=DU}|SbZ6O-D1dPw6njw$Lt9|P=J-~$7U{`pM|$pE!e>z z-Pr32WE^04eeb#@&u3+02F^3T^_enPH#sq%VY(F$Vl^=>ncDvHZvIVs&LwNPxcCe> zUtHY!x^qjY;~u68ehwakx9|T1E49sS%;0S1O6 z%qyfA7+UK2Bi7sJhTM>3n8td^t#vMwgY=SKE^Bs&C`F*CC&M#YkSJ?Hlu~X;gh#`c zPqE(^#LFA>l^fR2p7vLn`On{VPs8T_`se#$SA9mq&wbzg%CCRZJ+NiJ@qs=24IOUn z=WE#az3Aue0QRDGzq{M3pOrJ*+Aq}b@5$DhZ|Te5MgQkYzP+Ad+TX(rZ#e#NCFlYz z)n<@mJ;kut{NWvKcFPLsRdWr30= z!;72DEDQ{18NSHN6*s57JL(?A{9=CU+Sq$pov1jirR9?&Y<#O8FPkHWO9aRhr7fQpq!E6w*;BM=6t4k6K?%urva{UpY-}W&6 z5@SdA2jQ QXA1I%r>mdKI;Vst0I=Y$wg3PC literal 0 HcmV?d00001 diff --git a/src/main/resources/assets/armourandtoolsmod/textures/gui/container/ingot_fusion_toll_enhancer_jei.png b/src/main/resources/assets/armourandtoolsmod/textures/gui/container/ingot_fusion_toll_enhancer_jei.png new file mode 100644 index 0000000000000000000000000000000000000000..68d692ff15cd45c0cb183bb88af6ebd5194258ea GIT binary patch literal 1130 zcmeAS@N?(olHy`uVBq!ia0y~yU<5K58911MRQ8&P5D>38$lZzY=1HA;AcwQSBeIx* zf$sQKaGF!K_WLw>O&@M{P0kzWx2~qD_1M|Bqgj=+Nk> zt043KvxWQ9*%v?G{jP9G(Q}elrOM#|N$q~OM%&pp?tbonyOKx!K-&I7_nW)78}%^! z&;I@QwnW1Hebc}ekltaz*md8cS1v)Ps^Oyp z%uNX4fX z7Lh*~-m)^Wb(HXDgqzgwVVK)}k*P$Njr+o032ldiNh=s!yC*V<2qipc@!-B!@ZxpI zO{ShU1|}B%3x6eo{zPobX3m+;z{H`@fRETv%`9V6QjwJO>BN(Z$;bV9lnD^R?>d+1ppk-)Em} z@1M_R_b-0M)oWSNag$Z%Uw^g9f9?G2-3$H&+K0wR|F)S^+jpg1<>#l;rQhEE-hTDF zt^O^e Date: Sun, 1 Oct 2023 20:05:16 +0100 Subject: [PATCH 02/51] Recipe is being reported as null --- .../fusion/IngotFusionTollEnhancerMenu.kt | 2 +- .../core/init/RecipeTypeInit.kt | 4 +- .../integration/ArmourAndToolsModJEIPlugin.kt | 6 +-- ...ngotFusionTollEnhancerJEIRecipeCategory.kt | 8 ++-- .../fusion/IIngotFusionTollEnhancerRecipe.kt | 37 ------------------- .../fusion/IngotFusionTollEnhancerRecipe.kt | 13 ++++--- 6 files changed, 18 insertions(+), 52 deletions(-) delete mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IIngotFusionTollEnhancerRecipe.kt diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt index 11c56adf..bdcea4f1 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt @@ -52,7 +52,7 @@ class IngotFusionTollEnhancerMenu( SimpleContainerData(2)) init { - + // TODO : Recipe does not work try { checkContainerSize(inventory, NUMBER_OF_SLOTS) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt index bf01e0bc..4112d6bf 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt @@ -20,7 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod.ArmorAndToolsMod.MOD_ID import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IIngotFusionTollEnhancerRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import net.minecraft.resources.ResourceLocation import net.minecraft.world.item.crafting.RecipeType @@ -45,7 +45,7 @@ object RecipeTypeInit { } val INGOT_FUSION_TOLL_ENHANCER: - ObjectHolderDelegate> = + ObjectHolderDelegate> = RECIPE_TYPES.registerObject("ingot_fusion_toll_enhancer") { RecipeType.simple(ResourceLocation(MOD_ID, "ingot_fusion_toll_enhancer")) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt index ae9862fe..48581879 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt @@ -26,7 +26,7 @@ import io.github.realyusufismail.armourandtoolsmod.integration.armour.CustomArmo import io.github.realyusufismail.armourandtoolsmod.integration.fusion.IngotFusionTollEnhancerJEIRecipeCategory import io.github.realyusufismail.armourandtoolsmod.integration.tool.CustomToolCraftingTableJEIRecipeCategory import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IIngotFusionTollEnhancerRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import mezz.jei.api.IModPlugin import mezz.jei.api.JeiPlugin @@ -82,9 +82,9 @@ class ArmourAndToolsModJEIPlugin : IModPlugin { RecipeType( CustomToolCraftingTableJEIRecipeCategory.UID, CustomToolCraftingTableRecipe::class.java) - val ingotFusionTollEnhancerRecipeType: RecipeType = + val ingotFusionTollEnhancerRecipeType: RecipeType = RecipeType( IngotFusionTollEnhancerJEIRecipeCategory.UID, - IIngotFusionTollEnhancerRecipe::class.java) + IngotFusionTollEnhancerRecipe::class.java) } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt index fdb1943d..456f5627 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt @@ -22,7 +22,7 @@ import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit import io.github.realyusufismail.armourandtoolsmod.integration.ArmourAndToolsModJEIPlugin -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IIngotFusionTollEnhancerRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import mezz.jei.api.constants.VanillaTypes import mezz.jei.api.gui.builder.IRecipeLayoutBuilder import mezz.jei.api.gui.drawable.IDrawable @@ -35,7 +35,7 @@ import net.minecraft.network.chat.Component import net.minecraft.world.item.ItemStack class IngotFusionTollEnhancerJEIRecipeCategory(guiHelper: IGuiHelper) : - IRecipeCategory { + IRecipeCategory { private val fusionJEIGuiLocation = ArmourAndToolsMod.getModIdAndName( "textures/gui/container/ingot_fusion_toll_enhancer_jei.png") @@ -58,7 +58,7 @@ class IngotFusionTollEnhancerJEIRecipeCategory(guiHelper: IGuiHelper) : * @return the type of recipe that this category handles. * @since 9.5.0 */ - override fun getRecipeType(): RecipeType { + override fun getRecipeType(): RecipeType { return ArmourAndToolsModJEIPlugin.ingotFusionTollEnhancerRecipeType } @@ -104,7 +104,7 @@ class IngotFusionTollEnhancerJEIRecipeCategory(guiHelper: IGuiHelper) : */ override fun setRecipe( builder: IRecipeLayoutBuilder, - recipe: IIngotFusionTollEnhancerRecipe, + recipe: IngotFusionTollEnhancerRecipe, focuses: IFocusGroup ) { builder.addSlot(RecipeIngredientRole.INPUT, 16, 40).addIngredients(recipe.ingredients[0]) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IIngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IIngotFusionTollEnhancerRecipe.kt deleted file mode 100644 index a1c252ae..00000000 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IIngotFusionTollEnhancerRecipe.kt +++ /dev/null @@ -1,37 +0,0 @@ -/* - * Copyright 2023 RealYusufIsmail. - * - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * - * you may not use this file except in compliance with the License. - * - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package io.github.realyusufismail.armourandtoolsmod.recipe.fusion - -import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit -import net.minecraft.core.NonNullList -import net.minecraft.world.Container -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.RecipeType - -interface IIngotFusionTollEnhancerRecipe : Recipe { - override fun getType(): RecipeType<*> { - return RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get() - } - - override fun getIngredients(): NonNullList - - val result: ItemStack -} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index f0711c77..1122ca22 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -20,15 +20,14 @@ package io.github.realyusufismail.armourandtoolsmod.recipe.fusion import com.google.gson.JsonObject import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit import net.minecraft.core.NonNullList import net.minecraft.core.RegistryAccess import net.minecraft.network.FriendlyByteBuf import net.minecraft.resources.ResourceLocation import net.minecraft.world.Container import net.minecraft.world.item.ItemStack -import net.minecraft.world.item.crafting.Ingredient -import net.minecraft.world.item.crafting.RecipeSerializer -import net.minecraft.world.item.crafting.ShapedRecipe +import net.minecraft.world.item.crafting.* import net.minecraft.world.level.Level import net.minecraftforge.registries.ForgeRegistries @@ -36,9 +35,9 @@ class IngotFusionTollEnhancerRecipe( private val input1: Ingredient, private val input2: Ingredient, private val input3: Ingredient, - override val result: ItemStack, + val result: ItemStack, private val recipeId: ResourceLocation -) : IIngotFusionTollEnhancerRecipe { +) : Recipe { /** Used to check if a recipe matches current crafting inventory */ override fun matches(pContainer: Container, pLevel: Level): Boolean { @@ -78,6 +77,10 @@ class IngotFusionTollEnhancerRecipe( return ingredients } + override fun getType(): RecipeType<*> { + return RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get() + } + companion object { class Serializer : RecipeSerializer { From e9cc04cb550453c239ec50a11f971882b14e203c Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Sun, 1 Oct 2023 21:54:16 +0100 Subject: [PATCH 03/51] try a different root --- .../IngotFusionTollEnhancerBlockEntity.kt | 29 ++++++++------ .../core/init/RecipeTypeInit.kt | 7 ---- .../IngotFusionTollEnhancerRecipeBuilder.kt | 38 ++++++++++--------- .../integration/ArmourAndToolsModJEIPlugin.kt | 2 +- .../fusion/IngotFusionTollEnhancerRecipe.kt | 13 ++++++- 5 files changed, 51 insertions(+), 38 deletions(-) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt index 129045d5..7eda3b15 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt @@ -18,14 +18,15 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.fusion +import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit -import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import net.minecraft.core.BlockPos import net.minecraft.core.NonNullList import net.minecraft.network.FriendlyByteBuf import net.minecraft.network.chat.Component +import net.minecraft.world.SimpleContainer import net.minecraft.world.entity.player.Inventory import net.minecraft.world.inventory.AbstractContainerMenu import net.minecraft.world.inventory.ContainerData @@ -201,16 +202,22 @@ open class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: Block } private fun getRecipe(): IngotFusionTollEnhancerRecipe? { - return if (items[0].isEmpty || items[1].isEmpty || items[2].isEmpty) { - null - } else { - level!! - .recipeManager - .getRecipeFor( - RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), - this, - this.level ?: throw NullPointerException("Level is null")) - .orElse(null) as IngotFusionTollEnhancerRecipe? + val inventory = SimpleContainer(this.items.size) + for (i in items.indices) { + inventory.setItem(i, items[i]) } + + level.let { level -> + if (level != null) { + + ArmourAndToolsMod.logger.info("Level is not null") + + return level.recipeManager + .getRecipeFor(IngotFusionTollEnhancerRecipe.Type.INSTANCE, inventory, level) + .orElseThrow { IllegalStateException("No recipe found") } + } + } + + return null } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt index 4112d6bf..72c8bc14 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt @@ -20,7 +20,6 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod.ArmorAndToolsMod.MOD_ID import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import net.minecraft.resources.ResourceLocation import net.minecraft.world.item.crafting.RecipeType @@ -43,10 +42,4 @@ object RecipeTypeInit { RECIPE_TYPES.registerObject("tool_crafting") { RecipeType.simple(ResourceLocation(MOD_ID, "tool_crafting")) } - - val INGOT_FUSION_TOLL_ENHANCER: - ObjectHolderDelegate> = - RECIPE_TYPES.registerObject("ingot_fusion_toll_enhancer") { - RecipeType.simple(ResourceLocation(MOD_ID, "ingot_fusion_toll_enhancer")) - } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index 481d4427..d11ab03f 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -54,23 +54,27 @@ class IngotFusionTollEnhancerRecipeBuilder( } fun save(consumer: Consumer, rl: ResourceLocation) { - ensureValid(rl) - if (advancementBuilder.criteria.isNotEmpty()) - advancementBuilder - .parent(ResourceLocation("recipes/root")) - .addCriterion("has_the_recipe", RecipeUnlockedTrigger.unlocked(rl)) - .rewards(AdvancementRewards.Builder.recipe(rl)) - .requirements(RequirementsStrategy.OR) - consumer.accept( - Output( - input1, - input2, - input3, - output, - advancementBuilder, - ResourceLocation( - rl.namespace, ("recipes/" + recipeCategory.folderName) + "/" + rl.path), - rl)) + try { + ensureValid(rl) + if (advancementBuilder.criteria.isNotEmpty()) + advancementBuilder + .parent(ResourceLocation("recipes/root")) + .addCriterion("has_the_recipe", RecipeUnlockedTrigger.unlocked(rl)) + .rewards(AdvancementRewards.Builder.recipe(rl)) + .requirements(RequirementsStrategy.OR) + consumer.accept( + Output( + input1, + input2, + input3, + output, + advancementBuilder, + ResourceLocation( + rl.namespace, ("recipes/" + recipeCategory.folderName) + "/" + rl.path), + rl)) + } catch (e: IllegalStateException) { + throw IllegalStateException("Could not create recipe: $rl", e) + } } private fun ensureValid(rl: ResourceLocation) { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt index 48581879..416a67bc 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt @@ -53,7 +53,7 @@ class ArmourAndToolsModJEIPlugin : IModPlugin { val recipesTool = recipeManager.getAllRecipesFor(RecipeTypeInit.TOOL_CRAFTING.get()) val recipesArmour = recipeManager.getAllRecipesFor(RecipeTypeInit.ARMOUR_CRAFTING.get()) val recipesIngotFusionTollEnhancer = - recipeManager.getAllRecipesFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()) + recipeManager.getAllRecipesFor(IngotFusionTollEnhancerRecipe.Type.INSTANCE) registration.addRecipes(toolCraftingTableRecipeType, recipesTool) registration.addRecipes(armourCraftingTableRecipeType, recipesArmour) registration.addRecipes(ingotFusionTollEnhancerRecipeType, recipesIngotFusionTollEnhancer) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 1122ca22..7a50beb0 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -20,7 +20,6 @@ package io.github.realyusufismail.armourandtoolsmod.recipe.fusion import com.google.gson.JsonObject import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit -import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit import net.minecraft.core.NonNullList import net.minecraft.core.RegistryAccess import net.minecraft.network.FriendlyByteBuf @@ -78,7 +77,17 @@ class IngotFusionTollEnhancerRecipe( } override fun getType(): RecipeType<*> { - return RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get() + return Type.INSTANCE + } + + class Type : RecipeType { + override fun toString(): String { + return "ingot_fusion_toll_enhancer" + } + + companion object { + val INSTANCE = Type() + } } companion object { From cae45b362c69121363ce8fb7144c929badc16f17 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Sun, 1 Oct 2023 22:07:04 +0100 Subject: [PATCH 04/51] issue with recipe catgorry --- .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 4 +-- .../recipes/magma_strike_pickaxe.json | 1 + .../IngotFusionTollEnhancerRecipeBuilder.kt | 14 ++++++++ .../fusion/IngotFusionTollEnhancerRecipe.kt | 35 +++++++++++-------- 4 files changed, 38 insertions(+), 16 deletions(-) diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index d0acb9c0..6482fd8d 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-01T16:50:26.142413 Recipes +// 1.20.1 2023-10-01T22:02:49.9004328 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -279,7 +279,7 @@ adf63b0d9c8b2e333a5e4769a2fc0183f483544e data/armourandtoolsmod/recipes/graphite b790592cbe2e046b1e8169e2fb4a8da1483a8dfb data/armourandtoolsmod/recipes/graphite_shield.json aa31085980f2c7c3e8bad8a4dccb79315eac0102 data/armourandtoolsmod/recipes/imperium_pickaxe.json 9d9c3b5485306909e7c17e86c42d4afe8125c648 data/armourandtoolsmod/recipes/imperium_sword.json -eafd7e41a6ffe2b38a3296d6bcf2cf014115ed78 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +7b0ce47337781a0773d43249fbe9e34c73277427 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json 0399917d7fdda6f9af410c709805dfb149b2451c data/armourandtoolsmod/recipes/rainbow_block_recipe.json 5caa6184a7c066fac3bbc8e3869ae712171fe202 data/armourandtoolsmod/recipes/rainbow_boots.json cc01dc105a026c1a42db2e4a7bea9ca208ef22e2 data/armourandtoolsmod/recipes/rainbow_chestplate.json diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json index 295c7f0e..ee04c1da 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json @@ -1,5 +1,6 @@ { "type": "armourandtoolsmod:ingot_fusion_toll_enhancer_recipe", + "category": "tools", "input1": { "tag": "forge:ingots/imperium" }, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index d11ab03f..d61b2019 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -68,6 +68,7 @@ class IngotFusionTollEnhancerRecipeBuilder( input2, input3, output, + recipeCategory, advancementBuilder, ResourceLocation( rl.namespace, ("recipes/" + recipeCategory.folderName) + "/" + rl.path), @@ -81,12 +82,24 @@ class IngotFusionTollEnhancerRecipeBuilder( check(advancementBuilder.criteria.isNotEmpty()) { "Can not obtain recipe: $rl" } } + /** + * Protip: The error has a string, seaching for that string will give more context + * + * @param input1 The first input item + * @param input2 The second input item + * @param input3 The third input item + * @param output The output item + * @param category The recipe category + * @param advancementId The advancement id + * @param id The recipe id + */ @JvmRecord private data class Output( val input1: Ingredient, val input2: Ingredient, val input3: Ingredient, val output: Item, + val category: RecipeCategory, val advancementBuilder: Advancement.Builder, val advancementId: ResourceLocation, val id: ResourceLocation @@ -95,6 +108,7 @@ class IngotFusionTollEnhancerRecipeBuilder( json.add("input1", input1.toJson()) json.add("input2", input2.toJson()) json.add("input3", input3.toJson()) + json.addProperty("category", this.category.folderName) json.addProperty( "result", Objects.requireNonNull(ForgeRegistries.ITEMS.getKey(output), "Item is null") diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 7a50beb0..6ff4cad3 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -97,21 +97,28 @@ class IngotFusionTollEnhancerRecipe( pRecipeId: ResourceLocation, json: JsonObject ): IngotFusionTollEnhancerRecipe { - val input1 = Ingredient.fromJson(json.get("input1")) - val input2 = Ingredient.fromJson(json.get("input2")) - val input3 = Ingredient.fromJson(json.get("input3")) - - val result: ItemStack = - if (json["result"].isJsonObject) - ItemStack(ShapedRecipe.itemFromJson(json["result"].getAsJsonObject())) - else - ItemStack( - ForgeRegistries.ITEMS.getValue( - ResourceLocation(json["result"].asString)) - ?: throw IllegalStateException( - "Item: " + json["result"].asString + " does not exist")) - return IngotFusionTollEnhancerRecipe(input1, input2, input3, result, pRecipeId) + try { + val input1 = Ingredient.fromJson(json.get("input1")) + val input2 = Ingredient.fromJson(json.get("input2")) + val input3 = Ingredient.fromJson(json.get("input3")) + + //TODO: Error caused by lack of recipe book category + + val result: ItemStack = + if (json["result"].isJsonObject) + ItemStack(ShapedRecipe.itemFromJson(json["result"].getAsJsonObject())) + else + ItemStack( + ForgeRegistries.ITEMS.getValue( + ResourceLocation(json["result"].asString)) + ?: throw IllegalStateException( + "Item: " + json["result"].asString + " does not exist")) + + return IngotFusionTollEnhancerRecipe(input1, input2, input3, result, pRecipeId) + } catch (e: IllegalStateException) { + throw IllegalStateException("Could not create recipe: $pRecipeId", e) + } } override fun fromNetwork( From 82bbe812b16a35085d9086dc764c987b8b608471 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Mon, 2 Oct 2023 08:03:16 +0100 Subject: [PATCH 05/51] still trying to figure out the issue --- .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 4 +-- .../recipes/magma_strike_pickaxe.json | 1 - .../IngotFusionTollEnhancerRecipeBuilder.kt | 27 +++++++---------- .../IngotFusionTollEnhancerRecipeProvider.kt | 4 +-- .../fusion/IngotFusionTollEnhancerRecipe.kt | 30 ++++++++----------- 5 files changed, 26 insertions(+), 40 deletions(-) diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index 6482fd8d..1c853463 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-01T22:02:49.9004328 Recipes +// 1.20.1 2023-10-02T07:39:13.7264117 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -279,7 +279,7 @@ adf63b0d9c8b2e333a5e4769a2fc0183f483544e data/armourandtoolsmod/recipes/graphite b790592cbe2e046b1e8169e2fb4a8da1483a8dfb data/armourandtoolsmod/recipes/graphite_shield.json aa31085980f2c7c3e8bad8a4dccb79315eac0102 data/armourandtoolsmod/recipes/imperium_pickaxe.json 9d9c3b5485306909e7c17e86c42d4afe8125c648 data/armourandtoolsmod/recipes/imperium_sword.json -7b0ce47337781a0773d43249fbe9e34c73277427 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +eafd7e41a6ffe2b38a3296d6bcf2cf014115ed78 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json 0399917d7fdda6f9af410c709805dfb149b2451c data/armourandtoolsmod/recipes/rainbow_block_recipe.json 5caa6184a7c066fac3bbc8e3869ae712171fe202 data/armourandtoolsmod/recipes/rainbow_boots.json cc01dc105a026c1a42db2e4a7bea9ca208ef22e2 data/armourandtoolsmod/recipes/rainbow_chestplate.json diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json index ee04c1da..295c7f0e 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json @@ -1,6 +1,5 @@ { "type": "armourandtoolsmod:ingot_fusion_toll_enhancer_recipe", - "category": "tools", "input1": { "tag": "forge:ingots/imperium" }, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index d61b2019..39906200 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -28,7 +28,6 @@ import net.minecraft.advancements.RequirementsStrategy import net.minecraft.advancements.critereon.InventoryChangeTrigger import net.minecraft.advancements.critereon.RecipeUnlockedTrigger import net.minecraft.data.recipes.FinishedRecipe -import net.minecraft.data.recipes.RecipeCategory import net.minecraft.resources.ResourceLocation import net.minecraft.tags.TagKey import net.minecraft.world.item.Item @@ -40,8 +39,7 @@ class IngotFusionTollEnhancerRecipeBuilder( private val input1: Ingredient, private val input2: Ingredient, private val input3: Ingredient, - private val output: Item, - private var recipeCategory: RecipeCategory + private val output: Item ) { private val advancementBuilder = Advancement.Builder.advancement() @@ -68,10 +66,10 @@ class IngotFusionTollEnhancerRecipeBuilder( input2, input3, output, - recipeCategory, advancementBuilder, - ResourceLocation( - rl.namespace, ("recipes/" + recipeCategory.folderName) + "/" + rl.path), + ResourceLocation(rl.namespace, "recipes/root").also { advancementId -> + advancementBuilder.parent(advancementId) + }, rl)) } catch (e: IllegalStateException) { throw IllegalStateException("Could not create recipe: $rl", e) @@ -99,7 +97,6 @@ class IngotFusionTollEnhancerRecipeBuilder( val input2: Ingredient, val input3: Ingredient, val output: Item, - val category: RecipeCategory, val advancementBuilder: Advancement.Builder, val advancementId: ResourceLocation, val id: ResourceLocation @@ -108,7 +105,6 @@ class IngotFusionTollEnhancerRecipeBuilder( json.add("input1", input1.toJson()) json.add("input2", input2.toJson()) json.add("input3", input3.toJson()) - json.addProperty("category", this.category.folderName) json.addProperty( "result", Objects.requireNonNull(ForgeRegistries.ITEMS.getKey(output), "Item is null") @@ -138,33 +134,30 @@ class IngotFusionTollEnhancerRecipeBuilder( input1: Item, input2: Item, input3: Item, - output: Item, - recipeCategory: RecipeCategory + output: Item ): IngotFusionTollEnhancerRecipeBuilder { return IngotFusionTollEnhancerRecipeBuilder( - ingredient(input1), ingredient(input2), ingredient(input3), output, recipeCategory) + ingredient(input1), ingredient(input2), ingredient(input3), output) } fun builder( input1: TagKey, input2: TagKey, input3: TagKey, - output: Item, - recipeCategory: RecipeCategory + output: Item ): IngotFusionTollEnhancerRecipeBuilder { return IngotFusionTollEnhancerRecipeBuilder( - ingredient(input1), ingredient(input2), ingredient(input3), output, recipeCategory) + ingredient(input1), ingredient(input2), ingredient(input3), output) } fun builder( input1: TagKey, input2: Item, input3: TagKey, - output: Item, - recipeCategory: RecipeCategory + output: Item ): IngotFusionTollEnhancerRecipeBuilder { return IngotFusionTollEnhancerRecipeBuilder( - ingredient(input1), ingredient(input2), ingredient(input3), output, recipeCategory) + ingredient(input1), ingredient(input2), ingredient(input3), output) } private fun ingredient(entry: Item): Ingredient { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt index 2ea501d6..5d5ae726 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt @@ -24,7 +24,6 @@ import io.github.realyusufismail.armourandtoolsmod.datagen.recipe.MainModRecipeP import io.github.realyusufismail.armourandtoolsmod.datagen.recipe.builder.IngotFusionTollEnhancerRecipeBuilder import java.util.function.Consumer import net.minecraft.data.recipes.FinishedRecipe -import net.minecraft.data.recipes.RecipeCategory class IngotFusionTollEnhancerRecipeProvider( private val mainModRecipeProvider: MainModRecipeProvider, @@ -36,8 +35,7 @@ class IngotFusionTollEnhancerRecipeProvider( TagsInit.ItemTagsInit.INGOTS_IMPERIUM, ItemInit.IMPERIUM_PICKAXE.get(), TagsInit.ItemTagsInit.INGOTS_IMPERIUM, - ItemInit.MAGMA_STRIKE_PICKAXE.get(), - RecipeCategory.TOOLS) + ItemInit.MAGMA_STRIKE_PICKAXE.get()) .unlockedBy("has_imperium_ingot", has(ItemInit.IMPERIUM.get())) .save(pWriter, modId("magma_strike_pickaxe")) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 6ff4cad3..f6b31d27 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -24,11 +24,11 @@ import net.minecraft.core.NonNullList import net.minecraft.core.RegistryAccess import net.minecraft.network.FriendlyByteBuf import net.minecraft.resources.ResourceLocation +import net.minecraft.util.GsonHelper import net.minecraft.world.Container import net.minecraft.world.item.ItemStack import net.minecraft.world.item.crafting.* import net.minecraft.world.level.Level -import net.minecraftforge.registries.ForgeRegistries class IngotFusionTollEnhancerRecipe( private val input1: Ingredient, @@ -40,13 +40,16 @@ class IngotFusionTollEnhancerRecipe( /** Used to check if a recipe matches current crafting inventory */ override fun matches(pContainer: Container, pLevel: Level): Boolean { - return input1.test(pContainer.getItem(0)) && - input2.test(pContainer.getItem(1)) && - input3.test(pContainer.getItem(2)) + return if (pLevel.isClientSide) false + else if (pContainer.containerSize < 3) false + else + input1.test(pContainer.getItem(0)) && + input2.test(pContainer.getItem(1)) && + input3.test(pContainer.getItem(2)) } override fun assemble(pContainer: Container, pRegistryAccess: RegistryAccess): ItemStack { - return result.copy() + return result } /** Used to determine if this recipe can fit in a grid of the given width/height */ @@ -55,7 +58,7 @@ class IngotFusionTollEnhancerRecipe( } override fun getResultItem(pRegistryAccess: RegistryAccess): ItemStack { - return result + return result.copy() } override fun getId(): ResourceLocation { @@ -103,17 +106,10 @@ class IngotFusionTollEnhancerRecipe( val input2 = Ingredient.fromJson(json.get("input2")) val input3 = Ingredient.fromJson(json.get("input3")) - //TODO: Error caused by lack of recipe book category - - val result: ItemStack = - if (json["result"].isJsonObject) - ItemStack(ShapedRecipe.itemFromJson(json["result"].getAsJsonObject())) - else - ItemStack( - ForgeRegistries.ITEMS.getValue( - ResourceLocation(json["result"].asString)) - ?: throw IllegalStateException( - "Item: " + json["result"].asString + " does not exist")) + // TODO: Error caused by lack of recipe book category + + val result = + ShapedRecipe.itemStackFromJson(GsonHelper.getAsJsonObject(json, "result")) return IngotFusionTollEnhancerRecipe(input1, input2, input3, result, pRecipeId) } catch (e: IllegalStateException) { From 2d35d88cb4bbc3c9c9d37f66632114841b8d9bbe Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Mon, 2 Oct 2023 14:01:57 +0100 Subject: [PATCH 06/51] still get unkown recipe book error --- .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 4 +- .../recipes/magma_strike_pickaxe.json | 24 ++++---- .../IngotFusionTollEnhancerRecipeBuilder.kt | 56 ++++++++----------- .../IngotFusionTollEnhancerRecipeProvider.kt | 5 +- .../fusion/IngotFusionTollEnhancerRecipe.kt | 49 ++++++++++++---- 5 files changed, 79 insertions(+), 59 deletions(-) diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index 1c853463..b812b426 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-02T07:39:13.7264117 Recipes +// 1.20.1 2023-10-02T13:53:11.6216435 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -279,7 +279,7 @@ adf63b0d9c8b2e333a5e4769a2fc0183f483544e data/armourandtoolsmod/recipes/graphite b790592cbe2e046b1e8169e2fb4a8da1483a8dfb data/armourandtoolsmod/recipes/graphite_shield.json aa31085980f2c7c3e8bad8a4dccb79315eac0102 data/armourandtoolsmod/recipes/imperium_pickaxe.json 9d9c3b5485306909e7c17e86c42d4afe8125c648 data/armourandtoolsmod/recipes/imperium_sword.json -eafd7e41a6ffe2b38a3296d6bcf2cf014115ed78 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +7d9a1910c5a2d17607081bae58c3f8c25be6ac8d data/armourandtoolsmod/recipes/magma_strike_pickaxe.json 0399917d7fdda6f9af410c709805dfb149b2451c data/armourandtoolsmod/recipes/rainbow_block_recipe.json 5caa6184a7c066fac3bbc8e3869ae712171fe202 data/armourandtoolsmod/recipes/rainbow_boots.json cc01dc105a026c1a42db2e4a7bea9ca208ef22e2 data/armourandtoolsmod/recipes/rainbow_chestplate.json diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json index 295c7f0e..6c49652b 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json @@ -1,13 +1,17 @@ { "type": "armourandtoolsmod:ingot_fusion_toll_enhancer_recipe", - "input1": { - "tag": "forge:ingots/imperium" - }, - "input2": { - "item": "armourandtoolsmod:imperium_pickaxe" - }, - "input3": { - "tag": "forge:ingots/imperium" - }, - "result": "armourandtoolsmod:magma_strike_pickaxe" + "ingredients": [ + { + "item": "armourandtoolsmod:imperium" + }, + { + "item": "armourandtoolsmod:imperium_pickaxe" + }, + { + "item": "armourandtoolsmod:imperium" + } + ], + "result": { + "item": "armourandtoolsmod:magma_strike_pickaxe" + } } \ No newline at end of file diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index 39906200..5cbe90ed 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -18,6 +18,7 @@ */ package io.github.realyusufismail.armourandtoolsmod.datagen.recipe.builder +import com.google.gson.JsonArray import com.google.gson.JsonObject import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit import java.util.* @@ -29,7 +30,6 @@ import net.minecraft.advancements.critereon.InventoryChangeTrigger import net.minecraft.advancements.critereon.RecipeUnlockedTrigger import net.minecraft.data.recipes.FinishedRecipe import net.minecraft.resources.ResourceLocation -import net.minecraft.tags.TagKey import net.minecraft.world.item.Item import net.minecraft.world.item.crafting.Ingredient import net.minecraft.world.item.crafting.RecipeSerializer @@ -102,13 +102,29 @@ class IngotFusionTollEnhancerRecipeBuilder( val id: ResourceLocation ) : FinishedRecipe { override fun serializeRecipeData(json: JsonObject) { - json.add("input1", input1.toJson()) - json.add("input2", input2.toJson()) - json.add("input3", input3.toJson()) - json.addProperty( - "result", - Objects.requireNonNull(ForgeRegistries.ITEMS.getKey(output), "Item is null") - .toString()) + // in json arry have input one it as an arrya of items up to three + // "ingredients": [ + // { + // "item": "armourandtoolsmod:imperium" + // }, + // { + // "item": "armourandtoolsmod:imperium_pickaxe" + // }, + + val jsonArray = JsonArray() + val ingredients = arrayOf(input1, input2, input3) + + for (ingredient in ingredients) { + jsonArray.add(ingredient.toJson()) + } + + json.add("ingredients", jsonArray) + + val jsonObject = JsonObject() + jsonObject.addProperty("item", ForgeRegistries.ITEMS.getKey(output).toString()) + json.add("result", jsonObject) + + println(json.toString()) } override fun getId(): ResourceLocation { @@ -140,32 +156,8 @@ class IngotFusionTollEnhancerRecipeBuilder( ingredient(input1), ingredient(input2), ingredient(input3), output) } - fun builder( - input1: TagKey, - input2: TagKey, - input3: TagKey, - output: Item - ): IngotFusionTollEnhancerRecipeBuilder { - return IngotFusionTollEnhancerRecipeBuilder( - ingredient(input1), ingredient(input2), ingredient(input3), output) - } - - fun builder( - input1: TagKey, - input2: Item, - input3: TagKey, - output: Item - ): IngotFusionTollEnhancerRecipeBuilder { - return IngotFusionTollEnhancerRecipeBuilder( - ingredient(input1), ingredient(input2), ingredient(input3), output) - } - private fun ingredient(entry: Item): Ingredient { return Ingredient.of(entry) } - - private fun ingredient(entry: TagKey): Ingredient { - return Ingredient.of(entry) - } } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt index 5d5ae726..eb41c558 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt @@ -19,7 +19,6 @@ package io.github.realyusufismail.armourandtoolsmod.datagen.recipe.provider import io.github.realyusufismail.armourandtoolsmod.core.init.ItemInit -import io.github.realyusufismail.armourandtoolsmod.core.init.TagsInit import io.github.realyusufismail.armourandtoolsmod.datagen.recipe.MainModRecipeProvider import io.github.realyusufismail.armourandtoolsmod.datagen.recipe.builder.IngotFusionTollEnhancerRecipeBuilder import java.util.function.Consumer @@ -32,9 +31,9 @@ class IngotFusionTollEnhancerRecipeProvider( fun build() { IngotFusionTollEnhancerRecipeBuilder.builder( - TagsInit.ItemTagsInit.INGOTS_IMPERIUM, + ItemInit.IMPERIUM.get(), ItemInit.IMPERIUM_PICKAXE.get(), - TagsInit.ItemTagsInit.INGOTS_IMPERIUM, + ItemInit.IMPERIUM.get(), ItemInit.MAGMA_STRIKE_PICKAXE.get()) .unlockedBy("has_imperium_ingot", has(ItemInit.IMPERIUM.get())) .save(pWriter, modId("magma_strike_pickaxe")) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index f6b31d27..549cbf15 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -102,11 +102,28 @@ class IngotFusionTollEnhancerRecipe( ): IngotFusionTollEnhancerRecipe { try { - val input1 = Ingredient.fromJson(json.get("input1")) - val input2 = Ingredient.fromJson(json.get("input2")) - val input3 = Ingredient.fromJson(json.get("input3")) + // there is an array called Ingredients, and it contains 3 objects, each object + // is an ingredient + // "ingredients": [ + // { + // "item": "armourandtoolsmod:imperium" + // }, + // { + // "item": "armourandtoolsmod:imperium_pickaxe" + // }, + // { + // "item": "armourandtoolsmod:imperium" + // } + // ], + val ingredientArray = json.get("ingredients").asJsonArray + val input1 = Ingredient.fromJson(ingredientArray[0]) + val input2 = Ingredient.fromJson(ingredientArray[1]) + val input3 = Ingredient.fromJson(ingredientArray[2]) // TODO: Error caused by lack of recipe book category + // [13:57:18] [Render thread/WARN] [minecraft/ClientRecipeBook]: Unknown recipe + // category: + // [!!!com.mojang.logging.LogUtils$1ToString@6987a0f3=>java.lang.NullPointerException:Cannot invoke "Object.toString()" because the return value of "java.util.function.Supplier.get()" is null!!!]/armourandtoolsmod:magma_strike_pickaxe val result = ShapedRecipe.itemStackFromJson(GsonHelper.getAsJsonObject(json, "result")) @@ -121,21 +138,29 @@ class IngotFusionTollEnhancerRecipe( pRecipeId: ResourceLocation, pBuffer: FriendlyByteBuf ): IngotFusionTollEnhancerRecipe { - val input1 = Ingredient.fromNetwork(pBuffer) - val input2 = Ingredient.fromNetwork(pBuffer) - val input3 = Ingredient.fromNetwork(pBuffer) - val result = pBuffer.readItem() - return IngotFusionTollEnhancerRecipe(input1, input2, input3, result, pRecipeId) + try { + val input1 = Ingredient.fromNetwork(pBuffer) + val input2 = Ingredient.fromNetwork(pBuffer) + val input3 = Ingredient.fromNetwork(pBuffer) + val result = pBuffer.readItem() + return IngotFusionTollEnhancerRecipe(input1, input2, input3, result, pRecipeId) + } catch (e: IllegalStateException) { + throw IllegalStateException("Could not read recipe: $pRecipeId", e) + } } override fun toNetwork( pBuffer: FriendlyByteBuf, pRecipe: IngotFusionTollEnhancerRecipe ) { - pRecipe.input1.toNetwork(pBuffer) - pRecipe.input2.toNetwork(pBuffer) - pRecipe.input3.toNetwork(pBuffer) - pBuffer.writeItem(pRecipe.result) + try { + pRecipe.input1.toNetwork(pBuffer) + pRecipe.input2.toNetwork(pBuffer) + pRecipe.input3.toNetwork(pBuffer) + pBuffer.writeItem(pRecipe.result) + } catch (e: IllegalStateException) { + throw IllegalStateException("Could not write recipe: ${pRecipe.id}", e) + } } } } From fdff0dd890f7445d8921731c58e5b82f1dd22402 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Mon, 2 Oct 2023 19:46:52 +0100 Subject: [PATCH 07/51] still no idea --- .../fusion/IngotFusionTollEnhancerMenu.kt | 2 + .../core/init/RecipeTypeInit.kt | 6 ++ .../IngotFusionTollEnhancerRecipeBuilder.kt | 2 +- .../fusion/IngotFusionTollEnhancerRecipe.kt | 57 +++++++++++++++---- 4 files changed, 54 insertions(+), 13 deletions(-) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt index bdcea4f1..dd6120a4 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt @@ -18,6 +18,7 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.fusion +import io.github.realyusufismail.armourandtoolsmod.blocks.armour.CustomArmourCraftingTableContainer import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit import net.minecraft.network.FriendlyByteBuf @@ -25,6 +26,7 @@ import net.minecraft.world.entity.player.Inventory import net.minecraft.world.entity.player.Player import net.minecraft.world.inventory.* import net.minecraft.world.item.ItemStack +import net.minecraft.world.item.crafting.Recipe import net.minecraft.world.level.Level import net.minecraft.world.level.block.entity.BlockEntity import net.minecraftforge.common.capabilities.ForgeCapabilities diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt index 72c8bc14..f10f4053 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt @@ -20,6 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod.ArmorAndToolsMod.MOD_ID import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import net.minecraft.resources.ResourceLocation import net.minecraft.world.item.crafting.RecipeType @@ -42,4 +43,9 @@ object RecipeTypeInit { RECIPE_TYPES.registerObject("tool_crafting") { RecipeType.simple(ResourceLocation(MOD_ID, "tool_crafting")) } + + val INGOT_FUSION_TOLL_ENHANCER_RECIPE: ObjectHolderDelegate> = + RECIPE_TYPES.registerObject("ingot_fusion_toll_enhancer_recipe") { + RecipeType.simple(ResourceLocation(MOD_ID, "ingot_fusion_toll_enhancer_recipe")) + } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index 5cbe90ed..e16b118a 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -140,7 +140,7 @@ class IngotFusionTollEnhancerRecipeBuilder( else null } - override fun getAdvancementId(): ResourceLocation? { + override fun getAdvancementId(): ResourceLocation { return advancementId } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 549cbf15..7d8a049f 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -40,12 +40,16 @@ class IngotFusionTollEnhancerRecipe( /** Used to check if a recipe matches current crafting inventory */ override fun matches(pContainer: Container, pLevel: Level): Boolean { - return if (pLevel.isClientSide) false - else if (pContainer.containerSize < 3) false - else - input1.test(pContainer.getItem(0)) && - input2.test(pContainer.getItem(1)) && - input3.test(pContainer.getItem(2)) + try { + return if (pLevel.isClientSide) false + else if (pContainer.containerSize < 3) false + else + input1.test(pContainer.getItem(0)) && + input2.test(pContainer.getItem(1)) && + input3.test(pContainer.getItem(2)) + } catch (e: Exception) { + throw IllegalStateException("Error while checking recipe: $recipeId", e) + } } override fun assemble(pContainer: Container, pRegistryAccess: RegistryAccess): ItemStack { @@ -139,9 +143,37 @@ class IngotFusionTollEnhancerRecipe( pBuffer: FriendlyByteBuf ): IngotFusionTollEnhancerRecipe { try { - val input1 = Ingredient.fromNetwork(pBuffer) - val input2 = Ingredient.fromNetwork(pBuffer) - val input3 = Ingredient.fromNetwork(pBuffer) + + var input1: Ingredient? = null + var input2: Ingredient? = null + var input3: Ingredient? = null + + for (i in 0..3) { + val ingredient = Ingredient.fromNetwork(pBuffer) + + if (ingredient.isEmpty) { + throw IllegalStateException( + "No ingredients for ingot fusion toll enhancer recipe") + } + + when (i) { + 0 -> { + input1 = ingredient + } + 1 -> { + input2 = ingredient + } + 2 -> { + input3 = ingredient + } + } + } + + if (input1 == null || input2 == null || input3 == null) { + throw IllegalStateException( + "No ingredients for ingot fusion toll enhancer recipe") + } + val result = pBuffer.readItem() return IngotFusionTollEnhancerRecipe(input1, input2, input3, result, pRecipeId) } catch (e: IllegalStateException) { @@ -154,9 +186,10 @@ class IngotFusionTollEnhancerRecipe( pRecipe: IngotFusionTollEnhancerRecipe ) { try { - pRecipe.input1.toNetwork(pBuffer) - pRecipe.input2.toNetwork(pBuffer) - pRecipe.input3.toNetwork(pBuffer) + for (ingredient in pRecipe.getIngredients()) { + ingredient.toNetwork(pBuffer) + } + pBuffer.writeItem(pRecipe.result) } catch (e: IllegalStateException) { throw IllegalStateException("Could not write recipe: ${pRecipe.id}", e) From 6e8070531aa808411e33bc9ac1e5b02c1bf735cd Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Mon, 2 Oct 2023 21:32:05 +0100 Subject: [PATCH 08/51] make seprate pr for fix --- .../blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt | 7 +------ .../blocks/fusion/IngotFusionTollEnhancerMenu.kt | 1 - .../armourandtoolsmod/core/init/RecipeTypeInit.kt | 5 ----- 3 files changed, 1 insertion(+), 12 deletions(-) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt index 7eda3b15..6d988fc9 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt @@ -113,7 +113,7 @@ open class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: Block worldPosition, level!! .getBlockState(worldPosition) - .setValue( + .setValue( IngotFusionTollEnhancer.LIT, java.lang.Boolean.FALSE), 3) currentTick = 0 @@ -167,11 +167,6 @@ open class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: Block } else false } - fun encodeExtraData(buffer: FriendlyByteBuf) { - buffer.writeByte(items.size) - buffer.writeByte(data.count) - } - override fun setItems(p_199721_1_: NonNullList) { itemStack = p_199721_1_ } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt index dd6120a4..2f9dcbe3 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt @@ -54,7 +54,6 @@ class IngotFusionTollEnhancerMenu( SimpleContainerData(2)) init { - // TODO : Recipe does not work try { checkContainerSize(inventory, NUMBER_OF_SLOTS) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt index f10f4053..f4fea6d9 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt @@ -43,9 +43,4 @@ object RecipeTypeInit { RECIPE_TYPES.registerObject("tool_crafting") { RecipeType.simple(ResourceLocation(MOD_ID, "tool_crafting")) } - - val INGOT_FUSION_TOLL_ENHANCER_RECIPE: ObjectHolderDelegate> = - RECIPE_TYPES.registerObject("ingot_fusion_toll_enhancer_recipe") { - RecipeType.simple(ResourceLocation(MOD_ID, "ingot_fusion_toll_enhancer_recipe")) - } } From bf3280fae2d434d849c5f63fc06c30caba148559 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Mon, 2 Oct 2023 22:25:50 +0100 Subject: [PATCH 09/51] started work on rework --- .../IngotFusionTollEnhancerBlockEntity.kt | 4 +- .../fusion/IngotFusionTollEnhancerMenu.kt | 2 - .../blocks/rework/ReworkedBlockEntity.kt | 275 ++++++++++++++++++ .../core/init/RecipeTypeInit.kt | 6 + .../fusion/IngotFusionTollEnhancerRecipe.kt | 7 +- 5 files changed, 286 insertions(+), 8 deletions(-) create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/rework/ReworkedBlockEntity.kt diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt index 6d988fc9..96ec50de 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt @@ -24,7 +24,6 @@ import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import net.minecraft.core.BlockPos import net.minecraft.core.NonNullList -import net.minecraft.network.FriendlyByteBuf import net.minecraft.network.chat.Component import net.minecraft.world.SimpleContainer import net.minecraft.world.entity.player.Inventory @@ -113,8 +112,7 @@ open class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: Block worldPosition, level!! .getBlockState(worldPosition) - .setValue( - IngotFusionTollEnhancer.LIT, java.lang.Boolean.FALSE), + .setValue(IngotFusionTollEnhancer.LIT, java.lang.Boolean.FALSE), 3) currentTick = 0 setChanged() diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt index 2f9dcbe3..cb1d8ce1 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt @@ -18,7 +18,6 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.fusion -import io.github.realyusufismail.armourandtoolsmod.blocks.armour.CustomArmourCraftingTableContainer import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit import net.minecraft.network.FriendlyByteBuf @@ -26,7 +25,6 @@ import net.minecraft.world.entity.player.Inventory import net.minecraft.world.entity.player.Player import net.minecraft.world.inventory.* import net.minecraft.world.item.ItemStack -import net.minecraft.world.item.crafting.Recipe import net.minecraft.world.level.Level import net.minecraft.world.level.block.entity.BlockEntity import net.minecraftforge.common.capabilities.ForgeCapabilities diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/rework/ReworkedBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/rework/ReworkedBlockEntity.kt new file mode 100644 index 00000000..8be9848a --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/rework/ReworkedBlockEntity.kt @@ -0,0 +1,275 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.blocks.rework + +import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer +import io.github.realyusufismail.armourandtoolsmod.blocks.fusion.IngotFusionTollEnhancerMenu +import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe +import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap +import kotlin.properties.Delegates +import net.minecraft.core.BlockPos +import net.minecraft.core.Direction +import net.minecraft.core.NonNullList +import net.minecraft.nbt.CompoundTag +import net.minecraft.network.chat.Component +import net.minecraft.resources.ResourceLocation +import net.minecraft.world.Container +import net.minecraft.world.ContainerHelper +import net.minecraft.world.WorldlyContainer +import net.minecraft.world.entity.player.Inventory +import net.minecraft.world.entity.player.Player +import net.minecraft.world.entity.player.StackedContents +import net.minecraft.world.inventory.AbstractContainerMenu +import net.minecraft.world.inventory.ContainerData +import net.minecraft.world.inventory.RecipeHolder +import net.minecraft.world.inventory.StackedContentsCompatible +import net.minecraft.world.item.Item +import net.minecraft.world.item.ItemStack +import net.minecraft.world.item.Items +import net.minecraft.world.item.crafting.Recipe +import net.minecraft.world.item.crafting.RecipeManager +import net.minecraft.world.level.Level +import net.minecraft.world.level.block.entity.BaseContainerBlockEntity +import net.minecraft.world.level.block.state.BlockState + +class ReworkedBlockEntity(pPos: BlockPos, pBlockState: BlockState) : + BaseContainerBlockEntity( + BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), pPos, pBlockState), + WorldlyContainer, + RecipeHolder, + StackedContentsCompatible { + private val SLOT_OUTPUT = 4 + private var items = NonNullList.withSize(3, ItemStack.EMPTY) + // TODO: Check these and fix them + private var quickCheck: + RecipeManager.CachedCheck? = + null + private val recipesUsed = Object2IntOpenHashMap() + private val SLOTS_FOR_UP = intArrayOf(0) + private val SLOTS_FOR_DOWN = intArrayOf(2, 1) + private val SLOTS_FOR_SIDES = intArrayOf(1) + var litTime by Delegates.notNull() + var litDuration by Delegates.notNull() + var creatingTime by Delegates.notNull() + var creatingTotalTime by Delegates.notNull() + + private val dataAccess: ContainerData = + object : ContainerData { + override fun get(pIndex: Int): Int { + return when (pIndex) { + 0 -> litTime + 1 -> litDuration + 2 -> creatingTime + 3 -> creatingTotalTime + else -> + throw ArrayIndexOutOfBoundsException("ContainerData index out of bounds") + } + } + + override fun set(pIndex: Int, pValue: Int) { + when (pIndex) { + 0 -> litTime = pValue + 1 -> litDuration = pValue + 2 -> creatingTime = pValue + 3 -> creatingTotalTime = pValue + else -> + throw ArrayIndexOutOfBoundsException("ContainerData index out of bounds") + } + } + + override fun getCount(): Int { + return 4 + } + } + + // TODO: Implement this in the future + val fuel: Map = mutableMapOf() + + private fun isLit(): Boolean { + return litTime > 0 + } + + override fun load(pTag: CompoundTag) { + super.load(pTag) + items = NonNullList.withSize(this.containerSize, ItemStack.EMPTY) + ContainerHelper.loadAllItems(pTag, items) + this.litTime = pTag.getInt("LitTime") + this.creatingTime = pTag.getInt("CreatingTime") + this.creatingTotalTime = pTag.getInt("CreatingTotalTime") + + val compoundtag = pTag.getCompound("RecipesUsed") + + for (s in compoundtag.allKeys) { + recipesUsed.put(ResourceLocation(s), compoundtag.getInt(s)) + } + } + + override fun saveAdditional(pTag: CompoundTag) { + super.saveAdditional(pTag) + pTag.putInt("BurnTime", litTime) + pTag.putInt("CreatingTime", this.creatingTime) + pTag.putInt("CreatingTotalTime", this.creatingTotalTime) + ContainerHelper.saveAllItems(pTag, items) + val compoundtag = CompoundTag() + recipesUsed.forEach { (p_187449_: ResourceLocation, p_187450_: Int?) -> + compoundtag.putInt(p_187449_.toString(), p_187450_!!) + } + pTag.put("RecipesUsed", compoundtag) + } + + companion object { + fun serverTick( + level: Level, + pPos: BlockPos, + pState: BlockState, + pEntity: ReworkedBlockEntity + ) { + TODO() + } + + private fun getTotalCraftTime(pLevel: Level, pBlockEntity: ReworkedBlockEntity): Int { + return pBlockEntity.quickCheck!! + .getRecipeFor(pBlockEntity, pLevel) + .map { it::craftTime.get() } + .orElse(200) + } + } + + /** Returns the number of slots in the inventory. */ + override fun getContainerSize(): Int { + return items.size + } + + override fun clearContent() { + items.clear() + } + + override fun isEmpty(): Boolean { + for (itemstack in items) { + if (!itemstack.isEmpty) { + return false + } + } + + return true + } + + /** Returns the stack in the given slot. */ + override fun getItem(pSlot: Int): ItemStack { + return items[pSlot] + } + + /** + * Removes up to a specified number of items from an inventory slot and returns them in a new + * stack. + */ + override fun removeItem(pSlot: Int, pAmount: Int): ItemStack { + return ContainerHelper.removeItem(items, pSlot, pAmount) + } + + /** Removes a stack from the given slot and returns it. */ + override fun removeItemNoUpdate(pSlot: Int): ItemStack { + return ContainerHelper.takeItem(items, pSlot) + } + + /** + * Sets the given item stack to the specified slot in the inventory (can be crafting or armor + * sections). + */ + override fun setItem(pSlot: Int, pStack: ItemStack) { + val itemstack = items[pSlot] + val flag = !pStack.isEmpty && ItemStack.isSameItemSameTags(itemstack, pStack) + items[pSlot] = pStack + if (pStack.count > this.maxStackSize) { + pStack.count = this.maxStackSize + } + + if (pSlot == 0 && !flag) { + this.creatingTotalTime = getTotalCraftTime(level!!, this) + this.creatingTime = this.creatingTotalTime + this.setChanged() + } + } + + /** Don't rename this method to canInteractWith due to conflicts with Container */ + override fun stillValid(pPlayer: Player): Boolean { + return Container.stillValidBlockEntity(this, pPlayer) + } + + override fun getSlotsForFace(pSide: Direction): IntArray { + return if (pSide == Direction.DOWN) { + SLOTS_FOR_DOWN + } else { + if (pSide == Direction.UP) SLOTS_FOR_UP else SLOTS_FOR_SIDES + } + } + + /** + * Returns `true` if automation can insert the given item in the given slot from the given side. + */ + override fun canPlaceItemThroughFace( + pIndex: Int, + pItemStack: ItemStack, + pDirection: Direction? + ): Boolean { + return this.canPlaceItem(pIndex, pItemStack) + } + + /** + * Returns `true` if automation can extract the given item in the given slot from the given + * side. + */ + override fun canTakeItemThroughFace( + pIndex: Int, + pStack: ItemStack, + pDirection: Direction + ): Boolean { + return if (pDirection == Direction.DOWN && pIndex == 1) { + pStack.`is`(Items.WATER_BUCKET) || pStack.`is`(Items.BUCKET) + } else { + true + } + } + + override fun createMenu(pContainerId: Int, pInventory: Inventory): AbstractContainerMenu { + return IngotFusionTollEnhancerMenu(pContainerId, pInventory, this, dataAccess) + } + + override fun getDefaultName(): Component { + return IngotFusionTollEnhancer.getContainerTitle() + } + + override fun setRecipeUsed(pRecipe: Recipe<*>?) { + if (pRecipe != null) { + val resourcelocation = pRecipe.id + this.recipesUsed.addTo(resourcelocation, 1) + } + } + + override fun getRecipeUsed(): Recipe<*>? { + return null + } + + override fun fillStackedContents(pContents: StackedContents) { + for (itemstack in items) { + pContents.accountStack(itemstack) + } + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt index f4fea6d9..4112d6bf 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt @@ -43,4 +43,10 @@ object RecipeTypeInit { RECIPE_TYPES.registerObject("tool_crafting") { RecipeType.simple(ResourceLocation(MOD_ID, "tool_crafting")) } + + val INGOT_FUSION_TOLL_ENHANCER: + ObjectHolderDelegate> = + RECIPE_TYPES.registerObject("ingot_fusion_toll_enhancer") { + RecipeType.simple(ResourceLocation(MOD_ID, "ingot_fusion_toll_enhancer")) + } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 7d8a049f..158bce07 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -35,7 +35,8 @@ class IngotFusionTollEnhancerRecipe( private val input2: Ingredient, private val input3: Ingredient, val result: ItemStack, - private val recipeId: ResourceLocation + private val recipeId: ResourceLocation, + val craftTime: Int = 200 ) : Recipe { /** Used to check if a recipe matches current crafting inventory */ @@ -45,8 +46,8 @@ class IngotFusionTollEnhancerRecipe( else if (pContainer.containerSize < 3) false else input1.test(pContainer.getItem(0)) && - input2.test(pContainer.getItem(1)) && - input3.test(pContainer.getItem(2)) + input2.test(pContainer.getItem(1)) && + input3.test(pContainer.getItem(2)) } catch (e: Exception) { throw IllegalStateException("Error while checking recipe: $recipeId", e) } From 6a06fb0d884d03f6e84f86fa735c8c08cd5b670b Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Tue, 3 Oct 2023 11:11:14 +0100 Subject: [PATCH 10/51] begining rework --- .../IngotFusionTollEnhancerBlockEntity.kt | 216 ------------------ .../fusion/IngotFusionTollEnhancerMenu.kt | 129 ----------- .../blocks/fusion/OutputSlotItemHandler.kt | 30 --- .../IngotFusionTollEnhancerBlockEntity.kt} | 11 +- .../infusion/IngotFusionTollEnhancerMenu.kt | 86 +++++++ .../core/init/MenuTypeInit.kt | 2 +- .../container/ingot_fusion_toll_enhancer.png | Bin 1128 -> 2795 bytes .../ingot_fusion_toll_enhancer_jei.png | Bin 1130 -> 1740 bytes 8 files changed, 92 insertions(+), 382 deletions(-) delete mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt delete mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt delete mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/OutputSlotItemHandler.kt rename src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/{rework/ReworkedBlockEntity.kt => infusion/IngotFusionTollEnhancerBlockEntity.kt} (95%) create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt deleted file mode 100644 index 96ec50de..00000000 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerBlockEntity.kt +++ /dev/null @@ -1,216 +0,0 @@ -/* - * Copyright 2023 RealYusufIsmail. - * - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * - * you may not use this file except in compliance with the License. - * - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package io.github.realyusufismail.armourandtoolsmod.blocks.fusion - -import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod -import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer -import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe -import net.minecraft.core.BlockPos -import net.minecraft.core.NonNullList -import net.minecraft.network.chat.Component -import net.minecraft.world.SimpleContainer -import net.minecraft.world.entity.player.Inventory -import net.minecraft.world.inventory.AbstractContainerMenu -import net.minecraft.world.inventory.ContainerData -import net.minecraft.world.item.ItemStack -import net.minecraft.world.level.Level -import net.minecraft.world.level.block.entity.BlockEntityTicker -import net.minecraft.world.level.block.entity.FurnaceBlockEntity -import net.minecraft.world.level.block.entity.RandomizableContainerBlockEntity -import net.minecraft.world.level.block.state.BlockState - -const val NUMBER_OF_SLOTS = 4 - -/** @see FurnaceBlockEntity */ -open class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState) : - RandomizableContainerBlockEntity( - BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), pPos, pBlockState), - BlockEntityTicker { - private val maxTick = 200 - private var currentTick: Int = 0 - private var itemStack: NonNullList = - NonNullList.withSize(NUMBER_OF_SLOTS, ItemStack.EMPTY) - - val data: ContainerData = - object : ContainerData { - override fun get(pIndex: Int): Int { - return when (pIndex) { - 0 -> currentTick - 1 -> maxTick - else -> - throw ArrayIndexOutOfBoundsException("ContainerData index out of bounds") - } - } - - override fun set(pIndex: Int, pValue: Int) { - throw UnsupportedOperationException("ContainerData cannot be changed") - } - - override fun getCount(): Int { - return 2 - } - } - - override fun tick( - pLevel: Level, - pPos: BlockPos, - pState: BlockState, - pBlockEntity: IngotFusionTollEnhancerBlockEntity - ) { - try { - if (!level!!.isClientSide) { - val input1 = items[0] - val input2 = items[1] - val input3 = items[2] - if (empty(input1) && empty(input2) && empty(input3)) { - val recipe: IngotFusionTollEnhancerRecipe = - getRecipe() ?: throw NullPointerException("Recipe is null") - if (canProcessFromRecipe(recipe)) { - currentTick++ - level!!.setBlock( - worldPosition, - level!! - .getBlockState(worldPosition) - .setValue( - IngotFusionTollEnhancer.LIT, java.lang.Boolean.TRUE), - 3) - if (currentTick >= maxTick) { - processing(recipe) - currentTick = 0 - } - } else { - level!!.setBlock( - worldPosition, - level!! - .getBlockState(worldPosition) - .setValue( - IngotFusionTollEnhancer.LIT, java.lang.Boolean.FALSE), - 3) - currentTick = 0 - setChanged() - return - } - } else { - level!!.setBlock( - worldPosition, - level!! - .getBlockState(worldPosition) - .setValue(IngotFusionTollEnhancer.LIT, java.lang.Boolean.FALSE), - 3) - currentTick = 0 - setChanged() - return - } - } - setChanged() - } catch (e: NullPointerException) { - throw NullPointerException("Tick failed") - } - } - - private fun processing(recipe: IngotFusionTollEnhancerRecipe) { - if (canProcessFromRecipe(recipe)) { - val input1 = items[0] - val input2 = items[1] - val input3 = items[2] - val result: ItemStack = recipe.result - val outputSlot = items[3] - if (outputSlot.isEmpty) { - items[3] = result.copy() - } else if (outputSlot.item === result.item) { - outputSlot.grow(1) - } - input1.shrink(1) - input2.shrink(1) - input3.shrink(1) - setChanged() - } - } - - private fun canProcessFromRecipe(recipe: IngotFusionTollEnhancerRecipe): Boolean { - return if (empty(items[0]) && empty(items[1]) && empty(items[2])) { - val stack: ItemStack = recipe.result - if (stack.isEmpty) { - false - } else { - val resultSlot = items[3] - if (resultSlot.isEmpty) { - true - } else if (!ItemStack.isSameItem(resultSlot, stack)) { - false - } else if (resultSlot.count + stack.count <= 64 && - resultSlot.count + stack.count <= resultSlot.maxStackSize) { - true - } else { - resultSlot.count + stack.count <= stack.maxStackSize - } - } - } else false - } - - override fun setItems(p_199721_1_: NonNullList) { - itemStack = p_199721_1_ - } - - override fun getItems(): NonNullList { - return itemStack - } - - override fun getContainerSize(): Int { - return NUMBER_OF_SLOTS - } - - /** Returns the stack in the given slot. */ - override fun getItem(pSlot: Int): ItemStack { - return items[pSlot] - } - - private fun empty(stack: ItemStack): Boolean { - return !stack.isEmpty - } - - override fun createMenu(pContainerId: Int, pInventory: Inventory): AbstractContainerMenu { - return IngotFusionTollEnhancerMenu(pContainerId, pInventory, this, data) - } - - override fun getDefaultName(): Component { - return IngotFusionTollEnhancer.getContainerTitle() - } - - private fun getRecipe(): IngotFusionTollEnhancerRecipe? { - val inventory = SimpleContainer(this.items.size) - for (i in items.indices) { - inventory.setItem(i, items[i]) - } - - level.let { level -> - if (level != null) { - - ArmourAndToolsMod.logger.info("Level is not null") - - return level.recipeManager - .getRecipeFor(IngotFusionTollEnhancerRecipe.Type.INSTANCE, inventory, level) - .orElseThrow { IllegalStateException("No recipe found") } - } - } - - return null - } -} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt deleted file mode 100644 index cb1d8ce1..00000000 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerMenu.kt +++ /dev/null @@ -1,129 +0,0 @@ -/* - * Copyright 2023 RealYusufIsmail. - * - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * - * you may not use this file except in compliance with the License. - * - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package io.github.realyusufismail.armourandtoolsmod.blocks.fusion - -import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit -import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit -import net.minecraft.network.FriendlyByteBuf -import net.minecraft.world.entity.player.Inventory -import net.minecraft.world.entity.player.Player -import net.minecraft.world.inventory.* -import net.minecraft.world.item.ItemStack -import net.minecraft.world.level.Level -import net.minecraft.world.level.block.entity.BlockEntity -import net.minecraftforge.common.capabilities.ForgeCapabilities -import net.minecraftforge.items.SlotItemHandler - -/** @see FurnaceMenu */ -class IngotFusionTollEnhancerMenu( - pContainerId: Int, - private val inventory: Inventory, - private val blockEntity: BlockEntity, - private val data: ContainerData, - private val player: Player = inventory.player, -) : AbstractContainerMenu(MenuTypeInit.INGOT_FUSION_TOLL_ENHANCER_MENU.get(), pContainerId) { - private var level: Level = inventory.player.level() - - constructor( - pContainerId: Int, - inventory: Inventory, - data: FriendlyByteBuf - ) : this( - pContainerId, - inventory, - inventory.player.level().getBlockEntity(data.readBlockPos()) - ?: throw IllegalStateException("Block is null"), - SimpleContainerData(2)) - - init { - try { - checkContainerSize(inventory, NUMBER_OF_SLOTS) - - addPlayerInventory(inventory) - addPlayerHotbar(inventory) - - blockEntity.getCapability(ForgeCapabilities.ITEM_HANDLER).ifPresent { it -> - addSlot(SlotItemHandler(it, 0, 16, 40)) - addSlot(SlotItemHandler(it, 1, 43, 40)) - addSlot(SlotItemHandler(it, 2, 70, 40)) - - addSlot(OutputSlotItemHandler(it)) - } - - addDataSlots(data) - } catch (e: Exception) { - throw NullPointerException("Container cannot be null") - } - } - - override fun quickMoveStack(pPlayer: Player, index: Int): ItemStack { - var itemstack = ItemStack.EMPTY - val slot = slots[index] - if (slot.hasItem()) { - val stack1 = slot.item - itemstack = stack1.copy() - if (index < NUMBER_OF_SLOTS && - !moveItemStackTo(stack1, NUMBER_OF_SLOTS, slots.size, true)) { - return ItemStack.EMPTY - } - if (!moveItemStackTo(stack1, 0, NUMBER_OF_SLOTS, false)) { - return ItemStack.EMPTY - } - if (stack1.isEmpty) { - slot.set(ItemStack.EMPTY) - } else { - slot.setChanged() - } - } - return itemstack - } - - /** Determines whether supplied player can use this container */ - override fun stillValid(pPlayer: Player): Boolean { - return stillValid( - ContainerLevelAccess.create(level, blockEntity.blockPos), - player, - BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()) - } - - fun getLitProgress(): Int { - val process = data[0] - val maxTick = data[1] - return if (maxTick != 0 && process != 0) process * 24 / maxTick else 0 - } - - private fun addPlayerInventory(playerInventory: Inventory) { - for (row in 0..2) { - for (col in 0..8) { - addSlot( - Slot( - playerInventory, - col + row * 9 + 9, - 8 + col * 18, - 166 - (4 - row) * 18 - 10 + 13)) - } - } - } - - private fun addPlayerHotbar(playerInventory: Inventory) { - for (col in 0..8) { - addSlot(Slot(playerInventory, col, 8 + col * 18, 142 + 13)) - } - } -} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/OutputSlotItemHandler.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/OutputSlotItemHandler.kt deleted file mode 100644 index ff77e219..00000000 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/OutputSlotItemHandler.kt +++ /dev/null @@ -1,30 +0,0 @@ -/* - * Copyright 2023 RealYusufIsmail. - * - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * - * you may not use this file except in compliance with the License. - * - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package io.github.realyusufismail.armourandtoolsmod.blocks.fusion - -import net.minecraft.world.item.ItemStack -import net.minecraftforge.items.IItemHandler -import net.minecraftforge.items.SlotItemHandler - -class OutputSlotItemHandler(itemHandler: IItemHandler) : SlotItemHandler(itemHandler, 3, 138, 40) { - - override fun mayPlace(stack: ItemStack): Boolean { - return false - } -} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/rework/ReworkedBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt similarity index 95% rename from src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/rework/ReworkedBlockEntity.kt rename to src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt index 8be9848a..9cb7328a 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/rework/ReworkedBlockEntity.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt @@ -16,10 +16,9 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package io.github.realyusufismail.armourandtoolsmod.blocks.rework +package io.github.realyusufismail.armourandtoolsmod.blocks.infusion import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer -import io.github.realyusufismail.armourandtoolsmod.blocks.fusion.IngotFusionTollEnhancerMenu import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap @@ -49,7 +48,7 @@ import net.minecraft.world.level.Level import net.minecraft.world.level.block.entity.BaseContainerBlockEntity import net.minecraft.world.level.block.state.BlockState -class ReworkedBlockEntity(pPos: BlockPos, pBlockState: BlockState) : +class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState) : BaseContainerBlockEntity( BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), pPos, pBlockState), WorldlyContainer, @@ -139,12 +138,12 @@ class ReworkedBlockEntity(pPos: BlockPos, pBlockState: BlockState) : level: Level, pPos: BlockPos, pState: BlockState, - pEntity: ReworkedBlockEntity + pEntity: IngotFusionTollEnhancerBlockEntity ) { TODO() } - private fun getTotalCraftTime(pLevel: Level, pBlockEntity: ReworkedBlockEntity): Int { + private fun getTotalCraftTime(pLevel: Level, pBlockEntity: IngotFusionTollEnhancerBlockEntity): Int { return pBlockEntity.quickCheck!! .getRecipeFor(pBlockEntity, pLevel) .map { it::craftTime.get() } @@ -249,7 +248,7 @@ class ReworkedBlockEntity(pPos: BlockPos, pBlockState: BlockState) : } override fun createMenu(pContainerId: Int, pInventory: Inventory): AbstractContainerMenu { - return IngotFusionTollEnhancerMenu(pContainerId, pInventory, this, dataAccess) + return IngotFusionTollEnhancerMenu(pContainerId, this, dataAccess, pInventory) } override fun getDefaultName(): Component { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt new file mode 100644 index 00000000..2728b5d0 --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt @@ -0,0 +1,86 @@ +package io.github.realyusufismail.armourandtoolsmod.blocks.infusion + +import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit +import net.minecraft.network.FriendlyByteBuf +import net.minecraft.world.Container +import net.minecraft.world.entity.player.Inventory +import net.minecraft.world.entity.player.Player +import net.minecraft.world.entity.player.StackedContents +import net.minecraft.world.inventory.* +import net.minecraft.world.item.ItemStack +import net.minecraft.world.item.crafting.Recipe +import net.minecraft.world.level.block.entity.BlockEntity + +/** + * @see net.minecraft.stats.RecipeBookSettings + * @see FurnaceMenu + */ +class IngotFusionTollEnhancerMenu( + pContainerId: Int, + private val blockEntity: BlockEntity, + private val data: ContainerData, + pInventory: Inventory +) : RecipeBookMenu(MenuTypeInit.INGOT_FUSION_TOLL_ENHANCER_MENU.get(), pContainerId) { + + constructor( + pContainerId: Int, + inventory: Inventory, + data: FriendlyByteBuf + ) : this( + pContainerId, + inventory.player.level().getBlockEntity(data.readBlockPos()) + ?: throw IllegalStateException("Block is null"), + SimpleContainerData(2), + inventory) + + /** + * Handle when the stack in slot `index` is shift-clicked. Normally this moves the stack between the player + * inventory and the other inventory(s). + */ + override fun quickMoveStack(pPlayer: Player, pIndex: Int): ItemStack { + TODO("Not yet implemented") + } + + /** + * Determines whether supplied player can use this container + */ + override fun stillValid(pPlayer: Player): Boolean { + TODO("Not yet implemented") + } + + override fun fillCraftSlotsStackedContents(pItemHelper: StackedContents) { + TODO("Not yet implemented") + } + + override fun clearCraftingContent() { + TODO("Not yet implemented") + } + + override fun getResultSlotIndex(): Int { + TODO("Not yet implemented") + } + + override fun getGridWidth(): Int { + TODO("Not yet implemented") + } + + override fun getGridHeight(): Int { + TODO("Not yet implemented") + } + + override fun getSize(): Int { + TODO("Not yet implemented") + } + + override fun getRecipeBookType(): RecipeBookType { + TODO("Not yet implemented") + } + + override fun shouldMoveToInventory(pSlotIndex: Int): Boolean { + TODO("Not yet implemented") + } + + override fun recipeMatches(pRecipe: Recipe): Boolean { + TODO("Not yet implemented") + } +} \ No newline at end of file diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt index b6bd114d..402cb044 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt @@ -20,7 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod.ArmorAndToolsMod.MOD_ID import io.github.realyusufismail.armourandtoolsmod.blocks.armour.CustomArmourCraftingTableMenu -import io.github.realyusufismail.armourandtoolsmod.blocks.fusion.IngotFusionTollEnhancerMenu +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerMenu import io.github.realyusufismail.armourandtoolsmod.blocks.tool.CustomToolCraftingTableMenu import net.minecraft.world.flag.FeatureFlagSet import net.minecraft.world.flag.FeatureFlags diff --git a/src/main/resources/assets/armourandtoolsmod/textures/gui/container/ingot_fusion_toll_enhancer.png b/src/main/resources/assets/armourandtoolsmod/textures/gui/container/ingot_fusion_toll_enhancer.png index b1576d1f441c9349c5024fea8badc1c275f428af..9edaa13c779c53acaee6f28c6535b9e090aa615d 100644 GIT binary patch literal 2795 zcma)8cT^MU7XMNtK?JfAnqUB*f-In7P(fM%5nQB5S)^luD7^~OGFU*-C2moXE(o{; z0xZ2_Ao2voxF{$^BoJUjjeukcNjB{6A9~)~b9T4AH{aZJu(Oifx??K< zK=Oq3F-HJkqDvS+i-}I25s&>hvq(oPb3pA={!Nr1iDtHD0927BHqLAj<>F!1Zjk^; zwQmMYe~Z&@0JcIWj+r^fde4vA-tZzSqLw0UWrj=77ov5XcR9*mdgu^jXpw1o@sR}G z(h*s8!>h(p-qzM5U;~_cf_aqxEBQNX%R6>*SFT@axVT5=>sr~WeQ7nP?>Ms69q0*q z6Gj@-C;b;*jJ(A6$M-Gsp7a{5^|caxr;LQWw&{u1R^|_P1H_j@_({Fn*rt;`r2(>2 z9u=+&bqKY}mX?-sLk^8*K6`ZrL9ylZe@(fLlQ0ZM?0Rw-+3~YeN$H^sd$RGT(~X|) z?rHR)l1g01WC5!3IH%u|^!t$cyQkqFC!a+aJc}O+vH%3vM0R0w_r94}uND&oj4++} z$+eemDoBhg!*CftO5dxvHQ3E-vIBQ$`f3iOkKMC^$VE==IN`oH_*Fp;&Zqm##-Y)` zvC$J9^zBCNzSNGCey9)55Sz#rQ+BDD?OyLpBel}$^nm$-z8tY@+68YlGzAQLE(BDI z1UP~buBaWw*aC;_($0>St>&?nG?2_huie1fj}L2KHxfR^%mi>yFv5=eT7n^eH3o|* z4TrEPvZQiTWRv%X8DLzVz>>sUl4jV@ayw%zfeT z<3F#}&!Zs$Q(6jc4i~AWZWnPWW=i8FVSU*KGNDwQ?ZWp~IK_DFw_OcUIMQGllgG{! z7`vr{!n846$b^Gxp2`d?mP#HDX%3#-`S4~=#O7P<{bfN1kq5;H*~SX1&lVL3d85rS z^7Ug$ysluOfY172D(ZK`xq6G@5Mdl%1TPV1U)U3;%}Ur#F@-KDYeZ5?|sD(xz? zvrwaBH9DA4OyZ6durr_gVBjPyOtA4gbEGkn z6_NRL4r^MSp$VAxUZHTY`3*t=uh+x+oPiz1N1~;@Kxnd>0K$vhMh1;3;Yp#cq(P&A z*#vMhq!{F9AqluXIN>ZDY{w&g2~ORF`*=$F=<^DI@ZQ4rBE}uJQ;RY zHIuYscxD%jp=<#eVDmN%V-~VY>G88`oqOTFQuLA-8Oh^cZQ}enfSWT112@GX1D3VP zuo)1M^R=VPCKh`VDWaR$>!Ik5OPIfCg(DnB5jR#ZD&5`%rW_LSFR5P5{s9NlhLfiq zHdGeccneH6r6QMonvl3{oOR!an){nvJ>rNJU>t?#8>IXXCa^xaiTAhc&*@0EDlIV{ zTD%!rky6%o$kq=ph|@D3R;2b0yLoz+;k+h8I;L)KgSe>Y%%$;8`imoDL55kCIpb#y z`Me@dilYxDKB^ziqJH2WJ#p8C13CJ#ziQ zJ;mhW^M;*=8h7I1!J@Ezb}1z=!q6W%bTl3I|8;x;@rC2h=n0@m@WA!C^PfPkFRicH z;Nge5Zxft;$r;ZaNmop+6UAqM-G6uLUkVbTO`bJ@9EH!d{7V)4L{tMd%~4Fw#7CK9 zGOW~*7eBM9> z_hTj68>&62(un-l!;(PObW*Jc>H$}Fe4oj(;y zcN!y=ZWu5`o8i(DtgEjTikP@RCgkXH+0*XHP~T;up2 z%;V9eyGjFbh*t$Oh1`nfg{EJ)DtuPq8?EHJcVTJ{w^^oZAKo*cRhYQ7aGomBt61mg zv!vM8gz1?;Wjx(kI@nbB@Y(CQEQe0-6uzDs|In zG!n%n->--1Bbl7js_>o|<(!&&v zEz_&=_&>+7KPCxUvr20VxC5``MQyOl)<4y{FP*t!lVH&a}{Zgam6VX@=59vZ~#mHOd;G$K}3z~tQG~Dx++*Ymu zg7pp{5A0Ex)Wv{e(RJxFI(h*^h5qaBRlqMyxwaX<#nSRv|Vil%juD@w3gaKh5=7}ebO${$3n B-}V3i literal 1128 zcmeAS@N?(olHy`uVBq!ia0y~yU<5K58911MRQ8&P5D>38$lZxy-8q?;Kn_c~qpu?a z!^VE@KZ&eBzFdG$h%1o(|NsB7W5+^6L#HV-ba!{}GUw08$S^lI2THYuzbFGzTqQw% z!9ZmYz_96z&Uv6HXMsm#F#`kNeh_A~U=3DbU|`Eakt5%>1?!?IZpBCd%%3pL;W zKP39>z=BD7YBK}%)8E@)cSzcK-zcqh+g*#YLaEo+d+)0Hc|Le-e|COAka*_*)5mod z#Fo#Vu9eAlL41FGtv%<9=DU}|SbZ6O-D1dPw6njw$Lt9|P=J-~$7U{`pM|$pE!e>z z-Pr32WE^04eeb#@&u3+02F^3T^_enPH#sq%VY(F$Vl^=>ncDvHZvIVs&LwNPxcCe> zUtHY!x^qjY;~u68ehwakx9|T1E49sS%;0S1O6 z%qyfA7+UK2Bi7sJhTM>3n8td^t#vMwgY=SKE^Bs&C`F*CC&M#YkSJ?Hlu~X;gh#`c zPqE(^#LFA>l^fR2p7vLn`On{VPs8T_`se#$SA9mq&wbzg%CCRZJ+NiJ@qs=24IOUn z=WE#az3Aue0QRDGzq{M3pOrJ*+Aq}b@5$DhZ|Te5MgQkYzP+Ad+TX(rZ#e#NCFlYz z)n<@mJ;kut{NWvKcFPLsRdWr30= z!;72DEDQ{18NSHN6*s57JL(?A{9=CU+Sq$pov1jirR9?&Y<#O8FPkHWO9aRhr7fQpq!E6w*;BM=6t4k6K?%urva{UpY-}W&6 z5@SdA2jQ QXA1I%r>mdKI;Vst0I=Y$wg3PC diff --git a/src/main/resources/assets/armourandtoolsmod/textures/gui/container/ingot_fusion_toll_enhancer_jei.png b/src/main/resources/assets/armourandtoolsmod/textures/gui/container/ingot_fusion_toll_enhancer_jei.png index 68d692ff15cd45c0cb183bb88af6ebd5194258ea..19d6d0fe8dabb5c705a41ee6063202a14f98d429 100644 GIT binary patch literal 1740 zcmc&!i#yY69DlbKB8H-38M;_>QKqvlGNF>&VwFlPo@^p4a?SkGQKGC;hMmyGC5ePK zmszJ=4q6f^w^deSI+E66Hg=}dIZw~|2hRIE-}m$Vd_V8^`F_9e^FHr+g4<3_bpv$( zfTq(f2M+*XN*4yyRFvR-q9|aNg?sGW4oaV)L`s4n+qv2SP)^s7ADOG<^TKu=2nRr` zVb);REVK*(P&wk{U`LGh86DuJqK+1lH4q7JLAg<3vZhczI%o^bFx4y~h z=|Nj?6cXmD%7M?ZZKy8`dfc;3D*IYnNmVx5@V>r2vl`vd;NXaD$vMvXQqk3};q~P& z*5a4Ht_SR>F(0eM$lm^blnd+OL%%N(7QskTY`N;^tHMGD^VR0Sgsi*&n=YMHFg|wBw z7rn!`Aizu9TEq^ft%VH&0rqZMjYvB-Q}SN>b(F#L1E7X%M87MN{&m2GAWie3yG;k}K>5y(6Q95QvRFxq>oaBAhe(_Wfuvf!r;D=CA`lKbUOxfcDpoq{Cr&OBQv65p}=5%|o zd5CQfZHfAXWfX+VzKsS{`eGFy+8C+=T_g+vRK05>?=4x=p6|>Em}$Ltl(QhLD@?2k z!|R!Xn|2J*l;opTS*V!~xWz-)sj2DVN~F#!0BM&i4=vn`@M5nzgb^|AALB86740;u1RW+ed(BqZ;H=LxX3Vr@VuudYWL^8@vBKjyqzK5=Ly zzG}~YE)o*)^uSdo(DlURpZgDcbkk?fl4g@f6=q-<1-p;ag5~+afw{6Og-kA-81A@L zth?zqr8Xbm;$fHe_fA&=jfx+pFvD2OvKFd*!0 zDJl6=VlQ_UY}~yZ=r^0-H5xM%Uqzi(dsj0V=couJ?~c=%D^LSPnE*6@WMxVnX z$d{ISSHC#q>zga8g5(B|r)3k&pw>abqts>p8S%%YKY(&3!DBjW+_V#uPE` z)bEmbnscKc;Hg>?0gcPeE~w?nfQo=PE`&P9pAhMuN$hPIbnTcEf8d1lv4S*TR!jz0Vl8TOtZ2pwQ$LF9%7g1K%A@^f%nS_;=`0pYK;_g`S4(@lySw)X zKK;$lF_iQ5T)U=HLt8xIHeWgub3Nr$|uHXEMcGvWBl9w z@0>L>!kOF|=ZBnC{^CEar7y-N1aZ3GBg408Tt%!E;wSn4ch$Q;POG;0jlFZfaUo~6 O9VbUOhtln&#J>QGR^jmg literal 1130 zcmeAS@N?(olHy`uVBq!ia0y~yU<5K58911MRQ8&P5D>38$lZzY=1HA;AcwQSBeIx* zf$sQKaGF!K_WLw>O&@M{P0kzWx2~qD_1M|Bqgj=+Nk> zt043KvxWQ9*%v?G{jP9G(Q}elrOM#|N$q~OM%&pp?tbonyOKx!K-&I7_nW)78}%^! z&;I@QwnW1Hebc}ekltaz*md8cS1v)Ps^Oyp z%uNX4fX z7Lh*~-m)^Wb(HXDgqzgwVVK)}k*P$Njr+o032ldiNh=s!yC*V<2qipc@!-B!@ZxpI zO{ShU1|}B%3x6eo{zPobX3m+;z{H`@fRETv%`9V6QjwJO>BN(Z$;bV9lnD^R?>d+1ppk-)Em} z@1M_R_b-0M)oWSNag$Z%Uw^g9f9?G2-3$H&+K0wR|F)S^+jpg1<>#l;rQhEE-hTDF zt^O^e Date: Tue, 3 Oct 2023 19:37:28 +0100 Subject: [PATCH 11/51] Need to modify IngotFusionTollEnhancerBlockEntity so now it works for my block --- .../blocks/IngotFusionTollEnhancer.java | 2 +- .../core/init/BlockEntityTypeInit.java | 2 +- .../IngotFusionTollEnhancerBlockEntity.kt | 211 ++++++++++++++++-- .../infusion/IngotFusionTollEnhancerMenu.kt | 28 ++- 4 files changed, 214 insertions(+), 29 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java index e992c4bb..70b8f3c1 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java @@ -1,7 +1,7 @@ package io.github.realyusufismail.armourandtoolsmod.blocks; import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; -import io.github.realyusufismail.armourandtoolsmod.blocks.fusion.IngotFusionTollEnhancerBlockEntity; +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit; import io.github.realyusufismail.armourandtoolsmod.core.init.StatsInit; import net.minecraft.core.BlockPos; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java index e7df3bf2..53b79096 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java @@ -1,7 +1,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init; import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; -import io.github.realyusufismail.armourandtoolsmod.blocks.fusion.IngotFusionTollEnhancerBlockEntity; +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity; import net.minecraft.world.level.block.entity.BlockEntity; import net.minecraft.world.level.block.entity.BlockEntityType; import net.minecraftforge.registries.DeferredRegister; diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt index 9cb7328a..45c58b70 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt @@ -18,17 +18,26 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion +import com.google.common.collect.Maps import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit +import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit +import io.github.realyusufismail.armourandtoolsmod.core.init.ItemInit +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap import kotlin.properties.Delegates +import net.minecraft.SharedConstants +import net.minecraft.Util import net.minecraft.core.BlockPos import net.minecraft.core.Direction import net.minecraft.core.NonNullList +import net.minecraft.core.RegistryAccess import net.minecraft.nbt.CompoundTag import net.minecraft.network.chat.Component import net.minecraft.resources.ResourceLocation +import net.minecraft.tags.ItemTags +import net.minecraft.util.Mth import net.minecraft.world.Container import net.minecraft.world.ContainerHelper import net.minecraft.world.WorldlyContainer @@ -45,9 +54,13 @@ import net.minecraft.world.item.Items import net.minecraft.world.item.crafting.Recipe import net.minecraft.world.item.crafting.RecipeManager import net.minecraft.world.level.Level +import net.minecraft.world.level.block.Blocks +import net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity import net.minecraft.world.level.block.entity.BaseContainerBlockEntity import net.minecraft.world.level.block.state.BlockState +import net.minecraftforge.common.ForgeHooks +/** @see net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity */ class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState) : BaseContainerBlockEntity( BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), pPos, pBlockState), @@ -98,9 +111,6 @@ class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState } } - // TODO: Implement this in the future - val fuel: Map = mutableMapOf() - private fun isLit(): Boolean { return litTime > 0 } @@ -133,24 +143,6 @@ class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState pTag.put("RecipesUsed", compoundtag) } - companion object { - fun serverTick( - level: Level, - pPos: BlockPos, - pState: BlockState, - pEntity: IngotFusionTollEnhancerBlockEntity - ) { - TODO() - } - - private fun getTotalCraftTime(pLevel: Level, pBlockEntity: IngotFusionTollEnhancerBlockEntity): Int { - return pBlockEntity.quickCheck!! - .getRecipeFor(pBlockEntity, pLevel) - .map { it::craftTime.get() } - .orElse(200) - } - } - /** Returns the number of slots in the inventory. */ override fun getContainerSize(): Int { return items.size @@ -271,4 +263,181 @@ class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState pContents.accountStack(itemstack) } } + + companion object { + fun serverTick( + level: Level, + pPos: BlockPos, + pState: BlockState, + pEntity: IngotFusionTollEnhancerBlockEntity + ) { + val flag: Boolean = pEntity.isLit() + var flag1 = false + if (pEntity.isLit()) { + --pEntity.litTime + } + + val itemstack: ItemStack = pEntity.items[1] + val flag2: Boolean = !pEntity.items[0].isEmpty + val flag3 = !itemstack.isEmpty + if (pEntity.isLit() || flag3 && flag2) { + val recipe: Recipe<*>? = + if (flag2) { + pEntity.quickCheck?.getRecipeFor(pEntity, level)?.orElse(null) + } else { + null + } + + val i: Int = pEntity.maxStackSize + if (!pEntity.isLit() && + pEntity.canCreate(level.registryAccess(), recipe, pEntity.items, i)) { + pEntity.litTime = pEntity.getTotalCraftTime(itemstack) + pEntity.litDuration = pEntity.litTime + if (pEntity.isLit()) { + flag1 = true + if (itemstack.hasCraftingRemainingItem()) + pEntity.items[1] = itemstack.craftingRemainingItem + else if (flag3) { + val item = itemstack.item + itemstack.shrink(1) + if (itemstack.isEmpty) { + pEntity.items[1] = itemstack.craftingRemainingItem + } + } + } + } + if (pEntity.isLit() && + pEntity.canCreate(level.registryAccess(), recipe, pEntity.items, i)) { + ++pEntity.creatingTime + if (pEntity.creatingTime == pEntity.creatingTotalTime) { + pEntity.creatingTime = 0 + pEntity.creatingTotalTime = getTotalCraftTime(level, pEntity) + if (pEntity.craft(level.registryAccess(), recipe, pEntity.items, i)) { + pEntity.recipeUsed = recipe + } + flag1 = true + } + } else { + pEntity.creatingTime = 0 + } + } else if (!pEntity.isLit() && pEntity.creatingTime > 0) { + pEntity.creatingTime = Mth.clamp(pEntity.creatingTime - 2, 0, pEntity.creatingTime) + } + + var state = pState + if (flag != pEntity.isLit()) { + flag1 = true + state = + pState.setValue(IngotFusionTollEnhancer.LIT, pEntity.isLit()) + level.setBlock(pPos, state, 3) + } + + if (flag1) { + setChanged(level, pPos, state) + } + } + + private fun getTotalCraftTime( + pLevel: Level, + pBlockEntity: IngotFusionTollEnhancerBlockEntity + ): Int { + return pBlockEntity.quickCheck!! + .getRecipeFor(pBlockEntity, pLevel) + .map { it::craftTime.get() } + .orElse(200) + } + + fun getFuels(): MutableMap { + val map: MutableMap = Maps.newLinkedHashMap() + map.putAll(AbstractFurnaceBlockEntity.getFuel()) + addFuel(map, ItemInit.GRAPHITE.get(), 200) + addFuel(map, BlockInit.GRAPHITE_BLOCK.get().asItem(), 2000) + return map + } + + private fun addFuel(pMap: MutableMap, fuel: Item, pBurnTime: Int) { + if (isNeverAIngotFusionTollEnhanceFuel(fuel)) { + if (SharedConstants.IS_RUNNING_IN_IDE) { + throw (Util.pauseInIde( + IllegalStateException( + "A developer tried to explicitly make fire resistant item " + + fuel.getName(null as ItemStack?).string + + " a IngotFusionTollEnhancer fuel. That will not work!")) + as IllegalStateException) + } + } else { + pMap[fuel] = pBurnTime + } + } + + private fun isNeverAIngotFusionTollEnhanceFuel(pItem: Item): Boolean { + return pItem.builtInRegistryHolder().`is`(ItemTags.NON_FLAMMABLE_WOOD) + } + } + + private fun canCreate( + pRegistryAccess: RegistryAccess, + pRecipe: Recipe<*>?, + pInventory: NonNullList, + pMaxStackSize: Int + ): Boolean { + return if (!pInventory[0].isEmpty && pRecipe != null) { + val itemstack = (pRecipe as Recipe).assemble(this, pRegistryAccess) + if (itemstack.isEmpty) { + false + } else { + // TODO: Check this + val itemstack1 = pInventory[2] + + if (itemstack1.isEmpty) { + true + } else if (!ItemStack.isSameItem(itemstack1, itemstack)) { + false + } else if (itemstack1.count + itemstack.count <= pMaxStackSize && + itemstack1.count + itemstack.count <= itemstack1.maxStackSize) { + true + } else { + itemstack1.count + itemstack.count <= itemstack.maxStackSize + } + } + } else { + false + } + } + + private fun craft( + pRegistryAccess: RegistryAccess, + pRecipe: Recipe<*>?, + pInventory: NonNullList, + pMaxStackSize: Int + ): Boolean { + return if (pRecipe != null && + this.canCreate(pRegistryAccess, pRecipe, pInventory, pMaxStackSize)) { + val itemstack = pInventory[0] + val itemstack1 = (pRecipe as Recipe).assemble(this, pRegistryAccess) + val itemstack2 = pInventory[2] + if (itemstack2.isEmpty) { + pInventory[2] = itemstack1.copy() + } else if (itemstack2.`is`(itemstack1.item)) { + itemstack2.grow(itemstack1.count) + } + if (itemstack.`is`(Blocks.WET_SPONGE.asItem()) && + !pInventory[1].isEmpty && + pInventory[1].`is`(Items.BUCKET)) { + pInventory[1] = ItemStack(Items.WATER_BUCKET) + } + itemstack.shrink(1) + true + } else { + false + } + } + + private fun getTotalCraftTime(pItemStack: ItemStack): Int { + return if (pItemStack.isEmpty) { + 0 + } else { + ForgeHooks.getBurnTime(pItemStack, RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()) + } + } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt index 2728b5d0..8c7898e8 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit @@ -34,16 +52,14 @@ class IngotFusionTollEnhancerMenu( inventory) /** - * Handle when the stack in slot `index` is shift-clicked. Normally this moves the stack between the player - * inventory and the other inventory(s). + * Handle when the stack in slot `index` is shift-clicked. Normally this moves the stack between + * the player inventory and the other inventory(s). */ override fun quickMoveStack(pPlayer: Player, pIndex: Int): ItemStack { TODO("Not yet implemented") } - /** - * Determines whether supplied player can use this container - */ + /** Determines whether supplied player can use this container */ override fun stillValid(pPlayer: Player): Boolean { TODO("Not yet implemented") } @@ -83,4 +99,4 @@ class IngotFusionTollEnhancerMenu( override fun recipeMatches(pRecipe: Recipe): Boolean { TODO("Not yet implemented") } -} \ No newline at end of file +} From 96b08e909e0e9e40e33bae0178ba46fe24008103 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Tue, 3 Oct 2023 22:54:23 +0100 Subject: [PATCH 12/51] need to double chekc width, heigh and some stuff --- .../IngotFusionTollEnhancerBlockEntity.kt | 5 +- .../infusion/IngotFusionTollEnhancerMenu.kt | 131 +++++++++++++++--- .../blocks/infusion/slots/InfusionFuelSlot.kt | 23 +++ .../infusion/slots/OutputSlotItemHandler.kt | 12 ++ .../core/init/RecipeBookTypesInit.kt | 1 + .../IngotFusionTollEnhancerRecipeBuilder.kt | 11 +- ...ngotFusionTollEnhancerJEIRecipeCategory.kt | 2 + .../fusion/IngotFusionTollEnhancerRecipe.kt | 9 +- 8 files changed, 165 insertions(+), 29 deletions(-) create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt index 45c58b70..7a2e09fe 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt @@ -67,8 +67,7 @@ class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState WorldlyContainer, RecipeHolder, StackedContentsCompatible { - private val SLOT_OUTPUT = 4 - private var items = NonNullList.withSize(3, ItemStack.EMPTY) + private var items = NonNullList.withSize(NUMBER_OF_SLOTS, ItemStack.EMPTY) // TODO: Check these and fix them private var quickCheck: RecipeManager.CachedCheck? = @@ -265,6 +264,8 @@ class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState } companion object { + const val NUMBER_OF_SLOTS = 5 + fun serverTick( level: Level, pPos: BlockPos, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt index 8c7898e8..bf20dae8 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt @@ -18,7 +18,12 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity.Companion.NUMBER_OF_SLOTS +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots.InfusionFuelSlot +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots.OutputSlotItemHandler import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeBookTypesInit +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit import net.minecraft.network.FriendlyByteBuf import net.minecraft.world.Container import net.minecraft.world.entity.player.Inventory @@ -27,7 +32,11 @@ import net.minecraft.world.entity.player.StackedContents import net.minecraft.world.inventory.* import net.minecraft.world.item.ItemStack import net.minecraft.world.item.crafting.Recipe -import net.minecraft.world.level.block.entity.BlockEntity +import net.minecraft.world.level.Level +import net.minecraft.world.level.block.entity.BaseContainerBlockEntity +import net.minecraftforge.common.ForgeHooks +import net.minecraftforge.common.capabilities.ForgeCapabilities +import net.minecraftforge.items.SlotItemHandler /** * @see net.minecraft.stats.RecipeBookSettings @@ -35,10 +44,14 @@ import net.minecraft.world.level.block.entity.BlockEntity */ class IngotFusionTollEnhancerMenu( pContainerId: Int, - private val blockEntity: BlockEntity, + private val blockEntity: BaseContainerBlockEntity, private val data: ContainerData, pInventory: Inventory ) : RecipeBookMenu(MenuTypeInit.INGOT_FUSION_TOLL_ENHANCER_MENU.get(), pContainerId) { + private val recipeType = RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.registryObject.orElseThrow { IllegalStateException("Recipe type is null") } + private val recipeBook = RecipeBookTypesInit.INGOT_FUSION + private val level: Level + constructor( pContainerId: Int, @@ -46,57 +59,143 @@ class IngotFusionTollEnhancerMenu( data: FriendlyByteBuf ) : this( pContainerId, - inventory.player.level().getBlockEntity(data.readBlockPos()) - ?: throw IllegalStateException("Block is null"), + getBlockEntity(inventory, data), SimpleContainerData(2), inventory) + init { + level = pInventory.player.level() ?: throw IllegalStateException("Level is null") + + checkContainerDataCount(data, NUMBER_OF_SLOTS) + + addPlayerInventory(pInventory) + addPlayerHotbar(pInventory) + + blockEntity.getCapability(ForgeCapabilities.ITEM_HANDLER).ifPresent { it -> + //slots to place ingredients + addSlot(SlotItemHandler(it, 0, 16, 40)) + addSlot(SlotItemHandler(it, 1, 43, 40)) + addSlot(SlotItemHandler(it, 2, 70, 40)) + + //slot to place fuel + addSlot(InfusionFuelSlot(it, this)) + + //slot to place result + addSlot(OutputSlotItemHandler(it)) + } + } + /** * Handle when the stack in slot `index` is shift-clicked. Normally this moves the stack between * the player inventory and the other inventory(s). */ - override fun quickMoveStack(pPlayer: Player, pIndex: Int): ItemStack { - TODO("Not yet implemented") + override fun quickMoveStack(pPlayer: Player, index: Int): ItemStack { + var itemstack = ItemStack.EMPTY + val slot = slots[index] + if (slot.hasItem()) { + val stack1 = slot.item + itemstack = stack1.copy() + if (index < NUMBER_OF_SLOTS && + !moveItemStackTo(stack1, NUMBER_OF_SLOTS, slots.size, true)) { + return ItemStack.EMPTY + } + if (!moveItemStackTo(stack1, 0, NUMBER_OF_SLOTS, false)) { + return ItemStack.EMPTY + } + if (stack1.isEmpty) { + slot.set(ItemStack.EMPTY) + } else { + slot.setChanged() + } + } + return itemstack } /** Determines whether supplied player can use this container */ override fun stillValid(pPlayer: Player): Boolean { - TODO("Not yet implemented") + return blockEntity.stillValid(pPlayer) } override fun fillCraftSlotsStackedContents(pItemHelper: StackedContents) { - TODO("Not yet implemented") + if (this.blockEntity is StackedContentsCompatible) { + (this.blockEntity as StackedContentsCompatible).fillStackedContents(pItemHelper) + } } override fun clearCraftingContent() { - TODO("Not yet implemented") + + //Ingredient slots + this.getSlot(0).set(ItemStack.EMPTY) + this.getSlot(1).set(ItemStack.EMPTY) + this.getSlot(2).set(ItemStack.EMPTY) + + //Fuel slot + this.getSlot(3).set(ItemStack.EMPTY) + + //Output slot + this.getSlot(4).set(ItemStack.EMPTY) } override fun getResultSlotIndex(): Int { - TODO("Not yet implemented") + return 4 } override fun getGridWidth(): Int { - TODO("Not yet implemented") + return 3 } + //TODO: Check if this is correct override fun getGridHeight(): Int { - TODO("Not yet implemented") + return 1 } override fun getSize(): Int { - TODO("Not yet implemented") + return NUMBER_OF_SLOTS } override fun getRecipeBookType(): RecipeBookType { - TODO("Not yet implemented") + return recipeBook } override fun shouldMoveToInventory(pSlotIndex: Int): Boolean { - TODO("Not yet implemented") + return pSlotIndex != this.resultSlotIndex } override fun recipeMatches(pRecipe: Recipe): Boolean { - TODO("Not yet implemented") + return pRecipe.matches(this.blockEntity, this.level) + } + + private fun addPlayerInventory(playerInventory: Inventory) { + for (row in 0..2) { + for (col in 0..8) { + addSlot( + Slot( + playerInventory, + col + row * 9 + 9, + 8 + col * 18, + 166 - (4 - row) * 18 - 10 + 13)) + } + } + } + + private fun addPlayerHotbar(playerInventory: Inventory) { + for (col in 0..8) { + addSlot(Slot(playerInventory, col, 8 + col * 18, 142 + 13)) + } + } + + fun isFuel(pStack: ItemStack): Boolean { + return ForgeHooks.getBurnTime(pStack, recipeType) > 0 + } + + companion object { + fun getBlockEntity( inventory: Inventory, data: FriendlyByteBuf): BaseContainerBlockEntity { + val blockEntity = inventory.player.level().getBlockEntity(data.readBlockPos()) + if (blockEntity is BaseContainerBlockEntity) { + return blockEntity + } else { + throw IllegalStateException("Block entity is not correct") + } + } } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt new file mode 100644 index 00000000..37d46033 --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt @@ -0,0 +1,23 @@ +package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots + +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerMenu +import net.minecraft.world.inventory.FurnaceFuelSlot +import net.minecraft.world.item.ItemStack +import net.minecraft.world.item.Items +import net.minecraftforge.items.IItemHandler +import net.minecraftforge.items.SlotItemHandler + +class InfusionFuelSlot(itemHandler: IItemHandler, private val menu : IngotFusionTollEnhancerMenu) : SlotItemHandler(itemHandler, 3, 110, 65) { + + override fun mayPlace(stack: ItemStack): Boolean { + return menu.isFuel(stack) || isBucket(stack) + } + + override fun getMaxStackSize(pStack: ItemStack): Int { + return if (isBucket(pStack)) 1 else super.getMaxStackSize(pStack) + } + + private fun isBucket(pStack: ItemStack): Boolean { + return pStack.`is`(Items.BUCKET) + } +} \ No newline at end of file diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt new file mode 100644 index 00000000..634520db --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt @@ -0,0 +1,12 @@ +package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots + +import net.minecraft.world.item.ItemStack +import net.minecraftforge.items.IItemHandler +import net.minecraftforge.items.SlotItemHandler + +class OutputSlotItemHandler(itemHandler: IItemHandler) : SlotItemHandler(itemHandler, 4, 138, 40) { + + override fun mayPlace(stack: ItemStack): Boolean { + return false + } +} \ No newline at end of file diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeBookTypesInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeBookTypesInit.kt index c40e516a..4b29a6be 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeBookTypesInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeBookTypesInit.kt @@ -23,4 +23,5 @@ import net.minecraft.world.inventory.RecipeBookType object RecipeBookTypesInit { val ARMOUR_CRAFTING: RecipeBookType = RecipeBookType.create("armour_crafting") val TOOL_CRAFTING: RecipeBookType = RecipeBookType.create("tool_crafting") + val INGOT_FUSION: RecipeBookType = RecipeBookType.create("ingot_fusion") } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index e16b118a..59b7f19f 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -102,15 +102,6 @@ class IngotFusionTollEnhancerRecipeBuilder( val id: ResourceLocation ) : FinishedRecipe { override fun serializeRecipeData(json: JsonObject) { - // in json arry have input one it as an arrya of items up to three - // "ingredients": [ - // { - // "item": "armourandtoolsmod:imperium" - // }, - // { - // "item": "armourandtoolsmod:imperium_pickaxe" - // }, - val jsonArray = JsonArray() val ingredients = arrayOf(input1, input2, input3) @@ -120,6 +111,8 @@ class IngotFusionTollEnhancerRecipeBuilder( json.add("ingredients", jsonArray) + //TODO: Update to add new fuel slot + val jsonObject = JsonObject() jsonObject.addProperty("item", ForgeRegistries.ITEMS.getKey(output).toString()) json.add("result", jsonObject) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt index 456f5627..cbbe59c1 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt @@ -111,6 +111,8 @@ class IngotFusionTollEnhancerJEIRecipeCategory(guiHelper: IGuiHelper) : builder.addSlot(RecipeIngredientRole.INPUT, 43, 40).addIngredients(recipe.ingredients[1]) builder.addSlot(RecipeIngredientRole.INPUT, 70, 40).addIngredients(recipe.ingredients[2]) + builder.addSlot(RecipeIngredientRole.INPUT, 110, 65).addIngredients(recipe.fuel) + builder.addSlot(RecipeIngredientRole.OUTPUT, 138, 40).addItemStack(recipe.result) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 158bce07..81b424e7 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -34,6 +34,7 @@ class IngotFusionTollEnhancerRecipe( private val input1: Ingredient, private val input2: Ingredient, private val input3: Ingredient, + val fuel : Ingredient, val result: ItemStack, private val recipeId: ResourceLocation, val craftTime: Int = 200 @@ -125,6 +126,8 @@ class IngotFusionTollEnhancerRecipe( val input2 = Ingredient.fromJson(ingredientArray[1]) val input3 = Ingredient.fromJson(ingredientArray[2]) + val fuel = Ingredient.fromJson(json.get("fuel")) + // TODO: Error caused by lack of recipe book category // [13:57:18] [Render thread/WARN] [minecraft/ClientRecipeBook]: Unknown recipe // category: @@ -133,7 +136,7 @@ class IngotFusionTollEnhancerRecipe( val result = ShapedRecipe.itemStackFromJson(GsonHelper.getAsJsonObject(json, "result")) - return IngotFusionTollEnhancerRecipe(input1, input2, input3, result, pRecipeId) + return IngotFusionTollEnhancerRecipe(input1, input2, input3, fuel, result, pRecipeId) } catch (e: IllegalStateException) { throw IllegalStateException("Could not create recipe: $pRecipeId", e) } @@ -175,8 +178,9 @@ class IngotFusionTollEnhancerRecipe( "No ingredients for ingot fusion toll enhancer recipe") } + val fuel = Ingredient.fromNetwork(pBuffer) val result = pBuffer.readItem() - return IngotFusionTollEnhancerRecipe(input1, input2, input3, result, pRecipeId) + return IngotFusionTollEnhancerRecipe(input1, input2, input3, fuel, result, pRecipeId) } catch (e: IllegalStateException) { throw IllegalStateException("Could not read recipe: $pRecipeId", e) } @@ -191,6 +195,7 @@ class IngotFusionTollEnhancerRecipe( ingredient.toNetwork(pBuffer) } + pRecipe.fuel.toNetwork(pBuffer) pBuffer.writeItem(pRecipe.result) } catch (e: IllegalStateException) { throw IllegalStateException("Could not write recipe: ${pRecipe.id}", e) From 8b198b7380ca9d1e40f47b833b50df53f54ffec1 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Tue, 3 Oct 2023 22:56:52 +0100 Subject: [PATCH 13/51] Fixed some erros --- .../fusion/IngotFusionTollEnhancerScreen.java | 4 +- .../infusion/IngotFusionTollEnhancerMenu.kt | 40 ++++++++++++------- .../blocks/infusion/slots/InfusionFuelSlot.kt | 24 +++++++++-- .../infusion/slots/OutputSlotItemHandler.kt | 20 +++++++++- .../IngotFusionTollEnhancerRecipeBuilder.kt | 2 +- .../fusion/IngotFusionTollEnhancerRecipe.kt | 8 ++-- 6 files changed, 72 insertions(+), 26 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java index 873ece24..e6682f1d 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java @@ -3,14 +3,12 @@ import com.mojang.blaze3d.systems.RenderSystem; import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; -import net.minecraft.client.gui.Font; +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerMenu; import net.minecraft.client.gui.GuiGraphics; import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; -import net.minecraft.client.gui.screens.inventory.ContainerScreen; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; import net.minecraft.world.entity.player.Inventory; -import net.minecraft.world.inventory.ChestMenu; import org.jetbrains.annotations.NotNull; import java.util.Objects; diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt index bf20dae8..0c294093 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt @@ -48,20 +48,18 @@ class IngotFusionTollEnhancerMenu( private val data: ContainerData, pInventory: Inventory ) : RecipeBookMenu(MenuTypeInit.INGOT_FUSION_TOLL_ENHANCER_MENU.get(), pContainerId) { - private val recipeType = RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.registryObject.orElseThrow { IllegalStateException("Recipe type is null") } + private val recipeType = + RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.registryObject.orElseThrow { + IllegalStateException("Recipe type is null") + } private val recipeBook = RecipeBookTypesInit.INGOT_FUSION private val level: Level - constructor( pContainerId: Int, inventory: Inventory, data: FriendlyByteBuf - ) : this( - pContainerId, - getBlockEntity(inventory, data), - SimpleContainerData(2), - inventory) + ) : this(pContainerId, getBlockEntity(inventory, data), SimpleContainerData(2), inventory) init { level = pInventory.player.level() ?: throw IllegalStateException("Level is null") @@ -72,15 +70,15 @@ class IngotFusionTollEnhancerMenu( addPlayerHotbar(pInventory) blockEntity.getCapability(ForgeCapabilities.ITEM_HANDLER).ifPresent { it -> - //slots to place ingredients + // slots to place ingredients addSlot(SlotItemHandler(it, 0, 16, 40)) addSlot(SlotItemHandler(it, 1, 43, 40)) addSlot(SlotItemHandler(it, 2, 70, 40)) - //slot to place fuel + // slot to place fuel addSlot(InfusionFuelSlot(it, this)) - //slot to place result + // slot to place result addSlot(OutputSlotItemHandler(it)) } } @@ -124,15 +122,15 @@ class IngotFusionTollEnhancerMenu( override fun clearCraftingContent() { - //Ingredient slots + // Ingredient slots this.getSlot(0).set(ItemStack.EMPTY) this.getSlot(1).set(ItemStack.EMPTY) this.getSlot(2).set(ItemStack.EMPTY) - //Fuel slot + // Fuel slot this.getSlot(3).set(ItemStack.EMPTY) - //Output slot + // Output slot this.getSlot(4).set(ItemStack.EMPTY) } @@ -144,7 +142,7 @@ class IngotFusionTollEnhancerMenu( return 3 } - //TODO: Check if this is correct + // TODO: Check if this is correct override fun getGridHeight(): Int { return 1 } @@ -188,8 +186,20 @@ class IngotFusionTollEnhancerMenu( return ForgeHooks.getBurnTime(pStack, recipeType) > 0 } + fun getLitProgress(): Int { + var i = data[1] + if (i == 0) { + i = 200 + } + return data[0] * 13 / i + } + + fun isLit(): Boolean { + return data[0] > 0 + } + companion object { - fun getBlockEntity( inventory: Inventory, data: FriendlyByteBuf): BaseContainerBlockEntity { + fun getBlockEntity(inventory: Inventory, data: FriendlyByteBuf): BaseContainerBlockEntity { val blockEntity = inventory.player.level().getBlockEntity(data.readBlockPos()) if (blockEntity is BaseContainerBlockEntity) { return blockEntity diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt index 37d46033..0b8894ef 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt @@ -1,13 +1,31 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerMenu -import net.minecraft.world.inventory.FurnaceFuelSlot import net.minecraft.world.item.ItemStack import net.minecraft.world.item.Items import net.minecraftforge.items.IItemHandler import net.minecraftforge.items.SlotItemHandler -class InfusionFuelSlot(itemHandler: IItemHandler, private val menu : IngotFusionTollEnhancerMenu) : SlotItemHandler(itemHandler, 3, 110, 65) { +class InfusionFuelSlot(itemHandler: IItemHandler, private val menu: IngotFusionTollEnhancerMenu) : + SlotItemHandler(itemHandler, 3, 110, 65) { override fun mayPlace(stack: ItemStack): Boolean { return menu.isFuel(stack) || isBucket(stack) @@ -20,4 +38,4 @@ class InfusionFuelSlot(itemHandler: IItemHandler, private val menu : IngotFusion private fun isBucket(pStack: ItemStack): Boolean { return pStack.`is`(Items.BUCKET) } -} \ No newline at end of file +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt index 634520db..f9153c61 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots import net.minecraft.world.item.ItemStack @@ -9,4 +27,4 @@ class OutputSlotItemHandler(itemHandler: IItemHandler) : SlotItemHandler(itemHan override fun mayPlace(stack: ItemStack): Boolean { return false } -} \ No newline at end of file +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index 59b7f19f..2c4bec63 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -111,7 +111,7 @@ class IngotFusionTollEnhancerRecipeBuilder( json.add("ingredients", jsonArray) - //TODO: Update to add new fuel slot + // TODO: Update to add new fuel slot val jsonObject = JsonObject() jsonObject.addProperty("item", ForgeRegistries.ITEMS.getKey(output).toString()) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 81b424e7..b74cb2db 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -34,7 +34,7 @@ class IngotFusionTollEnhancerRecipe( private val input1: Ingredient, private val input2: Ingredient, private val input3: Ingredient, - val fuel : Ingredient, + val fuel: Ingredient, val result: ItemStack, private val recipeId: ResourceLocation, val craftTime: Int = 200 @@ -136,7 +136,8 @@ class IngotFusionTollEnhancerRecipe( val result = ShapedRecipe.itemStackFromJson(GsonHelper.getAsJsonObject(json, "result")) - return IngotFusionTollEnhancerRecipe(input1, input2, input3, fuel, result, pRecipeId) + return IngotFusionTollEnhancerRecipe( + input1, input2, input3, fuel, result, pRecipeId) } catch (e: IllegalStateException) { throw IllegalStateException("Could not create recipe: $pRecipeId", e) } @@ -180,7 +181,8 @@ class IngotFusionTollEnhancerRecipe( val fuel = Ingredient.fromNetwork(pBuffer) val result = pBuffer.readItem() - return IngotFusionTollEnhancerRecipe(input1, input2, input3, fuel, result, pRecipeId) + return IngotFusionTollEnhancerRecipe( + input1, input2, input3, fuel, result, pRecipeId) } catch (e: IllegalStateException) { throw IllegalStateException("Could not read recipe: $pRecipeId", e) } From 1e9a4cb7f7c3ddfc9208c4c8687cf4ffcfeb9411 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 4 Oct 2023 10:29:42 +0100 Subject: [PATCH 14/51] Fixed issue with quickCheck --- .../blocks/IngotFusionTollEnhancer.java | 32 ++++++++++++------- .../CustomArmourCraftingTableScreen.java | 3 -- .../tool/CustomToolCraftingTableScreen.java | 3 -- .../core/init/BlockEntityTypeInit.java | 1 - .../IngotFusionTollEnhancerBlockEntity.kt | 9 ++++-- 5 files changed, 26 insertions(+), 22 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java index 70b8f3c1..fd51c622 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java @@ -1,15 +1,16 @@ package io.github.realyusufismail.armourandtoolsmod.blocks; -import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity; -import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit; -import io.github.realyusufismail.armourandtoolsmod.core.init.StatsInit; +import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit; import net.minecraft.core.BlockPos; import net.minecraft.core.Direction; import net.minecraft.network.chat.Component; import net.minecraft.server.level.ServerLevel; import net.minecraft.server.level.ServerPlayer; -import net.minecraft.world.*; +import net.minecraft.world.Container; +import net.minecraft.world.Containers; +import net.minecraft.world.InteractionHand; +import net.minecraft.world.InteractionResult; import net.minecraft.world.entity.player.Player; import net.minecraft.world.item.ItemStack; import net.minecraft.world.item.TooltipFlag; @@ -50,6 +51,14 @@ public IngotFusionTollEnhancer() { this.registerDefaultState(defaultBlockState().setValue(FACING, Direction.NORTH).setValue(LIT, false)); } + public static @NotNull Component getContainerTitle() { + return Component.translatable("container.ingot_fusion_toll_enhancer"); + } + + public static Component getContainerDescription() { + return Component.translatable("container.ingot_fusion_toll_enhancer.description"); + } + @Override public @NotNull InteractionResult use(@NotNull BlockState blockState, @NotNull Level level, @NotNull BlockPos blockPos, @NotNull Player player, @NotNull InteractionHand interactionHand, @NotNull BlockHitResult blockHitResult) { @@ -150,16 +159,15 @@ public BlockState rotate(BlockState pState, Rotation pRotation) { return pState.rotate(pMirror.getRotation(pState.getValue(FACING))); } - public static @NotNull Component getContainerTitle() { - return Component.translatable("container.ingot_fusion_toll_enhancer"); - } - - public static Component getContainerDescription() { - return Component.translatable("container.ingot_fusion_toll_enhancer.description"); - } - @Override public void appendHoverText(ItemStack pStack, @Nullable BlockGetter pLevel, List pTooltip, TooltipFlag pFlag) { pTooltip.add(getContainerDescription()); } + + @Nullable + @Override + public BlockEntityTicker getTicker(Level level, BlockState state, + BlockEntityType type) { + return level.isClientSide ? null : createTickerHelper(type, BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), IngotFusionTollEnhancerBlockEntity::serverTick); + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java index 6ae652fb..6968197a 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java @@ -1,13 +1,10 @@ package io.github.realyusufismail.armourandtoolsmod.blocks.armour; -import com.mojang.blaze3d.systems.RenderSystem; -import com.mojang.blaze3d.vertex.PoseStack; import net.minecraft.client.gui.GuiGraphics; import net.minecraft.client.gui.components.ImageButton; import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; import net.minecraft.client.gui.screens.recipebook.RecipeBookComponent; import net.minecraft.client.gui.screens.recipebook.RecipeUpdateListener; -import net.minecraft.client.renderer.GameRenderer; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; import net.minecraft.world.entity.player.Inventory; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java index 1a09d1c8..94e370c0 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java @@ -1,13 +1,10 @@ package io.github.realyusufismail.armourandtoolsmod.blocks.tool; -import com.mojang.blaze3d.systems.RenderSystem; -import com.mojang.blaze3d.vertex.PoseStack; import net.minecraft.client.gui.GuiGraphics; import net.minecraft.client.gui.components.ImageButton; import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; import net.minecraft.client.gui.screens.recipebook.RecipeBookComponent; import net.minecraft.client.gui.screens.recipebook.RecipeUpdateListener; -import net.minecraft.client.renderer.GameRenderer; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; import net.minecraft.world.entity.player.Inventory; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java index 53b79096..158f8dd4 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java @@ -2,7 +2,6 @@ import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity; -import net.minecraft.world.level.block.entity.BlockEntity; import net.minecraft.world.level.block.entity.BlockEntityType; import net.minecraftforge.registries.DeferredRegister; import net.minecraftforge.registries.ForgeRegistries; diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt index 7a2e09fe..bafc2c34 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt @@ -69,9 +69,7 @@ class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState StackedContentsCompatible { private var items = NonNullList.withSize(NUMBER_OF_SLOTS, ItemStack.EMPTY) // TODO: Check these and fix them - private var quickCheck: - RecipeManager.CachedCheck? = - null + private var quickCheck: RecipeManager.CachedCheck private val recipesUsed = Object2IntOpenHashMap() private val SLOTS_FOR_UP = intArrayOf(0) private val SLOTS_FOR_DOWN = intArrayOf(2, 1) @@ -81,6 +79,10 @@ class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState var creatingTime by Delegates.notNull() var creatingTotalTime by Delegates.notNull() + init { + quickCheck = RecipeManager.createCheck(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()) + } + private val dataAccess: ContainerData = object : ContainerData { override fun get(pIndex: Int): Int { @@ -266,6 +268,7 @@ class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState companion object { const val NUMBER_OF_SLOTS = 5 + @JvmStatic fun serverTick( level: Level, pPos: BlockPos, From aa9542747355080cac389794559a67819a111acc Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 4 Oct 2023 10:33:41 +0100 Subject: [PATCH 15/51] The errors begin --- .../blocks/infusion/IngotFusionTollEnhancerMenu.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt index 0c294093..0fcf221c 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt @@ -59,7 +59,7 @@ class IngotFusionTollEnhancerMenu( pContainerId: Int, inventory: Inventory, data: FriendlyByteBuf - ) : this(pContainerId, getBlockEntity(inventory, data), SimpleContainerData(2), inventory) + ) : this(pContainerId, getBlockEntity(inventory, data), SimpleContainerData(4), inventory) init { level = pInventory.player.level() ?: throw IllegalStateException("Level is null") From b37cf3eef27f91a934508ae9c0349e5f6d46521c Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 4 Oct 2023 12:02:49 +0100 Subject: [PATCH 16/51] Fixed some issue with IngotFusionTollEnhancerScreen --- .../fusion/IngotFusionTollEnhancerScreen.java | 117 +++++++++++++++++- ...otFusionTollEnhancerRecipeBookComponent.kt | 60 +++++++++ 2 files changed, 175 insertions(+), 2 deletions(-) create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookComponent.kt diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java index e6682f1d..1991afd1 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java @@ -4,11 +4,17 @@ import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerMenu; +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookComponent; import net.minecraft.client.gui.GuiGraphics; +import net.minecraft.client.gui.components.ImageButton; import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; +import net.minecraft.client.gui.screens.recipebook.RecipeBookComponent; +import net.minecraft.client.gui.screens.recipebook.RecipeUpdateListener; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; import net.minecraft.world.entity.player.Inventory; +import net.minecraft.world.inventory.ClickType; +import net.minecraft.world.inventory.Slot; import org.jetbrains.annotations.NotNull; import java.util.Objects; @@ -16,13 +22,40 @@ /** * @see net.minecraft.client.gui.screens.inventory.FurnaceScreen */ -public class IngotFusionTollEnhancerScreen extends AbstractContainerScreen { +public class IngotFusionTollEnhancerScreen extends AbstractContainerScreen implements RecipeUpdateListener { public static final ResourceLocation SCREEN_ID = ArmourAndToolsMod.ArmorAndToolsMod.getModIdAndName("textures/gui/container/ingot_fusion_toll_enhancer.png"); + public final IngotFusionTollEnhancerRecipeBookComponent recipeBookComponent = new IngotFusionTollEnhancerRecipeBookComponent(); + private static final ResourceLocation RECIPE_BUTTON_LOCATION = + new ResourceLocation("textures/gui/recipe_button.png"); + private boolean widthTooNarrow; public IngotFusionTollEnhancerScreen(IngotFusionTollEnhancerMenu pMenu, Inventory pPlayerInventory, Component pTitle) { super(pMenu, pPlayerInventory, pTitle); } + protected void init() { + super.init(); + this.widthTooNarrow = this.width < 379; + this.recipeBookComponent.init(this.width, this.height, Objects.requireNonNull(this.minecraft, "Minecraft is null in table screen"), this.widthTooNarrow, + this.menu); + this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); + this.addRenderableWidget(new ImageButton(this.leftPos + 5, this.height / 2 - 49, 20, 18, 0, + 0, 19, RECIPE_BUTTON_LOCATION, (p_98484_) -> { + this.recipeBookComponent.toggleVisibility(); + this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, + this.imageWidth); + p_98484_.setPosition(this.leftPos + 5, this.height / 2 - 49); + })); + this.addWidget(this.recipeBookComponent); + this.setInitialFocus(this.recipeBookComponent); + this.titleLabelX = 29; + } + + public void containerTick() { + super.containerTick(); + this.recipeBookComponent.tick(); + } + @Override protected void renderBg(@NotNull GuiGraphics pGuiGraphics, float pPartialTick, int pMouseX, int pMouseY) { try { @@ -42,8 +75,19 @@ protected void renderBg(@NotNull GuiGraphics pGuiGraphics, float pPartialTick, i public void render(@NotNull GuiGraphics pGuiGraphics, int pMouseX, int pMouseY, float pPartialTick) { try { this.renderBackground(pGuiGraphics); + + if (this.recipeBookComponent.isVisible() && this.widthTooNarrow) { + this.renderBg(pGuiGraphics, pPartialTick, pMouseX, pMouseY); + this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + } else { + this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + this.recipeBookComponent.renderGhostRecipe(pGuiGraphics, this.leftPos, this.topPos, true, pPartialTick); + } + this.renderTooltip(pGuiGraphics, pMouseX, pMouseY); - super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + this.recipeBookComponent.renderTooltip(pGuiGraphics, this.leftPos, this.topPos, pMouseX, pMouseY); + //super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); } catch (NullPointerException e) { throw new NullPointerException("Render method called before Minecraft Instance is set"); } @@ -58,4 +102,73 @@ public void renderLabels(@NotNull GuiGraphics pGuiGraphics, int pMouseX, int pMo throw new NullPointerException("Unable to render labels"); } } + + protected boolean isHovering(int pX, int pY, int pWidth, int pHeight, double pMouseX, + double pMouseY) { + return (!this.widthTooNarrow || !this.recipeBookComponent.isVisible()) + && super.isHovering(pX, pY, pWidth, pHeight, pMouseX, pMouseY); + } + + public boolean mouseClicked(double pMouseX, double pMouseY, int pButton) { + if (this.recipeBookComponent.mouseClicked(pMouseX, pMouseY, pButton)) { + this.setFocused(this.recipeBookComponent); + return true; + } else { + return this.widthTooNarrow && this.recipeBookComponent.isVisible() || super.mouseClicked(pMouseX, pMouseY, pButton); + } + } + + protected boolean hasClickedOutside(double pMouseX, double pMouseY, int pGuiLeft, int pGuiTop, + int pMouseButton) { + boolean flag = pMouseX < (double) pGuiLeft || pMouseY < (double) pGuiTop + || pMouseX >= (double) (pGuiLeft + this.imageWidth) + || pMouseY >= (double) (pGuiTop + this.imageHeight); + return this.recipeBookComponent.hasClickedOutside(pMouseX, pMouseY, this.leftPos, + this.topPos, this.imageWidth, this.imageHeight, pMouseButton) && flag; + } + + /** + * Called when the mouse is clicked over a slot or outside the gui. + */ + protected void slotClicked(@NotNull Slot pSlot, int pSlotId, int pMouseButton, @NotNull ClickType pType) { + super.slotClicked(pSlot, pSlotId, pMouseButton, pType); + this.recipeBookComponent.slotClicked(pSlot); + } + + + /** + * Called when a keyboard key is pressed within the GUI element. + *

+ * @return {@code true} if the event is consumed, {@code false} otherwise. + * @param pKeyCode the key code of the pressed key. + * @param pScanCode the scan code of the pressed key. + * @param pModifiers the keyboard modifiers. + */ + public boolean keyPressed(int pKeyCode, int pScanCode, int pModifiers) { + return !this.recipeBookComponent.keyPressed(pKeyCode, pScanCode, pModifiers) && super.keyPressed(pKeyCode, pScanCode, pModifiers); + } + + /** + * Called when a character is typed within the GUI element. + *

+ * @return {@code true} if the event is consumed, {@code false} otherwise. + * @param pCodePoint the code point of the typed character. + * @param pModifiers the keyboard modifiers. + */ + public boolean charTyped(char pCodePoint, int pModifiers) { + return this.recipeBookComponent.charTyped(pCodePoint, pModifiers) || super.charTyped(pCodePoint, pModifiers); + } + + public void recipesUpdated() { + this.recipeBookComponent.recipesUpdated(); + } + + public void removed() { + super.removed(); + } + + @Override + public @NotNull RecipeBookComponent getRecipeBookComponent() { + return recipeBookComponent; + } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookComponent.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookComponent.kt new file mode 100644 index 00000000..0989ff05 --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookComponent.kt @@ -0,0 +1,60 @@ +package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book + +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity +import net.minecraft.client.gui.screens.recipebook.RecipeBookComponent +import net.minecraft.world.inventory.Slot +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 + +class IngotFusionTollEnhancerRecipeBookComponent : RecipeBookComponent() { + private var fuels: Ingredient? = null + private val fuelItems = IngotFusionTollEnhancerBlockEntity.getFuels().keys + + override fun initFilterButtonTextures() { + filterButton.initTextureValues(152, 182, 28, 18, RECIPE_BOOK_LOCATION) + } + + override fun slotClicked(pSlot: Slot?) { + super.slotClicked(pSlot) + if (pSlot != null && pSlot.index < menu.size) { + ghostRecipe.clear() + } + } + + override fun setupGhostRecipe(pRecipe: Recipe<*>, pSlots: List) { + val itemstack = pRecipe.getResultItem(minecraft.level!!.registryAccess()) + ghostRecipe.setRecipe(pRecipe) + ghostRecipe.addIngredient(Ingredient.of(itemstack), pSlots[2].x, pSlots[2].y) + val nonnulllist = pRecipe.ingredients + val slot = pSlots[1] + if (slot.item.isEmpty) { + if (fuels == null) { + fuels = Ingredient.of( + this.fuelItems.stream().filter { it: Item -> + it.isEnabled( + minecraft.level!!.enabledFeatures() + ) + }.map { pItem: Item -> + ItemStack( + pItem + ) + } + ) + } + ghostRecipe.addIngredient(fuels!!, slot.x, slot.y) + } + val iterator: Iterator = nonnulllist.iterator() + for (i in 0..1) { + if (!iterator.hasNext()) { + return + } + val ingredient = iterator.next() + if (!ingredient.isEmpty) { + val slot1 = pSlots[i] + ghostRecipe.addIngredient(ingredient, slot1.x, slot1.y) + } + } + } +} \ No newline at end of file From 3d4fdd8fb163985a2caca60faf001c3e6b9f1769 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 4 Oct 2023 12:17:54 +0100 Subject: [PATCH 17/51] Pushed the code --- .../blocks/IngotFusionTollEnhancer.java | 3 +- ...otFusionTollEnhancerRecipeBookComponent.kt | 41 +++++++++++++------ 2 files changed, 29 insertions(+), 15 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java index fd51c622..661d55a0 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java @@ -68,8 +68,7 @@ public static Component getContainerDescription() { try { Objects.requireNonNull(player, "Player is null"); Objects.requireNonNull(blockEntity, "BlockEntity is null"); - - NetworkHooks.openScreen((ServerPlayer) player, (IngotFusionTollEnhancerBlockEntity) blockEntity, blockPos); + player.openMenu((IngotFusionTollEnhancerBlockEntity) blockEntity); } catch (Exception e) { throw new RuntimeException("Failed to open screen." + e); } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookComponent.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookComponent.kt index 0989ff05..e2955a99 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookComponent.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookComponent.kt @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity @@ -25,23 +43,20 @@ class IngotFusionTollEnhancerRecipeBookComponent : RecipeBookComponent() { override fun setupGhostRecipe(pRecipe: Recipe<*>, pSlots: List) { val itemstack = pRecipe.getResultItem(minecraft.level!!.registryAccess()) - ghostRecipe.setRecipe(pRecipe) + ghostRecipe.recipe = pRecipe ghostRecipe.addIngredient(Ingredient.of(itemstack), pSlots[2].x, pSlots[2].y) val nonnulllist = pRecipe.ingredients val slot = pSlots[1] if (slot.item.isEmpty) { if (fuels == null) { - fuels = Ingredient.of( - this.fuelItems.stream().filter { it: Item -> - it.isEnabled( - minecraft.level!!.enabledFeatures() - ) - }.map { pItem: Item -> - ItemStack( - pItem - ) - } - ) + fuels = + Ingredient.of( + this.fuelItems + .stream() + .filter { it: Item -> + it.isEnabled(minecraft.level!!.enabledFeatures()) + } + .map { pItem: Item -> ItemStack(pItem) }) } ghostRecipe.addIngredient(fuels!!, slot.x, slot.y) } @@ -57,4 +72,4 @@ class IngotFusionTollEnhancerRecipeBookComponent : RecipeBookComponent() { } } } -} \ No newline at end of file +} From 4d6906b0380912fb61693248372aa8a95e5805c0 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 4 Oct 2023 17:25:29 +0100 Subject: [PATCH 18/51] Rewrote block entity to java --- build.gradle.kts | 14 + gradle.properties | 3 +- .../blocks/IngotFusionTollEnhancer.java | 279 ++++++----- .../CustomArmourCraftingTableScreen.java | 239 +++++----- .../fusion/IngotFusionTollEnhancerScreen.java | 174 ------- .../IngotFusionTollEnhancerBlockEntity.java | 395 ++++++++++++++++ .../IngotFusionTollEnhancerScreen.java | 211 +++++++++ .../blocks/lit/LITBlock.java | 262 +++++----- .../blocks/lit/LitBlockParticleColour.java | 25 +- .../blocks/lit/RainbowLitBlock.java | 13 +- .../blocks/lit/RubyLitBlock.java | 6 +- .../tool/CustomToolCraftingTableScreen.java | 239 +++++----- ...AndToolsModShieldItemRendererProvider.java | 26 +- ...ndToolsModTridentItemRendererProvider.java | 26 +- .../core/init/BlockEntityTypeInit.java | 17 +- .../core/init/EntityTypeInit.java | 28 +- .../IngotFusionTollEnhancerBlockEntity.kt | 447 ------------------ .../infusion/IngotFusionTollEnhancerMenu.kt | 5 +- .../armourandtoolsmod/client/ClientSetup.kt | 2 +- .../core/init/MenuTypeInit.kt | 1 + .../core/init/RecipeTypeInit.kt | 1 + 21 files changed, 1271 insertions(+), 1142 deletions(-) delete mode 100644 src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java create mode 100644 src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java create mode 100644 src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java delete mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt diff --git a/build.gradle.kts b/build.gradle.kts index a31af7c1..f57bfbea 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -129,6 +129,8 @@ configure { } } +configurations { compileOnly { extendsFrom(configurations.annotationProcessor.get()) } } + sourceSets.main { resources.srcDir("src/generated/resources") } repositories { @@ -155,6 +157,10 @@ dependencies { compileOnly(fg.deobf("mezz.jei:jei-${mcVersion}-common-api:" + properties["jeiVersion"])) compileOnly(fg.deobf("mezz.jei:jei-${mcVersion}-forge-api:" + properties["jeiVersion"])) runtimeOnly(fg.deobf("mezz.jei:jei-${mcVersion}-forge:" + properties["jeiVersion"])) + + // lombok + compileOnly("org.projectlombok:lombok:" + properties["lombokVersion"]) + annotationProcessor("org.projectlombok:lombok:" + properties["lombokVersion"]) } tasks.test { @@ -198,6 +204,14 @@ spotless { indentWithSpaces() endWithNewline() } + + java { + target("**/*.java") + googleJavaFormat() + trimTrailingWhitespace() + indentWithSpaces() + endWithNewline() + } } tasks.javadoc { diff --git a/gradle.properties b/gradle.properties index 7ca6c0db..1df42ef8 100644 --- a/gradle.properties +++ b/gradle.properties @@ -7,4 +7,5 @@ kotlinForForgeVersion = 4.4.0 logbackVersion = 1.4.11 junitVersion = 5.10.0 coreVersion = 1.20.1-1.0.1 -jeiVersion = 15.2.0.27 \ No newline at end of file +jeiVersion = 15.2.0.27 +lombokVersion = 1.18.30 \ No newline at end of file diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java index 661d55a0..8cf36a8d 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java @@ -2,11 +2,12 @@ import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit; +import java.util.List; +import java.util.Objects; import net.minecraft.core.BlockPos; import net.minecraft.core.Direction; import net.minecraft.network.chat.Component; import net.minecraft.server.level.ServerLevel; -import net.minecraft.server.level.ServerPlayer; import net.minecraft.world.Container; import net.minecraft.world.Containers; import net.minecraft.world.InteractionHand; @@ -29,144 +30,162 @@ import net.minecraft.world.level.block.state.properties.DirectionProperty; import net.minecraft.world.level.material.MapColor; import net.minecraft.world.phys.BlockHitResult; -import net.minecraftforge.network.NetworkHooks; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; -import java.util.List; -import java.util.Objects; - /** * @see net.minecraft.world.level.block.FurnaceBlock */ public class IngotFusionTollEnhancer extends BaseEntityBlock { - public static final BooleanProperty LIT = BlockStateProperties.LIT; - private static final DirectionProperty FACING = HorizontalDirectionalBlock.FACING; - - public IngotFusionTollEnhancer() { - super(BlockBehaviour.Properties.of() - .strength(5.0F, 6.0F) - .sound(SoundType.METAL) - .mapColor(MapColor.DIAMOND)); - this.registerDefaultState(defaultBlockState().setValue(FACING, Direction.NORTH).setValue(LIT, false)); - } - - public static @NotNull Component getContainerTitle() { - return Component.translatable("container.ingot_fusion_toll_enhancer"); - } - - public static Component getContainerDescription() { - return Component.translatable("container.ingot_fusion_toll_enhancer.description"); - } - - @Override - public @NotNull InteractionResult use(@NotNull BlockState blockState, @NotNull Level level, @NotNull BlockPos blockPos, @NotNull Player player, - @NotNull InteractionHand interactionHand, @NotNull BlockHitResult blockHitResult) { - if (!level.isClientSide) { - BlockEntity blockEntity = level.getBlockEntity(blockPos); - if (blockEntity instanceof IngotFusionTollEnhancerBlockEntity) { - try { - Objects.requireNonNull(player, "Player is null"); - Objects.requireNonNull(blockEntity, "BlockEntity is null"); - player.openMenu((IngotFusionTollEnhancerBlockEntity) blockEntity); - } catch (Exception e) { - throw new RuntimeException("Failed to open screen." + e); - } - } + public static final BooleanProperty LIT = BlockStateProperties.LIT; + private static final DirectionProperty FACING = HorizontalDirectionalBlock.FACING; + + public IngotFusionTollEnhancer() { + super( + BlockBehaviour.Properties.of() + .strength(5.0F, 6.0F) + .sound(SoundType.METAL) + .mapColor(MapColor.DIAMOND)); + this.registerDefaultState( + defaultBlockState().setValue(FACING, Direction.NORTH).setValue(LIT, false)); + } + + public static @NotNull Component getContainerTitle() { + return Component.translatable("container.ingot_fusion_toll_enhancer"); + } + + public static Component getContainerDescription() { + return Component.translatable("container.ingot_fusion_toll_enhancer.description"); + } + + @Override + public @NotNull InteractionResult use( + @NotNull BlockState blockState, + @NotNull Level level, + @NotNull BlockPos blockPos, + @NotNull Player player, + @NotNull InteractionHand interactionHand, + @NotNull BlockHitResult blockHitResult) { + if (!level.isClientSide) { + BlockEntity blockEntity = level.getBlockEntity(blockPos); + if (blockEntity instanceof IngotFusionTollEnhancerBlockEntity) { + try { + Objects.requireNonNull(player, "Player is null"); + Objects.requireNonNull(blockEntity, "BlockEntity is null"); + player.openMenu((IngotFusionTollEnhancerBlockEntity) blockEntity); + } catch (Exception e) { + throw new RuntimeException("Failed to open screen." + e); } - return InteractionResult.sidedSuccess(level.isClientSide); + } } - - @Override - public void onRemove(BlockState oldState, Level level, BlockPos blockPos, BlockState newState, boolean movedByPiston) { - if (!oldState.is(newState.getBlock())) { - BlockEntity blockEntity = level.getBlockEntity(blockPos); - if (blockEntity instanceof IngotFusionTollEnhancerBlockEntity) { - if (level instanceof ServerLevel) { - Containers.dropContents(level, blockPos, (Container) blockEntity); - level.updateNeighbourForOutputSignal(blockPos, this); - } - level.updateNeighbourForOutputSignal(blockPos, this); - } - super.onRemove(oldState, level, blockPos, newState, movedByPiston); + return InteractionResult.sidedSuccess(level.isClientSide); + } + + @Override + public void onRemove( + BlockState oldState, + Level level, + BlockPos blockPos, + BlockState newState, + boolean movedByPiston) { + if (!oldState.is(newState.getBlock())) { + BlockEntity blockEntity = level.getBlockEntity(blockPos); + if (blockEntity instanceof IngotFusionTollEnhancerBlockEntity) { + if (level instanceof ServerLevel) { + Containers.dropContents(level, blockPos, (Container) blockEntity); + level.updateNeighbourForOutputSignal(blockPos, this); } + level.updateNeighbourForOutputSignal(blockPos, this); + } + super.onRemove(oldState, level, blockPos, newState, movedByPiston); } - - @Nullable - @Override - public BlockEntity newBlockEntity(BlockPos pPos, BlockState pState) { - return new IngotFusionTollEnhancerBlockEntity(pPos, pState); - } - - @Override - public BlockState getStateForPlacement(BlockPlaceContext context) { - return this.defaultBlockState().setValue(FACING, context.getHorizontalDirection().getOpposite()); - } - - @Override - protected void createBlockStateDefinition(StateDefinition.Builder builder) { - builder.add(FACING, LIT); - } - - @Override - public boolean hasDynamicShape() { - return true; - } - - /** - * @deprecated call via {@link - * net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#hasAnalogOutputSignal} whenever possible. - * Implementing/overriding is fine. - */ - @Override - public boolean hasAnalogOutputSignal(BlockState pState) { - return true; - } - - /** - * The type of render function called. MODEL for mixed tesr and static model, MODELBLOCK_ANIMATED for TESR-only, - * LIQUID for vanilla liquids, INVISIBLE to skip all rendering - * - * @deprecated call via {@link net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#getRenderShape} - * whenever possible. Implementing/overriding is fine. - */ - public @NotNull RenderShape getRenderShape(BlockState pState) { - return RenderShape.MODEL; - } - - /** - * Returns the blockstate with the given rotation from the passed blockstate. If inapplicable, returns the passed - * blockstate. - * - * @deprecated call via {@link net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#rotate} whenever - * possible. Implementing/overriding is fine. - */ - @Override - public BlockState rotate(BlockState pState, Rotation pRotation) { - return pState.setValue(FACING, pRotation.rotate(pState.getValue(FACING))); - } - - /** - * Returns the blockstate with the given mirror of the passed blockstate. If inapplicable, returns the passed - * blockstate. - * - * @deprecated call via {@link net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#mirror} whenever - * possible. Implementing/overriding is fine. - */ - @Override - public @NotNull BlockState mirror(BlockState pState, Mirror pMirror) { - return pState.rotate(pMirror.getRotation(pState.getValue(FACING))); - } - - @Override - public void appendHoverText(ItemStack pStack, @Nullable BlockGetter pLevel, List pTooltip, TooltipFlag pFlag) { - pTooltip.add(getContainerDescription()); - } - - @Nullable - @Override - public BlockEntityTicker getTicker(Level level, BlockState state, - BlockEntityType type) { - return level.isClientSide ? null : createTickerHelper(type, BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), IngotFusionTollEnhancerBlockEntity::serverTick); - } + } + + @Nullable + @Override + public BlockEntity newBlockEntity(BlockPos pPos, BlockState pState) { + return new IngotFusionTollEnhancerBlockEntity(pPos, pState); + } + + @Override + public BlockState getStateForPlacement(BlockPlaceContext context) { + return this.defaultBlockState() + .setValue(FACING, context.getHorizontalDirection().getOpposite()); + } + + @Override + protected void createBlockStateDefinition(StateDefinition.Builder builder) { + builder.add(FACING, LIT); + } + + @Override + public boolean hasDynamicShape() { + return true; + } + + /** + * @deprecated call via {@link + * net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#hasAnalogOutputSignal} + * whenever possible. Implementing/overriding is fine. + */ + @Override + public boolean hasAnalogOutputSignal(BlockState pState) { + return true; + } + + /** + * The type of render function called. MODEL for mixed tesr and static model, MODELBLOCK_ANIMATED + * for TESR-only, LIQUID for vanilla liquids, INVISIBLE to skip all rendering + * + * @deprecated call via {@link + * net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#getRenderShape} + * whenever possible. Implementing/overriding is fine. + */ + public @NotNull RenderShape getRenderShape(BlockState pState) { + return RenderShape.MODEL; + } + + /** + * Returns the blockstate with the given rotation from the passed blockstate. If inapplicable, + * returns the passed blockstate. + * + * @deprecated call via {@link + * net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#rotate} whenever + * possible. Implementing/overriding is fine. + */ + @Override + public BlockState rotate(BlockState pState, Rotation pRotation) { + return pState.setValue(FACING, pRotation.rotate(pState.getValue(FACING))); + } + + /** + * Returns the blockstate with the given mirror of the passed blockstate. If inapplicable, returns + * the passed blockstate. + * + * @deprecated call via {@link + * net.minecraft.world.level.block.state.BlockBehaviour.BlockStateBase#mirror} whenever + * possible. Implementing/overriding is fine. + */ + @Override + public @NotNull BlockState mirror(BlockState pState, Mirror pMirror) { + return pState.rotate(pMirror.getRotation(pState.getValue(FACING))); + } + + @Override + public void appendHoverText( + ItemStack pStack, @Nullable BlockGetter pLevel, List pTooltip, TooltipFlag pFlag) { + pTooltip.add(getContainerDescription()); + } + + @Nullable + @Override + public BlockEntityTicker getTicker( + Level level, BlockState state, BlockEntityType type) { + return level.isClientSide + ? null + : createTickerHelper( + type, + BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), + IngotFusionTollEnhancerBlockEntity::serverTick); + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java index 6968197a..3ba775c7 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java @@ -1,5 +1,6 @@ package io.github.realyusufismail.armourandtoolsmod.blocks.armour; +import java.util.Objects; import net.minecraft.client.gui.GuiGraphics; import net.minecraft.client.gui.components.ImageButton; import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; @@ -12,115 +13,137 @@ import net.minecraft.world.inventory.Slot; import org.jetbrains.annotations.NotNull; -import java.util.Objects; - -public class CustomArmourCraftingTableScreen extends AbstractContainerScreen - implements RecipeUpdateListener { - private static final ResourceLocation CRAFTING_TABLE_LOCATION = - new ResourceLocation("textures/gui/container/crafting_table.png"); - private static final ResourceLocation RECIPE_BUTTON_LOCATION = - new ResourceLocation("textures/gui/recipe_button.png"); - private final RecipeBookComponent recipeBookComponent = new RecipeBookComponent(); - private boolean widthTooNarrow; - - public CustomArmourCraftingTableScreen(CustomArmourCraftingTableMenu pMenu, Inventory pPlayerInventory, - Component pTitle) { - super(pMenu, pPlayerInventory, pTitle); - } - - protected void init() { - super.init(); - this.widthTooNarrow = this.width < 379; - this.recipeBookComponent.init(this.width, this.height, Objects.requireNonNull(this.minecraft, "Minecraft is null in table screen"), this.widthTooNarrow, - this.menu); - this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); - this.addRenderableWidget(new ImageButton(this.leftPos + 5, this.height / 2 - 49, 20, 18, 0, - 0, 19, RECIPE_BUTTON_LOCATION, (p_98484_) -> { - this.recipeBookComponent.toggleVisibility(); - this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, - this.imageWidth); - p_98484_.setPosition(this.leftPos + 5, this.height / 2 - 49); - })); - this.addWidget(this.recipeBookComponent); - this.setInitialFocus(this.recipeBookComponent); - this.titleLabelX = 29; - } - - public void containerTick() { - super.containerTick(); - this.recipeBookComponent.tick(); - } - - /** - * Renders the graphical user interface (GUI) element. - * - * @param pGuiGraphics the GuiGraphics object used for rendering. - * @param pMouseX the x-coordinate of the mouse cursor. - * @param pMouseY the y-coordinate of the mouse cursor. - * @param pPartialTick the partial tick time. - */ - public void render(GuiGraphics pGuiGraphics, int pMouseX, int pMouseY, float pPartialTick) { - this.renderBackground(pGuiGraphics); - if (this.recipeBookComponent.isVisible() && this.widthTooNarrow) { - this.renderBg(pGuiGraphics, pPartialTick, pMouseX, pMouseY); - this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); - } else { - this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); - super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); - this.recipeBookComponent.renderGhostRecipe(pGuiGraphics, this.leftPos, this.topPos, true, pPartialTick); - } - - this.renderTooltip(pGuiGraphics, pMouseX, pMouseY); - this.recipeBookComponent.renderTooltip(pGuiGraphics, this.leftPos, this.topPos, pMouseX, pMouseY); - } - - protected void renderBg(GuiGraphics pGuiGraphics, float pPartialTick, int pMouseX, int pMouseY) { - int i = this.leftPos; - int j = (this.height - this.imageHeight) / 2; - pGuiGraphics.blit(CRAFTING_TABLE_LOCATION, i, j, 0, 0, this.imageWidth, this.imageHeight); - } - - protected boolean isHovering(int pX, int pY, int pWidth, int pHeight, double pMouseX, - double pMouseY) { - return (!this.widthTooNarrow || !this.recipeBookComponent.isVisible()) - && super.isHovering(pX, pY, pWidth, pHeight, pMouseX, pMouseY); - } - - public boolean mouseClicked(double pMouseX, double pMouseY, int pButton) { - if (this.recipeBookComponent.mouseClicked(pMouseX, pMouseY, pButton)) { - this.setFocused(this.recipeBookComponent); - return true; - } else { - return this.widthTooNarrow && this.recipeBookComponent.isVisible() || super.mouseClicked(pMouseX, pMouseY, pButton); - } - } - - protected boolean hasClickedOutside(double pMouseX, double pMouseY, int pGuiLeft, int pGuiTop, - int pMouseButton) { - boolean flag = pMouseX < (double) pGuiLeft || pMouseY < (double) pGuiTop - || pMouseX >= (double) (pGuiLeft + this.imageWidth) - || pMouseY >= (double) (pGuiTop + this.imageHeight); - return this.recipeBookComponent.hasClickedOutside(pMouseX, pMouseY, this.leftPos, - this.topPos, this.imageWidth, this.imageHeight, pMouseButton) && flag; - } - - /** - * Called when the mouse is clicked over a slot or outside the gui. - */ - protected void slotClicked(@NotNull Slot pSlot, int pSlotId, int pMouseButton, @NotNull ClickType pType) { - super.slotClicked(pSlot, pSlotId, pMouseButton, pType); - this.recipeBookComponent.slotClicked(pSlot); - } - - public void recipesUpdated() { - this.recipeBookComponent.recipesUpdated(); - } - - public void removed() { - super.removed(); +public class CustomArmourCraftingTableScreen + extends AbstractContainerScreen implements RecipeUpdateListener { + private static final ResourceLocation CRAFTING_TABLE_LOCATION = + new ResourceLocation("textures/gui/container/crafting_table.png"); + private static final ResourceLocation RECIPE_BUTTON_LOCATION = + new ResourceLocation("textures/gui/recipe_button.png"); + private final RecipeBookComponent recipeBookComponent = new RecipeBookComponent(); + private boolean widthTooNarrow; + + public CustomArmourCraftingTableScreen( + CustomArmourCraftingTableMenu pMenu, Inventory pPlayerInventory, Component pTitle) { + super(pMenu, pPlayerInventory, pTitle); + } + + protected void init() { + super.init(); + this.widthTooNarrow = this.width < 379; + this.recipeBookComponent.init( + this.width, + this.height, + Objects.requireNonNull(this.minecraft, "Minecraft is null in table screen"), + this.widthTooNarrow, + this.menu); + this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); + this.addRenderableWidget( + new ImageButton( + this.leftPos + 5, + this.height / 2 - 49, + 20, + 18, + 0, + 0, + 19, + RECIPE_BUTTON_LOCATION, + (p_98484_) -> { + this.recipeBookComponent.toggleVisibility(); + this.leftPos = + this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); + p_98484_.setPosition(this.leftPos + 5, this.height / 2 - 49); + })); + this.addWidget(this.recipeBookComponent); + this.setInitialFocus(this.recipeBookComponent); + this.titleLabelX = 29; + } + + public void containerTick() { + super.containerTick(); + this.recipeBookComponent.tick(); + } + + /** + * Renders the graphical user interface (GUI) element. + * + * @param pGuiGraphics the GuiGraphics object used for rendering. + * @param pMouseX the x-coordinate of the mouse cursor. + * @param pMouseY the y-coordinate of the mouse cursor. + * @param pPartialTick the partial tick time. + */ + public void render(GuiGraphics pGuiGraphics, int pMouseX, int pMouseY, float pPartialTick) { + this.renderBackground(pGuiGraphics); + if (this.recipeBookComponent.isVisible() && this.widthTooNarrow) { + this.renderBg(pGuiGraphics, pPartialTick, pMouseX, pMouseY); + this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + } else { + this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + this.recipeBookComponent.renderGhostRecipe( + pGuiGraphics, this.leftPos, this.topPos, true, pPartialTick); } - public @NotNull RecipeBookComponent getRecipeBookComponent() { - return this.recipeBookComponent; + this.renderTooltip(pGuiGraphics, pMouseX, pMouseY); + this.recipeBookComponent.renderTooltip( + pGuiGraphics, this.leftPos, this.topPos, pMouseX, pMouseY); + } + + protected void renderBg(GuiGraphics pGuiGraphics, float pPartialTick, int pMouseX, int pMouseY) { + int i = this.leftPos; + int j = (this.height - this.imageHeight) / 2; + pGuiGraphics.blit(CRAFTING_TABLE_LOCATION, i, j, 0, 0, this.imageWidth, this.imageHeight); + } + + protected boolean isHovering( + int pX, int pY, int pWidth, int pHeight, double pMouseX, double pMouseY) { + return (!this.widthTooNarrow || !this.recipeBookComponent.isVisible()) + && super.isHovering(pX, pY, pWidth, pHeight, pMouseX, pMouseY); + } + + public boolean mouseClicked(double pMouseX, double pMouseY, int pButton) { + if (this.recipeBookComponent.mouseClicked(pMouseX, pMouseY, pButton)) { + this.setFocused(this.recipeBookComponent); + return true; + } else { + return this.widthTooNarrow && this.recipeBookComponent.isVisible() + || super.mouseClicked(pMouseX, pMouseY, pButton); } + } + + protected boolean hasClickedOutside( + double pMouseX, double pMouseY, int pGuiLeft, int pGuiTop, int pMouseButton) { + boolean flag = + pMouseX < (double) pGuiLeft + || pMouseY < (double) pGuiTop + || pMouseX >= (double) (pGuiLeft + this.imageWidth) + || pMouseY >= (double) (pGuiTop + this.imageHeight); + return this.recipeBookComponent.hasClickedOutside( + pMouseX, + pMouseY, + this.leftPos, + this.topPos, + this.imageWidth, + this.imageHeight, + pMouseButton) + && flag; + } + + /** Called when the mouse is clicked over a slot or outside the gui. */ + protected void slotClicked( + @NotNull Slot pSlot, int pSlotId, int pMouseButton, @NotNull ClickType pType) { + super.slotClicked(pSlot, pSlotId, pMouseButton, pType); + this.recipeBookComponent.slotClicked(pSlot); + } + + public void recipesUpdated() { + this.recipeBookComponent.recipesUpdated(); + } + + public void removed() { + super.removed(); + } + + public @NotNull RecipeBookComponent getRecipeBookComponent() { + return this.recipeBookComponent; + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java deleted file mode 100644 index 1991afd1..00000000 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/fusion/IngotFusionTollEnhancerScreen.java +++ /dev/null @@ -1,174 +0,0 @@ -package io.github.realyusufismail.armourandtoolsmod.blocks.fusion; - -import com.mojang.blaze3d.systems.RenderSystem; -import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; -import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; -import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerMenu; -import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookComponent; -import net.minecraft.client.gui.GuiGraphics; -import net.minecraft.client.gui.components.ImageButton; -import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; -import net.minecraft.client.gui.screens.recipebook.RecipeBookComponent; -import net.minecraft.client.gui.screens.recipebook.RecipeUpdateListener; -import net.minecraft.network.chat.Component; -import net.minecraft.resources.ResourceLocation; -import net.minecraft.world.entity.player.Inventory; -import net.minecraft.world.inventory.ClickType; -import net.minecraft.world.inventory.Slot; -import org.jetbrains.annotations.NotNull; - -import java.util.Objects; - -/** - * @see net.minecraft.client.gui.screens.inventory.FurnaceScreen - */ -public class IngotFusionTollEnhancerScreen extends AbstractContainerScreen implements RecipeUpdateListener { - public static final ResourceLocation SCREEN_ID = ArmourAndToolsMod.ArmorAndToolsMod.getModIdAndName("textures/gui/container/ingot_fusion_toll_enhancer.png"); - public final IngotFusionTollEnhancerRecipeBookComponent recipeBookComponent = new IngotFusionTollEnhancerRecipeBookComponent(); - private static final ResourceLocation RECIPE_BUTTON_LOCATION = - new ResourceLocation("textures/gui/recipe_button.png"); - private boolean widthTooNarrow; - - public IngotFusionTollEnhancerScreen(IngotFusionTollEnhancerMenu pMenu, Inventory pPlayerInventory, Component pTitle) { - super(pMenu, pPlayerInventory, pTitle); - } - - protected void init() { - super.init(); - this.widthTooNarrow = this.width < 379; - this.recipeBookComponent.init(this.width, this.height, Objects.requireNonNull(this.minecraft, "Minecraft is null in table screen"), this.widthTooNarrow, - this.menu); - this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); - this.addRenderableWidget(new ImageButton(this.leftPos + 5, this.height / 2 - 49, 20, 18, 0, - 0, 19, RECIPE_BUTTON_LOCATION, (p_98484_) -> { - this.recipeBookComponent.toggleVisibility(); - this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, - this.imageWidth); - p_98484_.setPosition(this.leftPos + 5, this.height / 2 - 49); - })); - this.addWidget(this.recipeBookComponent); - this.setInitialFocus(this.recipeBookComponent); - this.titleLabelX = 29; - } - - public void containerTick() { - super.containerTick(); - this.recipeBookComponent.tick(); - } - - @Override - protected void renderBg(@NotNull GuiGraphics pGuiGraphics, float pPartialTick, int pMouseX, int pMouseY) { - try { - RenderSystem.setShaderColor(1.0F, 1.0F, 1.0F, 1.0F); - Objects.requireNonNull(minecraft, "Minecraft Instance is null").getTextureManager().bindForSetup(SCREEN_ID); - - int i = this.leftPos; - int j = this.topPos; - pGuiGraphics.blit(SCREEN_ID, i, j, 0, 0, 176, 179); - pGuiGraphics.blit(SCREEN_ID, i + 97, j + 38, 179, 25, menu.getLitProgress() + 1, 17); - } catch (NullPointerException e) { - throw new NullPointerException("Minecraft Instance is null"); - } - } - - @Override - public void render(@NotNull GuiGraphics pGuiGraphics, int pMouseX, int pMouseY, float pPartialTick) { - try { - this.renderBackground(pGuiGraphics); - - if (this.recipeBookComponent.isVisible() && this.widthTooNarrow) { - this.renderBg(pGuiGraphics, pPartialTick, pMouseX, pMouseY); - this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); - } else { - this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); - super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); - this.recipeBookComponent.renderGhostRecipe(pGuiGraphics, this.leftPos, this.topPos, true, pPartialTick); - } - - this.renderTooltip(pGuiGraphics, pMouseX, pMouseY); - this.recipeBookComponent.renderTooltip(pGuiGraphics, this.leftPos, this.topPos, pMouseX, pMouseY); - //super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); - } catch (NullPointerException e) { - throw new NullPointerException("Render method called before Minecraft Instance is set"); - } - } - - @Override - public void renderLabels(@NotNull GuiGraphics pGuiGraphics, int pMouseX, int pMouseY) { - try { - pGuiGraphics.drawString(this.font, this.playerInventoryTitle, 7, 81, 4210752, false); - pGuiGraphics.drawString(this.font, IngotFusionTollEnhancer.getContainerTitle(), 5, 10, 4210752, false); - } catch (NullPointerException e) { - throw new NullPointerException("Unable to render labels"); - } - } - - protected boolean isHovering(int pX, int pY, int pWidth, int pHeight, double pMouseX, - double pMouseY) { - return (!this.widthTooNarrow || !this.recipeBookComponent.isVisible()) - && super.isHovering(pX, pY, pWidth, pHeight, pMouseX, pMouseY); - } - - public boolean mouseClicked(double pMouseX, double pMouseY, int pButton) { - if (this.recipeBookComponent.mouseClicked(pMouseX, pMouseY, pButton)) { - this.setFocused(this.recipeBookComponent); - return true; - } else { - return this.widthTooNarrow && this.recipeBookComponent.isVisible() || super.mouseClicked(pMouseX, pMouseY, pButton); - } - } - - protected boolean hasClickedOutside(double pMouseX, double pMouseY, int pGuiLeft, int pGuiTop, - int pMouseButton) { - boolean flag = pMouseX < (double) pGuiLeft || pMouseY < (double) pGuiTop - || pMouseX >= (double) (pGuiLeft + this.imageWidth) - || pMouseY >= (double) (pGuiTop + this.imageHeight); - return this.recipeBookComponent.hasClickedOutside(pMouseX, pMouseY, this.leftPos, - this.topPos, this.imageWidth, this.imageHeight, pMouseButton) && flag; - } - - /** - * Called when the mouse is clicked over a slot or outside the gui. - */ - protected void slotClicked(@NotNull Slot pSlot, int pSlotId, int pMouseButton, @NotNull ClickType pType) { - super.slotClicked(pSlot, pSlotId, pMouseButton, pType); - this.recipeBookComponent.slotClicked(pSlot); - } - - - /** - * Called when a keyboard key is pressed within the GUI element. - *

- * @return {@code true} if the event is consumed, {@code false} otherwise. - * @param pKeyCode the key code of the pressed key. - * @param pScanCode the scan code of the pressed key. - * @param pModifiers the keyboard modifiers. - */ - public boolean keyPressed(int pKeyCode, int pScanCode, int pModifiers) { - return !this.recipeBookComponent.keyPressed(pKeyCode, pScanCode, pModifiers) && super.keyPressed(pKeyCode, pScanCode, pModifiers); - } - - /** - * Called when a character is typed within the GUI element. - *

- * @return {@code true} if the event is consumed, {@code false} otherwise. - * @param pCodePoint the code point of the typed character. - * @param pModifiers the keyboard modifiers. - */ - public boolean charTyped(char pCodePoint, int pModifiers) { - return this.recipeBookComponent.charTyped(pCodePoint, pModifiers) || super.charTyped(pCodePoint, pModifiers); - } - - public void recipesUpdated() { - this.recipeBookComponent.recipesUpdated(); - } - - public void removed() { - super.removed(); - } - - @Override - public @NotNull RecipeBookComponent getRecipeBookComponent() { - return recipeBookComponent; - } -} diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java new file mode 100644 index 00000000..daf34c62 --- /dev/null +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -0,0 +1,395 @@ +package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; + +import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; +import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit; +import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit; +import io.github.realyusufismail.armourandtoolsmod.core.init.ItemInit; +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit; +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe; +import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap; +import java.util.LinkedHashMap; +import java.util.Map; +import lombok.Getter; +import lombok.Setter; +import lombok.val; +import net.minecraft.SharedConstants; +import net.minecraft.Util; +import net.minecraft.core.BlockPos; +import net.minecraft.core.Direction; +import net.minecraft.core.NonNullList; +import net.minecraft.core.RegistryAccess; +import net.minecraft.network.chat.Component; +import net.minecraft.resources.ResourceLocation; +import net.minecraft.tags.ItemTags; +import net.minecraft.world.Container; +import net.minecraft.world.ContainerHelper; +import net.minecraft.world.WorldlyContainer; +import net.minecraft.world.entity.player.Inventory; +import net.minecraft.world.entity.player.Player; +import net.minecraft.world.entity.player.StackedContents; +import net.minecraft.world.inventory.AbstractContainerMenu; +import net.minecraft.world.inventory.ContainerData; +import net.minecraft.world.inventory.RecipeHolder; +import net.minecraft.world.inventory.StackedContentsCompatible; +import net.minecraft.world.item.Item; +import net.minecraft.world.item.ItemStack; +import net.minecraft.world.item.Items; +import net.minecraft.world.item.crafting.Recipe; +import net.minecraft.world.item.crafting.RecipeManager; +import net.minecraft.world.item.crafting.RecipeType; +import net.minecraft.world.level.Level; +import net.minecraft.world.level.block.Blocks; +import net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity; +import net.minecraft.world.level.block.entity.BaseContainerBlockEntity; +import net.minecraft.world.level.block.state.BlockState; +import net.minecraftforge.common.ForgeHooks; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; + +/** + * @see net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity + */ +public class IngotFusionTollEnhancerBlockEntity extends BaseContainerBlockEntity + implements WorldlyContainer, RecipeHolder, StackedContentsCompatible { + + @Getter + private final RecipeManager.CachedCheck quickCheck; + + @Getter + private final NonNullList items = + NonNullList.withSize(NUMBER_OF_SLOTS, ItemStack.EMPTY); + + private final Object2IntOpenHashMap recipesUsed = new Object2IntOpenHashMap<>(); + private final RecipeType type = + RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(); + protected static final int SLOT_INPUT_1 = 0; + protected static final int SLOT_INPUT_2 = 1; + protected static final int SLOT_INPUT_3 = 2; + protected static final int SLOT_FUEL = 3; + protected static final int SLOT_RESULT = 4; + public static final int NUMBER_OF_SLOTS = 5; + private static final int[] SLOTS_FOR_UP = new int[] {0}; + private static final int[] SLOTS_FOR_DOWN = new int[] {4, 3}; + private static final int[] SLOTS_FOR_SIDES = new int[] {1, 2}; + @Getter @Setter int litTime; + @Getter @Setter int litDuration; + @Getter @Setter int creatingTime; + @Getter @Setter int creatingTotalTime; + + public IngotFusionTollEnhancerBlockEntity(BlockPos blockPos, BlockState blockState) { + super(BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), blockPos, blockState); + + this.quickCheck = RecipeManager.createCheck(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()); + } + + protected final ContainerData dataAccess = + new ContainerData() { + public int get(int p_58431_) { + return switch (p_58431_) { + case 0 -> litTime; + case 1 -> litDuration; + case 2 -> creatingTime; + case 3 -> creatingTotalTime; + default -> 0; + }; + } + + public void set(int p_58433_, int p_58434_) { + switch (p_58433_) { + case 0 -> litTime = p_58434_; + case 1 -> litDuration = p_58434_; + case 2 -> creatingTime = p_58434_; + case 3 -> creatingTotalTime = p_58434_; + } + } + + public int getCount() { + return 4; + } + }; + + @Override + public int @NotNull [] getSlotsForFace(Direction pSide) { + if (pSide == Direction.DOWN) { + return SLOTS_FOR_DOWN; + } else { + return pSide == Direction.UP ? SLOTS_FOR_UP : SLOTS_FOR_SIDES; + } + } + + @Override + public boolean canPlaceItemThroughFace( + int pIndex, ItemStack pItemStack, @Nullable Direction pDirection) { + return this.canPlaceItem(pIndex, pItemStack); + } + + @Override + public boolean canTakeItemThroughFace(int pIndex, ItemStack pStack, Direction pDirection) { + if (pDirection == Direction.DOWN && pIndex == 1) { + return pStack.is(Items.WATER_BUCKET) || pStack.is(Items.BUCKET); + } else { + return true; + } + } + + @Override + protected @NotNull Component getDefaultName() { + return IngotFusionTollEnhancer.getContainerTitle(); + } + + @Override + protected @NotNull AbstractContainerMenu createMenu(int pContainerId, Inventory pInventory) { + return new IngotFusionTollEnhancerMenu(pContainerId, this, dataAccess, pInventory); + } + + @Override + public int getContainerSize() { + return items.size(); + } + + @Override + public boolean isEmpty() { + for (ItemStack itemStack : items) { + if (!itemStack.isEmpty()) { + return false; + } + } + return true; + } + + @Override + public @NotNull ItemStack getItem(int pSlot) { + return items.get(pSlot); + } + + @Override + public @NotNull ItemStack removeItem(int pSlot, int pAmount) { + return ContainerHelper.removeItem(items, pSlot, pAmount); + } + + @Override + public ItemStack removeItemNoUpdate(int pSlot) { + return ContainerHelper.takeItem(items, pSlot); + } + + @Override + public void setItem(int pSlot, ItemStack pStack) { + val itemstack = this.items.get(pSlot); + val flag = !pStack.isEmpty() && ItemStack.isSameItemSameTags(itemstack, pStack); + this.items.set(pSlot, pStack); + if (pStack.getCount() > this.getMaxStackSize()) { + pStack.setCount(this.getMaxStackSize()); + } + + if (pSlot == 0 && !flag) { + this.creatingTotalTime = getTotalCraftTime(this.level, this); + this.creatingTime = 0; + this.setChanged(); + } + } + + @Override + public boolean stillValid(Player pPlayer) { + return Container.stillValidBlockEntity(this, pPlayer); + } + + @Override + public void clearContent() { + items.clear(); + } + + @Override + public void setRecipeUsed(@Nullable Recipe pRecipe) { + if (pRecipe != null) { + ResourceLocation resourcelocation = pRecipe.getId(); + this.recipesUsed.addTo(resourcelocation, 1); + } + } + + @Nullable + @Override + public Recipe getRecipeUsed() { + return null; + } + + @Override + public void fillStackedContents(StackedContents pContents) { + for (ItemStack itemstack : this.items) { + pContents.accountStack(itemstack); + } + } + + private boolean isLit() { + return this.litTime > 0; + } + + public static void serverTick( + Level level, BlockPos pPos, BlockState pState, IngotFusionTollEnhancerBlockEntity pEntity) { + val flag = pEntity.isLit(); + var flag1 = false; + + if (pEntity.isLit()) { + pEntity.setLitTime(pEntity.getLitTime() - 1); + } + + val itemstack = pEntity.getItems().get(1); + val flag2 = !pEntity.getItems().get(0).isEmpty(); + val flag3 = !itemstack.isEmpty(); + + if (pEntity.isLit() || (flag3 && flag2)) { + Recipe recipe = + flag2 ? pEntity.getQuickCheck().getRecipeFor(pEntity, level).orElse(null) : null; + int i = pEntity.getMaxStackSize(); + + if (!pEntity.isLit() + && pEntity.canCreate(level.registryAccess(), recipe, pEntity.getItems(), i)) { + pEntity.setLitTime(pEntity.getTotalCraftTime(itemstack)); + pEntity.setLitDuration(pEntity.getLitTime()); + + if (pEntity.isLit()) { + flag1 = true; + + if (itemstack.hasCraftingRemainingItem()) { + pEntity.getItems().set(1, itemstack.getCraftingRemainingItem()); + } else if (flag3) { + Item item = itemstack.getItem(); + itemstack.shrink(1); + + if (itemstack.isEmpty()) { + pEntity.getItems().set(1, itemstack.getCraftingRemainingItem()); + } + } + } + } + + if (pEntity.isLit() + && pEntity.canCreate(level.registryAccess(), recipe, pEntity.getItems(), i)) { + pEntity.setCreatingTime(pEntity.getCreatingTime() + 1); + + if (pEntity.getCreatingTime() == pEntity.getCreatingTotalTime()) { + pEntity.setCreatingTime(0); + pEntity.setCreatingTotalTime(getTotalCraftTime(level, pEntity)); + + if (pEntity.craft(level.registryAccess(), recipe, pEntity.getItems(), i)) { + pEntity.setRecipeUsed(recipe); + } + flag1 = true; + } + } else { + pEntity.setCreatingTime(0); + } + } else if (!pEntity.isLit() && pEntity.getCreatingTime() > 0) { + pEntity.setCreatingTime(Math.max(pEntity.getCreatingTime() - 2, 0)); + } + + BlockState state = pState; + + if (flag != pEntity.isLit()) { + flag1 = true; + state = pState.setValue(IngotFusionTollEnhancer.LIT, pEntity.isLit()); + level.setBlock(pPos, state, 3); + } + + if (flag1) { + setChanged(level, pPos, state); + } + } + + private boolean canCreate( + RegistryAccess pRegistryAccess, + @Nullable Recipe pRecipe, + NonNullList pItems, + int pMaxStackSize) { + if (!pItems.get(0).isEmpty() && pRecipe != null) { + val itemstack = ((Recipe) pRecipe).assemble(this, pRegistryAccess); + if (itemstack.isEmpty()) { + return false; + } else { + // TODO: Check this + val itemstack1 = pItems.get(4); + if (itemstack1.isEmpty()) { + return true; + } else if (!ItemStack.isSameItem(itemstack1, itemstack)) { + return false; + } else if (itemstack1.getCount() + itemstack.getCount() <= pMaxStackSize + && itemstack1.getCount() + itemstack.getCount() <= itemstack1.getMaxStackSize()) { + return true; + } else { + return itemstack1.getCount() + itemstack.getCount() <= itemstack.getMaxStackSize(); + } + } + } else { + return false; + } + } + + private boolean craft( + RegistryAccess registryAccess, + Recipe recipe, + NonNullList inventroy, + Integer maxStackSize) { + if (recipe != null && canCreate(registryAccess, recipe, inventroy, maxStackSize)) { + val itemstack = inventroy.get(0); + val itemstack1 = ((Recipe) recipe).assemble(this, registryAccess); + val itemstack2 = inventroy.get(4); + if (itemstack2.isEmpty()) { + inventroy.set(4, itemstack1.copy()); + } else { + itemstack2.is(itemstack1.getItem()); + } + + if (itemstack.is(Blocks.WET_SPONGE.asItem()) + && !inventroy.get(1).isEmpty() + && inventroy.get(1).is(Items.BUCKET)) { + inventroy.set(1, new ItemStack(Items.WATER_BUCKET)); + } + + itemstack.shrink(1); + return true; + } else { + return false; + } + } + + private Integer getTotalCraftTime(ItemStack itemStack) { + if (itemStack.isEmpty()) { + return 0; + } else { + return ForgeHooks.getBurnTime(itemStack, RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()); + } + } + + private static int getTotalCraftTime( + Level pLevel, IngotFusionTollEnhancerBlockEntity pBlockEntity) { + return pBlockEntity + .getQuickCheck() + .getRecipeFor(pBlockEntity, pLevel) + .map(IngotFusionTollEnhancerRecipe::getCraftTime) + .orElse(200); + } + + public static Map getFuels() { + Map map = new LinkedHashMap<>(AbstractFurnaceBlockEntity.getFuel()); + addFuel(map, ItemInit.INSTANCE.getGRAPHITE().get(), 200); + addFuel(map, BlockInit.INSTANCE.getGRAPHITE_BLOCK().get().asItem(), 2000); + return map; + } + + public static void addFuel(Map pMap, Item fuel, int pBurnTime) { + if (!isNeverAIngotFusionTollEnhanceFuel(fuel)) { + pMap.put(fuel, pBurnTime); + } else { + if (SharedConstants.IS_RUNNING_IN_IDE) { + throw (Util.pauseInIde( + new IllegalStateException( + "A developer tried to explicitly make fire resistant item " + + fuel.getName(null).getString() + + " a IngotFusionTollEnhancer fuel. That will not work!"))); + } + } + } + + public static boolean isNeverAIngotFusionTollEnhanceFuel(Item pItem) { + return pItem.builtInRegistryHolder().is(ItemTags.NON_FLAMMABLE_WOOD); + } +} diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java new file mode 100644 index 00000000..f5f26f16 --- /dev/null +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java @@ -0,0 +1,211 @@ +package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; + +import com.mojang.blaze3d.systems.RenderSystem; +import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; +import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookComponent; +import java.util.Objects; +import net.minecraft.client.gui.GuiGraphics; +import net.minecraft.client.gui.components.ImageButton; +import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; +import net.minecraft.client.gui.screens.recipebook.RecipeBookComponent; +import net.minecraft.client.gui.screens.recipebook.RecipeUpdateListener; +import net.minecraft.network.chat.Component; +import net.minecraft.resources.ResourceLocation; +import net.minecraft.world.entity.player.Inventory; +import net.minecraft.world.inventory.ClickType; +import net.minecraft.world.inventory.Slot; +import org.jetbrains.annotations.NotNull; + +/** + * @see net.minecraft.client.gui.screens.inventory.FurnaceScreen + */ +public class IngotFusionTollEnhancerScreen + extends AbstractContainerScreen implements RecipeUpdateListener { + public static final ResourceLocation SCREEN_ID = + ArmourAndToolsMod.ArmorAndToolsMod.getModIdAndName( + "textures/gui/container/ingot_fusion_toll_enhancer.png"); + public final IngotFusionTollEnhancerRecipeBookComponent recipeBookComponent = + new IngotFusionTollEnhancerRecipeBookComponent(); + private static final ResourceLocation RECIPE_BUTTON_LOCATION = + new ResourceLocation("textures/gui/recipe_button.png"); + private boolean widthTooNarrow; + + public IngotFusionTollEnhancerScreen( + IngotFusionTollEnhancerMenu pMenu, Inventory pPlayerInventory, Component pTitle) { + super(pMenu, pPlayerInventory, pTitle); + } + + protected void init() { + super.init(); + this.widthTooNarrow = this.width < 379; + this.recipeBookComponent.init( + this.width, + this.height, + Objects.requireNonNull(this.minecraft, "Minecraft is null in table screen"), + this.widthTooNarrow, + this.menu); + this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); + this.addRenderableWidget( + new ImageButton( + this.leftPos + 5, + this.height / 2 - 49, + 20, + 18, + 0, + 0, + 19, + RECIPE_BUTTON_LOCATION, + (p_98484_) -> { + this.recipeBookComponent.toggleVisibility(); + this.leftPos = + this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); + p_98484_.setPosition(this.leftPos + 5, this.height / 2 - 49); + })); + this.addWidget(this.recipeBookComponent); + this.setInitialFocus(this.recipeBookComponent); + this.titleLabelX = 29; + } + + public void containerTick() { + super.containerTick(); + this.recipeBookComponent.tick(); + } + + @Override + protected void renderBg( + @NotNull GuiGraphics pGuiGraphics, float pPartialTick, int pMouseX, int pMouseY) { + try { + RenderSystem.setShaderColor(1.0F, 1.0F, 1.0F, 1.0F); + Objects.requireNonNull(minecraft, "Minecraft Instance is null") + .getTextureManager() + .bindForSetup(SCREEN_ID); + + int i = this.leftPos; + int j = this.topPos; + pGuiGraphics.blit(SCREEN_ID, i, j, 0, 0, 176, 179); + pGuiGraphics.blit(SCREEN_ID, i + 97, j + 38, 179, 25, menu.getLitProgress() + 1, 17); + } catch (NullPointerException e) { + throw new NullPointerException("Minecraft Instance is null"); + } + } + + @Override + public void render( + @NotNull GuiGraphics pGuiGraphics, int pMouseX, int pMouseY, float pPartialTick) { + try { + this.renderBackground(pGuiGraphics); + + if (this.recipeBookComponent.isVisible() && this.widthTooNarrow) { + this.renderBg(pGuiGraphics, pPartialTick, pMouseX, pMouseY); + this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + } else { + this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + this.recipeBookComponent.renderGhostRecipe( + pGuiGraphics, this.leftPos, this.topPos, true, pPartialTick); + } + + this.renderTooltip(pGuiGraphics, pMouseX, pMouseY); + this.recipeBookComponent.renderTooltip( + pGuiGraphics, this.leftPos, this.topPos, pMouseX, pMouseY); + // super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + } catch (NullPointerException e) { + throw new NullPointerException("Render method called before Minecraft Instance is set"); + } + } + + @Override + public void renderLabels(@NotNull GuiGraphics pGuiGraphics, int pMouseX, int pMouseY) { + try { + pGuiGraphics.drawString(this.font, this.playerInventoryTitle, 7, 81, 4210752, false); + pGuiGraphics.drawString( + this.font, IngotFusionTollEnhancer.getContainerTitle(), 5, 10, 4210752, false); + } catch (NullPointerException e) { + throw new NullPointerException("Unable to render labels"); + } + } + + protected boolean isHovering( + int pX, int pY, int pWidth, int pHeight, double pMouseX, double pMouseY) { + return (!this.widthTooNarrow || !this.recipeBookComponent.isVisible()) + && super.isHovering(pX, pY, pWidth, pHeight, pMouseX, pMouseY); + } + + public boolean mouseClicked(double pMouseX, double pMouseY, int pButton) { + if (this.recipeBookComponent.mouseClicked(pMouseX, pMouseY, pButton)) { + this.setFocused(this.recipeBookComponent); + return true; + } else { + return this.widthTooNarrow && this.recipeBookComponent.isVisible() + || super.mouseClicked(pMouseX, pMouseY, pButton); + } + } + + protected boolean hasClickedOutside( + double pMouseX, double pMouseY, int pGuiLeft, int pGuiTop, int pMouseButton) { + boolean flag = + pMouseX < (double) pGuiLeft + || pMouseY < (double) pGuiTop + || pMouseX >= (double) (pGuiLeft + this.imageWidth) + || pMouseY >= (double) (pGuiTop + this.imageHeight); + return this.recipeBookComponent.hasClickedOutside( + pMouseX, + pMouseY, + this.leftPos, + this.topPos, + this.imageWidth, + this.imageHeight, + pMouseButton) + && flag; + } + + /** Called when the mouse is clicked over a slot or outside the gui. */ + protected void slotClicked( + @NotNull Slot pSlot, int pSlotId, int pMouseButton, @NotNull ClickType pType) { + super.slotClicked(pSlot, pSlotId, pMouseButton, pType); + this.recipeBookComponent.slotClicked(pSlot); + } + + /** + * Called when a keyboard key is pressed within the GUI element. + * + *

+ * + * @return {@code true} if the event is consumed, {@code false} otherwise. + * @param pKeyCode the key code of the pressed key. + * @param pScanCode the scan code of the pressed key. + * @param pModifiers the keyboard modifiers. + */ + public boolean keyPressed(int pKeyCode, int pScanCode, int pModifiers) { + return !this.recipeBookComponent.keyPressed(pKeyCode, pScanCode, pModifiers) + && super.keyPressed(pKeyCode, pScanCode, pModifiers); + } + + /** + * Called when a character is typed within the GUI element. + * + *

+ * + * @return {@code true} if the event is consumed, {@code false} otherwise. + * @param pCodePoint the code point of the typed character. + * @param pModifiers the keyboard modifiers. + */ + public boolean charTyped(char pCodePoint, int pModifiers) { + return this.recipeBookComponent.charTyped(pCodePoint, pModifiers) + || super.charTyped(pCodePoint, pModifiers); + } + + public void recipesUpdated() { + this.recipeBookComponent.recipesUpdated(); + } + + public void removed() { + super.removed(); + } + + @Override + public @NotNull RecipeBookComponent getRecipeBookComponent() { + return recipeBookComponent; + } +} diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LITBlock.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LITBlock.java index 54fcbb84..ef8eb119 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LITBlock.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LITBlock.java @@ -1,6 +1,10 @@ package io.github.realyusufismail.armourandtoolsmod.blocks.lit; import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.function.ToIntFunction; import net.minecraft.core.BlockPos; import net.minecraft.core.Direction; import net.minecraft.server.level.ServerLevel; @@ -22,11 +26,6 @@ import net.minecraft.world.level.material.MapColor; import net.minecraft.world.phys.BlockHitResult; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.function.ToIntFunction; - /** * A block that emits light when stepped on. * @@ -34,118 +33,161 @@ */ @SuppressWarnings("deprecation") public class LITBlock extends Block { - public static final BooleanProperty LIT = RedstoneTorchBlock.LIT; - public static Map> particleColours = new HashMap<>(); - - protected LITBlock(List particleColour, int lightLevel, Class blockClass) { - super(Properties.of() - .requiresCorrectToolForDrops() - .randomTicks() - .lightLevel(litBlockEmission(lightLevel)) - .mapColor(MapColor.METAL) - .strength(3.0f, 3.0f)); - - particleColours.put(blockClass, particleColour); - this.registerDefaultState(this.defaultBlockState().setValue(LIT, Boolean.FALSE)); + public static final BooleanProperty LIT = RedstoneTorchBlock.LIT; + public static Map> particleColours = new HashMap<>(); + + protected LITBlock( + List particleColour, int lightLevel, Class blockClass) { + super( + Properties.of() + .requiresCorrectToolForDrops() + .randomTicks() + .lightLevel(litBlockEmission(lightLevel)) + .mapColor(MapColor.METAL) + .strength(3.0f, 3.0f)); + + particleColours.put(blockClass, particleColour); + this.registerDefaultState(this.defaultBlockState().setValue(LIT, Boolean.FALSE)); + } + + private static void interact(BlockState pState, Level pLevel, BlockPos pPos) { + spawnParticles(pLevel, pPos); + if (!pState.getValue(LIT)) { + pLevel.setBlock(pPos, pState.setValue(LIT, Boolean.valueOf(true)), 3); } - - private static void interact(BlockState pState, Level pLevel, BlockPos pPos) { - spawnParticles(pLevel, pPos); - if (!pState.getValue(LIT)) { - pLevel.setBlock(pPos, pState.setValue(LIT, Boolean.valueOf(true)), 3); - } + } + + protected static void spawnParticles(Level pLevel, BlockPos pPos) { + RandomSource randomsource = pLevel.random; + + for (Direction direction : Direction.values()) { + BlockPos blockpos = pPos.relative(direction); + if (!pLevel.getBlockState(blockpos).isSolidRender(pLevel, blockpos)) { + Direction.Axis direction$axis = direction.getAxis(); + double d1 = + direction$axis == Direction.Axis.X + ? 0.5D + 0.5625D * (double) direction.getStepX() + : (double) randomsource.nextFloat(); + double d2 = + direction$axis == Direction.Axis.Y + ? 0.5D + 0.5625D * (double) direction.getStepY() + : (double) randomsource.nextFloat(); + double d3 = + direction$axis == Direction.Axis.Z + ? 0.5D + 0.5625D * (double) direction.getStepZ() + : (double) randomsource.nextFloat(); + + var block = pLevel.getBlockState(pPos).getBlock(); + var particleColours = LITBlock.particleColours.get(block.getClass()); + var colour = particleColours.get(randomsource.nextInt(particleColours.size())); + ArmourAndToolsMod.ArmorAndToolsMod.getLogger() + .debug( + "Colour: " + + colour + + "for block: " + + block.getClass().getName() + + " at pos: " + + pPos + + " with particleColours: " + + particleColours); + pLevel.addParticle( + colour.getParticleOption(), + (double) pPos.getX() + d1, + (double) pPos.getY() + d2, + (double) pPos.getZ() + d3, + 0.0D, + 0.0D, + 0.0D); + } } - - protected static void spawnParticles(Level pLevel, BlockPos pPos) { - RandomSource randomsource = pLevel.random; - - for (Direction direction : Direction.values()) { - BlockPos blockpos = pPos.relative(direction); - if (!pLevel.getBlockState(blockpos).isSolidRender(pLevel, blockpos)) { - Direction.Axis direction$axis = direction.getAxis(); - double d1 = direction$axis == Direction.Axis.X ? 0.5D + 0.5625D * (double) direction.getStepX() : (double) randomsource.nextFloat(); - double d2 = direction$axis == Direction.Axis.Y ? 0.5D + 0.5625D * (double) direction.getStepY() : (double) randomsource.nextFloat(); - double d3 = direction$axis == Direction.Axis.Z ? 0.5D + 0.5625D * (double) direction.getStepZ() : (double) randomsource.nextFloat(); - - var block = pLevel.getBlockState(pPos).getBlock(); - var particleColours = LITBlock.particleColours.get(block.getClass()); - var colour = particleColours.get(randomsource.nextInt(particleColours.size())); - ArmourAndToolsMod.ArmorAndToolsMod.getLogger().debug("Colour: " + colour + "for block: " + block.getClass().getName() + " at pos: " + pPos + " with particleColours: " + particleColours); - pLevel.addParticle(colour.getParticleOption(), (double) pPos.getX() + d1, (double) pPos.getY() + d2, (double) pPos.getZ() + d3, 0.0D, 0.0D, 0.0D); - } - } + } + + private static ToIntFunction litBlockEmission(int pLightValue) { + return (p_50763_) -> { + return p_50763_.getValue(BlockStateProperties.LIT) ? pLightValue : 0; + }; + } + + public void attack(BlockState pState, Level pLevel, BlockPos pPos, Player pPlayer) { + interact(pState, pLevel, pPos); + super.attack(pState, pLevel, pPos, pPlayer); + } + + public void stepOn(Level pLevel, BlockPos pPos, BlockState pState, Entity pEntity) { + if (!pEntity.isSteppingCarefully()) { + interact(pState, pLevel, pPos); } - private static ToIntFunction litBlockEmission(int pLightValue) { - return (p_50763_) -> { - return p_50763_.getValue(BlockStateProperties.LIT) ? pLightValue : 0; - }; + super.stepOn(pLevel, pPos, pState, pEntity); + } + + public InteractionResult use( + BlockState pState, + Level pLevel, + BlockPos pPos, + Player pPlayer, + InteractionHand pHand, + BlockHitResult pHit) { + if (pLevel.isClientSide) { + spawnParticles(pLevel, pPos); + } else { + interact(pState, pLevel, pPos); } - public void attack(BlockState pState, Level pLevel, BlockPos pPos, Player pPlayer) { - interact(pState, pLevel, pPos); - super.attack(pState, pLevel, pPos, pPlayer); + ItemStack itemstack = pPlayer.getItemInHand(pHand); + return itemstack.getItem() instanceof BlockItem + && (new BlockPlaceContext(pPlayer, pHand, itemstack, pHit)).canPlace() + ? InteractionResult.PASS + : InteractionResult.SUCCESS; + } + + /** + * @return whether this block needs random ticking. + */ + public boolean isRandomlyTicking(BlockState pState) { + return pState.getValue(LIT); + } + + /** Performs a random tick on a block. */ + public void randomTick( + BlockState pState, ServerLevel pLevel, BlockPos pPos, RandomSource pRandom) { + if (pState.getValue(LIT)) { + pLevel.setBlock(pPos, pState.setValue(LIT, Boolean.valueOf(false)), 3); } - - public void stepOn(Level pLevel, BlockPos pPos, BlockState pState, Entity pEntity) { - if (!pEntity.isSteppingCarefully()) { - interact(pState, pLevel, pPos); - } - - super.stepOn(pLevel, pPos, pState, pEntity); + } + + /** Perform side-effects from block dropping, such as creating silverfish */ + public void spawnAfterBreak( + BlockState pState, + ServerLevel pLevel, + BlockPos pPos, + ItemStack pStack, + boolean pDropExperience) { + super.spawnAfterBreak(pState, pLevel, pPos, pStack, pDropExperience); + } + + @Override + public int getExpDrop( + BlockState state, + net.minecraft.world.level.LevelReader world, + RandomSource randomSource, + BlockPos pos, + int fortune, + int silktouch) { + return silktouch == 0 ? 1 + randomSource.nextInt(5) : 0; + } + + /** + * Called periodically clientside on blocks near the player to show effects (like furnace fire + * particles). + */ + public void animateTick(BlockState pState, Level pLevel, BlockPos pPos, RandomSource pRandom) { + if (pState.getValue(LIT)) { + spawnParticles(pLevel, pPos); } + } - public InteractionResult use(BlockState pState, Level pLevel, BlockPos pPos, Player pPlayer, InteractionHand pHand, BlockHitResult pHit) { - if (pLevel.isClientSide) { - spawnParticles(pLevel, pPos); - } else { - interact(pState, pLevel, pPos); - } - - ItemStack itemstack = pPlayer.getItemInHand(pHand); - return itemstack.getItem() instanceof BlockItem && (new BlockPlaceContext(pPlayer, pHand, itemstack, pHit)).canPlace() ? InteractionResult.PASS : InteractionResult.SUCCESS; - } - - /** - * @return whether this block needs random ticking. - */ - public boolean isRandomlyTicking(BlockState pState) { - return pState.getValue(LIT); - } - - /** - * Performs a random tick on a block. - */ - public void randomTick(BlockState pState, ServerLevel pLevel, BlockPos pPos, RandomSource pRandom) { - if (pState.getValue(LIT)) { - pLevel.setBlock(pPos, pState.setValue(LIT, Boolean.valueOf(false)), 3); - } - - } - - /** - * Perform side-effects from block dropping, such as creating silverfish - */ - public void spawnAfterBreak(BlockState pState, ServerLevel pLevel, BlockPos pPos, ItemStack pStack, boolean pDropExperience) { - super.spawnAfterBreak(pState, pLevel, pPos, pStack, pDropExperience); - } - - @Override - public int getExpDrop(BlockState state, net.minecraft.world.level.LevelReader world, RandomSource randomSource, BlockPos pos, int fortune, int silktouch) { - return silktouch == 0 ? 1 + randomSource.nextInt(5) : 0; - } - - /** - * Called periodically clientside on blocks near the player to show effects (like furnace fire particles). - */ - public void animateTick(BlockState pState, Level pLevel, BlockPos pPos, RandomSource pRandom) { - if (pState.getValue(LIT)) { - spawnParticles(pLevel, pPos); - } - - } - - protected void createBlockStateDefinition(StateDefinition.Builder pBuilder) { - pBuilder.add(LIT); - } + protected void createBlockStateDefinition(StateDefinition.Builder pBuilder) { + pBuilder.add(LIT); + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LitBlockParticleColour.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LitBlockParticleColour.java index ab734fb6..f6ae7e3f 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LitBlockParticleColour.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LitBlockParticleColour.java @@ -5,20 +5,19 @@ import org.joml.Vector3f; public enum LitBlockParticleColour { - RAINBOW_PARTICLE_COLOR_PURPLE(Vec3.fromRGB24(148000211).toVector3f()), - RAINBOW_PARTICLE_COLOR_RED(Vec3.fromRGB24(16711680).toVector3f()), - RAINBOW_PARTICLE_COLOR_GREEN(Vec3.fromRGB24(65280).toVector3f()), - RAINBOW_PARTICLE_COLOR_BLUE(Vec3.fromRGB24(255).toVector3f()), - RUBY_PARTICLE_COLOR(Vec3.fromRGB24(14684511).toVector3f()); + RAINBOW_PARTICLE_COLOR_PURPLE(Vec3.fromRGB24(148000211).toVector3f()), + RAINBOW_PARTICLE_COLOR_RED(Vec3.fromRGB24(16711680).toVector3f()), + RAINBOW_PARTICLE_COLOR_GREEN(Vec3.fromRGB24(65280).toVector3f()), + RAINBOW_PARTICLE_COLOR_BLUE(Vec3.fromRGB24(255).toVector3f()), + RUBY_PARTICLE_COLOR(Vec3.fromRGB24(14684511).toVector3f()); + private final Vector3f colour; - private final Vector3f colour; + LitBlockParticleColour(Vector3f colour) { + this.colour = colour; + } - LitBlockParticleColour(Vector3f colour) { - this.colour = colour; - } - - public DustParticleOptions getParticleOption() { - return new DustParticleOptions(colour, 1.0f); - } + public DustParticleOptions getParticleOption() { + return new DustParticleOptions(colour, 1.0f); + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RainbowLitBlock.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RainbowLitBlock.java index 605dd601..525d78ab 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RainbowLitBlock.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RainbowLitBlock.java @@ -3,7 +3,14 @@ import java.util.List; public class RainbowLitBlock extends LITBlock { - public RainbowLitBlock() { - super(List.of(LitBlockParticleColour.RAINBOW_PARTICLE_COLOR_RED, LitBlockParticleColour.RAINBOW_PARTICLE_COLOR_GREEN, LitBlockParticleColour.RAINBOW_PARTICLE_COLOR_BLUE, LitBlockParticleColour.RAINBOW_PARTICLE_COLOR_PURPLE), 11, RainbowLitBlock.class); - } + public RainbowLitBlock() { + super( + List.of( + LitBlockParticleColour.RAINBOW_PARTICLE_COLOR_RED, + LitBlockParticleColour.RAINBOW_PARTICLE_COLOR_GREEN, + LitBlockParticleColour.RAINBOW_PARTICLE_COLOR_BLUE, + LitBlockParticleColour.RAINBOW_PARTICLE_COLOR_PURPLE), + 11, + RainbowLitBlock.class); + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RubyLitBlock.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RubyLitBlock.java index 425c9931..5646d40c 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RubyLitBlock.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RubyLitBlock.java @@ -3,7 +3,7 @@ import java.util.List; public class RubyLitBlock extends LITBlock { - public RubyLitBlock() { - super(List.of(LitBlockParticleColour.RUBY_PARTICLE_COLOR), 11, RubyLitBlock.class); - } + public RubyLitBlock() { + super(List.of(LitBlockParticleColour.RUBY_PARTICLE_COLOR), 11, RubyLitBlock.class); + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java index 94e370c0..fb765201 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java @@ -1,5 +1,6 @@ package io.github.realyusufismail.armourandtoolsmod.blocks.tool; +import java.util.Objects; import net.minecraft.client.gui.GuiGraphics; import net.minecraft.client.gui.components.ImageButton; import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; @@ -12,118 +13,140 @@ import net.minecraft.world.inventory.Slot; import org.jetbrains.annotations.NotNull; -import java.util.Objects; - /** * @see net.minecraft.client.gui.screens.inventory.CraftingScreen */ -public class CustomToolCraftingTableScreen extends AbstractContainerScreen - implements RecipeUpdateListener { - private static final ResourceLocation CRAFTING_TABLE_LOCATION = - new ResourceLocation("textures/gui/container/crafting_table.png"); - private static final ResourceLocation RECIPE_BUTTON_LOCATION = - new ResourceLocation("textures/gui/recipe_button.png"); - private final RecipeBookComponent recipeBookComponent = new RecipeBookComponent(); - private boolean widthTooNarrow; - - public CustomToolCraftingTableScreen(CustomToolCraftingTableMenu pMenu, Inventory pPlayerInventory, - Component pTitle) { - super(pMenu, pPlayerInventory, pTitle); - } - - protected void init() { - super.init(); - this.widthTooNarrow = this.width < 379; - this.recipeBookComponent.init(this.width, this.height, Objects.requireNonNull(this.minecraft, "Minecraft is null in table screen"), this.widthTooNarrow, - this.menu); - this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); - this.addRenderableWidget(new ImageButton(this.leftPos + 5, this.height / 2 - 49, 20, 18, 0, - 0, 19, RECIPE_BUTTON_LOCATION, (p_98484_) -> { - this.recipeBookComponent.toggleVisibility(); - this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, - this.imageWidth); - p_98484_.setPosition(this.leftPos + 5, this.height / 2 - 49); - })); - this.addWidget(this.recipeBookComponent); - this.setInitialFocus(this.recipeBookComponent); - this.titleLabelX = 29; - } - - public void containerTick() { - super.containerTick(); - this.recipeBookComponent.tick(); - } - - /** - * Renders the graphical user interface (GUI) element. - * - * @param pGuiGraphics the GuiGraphics object used for rendering. - * @param pMouseX the x-coordinate of the mouse cursor. - * @param pMouseY the y-coordinate of the mouse cursor. - * @param pPartialTick the partial tick time. - */ - public void render(GuiGraphics pGuiGraphics, int pMouseX, int pMouseY, float pPartialTick) { - this.renderBackground(pGuiGraphics); - if (this.recipeBookComponent.isVisible() && this.widthTooNarrow) { - this.renderBg(pGuiGraphics, pPartialTick, pMouseX, pMouseY); - this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); - } else { - this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); - super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); - this.recipeBookComponent.renderGhostRecipe(pGuiGraphics, this.leftPos, this.topPos, true, pPartialTick); - } - - this.renderTooltip(pGuiGraphics, pMouseX, pMouseY); - this.recipeBookComponent.renderTooltip(pGuiGraphics, this.leftPos, this.topPos, pMouseX, pMouseY); - } - - protected void renderBg(GuiGraphics pGuiGraphics, float pPartialTick, int pMouseX, int pMouseY) { - int i = this.leftPos; - int j = (this.height - this.imageHeight) / 2; - pGuiGraphics.blit(CRAFTING_TABLE_LOCATION, i, j, 0, 0, this.imageWidth, this.imageHeight); - } - - protected boolean isHovering(int pX, int pY, int pWidth, int pHeight, double pMouseX, - double pMouseY) { - return (!this.widthTooNarrow || !this.recipeBookComponent.isVisible()) - && super.isHovering(pX, pY, pWidth, pHeight, pMouseX, pMouseY); - } - - public boolean mouseClicked(double pMouseX, double pMouseY, int pButton) { - if (this.recipeBookComponent.mouseClicked(pMouseX, pMouseY, pButton)) { - this.setFocused(this.recipeBookComponent); - return true; - } else { - return this.widthTooNarrow && this.recipeBookComponent.isVisible() || super.mouseClicked(pMouseX, pMouseY, pButton); - } - } - - protected boolean hasClickedOutside(double pMouseX, double pMouseY, int pGuiLeft, int pGuiTop, - int pMouseButton) { - boolean flag = pMouseX < (double) pGuiLeft || pMouseY < (double) pGuiTop - || pMouseX >= (double) (pGuiLeft + this.imageWidth) - || pMouseY >= (double) (pGuiTop + this.imageHeight); - return this.recipeBookComponent.hasClickedOutside(pMouseX, pMouseY, this.leftPos, - this.topPos, this.imageWidth, this.imageHeight, pMouseButton) && flag; - } - - /** - * Called when the mouse is clicked over a slot or outside the gui. - */ - protected void slotClicked(@NotNull Slot pSlot, int pSlotId, int pMouseButton, @NotNull ClickType pType) { - super.slotClicked(pSlot, pSlotId, pMouseButton, pType); - this.recipeBookComponent.slotClicked(pSlot); - } - - public void recipesUpdated() { - this.recipeBookComponent.recipesUpdated(); - } - - public void removed() { - super.removed(); +public class CustomToolCraftingTableScreen + extends AbstractContainerScreen implements RecipeUpdateListener { + private static final ResourceLocation CRAFTING_TABLE_LOCATION = + new ResourceLocation("textures/gui/container/crafting_table.png"); + private static final ResourceLocation RECIPE_BUTTON_LOCATION = + new ResourceLocation("textures/gui/recipe_button.png"); + private final RecipeBookComponent recipeBookComponent = new RecipeBookComponent(); + private boolean widthTooNarrow; + + public CustomToolCraftingTableScreen( + CustomToolCraftingTableMenu pMenu, Inventory pPlayerInventory, Component pTitle) { + super(pMenu, pPlayerInventory, pTitle); + } + + protected void init() { + super.init(); + this.widthTooNarrow = this.width < 379; + this.recipeBookComponent.init( + this.width, + this.height, + Objects.requireNonNull(this.minecraft, "Minecraft is null in table screen"), + this.widthTooNarrow, + this.menu); + this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); + this.addRenderableWidget( + new ImageButton( + this.leftPos + 5, + this.height / 2 - 49, + 20, + 18, + 0, + 0, + 19, + RECIPE_BUTTON_LOCATION, + (p_98484_) -> { + this.recipeBookComponent.toggleVisibility(); + this.leftPos = + this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); + p_98484_.setPosition(this.leftPos + 5, this.height / 2 - 49); + })); + this.addWidget(this.recipeBookComponent); + this.setInitialFocus(this.recipeBookComponent); + this.titleLabelX = 29; + } + + public void containerTick() { + super.containerTick(); + this.recipeBookComponent.tick(); + } + + /** + * Renders the graphical user interface (GUI) element. + * + * @param pGuiGraphics the GuiGraphics object used for rendering. + * @param pMouseX the x-coordinate of the mouse cursor. + * @param pMouseY the y-coordinate of the mouse cursor. + * @param pPartialTick the partial tick time. + */ + public void render(GuiGraphics pGuiGraphics, int pMouseX, int pMouseY, float pPartialTick) { + this.renderBackground(pGuiGraphics); + if (this.recipeBookComponent.isVisible() && this.widthTooNarrow) { + this.renderBg(pGuiGraphics, pPartialTick, pMouseX, pMouseY); + this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + } else { + this.recipeBookComponent.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); + this.recipeBookComponent.renderGhostRecipe( + pGuiGraphics, this.leftPos, this.topPos, true, pPartialTick); } - public @NotNull RecipeBookComponent getRecipeBookComponent() { - return this.recipeBookComponent; + this.renderTooltip(pGuiGraphics, pMouseX, pMouseY); + this.recipeBookComponent.renderTooltip( + pGuiGraphics, this.leftPos, this.topPos, pMouseX, pMouseY); + } + + protected void renderBg(GuiGraphics pGuiGraphics, float pPartialTick, int pMouseX, int pMouseY) { + int i = this.leftPos; + int j = (this.height - this.imageHeight) / 2; + pGuiGraphics.blit(CRAFTING_TABLE_LOCATION, i, j, 0, 0, this.imageWidth, this.imageHeight); + } + + protected boolean isHovering( + int pX, int pY, int pWidth, int pHeight, double pMouseX, double pMouseY) { + return (!this.widthTooNarrow || !this.recipeBookComponent.isVisible()) + && super.isHovering(pX, pY, pWidth, pHeight, pMouseX, pMouseY); + } + + public boolean mouseClicked(double pMouseX, double pMouseY, int pButton) { + if (this.recipeBookComponent.mouseClicked(pMouseX, pMouseY, pButton)) { + this.setFocused(this.recipeBookComponent); + return true; + } else { + return this.widthTooNarrow && this.recipeBookComponent.isVisible() + || super.mouseClicked(pMouseX, pMouseY, pButton); } + } + + protected boolean hasClickedOutside( + double pMouseX, double pMouseY, int pGuiLeft, int pGuiTop, int pMouseButton) { + boolean flag = + pMouseX < (double) pGuiLeft + || pMouseY < (double) pGuiTop + || pMouseX >= (double) (pGuiLeft + this.imageWidth) + || pMouseY >= (double) (pGuiTop + this.imageHeight); + return this.recipeBookComponent.hasClickedOutside( + pMouseX, + pMouseY, + this.leftPos, + this.topPos, + this.imageWidth, + this.imageHeight, + pMouseButton) + && flag; + } + + /** Called when the mouse is clicked over a slot or outside the gui. */ + protected void slotClicked( + @NotNull Slot pSlot, int pSlotId, int pMouseButton, @NotNull ClickType pType) { + super.slotClicked(pSlot, pSlotId, pMouseButton, pType); + this.recipeBookComponent.slotClicked(pSlot); + } + + public void recipesUpdated() { + this.recipeBookComponent.recipesUpdated(); + } + + public void removed() { + super.removed(); + } + + public @NotNull RecipeBookComponent getRecipeBookComponent() { + return this.recipeBookComponent; + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModShieldItemRendererProvider.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModShieldItemRendererProvider.java index 3d86adf4..3e9215d1 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModShieldItemRendererProvider.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModShieldItemRendererProvider.java @@ -5,20 +5,20 @@ import net.minecraftforge.client.extensions.common.IClientItemExtensions; public class ArmourAndToolsModShieldItemRendererProvider { - private static ArmourAndToolsModShieldItemRenderer shieldItemRenderer; + private static ArmourAndToolsModShieldItemRenderer shieldItemRenderer; - public static void init(final RegisterClientReloadListenersEvent event) { - shieldItemRenderer = new ArmourAndToolsModShieldItemRenderer(); + public static void init(final RegisterClientReloadListenersEvent event) { + shieldItemRenderer = new ArmourAndToolsModShieldItemRenderer(); - event.registerReloadListener(shieldItemRenderer); - } + event.registerReloadListener(shieldItemRenderer); + } - public static IClientItemExtensions shield() { - return new IClientItemExtensions() { - @Override - public ArmourAndToolsModShieldItemRenderer getCustomRenderer() { - return shieldItemRenderer; - } - }; - } + public static IClientItemExtensions shield() { + return new IClientItemExtensions() { + @Override + public ArmourAndToolsModShieldItemRenderer getCustomRenderer() { + return shieldItemRenderer; + } + }; + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModTridentItemRendererProvider.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModTridentItemRendererProvider.java index cc1e382b..e1ffd37c 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModTridentItemRendererProvider.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModTridentItemRendererProvider.java @@ -5,20 +5,20 @@ import net.minecraftforge.client.extensions.common.IClientItemExtensions; public class ArmourAndToolsModTridentItemRendererProvider { - private static AqumarineTridentItemRendererISTER aqumarineTridentItemRendererISTER; + private static AqumarineTridentItemRendererISTER aqumarineTridentItemRendererISTER; - public static void init(final RegisterClientReloadListenersEvent event) { - aqumarineTridentItemRendererISTER = new AqumarineTridentItemRendererISTER(); + public static void init(final RegisterClientReloadListenersEvent event) { + aqumarineTridentItemRendererISTER = new AqumarineTridentItemRendererISTER(); - event.registerReloadListener(aqumarineTridentItemRendererISTER); - } + event.registerReloadListener(aqumarineTridentItemRendererISTER); + } - public static IClientItemExtensions aqumarineTrident() { - return new IClientItemExtensions() { - @Override - public AqumarineTridentItemRendererISTER getCustomRenderer() { - return aqumarineTridentItemRendererISTER; - } - }; - } + public static IClientItemExtensions aqumarineTrident() { + return new IClientItemExtensions() { + @Override + public AqumarineTridentItemRendererISTER getCustomRenderer() { + return aqumarineTridentItemRendererISTER; + } + }; + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java index 158f8dd4..03f13711 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java @@ -9,11 +9,16 @@ public class BlockEntityTypeInit { - public static DeferredRegister> BLOCK_ENTITY_TYPES = - DeferredRegister.create(ForgeRegistries.BLOCK_ENTITY_TYPES, ArmourAndToolsMod.MOD_ID); + public static DeferredRegister> BLOCK_ENTITY_TYPES = + DeferredRegister.create(ForgeRegistries.BLOCK_ENTITY_TYPES, ArmourAndToolsMod.MOD_ID); - public static RegistryObject> INGOT_FUSION_TOLL_ENHANCER = - BLOCK_ENTITY_TYPES.register("ingot_fusion_toll_enhancer", - () -> BlockEntityType.Builder.of(IngotFusionTollEnhancerBlockEntity::new, - BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()).build(null)); + public static RegistryObject> + INGOT_FUSION_TOLL_ENHANCER = + BLOCK_ENTITY_TYPES.register( + "ingot_fusion_toll_enhancer", + () -> + BlockEntityType.Builder.of( + IngotFusionTollEnhancerBlockEntity::new, + BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()) + .build(null)); } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/EntityTypeInit.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/EntityTypeInit.java index d4a2016c..41581b9b 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/EntityTypeInit.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/EntityTypeInit.java @@ -10,15 +10,23 @@ import net.minecraftforge.registries.RegistryObject; public class EntityTypeInit { - public static DeferredRegister> ENTITY_TYPES = DeferredRegister.create(ForgeRegistries.ENTITY_TYPES, ArmourAndToolsMod.MOD_ID); - - public static final RegistryObject> AQUMARINE_THROWN_TRIDENT = ENTITY_TYPES.register("aqumarine_thrown_trident", - () -> EntityType.Builder.of(AqumarineTridentEntity::new, MobCategory.MISC) - .sized(0.5F, 0.5F) - .fireImmune() - .clientTrackingRange(4) - .updateInterval(20) - .setCustomClientFactory((spawnEntity, world) -> new AqumarineTridentEntity(EntityTypeInit.AQUMARINE_THROWN_TRIDENT.get(), world)) - .build(ArmourAndToolsMod.MOD_ID + ":aqumarine_thrown_trident")); + public static DeferredRegister> ENTITY_TYPES = + DeferredRegister.create(ForgeRegistries.ENTITY_TYPES, ArmourAndToolsMod.MOD_ID); + public static final RegistryObject> + AQUMARINE_THROWN_TRIDENT = + ENTITY_TYPES.register( + "aqumarine_thrown_trident", + () -> + EntityType.Builder.of( + AqumarineTridentEntity::new, MobCategory.MISC) + .sized(0.5F, 0.5F) + .fireImmune() + .clientTrackingRange(4) + .updateInterval(20) + .setCustomClientFactory( + (spawnEntity, world) -> + new AqumarineTridentEntity( + EntityTypeInit.AQUMARINE_THROWN_TRIDENT.get(), world)) + .build(ArmourAndToolsMod.MOD_ID + ":aqumarine_thrown_trident")); } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt deleted file mode 100644 index bafc2c34..00000000 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.kt +++ /dev/null @@ -1,447 +0,0 @@ -/* - * Copyright 2023 RealYusufIsmail. - * - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * - * you may not use this file except in compliance with the License. - * - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package io.github.realyusufismail.armourandtoolsmod.blocks.infusion - -import com.google.common.collect.Maps -import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer -import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit -import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit -import io.github.realyusufismail.armourandtoolsmod.core.init.ItemInit -import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe -import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap -import kotlin.properties.Delegates -import net.minecraft.SharedConstants -import net.minecraft.Util -import net.minecraft.core.BlockPos -import net.minecraft.core.Direction -import net.minecraft.core.NonNullList -import net.minecraft.core.RegistryAccess -import net.minecraft.nbt.CompoundTag -import net.minecraft.network.chat.Component -import net.minecraft.resources.ResourceLocation -import net.minecraft.tags.ItemTags -import net.minecraft.util.Mth -import net.minecraft.world.Container -import net.minecraft.world.ContainerHelper -import net.minecraft.world.WorldlyContainer -import net.minecraft.world.entity.player.Inventory -import net.minecraft.world.entity.player.Player -import net.minecraft.world.entity.player.StackedContents -import net.minecraft.world.inventory.AbstractContainerMenu -import net.minecraft.world.inventory.ContainerData -import net.minecraft.world.inventory.RecipeHolder -import net.minecraft.world.inventory.StackedContentsCompatible -import net.minecraft.world.item.Item -import net.minecraft.world.item.ItemStack -import net.minecraft.world.item.Items -import net.minecraft.world.item.crafting.Recipe -import net.minecraft.world.item.crafting.RecipeManager -import net.minecraft.world.level.Level -import net.minecraft.world.level.block.Blocks -import net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity -import net.minecraft.world.level.block.entity.BaseContainerBlockEntity -import net.minecraft.world.level.block.state.BlockState -import net.minecraftforge.common.ForgeHooks - -/** @see net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity */ -class IngotFusionTollEnhancerBlockEntity(pPos: BlockPos, pBlockState: BlockState) : - BaseContainerBlockEntity( - BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), pPos, pBlockState), - WorldlyContainer, - RecipeHolder, - StackedContentsCompatible { - private var items = NonNullList.withSize(NUMBER_OF_SLOTS, ItemStack.EMPTY) - // TODO: Check these and fix them - private var quickCheck: RecipeManager.CachedCheck - private val recipesUsed = Object2IntOpenHashMap() - private val SLOTS_FOR_UP = intArrayOf(0) - private val SLOTS_FOR_DOWN = intArrayOf(2, 1) - private val SLOTS_FOR_SIDES = intArrayOf(1) - var litTime by Delegates.notNull() - var litDuration by Delegates.notNull() - var creatingTime by Delegates.notNull() - var creatingTotalTime by Delegates.notNull() - - init { - quickCheck = RecipeManager.createCheck(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()) - } - - private val dataAccess: ContainerData = - object : ContainerData { - override fun get(pIndex: Int): Int { - return when (pIndex) { - 0 -> litTime - 1 -> litDuration - 2 -> creatingTime - 3 -> creatingTotalTime - else -> - throw ArrayIndexOutOfBoundsException("ContainerData index out of bounds") - } - } - - override fun set(pIndex: Int, pValue: Int) { - when (pIndex) { - 0 -> litTime = pValue - 1 -> litDuration = pValue - 2 -> creatingTime = pValue - 3 -> creatingTotalTime = pValue - else -> - throw ArrayIndexOutOfBoundsException("ContainerData index out of bounds") - } - } - - override fun getCount(): Int { - return 4 - } - } - - private fun isLit(): Boolean { - return litTime > 0 - } - - override fun load(pTag: CompoundTag) { - super.load(pTag) - items = NonNullList.withSize(this.containerSize, ItemStack.EMPTY) - ContainerHelper.loadAllItems(pTag, items) - this.litTime = pTag.getInt("LitTime") - this.creatingTime = pTag.getInt("CreatingTime") - this.creatingTotalTime = pTag.getInt("CreatingTotalTime") - - val compoundtag = pTag.getCompound("RecipesUsed") - - for (s in compoundtag.allKeys) { - recipesUsed.put(ResourceLocation(s), compoundtag.getInt(s)) - } - } - - override fun saveAdditional(pTag: CompoundTag) { - super.saveAdditional(pTag) - pTag.putInt("BurnTime", litTime) - pTag.putInt("CreatingTime", this.creatingTime) - pTag.putInt("CreatingTotalTime", this.creatingTotalTime) - ContainerHelper.saveAllItems(pTag, items) - val compoundtag = CompoundTag() - recipesUsed.forEach { (p_187449_: ResourceLocation, p_187450_: Int?) -> - compoundtag.putInt(p_187449_.toString(), p_187450_!!) - } - pTag.put("RecipesUsed", compoundtag) - } - - /** Returns the number of slots in the inventory. */ - override fun getContainerSize(): Int { - return items.size - } - - override fun clearContent() { - items.clear() - } - - override fun isEmpty(): Boolean { - for (itemstack in items) { - if (!itemstack.isEmpty) { - return false - } - } - - return true - } - - /** Returns the stack in the given slot. */ - override fun getItem(pSlot: Int): ItemStack { - return items[pSlot] - } - - /** - * Removes up to a specified number of items from an inventory slot and returns them in a new - * stack. - */ - override fun removeItem(pSlot: Int, pAmount: Int): ItemStack { - return ContainerHelper.removeItem(items, pSlot, pAmount) - } - - /** Removes a stack from the given slot and returns it. */ - override fun removeItemNoUpdate(pSlot: Int): ItemStack { - return ContainerHelper.takeItem(items, pSlot) - } - - /** - * Sets the given item stack to the specified slot in the inventory (can be crafting or armor - * sections). - */ - override fun setItem(pSlot: Int, pStack: ItemStack) { - val itemstack = items[pSlot] - val flag = !pStack.isEmpty && ItemStack.isSameItemSameTags(itemstack, pStack) - items[pSlot] = pStack - if (pStack.count > this.maxStackSize) { - pStack.count = this.maxStackSize - } - - if (pSlot == 0 && !flag) { - this.creatingTotalTime = getTotalCraftTime(level!!, this) - this.creatingTime = this.creatingTotalTime - this.setChanged() - } - } - - /** Don't rename this method to canInteractWith due to conflicts with Container */ - override fun stillValid(pPlayer: Player): Boolean { - return Container.stillValidBlockEntity(this, pPlayer) - } - - override fun getSlotsForFace(pSide: Direction): IntArray { - return if (pSide == Direction.DOWN) { - SLOTS_FOR_DOWN - } else { - if (pSide == Direction.UP) SLOTS_FOR_UP else SLOTS_FOR_SIDES - } - } - - /** - * Returns `true` if automation can insert the given item in the given slot from the given side. - */ - override fun canPlaceItemThroughFace( - pIndex: Int, - pItemStack: ItemStack, - pDirection: Direction? - ): Boolean { - return this.canPlaceItem(pIndex, pItemStack) - } - - /** - * Returns `true` if automation can extract the given item in the given slot from the given - * side. - */ - override fun canTakeItemThroughFace( - pIndex: Int, - pStack: ItemStack, - pDirection: Direction - ): Boolean { - return if (pDirection == Direction.DOWN && pIndex == 1) { - pStack.`is`(Items.WATER_BUCKET) || pStack.`is`(Items.BUCKET) - } else { - true - } - } - - override fun createMenu(pContainerId: Int, pInventory: Inventory): AbstractContainerMenu { - return IngotFusionTollEnhancerMenu(pContainerId, this, dataAccess, pInventory) - } - - override fun getDefaultName(): Component { - return IngotFusionTollEnhancer.getContainerTitle() - } - - override fun setRecipeUsed(pRecipe: Recipe<*>?) { - if (pRecipe != null) { - val resourcelocation = pRecipe.id - this.recipesUsed.addTo(resourcelocation, 1) - } - } - - override fun getRecipeUsed(): Recipe<*>? { - return null - } - - override fun fillStackedContents(pContents: StackedContents) { - for (itemstack in items) { - pContents.accountStack(itemstack) - } - } - - companion object { - const val NUMBER_OF_SLOTS = 5 - - @JvmStatic - fun serverTick( - level: Level, - pPos: BlockPos, - pState: BlockState, - pEntity: IngotFusionTollEnhancerBlockEntity - ) { - val flag: Boolean = pEntity.isLit() - var flag1 = false - if (pEntity.isLit()) { - --pEntity.litTime - } - - val itemstack: ItemStack = pEntity.items[1] - val flag2: Boolean = !pEntity.items[0].isEmpty - val flag3 = !itemstack.isEmpty - if (pEntity.isLit() || flag3 && flag2) { - val recipe: Recipe<*>? = - if (flag2) { - pEntity.quickCheck?.getRecipeFor(pEntity, level)?.orElse(null) - } else { - null - } - - val i: Int = pEntity.maxStackSize - if (!pEntity.isLit() && - pEntity.canCreate(level.registryAccess(), recipe, pEntity.items, i)) { - pEntity.litTime = pEntity.getTotalCraftTime(itemstack) - pEntity.litDuration = pEntity.litTime - if (pEntity.isLit()) { - flag1 = true - if (itemstack.hasCraftingRemainingItem()) - pEntity.items[1] = itemstack.craftingRemainingItem - else if (flag3) { - val item = itemstack.item - itemstack.shrink(1) - if (itemstack.isEmpty) { - pEntity.items[1] = itemstack.craftingRemainingItem - } - } - } - } - if (pEntity.isLit() && - pEntity.canCreate(level.registryAccess(), recipe, pEntity.items, i)) { - ++pEntity.creatingTime - if (pEntity.creatingTime == pEntity.creatingTotalTime) { - pEntity.creatingTime = 0 - pEntity.creatingTotalTime = getTotalCraftTime(level, pEntity) - if (pEntity.craft(level.registryAccess(), recipe, pEntity.items, i)) { - pEntity.recipeUsed = recipe - } - flag1 = true - } - } else { - pEntity.creatingTime = 0 - } - } else if (!pEntity.isLit() && pEntity.creatingTime > 0) { - pEntity.creatingTime = Mth.clamp(pEntity.creatingTime - 2, 0, pEntity.creatingTime) - } - - var state = pState - if (flag != pEntity.isLit()) { - flag1 = true - state = - pState.setValue(IngotFusionTollEnhancer.LIT, pEntity.isLit()) - level.setBlock(pPos, state, 3) - } - - if (flag1) { - setChanged(level, pPos, state) - } - } - - private fun getTotalCraftTime( - pLevel: Level, - pBlockEntity: IngotFusionTollEnhancerBlockEntity - ): Int { - return pBlockEntity.quickCheck!! - .getRecipeFor(pBlockEntity, pLevel) - .map { it::craftTime.get() } - .orElse(200) - } - - fun getFuels(): MutableMap { - val map: MutableMap = Maps.newLinkedHashMap() - map.putAll(AbstractFurnaceBlockEntity.getFuel()) - addFuel(map, ItemInit.GRAPHITE.get(), 200) - addFuel(map, BlockInit.GRAPHITE_BLOCK.get().asItem(), 2000) - return map - } - - private fun addFuel(pMap: MutableMap, fuel: Item, pBurnTime: Int) { - if (isNeverAIngotFusionTollEnhanceFuel(fuel)) { - if (SharedConstants.IS_RUNNING_IN_IDE) { - throw (Util.pauseInIde( - IllegalStateException( - "A developer tried to explicitly make fire resistant item " + - fuel.getName(null as ItemStack?).string + - " a IngotFusionTollEnhancer fuel. That will not work!")) - as IllegalStateException) - } - } else { - pMap[fuel] = pBurnTime - } - } - - private fun isNeverAIngotFusionTollEnhanceFuel(pItem: Item): Boolean { - return pItem.builtInRegistryHolder().`is`(ItemTags.NON_FLAMMABLE_WOOD) - } - } - - private fun canCreate( - pRegistryAccess: RegistryAccess, - pRecipe: Recipe<*>?, - pInventory: NonNullList, - pMaxStackSize: Int - ): Boolean { - return if (!pInventory[0].isEmpty && pRecipe != null) { - val itemstack = (pRecipe as Recipe).assemble(this, pRegistryAccess) - if (itemstack.isEmpty) { - false - } else { - // TODO: Check this - val itemstack1 = pInventory[2] - - if (itemstack1.isEmpty) { - true - } else if (!ItemStack.isSameItem(itemstack1, itemstack)) { - false - } else if (itemstack1.count + itemstack.count <= pMaxStackSize && - itemstack1.count + itemstack.count <= itemstack1.maxStackSize) { - true - } else { - itemstack1.count + itemstack.count <= itemstack.maxStackSize - } - } - } else { - false - } - } - - private fun craft( - pRegistryAccess: RegistryAccess, - pRecipe: Recipe<*>?, - pInventory: NonNullList, - pMaxStackSize: Int - ): Boolean { - return if (pRecipe != null && - this.canCreate(pRegistryAccess, pRecipe, pInventory, pMaxStackSize)) { - val itemstack = pInventory[0] - val itemstack1 = (pRecipe as Recipe).assemble(this, pRegistryAccess) - val itemstack2 = pInventory[2] - if (itemstack2.isEmpty) { - pInventory[2] = itemstack1.copy() - } else if (itemstack2.`is`(itemstack1.item)) { - itemstack2.grow(itemstack1.count) - } - if (itemstack.`is`(Blocks.WET_SPONGE.asItem()) && - !pInventory[1].isEmpty && - pInventory[1].`is`(Items.BUCKET)) { - pInventory[1] = ItemStack(Items.WATER_BUCKET) - } - itemstack.shrink(1) - true - } else { - false - } - } - - private fun getTotalCraftTime(pItemStack: ItemStack): Int { - return if (pItemStack.isEmpty) { - 0 - } else { - ForgeHooks.getBurnTime(pItemStack, RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()) - } - } -} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt index 0fcf221c..cbf542f7 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt @@ -18,7 +18,7 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion -import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity.Companion.NUMBER_OF_SLOTS +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity.NUMBER_OF_SLOTS import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots.InfusionFuelSlot import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots.OutputSlotItemHandler import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit @@ -64,7 +64,8 @@ class IngotFusionTollEnhancerMenu( init { level = pInventory.player.level() ?: throw IllegalStateException("Level is null") - checkContainerDataCount(data, NUMBER_OF_SLOTS) + checkContainerSize(blockEntity, NUMBER_OF_SLOTS) + checkContainerDataCount(data, 4) addPlayerInventory(pInventory) addPlayerHotbar(pInventory) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt index 9eab7acd..45f972f4 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt @@ -19,7 +19,7 @@ package io.github.realyusufismail.armourandtoolsmod.client import io.github.realyusufismail.armourandtoolsmod.blocks.armour.CustomArmourCraftingTableScreen -import io.github.realyusufismail.armourandtoolsmod.blocks.fusion.IngotFusionTollEnhancerScreen +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerScreen import io.github.realyusufismail.armourandtoolsmod.blocks.tool.CustomToolCraftingTableScreen import io.github.realyusufismail.armourandtoolsmod.client.renderer.trident.AqumarineTridentItemRenderer import io.github.realyusufismail.armourandtoolsmod.core.init.* diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt index 402cb044..3741cabf 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt @@ -48,6 +48,7 @@ object MenuTypeInit { val INGOT_FUSION_TOLL_ENHANCER_MENU: ObjectHolderDelegate> = MENU.registerObject("ingot_fusion_toll_enhancer") { + //TODO : Get null here. IForgeMenuType.create { pContainerId, pInventory, pData -> IngotFusionTollEnhancerMenu(pContainerId, pInventory, pData) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt index 4112d6bf..3686e0a2 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt @@ -44,6 +44,7 @@ object RecipeTypeInit { RecipeType.simple(ResourceLocation(MOD_ID, "tool_crafting")) } + @JvmField val INGOT_FUSION_TOLL_ENHANCER: ObjectHolderDelegate> = RECIPE_TYPES.registerObject("ingot_fusion_toll_enhancer") { From 7f328328c9a5a93fc2f4b98818c46241a24c0ab4 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 4 Oct 2023 22:16:28 +0100 Subject: [PATCH 19/51] Updated json recipe for infuison --- build.gradle.kts | 19 ++++++++ .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 5 +- .../advancements/recipes/root.json | 35 ++++++++++++++ .../recipes/magma_strike_pickaxe.json | 3 ++ .../blocks/IngotFusionTollEnhancer.java | 18 ++++++++ .../CustomArmourCraftingTableScreen.java | 18 ++++++++ .../IngotFusionTollEnhancerBlockEntity.java | 25 ++++++++++ .../IngotFusionTollEnhancerScreen.java | 18 ++++++++ .../blocks/lit/LITBlock.java | 18 ++++++++ .../blocks/lit/LitBlockParticleColour.java | 18 ++++++++ .../blocks/lit/RainbowLitBlock.java | 18 ++++++++ .../blocks/lit/RubyLitBlock.java | 18 ++++++++ .../tool/CustomToolCraftingTableScreen.java | 18 ++++++++ ...AndToolsModShieldItemRendererProvider.java | 18 ++++++++ ...ndToolsModTridentItemRendererProvider.java | 18 ++++++++ .../core/init/BlockEntityTypeInit.java | 18 ++++++++ .../core/init/EntityTypeInit.java | 18 ++++++++ ...gotFusionTollEnhancerRecipeBookCategory.kt | 36 +++++++++++++++ .../core/init/MenuTypeInit.kt | 2 +- .../IngotFusionTollEnhancerRecipeBuilder.kt | 46 +++++++++++++------ .../IngotFusionTollEnhancerRecipeProvider.kt | 6 ++- ...ngotFusionTollEnhancerJEIRecipeCategory.kt | 5 +- .../fusion/IngotFusionTollEnhancerRecipe.kt | 41 +++++++---------- 23 files changed, 395 insertions(+), 44 deletions(-) create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/root.json create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt diff --git a/build.gradle.kts b/build.gradle.kts index f57bfbea..77248259 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -211,6 +211,25 @@ spotless { trimTrailingWhitespace() indentWithSpaces() endWithNewline() + licenseHeader( + """/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ """) } } diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index b812b426..be95b32c 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-02T13:53:11.6216435 Recipes +// 1.20.1 2023-10-04T22:14:41.9946575 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -160,6 +160,7 @@ b15626440399c8d4ec922cffd9f4391ff8dc7de9 data/armourandtoolsmod/advancements/rec 8dfc7d5e8d8d0edff54402501e101b77b8141a4e data/armourandtoolsmod/advancements/recipes/misc/smelting_sapphire_shield.json 1d355a6149df6ee90baceb2af58481b174d39f53 data/armourandtoolsmod/advancements/recipes/misc/smelting_sapphire_shovel.json cf55c36fed542c0e3e3b99255aec56aae6a5bbc2 data/armourandtoolsmod/advancements/recipes/misc/smelting_sapphire_sword.json +ecea73ae8a409b07d9010ff73813373c5ce30c15 data/armourandtoolsmod/advancements/recipes/root.json e9b479dce4a333e720dc29b6332122e7b592f0ca data/armourandtoolsmod/advancements/recipes/tools/amethyst_axe.json 64fbc2a7192aa157444bfae3b1e41b9b8bd4c42e data/armourandtoolsmod/advancements/recipes/tools/amethyst_pickaxe.json d23584eced53cc0fa543f7749096db34a79e98e8 data/armourandtoolsmod/advancements/recipes/tools/amethyst_shovel.json @@ -279,7 +280,7 @@ adf63b0d9c8b2e333a5e4769a2fc0183f483544e data/armourandtoolsmod/recipes/graphite b790592cbe2e046b1e8169e2fb4a8da1483a8dfb data/armourandtoolsmod/recipes/graphite_shield.json aa31085980f2c7c3e8bad8a4dccb79315eac0102 data/armourandtoolsmod/recipes/imperium_pickaxe.json 9d9c3b5485306909e7c17e86c42d4afe8125c648 data/armourandtoolsmod/recipes/imperium_sword.json -7d9a1910c5a2d17607081bae58c3f8c25be6ac8d data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +f946f7739c5aef561ecdaf9a0ad20a82a280a1c3 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json 0399917d7fdda6f9af410c709805dfb149b2451c data/armourandtoolsmod/recipes/rainbow_block_recipe.json 5caa6184a7c066fac3bbc8e3869ae712171fe202 data/armourandtoolsmod/recipes/rainbow_boots.json cc01dc105a026c1a42db2e4a7bea9ca208ef22e2 data/armourandtoolsmod/recipes/rainbow_chestplate.json diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/root.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/root.json new file mode 100644 index 00000000..704c00c9 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/root.json @@ -0,0 +1,35 @@ +{ + "parent": "armourandtoolsmod:recipes/root", + "criteria": { + "has_imperium_ingot": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:imperium" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:magma_strike_pickaxe" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_imperium_ingot", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:magma_strike_pickaxe" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json index 6c49652b..7b6c31d0 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json @@ -1,5 +1,8 @@ { "type": "armourandtoolsmod:ingot_fusion_toll_enhancer_recipe", + "category": "upgrading", + "craftTime": 500, + "experience": 0.5, "ingredients": [ { "item": "armourandtoolsmod:imperium" diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java index 8cf36a8d..ec3228be 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks; import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java index 3ba775c7..5df64be0 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/armour/CustomArmourCraftingTableScreen.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.armour; import java.util.Objects; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index daf34c62..147312fe 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; @@ -9,6 +27,7 @@ import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap; import java.util.LinkedHashMap; import java.util.Map; +import java.util.Set; import lombok.Getter; import lombok.Setter; import lombok.val; @@ -375,6 +394,12 @@ public static Map getFuels() { return map; } + public static Set getFuelAsItemStacks() { + return getFuels().keySet().stream() + .map(ItemStack::new) + .collect(java.util.stream.Collectors.toSet()); + } + public static void addFuel(Map pMap, Item fuel, int pBurnTime) { if (!isNeverAIngotFusionTollEnhanceFuel(fuel)) { pMap.put(fuel, pBurnTime); diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java index f5f26f16..5ab4c369 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; import com.mojang.blaze3d.systems.RenderSystem; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LITBlock.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LITBlock.java index ef8eb119..a4b6f1a4 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LITBlock.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LITBlock.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.lit; import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LitBlockParticleColour.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LitBlockParticleColour.java index f6ae7e3f..1a754e15 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LitBlockParticleColour.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/LitBlockParticleColour.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.lit; import net.minecraft.core.particles.DustParticleOptions; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RainbowLitBlock.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RainbowLitBlock.java index 525d78ab..f1dbdefc 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RainbowLitBlock.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RainbowLitBlock.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.lit; import java.util.List; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RubyLitBlock.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RubyLitBlock.java index 5646d40c..f2b3858a 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RubyLitBlock.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/lit/RubyLitBlock.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.lit; import java.util.List; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java index fb765201..42f85a06 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/tool/CustomToolCraftingTableScreen.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.blocks.tool; import java.util.Objects; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModShieldItemRendererProvider.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModShieldItemRendererProvider.java index 3e9215d1..87f0d2a1 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModShieldItemRendererProvider.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModShieldItemRendererProvider.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.client; import io.github.realyusufismail.armourandtoolsmod.client.renderer.shield.ArmourAndToolsModShieldItemRenderer; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModTridentItemRendererProvider.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModTridentItemRendererProvider.java index e1ffd37c..fc3c7efd 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModTridentItemRendererProvider.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/client/ArmourAndToolsModTridentItemRendererProvider.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.client; import io.github.realyusufismail.armourandtoolsmod.client.renderer.trident.ister.AqumarineTridentItemRendererISTER; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java index 03f13711..ed0873c2 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/BlockEntityTypeInit.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.core.init; import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/EntityTypeInit.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/EntityTypeInit.java index 41581b9b..fa5fef4a 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/EntityTypeInit.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/core/init/EntityTypeInit.java @@ -1,3 +1,21 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package io.github.realyusufismail.armourandtoolsmod.core.init; import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt new file mode 100644 index 00000000..cef589d0 --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt @@ -0,0 +1,36 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book + +import net.minecraft.util.StringRepresentable + +enum class IngotFusionTollEnhancerRecipeBookCategory(private var bookName: String) : + StringRepresentable { + UPGRADING("upgrading"), + MISC("misc"); + + companion object { + val CODEC: StringRepresentable.EnumCodec = + StringRepresentable.fromEnum { entries.toTypedArray() } + } + + override fun getSerializedName(): String { + return bookName + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt index 3741cabf..bba74de1 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt @@ -48,7 +48,7 @@ object MenuTypeInit { val INGOT_FUSION_TOLL_ENHANCER_MENU: ObjectHolderDelegate> = MENU.registerObject("ingot_fusion_toll_enhancer") { - //TODO : Get null here. + // TODO : Get null here. IForgeMenuType.create { pContainerId, pInventory, pData -> IngotFusionTollEnhancerMenu(pContainerId, pInventory, pData) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index 2c4bec63..28ae962c 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -20,6 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.datagen.recipe.builder import com.google.gson.JsonArray import com.google.gson.JsonObject +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookCategory import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit import java.util.* import java.util.function.Consumer @@ -36,10 +37,13 @@ import net.minecraft.world.item.crafting.RecipeSerializer import net.minecraftforge.registries.ForgeRegistries class IngotFusionTollEnhancerRecipeBuilder( + private val recipeCategory: IngotFusionTollEnhancerRecipeBookCategory, private val input1: Ingredient, private val input2: Ingredient, private val input3: Ingredient, - private val output: Item + private val result: Item, + private val craftTime: Int = 200, + private val experience: Float = 0.2f ) { private val advancementBuilder = Advancement.Builder.advancement() @@ -61,11 +65,14 @@ class IngotFusionTollEnhancerRecipeBuilder( .rewards(AdvancementRewards.Builder.recipe(rl)) .requirements(RequirementsStrategy.OR) consumer.accept( - Output( + Result( + recipeCategory, input1, input2, input3, - output, + result, + craftTime, + experience, advancementBuilder, ResourceLocation(rl.namespace, "recipes/root").also { advancementId -> advancementBuilder.parent(advancementId) @@ -92,11 +99,14 @@ class IngotFusionTollEnhancerRecipeBuilder( * @param id The recipe id */ @JvmRecord - private data class Output( + private data class Result( + val recipeCategory: IngotFusionTollEnhancerRecipeBookCategory, val input1: Ingredient, val input2: Ingredient, val input3: Ingredient, - val output: Item, + val result: Item, + val craftTime: Int, + val experience: Float, val advancementBuilder: Advancement.Builder, val advancementId: ResourceLocation, val id: ResourceLocation @@ -111,13 +121,13 @@ class IngotFusionTollEnhancerRecipeBuilder( json.add("ingredients", jsonArray) - // TODO: Update to add new fuel slot + json.addProperty("craftTime", craftTime) + json.addProperty("experience", experience) + json.addProperty("category", recipeCategory.serializedName) val jsonObject = JsonObject() - jsonObject.addProperty("item", ForgeRegistries.ITEMS.getKey(output).toString()) + jsonObject.addProperty("item", ForgeRegistries.ITEMS.getKey(result).toString()) json.add("result", jsonObject) - - println(json.toString()) } override fun getId(): ResourceLocation { @@ -128,9 +138,8 @@ class IngotFusionTollEnhancerRecipeBuilder( return RecipeSerializerInit.INGOT_FUSION_TOLL_ENHANCER_RECIPE.get() } - override fun serializeAdvancement(): JsonObject? { - return if (advancementBuilder.criteria.isEmpty()) advancementBuilder.serializeToJson() - else null + override fun serializeAdvancement(): JsonObject { + return advancementBuilder.serializeToJson() } override fun getAdvancementId(): ResourceLocation { @@ -140,13 +149,22 @@ class IngotFusionTollEnhancerRecipeBuilder( companion object { fun builder( + recipeCategory: IngotFusionTollEnhancerRecipeBookCategory, input1: Item, input2: Item, input3: Item, - output: Item + result: Item, + craftTime: Int? = null, + experience: Float? = null ): IngotFusionTollEnhancerRecipeBuilder { return IngotFusionTollEnhancerRecipeBuilder( - ingredient(input1), ingredient(input2), ingredient(input3), output) + recipeCategory, + ingredient(input1), + ingredient(input2), + ingredient(input3), + result, + craftTime ?: 200, + experience ?: 0.2f) } private fun ingredient(entry: Item): Ingredient { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt index eb41c558..76c6f01f 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt @@ -18,6 +18,7 @@ */ package io.github.realyusufismail.armourandtoolsmod.datagen.recipe.provider +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookCategory import io.github.realyusufismail.armourandtoolsmod.core.init.ItemInit import io.github.realyusufismail.armourandtoolsmod.datagen.recipe.MainModRecipeProvider import io.github.realyusufismail.armourandtoolsmod.datagen.recipe.builder.IngotFusionTollEnhancerRecipeBuilder @@ -31,10 +32,13 @@ class IngotFusionTollEnhancerRecipeProvider( fun build() { IngotFusionTollEnhancerRecipeBuilder.builder( + IngotFusionTollEnhancerRecipeBookCategory.UPGRADING, ItemInit.IMPERIUM.get(), ItemInit.IMPERIUM_PICKAXE.get(), ItemInit.IMPERIUM.get(), - ItemInit.MAGMA_STRIKE_PICKAXE.get()) + ItemInit.MAGMA_STRIKE_PICKAXE.get(), + 500, + 0.5f) .unlockedBy("has_imperium_ingot", has(ItemInit.IMPERIUM.get())) .save(pWriter, modId("magma_strike_pickaxe")) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt index cbbe59c1..972e23a9 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt @@ -20,6 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.integration.fusion import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit import io.github.realyusufismail.armourandtoolsmod.integration.ArmourAndToolsModJEIPlugin import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe @@ -111,7 +112,9 @@ class IngotFusionTollEnhancerJEIRecipeCategory(guiHelper: IGuiHelper) : builder.addSlot(RecipeIngredientRole.INPUT, 43, 40).addIngredients(recipe.ingredients[1]) builder.addSlot(RecipeIngredientRole.INPUT, 70, 40).addIngredients(recipe.ingredients[2]) - builder.addSlot(RecipeIngredientRole.INPUT, 110, 65).addIngredients(recipe.fuel) + builder + .addSlot(RecipeIngredientRole.INPUT, 110, 65) + .addItemStacks(IngotFusionTollEnhancerBlockEntity.getFuelAsItemStacks().toList()) builder.addSlot(RecipeIngredientRole.OUTPUT, 138, 40).addItemStack(recipe.result) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index b74cb2db..6fd39b04 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -19,6 +19,7 @@ package io.github.realyusufismail.armourandtoolsmod.recipe.fusion import com.google.gson.JsonObject +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookCategory import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit import net.minecraft.core.NonNullList import net.minecraft.core.RegistryAccess @@ -34,10 +35,10 @@ class IngotFusionTollEnhancerRecipe( private val input1: Ingredient, private val input2: Ingredient, private val input3: Ingredient, - val fuel: Ingredient, val result: ItemStack, + val craftTime: Int, + private val experience: Float, private val recipeId: ResourceLocation, - val craftTime: Int = 200 ) : Recipe { /** Used to check if a recipe matches current crafting inventory */ @@ -108,36 +109,23 @@ class IngotFusionTollEnhancerRecipe( ): IngotFusionTollEnhancerRecipe { try { - // there is an array called Ingredients, and it contains 3 objects, each object - // is an ingredient - // "ingredients": [ - // { - // "item": "armourandtoolsmod:imperium" - // }, - // { - // "item": "armourandtoolsmod:imperium_pickaxe" - // }, - // { - // "item": "armourandtoolsmod:imperium" - // } - // ], val ingredientArray = json.get("ingredients").asJsonArray val input1 = Ingredient.fromJson(ingredientArray[0]) val input2 = Ingredient.fromJson(ingredientArray[1]) val input3 = Ingredient.fromJson(ingredientArray[2]) - val fuel = Ingredient.fromJson(json.get("fuel")) - - // TODO: Error caused by lack of recipe book category - // [13:57:18] [Render thread/WARN] [minecraft/ClientRecipeBook]: Unknown recipe - // category: - // [!!!com.mojang.logging.LogUtils$1ToString@6987a0f3=>java.lang.NullPointerException:Cannot invoke "Object.toString()" because the return value of "java.util.function.Supplier.get()" is null!!!]/armourandtoolsmod:magma_strike_pickaxe + val craftTime = GsonHelper.getAsInt(json, "craftTime") + val experience = GsonHelper.getAsFloat(json, "experience") + val recipeCategory = + IngotFusionTollEnhancerRecipeBookCategory.CODEC.byName( + GsonHelper.getAsString(json, "category", null as String?), + IngotFusionTollEnhancerRecipeBookCategory.MISC) val result = ShapedRecipe.itemStackFromJson(GsonHelper.getAsJsonObject(json, "result")) return IngotFusionTollEnhancerRecipe( - input1, input2, input3, fuel, result, pRecipeId) + input1, input2, input3, result, craftTime, experience, pRecipeId) } catch (e: IllegalStateException) { throw IllegalStateException("Could not create recipe: $pRecipeId", e) } @@ -179,10 +167,12 @@ class IngotFusionTollEnhancerRecipe( "No ingredients for ingot fusion toll enhancer recipe") } - val fuel = Ingredient.fromNetwork(pBuffer) val result = pBuffer.readItem() + val craftTime = pBuffer.readInt() + val experience = pBuffer.readFloat() + return IngotFusionTollEnhancerRecipe( - input1, input2, input3, fuel, result, pRecipeId) + input1, input2, input3, result, craftTime, experience, pRecipeId) } catch (e: IllegalStateException) { throw IllegalStateException("Could not read recipe: $pRecipeId", e) } @@ -197,8 +187,9 @@ class IngotFusionTollEnhancerRecipe( ingredient.toNetwork(pBuffer) } - pRecipe.fuel.toNetwork(pBuffer) pBuffer.writeItem(pRecipe.result) + pBuffer.writeInt(pRecipe.craftTime) + pBuffer.writeFloat(pRecipe.experience) } catch (e: IllegalStateException) { throw IllegalStateException("Could not write recipe: ${pRecipe.id}", e) } From 4a1936b3e7a9c12b940118bcc8799affd20c4ce2 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 5 Oct 2023 20:06:51 +0100 Subject: [PATCH 20/51] screen works. No issue there. Having issue with recipe --- .../blocks/IngotFusionTollEnhancer.java | 6 +++- .../IngotFusionTollEnhancerBlockEntity.java | 33 +++++++++++++++++-- .../IngotFusionTollEnhancerScreen.java | 2 +- .../infusion/IngotFusionTollEnhancerMenu.kt | 3 +- .../blocks/infusion/slots/InfusionFuelSlot.kt | 2 +- ...ngotFusionTollEnhancerJEIRecipeCategory.kt | 2 +- .../fusion/IngotFusionTollEnhancerRecipe.kt | 1 + 7 files changed, 41 insertions(+), 8 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java index ec3228be..ed0a1078 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/IngotFusionTollEnhancer.java @@ -26,6 +26,7 @@ import net.minecraft.core.Direction; import net.minecraft.network.chat.Component; import net.minecraft.server.level.ServerLevel; +import net.minecraft.server.level.ServerPlayer; import net.minecraft.world.Container; import net.minecraft.world.Containers; import net.minecraft.world.InteractionHand; @@ -48,6 +49,7 @@ import net.minecraft.world.level.block.state.properties.DirectionProperty; import net.minecraft.world.level.material.MapColor; import net.minecraft.world.phys.BlockHitResult; +import net.minecraftforge.network.NetworkHooks; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; @@ -90,7 +92,9 @@ public static Component getContainerDescription() { try { Objects.requireNonNull(player, "Player is null"); Objects.requireNonNull(blockEntity, "BlockEntity is null"); - player.openMenu((IngotFusionTollEnhancerBlockEntity) blockEntity); + + NetworkHooks.openScreen( + (ServerPlayer) player, (IngotFusionTollEnhancerBlockEntity) blockEntity, blockPos); } catch (Exception e) { throw new RuntimeException("Failed to open screen." + e); } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index 147312fe..f81ee6e1 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -37,6 +37,7 @@ import net.minecraft.core.Direction; import net.minecraft.core.NonNullList; import net.minecraft.core.RegistryAccess; +import net.minecraft.nbt.CompoundTag; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; import net.minecraft.tags.ItemTags; @@ -75,8 +76,7 @@ public class IngotFusionTollEnhancerBlockEntity extends BaseContainerBlockEntity private final RecipeManager.CachedCheck quickCheck; @Getter - private final NonNullList items = - NonNullList.withSize(NUMBER_OF_SLOTS, ItemStack.EMPTY); + private NonNullList items = NonNullList.withSize(NUMBER_OF_SLOTS, ItemStack.EMPTY); private final Object2IntOpenHashMap recipesUsed = new Object2IntOpenHashMap<>(); private final RecipeType type = @@ -127,6 +127,35 @@ public int getCount() { } }; + public void load(CompoundTag pTag) { + super.load(pTag); + this.items = NonNullList.withSize(this.getContainerSize(), ItemStack.EMPTY); + ContainerHelper.loadAllItems(pTag, this.items); + this.litTime = pTag.getInt("BurnTime"); + this.creatingTime = pTag.getInt("CraftTime"); + this.creatingTotalTime = pTag.getInt("CraftTimeTotal"); + this.litDuration = this.getTotalCraftTime(this.items.get(1)); + CompoundTag compoundtag = pTag.getCompound("RecipesUsed"); + + for (String s : compoundtag.getAllKeys()) { + this.recipesUsed.put(new ResourceLocation(s), compoundtag.getInt(s)); + } + } + + protected void saveAdditional(CompoundTag pTag) { + super.saveAdditional(pTag); + pTag.putInt("BurnTime", this.litTime); + pTag.putInt("CraftTime", this.creatingTime); + pTag.putInt("CraftTimeTotal", this.creatingTotalTime); + ContainerHelper.saveAllItems(pTag, this.items); + CompoundTag compoundtag = new CompoundTag(); + this.recipesUsed.forEach( + (p_187449_, p_187450_) -> { + compoundtag.putInt(p_187449_.toString(), p_187450_); + }); + pTag.put("RecipesUsed", compoundtag); + } + @Override public int @NotNull [] getSlotsForFace(Direction pSide) { if (pSide == Direction.DOWN) { diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java index 5ab4c369..c5a7c1e0 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java @@ -67,7 +67,7 @@ protected void init() { this.addRenderableWidget( new ImageButton( this.leftPos + 5, - this.height / 2 - 49, + this.height / 2 - 22, 20, 18, 0, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt index cbf542f7..ac325879 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt @@ -140,10 +140,9 @@ class IngotFusionTollEnhancerMenu( } override fun getGridWidth(): Int { - return 3 + return 1 } - // TODO: Check if this is correct override fun getGridHeight(): Int { return 1 } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt index 0b8894ef..5b90ff61 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt @@ -25,7 +25,7 @@ import net.minecraftforge.items.IItemHandler import net.minecraftforge.items.SlotItemHandler class InfusionFuelSlot(itemHandler: IItemHandler, private val menu: IngotFusionTollEnhancerMenu) : - SlotItemHandler(itemHandler, 3, 110, 65) { + SlotItemHandler(itemHandler, 3, 102, 69) { override fun mayPlace(stack: ItemStack): Boolean { return menu.isFuel(stack) || isBucket(stack) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt index 972e23a9..5c483cc9 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt @@ -113,7 +113,7 @@ class IngotFusionTollEnhancerJEIRecipeCategory(guiHelper: IGuiHelper) : builder.addSlot(RecipeIngredientRole.INPUT, 70, 40).addIngredients(recipe.ingredients[2]) builder - .addSlot(RecipeIngredientRole.INPUT, 110, 65) + .addSlot(RecipeIngredientRole.INPUT, 102, 68) .addItemStacks(IngotFusionTollEnhancerBlockEntity.getFuelAsItemStacks().toList()) builder.addSlot(RecipeIngredientRole.OUTPUT, 138, 40).addItemStack(recipe.result) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 6fd39b04..1c7e38eb 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -31,6 +31,7 @@ import net.minecraft.world.item.ItemStack import net.minecraft.world.item.crafting.* import net.minecraft.world.level.Level +/** @see */ class IngotFusionTollEnhancerRecipe( private val input1: Ingredient, private val input2: Ingredient, From c1eb73e655b78c6e6a8ee0b63cebfd39ca3f2649 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 5 Oct 2023 21:10:35 +0100 Subject: [PATCH 21/51] added some methods --- .../IngotFusionTollEnhancerBlockEntity.java | 60 +++++++++++++++++++ .../blocks/infusion/slots/InfusionFuelSlot.kt | 2 +- .../IngotFusionTollEnhancerRecipeBuilder.kt | 2 +- ...ngotFusionTollEnhancerJEIRecipeCategory.kt | 2 +- .../fusion/IngotFusionTollEnhancerRecipe.kt | 2 +- 5 files changed, 64 insertions(+), 4 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index f81ee6e1..e7ef7a68 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -18,14 +18,17 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; +import com.google.common.collect.Lists; import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit; import io.github.realyusufismail.armourandtoolsmod.core.init.ItemInit; import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit; import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe; +import it.unimi.dsi.fastutil.objects.Object2IntMap; import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap; import java.util.LinkedHashMap; +import java.util.List; import java.util.Map; import java.util.Set; import lombok.Getter; @@ -40,10 +43,14 @@ import net.minecraft.nbt.CompoundTag; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; +import net.minecraft.server.level.ServerLevel; +import net.minecraft.server.level.ServerPlayer; import net.minecraft.tags.ItemTags; +import net.minecraft.util.Mth; import net.minecraft.world.Container; import net.minecraft.world.ContainerHelper; import net.minecraft.world.WorldlyContainer; +import net.minecraft.world.entity.ExperienceOrb; import net.minecraft.world.entity.player.Inventory; import net.minecraft.world.entity.player.Player; import net.minecraft.world.entity.player.StackedContents; @@ -54,6 +61,7 @@ import net.minecraft.world.item.Item; import net.minecraft.world.item.ItemStack; import net.minecraft.world.item.Items; +import net.minecraft.world.item.crafting.AbstractCookingRecipe; import net.minecraft.world.item.crafting.Recipe; import net.minecraft.world.item.crafting.RecipeManager; import net.minecraft.world.item.crafting.RecipeType; @@ -62,6 +70,7 @@ import net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity; import net.minecraft.world.level.block.entity.BaseContainerBlockEntity; import net.minecraft.world.level.block.state.BlockState; +import net.minecraft.world.phys.Vec3; import net.minecraftforge.common.ForgeHooks; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; @@ -127,6 +136,7 @@ public int getCount() { } }; + @Override public void load(CompoundTag pTag) { super.load(pTag); this.items = NonNullList.withSize(this.getContainerSize(), ItemStack.EMPTY); @@ -142,6 +152,7 @@ public void load(CompoundTag pTag) { } } + @Override protected void saveAdditional(CompoundTag pTag) { super.saveAdditional(pTag); pTag.putInt("BurnTime", this.litTime); @@ -260,6 +271,55 @@ public Recipe getRecipeUsed() { return null; } + @Override + public void awardUsedRecipes(Player pPlayer, List pItems) {} + + public void awardUsedRecipesAndPopExperience(ServerPlayer pPlayer) { + List> list = + this.getRecipesToAwardAndPopExperience(pPlayer.serverLevel(), pPlayer.position()); + pPlayer.awardRecipes(list); + + for (Recipe recipe : list) { + if (recipe != null) { + pPlayer.triggerRecipeCrafted(recipe, this.items); + } + } + + this.recipesUsed.clear(); + } + + public List> getRecipesToAwardAndPopExperience(ServerLevel pLevel, Vec3 pPopVec) { + List> list = Lists.newArrayList(); + + for (Object2IntMap.Entry entry : this.recipesUsed.object2IntEntrySet()) { + pLevel + .getRecipeManager() + .byKey(entry.getKey()) + .ifPresent( + (p_155023_) -> { + list.add(p_155023_); + createExperience( + pLevel, + pPopVec, + entry.getIntValue(), + ((AbstractCookingRecipe) p_155023_).getExperience()); + }); + } + + return list; + } + + private static void createExperience( + ServerLevel pLevel, Vec3 pPopVec, int pRecipeIndex, float pExperience) { + int i = Mth.floor((float) pRecipeIndex * pExperience); + float f = Mth.frac((float) pRecipeIndex * pExperience); + if (f != 0.0F && Math.random() < (double) f) { + ++i; + } + + ExperienceOrb.award(pLevel, pPopVec, i); + } + @Override public void fillStackedContents(StackedContents pContents) { for (ItemStack itemstack : this.items) { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt index 5b90ff61..ce2073b6 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt @@ -25,7 +25,7 @@ import net.minecraftforge.items.IItemHandler import net.minecraftforge.items.SlotItemHandler class InfusionFuelSlot(itemHandler: IItemHandler, private val menu: IngotFusionTollEnhancerMenu) : - SlotItemHandler(itemHandler, 3, 102, 69) { + SlotItemHandler(itemHandler, 3, 102, 65) { override fun mayPlace(stack: ItemStack): Boolean { return menu.isFuel(stack) || isBucket(stack) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index 28ae962c..fbfe11d2 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -121,7 +121,7 @@ class IngotFusionTollEnhancerRecipeBuilder( json.add("ingredients", jsonArray) - json.addProperty("craftTime", craftTime) + json.addProperty("crafttime", craftTime) json.addProperty("experience", experience) json.addProperty("category", recipeCategory.serializedName) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt index 5c483cc9..b419ec4b 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt @@ -113,7 +113,7 @@ class IngotFusionTollEnhancerJEIRecipeCategory(guiHelper: IGuiHelper) : builder.addSlot(RecipeIngredientRole.INPUT, 70, 40).addIngredients(recipe.ingredients[2]) builder - .addSlot(RecipeIngredientRole.INPUT, 102, 68) + .addSlot(RecipeIngredientRole.INPUT, 102, 70) .addItemStacks(IngotFusionTollEnhancerBlockEntity.getFuelAsItemStacks().toList()) builder.addSlot(RecipeIngredientRole.OUTPUT, 138, 40).addItemStack(recipe.result) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 1c7e38eb..9fca79c1 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -115,7 +115,7 @@ class IngotFusionTollEnhancerRecipe( val input2 = Ingredient.fromJson(ingredientArray[1]) val input3 = Ingredient.fromJson(ingredientArray[2]) - val craftTime = GsonHelper.getAsInt(json, "craftTime") + val craftTime = GsonHelper.getAsInt(json, "crafttime") val experience = GsonHelper.getAsFloat(json, "experience") val recipeCategory = IngotFusionTollEnhancerRecipeBookCategory.CODEC.byName( From b5e2a80da355623b1ba134b4d5252e5aa2ac5f08 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 5 Oct 2023 21:14:08 +0100 Subject: [PATCH 22/51] Added getCapability --- .../IngotFusionTollEnhancerBlockEntity.java | 33 +++++++++++++++++++ 1 file changed, 33 insertions(+) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index e7ef7a68..d5714e57 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -327,6 +327,39 @@ public void fillStackedContents(StackedContents pContents) { } } + net.minecraftforge.common.util.LazyOptional[] + handlers = + net.minecraftforge.items.wrapper.SidedInvWrapper.create( + this, Direction.UP, Direction.DOWN, Direction.NORTH); + + @Override + public net.minecraftforge.common.util.@NotNull LazyOptional getCapability( + net.minecraftforge.common.capabilities.Capability capability, + @javax.annotation.Nullable Direction facing) { + if (!this.remove + && facing != null + && capability == net.minecraftforge.common.capabilities.ForgeCapabilities.ITEM_HANDLER) { + if (facing == Direction.UP) return handlers[0].cast(); + else if (facing == Direction.DOWN) return handlers[1].cast(); + else return handlers[2].cast(); + } + return super.getCapability(capability, facing); + } + + @Override + public void invalidateCaps() { + super.invalidateCaps(); + for (int x = 0; x < handlers.length; x++) handlers[x].invalidate(); + } + + @Override + public void reviveCaps() { + super.reviveCaps(); + this.handlers = + net.minecraftforge.items.wrapper.SidedInvWrapper.create( + this, Direction.UP, Direction.DOWN, Direction.NORTH); + } + private boolean isLit() { return this.litTime > 0; } From e9f8eadf8aef43df08c2d1a70baec12e77ff8564 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 5 Oct 2023 22:20:11 +0100 Subject: [PATCH 23/51] still not making the item. RECIPE Issue --- gradle/config/detekt.yml | 2 +- .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 4 +-- .../recipes/magma_strike_pickaxe.json | 2 +- .../IngotFusionTollEnhancerBlockEntity.java | 4 ++- .../infusion/IngotFusionTollEnhancerMenu.kt | 5 ++- .../infusion/slots/OutputSlotItemHandler.kt | 34 ++++++++++++++++++- .../integration/ArmourAndToolsModJEIPlugin.kt | 2 +- ...ngotFusionTollEnhancerJEIRecipeCategory.kt | 2 +- .../fusion/IngotFusionTollEnhancerRecipe.kt | 13 ++----- 9 files changed, 46 insertions(+), 22 deletions(-) diff --git a/gradle/config/detekt.yml b/gradle/config/detekt.yml index 10f3f57b..b411f941 100644 --- a/gradle/config/detekt.yml +++ b/gradle/config/detekt.yml @@ -129,7 +129,7 @@ complexity: active: false threshold: 60 LongParameterList: - active: true + active: false functionThreshold: 6 constructorThreshold: 10 ignoreDefaultParameters: false diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index be95b32c..072cc1fc 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-04T22:14:41.9946575 Recipes +// 1.20.1 2023-10-05T22:13:53.0037291 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -280,7 +280,7 @@ adf63b0d9c8b2e333a5e4769a2fc0183f483544e data/armourandtoolsmod/recipes/graphite b790592cbe2e046b1e8169e2fb4a8da1483a8dfb data/armourandtoolsmod/recipes/graphite_shield.json aa31085980f2c7c3e8bad8a4dccb79315eac0102 data/armourandtoolsmod/recipes/imperium_pickaxe.json 9d9c3b5485306909e7c17e86c42d4afe8125c648 data/armourandtoolsmod/recipes/imperium_sword.json -f946f7739c5aef561ecdaf9a0ad20a82a280a1c3 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +13a143b409bfcf85f13096fa0ef7ab3ea013deb6 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json 0399917d7fdda6f9af410c709805dfb149b2451c data/armourandtoolsmod/recipes/rainbow_block_recipe.json 5caa6184a7c066fac3bbc8e3869ae712171fe202 data/armourandtoolsmod/recipes/rainbow_boots.json cc01dc105a026c1a42db2e4a7bea9ca208ef22e2 data/armourandtoolsmod/recipes/rainbow_chestplate.json diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json index 7b6c31d0..4d8696a7 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json @@ -1,7 +1,7 @@ { "type": "armourandtoolsmod:ingot_fusion_toll_enhancer_recipe", "category": "upgrading", - "craftTime": 500, + "crafttime": 500, "experience": 0.5, "ingredients": [ { diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index d5714e57..8a0e7294 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -349,7 +349,9 @@ public void fillStackedContents(StackedContents pContents) { @Override public void invalidateCaps() { super.invalidateCaps(); - for (int x = 0; x < handlers.length; x++) handlers[x].invalidate(); + for (net.minecraftforge.common.util.LazyOptional< + ? extends net.minecraftforge.items.IItemHandler> + handler : handlers) handler.invalidate(); } @Override diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt index ac325879..31ed4825 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt @@ -34,7 +34,6 @@ import net.minecraft.world.item.ItemStack import net.minecraft.world.item.crafting.Recipe import net.minecraft.world.level.Level import net.minecraft.world.level.block.entity.BaseContainerBlockEntity -import net.minecraftforge.common.ForgeHooks import net.minecraftforge.common.capabilities.ForgeCapabilities import net.minecraftforge.items.SlotItemHandler @@ -80,7 +79,7 @@ class IngotFusionTollEnhancerMenu( addSlot(InfusionFuelSlot(it, this)) // slot to place result - addSlot(OutputSlotItemHandler(it)) + addSlot(OutputSlotItemHandler(it, pInventory.player)) } } @@ -183,7 +182,7 @@ class IngotFusionTollEnhancerMenu( } fun isFuel(pStack: ItemStack): Boolean { - return ForgeHooks.getBurnTime(pStack, recipeType) > 0 + return IngotFusionTollEnhancerBlockEntity.getFuels().containsKey(pStack.item) } fun getLitProgress(): Int { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt index f9153c61..1c09fbbe 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt @@ -18,13 +18,45 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity +import kotlin.math.min +import net.minecraft.server.level.ServerPlayer +import net.minecraft.world.entity.player.Player import net.minecraft.world.item.ItemStack +import net.minecraftforge.event.ForgeEventFactory import net.minecraftforge.items.IItemHandler import net.minecraftforge.items.SlotItemHandler -class OutputSlotItemHandler(itemHandler: IItemHandler) : SlotItemHandler(itemHandler, 4, 138, 40) { +class OutputSlotItemHandler(itemHandler: IItemHandler, val player: Player) : + SlotItemHandler(itemHandler, 4, 138, 40) { + private var removeCount: Int? = null override fun mayPlace(stack: ItemStack): Boolean { return false } + + override fun remove(pAmount: Int): ItemStack { + if (hasItem()) { + this.removeCount = min(pAmount, this.item.count) + } + return super.remove(pAmount) + } + + override fun onTake(pPlayer: Player, pStack: ItemStack) { + checkTakeAchievements(pStack) + super.onTake(pPlayer, pStack) + } + + /** @param pStack the output - ie, iron ingots, and pickaxes, not ore and wood. */ + override fun checkTakeAchievements(pStack: ItemStack) { + pStack.onCraftedBy(this.player.level(), this.player, removeCount ?: 0) + val player: Player = this.player + if (player is ServerPlayer) { + val container = container + (container as? IngotFusionTollEnhancerBlockEntity)?.awardUsedRecipesAndPopExperience( + player) + } + removeCount = 0 + ForgeEventFactory.firePlayerSmeltedEvent(player, pStack) + } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt index 416a67bc..48581879 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt @@ -53,7 +53,7 @@ class ArmourAndToolsModJEIPlugin : IModPlugin { val recipesTool = recipeManager.getAllRecipesFor(RecipeTypeInit.TOOL_CRAFTING.get()) val recipesArmour = recipeManager.getAllRecipesFor(RecipeTypeInit.ARMOUR_CRAFTING.get()) val recipesIngotFusionTollEnhancer = - recipeManager.getAllRecipesFor(IngotFusionTollEnhancerRecipe.Type.INSTANCE) + recipeManager.getAllRecipesFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()) registration.addRecipes(toolCraftingTableRecipeType, recipesTool) registration.addRecipes(armourCraftingTableRecipeType, recipesArmour) registration.addRecipes(ingotFusionTollEnhancerRecipeType, recipesIngotFusionTollEnhancer) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt index b419ec4b..be83182b 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt @@ -113,7 +113,7 @@ class IngotFusionTollEnhancerJEIRecipeCategory(guiHelper: IGuiHelper) : builder.addSlot(RecipeIngredientRole.INPUT, 70, 40).addIngredients(recipe.ingredients[2]) builder - .addSlot(RecipeIngredientRole.INPUT, 102, 70) + .addSlot(RecipeIngredientRole.INPUT, 102, 65) .addItemStacks(IngotFusionTollEnhancerBlockEntity.getFuelAsItemStacks().toList()) builder.addSlot(RecipeIngredientRole.OUTPUT, 138, 40).addItemStack(recipe.result) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 9fca79c1..eea7781d 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -21,6 +21,7 @@ package io.github.realyusufismail.armourandtoolsmod.recipe.fusion import com.google.gson.JsonObject import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookCategory import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit import net.minecraft.core.NonNullList import net.minecraft.core.RegistryAccess import net.minecraft.network.FriendlyByteBuf @@ -88,17 +89,7 @@ class IngotFusionTollEnhancerRecipe( } override fun getType(): RecipeType<*> { - return Type.INSTANCE - } - - class Type : RecipeType { - override fun toString(): String { - return "ingot_fusion_toll_enhancer" - } - - companion object { - val INSTANCE = Type() - } + return RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get() } companion object { From 27d34d7305d06cbd157951154a96a30cbf40b06f Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 5 Oct 2023 22:34:14 +0100 Subject: [PATCH 24/51] recipe name could be cuaisng issue --- .../resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 4 ++-- .../{root.json => upgrading/magma_strike_pickaxe.json} | 2 +- .../recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt | 4 +--- 3 files changed, 4 insertions(+), 6 deletions(-) rename src/generated/resources/data/armourandtoolsmod/advancements/recipes/{root.json => upgrading/magma_strike_pickaxe.json} (93%) diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index 072cc1fc..a26276ed 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-05T22:13:53.0037291 Recipes +// 1.20.1 2023-10-05T22:33:43.7549845 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -160,7 +160,6 @@ b15626440399c8d4ec922cffd9f4391ff8dc7de9 data/armourandtoolsmod/advancements/rec 8dfc7d5e8d8d0edff54402501e101b77b8141a4e data/armourandtoolsmod/advancements/recipes/misc/smelting_sapphire_shield.json 1d355a6149df6ee90baceb2af58481b174d39f53 data/armourandtoolsmod/advancements/recipes/misc/smelting_sapphire_shovel.json cf55c36fed542c0e3e3b99255aec56aae6a5bbc2 data/armourandtoolsmod/advancements/recipes/misc/smelting_sapphire_sword.json -ecea73ae8a409b07d9010ff73813373c5ce30c15 data/armourandtoolsmod/advancements/recipes/root.json e9b479dce4a333e720dc29b6332122e7b592f0ca data/armourandtoolsmod/advancements/recipes/tools/amethyst_axe.json 64fbc2a7192aa157444bfae3b1e41b9b8bd4c42e data/armourandtoolsmod/advancements/recipes/tools/amethyst_pickaxe.json d23584eced53cc0fa543f7749096db34a79e98e8 data/armourandtoolsmod/advancements/recipes/tools/amethyst_shovel.json @@ -183,6 +182,7 @@ e0a2d46e6a562d46dccc42eedcda00b89d3a7cd2 data/armourandtoolsmod/advancements/rec 8eb669e829e5a81651b5691926c209d16e317be4 data/armourandtoolsmod/advancements/recipes/tools/ruby_shovel.json afaa0f79973970a20fc6ad1a6b628e40e73b2ae7 data/armourandtoolsmod/advancements/recipes/tools/ruby_sword.json 406cfeb511bd6a34d4fcf0a30868e5fa7073bd25 data/armourandtoolsmod/advancements/recipes/tools/sapphire_shield.json +ef7ef1d4b425916d8205de09e00227225687c9de data/armourandtoolsmod/advancements/recipes/upgrading/magma_strike_pickaxe.json 78da516c72de91179803d7068271bcde9500cee8 data/armourandtoolsmod/recipes/amethyst_axe.json 36968ac2704b6aba42cbae8bd74269a8ca416f6a data/armourandtoolsmod/recipes/amethyst_boots.json f6ab1e0d36c50e07935b2072de4731f32e2b9c64 data/armourandtoolsmod/recipes/amethyst_chestplate.json diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/root.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/upgrading/magma_strike_pickaxe.json similarity index 93% rename from src/generated/resources/data/armourandtoolsmod/advancements/recipes/root.json rename to src/generated/resources/data/armourandtoolsmod/advancements/recipes/upgrading/magma_strike_pickaxe.json index 704c00c9..e7e0538b 100644 --- a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/root.json +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/upgrading/magma_strike_pickaxe.json @@ -1,5 +1,5 @@ { - "parent": "armourandtoolsmod:recipes/root", + "parent": "minecraft:recipes/root", "criteria": { "has_imperium_ingot": { "conditions": { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index fbfe11d2..be28e178 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -74,9 +74,7 @@ class IngotFusionTollEnhancerRecipeBuilder( craftTime, experience, advancementBuilder, - ResourceLocation(rl.namespace, "recipes/root").also { advancementId -> - advancementBuilder.parent(advancementId) - }, + rl.withPrefix("recipes/" + recipeCategory.serializedName + "/"), rl)) } catch (e: IllegalStateException) { throw IllegalStateException("Could not create recipe: $rl", e) From 9d03bc5ada7e53b26733969a51b5e589b6dbc111 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 6 Oct 2023 08:05:46 +0100 Subject: [PATCH 25/51] made a change with RecipeSerializer anem for ingot --- .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 6 +- .../magma_strike_pickaxe.json | 0 .../recipes/magma_strike_pickaxe.json | 4 +- ...gotFusionTollEnhancerRecipeBookCategory.kt | 3 +- .../core/init/RecipeCategoriesInit.kt | 66 +++++++++++++++++++ .../core/init/RecipeSerializerInit.kt | 4 +- .../IngotFusionTollEnhancerRecipeProvider.kt | 2 +- .../fusion/IngotFusionTollEnhancerRecipe.kt | 22 ++++++- 8 files changed, 95 insertions(+), 12 deletions(-) rename src/generated/resources/data/armourandtoolsmod/advancements/recipes/{upgrading => tool}/magma_strike_pickaxe.json (100%) diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index a26276ed..192de265 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-05T22:33:43.7549845 Recipes +// 1.20.1 2023-10-06T08:03:36.4370507 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -182,7 +182,7 @@ e0a2d46e6a562d46dccc42eedcda00b89d3a7cd2 data/armourandtoolsmod/advancements/rec 8eb669e829e5a81651b5691926c209d16e317be4 data/armourandtoolsmod/advancements/recipes/tools/ruby_shovel.json afaa0f79973970a20fc6ad1a6b628e40e73b2ae7 data/armourandtoolsmod/advancements/recipes/tools/ruby_sword.json 406cfeb511bd6a34d4fcf0a30868e5fa7073bd25 data/armourandtoolsmod/advancements/recipes/tools/sapphire_shield.json -ef7ef1d4b425916d8205de09e00227225687c9de data/armourandtoolsmod/advancements/recipes/upgrading/magma_strike_pickaxe.json +ef7ef1d4b425916d8205de09e00227225687c9de data/armourandtoolsmod/advancements/recipes/tool/magma_strike_pickaxe.json 78da516c72de91179803d7068271bcde9500cee8 data/armourandtoolsmod/recipes/amethyst_axe.json 36968ac2704b6aba42cbae8bd74269a8ca416f6a data/armourandtoolsmod/recipes/amethyst_boots.json f6ab1e0d36c50e07935b2072de4731f32e2b9c64 data/armourandtoolsmod/recipes/amethyst_chestplate.json @@ -280,7 +280,7 @@ adf63b0d9c8b2e333a5e4769a2fc0183f483544e data/armourandtoolsmod/recipes/graphite b790592cbe2e046b1e8169e2fb4a8da1483a8dfb data/armourandtoolsmod/recipes/graphite_shield.json aa31085980f2c7c3e8bad8a4dccb79315eac0102 data/armourandtoolsmod/recipes/imperium_pickaxe.json 9d9c3b5485306909e7c17e86c42d4afe8125c648 data/armourandtoolsmod/recipes/imperium_sword.json -13a143b409bfcf85f13096fa0ef7ab3ea013deb6 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +cda4dfad9454c54fef77cfc3a6f5e9c10c92db7e data/armourandtoolsmod/recipes/magma_strike_pickaxe.json 0399917d7fdda6f9af410c709805dfb149b2451c data/armourandtoolsmod/recipes/rainbow_block_recipe.json 5caa6184a7c066fac3bbc8e3869ae712171fe202 data/armourandtoolsmod/recipes/rainbow_boots.json cc01dc105a026c1a42db2e4a7bea9ca208ef22e2 data/armourandtoolsmod/recipes/rainbow_chestplate.json diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/upgrading/magma_strike_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tool/magma_strike_pickaxe.json similarity index 100% rename from src/generated/resources/data/armourandtoolsmod/advancements/recipes/upgrading/magma_strike_pickaxe.json rename to src/generated/resources/data/armourandtoolsmod/advancements/recipes/tool/magma_strike_pickaxe.json diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json index 4d8696a7..d9cc454a 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json @@ -1,6 +1,6 @@ { - "type": "armourandtoolsmod:ingot_fusion_toll_enhancer_recipe", - "category": "upgrading", + "type": "armourandtoolsmod:ingot_fusion_toll_enhancer", + "category": "tool", "crafttime": 500, "experience": 0.5, "ingredients": [ diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt index cef589d0..7dfbb944 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt @@ -22,7 +22,8 @@ import net.minecraft.util.StringRepresentable enum class IngotFusionTollEnhancerRecipeBookCategory(private var bookName: String) : StringRepresentable { - UPGRADING("upgrading"), + TOOL("tool"), + ARMOUR("armour"), MISC("misc"); companion object { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeCategoriesInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeCategoriesInit.kt index 6276d29d..b67ef490 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeCategoriesInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeCategoriesInit.kt @@ -22,8 +22,10 @@ import com.google.common.base.Supplier import com.google.common.base.Suppliers import com.google.common.collect.ImmutableList import io.github.realyusufismail.armourandtoolsmod.blocks.armour.book.CustomArmourCraftingBookCategory +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookCategory import io.github.realyusufismail.armourandtoolsmod.blocks.tool.book.CustomToolsCraftingBookCategory import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import net.minecraft.client.RecipeBookCategories import net.minecraft.world.item.ItemStack @@ -113,6 +115,30 @@ object RecipeCategoriesInit { RecipeBookCategories.create("TOOL_CRAFTING_MISC", ItemStack(Items.DIAMOND_SHOVEL)) } + private val INGOT_FUSION_TOLL_ENHANCER_SEARCH: Supplier = + Suppliers.memoize { + RecipeBookCategories.create( + "INGOT_FUSION_TOLL_ENHANCER_SEARCH", ItemStack(Items.COMPASS)) + } + + private val INGOT_FUSION_TOLL_ENHANCER_TOOL: Supplier = + Suppliers.memoize { + RecipeBookCategories.create( + "INGOT_FUSION_TOLL_ENHANCER_TOOL", ItemStack(ItemInit.MAGMA_STRIKE_PICKAXE.get())) + } + + private val INGOT_FUSION_TOLL_ENHANCER_ARMOUR: Supplier = + Suppliers.memoize { + RecipeBookCategories.create( + "INGOT_FUSION_TOLL_ENHANCER_ARMOUR", ItemStack(ItemInit.RAINBOW_CHESTPLATE.get())) + } + + private val INGOT_FUSION_TOLL_ENHANCER_MISC: Supplier = + Suppliers.memoize { + RecipeBookCategories.create( + "INGOT_FUSION_TOLL_ENHANCER_MISC", ItemStack(Items.DIAMOND_SHOVEL)) + } + fun registerRecipeBookCategories(event: RegisterRecipeBookCategoriesEvent) { event.registerBookCategories( RecipeBookTypesInit.ARMOUR_CRAFTING, @@ -224,5 +250,45 @@ object RecipeCategoriesInit { TOOL_CRAFTING_MISC.get() } } + + event.registerBookCategories( + RecipeBookTypesInit.INGOT_FUSION, + ImmutableList.of( + INGOT_FUSION_TOLL_ENHANCER_SEARCH.get(), + INGOT_FUSION_TOLL_ENHANCER_TOOL.get(), + INGOT_FUSION_TOLL_ENHANCER_ARMOUR.get(), + INGOT_FUSION_TOLL_ENHANCER_MISC.get())) + + event.registerAggregateCategory( + INGOT_FUSION_TOLL_ENHANCER_SEARCH.get(), + ImmutableList.of( + INGOT_FUSION_TOLL_ENHANCER_TOOL.get(), + INGOT_FUSION_TOLL_ENHANCER_ARMOUR.get(), + INGOT_FUSION_TOLL_ENHANCER_MISC.get())) + + event.registerAggregateCategory( + INGOT_FUSION_TOLL_ENHANCER_TOOL.get(), listOf(INGOT_FUSION_TOLL_ENHANCER_TOOL.get())) + + event.registerAggregateCategory( + INGOT_FUSION_TOLL_ENHANCER_ARMOUR.get(), + listOf(INGOT_FUSION_TOLL_ENHANCER_ARMOUR.get())) + + event.registerAggregateCategory( + INGOT_FUSION_TOLL_ENHANCER_MISC.get(), listOf(INGOT_FUSION_TOLL_ENHANCER_MISC.get())) + + event.registerRecipeCategoryFinder(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()) { + if (it is IngotFusionTollEnhancerRecipe) { + when (it.recipeCategory) { + IngotFusionTollEnhancerRecipeBookCategory.TOOL -> + INGOT_FUSION_TOLL_ENHANCER_TOOL.get() + IngotFusionTollEnhancerRecipeBookCategory.ARMOUR -> + INGOT_FUSION_TOLL_ENHANCER_ARMOUR.get() + IngotFusionTollEnhancerRecipeBookCategory.MISC -> + INGOT_FUSION_TOLL_ENHANCER_MISC.get() + } + } else { + INGOT_FUSION_TOLL_ENHANCER_MISC.get() + } + } } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt index eec4846b..91ef2cd6 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt @@ -43,9 +43,7 @@ object RecipeSerializerInit { val INGOT_FUSION_TOLL_ENHANCER_RECIPE: ObjectHolderDelegate> = - register( - "ingot_fusion_toll_enhancer_recipe", - IngotFusionTollEnhancerRecipe.Companion.Serializer()) + register("ingot_fusion_toll_enhancer", IngotFusionTollEnhancerRecipe.Companion.Serializer()) private fun , T : Recipe<*>> register( pKey: String, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt index 76c6f01f..edec0913 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt @@ -32,7 +32,7 @@ class IngotFusionTollEnhancerRecipeProvider( fun build() { IngotFusionTollEnhancerRecipeBuilder.builder( - IngotFusionTollEnhancerRecipeBookCategory.UPGRADING, + IngotFusionTollEnhancerRecipeBookCategory.TOOL, ItemInit.IMPERIUM.get(), ItemInit.IMPERIUM_PICKAXE.get(), ItemInit.IMPERIUM.get(), diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index eea7781d..47011ba2 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -40,6 +40,7 @@ class IngotFusionTollEnhancerRecipe( val result: ItemStack, val craftTime: Int, private val experience: Float, + val recipeCategory: IngotFusionTollEnhancerRecipeBookCategory, private val recipeId: ResourceLocation, ) : Recipe { @@ -117,7 +118,14 @@ class IngotFusionTollEnhancerRecipe( ShapedRecipe.itemStackFromJson(GsonHelper.getAsJsonObject(json, "result")) return IngotFusionTollEnhancerRecipe( - input1, input2, input3, result, craftTime, experience, pRecipeId) + input1, + input2, + input3, + result, + craftTime, + experience, + recipeCategory, + pRecipeId) } catch (e: IllegalStateException) { throw IllegalStateException("Could not create recipe: $pRecipeId", e) } @@ -162,9 +170,18 @@ class IngotFusionTollEnhancerRecipe( val result = pBuffer.readItem() val craftTime = pBuffer.readInt() val experience = pBuffer.readFloat() + val recipeCategory = + pBuffer.readEnum(IngotFusionTollEnhancerRecipeBookCategory::class.java) return IngotFusionTollEnhancerRecipe( - input1, input2, input3, result, craftTime, experience, pRecipeId) + input1, + input2, + input3, + result, + craftTime, + experience, + recipeCategory, + pRecipeId) } catch (e: IllegalStateException) { throw IllegalStateException("Could not read recipe: $pRecipeId", e) } @@ -182,6 +199,7 @@ class IngotFusionTollEnhancerRecipe( pBuffer.writeItem(pRecipe.result) pBuffer.writeInt(pRecipe.craftTime) pBuffer.writeFloat(pRecipe.experience) + pBuffer.writeEnum(pRecipe.recipeCategory) } catch (e: IllegalStateException) { throw IllegalStateException("Could not write recipe: ${pRecipe.id}", e) } From 44b867cac57c46620245f0ab1d1f4710b7902aa6 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 6 Oct 2023 08:39:33 +0100 Subject: [PATCH 26/51] recipe issue is that is left --- .../blocks/infusion/IngotFusionTollEnhancerScreen.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java index c5a7c1e0..5b90e34c 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java @@ -78,7 +78,7 @@ protected void init() { this.recipeBookComponent.toggleVisibility(); this.leftPos = this.recipeBookComponent.updateScreenPosition(this.width, this.imageWidth); - p_98484_.setPosition(this.leftPos + 5, this.height / 2 - 49); + p_98484_.setPosition(this.leftPos + 5, this.height / 2 - 22); })); this.addWidget(this.recipeBookComponent); this.setInitialFocus(this.recipeBookComponent); From 4e67c83ed45d223167528ecb21895465fd37f865 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 6 Oct 2023 08:59:25 +0100 Subject: [PATCH 27/51] Added doka workflow --- .github/workflows/page.yml | 42 ++++++++++++++++++++++++++++++++++++++ build.gradle.kts | 28 ++++++++++++++++++++++++- 2 files changed, 69 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/page.yml diff --git a/.github/workflows/page.yml b/.github/workflows/page.yml new file mode 100644 index 00000000..9ee54a6c --- /dev/null +++ b/.github/workflows/page.yml @@ -0,0 +1,42 @@ +name: Generate dokka github pages + +on: + push: + branches: [ main ] + workflow_dispatch: + +permissions: + contents: read + pages: write + id-token: write + +concurrency: + group: "pages" + cancel-in-progress: true + +jobs: + build: + runs-on: ubuntu-latest + environment: + name: github-pages + url: ${{ steps.deployment.outputs.page_url }} + steps: + - uses: actions/checkout@v3 + - name: Set up JDK 17 + uses: actions/setup-java@v3 + with: + java-version: 17 + distribution: temurin + - name: Grant execute permission for gradlew + run: chmod +x gradlew + - name: Generate documentation directory + uses: gradle/gradle-build-action@v2 + with: + arguments: dokkaHtml + - name: Upload artifact + uses: actions/upload-pages-artifact@v1 + with: + path: ./build/dokka/html + - name: Deploy to GitHub Pages + id: deployment + uses: actions/deploy-pages@main \ No newline at end of file diff --git a/build.gradle.kts b/build.gradle.kts index 77248259..94713f20 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -1,11 +1,18 @@ import io.gitlab.arturbosch.detekt.Detekt +import java.net.URL import net.minecraftforge.gradle.userdev.UserDevExtension +import org.jetbrains.dokka.base.DokkaBase +import org.jetbrains.dokka.base.DokkaBaseConfiguration +import org.jetbrains.dokka.gradle.DokkaTask import org.jetbrains.kotlin.gradle.tasks.KotlinCompile buildscript { repositories { mavenCentral() } - dependencies { classpath("io.github.realyusufismail:jconfig:1.0.8") } + dependencies { + classpath("org.jetbrains.dokka:dokka-base:1.9.0") + classpath("io.github.realyusufismail:jconfig:1.0.8") + } } plugins { @@ -16,6 +23,7 @@ plugins { id("org.parchmentmc.librarian.forgegradle") version "1.+" id("io.gitlab.arturbosch.detekt") version "1.23.0" id("net.darkhax.curseforgegradle") version "1.1.16" + id("org.jetbrains.dokka") version "1.9.0" jacoco // code coverage reports } @@ -302,3 +310,21 @@ tasks.create("cfPublish", net.darkhax.curseforgegradle.TaskPublishCurseForge::cl mainFile.addModLoader("forge") mainFile.addGameVersion(mcVersion) } + +tasks.getByName("dokkaHtml", DokkaTask::class) { + dokkaSourceSets.configureEach { + includes.from("README.md") + jdkVersion.set(17) + sourceLink { + localDirectory.set(file("src/main/kotlin")) + remoteUrl.set( + URL( + "https://github.com/RealYusufIsmail-Mc-Mods/Armour-and-Tools-Mod/blob/main/src/main/kotlin")) + remoteLineSuffix.set("#L") + } + + pluginConfiguration { + footerMessage = "Copyright © 2023 RealYusufIsmail MC Mods" + } + } +} From 39ba784ffcf3fedfcbccc2dcca5159c317489c58 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 6 Oct 2023 09:06:43 +0100 Subject: [PATCH 28/51] Added source link for java --- build.gradle.kts | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/build.gradle.kts b/build.gradle.kts index 94713f20..55199d3c 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -323,6 +323,14 @@ tasks.getByName("dokkaHtml", DokkaTask::class) { remoteLineSuffix.set("#L") } + sourceLink { + localDirectory.set(file("src/main/java")) + remoteUrl.set( + URL( + "https://github.com/RealYusufIsmail-Mc-Mods/Armour-and-Tools-Mod/blob/main/src/main/java")) + remoteLineSuffix.set("#L") + } + pluginConfiguration { footerMessage = "Copyright © 2023 RealYusufIsmail MC Mods" } From 1e0e35efeb33e1c816843d34e4ec2fe2d6586cdb Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 6 Oct 2023 11:32:04 +0100 Subject: [PATCH 29/51] modified some workflows --- .github/workflows/codecov.yml | 2 +- .github/workflows/gradle.yml | 6 +++--- .github/workflows/stale.yml | 29 ----------------------------- 3 files changed, 4 insertions(+), 33 deletions(-) delete mode 100644 .github/workflows/stale.yml diff --git a/.github/workflows/codecov.yml b/.github/workflows/codecov.yml index 20e8e50a..7b13bbe8 100644 --- a/.github/workflows/codecov.yml +++ b/.github/workflows/codecov.yml @@ -8,7 +8,7 @@ jobs: name: "Codecov" steps: - uses: actions/checkout@v4 - - name: Setup java + - name: Setup java 17 uses: actions/setup-java@v3 with: distribution: "temurin" diff --git a/.github/workflows/gradle.yml b/.github/workflows/gradle.yml index ec716ec0..7ae95f4b 100644 --- a/.github/workflows/gradle.yml +++ b/.github/workflows/gradle.yml @@ -5,9 +5,9 @@ name: Java CI on: push: - branches: [ main, 1.20.1 ] + branches: [ main ] pull_request: - branches: [ main, 1.20.1 ] + branches: [ main ] jobs: build: @@ -15,7 +15,7 @@ jobs: steps: - uses: actions/checkout@v4 - - name: Set up JDK 11 + - name: Set up JDK 17 uses: actions/setup-java@v3 with: java-version: '17' diff --git a/.github/workflows/stale.yml b/.github/workflows/stale.yml deleted file mode 100644 index 3c5ce708..00000000 --- a/.github/workflows/stale.yml +++ /dev/null @@ -1,29 +0,0 @@ -# This workflow warns and then closes issues and PRs that have had no activity for a specified amount of time. -# -# You can adjust the behavior by modifying this file. -# For more information, see: -# https://github.com/actions/stale -name: Mark stale issues and pull requests - -on: - schedule: - - cron: '0 7 * * *' - -jobs: - stale: - - runs-on: ubuntu-latest - permissions: - issues: write - pull-requests: write - - steps: - - uses: actions/stale@v8 - with: - repo-token: ${{ secrets.GITHUB_TOKEN }} - stale-issue-message: 'This issue is stale because it has been open 40 days with no activity. Remove stale label or comment or this will be closed in 5 days.' - stale-pr-message: 'This pull request is stale because it has been open 40 days with no activity. Remove stale label or comment or this will be closed in 5 days.' - close-issue-label: 'inactivity-closed' - close-pr-label: 'inactivity-closed' - days-before-stale: 40 - days-before-close: 5 From 534ec763ee28073c7a02271f577188f377955828 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 6 Oct 2023 12:12:33 +0100 Subject: [PATCH 30/51] Update IngotFusionTollEnhancerBlockEntity.java --- .../IngotFusionTollEnhancerBlockEntity.java | 99 ++++++++++--------- 1 file changed, 52 insertions(+), 47 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index 8a0e7294..cb7d3075 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -368,73 +368,78 @@ private boolean isLit() { public static void serverTick( Level level, BlockPos pPos, BlockState pState, IngotFusionTollEnhancerBlockEntity pEntity) { - val flag = pEntity.isLit(); - var flag1 = false; - if (pEntity.isLit()) { - pEntity.setLitTime(pEntity.getLitTime() - 1); - } + try { + val flag = pEntity.isLit(); + var flag1 = false; - val itemstack = pEntity.getItems().get(1); - val flag2 = !pEntity.getItems().get(0).isEmpty(); - val flag3 = !itemstack.isEmpty(); + if (pEntity.isLit()) { + pEntity.setLitTime(pEntity.getLitTime() - 1); + } - if (pEntity.isLit() || (flag3 && flag2)) { - Recipe recipe = - flag2 ? pEntity.getQuickCheck().getRecipeFor(pEntity, level).orElse(null) : null; - int i = pEntity.getMaxStackSize(); + val itemstack = pEntity.getItems().get(1); + val flag2 = !pEntity.getItems().get(0).isEmpty(); + val flag3 = !itemstack.isEmpty(); - if (!pEntity.isLit() - && pEntity.canCreate(level.registryAccess(), recipe, pEntity.getItems(), i)) { - pEntity.setLitTime(pEntity.getTotalCraftTime(itemstack)); - pEntity.setLitDuration(pEntity.getLitTime()); + if (pEntity.isLit() || (flag3 && flag2)) { + Recipe recipe = + flag2 ? pEntity.getQuickCheck().getRecipeFor(pEntity, level).orElse(null) : null; + int i = pEntity.getMaxStackSize(); - if (pEntity.isLit()) { - flag1 = true; + if (!pEntity.isLit() + && pEntity.canCreate(level.registryAccess(), recipe, pEntity.getItems(), i)) { + pEntity.setLitTime(pEntity.getTotalCraftTime(itemstack)); + pEntity.setLitDuration(pEntity.getLitTime()); - if (itemstack.hasCraftingRemainingItem()) { - pEntity.getItems().set(1, itemstack.getCraftingRemainingItem()); - } else if (flag3) { - Item item = itemstack.getItem(); - itemstack.shrink(1); + if (pEntity.isLit()) { + flag1 = true; - if (itemstack.isEmpty()) { + if (itemstack.hasCraftingRemainingItem()) { pEntity.getItems().set(1, itemstack.getCraftingRemainingItem()); + } else if (flag3) { + Item item = itemstack.getItem(); + itemstack.shrink(1); + + if (itemstack.isEmpty()) { + pEntity.getItems().set(1, itemstack.getCraftingRemainingItem()); + } } } } - } - if (pEntity.isLit() - && pEntity.canCreate(level.registryAccess(), recipe, pEntity.getItems(), i)) { - pEntity.setCreatingTime(pEntity.getCreatingTime() + 1); + if (pEntity.isLit() + && pEntity.canCreate(level.registryAccess(), recipe, pEntity.getItems(), i)) { + pEntity.setCreatingTime(pEntity.getCreatingTime() + 1); - if (pEntity.getCreatingTime() == pEntity.getCreatingTotalTime()) { - pEntity.setCreatingTime(0); - pEntity.setCreatingTotalTime(getTotalCraftTime(level, pEntity)); + if (pEntity.getCreatingTime() == pEntity.getCreatingTotalTime()) { + pEntity.setCreatingTime(0); + pEntity.setCreatingTotalTime(getTotalCraftTime(level, pEntity)); - if (pEntity.craft(level.registryAccess(), recipe, pEntity.getItems(), i)) { - pEntity.setRecipeUsed(recipe); + if (pEntity.craft(level.registryAccess(), recipe, pEntity.getItems(), i)) { + pEntity.setRecipeUsed(recipe); + } + flag1 = true; } - flag1 = true; + } else { + pEntity.setCreatingTime(0); } - } else { - pEntity.setCreatingTime(0); + } else if (!pEntity.isLit() && pEntity.getCreatingTime() > 0) { + pEntity.setCreatingTime(Math.max(pEntity.getCreatingTime() - 2, 0)); } - } else if (!pEntity.isLit() && pEntity.getCreatingTime() > 0) { - pEntity.setCreatingTime(Math.max(pEntity.getCreatingTime() - 2, 0)); - } - BlockState state = pState; + BlockState state = pState; - if (flag != pEntity.isLit()) { - flag1 = true; - state = pState.setValue(IngotFusionTollEnhancer.LIT, pEntity.isLit()); - level.setBlock(pPos, state, 3); - } + if (flag != pEntity.isLit()) { + flag1 = true; + state = pState.setValue(IngotFusionTollEnhancer.LIT, pEntity.isLit()); + level.setBlock(pPos, state, 3); + } - if (flag1) { - setChanged(level, pPos, state); + if (flag1) { + setChanged(level, pPos, state); + } + } catch (Exception e) { + throw new RuntimeException("Failed to tick block entity." + e); } } From df6ea00f008741b4a6bca337261e4ffe77651be3 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 11 Oct 2023 09:11:46 +0100 Subject: [PATCH 31/51] Pinned down the problem --- .../IngotFusionTollEnhancerBlockEntity.java | 263 ++++++++---------- .../IngotFusionTollEnhancerScreen.java | 2 +- .../infusion/IngotFusionTollEnhancerMenu.kt | 12 +- .../CustomArmourCraftingTableShapedRecipe.kt | 1 - .../fusion/IngotFusionTollEnhancerRecipe.kt | 53 ++-- .../CustomToolCraftingTableShapedRecipe.kt | 1 - 6 files changed, 149 insertions(+), 183 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index cb7d3075..d87581da 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -19,6 +19,7 @@ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; import com.google.common.collect.Lists; +import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit; @@ -27,10 +28,7 @@ import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe; import it.unimi.dsi.fastutil.objects.Object2IntMap; import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap; -import java.util.LinkedHashMap; -import java.util.List; -import java.util.Map; -import java.util.Set; +import java.util.*; import lombok.Getter; import lombok.Setter; import lombok.val; @@ -39,7 +37,6 @@ import net.minecraft.core.BlockPos; import net.minecraft.core.Direction; import net.minecraft.core.NonNullList; -import net.minecraft.core.RegistryAccess; import net.minecraft.nbt.CompoundTag; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; @@ -49,6 +46,7 @@ import net.minecraft.util.Mth; import net.minecraft.world.Container; import net.minecraft.world.ContainerHelper; +import net.minecraft.world.SimpleContainer; import net.minecraft.world.WorldlyContainer; import net.minecraft.world.entity.ExperienceOrb; import net.minecraft.world.entity.player.Inventory; @@ -66,12 +64,12 @@ import net.minecraft.world.item.crafting.RecipeManager; import net.minecraft.world.item.crafting.RecipeType; import net.minecraft.world.level.Level; -import net.minecraft.world.level.block.Blocks; import net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity; import net.minecraft.world.level.block.entity.BaseContainerBlockEntity; import net.minecraft.world.level.block.state.BlockState; import net.minecraft.world.phys.Vec3; import net.minecraftforge.common.ForgeHooks; +import net.minecraftforge.items.ItemStackHandler; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; @@ -99,10 +97,8 @@ public class IngotFusionTollEnhancerBlockEntity extends BaseContainerBlockEntity private static final int[] SLOTS_FOR_UP = new int[] {0}; private static final int[] SLOTS_FOR_DOWN = new int[] {4, 3}; private static final int[] SLOTS_FOR_SIDES = new int[] {1, 2}; - @Getter @Setter int litTime; - @Getter @Setter int litDuration; - @Getter @Setter int creatingTime; - @Getter @Setter int creatingTotalTime; + @Getter @Setter int creatingTime = 0; + @Getter @Setter int creatingTotalTime = 200; public IngotFusionTollEnhancerBlockEntity(BlockPos blockPos, BlockState blockState) { super(BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), blockPos, blockState); @@ -110,29 +106,33 @@ public IngotFusionTollEnhancerBlockEntity(BlockPos blockPos, BlockState blockSta this.quickCheck = RecipeManager.createCheck(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()); } + private final ItemStackHandler itemHandler = + new ItemStackHandler(NUMBER_OF_SLOTS) { + @Override + protected void onContentsChanged(int slot) { + setChanged(); + } + }; + protected final ContainerData dataAccess = new ContainerData() { public int get(int p_58431_) { return switch (p_58431_) { - case 0 -> litTime; - case 1 -> litDuration; - case 2 -> creatingTime; - case 3 -> creatingTotalTime; - default -> 0; + case 0 -> IngotFusionTollEnhancerBlockEntity.this.creatingTime; + case 1 -> IngotFusionTollEnhancerBlockEntity.this.creatingTotalTime; + default -> throw new IllegalArgumentException("Invalid index: " + p_58431_); }; } public void set(int p_58433_, int p_58434_) { switch (p_58433_) { - case 0 -> litTime = p_58434_; - case 1 -> litDuration = p_58434_; - case 2 -> creatingTime = p_58434_; - case 3 -> creatingTotalTime = p_58434_; + case 0 -> IngotFusionTollEnhancerBlockEntity.this.creatingTime = p_58434_; + case 1 -> IngotFusionTollEnhancerBlockEntity.this.creatingTotalTime = p_58434_; } } public int getCount() { - return 4; + return 2; } }; @@ -141,10 +141,10 @@ public void load(CompoundTag pTag) { super.load(pTag); this.items = NonNullList.withSize(this.getContainerSize(), ItemStack.EMPTY); ContainerHelper.loadAllItems(pTag, this.items); - this.litTime = pTag.getInt("BurnTime"); + this.creatingTime = pTag.getInt("CraftTime"); this.creatingTotalTime = pTag.getInt("CraftTimeTotal"); - this.litDuration = this.getTotalCraftTime(this.items.get(1)); + CompoundTag compoundtag = pTag.getCompound("RecipesUsed"); for (String s : compoundtag.getAllKeys()) { @@ -154,17 +154,20 @@ public void load(CompoundTag pTag) { @Override protected void saveAdditional(CompoundTag pTag) { - super.saveAdditional(pTag); - pTag.putInt("BurnTime", this.litTime); + pTag.putInt("CraftTime", this.creatingTime); pTag.putInt("CraftTimeTotal", this.creatingTotalTime); + ContainerHelper.saveAllItems(pTag, this.items); CompoundTag compoundtag = new CompoundTag(); this.recipesUsed.forEach( (p_187449_, p_187450_) -> { compoundtag.putInt(p_187449_.toString(), p_187450_); }); + pTag.put("RecipesUsed", compoundtag); + + super.saveAdditional(pTag); } @Override @@ -362,141 +365,117 @@ public void reviveCaps() { this, Direction.UP, Direction.DOWN, Direction.NORTH); } - private boolean isLit() { - return this.litTime > 0; - } - public static void serverTick( Level level, BlockPos pPos, BlockState pState, IngotFusionTollEnhancerBlockEntity pEntity) { + if (level.isClientSide()) { + ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("Client"); + return; + } - try { - val flag = pEntity.isLit(); - var flag1 = false; - - if (pEntity.isLit()) { - pEntity.setLitTime(pEntity.getLitTime() - 1); - } + if (hasRecipe(pEntity)) { + // craftItem(pEntity); - val itemstack = pEntity.getItems().get(1); - val flag2 = !pEntity.getItems().get(0).isEmpty(); - val flag3 = !itemstack.isEmpty(); - - if (pEntity.isLit() || (flag3 && flag2)) { - Recipe recipe = - flag2 ? pEntity.getQuickCheck().getRecipeFor(pEntity, level).orElse(null) : null; - int i = pEntity.getMaxStackSize(); - - if (!pEntity.isLit() - && pEntity.canCreate(level.registryAccess(), recipe, pEntity.getItems(), i)) { - pEntity.setLitTime(pEntity.getTotalCraftTime(itemstack)); - pEntity.setLitDuration(pEntity.getLitTime()); - - if (pEntity.isLit()) { - flag1 = true; - - if (itemstack.hasCraftingRemainingItem()) { - pEntity.getItems().set(1, itemstack.getCraftingRemainingItem()); - } else if (flag3) { - Item item = itemstack.getItem(); - itemstack.shrink(1); - - if (itemstack.isEmpty()) { - pEntity.getItems().set(1, itemstack.getCraftingRemainingItem()); - } - } - } - } + pEntity.creatingTime++; + setChanged(level, pPos, pState); - if (pEntity.isLit() - && pEntity.canCreate(level.registryAccess(), recipe, pEntity.getItems(), i)) { - pEntity.setCreatingTime(pEntity.getCreatingTime() + 1); + if (pEntity.creatingTime >= pEntity.creatingTotalTime) { + craftItem(pEntity); + } + } else { + ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("No Recipe"); + pEntity.resetProgress(); + setChanged(level, pPos, pState); + } + } - if (pEntity.getCreatingTime() == pEntity.getCreatingTotalTime()) { - pEntity.setCreatingTime(0); - pEntity.setCreatingTotalTime(getTotalCraftTime(level, pEntity)); + private static void craftItem(IngotFusionTollEnhancerBlockEntity pEntity) { + Level level = pEntity.level; + SimpleContainer inventory = new SimpleContainer(pEntity.itemHandler.getSlots()); + for (int i = 0; i < pEntity.itemHandler.getSlots(); i++) { + inventory.setItem(i, pEntity.itemHandler.getStackInSlot(i)); + } - if (pEntity.craft(level.registryAccess(), recipe, pEntity.getItems(), i)) { - pEntity.setRecipeUsed(recipe); - } - flag1 = true; - } - } else { - pEntity.setCreatingTime(0); + Optional recipe = + level + .getRecipeManager() + .getRecipeFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), inventory, level); + + if (hasRecipe(pEntity)) { + if (recipe.isPresent()) { + ItemStack result = recipe.get().getResult(); + if (pEntity.itemHandler.getStackInSlot(4).isEmpty()) { + pEntity.itemHandler.setStackInSlot(4, result.copy()); + } else if (pEntity.itemHandler.getStackInSlot(4).getItem() == result.getItem()) { + pEntity.itemHandler.getStackInSlot(4).grow(result.getCount()); } - } else if (!pEntity.isLit() && pEntity.getCreatingTime() > 0) { - pEntity.setCreatingTime(Math.max(pEntity.getCreatingTime() - 2, 0)); - } - BlockState state = pState; - - if (flag != pEntity.isLit()) { - flag1 = true; - state = pState.setValue(IngotFusionTollEnhancer.LIT, pEntity.isLit()); - level.setBlock(pPos, state, 3); - } + for (int i = 0; i < pEntity.itemHandler.getSlots(); i++) { + pEntity.itemHandler.getStackInSlot(i).shrink(1); + } - if (flag1) { - setChanged(level, pPos, state); + pEntity.resetProgress(); } - } catch (Exception e) { - throw new RuntimeException("Failed to tick block entity." + e); } } - private boolean canCreate( - RegistryAccess pRegistryAccess, - @Nullable Recipe pRecipe, - NonNullList pItems, - int pMaxStackSize) { - if (!pItems.get(0).isEmpty() && pRecipe != null) { - val itemstack = ((Recipe) pRecipe).assemble(this, pRegistryAccess); - if (itemstack.isEmpty()) { - return false; - } else { - // TODO: Check this - val itemstack1 = pItems.get(4); - if (itemstack1.isEmpty()) { - return true; - } else if (!ItemStack.isSameItem(itemstack1, itemstack)) { - return false; - } else if (itemstack1.getCount() + itemstack.getCount() <= pMaxStackSize - && itemstack1.getCount() + itemstack.getCount() <= itemstack1.getMaxStackSize()) { - return true; - } else { - return itemstack1.getCount() + itemstack.getCount() <= itemstack.getMaxStackSize(); - } - } - } else { - return false; - } + private void resetProgress() { + this.creatingTime = 0; } - private boolean craft( - RegistryAccess registryAccess, - Recipe recipe, - NonNullList inventroy, - Integer maxStackSize) { - if (recipe != null && canCreate(registryAccess, recipe, inventroy, maxStackSize)) { - val itemstack = inventroy.get(0); - val itemstack1 = ((Recipe) recipe).assemble(this, registryAccess); - val itemstack2 = inventroy.get(4); - if (itemstack2.isEmpty()) { - inventroy.set(4, itemstack1.copy()); - } else { - itemstack2.is(itemstack1.getItem()); - } - - if (itemstack.is(Blocks.WET_SPONGE.asItem()) - && !inventroy.get(1).isEmpty() - && inventroy.get(1).is(Items.BUCKET)) { - inventroy.set(1, new ItemStack(Items.WATER_BUCKET)); - } - - itemstack.shrink(1); - return true; - } else { - return false; + private static boolean hasRecipe(IngotFusionTollEnhancerBlockEntity entity) { + Level level = entity.level; + //TODO: Issue here where it returns air instead of the item + SimpleContainer inventory = new SimpleContainer(entity.itemHandler.getSlots()); + for (int i = 0; i < entity.itemHandler.getSlots(); i++) { + inventory.setItem(i, entity.itemHandler.getStackInSlot(i)); } + + ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("Checking Recipe for: " + inventory); + ArmourAndToolsMod.ArmorAndToolsMod.getLogger() + .info("Checking Recipe for: " + inventory.getItem(0)); + ArmourAndToolsMod.ArmorAndToolsMod.getLogger() + .info("Checking Recipe for: " + inventory.getItem(1)); + ArmourAndToolsMod.ArmorAndToolsMod.getLogger() + .info("Checking Recipe for: " + inventory.getItem(2)); + ArmourAndToolsMod.ArmorAndToolsMod.getLogger() + .info("Checking Recipe for: " + inventory.getItem(3)); + + level + .getRecipeManager() + .getRecipeFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), inventory, level) + .ifPresentOrElse( + (recipe) -> { + ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("Recipe: " + recipe); + ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("Recipe: " + recipe.getResult()); + }, + () -> { + ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("No Recipe"); + }); + + Optional recipe = + level + .getRecipeManager() + .getRecipeFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), inventory, level); + + return recipe.isPresent() + && canInsertAmountIntoOutputSlot(inventory) + && canInsertItemIntoOutputSlot(inventory, recipe.get().getResult()); + } + + private static boolean canInsertItemIntoOutputSlot(SimpleContainer inventory, ItemStack stack) { + ArmourAndToolsMod.ArmorAndToolsMod.getLogger() + .info("canInsertItemIntoOutputSlot: " + inventory.getItem(4).getItem() + " " + stack); + return inventory.getItem(4).isEmpty() || inventory.getItem(4).getItem() == stack.getItem(); + } + + private static boolean canInsertAmountIntoOutputSlot(SimpleContainer inventory) { + ArmourAndToolsMod.ArmorAndToolsMod.getLogger() + .info( + "canInsertAmountIntoOutputSlot: " + + inventory.getItem(4).getCount() + + " " + + inventory.getItem(4).getMaxStackSize()); + return inventory.getItem(4).getCount() + 1 <= inventory.getItem(4).getMaxStackSize(); } private Integer getTotalCraftTime(ItemStack itemStack) { diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java index 5b90e34c..64a5a900 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java @@ -102,7 +102,7 @@ protected void renderBg( int i = this.leftPos; int j = this.topPos; pGuiGraphics.blit(SCREEN_ID, i, j, 0, 0, 176, 179); - pGuiGraphics.blit(SCREEN_ID, i + 97, j + 38, 179, 25, menu.getLitProgress() + 1, 17); + pGuiGraphics.blit(SCREEN_ID, i + 97, j + 38, 179, 25, menu.getScaledProgress() + 1, 17); } catch (NullPointerException e) { throw new NullPointerException("Minecraft Instance is null"); } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt index 31ed4825..ae1b3e5c 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt @@ -58,13 +58,13 @@ class IngotFusionTollEnhancerMenu( pContainerId: Int, inventory: Inventory, data: FriendlyByteBuf - ) : this(pContainerId, getBlockEntity(inventory, data), SimpleContainerData(4), inventory) + ) : this(pContainerId, getBlockEntity(inventory, data), SimpleContainerData(2), inventory) init { level = pInventory.player.level() ?: throw IllegalStateException("Level is null") checkContainerSize(blockEntity, NUMBER_OF_SLOTS) - checkContainerDataCount(data, 4) + checkContainerDataCount(data, 2) addPlayerInventory(pInventory) addPlayerHotbar(pInventory) @@ -162,6 +162,14 @@ class IngotFusionTollEnhancerMenu( return pRecipe.matches(this.blockEntity, this.level) } + fun getScaledProgress(): Int { + val progress = data[0] + val maxProgress = data[1] // Max Progress + val progressArrowSize = 26 // This is the height in pixels of your arrow + return if (maxProgress != 0 && progress != 0) progress * progressArrowSize / maxProgress + else 0 + } + private fun addPlayerInventory(playerInventory: Inventory) { for (row in 0..2) { for (col in 0..8) { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/armour/CustomArmourCraftingTableShapedRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/armour/CustomArmourCraftingTableShapedRecipe.kt index 3e04cd8e..8316b7d4 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/armour/CustomArmourCraftingTableShapedRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/armour/CustomArmourCraftingTableShapedRecipe.kt @@ -42,7 +42,6 @@ import net.minecraftforge.common.ForgeHooks import net.minecraftforge.common.crafting.CraftingHelper import net.minecraftforge.common.crafting.IShapedRecipe -/** @see io.github.realyusufismail.realyusufismailcore.recipe.YusufShapedRecipeBuilder */ class CustomArmourCraftingTableShapedRecipe( private val id: ResourceLocation, private val group: String, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 47011ba2..0760f02b 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -103,9 +103,12 @@ class IngotFusionTollEnhancerRecipe( try { val ingredientArray = json.get("ingredients").asJsonArray - val input1 = Ingredient.fromJson(ingredientArray[0]) - val input2 = Ingredient.fromJson(ingredientArray[1]) - val input3 = Ingredient.fromJson(ingredientArray[2]) + val inputs = NonNullList.withSize(3, Ingredient.EMPTY) + + for (i in 0..2) { + val ingredient = ingredientArray[i].asJsonObject + inputs[i] = Ingredient.fromJson(ingredient) + } val craftTime = GsonHelper.getAsInt(json, "crafttime") val experience = GsonHelper.getAsFloat(json, "experience") @@ -118,9 +121,9 @@ class IngotFusionTollEnhancerRecipe( ShapedRecipe.itemStackFromJson(GsonHelper.getAsJsonObject(json, "result")) return IngotFusionTollEnhancerRecipe( - input1, - input2, - input3, + inputs[0], + inputs[1], + inputs[2], result, craftTime, experience, @@ -137,34 +140,10 @@ class IngotFusionTollEnhancerRecipe( ): IngotFusionTollEnhancerRecipe { try { - var input1: Ingredient? = null - var input2: Ingredient? = null - var input3: Ingredient? = null - - for (i in 0..3) { - val ingredient = Ingredient.fromNetwork(pBuffer) - - if (ingredient.isEmpty) { - throw IllegalStateException( - "No ingredients for ingot fusion toll enhancer recipe") - } - - when (i) { - 0 -> { - input1 = ingredient - } - 1 -> { - input2 = ingredient - } - 2 -> { - input3 = ingredient - } - } - } + val input = NonNullList.withSize(pBuffer.readInt(), Ingredient.EMPTY) - if (input1 == null || input2 == null || input3 == null) { - throw IllegalStateException( - "No ingredients for ingot fusion toll enhancer recipe") + for (i in input.indices) { + input[i] = Ingredient.fromNetwork(pBuffer) } val result = pBuffer.readItem() @@ -174,9 +153,9 @@ class IngotFusionTollEnhancerRecipe( pBuffer.readEnum(IngotFusionTollEnhancerRecipeBookCategory::class.java) return IngotFusionTollEnhancerRecipe( - input1, - input2, - input3, + input[0], + input[1], + input[2], result, craftTime, experience, @@ -192,6 +171,8 @@ class IngotFusionTollEnhancerRecipe( pRecipe: IngotFusionTollEnhancerRecipe ) { try { + pBuffer.writeInt(pRecipe.getIngredients().size) + for (ingredient in pRecipe.getIngredients()) { ingredient.toNetwork(pBuffer) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/tool/CustomToolCraftingTableShapedRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/tool/CustomToolCraftingTableShapedRecipe.kt index adafe288..9ffa8cb7 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/tool/CustomToolCraftingTableShapedRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/tool/CustomToolCraftingTableShapedRecipe.kt @@ -42,7 +42,6 @@ import net.minecraftforge.common.ForgeHooks import net.minecraftforge.common.crafting.CraftingHelper import net.minecraftforge.common.crafting.IShapedRecipe -/** @see io.github.realyusufismail.realyusufismailcore.recipe.YusufShapedRecipeBuilder */ class CustomToolCraftingTableShapedRecipe( private val id: ResourceLocation, private val group: String, From c72dc43834319ff5c8bd39401fd32673104c86b3 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 11 Oct 2023 13:08:13 +0100 Subject: [PATCH 32/51] still not working --- .../IngotFusionTollEnhancerBlockEntity.java | 41 ++++++------------- .../ArmourCraftingTableRecipeProvider.kt | 6 +++ .../fusion/IngotFusionTollEnhancerRecipe.kt | 15 ++----- 3 files changed, 22 insertions(+), 40 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index d87581da..504d928c 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -367,11 +367,6 @@ public void reviveCaps() { public static void serverTick( Level level, BlockPos pPos, BlockState pState, IngotFusionTollEnhancerBlockEntity pEntity) { - if (level.isClientSide()) { - ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("Client"); - return; - } - if (hasRecipe(pEntity)) { // craftItem(pEntity); @@ -401,20 +396,17 @@ private static void craftItem(IngotFusionTollEnhancerBlockEntity pEntity) { .getRecipeFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), inventory, level); if (hasRecipe(pEntity)) { - if (recipe.isPresent()) { - ItemStack result = recipe.get().getResult(); - if (pEntity.itemHandler.getStackInSlot(4).isEmpty()) { - pEntity.itemHandler.setStackInSlot(4, result.copy()); - } else if (pEntity.itemHandler.getStackInSlot(4).getItem() == result.getItem()) { - pEntity.itemHandler.getStackInSlot(4).grow(result.getCount()); - } + pEntity.itemHandler.extractItem(0, 1, false); + pEntity.itemHandler.extractItem(1, 1, false); + pEntity.itemHandler.extractItem(2, 1, false); - for (int i = 0; i < pEntity.itemHandler.getSlots(); i++) { - pEntity.itemHandler.getStackInSlot(i).shrink(1); - } + pEntity.itemHandler.setStackInSlot( + 4, + new ItemStack( + recipe.get().getResult().getItem(), + pEntity.itemHandler.getStackInSlot(4).getCount() + 1)); - pEntity.resetProgress(); - } + pEntity.resetProgress(); } } @@ -424,22 +416,13 @@ private void resetProgress() { private static boolean hasRecipe(IngotFusionTollEnhancerBlockEntity entity) { Level level = entity.level; - //TODO: Issue here where it returns air instead of the item + // TODO: Issue here where it returns air instead of the item + SimpleContainer inventory = new SimpleContainer(entity.itemHandler.getSlots()); for (int i = 0; i < entity.itemHandler.getSlots(); i++) { inventory.setItem(i, entity.itemHandler.getStackInSlot(i)); } - ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("Checking Recipe for: " + inventory); - ArmourAndToolsMod.ArmorAndToolsMod.getLogger() - .info("Checking Recipe for: " + inventory.getItem(0)); - ArmourAndToolsMod.ArmorAndToolsMod.getLogger() - .info("Checking Recipe for: " + inventory.getItem(1)); - ArmourAndToolsMod.ArmorAndToolsMod.getLogger() - .info("Checking Recipe for: " + inventory.getItem(2)); - ArmourAndToolsMod.ArmorAndToolsMod.getLogger() - .info("Checking Recipe for: " + inventory.getItem(3)); - level .getRecipeManager() .getRecipeFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), inventory, level) @@ -478,7 +461,7 @@ private static boolean canInsertAmountIntoOutputSlot(SimpleContainer inventory) return inventory.getItem(4).getCount() + 1 <= inventory.getItem(4).getMaxStackSize(); } - private Integer getTotalCraftTime(ItemStack itemStack) { + private static Integer getTotalCraftTime(ItemStack itemStack) { if (itemStack.isEmpty()) { return 0; } else { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ArmourCraftingTableRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ArmourCraftingTableRecipeProvider.kt index 088a7cc1..460f20fd 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ArmourCraftingTableRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ArmourCraftingTableRecipeProvider.kt @@ -35,6 +35,12 @@ class ArmourCraftingTableRecipeProvider( private val hasItem = "has_item" fun build() { + // TODO: Some recipies are broken + // java.lang.ArrayIndexOutOfBoundsException: null + // [11:25:59] [Render thread/ERROR] [me.je.li.ut.IngredientSupplierHelper/]: Found a broken + // recipe, failed to setRecipe with RecipeLayoutBuilder: Armour and Tools Mod + // armourandtoolsmod:aqumarine_boots class + // io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableShapedRecipe CustomArmourCraftingTableRecipeBuilder.shaped( CustomArmourCraftingBookCategory.ARMOUR_HEAD, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt index 0760f02b..88da4de0 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt @@ -46,20 +46,13 @@ class IngotFusionTollEnhancerRecipe( /** Used to check if a recipe matches current crafting inventory */ override fun matches(pContainer: Container, pLevel: Level): Boolean { - try { - return if (pLevel.isClientSide) false - else if (pContainer.containerSize < 3) false - else - input1.test(pContainer.getItem(0)) && - input2.test(pContainer.getItem(1)) && - input3.test(pContainer.getItem(2)) - } catch (e: Exception) { - throw IllegalStateException("Error while checking recipe: $recipeId", e) - } + return input1.test(pContainer.getItem(0)) && + input2.test(pContainer.getItem(1)) && + input3.test(pContainer.getItem(2)) } override fun assemble(pContainer: Container, pRegistryAccess: RegistryAccess): ItemStack { - return result + return result.copy() } /** Used to determine if this recipe can fit in a grid of the given width/height */ From 5831b3239a77da556cda78757f21c39830774727 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 11 Oct 2023 21:51:13 +0100 Subject: [PATCH 33/51] Done a complete re-write for IngotFusionTollEnhancerBlock --- .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 4 +- .../recipes/magma_strike_pickaxe.json | 26 +- .../IngotFusionTollEnhancerBlockEntity.java | 534 ++++++++---------- .../infusion/IngotFusionTollEnhancerMenu.java | 222 ++++++++ .../IngotFusionTollEnhancerScreen.java | 3 +- .../IngotFusionTollEnhancerRecipe.java | 198 +++++++ .../infusion/IngotFusionTollEnhancerMenu.kt | 218 ------- ...gotFusionTollEnhancerRecipeBookCategory.kt | 1 + .../blocks/infusion/slots/InfusionFuelSlot.kt | 3 +- .../infusion/slots/OutputSlotItemHandler.kt | 17 +- .../core/init/JEIRecipeTypes.kt | 2 +- .../core/init/MenuTypeInit.kt | 1 + .../core/init/RecipeBookTypesInit.kt | 2 +- .../core/init/RecipeCategoriesInit.kt | 4 +- .../core/init/RecipeSerializerInit.kt | 5 +- .../core/init/RecipeTypeInit.kt | 2 +- .../IngotFusionTollEnhancerRecipeBuilder.kt | 69 +-- .../IngotFusionTollEnhancerRecipeProvider.kt | 5 +- .../integration/ArmourAndToolsModJEIPlugin.kt | 2 +- ...ngotFusionTollEnhancerJEIRecipeCategory.kt | 2 +- .../fusion/IngotFusionTollEnhancerRecipe.kt | 183 ------ 21 files changed, 726 insertions(+), 777 deletions(-) create mode 100644 src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java create mode 100644 src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java delete mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt delete mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index 192de265..3bdf4133 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-06T08:03:36.4370507 Recipes +// 1.20.1 2023-10-11T21:50:46.5765886 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -280,7 +280,7 @@ adf63b0d9c8b2e333a5e4769a2fc0183f483544e data/armourandtoolsmod/recipes/graphite b790592cbe2e046b1e8169e2fb4a8da1483a8dfb data/armourandtoolsmod/recipes/graphite_shield.json aa31085980f2c7c3e8bad8a4dccb79315eac0102 data/armourandtoolsmod/recipes/imperium_pickaxe.json 9d9c3b5485306909e7c17e86c42d4afe8125c648 data/armourandtoolsmod/recipes/imperium_sword.json -cda4dfad9454c54fef77cfc3a6f5e9c10c92db7e data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +dcadccfdd9e219de6e433b1b34cf5c1a20aaee73 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json 0399917d7fdda6f9af410c709805dfb149b2451c data/armourandtoolsmod/recipes/rainbow_block_recipe.json 5caa6184a7c066fac3bbc8e3869ae712171fe202 data/armourandtoolsmod/recipes/rainbow_boots.json cc01dc105a026c1a42db2e4a7bea9ca208ef22e2 data/armourandtoolsmod/recipes/rainbow_chestplate.json diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json index d9cc454a..f082a6a0 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/magma_strike_pickaxe.json @@ -1,20 +1,18 @@ { "type": "armourandtoolsmod:ingot_fusion_toll_enhancer", "category": "tool", - "crafttime": 500, - "experience": 0.5, - "ingredients": [ - { - "item": "armourandtoolsmod:imperium" - }, - { - "item": "armourandtoolsmod:imperium_pickaxe" - }, - { - "item": "armourandtoolsmod:imperium" - } - ], + "ingredient1": { + "item": "armourandtoolsmod:imperium" + }, + "ingredient2": { + "item": "armourandtoolsmod:imperium_pickaxe" + }, + "ingredient3": { + "item": "armourandtoolsmod:imperium" + }, "result": { - "item": "armourandtoolsmod:magma_strike_pickaxe" + "count": 1, + "item": "armourandtoolsmod:magma_strike_pickaxe", + "nbt": "{Damage:0}" } } \ No newline at end of file diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index 504d928c..e4a943a5 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -18,15 +18,13 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; -import com.google.common.collect.Lists; import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit; import io.github.realyusufismail.armourandtoolsmod.core.init.ItemInit; import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit; -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe; -import it.unimi.dsi.fastutil.objects.Object2IntMap; +import io.github.realyusufismail.armourandtoolsmod.recipe.infusion.IngotFusionTollEnhancerRecipe; import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap; import java.util.*; import lombok.Getter; @@ -40,15 +38,8 @@ import net.minecraft.nbt.CompoundTag; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; -import net.minecraft.server.level.ServerLevel; -import net.minecraft.server.level.ServerPlayer; import net.minecraft.tags.ItemTags; -import net.minecraft.util.Mth; -import net.minecraft.world.Container; -import net.minecraft.world.ContainerHelper; -import net.minecraft.world.SimpleContainer; -import net.minecraft.world.WorldlyContainer; -import net.minecraft.world.entity.ExperienceOrb; +import net.minecraft.world.*; import net.minecraft.world.entity.player.Inventory; import net.minecraft.world.entity.player.Player; import net.minecraft.world.entity.player.StackedContents; @@ -59,7 +50,6 @@ import net.minecraft.world.item.Item; import net.minecraft.world.item.ItemStack; import net.minecraft.world.item.Items; -import net.minecraft.world.item.crafting.AbstractCookingRecipe; import net.minecraft.world.item.crafting.Recipe; import net.minecraft.world.item.crafting.RecipeManager; import net.minecraft.world.item.crafting.RecipeType; @@ -67,9 +57,6 @@ import net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity; import net.minecraft.world.level.block.entity.BaseContainerBlockEntity; import net.minecraft.world.level.block.state.BlockState; -import net.minecraft.world.phys.Vec3; -import net.minecraftforge.common.ForgeHooks; -import net.minecraftforge.items.ItemStackHandler; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; @@ -82,37 +69,30 @@ public class IngotFusionTollEnhancerBlockEntity extends BaseContainerBlockEntity @Getter private final RecipeManager.CachedCheck quickCheck; - @Getter - private NonNullList items = NonNullList.withSize(NUMBER_OF_SLOTS, ItemStack.EMPTY); - - private final Object2IntOpenHashMap recipesUsed = new Object2IntOpenHashMap<>(); + // recipe private final RecipeType type = RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(); - protected static final int SLOT_INPUT_1 = 0; - protected static final int SLOT_INPUT_2 = 1; - protected static final int SLOT_INPUT_3 = 2; - protected static final int SLOT_FUEL = 3; - protected static final int SLOT_RESULT = 4; + + private final Object2IntOpenHashMap recipesUsed = new Object2IntOpenHashMap<>(); + + // slots public static final int NUMBER_OF_SLOTS = 5; - private static final int[] SLOTS_FOR_UP = new int[] {0}; - private static final int[] SLOTS_FOR_DOWN = new int[] {4, 3}; - private static final int[] SLOTS_FOR_SIDES = new int[] {1, 2}; - @Getter @Setter int creatingTime = 0; - @Getter @Setter int creatingTotalTime = 200; + public static final int FUEL_SLOT = 3; + public static final int RESULT_SLOT = 4; + public static final int NUMBER_OF_DATA = 3; - public IngotFusionTollEnhancerBlockEntity(BlockPos blockPos, BlockState blockState) { - super(BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), blockPos, blockState); + @Getter + private NonNullList items = NonNullList.withSize(NUMBER_OF_SLOTS, ItemStack.EMPTY); - this.quickCheck = RecipeManager.createCheck(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()); - } + // ingredients + private ItemStack ingredient1; + private ItemStack ingredient2; + private ItemStack ingredient3; - private final ItemStackHandler itemHandler = - new ItemStackHandler(NUMBER_OF_SLOTS) { - @Override - protected void onContentsChanged(int slot) { - setChanged(); - } - }; + // data + @Getter @Setter int creatingTime = 0; + @Getter @Setter int creatingTotalTime = 200; + @Getter @Setter int fuel = 0; protected final ContainerData dataAccess = new ContainerData() { @@ -120,6 +100,7 @@ public int get(int p_58431_) { return switch (p_58431_) { case 0 -> IngotFusionTollEnhancerBlockEntity.this.creatingTime; case 1 -> IngotFusionTollEnhancerBlockEntity.this.creatingTotalTime; + case 2 -> IngotFusionTollEnhancerBlockEntity.this.fuel; default -> throw new IllegalArgumentException("Invalid index: " + p_58431_); }; } @@ -128,24 +109,30 @@ public void set(int p_58433_, int p_58434_) { switch (p_58433_) { case 0 -> IngotFusionTollEnhancerBlockEntity.this.creatingTime = p_58434_; case 1 -> IngotFusionTollEnhancerBlockEntity.this.creatingTotalTime = p_58434_; + case 2 -> IngotFusionTollEnhancerBlockEntity.this.fuel = p_58434_; } } public int getCount() { - return 2; + return NUMBER_OF_DATA; } }; + public IngotFusionTollEnhancerBlockEntity(BlockPos blockPos, BlockState blockState) { + super(BlockEntityTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), blockPos, blockState); + + this.quickCheck = RecipeManager.createCheck(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()); + } + @Override public void load(CompoundTag pTag) { super.load(pTag); this.items = NonNullList.withSize(this.getContainerSize(), ItemStack.EMPTY); ContainerHelper.loadAllItems(pTag, this.items); - this.creatingTime = pTag.getInt("CraftTime"); this.creatingTotalTime = pTag.getInt("CraftTimeTotal"); - CompoundTag compoundtag = pTag.getCompound("RecipesUsed"); + val compoundtag = pTag.getCompound("RecipesUsed"); for (String s : compoundtag.getAllKeys()) { this.recipesUsed.put(new ResourceLocation(s), compoundtag.getInt(s)); @@ -154,12 +141,10 @@ public void load(CompoundTag pTag) { @Override protected void saveAdditional(CompoundTag pTag) { - pTag.putInt("CraftTime", this.creatingTime); pTag.putInt("CraftTimeTotal", this.creatingTotalTime); - ContainerHelper.saveAllItems(pTag, this.items); - CompoundTag compoundtag = new CompoundTag(); + val compoundtag = new CompoundTag(); this.recipesUsed.forEach( (p_187449_, p_187450_) -> { compoundtag.putInt(p_187449_.toString(), p_187450_); @@ -170,312 +155,246 @@ protected void saveAdditional(CompoundTag pTag) { super.saveAdditional(pTag); } - @Override - public int @NotNull [] getSlotsForFace(Direction pSide) { - if (pSide == Direction.DOWN) { - return SLOTS_FOR_DOWN; - } else { - return pSide == Direction.UP ? SLOTS_FOR_UP : SLOTS_FOR_SIDES; - } - } - - @Override - public boolean canPlaceItemThroughFace( - int pIndex, ItemStack pItemStack, @Nullable Direction pDirection) { - return this.canPlaceItem(pIndex, pItemStack); - } - - @Override - public boolean canTakeItemThroughFace(int pIndex, ItemStack pStack, Direction pDirection) { - if (pDirection == Direction.DOWN && pIndex == 1) { - return pStack.is(Items.WATER_BUCKET) || pStack.is(Items.BUCKET); - } else { - return true; - } - } - @Override protected @NotNull Component getDefaultName() { return IngotFusionTollEnhancer.getContainerTitle(); } @Override - protected @NotNull AbstractContainerMenu createMenu(int pContainerId, Inventory pInventory) { - return new IngotFusionTollEnhancerMenu(pContainerId, this, dataAccess, pInventory); + protected AbstractContainerMenu createMenu(int pContainerId, Inventory pInventory) { + return new IngotFusionTollEnhancerMenu(pContainerId, this, this.dataAccess, pInventory); } @Override public int getContainerSize() { - return items.size(); + return this.items.size(); } @Override public boolean isEmpty() { - for (ItemStack itemStack : items) { - if (!itemStack.isEmpty()) { + for (ItemStack itemstack : this.items) { + if (!itemstack.isEmpty()) { return false; } } + return true; } @Override - public @NotNull ItemStack getItem(int pSlot) { - return items.get(pSlot); + public ItemStack getItem(int pSlot) { + return pSlot >= 0 && pSlot < this.items.size() ? this.items.get(pSlot) : ItemStack.EMPTY; } @Override - public @NotNull ItemStack removeItem(int pSlot, int pAmount) { - return ContainerHelper.removeItem(items, pSlot, pAmount); + public ItemStack removeItem(int pSlot, int pAmount) { + return ContainerHelper.removeItem(this.items, pSlot, pAmount); } @Override public ItemStack removeItemNoUpdate(int pSlot) { - return ContainerHelper.takeItem(items, pSlot); + return ContainerHelper.takeItem(this.items, pSlot); } @Override public void setItem(int pSlot, ItemStack pStack) { - val itemstack = this.items.get(pSlot); - val flag = !pStack.isEmpty() && ItemStack.isSameItemSameTags(itemstack, pStack); - this.items.set(pSlot, pStack); - if (pStack.getCount() > this.getMaxStackSize()) { - pStack.setCount(this.getMaxStackSize()); - } - - if (pSlot == 0 && !flag) { - this.creatingTotalTime = getTotalCraftTime(this.level, this); - this.creatingTime = 0; - this.setChanged(); + if (pSlot >= 0 && pSlot < this.items.size()) { + this.items.set(pSlot, pStack); } } @Override public boolean stillValid(Player pPlayer) { - return Container.stillValidBlockEntity(this, pPlayer); + if (this.level.getBlockEntity(this.worldPosition) != this) { + return false; + } else { + return pPlayer.distanceToSqr( + (double) this.worldPosition.getX() + 0.5D, + (double) this.worldPosition.getY() + 0.5D, + (double) this.worldPosition.getZ() + 0.5D) + <= 64.0D; + } } @Override public void clearContent() { - items.clear(); + this.items.clear(); } - @Override - public void setRecipeUsed(@Nullable Recipe pRecipe) { - if (pRecipe != null) { - ResourceLocation resourcelocation = pRecipe.getId(); - this.recipesUsed.addTo(resourcelocation, 1); + public static void serverTick( + @NotNull Level level, + @NotNull BlockPos pos, + @NotNull BlockState state, + @NotNull IngotFusionTollEnhancerBlockEntity blockEntity) { + ItemStack itemstack = blockEntity.items.get(FUEL_SLOT); + if (blockEntity.fuel <= 0 && getFuels().containsKey(itemstack.getItem())) { + blockEntity.fuel = getFuels().get(itemstack.getItem()); + blockEntity.items.set( + FUEL_SLOT, new ItemStack(itemstack.getItem(), itemstack.getCount() - 1)); } - } - - @Nullable - @Override - public Recipe getRecipeUsed() { - return null; - } - - @Override - public void awardUsedRecipes(Player pPlayer, List pItems) {} - - public void awardUsedRecipesAndPopExperience(ServerPlayer pPlayer) { - List> list = - this.getRecipesToAwardAndPopExperience(pPlayer.serverLevel(), pPlayer.position()); - pPlayer.awardRecipes(list); - for (Recipe recipe : list) { - if (recipe != null) { - pPlayer.triggerRecipeCrafted(recipe, this.items); + boolean flag = blockEntity.isCreatable(level); + boolean flag1 = blockEntity.creatingTime > 0; + ItemStack ingredient1 = blockEntity.items.get(0); + ItemStack ingredient2 = blockEntity.items.get(1); + ItemStack ingredient3 = blockEntity.items.get(2); + if (flag1) { + --blockEntity.creatingTime; + boolean flag2 = blockEntity.creatingTime == 0; + if (flag2 && flag) { + blockEntity.createItem(level); + blockEntity.setChanged(); + } else if (!flag) { + blockEntity.creatingTime = 0; + blockEntity.setChanged(); + } else if (blockEntity.ingredient1 != ingredient1 + || blockEntity.ingredient2 != ingredient2 + || blockEntity.ingredient3 != ingredient3) { + blockEntity.creatingTime = 0; + blockEntity.setChanged(); } + } else if (flag && blockEntity.fuel > 0) { + --blockEntity.fuel; + + // TODO: Add ability to alter creating time. + blockEntity.creatingTime = 200; + blockEntity.ingredient1 = ingredient1; + blockEntity.ingredient2 = ingredient2; + blockEntity.ingredient3 = ingredient3; + blockEntity.setChanged(); } - - this.recipesUsed.clear(); - } - - public List> getRecipesToAwardAndPopExperience(ServerLevel pLevel, Vec3 pPopVec) { - List> list = Lists.newArrayList(); - - for (Object2IntMap.Entry entry : this.recipesUsed.object2IntEntrySet()) { - pLevel - .getRecipeManager() - .byKey(entry.getKey()) - .ifPresent( - (p_155023_) -> { - list.add(p_155023_); - createExperience( - pLevel, - pPopVec, - entry.getIntValue(), - ((AbstractCookingRecipe) p_155023_).getExperience()); - }); - } - - return list; } - private static void createExperience( - ServerLevel pLevel, Vec3 pPopVec, int pRecipeIndex, float pExperience) { - int i = Mth.floor((float) pRecipeIndex * pExperience); - float f = Mth.frac((float) pRecipeIndex * pExperience); - if (f != 0.0F && Math.random() < (double) f) { - ++i; - } - - ExperienceOrb.award(pLevel, pPopVec, i); - } + private boolean isCreatable(Level level) { + ItemStack ingredient1 = this.items.get(0); + ItemStack ingredient2 = this.items.get(1); + ItemStack ingredient3 = this.items.get(2); - @Override - public void fillStackedContents(StackedContents pContents) { - for (ItemStack itemstack : this.items) { - pContents.accountStack(itemstack); + if (ingredient1.isEmpty() || ingredient2.isEmpty() || ingredient3.isEmpty()) { + return false; + } else if (!isValidInput(level, ingredient1, ingredient2, ingredient3)) { + return false; + } else { + for (int i = 0; i < 3; ++i) { + if (!this.items.get(i).isEmpty()) { + if (!this.items.get(i + 2).isEmpty()) { + continue; + } + // TODO: check if this is correct + ArmourAndToolsMod.ArmorAndToolsMod.getLogger() + .info("Item: " + this.items.size() + " " + i); + ItemStack ingredient = this.items.get(i); + if (!ingredient.isEmpty() + && hasRecipe(ingredient, ingredient1, ingredient2, ingredient3)) { + return true; + } + } + } + return false; } } - net.minecraftforge.common.util.LazyOptional[] - handlers = - net.minecraftforge.items.wrapper.SidedInvWrapper.create( - this, Direction.UP, Direction.DOWN, Direction.NORTH); + private void createItem(Level level) { + var ingredient1 = this.items.get(0); + var ingredient2 = this.items.get(1); + var ingredient3 = this.items.get(2); - @Override - public net.minecraftforge.common.util.@NotNull LazyOptional getCapability( - net.minecraftforge.common.capabilities.Capability capability, - @javax.annotation.Nullable Direction facing) { - if (!this.remove - && facing != null - && capability == net.minecraftforge.common.capabilities.ForgeCapabilities.ITEM_HANDLER) { - if (facing == Direction.UP) return handlers[0].cast(); - else if (facing == Direction.DOWN) return handlers[1].cast(); - else return handlers[2].cast(); + for (int i = 0; i < 3; ++i) { + if (!this.items.get(i).isEmpty()) { + ItemStack stack = + getOutput(level, this.items.get(i), ingredient1, ingredient2, ingredient3); + this.items.set(i, ItemStack.EMPTY); + this.items.set(i + 2, stack); + } } - return super.getCapability(capability, facing); - } - - @Override - public void invalidateCaps() { - super.invalidateCaps(); - for (net.minecraftforge.common.util.LazyOptional< - ? extends net.minecraftforge.items.IItemHandler> - handler : handlers) handler.invalidate(); - } - @Override - public void reviveCaps() { - super.reviveCaps(); - this.handlers = - net.minecraftforge.items.wrapper.SidedInvWrapper.create( - this, Direction.UP, Direction.DOWN, Direction.NORTH); - } - - public static void serverTick( - Level level, BlockPos pPos, BlockState pState, IngotFusionTollEnhancerBlockEntity pEntity) { - if (hasRecipe(pEntity)) { - // craftItem(pEntity); - - pEntity.creatingTime++; - setChanged(level, pPos, pState); - - if (pEntity.creatingTime >= pEntity.creatingTotalTime) { - craftItem(pEntity); + val blockPos = this.getBlockPos(); + if (ingredient1.hasCraftingRemainingItem()) { + val ingredient1Remaining = ingredient1.getCraftingRemainingItem(); + ingredient1.shrink(1); + if (ingredient1.isEmpty()) { + ingredient1 = ingredient1Remaining; + } else if (!this.level.isClientSide) { + Containers.dropItemStack( + this.level, + (double) blockPos.getX(), + (double) blockPos.getY(), + (double) blockPos.getZ(), + ingredient1Remaining); } } else { - ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("No Recipe"); - pEntity.resetProgress(); - setChanged(level, pPos, pState); + ingredient1.shrink(1); } - } - - private static void craftItem(IngotFusionTollEnhancerBlockEntity pEntity) { - Level level = pEntity.level; - SimpleContainer inventory = new SimpleContainer(pEntity.itemHandler.getSlots()); - for (int i = 0; i < pEntity.itemHandler.getSlots(); i++) { - inventory.setItem(i, pEntity.itemHandler.getStackInSlot(i)); - } - - Optional recipe = - level - .getRecipeManager() - .getRecipeFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), inventory, level); - if (hasRecipe(pEntity)) { - pEntity.itemHandler.extractItem(0, 1, false); - pEntity.itemHandler.extractItem(1, 1, false); - pEntity.itemHandler.extractItem(2, 1, false); - - pEntity.itemHandler.setStackInSlot( - 4, - new ItemStack( - recipe.get().getResult().getItem(), - pEntity.itemHandler.getStackInSlot(4).getCount() + 1)); - - pEntity.resetProgress(); + if (ingredient2.hasCraftingRemainingItem()) { + val ingredient2Remaining = ingredient2.getCraftingRemainingItem(); + ingredient2.shrink(1); + if (ingredient2.isEmpty()) { + ingredient2 = ingredient2Remaining; + } else if (!this.level.isClientSide) { + Containers.dropItemStack( + this.level, + (double) blockPos.getX(), + (double) blockPos.getY(), + (double) blockPos.getZ(), + ingredient2Remaining); + } + } else { + ingredient2.shrink(1); } - } - private void resetProgress() { - this.creatingTime = 0; - } - - private static boolean hasRecipe(IngotFusionTollEnhancerBlockEntity entity) { - Level level = entity.level; - // TODO: Issue here where it returns air instead of the item - - SimpleContainer inventory = new SimpleContainer(entity.itemHandler.getSlots()); - for (int i = 0; i < entity.itemHandler.getSlots(); i++) { - inventory.setItem(i, entity.itemHandler.getStackInSlot(i)); + if (ingredient3.hasCraftingRemainingItem()) { + val ingredient3Remaining = ingredient3.getCraftingRemainingItem(); + ingredient3.shrink(1); + if (ingredient3.isEmpty()) { + ingredient3 = ingredient3Remaining; + } else if (!this.level.isClientSide) { + Containers.dropItemStack( + this.level, + (double) blockPos.getX(), + (double) blockPos.getY(), + (double) blockPos.getZ(), + ingredient3Remaining); + } + } else { + ingredient3.shrink(1); } - level - .getRecipeManager() - .getRecipeFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), inventory, level) - .ifPresentOrElse( - (recipe) -> { - ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("Recipe: " + recipe); - ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("Recipe: " + recipe.getResult()); - }, - () -> { - ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("No Recipe"); - }); - - Optional recipe = - level - .getRecipeManager() - .getRecipeFor(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), inventory, level); - - return recipe.isPresent() - && canInsertAmountIntoOutputSlot(inventory) - && canInsertItemIntoOutputSlot(inventory, recipe.get().getResult()); - } + this.items.set(0, ingredient1); + this.items.set(1, ingredient2); + this.items.set(2, ingredient3); - private static boolean canInsertItemIntoOutputSlot(SimpleContainer inventory, ItemStack stack) { - ArmourAndToolsMod.ArmorAndToolsMod.getLogger() - .info("canInsertItemIntoOutputSlot: " + inventory.getItem(4).getItem() + " " + stack); - return inventory.getItem(4).isEmpty() || inventory.getItem(4).getItem() == stack.getItem(); + // level.levelEvent(1035, blockpos, 0); + level.levelEvent( + 1500, blockPos, this.items.get(4).isEmpty() ? 0 : this.items.get(4).getCount()); } - private static boolean canInsertAmountIntoOutputSlot(SimpleContainer inventory) { - ArmourAndToolsMod.ArmorAndToolsMod.getLogger() - .info( - "canInsertAmountIntoOutputSlot: " - + inventory.getItem(4).getCount() - + " " - + inventory.getItem(4).getMaxStackSize()); - return inventory.getItem(4).getCount() + 1 <= inventory.getItem(4).getMaxStackSize(); + private boolean isValidInput( + Level level, ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { + return level.getRecipeManager().getAllRecipesFor(type).stream() + .anyMatch(recipe -> recipe.isInputValid(ingredient1, ingredient2, ingredient3)); } - private static Integer getTotalCraftTime(ItemStack itemStack) { - if (itemStack.isEmpty()) { - return 0; - } else { - return ForgeHooks.getBurnTime(itemStack, RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()); - } + private boolean hasRecipe( + ItemStack ingredient, ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { + return level.getRecipeManager().getAllRecipesFor(type).stream() + .anyMatch( + recipe -> + recipe.isInputValid(ingredient1, ingredient2, ingredient3) + && recipe.isIngredient(ingredient)); } - private static int getTotalCraftTime( - Level pLevel, IngotFusionTollEnhancerBlockEntity pBlockEntity) { - return pBlockEntity - .getQuickCheck() - .getRecipeFor(pBlockEntity, pLevel) - .map(IngotFusionTollEnhancerRecipe::getCraftTime) - .orElse(200); + private ItemStack getOutput( + Level level, + ItemStack input, + ItemStack ingredient1, + ItemStack ingredient2, + ItemStack ingredient3) { + return level.getRecipeManager().getAllRecipesFor(type).stream() + .map(recipe -> recipe.getResult(input, ingredient1, ingredient2, ingredient3)) + .filter(itemStack -> !itemStack.isEmpty()) + .findFirst() + .orElse(ItemStack.EMPTY); } public static Map getFuels() { @@ -485,12 +404,6 @@ public static Map getFuels() { return map; } - public static Set getFuelAsItemStacks() { - return getFuels().keySet().stream() - .map(ItemStack::new) - .collect(java.util.stream.Collectors.toSet()); - } - public static void addFuel(Map pMap, Item fuel, int pBurnTime) { if (!isNeverAIngotFusionTollEnhanceFuel(fuel)) { pMap.put(fuel, pBurnTime); @@ -508,4 +421,51 @@ public static void addFuel(Map pMap, Item fuel, int pBurnTime) { public static boolean isNeverAIngotFusionTollEnhanceFuel(Item pItem) { return pItem.builtInRegistryHolder().is(ItemTags.NON_FLAMMABLE_WOOD); } + + public static Set getFuelAsItemStacks() { + return getFuels().keySet().stream() + .map(ItemStack::new) + .collect(java.util.stream.Collectors.toSet()); + } + + @Override + public int[] getSlotsForFace(Direction pSide) { + return switch (pSide) { + case DOWN -> new int[] {RESULT_SLOT}; + case UP -> new int[] {FUEL_SLOT}; + default -> new int[] {0, 1, 2, 3, 4}; + }; + } + + @Override + public boolean canPlaceItemThroughFace( + int pIndex, ItemStack pItemStack, @Nullable Direction pDirection) { + return this.canPlaceItem(pIndex, pItemStack); + } + + @Override + public boolean canTakeItemThroughFace(int pIndex, ItemStack pStack, Direction pDirection) { + return pIndex != FUEL_SLOT || pStack.getItem() == Items.BUCKET; + } + + @Override + public void setRecipeUsed(@Nullable Recipe pRecipe) { + if (pRecipe != null) { + ResourceLocation resourcelocation = pRecipe.getId(); + this.recipesUsed.addTo(resourcelocation, 1); + } + } + + @Nullable + @Override + public Recipe getRecipeUsed() { + return null; + } + + @Override + public void fillStackedContents(StackedContents pContents) { + for (ItemStack itemstack : this.items) { + pContents.accountStack(itemstack); + } + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java new file mode 100644 index 00000000..1a7fd3b7 --- /dev/null +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java @@ -0,0 +1,222 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; + +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots.InfusionFuelSlot; +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots.OutputSlotItemHandler; +import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit; +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeBookTypesInit; +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit; +import io.github.realyusufismail.armourandtoolsmod.recipe.infusion.IngotFusionTollEnhancerRecipe; +import lombok.val; +import net.minecraft.network.FriendlyByteBuf; +import net.minecraft.world.Container; +import net.minecraft.world.entity.player.Inventory; +import net.minecraft.world.entity.player.Player; +import net.minecraft.world.entity.player.StackedContents; +import net.minecraft.world.inventory.*; +import net.minecraft.world.item.ItemStack; +import net.minecraft.world.item.crafting.Recipe; +import net.minecraft.world.item.crafting.RecipeType; +import net.minecraft.world.level.Level; +import net.minecraft.world.level.block.entity.BaseContainerBlockEntity; +import net.minecraftforge.common.capabilities.ForgeCapabilities; +import net.minecraftforge.items.SlotItemHandler; +import org.jetbrains.annotations.NotNull; + +/** + * @see net.minecraft.stats.RecipeBookSettings + * @see FurnaceMenu + */ +public class IngotFusionTollEnhancerMenu extends RecipeBookMenu { + private final RecipeType recipeType; + private final RecipeBookType recipeBook; + private final Level level; + private static final int NUMBER_OF_SLOTS = 5; + private final ContainerData data; + private final BaseContainerBlockEntity blockEntity; + + public IngotFusionTollEnhancerMenu( + int pContainerId, + BaseContainerBlockEntity blockEntity, + ContainerData data, + @NotNull Inventory pInventory) { + super(MenuTypeInit.INGOT_FUSION_TOLL_ENHANCER_MENU.get(), pContainerId); + this.recipeType = RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(); + this.recipeBook = RecipeBookTypesInit.INGOT_FUSION; + this.level = pInventory.player.level(); + this.data = data; + this.blockEntity = blockEntity; + + checkContainerSize(blockEntity, NUMBER_OF_SLOTS); + checkContainerDataCount(data, IngotFusionTollEnhancerBlockEntity.NUMBER_OF_DATA); + + addPlayerInventory(pInventory); + addPlayerHotbar(pInventory); + + blockEntity + .getCapability(ForgeCapabilities.ITEM_HANDLER) + .ifPresent( + it -> { + // slots to place ingredients + addSlot(new SlotItemHandler(it, 0, 16, 40)); + addSlot(new SlotItemHandler(it, 1, 43, 40)); + addSlot(new SlotItemHandler(it, 2, 70, 40)); + + // slot to place fuel + addSlot(new InfusionFuelSlot(it, this)); + + // slot to place result + addSlot(new OutputSlotItemHandler(it, pInventory.player)); + }); + } + + public IngotFusionTollEnhancerMenu(int pContainerId, Inventory inventory, FriendlyByteBuf data) { + this( + pContainerId, + getBlockEntity(inventory, data), + new SimpleContainerData(IngotFusionTollEnhancerBlockEntity.NUMBER_OF_DATA), + inventory); + } + + private void addPlayerInventory(Inventory playerInventory) { + for (int row = 0; row < 3; row++) { + for (int col = 0; col < 9; col++) { + addSlot( + new Slot( + playerInventory, col + row * 9 + 9, 8 + col * 18, 166 - (4 - row) * 18 - 10 + 13)); + } + } + } + + private void addPlayerHotbar(Inventory playerInventory) { + for (int col = 0; col < 9; col++) { + addSlot(new Slot(playerInventory, col, 8 + col * 18, 142 + 13)); + } + } + + public static BaseContainerBlockEntity getBlockEntity(Inventory inventory, FriendlyByteBuf data) { + BaseContainerBlockEntity blockEntity = + (BaseContainerBlockEntity) inventory.player.level().getBlockEntity(data.readBlockPos()); + if (blockEntity != null) { + return blockEntity; + } else { + throw new IllegalStateException("Block entity is not correct"); + } + } + + @Override + public boolean stillValid(Player pPlayer) { + return this.blockEntity.stillValid(pPlayer); + } + + public int getCreatingTime() { + return this.data.get(0); + } + + public int getMaxCreatingTime() { + return this.data.get(1); + } + + public int getCreatingProgress() { + val creatingTime = getCreatingTime(); + val maxCreatingTime = getMaxCreatingTime(); + return maxCreatingTime != 0 && creatingTime != 0 ? creatingTime * 24 / maxCreatingTime : 0; + } + + @Override + public @NotNull ItemStack quickMoveStack(Player pPlayer, int slotId) { + ItemStack itemstack = ItemStack.EMPTY; + Slot slot = this.slots.get(slotId); + if (slot != null && slot.hasItem()) { + ItemStack itemstack1 = slot.getItem(); + itemstack = itemstack1.copy(); + if (slotId < NUMBER_OF_SLOTS + && !moveItemStackTo(itemstack1, NUMBER_OF_SLOTS, this.slots.size(), true)) { + return ItemStack.EMPTY; + } + + if (!moveItemStackTo(itemstack1, 0, NUMBER_OF_SLOTS, false)) { + return ItemStack.EMPTY; + } else if (slotId < NUMBER_OF_SLOTS) { + // TODO: check if this is correct + slot.onQuickCraft(itemstack1, itemstack); + } + + if (itemstack1.isEmpty()) { + slot.set(ItemStack.EMPTY); + } else { + slot.setChanged(); + } + } + + return itemstack; + } + + @Override + public void fillCraftSlotsStackedContents(StackedContents pItemHelper) { + if (this.blockEntity instanceof StackedContentsCompatible) { + ((StackedContentsCompatible) this.blockEntity).fillStackedContents(pItemHelper); + } + } + + @Override + public void clearCraftingContent() { + this.slots.get(NUMBER_OF_SLOTS).set(ItemStack.EMPTY); + } + + @Override + public boolean recipeMatches(Recipe pRecipe) { + return pRecipe.matches(this.blockEntity, this.level); + } + + @Override + public int getResultSlotIndex() { + return 4; + } + + @Override + public int getGridWidth() { + return 1; + } + + @Override + public int getGridHeight() { + return 1; + } + + @Override + public int getSize() { + return NUMBER_OF_SLOTS; + } + + public boolean isFuel(ItemStack pStack) { + return IngotFusionTollEnhancerBlockEntity.getFuels().containsKey(pStack.getItem()); + } + + @Override + public @NotNull RecipeBookType getRecipeBookType() { + return RecipeBookTypesInit.INGOT_FUSION; + } + + @Override + public boolean shouldMoveToInventory(int pSlotIndex) { + return pSlotIndex != this.getResultSlotIndex(); + } +} diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java index 64a5a900..6b174b70 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerScreen.java @@ -102,7 +102,7 @@ protected void renderBg( int i = this.leftPos; int j = this.topPos; pGuiGraphics.blit(SCREEN_ID, i, j, 0, 0, 176, 179); - pGuiGraphics.blit(SCREEN_ID, i + 97, j + 38, 179, 25, menu.getScaledProgress() + 1, 17); + pGuiGraphics.blit(SCREEN_ID, i + 97, j + 38, 179, 25, menu.getCreatingProgress() + 1, 17); } catch (NullPointerException e) { throw new NullPointerException("Minecraft Instance is null"); } @@ -127,7 +127,6 @@ public void render( this.renderTooltip(pGuiGraphics, pMouseX, pMouseY); this.recipeBookComponent.renderTooltip( pGuiGraphics, this.leftPos, this.topPos, pMouseX, pMouseY); - // super.render(pGuiGraphics, pMouseX, pMouseY, pPartialTick); } catch (NullPointerException e) { throw new NullPointerException("Render method called before Minecraft Instance is set"); } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java new file mode 100644 index 00000000..9fd617d1 --- /dev/null +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java @@ -0,0 +1,198 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.recipe.infusion; + +import com.google.gson.JsonObject; +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookCategory; +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit; +import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit; +import java.util.Arrays; +import lombok.Getter; +import lombok.val; +import net.minecraft.core.RegistryAccess; +import net.minecraft.network.FriendlyByteBuf; +import net.minecraft.resources.ResourceLocation; +import net.minecraft.util.GsonHelper; +import net.minecraft.world.Container; +import net.minecraft.world.item.ItemStack; +import net.minecraft.world.item.crafting.*; +import net.minecraft.world.level.Level; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; + +public class IngotFusionTollEnhancerRecipe implements Recipe { + + protected final RecipeType type; + protected final ResourceLocation id; + @Getter protected final Ingredient ingredient1; + @Getter protected final Ingredient ingredient2; + @Getter protected final Ingredient ingredient3; + protected final Ingredient input; + @Getter @NotNull public final ItemStack result; + @Getter @NotNull public final IngotFusionTollEnhancerRecipeBookCategory category; + + public IngotFusionTollEnhancerRecipe( + RecipeType type, + ResourceLocation id, + Ingredient ingredient1, + Ingredient ingredient2, + Ingredient ingredient3, + Ingredient input, + ItemStack result, + IngotFusionTollEnhancerRecipeBookCategory category) { + this.type = type; + this.id = id; + this.ingredient1 = ingredient1; + this.ingredient2 = ingredient2; + this.ingredient3 = ingredient3; + this.input = input; + this.result = result; + this.category = category; + } + + @Override + public boolean matches(Container pContainer, Level pLevel) { + return this.ingredient1.test(pContainer.getItem(0)) + && this.ingredient2.test(pContainer.getItem(1)) + && this.ingredient3.test(pContainer.getItem(2)) + && this.input.test(pContainer.getItem(3)); + } + + @Override + public @NotNull ItemStack assemble(Container pContainer, RegistryAccess pRegistryAccess) { + return this.result.copy(); + } + + @Override + public boolean canCraftInDimensions(int pWidth, int pHeight) { + return true; + } + + @Override + public ItemStack getResultItem(RegistryAccess pRegistryAccess) { + return this.result; + } + + @Override + public ResourceLocation getId() { + return this.id; + } + + @Override + public RecipeSerializer getSerializer() { + return RecipeSerializerInit.INGOT_FUSION_TOLL_ENHANCER_RECIPE.get(); + } + + @Override + public RecipeType getType() { + return this.type; + } + + public boolean isInputValid(ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { + return Arrays.stream(this.input.getItems()) + .anyMatch( + itemStack -> { + if (!ItemStack.isSameItem(ingredient1, itemStack)) { + return false; + } else if (!ItemStack.isSameItem(ingredient2, itemStack)) { + return false; + } else return ItemStack.isSameItem(ingredient3, itemStack); + }); + } + + public boolean isIngredient(ItemStack ingredient) { + return Arrays.stream(this.ingredient1.getItems()) + .anyMatch( + itemStack -> { + return ItemStack.isSameItem(ingredient, itemStack); + }) + || Arrays.stream(this.ingredient2.getItems()) + .anyMatch( + itemStack -> { + return ItemStack.isSameItem(ingredient, itemStack); + }) + || Arrays.stream(this.ingredient3.getItems()) + .anyMatch( + itemStack -> { + return ItemStack.isSameItem(ingredient, itemStack); + }); + } + + public ItemStack getResult( + ItemStack input, ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { + return isInputValid(ingredient1, ingredient2, ingredient3) && isIngredient(input) + ? this.result + : ItemStack.EMPTY; + } + + public static class Serializer implements RecipeSerializer { + + @Override + public IngotFusionTollEnhancerRecipe fromJson(ResourceLocation pRecipeId, JsonObject json) { + val category = + IngotFusionTollEnhancerRecipeBookCategory.CODEC.byName( + GsonHelper.getAsString(json, "category", null), + IngotFusionTollEnhancerRecipeBookCategory.MISC); + val ingredient1 = Ingredient.fromJson(GsonHelper.getAsJsonObject(json, "ingredient1")); + val ingredient2 = Ingredient.fromJson(GsonHelper.getAsJsonObject(json, "ingredient2")); + val ingredient3 = Ingredient.fromJson(GsonHelper.getAsJsonObject(json, "ingredient3")); + val input = Ingredient.fromJson(GsonHelper.getAsJsonObject(json, "input")); + val result = ShapedRecipe.itemStackFromJson(GsonHelper.getAsJsonObject(json, "result")); + return new IngotFusionTollEnhancerRecipe( + RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), + pRecipeId, + ingredient1, + ingredient2, + ingredient3, + input, + result, + category); + } + + @Override + public @Nullable IngotFusionTollEnhancerRecipe fromNetwork( + ResourceLocation pRecipeId, FriendlyByteBuf pBuffer) { + val category = pBuffer.readEnum(IngotFusionTollEnhancerRecipeBookCategory.class); + val ingredient1 = Ingredient.fromNetwork(pBuffer); + val ingredient2 = Ingredient.fromNetwork(pBuffer); + val ingredient3 = Ingredient.fromNetwork(pBuffer); + val input = Ingredient.fromNetwork(pBuffer); + val result = pBuffer.readItem(); + return new IngotFusionTollEnhancerRecipe( + RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), + pRecipeId, + ingredient1, + ingredient2, + ingredient3, + input, + result, + category); + } + + @Override + public void toNetwork(FriendlyByteBuf pBuffer, IngotFusionTollEnhancerRecipe pRecipe) { + pBuffer.writeEnum(pRecipe.category); + pRecipe.ingredient1.toNetwork(pBuffer); + pRecipe.ingredient2.toNetwork(pBuffer); + pRecipe.ingredient3.toNetwork(pBuffer); + pRecipe.input.toNetwork(pBuffer); + pBuffer.writeItem(pRecipe.result); + } + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt deleted file mode 100644 index ae1b3e5c..00000000 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.kt +++ /dev/null @@ -1,218 +0,0 @@ -/* - * Copyright 2023 RealYusufIsmail. - * - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * - * you may not use this file except in compliance with the License. - * - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package io.github.realyusufismail.armourandtoolsmod.blocks.infusion - -import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity.NUMBER_OF_SLOTS -import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots.InfusionFuelSlot -import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots.OutputSlotItemHandler -import io.github.realyusufismail.armourandtoolsmod.core.init.MenuTypeInit -import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeBookTypesInit -import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit -import net.minecraft.network.FriendlyByteBuf -import net.minecraft.world.Container -import net.minecraft.world.entity.player.Inventory -import net.minecraft.world.entity.player.Player -import net.minecraft.world.entity.player.StackedContents -import net.minecraft.world.inventory.* -import net.minecraft.world.item.ItemStack -import net.minecraft.world.item.crafting.Recipe -import net.minecraft.world.level.Level -import net.minecraft.world.level.block.entity.BaseContainerBlockEntity -import net.minecraftforge.common.capabilities.ForgeCapabilities -import net.minecraftforge.items.SlotItemHandler - -/** - * @see net.minecraft.stats.RecipeBookSettings - * @see FurnaceMenu - */ -class IngotFusionTollEnhancerMenu( - pContainerId: Int, - private val blockEntity: BaseContainerBlockEntity, - private val data: ContainerData, - pInventory: Inventory -) : RecipeBookMenu(MenuTypeInit.INGOT_FUSION_TOLL_ENHANCER_MENU.get(), pContainerId) { - private val recipeType = - RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.registryObject.orElseThrow { - IllegalStateException("Recipe type is null") - } - private val recipeBook = RecipeBookTypesInit.INGOT_FUSION - private val level: Level - - constructor( - pContainerId: Int, - inventory: Inventory, - data: FriendlyByteBuf - ) : this(pContainerId, getBlockEntity(inventory, data), SimpleContainerData(2), inventory) - - init { - level = pInventory.player.level() ?: throw IllegalStateException("Level is null") - - checkContainerSize(blockEntity, NUMBER_OF_SLOTS) - checkContainerDataCount(data, 2) - - addPlayerInventory(pInventory) - addPlayerHotbar(pInventory) - - blockEntity.getCapability(ForgeCapabilities.ITEM_HANDLER).ifPresent { it -> - // slots to place ingredients - addSlot(SlotItemHandler(it, 0, 16, 40)) - addSlot(SlotItemHandler(it, 1, 43, 40)) - addSlot(SlotItemHandler(it, 2, 70, 40)) - - // slot to place fuel - addSlot(InfusionFuelSlot(it, this)) - - // slot to place result - addSlot(OutputSlotItemHandler(it, pInventory.player)) - } - } - - /** - * Handle when the stack in slot `index` is shift-clicked. Normally this moves the stack between - * the player inventory and the other inventory(s). - */ - override fun quickMoveStack(pPlayer: Player, index: Int): ItemStack { - var itemstack = ItemStack.EMPTY - val slot = slots[index] - if (slot.hasItem()) { - val stack1 = slot.item - itemstack = stack1.copy() - if (index < NUMBER_OF_SLOTS && - !moveItemStackTo(stack1, NUMBER_OF_SLOTS, slots.size, true)) { - return ItemStack.EMPTY - } - if (!moveItemStackTo(stack1, 0, NUMBER_OF_SLOTS, false)) { - return ItemStack.EMPTY - } - if (stack1.isEmpty) { - slot.set(ItemStack.EMPTY) - } else { - slot.setChanged() - } - } - return itemstack - } - - /** Determines whether supplied player can use this container */ - override fun stillValid(pPlayer: Player): Boolean { - return blockEntity.stillValid(pPlayer) - } - - override fun fillCraftSlotsStackedContents(pItemHelper: StackedContents) { - if (this.blockEntity is StackedContentsCompatible) { - (this.blockEntity as StackedContentsCompatible).fillStackedContents(pItemHelper) - } - } - - override fun clearCraftingContent() { - - // Ingredient slots - this.getSlot(0).set(ItemStack.EMPTY) - this.getSlot(1).set(ItemStack.EMPTY) - this.getSlot(2).set(ItemStack.EMPTY) - - // Fuel slot - this.getSlot(3).set(ItemStack.EMPTY) - - // Output slot - this.getSlot(4).set(ItemStack.EMPTY) - } - - override fun getResultSlotIndex(): Int { - return 4 - } - - override fun getGridWidth(): Int { - return 1 - } - - override fun getGridHeight(): Int { - return 1 - } - - override fun getSize(): Int { - return NUMBER_OF_SLOTS - } - - override fun getRecipeBookType(): RecipeBookType { - return recipeBook - } - - override fun shouldMoveToInventory(pSlotIndex: Int): Boolean { - return pSlotIndex != this.resultSlotIndex - } - - override fun recipeMatches(pRecipe: Recipe): Boolean { - return pRecipe.matches(this.blockEntity, this.level) - } - - fun getScaledProgress(): Int { - val progress = data[0] - val maxProgress = data[1] // Max Progress - val progressArrowSize = 26 // This is the height in pixels of your arrow - return if (maxProgress != 0 && progress != 0) progress * progressArrowSize / maxProgress - else 0 - } - - private fun addPlayerInventory(playerInventory: Inventory) { - for (row in 0..2) { - for (col in 0..8) { - addSlot( - Slot( - playerInventory, - col + row * 9 + 9, - 8 + col * 18, - 166 - (4 - row) * 18 - 10 + 13)) - } - } - } - - private fun addPlayerHotbar(playerInventory: Inventory) { - for (col in 0..8) { - addSlot(Slot(playerInventory, col, 8 + col * 18, 142 + 13)) - } - } - - fun isFuel(pStack: ItemStack): Boolean { - return IngotFusionTollEnhancerBlockEntity.getFuels().containsKey(pStack.item) - } - - fun getLitProgress(): Int { - var i = data[1] - if (i == 0) { - i = 200 - } - return data[0] * 13 / i - } - - fun isLit(): Boolean { - return data[0] > 0 - } - - companion object { - fun getBlockEntity(inventory: Inventory, data: FriendlyByteBuf): BaseContainerBlockEntity { - val blockEntity = inventory.player.level().getBlockEntity(data.readBlockPos()) - if (blockEntity is BaseContainerBlockEntity) { - return blockEntity - } else { - throw IllegalStateException("Block entity is not correct") - } - } - } -} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt index 7dfbb944..b1470c68 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/book/IngotFusionTollEnhancerRecipeBookCategory.kt @@ -27,6 +27,7 @@ enum class IngotFusionTollEnhancerRecipeBookCategory(private var bookName: Strin MISC("misc"); companion object { + @JvmField val CODEC: StringRepresentable.EnumCodec = StringRepresentable.fromEnum { entries.toTypedArray() } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt index ce2073b6..f9bfe56d 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/InfusionFuelSlot.kt @@ -18,6 +18,7 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots +import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerMenu import net.minecraft.world.item.ItemStack import net.minecraft.world.item.Items @@ -25,7 +26,7 @@ import net.minecraftforge.items.IItemHandler import net.minecraftforge.items.SlotItemHandler class InfusionFuelSlot(itemHandler: IItemHandler, private val menu: IngotFusionTollEnhancerMenu) : - SlotItemHandler(itemHandler, 3, 102, 65) { + SlotItemHandler(itemHandler, IngotFusionTollEnhancerBlockEntity.FUEL_SLOT, 102, 65) { override fun mayPlace(stack: ItemStack): Boolean { return menu.isFuel(stack) || isBucket(stack) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt index 1c09fbbe..b57e62ff 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt @@ -20,15 +20,13 @@ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity import kotlin.math.min -import net.minecraft.server.level.ServerPlayer import net.minecraft.world.entity.player.Player import net.minecraft.world.item.ItemStack -import net.minecraftforge.event.ForgeEventFactory import net.minecraftforge.items.IItemHandler import net.minecraftforge.items.SlotItemHandler class OutputSlotItemHandler(itemHandler: IItemHandler, val player: Player) : - SlotItemHandler(itemHandler, 4, 138, 40) { + SlotItemHandler(itemHandler, IngotFusionTollEnhancerBlockEntity.RESULT_SLOT, 138, 40) { private var removeCount: Int? = null override fun mayPlace(stack: ItemStack): Boolean { @@ -46,17 +44,4 @@ class OutputSlotItemHandler(itemHandler: IItemHandler, val player: Player) : checkTakeAchievements(pStack) super.onTake(pPlayer, pStack) } - - /** @param pStack the output - ie, iron ingots, and pickaxes, not ore and wood. */ - override fun checkTakeAchievements(pStack: ItemStack) { - pStack.onCraftedBy(this.player.level(), this.player, removeCount ?: 0) - val player: Player = this.player - if (player is ServerPlayer) { - val container = container - (container as? IngotFusionTollEnhancerBlockEntity)?.awardUsedRecipesAndPopExperience( - player) - } - removeCount = 0 - ForgeEventFactory.firePlayerSmeltedEvent(player, pStack) - } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt index c2d938f8..b5b3bbc4 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt @@ -20,7 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.infusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import mezz.jei.api.recipe.RecipeType diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt index bba74de1..6a920dbb 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/MenuTypeInit.kt @@ -45,6 +45,7 @@ object MenuTypeInit { ObjectHolderDelegate> = register("custom_tool_crafting_table", ::CustomToolCraftingTableMenu) + @JvmField val INGOT_FUSION_TOLL_ENHANCER_MENU: ObjectHolderDelegate> = MENU.registerObject("ingot_fusion_toll_enhancer") { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeBookTypesInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeBookTypesInit.kt index 4b29a6be..85d26596 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeBookTypesInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeBookTypesInit.kt @@ -23,5 +23,5 @@ import net.minecraft.world.inventory.RecipeBookType object RecipeBookTypesInit { val ARMOUR_CRAFTING: RecipeBookType = RecipeBookType.create("armour_crafting") val TOOL_CRAFTING: RecipeBookType = RecipeBookType.create("tool_crafting") - val INGOT_FUSION: RecipeBookType = RecipeBookType.create("ingot_fusion") + @JvmField val INGOT_FUSION: RecipeBookType = RecipeBookType.create("ingot_fusion") } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeCategoriesInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeCategoriesInit.kt index b67ef490..5bbcad80 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeCategoriesInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeCategoriesInit.kt @@ -25,7 +25,7 @@ import io.github.realyusufismail.armourandtoolsmod.blocks.armour.book.CustomArmo import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookCategory import io.github.realyusufismail.armourandtoolsmod.blocks.tool.book.CustomToolsCraftingBookCategory import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.infusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import net.minecraft.client.RecipeBookCategories import net.minecraft.world.item.ItemStack @@ -278,7 +278,7 @@ object RecipeCategoriesInit { event.registerRecipeCategoryFinder(RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get()) { if (it is IngotFusionTollEnhancerRecipe) { - when (it.recipeCategory) { + when (it.category) { IngotFusionTollEnhancerRecipeBookCategory.TOOL -> INGOT_FUSION_TOLL_ENHANCER_TOOL.get() IngotFusionTollEnhancerRecipeBookCategory.ARMOUR -> diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt index 91ef2cd6..d4a5279b 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeSerializerInit.kt @@ -20,7 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod.ArmorAndToolsMod.MOD_ID import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableShapedRecipe -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.infusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableShapedRecipe import net.minecraft.world.item.crafting.Recipe import net.minecraft.world.item.crafting.RecipeSerializer @@ -41,9 +41,10 @@ object RecipeSerializerInit { ObjectHolderDelegate> = register("custom_tool_crafter", CustomToolCraftingTableShapedRecipe.Serializer()) + @JvmField val INGOT_FUSION_TOLL_ENHANCER_RECIPE: ObjectHolderDelegate> = - register("ingot_fusion_toll_enhancer", IngotFusionTollEnhancerRecipe.Companion.Serializer()) + register("ingot_fusion_toll_enhancer", IngotFusionTollEnhancerRecipe.Serializer()) private fun , T : Recipe<*>> register( pKey: String, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt index 3686e0a2..99e270e7 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/RecipeTypeInit.kt @@ -20,7 +20,7 @@ package io.github.realyusufismail.armourandtoolsmod.core.init import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod.ArmorAndToolsMod.MOD_ID import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.infusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import net.minecraft.resources.ResourceLocation import net.minecraft.world.item.crafting.RecipeType diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt index be28e178..e2fd9c47 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/IngotFusionTollEnhancerRecipeBuilder.kt @@ -18,7 +18,6 @@ */ package io.github.realyusufismail.armourandtoolsmod.datagen.recipe.builder -import com.google.gson.JsonArray import com.google.gson.JsonObject import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookCategory import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit @@ -32,18 +31,17 @@ import net.minecraft.advancements.critereon.RecipeUnlockedTrigger import net.minecraft.data.recipes.FinishedRecipe import net.minecraft.resources.ResourceLocation 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.RecipeSerializer import net.minecraftforge.registries.ForgeRegistries class IngotFusionTollEnhancerRecipeBuilder( private val recipeCategory: IngotFusionTollEnhancerRecipeBookCategory, - private val input1: Ingredient, - private val input2: Ingredient, - private val input3: Ingredient, - private val result: Item, - private val craftTime: Int = 200, - private val experience: Float = 0.2f + private val ingredient1: Ingredient, + private val ingredient2: Ingredient, + private val ingredient3: Ingredient, + private val result: ItemStack, ) { private val advancementBuilder = Advancement.Builder.advancement() @@ -67,12 +65,10 @@ class IngotFusionTollEnhancerRecipeBuilder( consumer.accept( Result( recipeCategory, - input1, - input2, - input3, + ingredient1, + ingredient2, + ingredient3, result, - craftTime, - experience, advancementBuilder, rl.withPrefix("recipes/" + recipeCategory.serializedName + "/"), rl)) @@ -99,33 +95,30 @@ class IngotFusionTollEnhancerRecipeBuilder( @JvmRecord private data class Result( val recipeCategory: IngotFusionTollEnhancerRecipeBookCategory, - val input1: Ingredient, - val input2: Ingredient, - val input3: Ingredient, - val result: Item, - val craftTime: Int, - val experience: Float, + val ingredient1: Ingredient, + val ingredient2: Ingredient, + val ingredient3: Ingredient, + val result: ItemStack, val advancementBuilder: Advancement.Builder, val advancementId: ResourceLocation, val id: ResourceLocation ) : FinishedRecipe { override fun serializeRecipeData(json: JsonObject) { - val jsonArray = JsonArray() - val ingredients = arrayOf(input1, input2, input3) - - for (ingredient in ingredients) { - jsonArray.add(ingredient.toJson()) - } - - json.add("ingredients", jsonArray) - - json.addProperty("crafttime", craftTime) - json.addProperty("experience", experience) json.addProperty("category", recipeCategory.serializedName) + json.add("result", serializeResult(result)) + json.add("ingredient1", ingredient1.toJson()) + json.add("ingredient2", ingredient2.toJson()) + json.add("ingredient3", ingredient3.toJson()) + } - val jsonObject = JsonObject() - jsonObject.addProperty("item", ForgeRegistries.ITEMS.getKey(result).toString()) - json.add("result", jsonObject) + private fun serializeResult(stack: ItemStack): JsonObject { + val json = JsonObject() + json.addProperty("item", ForgeRegistries.ITEMS.getKey(stack.item).toString()) + json.addProperty("count", stack.count) + if (stack.hasTag()) { + json.addProperty("nbt", stack.tag.toString()) + } + return json } override fun getId(): ResourceLocation { @@ -151,18 +144,10 @@ class IngotFusionTollEnhancerRecipeBuilder( input1: Item, input2: Item, input3: Item, - result: Item, - craftTime: Int? = null, - experience: Float? = null + result: ItemStack, ): IngotFusionTollEnhancerRecipeBuilder { return IngotFusionTollEnhancerRecipeBuilder( - recipeCategory, - ingredient(input1), - ingredient(input2), - ingredient(input3), - result, - craftTime ?: 200, - experience ?: 0.2f) + recipeCategory, ingredient(input1), ingredient(input2), ingredient(input3), result) } private fun ingredient(entry: Item): Ingredient { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt index edec0913..496cf7ee 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/IngotFusionTollEnhancerRecipeProvider.kt @@ -24,6 +24,7 @@ import io.github.realyusufismail.armourandtoolsmod.datagen.recipe.MainModRecipeP import io.github.realyusufismail.armourandtoolsmod.datagen.recipe.builder.IngotFusionTollEnhancerRecipeBuilder import java.util.function.Consumer import net.minecraft.data.recipes.FinishedRecipe +import net.minecraft.world.item.ItemStack class IngotFusionTollEnhancerRecipeProvider( private val mainModRecipeProvider: MainModRecipeProvider, @@ -36,9 +37,7 @@ class IngotFusionTollEnhancerRecipeProvider( ItemInit.IMPERIUM.get(), ItemInit.IMPERIUM_PICKAXE.get(), ItemInit.IMPERIUM.get(), - ItemInit.MAGMA_STRIKE_PICKAXE.get(), - 500, - 0.5f) + ItemStack(ItemInit.MAGMA_STRIKE_PICKAXE.get())) .unlockedBy("has_imperium_ingot", has(ItemInit.IMPERIUM.get())) .save(pWriter, modId("magma_strike_pickaxe")) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt index 48581879..5c2540a3 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/ArmourAndToolsModJEIPlugin.kt @@ -26,7 +26,7 @@ import io.github.realyusufismail.armourandtoolsmod.integration.armour.CustomArmo import io.github.realyusufismail.armourandtoolsmod.integration.fusion.IngotFusionTollEnhancerJEIRecipeCategory import io.github.realyusufismail.armourandtoolsmod.integration.tool.CustomToolCraftingTableJEIRecipeCategory import io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableRecipe -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.infusion.IngotFusionTollEnhancerRecipe import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import mezz.jei.api.IModPlugin import mezz.jei.api.JeiPlugin diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt index be83182b..3622f1a3 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt @@ -23,7 +23,7 @@ import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhance import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit import io.github.realyusufismail.armourandtoolsmod.integration.ArmourAndToolsModJEIPlugin -import io.github.realyusufismail.armourandtoolsmod.recipe.fusion.IngotFusionTollEnhancerRecipe +import io.github.realyusufismail.armourandtoolsmod.recipe.infusion.IngotFusionTollEnhancerRecipe import mezz.jei.api.constants.VanillaTypes import mezz.jei.api.gui.builder.IRecipeLayoutBuilder import mezz.jei.api.gui.drawable.IDrawable diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt deleted file mode 100644 index 88da4de0..00000000 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/recipe/fusion/IngotFusionTollEnhancerRecipe.kt +++ /dev/null @@ -1,183 +0,0 @@ -/* - * Copyright 2023 RealYusufIsmail. - * - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * - * you may not use this file except in compliance with the License. - * - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package io.github.realyusufismail.armourandtoolsmod.recipe.fusion - -import com.google.gson.JsonObject -import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.book.IngotFusionTollEnhancerRecipeBookCategory -import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeSerializerInit -import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit -import net.minecraft.core.NonNullList -import net.minecraft.core.RegistryAccess -import net.minecraft.network.FriendlyByteBuf -import net.minecraft.resources.ResourceLocation -import net.minecraft.util.GsonHelper -import net.minecraft.world.Container -import net.minecraft.world.item.ItemStack -import net.minecraft.world.item.crafting.* -import net.minecraft.world.level.Level - -/** @see */ -class IngotFusionTollEnhancerRecipe( - private val input1: Ingredient, - private val input2: Ingredient, - private val input3: Ingredient, - val result: ItemStack, - val craftTime: Int, - private val experience: Float, - val recipeCategory: IngotFusionTollEnhancerRecipeBookCategory, - private val recipeId: ResourceLocation, -) : Recipe { - - /** Used to check if a recipe matches current crafting inventory */ - override fun matches(pContainer: Container, pLevel: Level): Boolean { - return input1.test(pContainer.getItem(0)) && - input2.test(pContainer.getItem(1)) && - input3.test(pContainer.getItem(2)) - } - - override fun assemble(pContainer: Container, pRegistryAccess: RegistryAccess): ItemStack { - return result.copy() - } - - /** Used to determine if this recipe can fit in a grid of the given width/height */ - override fun canCraftInDimensions(pWidth: Int, pHeight: Int): Boolean { - return true - } - - override fun getResultItem(pRegistryAccess: RegistryAccess): ItemStack { - return result.copy() - } - - override fun getId(): ResourceLocation { - return recipeId - } - - override fun getSerializer(): RecipeSerializer<*> { - return RecipeSerializerInit.INGOT_FUSION_TOLL_ENHANCER_RECIPE.registryObject.orElseThrow { - IllegalStateException("No serializer for recipe type INGOT_FUSION_TOLL_ENHANCER_RECIPE") - } - } - - override fun getIngredients(): NonNullList { - val ingredients = NonNullList.create() - ingredients.add(input1) - ingredients.add(input2) - ingredients.add(input3) - return ingredients - } - - override fun getType(): RecipeType<*> { - return RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get() - } - - companion object { - - class Serializer : RecipeSerializer { - override fun fromJson( - pRecipeId: ResourceLocation, - json: JsonObject - ): IngotFusionTollEnhancerRecipe { - - try { - val ingredientArray = json.get("ingredients").asJsonArray - val inputs = NonNullList.withSize(3, Ingredient.EMPTY) - - for (i in 0..2) { - val ingredient = ingredientArray[i].asJsonObject - inputs[i] = Ingredient.fromJson(ingredient) - } - - val craftTime = GsonHelper.getAsInt(json, "crafttime") - val experience = GsonHelper.getAsFloat(json, "experience") - val recipeCategory = - IngotFusionTollEnhancerRecipeBookCategory.CODEC.byName( - GsonHelper.getAsString(json, "category", null as String?), - IngotFusionTollEnhancerRecipeBookCategory.MISC) - - val result = - ShapedRecipe.itemStackFromJson(GsonHelper.getAsJsonObject(json, "result")) - - return IngotFusionTollEnhancerRecipe( - inputs[0], - inputs[1], - inputs[2], - result, - craftTime, - experience, - recipeCategory, - pRecipeId) - } catch (e: IllegalStateException) { - throw IllegalStateException("Could not create recipe: $pRecipeId", e) - } - } - - override fun fromNetwork( - pRecipeId: ResourceLocation, - pBuffer: FriendlyByteBuf - ): IngotFusionTollEnhancerRecipe { - try { - - val input = NonNullList.withSize(pBuffer.readInt(), Ingredient.EMPTY) - - for (i in input.indices) { - input[i] = Ingredient.fromNetwork(pBuffer) - } - - val result = pBuffer.readItem() - val craftTime = pBuffer.readInt() - val experience = pBuffer.readFloat() - val recipeCategory = - pBuffer.readEnum(IngotFusionTollEnhancerRecipeBookCategory::class.java) - - return IngotFusionTollEnhancerRecipe( - input[0], - input[1], - input[2], - result, - craftTime, - experience, - recipeCategory, - pRecipeId) - } catch (e: IllegalStateException) { - throw IllegalStateException("Could not read recipe: $pRecipeId", e) - } - } - - override fun toNetwork( - pBuffer: FriendlyByteBuf, - pRecipe: IngotFusionTollEnhancerRecipe - ) { - try { - pBuffer.writeInt(pRecipe.getIngredients().size) - - for (ingredient in pRecipe.getIngredients()) { - ingredient.toNetwork(pBuffer) - } - - pBuffer.writeItem(pRecipe.result) - pBuffer.writeInt(pRecipe.craftTime) - pBuffer.writeFloat(pRecipe.experience) - pBuffer.writeEnum(pRecipe.recipeCategory) - } catch (e: IllegalStateException) { - throw IllegalStateException("Could not write recipe: ${pRecipe.id}", e) - } - } - } - } -} From 465ba4dc422460137ce0969a96bda2a9bad82c74 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 11 Oct 2023 22:12:49 +0100 Subject: [PATCH 34/51] removed input. Need to double check --- .../IngotFusionTollEnhancerRecipe.java | 48 +++++++++++-------- 1 file changed, 29 insertions(+), 19 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java index 9fd617d1..7b45ccfb 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java @@ -43,7 +43,6 @@ public class IngotFusionTollEnhancerRecipe implements Recipe { @Getter protected final Ingredient ingredient1; @Getter protected final Ingredient ingredient2; @Getter protected final Ingredient ingredient3; - protected final Ingredient input; @Getter @NotNull public final ItemStack result; @Getter @NotNull public final IngotFusionTollEnhancerRecipeBookCategory category; @@ -53,7 +52,6 @@ public IngotFusionTollEnhancerRecipe( Ingredient ingredient1, Ingredient ingredient2, Ingredient ingredient3, - Ingredient input, ItemStack result, IngotFusionTollEnhancerRecipeBookCategory category) { this.type = type; @@ -61,7 +59,6 @@ public IngotFusionTollEnhancerRecipe( this.ingredient1 = ingredient1; this.ingredient2 = ingredient2; this.ingredient3 = ingredient3; - this.input = input; this.result = result; this.category = category; } @@ -70,8 +67,7 @@ public IngotFusionTollEnhancerRecipe( public boolean matches(Container pContainer, Level pLevel) { return this.ingredient1.test(pContainer.getItem(0)) && this.ingredient2.test(pContainer.getItem(1)) - && this.ingredient3.test(pContainer.getItem(2)) - && this.input.test(pContainer.getItem(3)); + && this.ingredient3.test(pContainer.getItem(2)); } @Override @@ -105,15 +101,34 @@ public RecipeType getType() { } public boolean isInputValid(ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { - return Arrays.stream(this.input.getItems()) - .anyMatch( - itemStack -> { - if (!ItemStack.isSameItem(ingredient1, itemStack)) { - return false; - } else if (!ItemStack.isSameItem(ingredient2, itemStack)) { - return false; - } else return ItemStack.isSameItem(ingredient3, itemStack); - }); + //TODO: see if input is needed to be added back + return Arrays.stream(this.ingredient1.getItems()) + .anyMatch( + itemStack -> { + if (!ItemStack.isSameItem(ingredient1, itemStack)) { + return false; + } else if (!ItemStack.isSameItem(ingredient2, itemStack)) { + return false; + } else return ItemStack.isSameItem(ingredient3, itemStack); + }) + || Arrays.stream(this.ingredient2.getItems()) + .anyMatch( + itemStack -> { + if (!ItemStack.isSameItem(ingredient1, itemStack)) { + return false; + } else if (!ItemStack.isSameItem(ingredient2, itemStack)) { + return false; + } else return ItemStack.isSameItem(ingredient3, itemStack); + }) + || Arrays.stream(this.ingredient3.getItems()) + .anyMatch( + itemStack -> { + if (!ItemStack.isSameItem(ingredient1, itemStack)) { + return false; + } else if (!ItemStack.isSameItem(ingredient2, itemStack)) { + return false; + } else return ItemStack.isSameItem(ingredient3, itemStack); + }); } public boolean isIngredient(ItemStack ingredient) { @@ -152,7 +167,6 @@ public IngotFusionTollEnhancerRecipe fromJson(ResourceLocation pRecipeId, JsonOb val ingredient1 = Ingredient.fromJson(GsonHelper.getAsJsonObject(json, "ingredient1")); val ingredient2 = Ingredient.fromJson(GsonHelper.getAsJsonObject(json, "ingredient2")); val ingredient3 = Ingredient.fromJson(GsonHelper.getAsJsonObject(json, "ingredient3")); - val input = Ingredient.fromJson(GsonHelper.getAsJsonObject(json, "input")); val result = ShapedRecipe.itemStackFromJson(GsonHelper.getAsJsonObject(json, "result")); return new IngotFusionTollEnhancerRecipe( RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), @@ -160,7 +174,6 @@ public IngotFusionTollEnhancerRecipe fromJson(ResourceLocation pRecipeId, JsonOb ingredient1, ingredient2, ingredient3, - input, result, category); } @@ -172,7 +185,6 @@ public IngotFusionTollEnhancerRecipe fromJson(ResourceLocation pRecipeId, JsonOb val ingredient1 = Ingredient.fromNetwork(pBuffer); val ingredient2 = Ingredient.fromNetwork(pBuffer); val ingredient3 = Ingredient.fromNetwork(pBuffer); - val input = Ingredient.fromNetwork(pBuffer); val result = pBuffer.readItem(); return new IngotFusionTollEnhancerRecipe( RecipeTypeInit.INGOT_FUSION_TOLL_ENHANCER.get(), @@ -180,7 +192,6 @@ public IngotFusionTollEnhancerRecipe fromJson(ResourceLocation pRecipeId, JsonOb ingredient1, ingredient2, ingredient3, - input, result, category); } @@ -191,7 +202,6 @@ public void toNetwork(FriendlyByteBuf pBuffer, IngotFusionTollEnhancerRecipe pRe pRecipe.ingredient1.toNetwork(pBuffer); pRecipe.ingredient2.toNetwork(pBuffer); pRecipe.ingredient3.toNetwork(pBuffer); - pRecipe.input.toNetwork(pBuffer); pBuffer.writeItem(pRecipe.result); } } From dd38c4bcdac73e5bc083f70792f291b53eb9f89c Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Wed, 11 Oct 2023 23:08:56 +0100 Subject: [PATCH 35/51] Need to go over fuels --- .../infusion/IngotFusionTollEnhancerBlockEntity.java | 7 +++++-- .../recipe/infusion/IngotFusionTollEnhancerRecipe.java | 2 +- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index e4a943a5..2d8f07f1 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -238,7 +238,7 @@ public static void serverTick( ItemStack ingredient1 = blockEntity.items.get(0); ItemStack ingredient2 = blockEntity.items.get(1); ItemStack ingredient3 = blockEntity.items.get(2); - if (flag1) { + if (flag1) { // Says flag is false --blockEntity.creatingTime; boolean flag2 = blockEntity.creatingTime == 0; if (flag2 && flag) { @@ -253,7 +253,7 @@ public static void serverTick( blockEntity.creatingTime = 0; blockEntity.setChanged(); } - } else if (flag && blockEntity.fuel > 0) { + } else if (flag) { --blockEntity.fuel; // TODO: Add ability to alter creating time. @@ -262,6 +262,9 @@ public static void serverTick( blockEntity.ingredient2 = ingredient2; blockEntity.ingredient3 = ingredient3; blockEntity.setChanged(); + } else { + blockEntity.creatingTime = 0; + blockEntity.setChanged(); } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java index 7b45ccfb..bd22a4e4 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java @@ -101,7 +101,7 @@ public RecipeType getType() { } public boolean isInputValid(ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { - //TODO: see if input is needed to be added back + // TODO: see if input is needed to be added back return Arrays.stream(this.ingredient1.getItems()) .anyMatch( itemStack -> { From 3fcb099c94849cbfd66162af11763d8789a1d800 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 12 Oct 2023 07:45:48 +0100 Subject: [PATCH 36/51] recipe works issh --- .../IngotFusionTollEnhancerBlockEntity.java | 19 ++--------- .../IngotFusionTollEnhancerRecipe.java | 33 +------------------ 2 files changed, 4 insertions(+), 48 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index 2d8f07f1..3db5c90a 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -273,11 +273,7 @@ private boolean isCreatable(Level level) { ItemStack ingredient2 = this.items.get(1); ItemStack ingredient3 = this.items.get(2); - if (ingredient1.isEmpty() || ingredient2.isEmpty() || ingredient3.isEmpty()) { - return false; - } else if (!isValidInput(level, ingredient1, ingredient2, ingredient3)) { - return false; - } else { + if (!ingredient1.isEmpty() && !ingredient2.isEmpty() && !ingredient3.isEmpty()) { for (int i = 0; i < 3; ++i) { if (!this.items.get(i).isEmpty()) { if (!this.items.get(i + 2).isEmpty()) { @@ -293,8 +289,8 @@ && hasRecipe(ingredient, ingredient1, ingredient2, ingredient3)) { } } } - return false; } + return false; } private void createItem(Level level) { @@ -372,19 +368,10 @@ private void createItem(Level level) { 1500, blockPos, this.items.get(4).isEmpty() ? 0 : this.items.get(4).getCount()); } - private boolean isValidInput( - Level level, ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { - return level.getRecipeManager().getAllRecipesFor(type).stream() - .anyMatch(recipe -> recipe.isInputValid(ingredient1, ingredient2, ingredient3)); - } - private boolean hasRecipe( ItemStack ingredient, ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { return level.getRecipeManager().getAllRecipesFor(type).stream() - .anyMatch( - recipe -> - recipe.isInputValid(ingredient1, ingredient2, ingredient3) - && recipe.isIngredient(ingredient)); + .anyMatch(recipe -> recipe.isIngredient(ingredient)); } private ItemStack getOutput( diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java index bd22a4e4..00eeb4a4 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java @@ -100,37 +100,6 @@ public RecipeType getType() { return this.type; } - public boolean isInputValid(ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { - // TODO: see if input is needed to be added back - return Arrays.stream(this.ingredient1.getItems()) - .anyMatch( - itemStack -> { - if (!ItemStack.isSameItem(ingredient1, itemStack)) { - return false; - } else if (!ItemStack.isSameItem(ingredient2, itemStack)) { - return false; - } else return ItemStack.isSameItem(ingredient3, itemStack); - }) - || Arrays.stream(this.ingredient2.getItems()) - .anyMatch( - itemStack -> { - if (!ItemStack.isSameItem(ingredient1, itemStack)) { - return false; - } else if (!ItemStack.isSameItem(ingredient2, itemStack)) { - return false; - } else return ItemStack.isSameItem(ingredient3, itemStack); - }) - || Arrays.stream(this.ingredient3.getItems()) - .anyMatch( - itemStack -> { - if (!ItemStack.isSameItem(ingredient1, itemStack)) { - return false; - } else if (!ItemStack.isSameItem(ingredient2, itemStack)) { - return false; - } else return ItemStack.isSameItem(ingredient3, itemStack); - }); - } - public boolean isIngredient(ItemStack ingredient) { return Arrays.stream(this.ingredient1.getItems()) .anyMatch( @@ -151,7 +120,7 @@ public boolean isIngredient(ItemStack ingredient) { public ItemStack getResult( ItemStack input, ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { - return isInputValid(ingredient1, ingredient2, ingredient3) && isIngredient(input) + return isIngredient(ingredient1) && isIngredient(ingredient2) && isIngredient(ingredient3) ? this.result : ItemStack.EMPTY; } From b8aff70a32b8e023b374575d85f99a62ee7a5a5f Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 12 Oct 2023 09:49:42 +0100 Subject: [PATCH 37/51] Added table texure --- .../b437fe956183b85bad8f19eb71f021ad5d4a1455 | 6 +++- .../ingot_fusion_toll_enhancer.json | 7 +++++ .../block/ingot_fusion_toll_enhancer.json | 8 +++++ .../block/ingot_fusion_toll_enhancer_on.json | 8 +++++ .../item/ingot_fusion_toll_enhancer.json | 3 ++ .../IngotFusionTollEnhancerBlockEntity.java | 28 +++++++++++------- .../datagen/texture/ModBlockStateProvider.kt | 21 +++++++++++++ .../ingot_fusion_toll_enhancer_front.png | Bin 0 -> 526 bytes .../block/ingot_fusion_toll_enhancer_side.png | Bin 0 -> 470 bytes .../block/ingot_fusion_toll_enhancer_top.png | Bin 0 -> 296 bytes 10 files changed, 69 insertions(+), 12 deletions(-) create mode 100644 src/generated/resources/assets/armourandtoolsmod/blockstates/ingot_fusion_toll_enhancer.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer_on.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/item/ingot_fusion_toll_enhancer.json create mode 100644 src/main/resources/assets/armourandtoolsmod/textures/block/ingot_fusion_toll_enhancer_front.png create mode 100644 src/main/resources/assets/armourandtoolsmod/textures/block/ingot_fusion_toll_enhancer_side.png create mode 100644 src/main/resources/assets/armourandtoolsmod/textures/block/ingot_fusion_toll_enhancer_top.png diff --git a/src/generated/resources/.cache/b437fe956183b85bad8f19eb71f021ad5d4a1455 b/src/generated/resources/.cache/b437fe956183b85bad8f19eb71f021ad5d4a1455 index 9c2713eb..0ea0e701 100644 --- a/src/generated/resources/.cache/b437fe956183b85bad8f19eb71f021ad5d4a1455 +++ b/src/generated/resources/.cache/b437fe956183b85bad8f19eb71f021ad5d4a1455 @@ -1,4 +1,4 @@ -// 1.20.1 2023-08-28T05:16:02.6313285 Armour and Tools Mod Blockstates +// 1.20.1 2023-10-12T09:56:56.1414719 Armour and Tools Mod Blockstates 2e7a970f6d2f498e44c8111ab18365eb11feb9ec assets/armourandtoolsmod/blockstates/aqumarine_block.json 54fe09c01a2e09240df74b50d546d52a3f055d6c assets/armourandtoolsmod/blockstates/aqumarine_ore.json 14011b50d9bf8bbaeb041d4da1d2f0c5303ddef7 assets/armourandtoolsmod/blockstates/custom_armour_crafting_table.json @@ -12,6 +12,7 @@ c8512e5a03eec24140e6961b05767d6ef0fb4177 assets/armourandtoolsmod/blockstates/de dd94bac512b66e6bfc7167e1efd6d19e7603cfbd assets/armourandtoolsmod/blockstates/enderite_ore.json 5e08334bf3b4305ed8c8e5bd49e7ddb3181ef482 assets/armourandtoolsmod/blockstates/graphite_block.json 4bedced77b9f7a7387a64bf8343ddb0f38b630c0 assets/armourandtoolsmod/blockstates/graphite_ore.json +d950e01376c01d6fdc91a8d6de6eb3ae179fb075 assets/armourandtoolsmod/blockstates/ingot_fusion_toll_enhancer.json a7fc4d7c5702aac2d7d8dde4cdf85761bc17b328 assets/armourandtoolsmod/blockstates/rainbow_block.json 2ee63bda3f405985ced49a0bb440757d4604bf50 assets/armourandtoolsmod/blockstates/rainbow_ore.json 051baf056e542c7ec5a787b36466989f550c34e9 assets/armourandtoolsmod/blockstates/ruby_block.json @@ -31,6 +32,8 @@ b07323a775ec3f1763b3c962b5d88c90d99e75a9 assets/armourandtoolsmod/models/block/e 7ae33083e9abb3b737adcadb357b22a965235e11 assets/armourandtoolsmod/models/block/enderite_ore.json d7eebd8671ec4eebb5cca3e052d40e71adb5452d assets/armourandtoolsmod/models/block/graphite_block.json 963578bbc0213efb09abaeb28ef490575858a880 assets/armourandtoolsmod/models/block/graphite_ore.json +f4954b01aaf1b85248d6f52ec350a3ae63bfd9cb assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer.json +f4954b01aaf1b85248d6f52ec350a3ae63bfd9cb assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer_on.json 70b12befd6c2592923ec2034968ac0f2e25ea4c2 assets/armourandtoolsmod/models/block/rainbow_block.json ab39e04a10b45067e9bbbb9adc90663705707a2d assets/armourandtoolsmod/models/block/rainbow_ore.json c81947216ccbbcff05acd805ede5bc22e8de0310 assets/armourandtoolsmod/models/block/ruby_block.json @@ -50,6 +53,7 @@ d5f995b7d1f2e1efb8c548570e7df12eea351ca6 assets/armourandtoolsmod/models/item/de 0dcf9c375173535daa54cb002ae8322fa5f21ebb assets/armourandtoolsmod/models/item/enderite_ore.json 40d8fe283ae9334173aa5cb34c3fe2eff59c584a assets/armourandtoolsmod/models/item/graphite_block.json e968896fc4c6ac9c0abff1d23cc576138bdb9e46 assets/armourandtoolsmod/models/item/graphite_ore.json +16a5fd8223f64c59e32fc4f75dc55a986b03c4df assets/armourandtoolsmod/models/item/ingot_fusion_toll_enhancer.json 241bc326669ed4b6f05d6ccbb37070a46f5d83c8 assets/armourandtoolsmod/models/item/rainbow_block.json 33ba53e3ed9e948a872ab89715acbce1b22957dd assets/armourandtoolsmod/models/item/rainbow_ore.json ba5b646dfe3caf522b146a66b85b490535ac4df4 assets/armourandtoolsmod/models/item/ruby_block.json diff --git a/src/generated/resources/assets/armourandtoolsmod/blockstates/ingot_fusion_toll_enhancer.json b/src/generated/resources/assets/armourandtoolsmod/blockstates/ingot_fusion_toll_enhancer.json new file mode 100644 index 00000000..11a9cf85 --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/blockstates/ingot_fusion_toll_enhancer.json @@ -0,0 +1,7 @@ +{ + "variants": { + "": { + "model": "armourandtoolsmod:block/ingot_fusion_toll_enhancer" + } + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer.json b/src/generated/resources/assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer.json new file mode 100644 index 00000000..6674fd43 --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer.json @@ -0,0 +1,8 @@ +{ + "parent": "minecraft:block/orientable", + "textures": { + "front": "armourandtoolsmod:block/ingot_fusion_toll_enhancer_front", + "side": "armourandtoolsmod:block/ingot_fusion_toll_enhancer_side", + "top": "armourandtoolsmod:block/ingot_fusion_toll_enhancer_top" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer_on.json b/src/generated/resources/assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer_on.json new file mode 100644 index 00000000..6674fd43 --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer_on.json @@ -0,0 +1,8 @@ +{ + "parent": "minecraft:block/orientable", + "textures": { + "front": "armourandtoolsmod:block/ingot_fusion_toll_enhancer_front", + "side": "armourandtoolsmod:block/ingot_fusion_toll_enhancer_side", + "top": "armourandtoolsmod:block/ingot_fusion_toll_enhancer_top" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/models/item/ingot_fusion_toll_enhancer.json b/src/generated/resources/assets/armourandtoolsmod/models/item/ingot_fusion_toll_enhancer.json new file mode 100644 index 00000000..1d1f350a --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/item/ingot_fusion_toll_enhancer.json @@ -0,0 +1,3 @@ +{ + "parent": "armourandtoolsmod:block/ingot_fusion_toll_enhancer" +} \ No newline at end of file diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index 3db5c90a..f3a2382f 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -18,7 +18,6 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; -import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit; @@ -227,10 +226,12 @@ public static void serverTick( @NotNull BlockState state, @NotNull IngotFusionTollEnhancerBlockEntity blockEntity) { ItemStack itemstack = blockEntity.items.get(FUEL_SLOT); + + // Do i need blockEntity.fuel in this if statement? if (blockEntity.fuel <= 0 && getFuels().containsKey(itemstack.getItem())) { - blockEntity.fuel = getFuels().get(itemstack.getItem()); - blockEntity.items.set( - FUEL_SLOT, new ItemStack(itemstack.getItem(), itemstack.getCount() - 1)); + blockEntity.fuel = 20; + itemstack.shrink(1); + blockEntity.setChanged(); } boolean flag = blockEntity.isCreatable(level); @@ -274,14 +275,14 @@ private boolean isCreatable(Level level) { ItemStack ingredient3 = this.items.get(2); if (!ingredient1.isEmpty() && !ingredient2.isEmpty() && !ingredient3.isEmpty()) { + + // TODO: Need to check this for loop for (int i = 0; i < 3; ++i) { if (!this.items.get(i).isEmpty()) { if (!this.items.get(i + 2).isEmpty()) { continue; } - // TODO: check if this is correct - ArmourAndToolsMod.ArmorAndToolsMod.getLogger() - .info("Item: " + this.items.size() + " " + i); + ItemStack ingredient = this.items.get(i); if (!ingredient.isEmpty() && hasRecipe(ingredient, ingredient1, ingredient2, ingredient3)) { @@ -300,10 +301,15 @@ private void createItem(Level level) { for (int i = 0; i < 3; ++i) { if (!this.items.get(i).isEmpty()) { - ItemStack stack = - getOutput(level, this.items.get(i), ingredient1, ingredient2, ingredient3); - this.items.set(i, ItemStack.EMPTY); - this.items.set(i + 2, stack); + if (!this.items.get(i + 2).isEmpty()) { + continue; + } + + ItemStack ingredient = this.items.get(i); + if (!ingredient.isEmpty() && hasRecipe(ingredient, ingredient1, ingredient2, ingredient3)) { + this.items.set( + i + 2, getOutput(level, ingredient, ingredient1, ingredient2, ingredient3)); + } } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModBlockStateProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModBlockStateProvider.kt index 37456ec8..5b676bb4 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModBlockStateProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModBlockStateProvider.kt @@ -56,6 +56,8 @@ class ModBlockStateProvider(output: PackOutput, exFileHelper: ExistingFileHelper customCraftingTable(BlockInit.CUSTOM_ARMOUR_CRAFTING_TABLE.get()) customCraftingTable(BlockInit.CUSTOM_TOOL_CRAFTING_TABLE.get()) + orientableBlock(BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()) + orientableBlockOn(BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()) } private fun customCraftingTable(block: Block) { @@ -82,4 +84,23 @@ class ModBlockStateProvider(output: PackOutput, exFileHelper: ExistingFileHelper simpleBlock(block, models().cubeAll(name.path, modLoc("block/${name.path}"))) simpleBlockItem(block, models().cubeAll(name.path, modLoc("block/${name.path}"))) } + + private fun orientableBlock(block: Block) { + val name = ForgeRegistries.BLOCKS.getKey(block) ?: return + val builder = models().withExistingParent(name.path, "block/orientable") + builder.texture("top", modLoc("block/${name.path}_top")) + builder.texture("side", modLoc("block/${name.path}_side")) + builder.texture("front", modLoc("block/${name.path}_front")) + this.simpleBlock(block, builder) + this.simpleBlockItem(block, builder) + } + + private fun orientableBlockOn(block: Block) { + val nameWithOn = (ForgeRegistries.BLOCKS.getKey(block) ?: return).path + "_on" + val name = ForgeRegistries.BLOCKS.getKey(block) ?: return + val builder = models().withExistingParent(nameWithOn, "block/orientable") + builder.texture("top", modLoc("block/${name.path}_top")) + builder.texture("side", modLoc("block/${name.path}_side")) + builder.texture("front", modLoc("block/${name.path}_front")) + } } diff --git a/src/main/resources/assets/armourandtoolsmod/textures/block/ingot_fusion_toll_enhancer_front.png b/src/main/resources/assets/armourandtoolsmod/textures/block/ingot_fusion_toll_enhancer_front.png new file mode 100644 index 0000000000000000000000000000000000000000..6f32bcb451040fed6b14c80898ca580bcbe235d0 GIT binary patch literal 526 zcmV+p0`dKcP)!E4iC7{-68!TH&gwv$9wGH266TNHGM1O&l@4#qsG7Y80z z*#EHo33?UrFA(ZQJ$dmU6beE;Y==p9S;urJHn0xTEi$U{5b}|4%qc#X=l$O2eV%-I z6Rlor#AKjp5G$S2p#zwv`R|Slf*>IGU(O7)^5g~O!b0Q$h@yiN4aareDw_<30hgwx z)ydN2sZahK9blDBbi3*>7zQjpdML$}@oS#w_vwA?$zHKoR04u`d)QScS)vem+Am(R zeq*2OA4;seTBrTs2!Qg%8bTOs_136dzD5*{7=GW9LAmsOYIO%d;ac562m>(@CiO&! z5QdzQ0Yc>QT#vQ)J)&qN>+D$u>~8nvVYXFK7+`+RrPK8R=yZMN=Ul1n zZuimZwMHENIHYjyJezMfY20nljz=tNh8&!lxx%-dPm%#rk8W2Te1C)1@)EF0Yk7&; zd#kkGJXW^e=^EU+*#wdsJbm^YyXv6bzOxYf{szwU3@5>=B)|FIzQ*`)Kp2J;3I+OK zc4#)QCZF;6@Zf78dueS|OemRHn2N3hWQD&4r%;v%ko$SWuQO*Q{|Tw*H+b}-F?c=A Qn*aa+07*qoM6N<$g1y)DasU7T literal 0 HcmV?d00001 diff --git a/src/main/resources/assets/armourandtoolsmod/textures/block/ingot_fusion_toll_enhancer_side.png b/src/main/resources/assets/armourandtoolsmod/textures/block/ingot_fusion_toll_enhancer_side.png new file mode 100644 index 0000000000000000000000000000000000000000..9a157c2bd3ebaf9ecc04b906e4155721b49c6c7d GIT binary patch literal 470 zcmV;{0V)28P)Fn%cXy)@Unw(cYE4O4((Y~e;~h2mo_^2s`+dL9_xC)H5(*j; zK(Q%EDM3;b>;OKWuQt{vOw+{nCuSKGZ+%0BX;pO<&-wgwMZP>P3WS1&%s!a3G&a{% z`T8z{-|NG!1$43xCc`5`08C%3K&u~)axC;jiJ!!aB#*~a64=S01@uA_0XEh*NpwAu z%H;`7#W`Kmm}Zr5#$DCH*H`T~muXbhRV2?U-E0wKJ}j6^#7VTlptI8=U>@IdbD1tV zNagZui%A3kF+@bL7ZI?!gop}@!2ZD@Zif?_7SI9M7L!%2?nNhl>LXe}|A#&J8l&G^ z+Q#H=5@W#lmH71fg4^LN^gvZzjE#?$UC(@rtyo-IE;#7z>zC)}XXwqX6%YJP1xMLi zv#LNkb47c5M`;S*QBM3#ObG=I`Skh%K%IOC;7zgW*2#BE-tBPm0ls5>$7qkC?*IS* M07*qoM6N<$g3NN$fB*mh literal 0 HcmV?d00001 diff --git a/src/main/resources/assets/armourandtoolsmod/textures/block/ingot_fusion_toll_enhancer_top.png b/src/main/resources/assets/armourandtoolsmod/textures/block/ingot_fusion_toll_enhancer_top.png new file mode 100644 index 0000000000000000000000000000000000000000..2537301734f6e692246a86cdd496b96838d1e1ac GIT binary patch literal 296 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`EX7WqAsj$Z!;#Vf!Sf%L~a^~qXgrH6|*g)YaAsCZ_H<0;nB3Ja{1kjA8pNf|83d4FFnLtXw9|T zHww#ocIk###OCWv=l-&0v-!6FRyCHpGBan{tmf(6)hX5zxbR&41n*J?=ivQ!zsKmD z_VB9Mb48eA)|sfOWyk%h6x<@e+*iDR^6P>#A_~UGjGi3RIKdyhP(e*&nhMjYcil5C siTf=39I~&uZnHw>X``ao%$;-Y$FB{2^UkH`CeW)4p00i_>zopr01$Y2hX4Qo literal 0 HcmV?d00001 From 8d233841c1363fdd48f82039646b380f4db9bc0e Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 12 Oct 2023 10:54:46 +0100 Subject: [PATCH 38/51] reuslt get output in one place now --- .../IngotFusionTollEnhancerBlockEntity.java | 31 +++++++------------ .../infusion/IngotFusionTollEnhancerMenu.java | 4 +++ .../IngotFusionTollEnhancerRecipe.java | 3 +- 3 files changed, 16 insertions(+), 22 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index f3a2382f..d5ece3d2 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -18,6 +18,7 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; +import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockInit; @@ -96,6 +97,8 @@ public class IngotFusionTollEnhancerBlockEntity extends BaseContainerBlockEntity protected final ContainerData dataAccess = new ContainerData() { public int get(int p_58431_) { + ArmourAndToolsMod.ArmorAndToolsMod.getLogger() + .info("Getting data: " + p_58431_ + " to " + p_58431_); return switch (p_58431_) { case 0 -> IngotFusionTollEnhancerBlockEntity.this.creatingTime; case 1 -> IngotFusionTollEnhancerBlockEntity.this.creatingTotalTime; @@ -105,6 +108,8 @@ public int get(int p_58431_) { } public void set(int p_58433_, int p_58434_) { + ArmourAndToolsMod.ArmorAndToolsMod.getLogger() + .info("Setting data: " + p_58433_ + " to " + p_58434_); switch (p_58433_) { case 0 -> IngotFusionTollEnhancerBlockEntity.this.creatingTime = p_58434_; case 1 -> IngotFusionTollEnhancerBlockEntity.this.creatingTotalTime = p_58434_; @@ -161,6 +166,7 @@ protected void saveAdditional(CompoundTag pTag) { @Override protected AbstractContainerMenu createMenu(int pContainerId, Inventory pInventory) { + ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("Creating menu"); return new IngotFusionTollEnhancerMenu(pContainerId, this, this.dataAccess, pInventory); } @@ -299,19 +305,8 @@ private void createItem(Level level) { var ingredient2 = this.items.get(1); var ingredient3 = this.items.get(2); - for (int i = 0; i < 3; ++i) { - if (!this.items.get(i).isEmpty()) { - if (!this.items.get(i + 2).isEmpty()) { - continue; - } - - ItemStack ingredient = this.items.get(i); - if (!ingredient.isEmpty() && hasRecipe(ingredient, ingredient1, ingredient2, ingredient3)) { - this.items.set( - i + 2, getOutput(level, ingredient, ingredient1, ingredient2, ingredient3)); - } - } - } + var output = getOutput(level, ingredient1, ingredient2, ingredient3); + this.items.set(4, output); val blockPos = this.getBlockPos(); if (ingredient1.hasCraftingRemainingItem()) { @@ -371,7 +366,7 @@ private void createItem(Level level) { // level.levelEvent(1035, blockpos, 0); level.levelEvent( - 1500, blockPos, this.items.get(4).isEmpty() ? 0 : this.items.get(4).getCount()); + 1035, blockPos, this.items.get(4).isEmpty() ? 0 : this.items.get(4).getCount()); } private boolean hasRecipe( @@ -381,13 +376,9 @@ private boolean hasRecipe( } private ItemStack getOutput( - Level level, - ItemStack input, - ItemStack ingredient1, - ItemStack ingredient2, - ItemStack ingredient3) { + Level level, ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { return level.getRecipeManager().getAllRecipesFor(type).stream() - .map(recipe -> recipe.getResult(input, ingredient1, ingredient2, ingredient3)) + .map(recipe -> recipe.getResult(ingredient1, ingredient2, ingredient3)) .filter(itemStack -> !itemStack.isEmpty()) .findFirst() .orElse(ItemStack.EMPTY); diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java index 1a7fd3b7..2619221a 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java @@ -137,6 +137,10 @@ public int getMaxCreatingTime() { public int getCreatingProgress() { val creatingTime = getCreatingTime(); val maxCreatingTime = getMaxCreatingTime(); + + // ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("creatingTime: " + creatingTime); + // ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("maxCreatingTime: " + maxCreatingTime); + return maxCreatingTime != 0 && creatingTime != 0 ? creatingTime * 24 / maxCreatingTime : 0; } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java index 00eeb4a4..2be7e0cb 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java @@ -118,8 +118,7 @@ public boolean isIngredient(ItemStack ingredient) { }); } - public ItemStack getResult( - ItemStack input, ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { + public ItemStack getResult(ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { return isIngredient(ingredient1) && isIngredient(ingredient2) && isIngredient(ingredient3) ? this.result : ItemStack.EMPTY; From 9c24f2f8d7bfb654f1cc41a86edca027ea05cb87 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 12 Oct 2023 12:22:37 +0100 Subject: [PATCH 39/51] removed some loggers --- .../infusion/IngotFusionTollEnhancerBlockEntity.java | 10 ++++------ .../blocks/infusion/IngotFusionTollEnhancerMenu.java | 3 --- .../trident/ArmourToolsModTridentItemRenderer.kt | 3 --- 3 files changed, 4 insertions(+), 12 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index d5ece3d2..205a5dcd 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -285,13 +285,12 @@ private boolean isCreatable(Level level) { // TODO: Need to check this for loop for (int i = 0; i < 3; ++i) { if (!this.items.get(i).isEmpty()) { - if (!this.items.get(i + 2).isEmpty()) { + if (!this.items.get(RESULT_SLOT).isEmpty()) { continue; } ItemStack ingredient = this.items.get(i); - if (!ingredient.isEmpty() - && hasRecipe(ingredient, ingredient1, ingredient2, ingredient3)) { + if (!ingredient.isEmpty() && hasRecipe(ingredient)) { return true; } } @@ -306,7 +305,7 @@ private void createItem(Level level) { var ingredient3 = this.items.get(2); var output = getOutput(level, ingredient1, ingredient2, ingredient3); - this.items.set(4, output); + this.items.set(RESULT_SLOT, output); val blockPos = this.getBlockPos(); if (ingredient1.hasCraftingRemainingItem()) { @@ -369,8 +368,7 @@ private void createItem(Level level) { 1035, blockPos, this.items.get(4).isEmpty() ? 0 : this.items.get(4).getCount()); } - private boolean hasRecipe( - ItemStack ingredient, ItemStack ingredient1, ItemStack ingredient2, ItemStack ingredient3) { + private boolean hasRecipe(ItemStack ingredient) { return level.getRecipeManager().getAllRecipesFor(type).stream() .anyMatch(recipe -> recipe.isIngredient(ingredient)); } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java index 2619221a..bda8a437 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java @@ -138,9 +138,6 @@ public int getCreatingProgress() { val creatingTime = getCreatingTime(); val maxCreatingTime = getMaxCreatingTime(); - // ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("creatingTime: " + creatingTime); - // ArmourAndToolsMod.ArmorAndToolsMod.getLogger().info("maxCreatingTime: " + maxCreatingTime); - return maxCreatingTime != 0 && creatingTime != 0 ? creatingTime * 24 / maxCreatingTime : 0; } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/renderer/trident/ArmourToolsModTridentItemRenderer.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/renderer/trident/ArmourToolsModTridentItemRenderer.kt index 2954a1dc..a590e692 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/renderer/trident/ArmourToolsModTridentItemRenderer.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/renderer/trident/ArmourToolsModTridentItemRenderer.kt @@ -20,7 +20,6 @@ package io.github.realyusufismail.armourandtoolsmod.client.renderer.trident import com.mojang.blaze3d.vertex.PoseStack import com.mojang.math.Axis -import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod import io.github.realyusufismail.armourandtoolsmod.common.entity.ArmourToolsModTridentEntity import net.minecraft.client.model.TridentModel import net.minecraft.client.model.geom.ModelLayers @@ -47,8 +46,6 @@ abstract class ArmourToolsModTridentItemRenderer(context: EntityRendererProvider bufferIn: MultiBufferSource, packedLightIn: Int ) { - ArmourAndToolsMod.logger.info( - "Rendering Trident Entity at $entityYaw, $partialTicks, $packedLightIn") matrixStackIn.pushPose() matrixStackIn.mulPose( Axis.YP.rotationDegrees(Mth.lerp(partialTicks, pEntity.yRotO, pEntity.yRot) - 90.0f)) From a8ea11209296cc0f55290ed3882c309ae824e3f8 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 12 Oct 2023 12:50:03 +0100 Subject: [PATCH 40/51] now requires fuel --- .../infusion/IngotFusionTollEnhancerBlockEntity.java | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index 205a5dcd..4760ce62 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -135,6 +135,7 @@ public void load(CompoundTag pTag) { ContainerHelper.loadAllItems(pTag, this.items); this.creatingTime = pTag.getInt("CraftTime"); this.creatingTotalTime = pTag.getInt("CraftTimeTotal"); + this.fuel = getFuels().getOrDefault(this.items.get(FUEL_SLOT).getItem(), 0); val compoundtag = pTag.getCompound("RecipesUsed"); @@ -147,6 +148,8 @@ public void load(CompoundTag pTag) { protected void saveAdditional(CompoundTag pTag) { pTag.putInt("CraftTime", this.creatingTime); pTag.putInt("CraftTimeTotal", this.creatingTotalTime); + pTag.putInt("Fuel", this.fuel); + ContainerHelper.saveAllItems(pTag, this.items); val compoundtag = new CompoundTag(); this.recipesUsed.forEach( @@ -235,7 +238,7 @@ public static void serverTick( // Do i need blockEntity.fuel in this if statement? if (blockEntity.fuel <= 0 && getFuels().containsKey(itemstack.getItem())) { - blockEntity.fuel = 20; + blockEntity.fuel = getFuels().get(itemstack.getItem()); itemstack.shrink(1); blockEntity.setChanged(); } @@ -260,18 +263,14 @@ public static void serverTick( blockEntity.creatingTime = 0; blockEntity.setChanged(); } - } else if (flag) { + } else if (flag && blockEntity.fuel > 0) { --blockEntity.fuel; - // TODO: Add ability to alter creating time. blockEntity.creatingTime = 200; blockEntity.ingredient1 = ingredient1; blockEntity.ingredient2 = ingredient2; blockEntity.ingredient3 = ingredient3; blockEntity.setChanged(); - } else { - blockEntity.creatingTime = 0; - blockEntity.setChanged(); } } From 19830daf2bd12db0bc7c122f5d771fc8ee5cdcf9 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 12 Oct 2023 12:55:58 +0100 Subject: [PATCH 41/51] arrow now works --- .../blocks/infusion/IngotFusionTollEnhancerBlockEntity.java | 4 ---- .../blocks/infusion/IngotFusionTollEnhancerMenu.java | 2 ++ 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index 4760ce62..93d69a3c 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -97,8 +97,6 @@ public class IngotFusionTollEnhancerBlockEntity extends BaseContainerBlockEntity protected final ContainerData dataAccess = new ContainerData() { public int get(int p_58431_) { - ArmourAndToolsMod.ArmorAndToolsMod.getLogger() - .info("Getting data: " + p_58431_ + " to " + p_58431_); return switch (p_58431_) { case 0 -> IngotFusionTollEnhancerBlockEntity.this.creatingTime; case 1 -> IngotFusionTollEnhancerBlockEntity.this.creatingTotalTime; @@ -108,8 +106,6 @@ public int get(int p_58431_) { } public void set(int p_58433_, int p_58434_) { - ArmourAndToolsMod.ArmorAndToolsMod.getLogger() - .info("Setting data: " + p_58433_ + " to " + p_58434_); switch (p_58433_) { case 0 -> IngotFusionTollEnhancerBlockEntity.this.creatingTime = p_58434_; case 1 -> IngotFusionTollEnhancerBlockEntity.this.creatingTotalTime = p_58434_; diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java index bda8a437..05e63132 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java @@ -85,6 +85,8 @@ public IngotFusionTollEnhancerMenu( // slot to place result addSlot(new OutputSlotItemHandler(it, pInventory.player)); }); + + addDataSlots(data); } public IngotFusionTollEnhancerMenu(int pContainerId, Inventory inventory, FriendlyByteBuf data) { From fe9bbb9c21602c1719d38ef2a8dc187adc2b2e49 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 12 Oct 2023 14:09:04 +0100 Subject: [PATCH 42/51] Fixed issue with JEI --- .github/workflows/page.yml | 6 +- .../IngotFusionTollEnhancerBlockEntity.java | 56 +++++++++++++++++++ .../infusion/IngotFusionTollEnhancerMenu.java | 2 +- .../IngotFusionTollEnhancerRecipe.java | 6 +- .../infusion/slots/OutputSlotItemHandler.kt | 15 +++++ ...ngotFusionTollEnhancerJEIRecipeCategory.kt | 6 +- 6 files changed, 81 insertions(+), 10 deletions(-) diff --git a/.github/workflows/page.yml b/.github/workflows/page.yml index 9ee54a6c..a7e371b4 100644 --- a/.github/workflows/page.yml +++ b/.github/workflows/page.yml @@ -21,7 +21,7 @@ jobs: name: github-pages url: ${{ steps.deployment.outputs.page_url }} steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - name: Set up JDK 17 uses: actions/setup-java@v3 with: @@ -30,11 +30,11 @@ jobs: - name: Grant execute permission for gradlew run: chmod +x gradlew - name: Generate documentation directory - uses: gradle/gradle-build-action@v2 + uses: gradle/gradle-build-action@v2.9.0 with: arguments: dokkaHtml - name: Upload artifact - uses: actions/upload-pages-artifact@v1 + uses: actions/upload-pages-artifact@v2 with: path: ./build/dokka/html - name: Deploy to GitHub Pages diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java index 93d69a3c..3403c576 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerBlockEntity.java @@ -18,6 +18,7 @@ */ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion; +import com.google.common.collect.Lists; import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod; import io.github.realyusufismail.armourandtoolsmod.blocks.IngotFusionTollEnhancer; import io.github.realyusufismail.armourandtoolsmod.core.init.BlockEntityTypeInit; @@ -25,6 +26,7 @@ import io.github.realyusufismail.armourandtoolsmod.core.init.ItemInit; import io.github.realyusufismail.armourandtoolsmod.core.init.RecipeTypeInit; import io.github.realyusufismail.armourandtoolsmod.recipe.infusion.IngotFusionTollEnhancerRecipe; +import it.unimi.dsi.fastutil.objects.Object2IntMap; import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap; import java.util.*; import lombok.Getter; @@ -38,8 +40,12 @@ import net.minecraft.nbt.CompoundTag; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; +import net.minecraft.server.level.ServerLevel; +import net.minecraft.server.level.ServerPlayer; import net.minecraft.tags.ItemTags; +import net.minecraft.util.Mth; import net.minecraft.world.*; +import net.minecraft.world.entity.ExperienceOrb; import net.minecraft.world.entity.player.Inventory; import net.minecraft.world.entity.player.Player; import net.minecraft.world.entity.player.StackedContents; @@ -50,6 +56,7 @@ import net.minecraft.world.item.Item; import net.minecraft.world.item.ItemStack; import net.minecraft.world.item.Items; +import net.minecraft.world.item.crafting.AbstractCookingRecipe; import net.minecraft.world.item.crafting.Recipe; import net.minecraft.world.item.crafting.RecipeManager; import net.minecraft.world.item.crafting.RecipeType; @@ -57,6 +64,7 @@ import net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity; import net.minecraft.world.level.block.entity.BaseContainerBlockEntity; import net.minecraft.world.level.block.state.BlockState; +import net.minecraft.world.phys.Vec3; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; @@ -448,4 +456,52 @@ public void fillStackedContents(StackedContents pContents) { pContents.accountStack(itemstack); } } + + public void awardUsedRecipes(Player pPlayer, List pItems) {} + + public void awardUsedRecipesAndPopExperience(ServerPlayer pPlayer) { + List> list = + this.getRecipesToAwardAndPopExperience(pPlayer.serverLevel(), pPlayer.position()); + pPlayer.awardRecipes(list); + + for (Recipe recipe : list) { + if (recipe != null) { + pPlayer.triggerRecipeCrafted(recipe, this.items); + } + } + + this.recipesUsed.clear(); + } + + public List> getRecipesToAwardAndPopExperience(ServerLevel pLevel, Vec3 pPopVec) { + List> list = Lists.newArrayList(); + + for (Object2IntMap.Entry entry : this.recipesUsed.object2IntEntrySet()) { + pLevel + .getRecipeManager() + .byKey(entry.getKey()) + .ifPresent( + (p_155023_) -> { + list.add(p_155023_); + createExperience( + pLevel, + pPopVec, + entry.getIntValue(), + ((AbstractCookingRecipe) p_155023_).getExperience()); + }); + } + + return list; + } + + private static void createExperience( + ServerLevel pLevel, Vec3 pPopVec, int pRecipeIndex, float pExperience) { + int i = Mth.floor((float) pRecipeIndex * pExperience); + float f = Mth.frac((float) pRecipeIndex * pExperience); + if (f != 0.0F && Math.random() < (double) f) { + ++i; + } + + ExperienceOrb.award(pLevel, pPopVec, i); + } } diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java index 05e63132..86f54bb2 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/IngotFusionTollEnhancerMenu.java @@ -215,7 +215,7 @@ public boolean isFuel(ItemStack pStack) { @Override public @NotNull RecipeBookType getRecipeBookType() { - return RecipeBookTypesInit.INGOT_FUSION; + return recipeBook; } @Override diff --git a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java index 2be7e0cb..668c59e2 100644 --- a/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java +++ b/src/main/java/io/github/realyusufismail/armourandtoolsmod/recipe/infusion/IngotFusionTollEnhancerRecipe.java @@ -40,9 +40,9 @@ public class IngotFusionTollEnhancerRecipe implements Recipe { protected final RecipeType type; protected final ResourceLocation id; - @Getter protected final Ingredient ingredient1; - @Getter protected final Ingredient ingredient2; - @Getter protected final Ingredient ingredient3; + @Getter public final Ingredient ingredient1; + @Getter public final Ingredient ingredient2; + @Getter public final Ingredient ingredient3; @Getter @NotNull public final ItemStack result; @Getter @NotNull public final IngotFusionTollEnhancerRecipeBookCategory category; diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt index b57e62ff..29489963 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/blocks/infusion/slots/OutputSlotItemHandler.kt @@ -20,8 +20,10 @@ package io.github.realyusufismail.armourandtoolsmod.blocks.infusion.slots import io.github.realyusufismail.armourandtoolsmod.blocks.infusion.IngotFusionTollEnhancerBlockEntity import kotlin.math.min +import net.minecraft.server.level.ServerPlayer import net.minecraft.world.entity.player.Player import net.minecraft.world.item.ItemStack +import net.minecraftforge.event.ForgeEventFactory import net.minecraftforge.items.IItemHandler import net.minecraftforge.items.SlotItemHandler @@ -44,4 +46,17 @@ class OutputSlotItemHandler(itemHandler: IItemHandler, val player: Player) : checkTakeAchievements(pStack) super.onTake(pPlayer, pStack) } + + /** @param pStack the output - ie, iron ingots, and pickaxes, not ore and wood. */ + override fun checkTakeAchievements(pStack: ItemStack) { + pStack.onCraftedBy(player.level(), player, removeCount!!) + val player = player + if (player is ServerPlayer) { + val container = container + (container as? IngotFusionTollEnhancerBlockEntity)?.awardUsedRecipesAndPopExperience( + player) + } + removeCount = 0 + ForgeEventFactory.firePlayerSmeltedEvent(this.player, pStack) + } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt index 3622f1a3..110bd6d6 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/fusion/IngotFusionTollEnhancerJEIRecipeCategory.kt @@ -108,9 +108,9 @@ class IngotFusionTollEnhancerJEIRecipeCategory(guiHelper: IGuiHelper) : recipe: IngotFusionTollEnhancerRecipe, focuses: IFocusGroup ) { - builder.addSlot(RecipeIngredientRole.INPUT, 16, 40).addIngredients(recipe.ingredients[0]) - builder.addSlot(RecipeIngredientRole.INPUT, 43, 40).addIngredients(recipe.ingredients[1]) - builder.addSlot(RecipeIngredientRole.INPUT, 70, 40).addIngredients(recipe.ingredients[2]) + builder.addSlot(RecipeIngredientRole.INPUT, 16, 40).addIngredients(recipe.ingredient1) + builder.addSlot(RecipeIngredientRole.INPUT, 43, 40).addIngredients(recipe.ingredient2) + builder.addSlot(RecipeIngredientRole.INPUT, 70, 40).addIngredients(recipe.ingredient3) builder .addSlot(RecipeIngredientRole.INPUT, 102, 65) From a8824832b8128e95e7b61667abe693cde7ab05d5 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 12 Oct 2023 22:13:20 +0100 Subject: [PATCH 43/51] Added imperium ore. and ingot --- CHANGELOG.md | 7 +++ .../103d9f3f36b01595f1aa5172191e60eff02e6924 | 4 +- .../59eb3dbb5f86130e09b3c62d89b9525ee01cf52d | 4 +- .../9cedfe5b9b9b8fb51ee0cbcde6ee21cf9da7c57c | 8 ++- .../9f61bb65fbe4cfb8a15e0d3253c99409d3dd169b | 3 +- .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 16 +++++- .../b051adeca7b8303d1a7d46afb7c4eaf8cfa3a7f5 | 4 +- .../b437fe956183b85bad8f19eb71f021ad5d4a1455 | 8 ++- .../c622617f6fabf890a00b9275cd5f643584a8a2c8 | 4 +- .../e5c5eb35b4ba40351ecb7d9f04c3527f2f5779b0 | 5 +- .../blockstates/deepslate_imperium_ore.json | 7 +++ .../blockstates/imperium_ore.json | 7 +++ .../assets/armourandtoolsmod/lang/en_us.json | 3 + .../models/block/deepslate_imperium_ore.json | 6 ++ .../models/block/imperium_ore.json | 6 ++ .../models/item/deepslate_imperium_ore.json | 3 + .../models/item/imperium_ore.json | 3 + .../models/item/raw_imperium.json | 6 ++ .../advancements/imperium_ingot.json | 36 ++++++++++++ .../advancements/imperium_ore.json | 36 ++++++++++++ .../advancements/imperium_tools.json | 52 ++++++++++++++++++ .../ingot_fusion_toll_enhancer_recipe.json | 35 ++++++++++++ .../misc/blasting_deepslate_imperium_ore.json | 35 ++++++++++++ .../recipes/misc/blasting_imperium_ore.json | 35 ++++++++++++ .../recipes/misc/blasting_raw_imperium.json | 35 ++++++++++++ .../misc/smelting_deepslate_imperium_ore.json | 35 ++++++++++++ .../recipes/misc/smelting_imperium_ore.json | 35 ++++++++++++ .../recipes/misc/smelting_raw_imperium.json | 35 ++++++++++++ .../blocks/deepslate_imperium_ore.json | 50 +++++++++++++++++ .../loot_tables/blocks/imperium_ore.json | 50 +++++++++++++++++ .../blasting_deepslate_imperium_ore.json | 9 +++ .../recipes/blasting_imperium_ore.json | 9 +++ .../recipes/blasting_raw_imperium.json | 9 +++ .../ingot_fusion_toll_enhancer_recipe.json | 24 ++++++++ .../smelting_deepslate_imperium_ore.json | 9 +++ .../recipes/smelting_imperium_ore.json | 9 +++ .../recipes/smelting_raw_imperium.json | 9 +++ .../configured_feature/imperium_ore.json | 18 ++++++ .../worldgen/placed_feature/imperium_ore.json | 27 +++++++++ .../blocks/deepslate_ores/imperium_ores.json | 5 ++ .../forge/tags/blocks/ores/imperium_ores.json | 5 ++ .../items/deepslate_ores/imperium_ores.json | 5 ++ .../forge/tags/items/ores/imperium_ores.json | 5 ++ .../tags/blocks/mineable/pickaxe.json | 2 + .../tags/blocks/needs_iron_tool.json | 2 + .../armourandtoolsmod/core/init/BlockInit.kt | 14 +++++ .../armourandtoolsmod/core/init/ItemInit.kt | 2 + .../armourandtoolsmod/core/init/TagsInit.kt | 29 ++++++++++ .../datagen/advancment/Advancements.kt | 49 +++++++++++++++++ .../datagen/lang/ModEnLangProvider.kt | 3 + .../datagen/loot/ModBlockLootTables.kt | 6 ++ .../NormalCraftingTableRecipeProvider.kt | 14 +++++ .../ToolCraftingTableRecipeProvider.kt | 2 + .../datagen/tags/ModBlockTagsProvider.kt | 5 ++ .../datagen/tags/ModItemTagsProvider.kt | 6 ++ .../datagen/texture/ModBlockStateProvider.kt | 7 +++ .../datagen/texture/ModItemStateProvider.kt | 1 + .../worldgen/ModConfiguredFeatures.kt | 10 ++++ .../worldgen/ModPlacedFeatures.kt | 12 ++++ .../textures/block/deepslate_imperium_ore.png | Bin 0 -> 600 bytes .../textures/block/imperium_ore.png | Bin 0 -> 521 bytes .../textures/item/imperium_axe.png | Bin 0 -> 240 bytes .../textures/item/raw_imperium.png | Bin 0 -> 351 bytes 63 files changed, 868 insertions(+), 12 deletions(-) create mode 100644 src/generated/resources/assets/armourandtoolsmod/blockstates/deepslate_imperium_ore.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/blockstates/imperium_ore.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/block/deepslate_imperium_ore.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/block/imperium_ore.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/item/deepslate_imperium_ore.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/item/imperium_ore.json create mode 100644 src/generated/resources/assets/armourandtoolsmod/models/item/raw_imperium.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/imperium_ingot.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/imperium_tools.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/building_blocks/ingot_fusion_toll_enhancer_recipe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_deepslate_imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_imperium.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_deepslate_imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_imperium.json create mode 100644 src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/deepslate_imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/blasting_deepslate_imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/blasting_raw_imperium.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/ingot_fusion_toll_enhancer_recipe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/smelting_deepslate_imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/smelting_raw_imperium.json create mode 100644 src/generated/resources/data/armourandtoolsmod/worldgen/configured_feature/imperium_ore.json create mode 100644 src/generated/resources/data/armourandtoolsmod/worldgen/placed_feature/imperium_ore.json create mode 100644 src/generated/resources/data/forge/tags/blocks/deepslate_ores/imperium_ores.json create mode 100644 src/generated/resources/data/forge/tags/blocks/ores/imperium_ores.json create mode 100644 src/generated/resources/data/forge/tags/items/deepslate_ores/imperium_ores.json create mode 100644 src/generated/resources/data/forge/tags/items/ores/imperium_ores.json create mode 100644 src/main/resources/assets/armourandtoolsmod/textures/block/deepslate_imperium_ore.png create mode 100644 src/main/resources/assets/armourandtoolsmod/textures/block/imperium_ore.png create mode 100644 src/main/resources/assets/armourandtoolsmod/textures/item/imperium_axe.png create mode 100644 src/main/resources/assets/armourandtoolsmod/textures/item/raw_imperium.png diff --git a/CHANGELOG.md b/CHANGELOG.md index c471d88a..f9975fd7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,13 @@ All notable changes to this project will be documented in this file. +## [1.20.1-1.0.6] - UNRELEASED + +### Added Ingot Fusion Enchanter (been in the works for a mont with more than two rewrites) : +### This allows you to upgrade certain items. Currently only works with the MAGMA_STRIKE_PICKAXE. More to come in future. +### Added imperium sword, pickaxe, axe, ingot and ore. More to come in the future. +### Fixed some issues I came across while testing. + ## [1.20.1-1.0.5] - 2023-09-26 ### Added JEI integration for custom crafting tables. diff --git a/src/generated/resources/.cache/103d9f3f36b01595f1aa5172191e60eff02e6924 b/src/generated/resources/.cache/103d9f3f36b01595f1aa5172191e60eff02e6924 index 69b04235..9d4e46a1 100644 --- a/src/generated/resources/.cache/103d9f3f36b01595f1aa5172191e60eff02e6924 +++ b/src/generated/resources/.cache/103d9f3f36b01595f1aa5172191e60eff02e6924 @@ -1,13 +1,15 @@ -// 1.20.1 2023-09-03T09:44:53.454996 Registries +// 1.20.1 2023-10-12T22:09:59.3276706 Registries 8ebeb9bcc133ba172a3775d0e796bc03967d305e data/armourandtoolsmod/worldgen/configured_feature/aqumarine_ore.json efcff90a0c2ce2de5ad73b08e38af0880ff404de data/armourandtoolsmod/worldgen/configured_feature/enderite_ore.json b77f5a337f5557cc75c6aa6e358f59b658ba914c data/armourandtoolsmod/worldgen/configured_feature/graphite_ore.json +3586104847bae073d8ffda6725cfe9f65fd3db37 data/armourandtoolsmod/worldgen/configured_feature/imperium_ore.json b6141dbad16c493a2dd3da977a099762593c0ce1 data/armourandtoolsmod/worldgen/configured_feature/rainbow_ore.json 3057438b0a0e49c8fa64f17eca031307d1247594 data/armourandtoolsmod/worldgen/configured_feature/ruby_ore.json ae5ee97a8e0db56c8b686c63d73efad162974df7 data/armourandtoolsmod/worldgen/configured_feature/sapphire_ore.json f27642c578ca288c102d5a06421fcd879102fd7a data/armourandtoolsmod/worldgen/placed_feature/aqumarine_ore.json a0c79f9bf1ba7248cab71480bb71041682400cdd data/armourandtoolsmod/worldgen/placed_feature/enderite_ore.json 65608a650f79607aeb96f0ad3ed9a099f59aec67 data/armourandtoolsmod/worldgen/placed_feature/graphite_ore.json +c8eccb16b2db153e5902b8c8ab07a2a7f51a2f36 data/armourandtoolsmod/worldgen/placed_feature/imperium_ore.json c784f4c858f7b80fcc27ca88c8f80774bfa35b23 data/armourandtoolsmod/worldgen/placed_feature/rainbow_ore.json 7bb425cc1128f1c7cce61f9ef23b30e7bf3b3331 data/armourandtoolsmod/worldgen/placed_feature/ruby_ore.json ed58618a3af3d63c835c2a5dccff501b8272f323 data/armourandtoolsmod/worldgen/placed_feature/sapphire_ore.json diff --git a/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d b/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d index 40adfdee..79ccde6c 100644 --- a/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d +++ b/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d @@ -1,10 +1,11 @@ -// 1.20.1 2023-09-30T23:22:14.944242 Loot Tables +// 1.20.1 2023-10-12T22:09:59.3226175 Loot Tables 2898515efda3fb01ac7eb6337875f6310869a683 data/armourandtoolsmod/loot_tables/blocks/aqumarine_block.json 1efb52b906488da11f7948ed6a21285c1ae085c5 data/armourandtoolsmod/loot_tables/blocks/aqumarine_ore.json 0f854404a05c040106f826bf3e6eb1debb2b8513 data/armourandtoolsmod/loot_tables/blocks/custom_armour_crafting_table.json 56189365fbfbeedbc9086e95af54637dc1288e25 data/armourandtoolsmod/loot_tables/blocks/custom_tool_crafting_table.json 037852d2164bc89fdf7eec7ca820d976bfb8cf00 data/armourandtoolsmod/loot_tables/blocks/deepslate_aqumarine_ore.json 052b565467fcb498276abcd82329fa8e9f3dac0c data/armourandtoolsmod/loot_tables/blocks/deepslate_graphite_ore.json +c80a43cdf06bb47f0ea5ac5792cff47d6dd1365a data/armourandtoolsmod/loot_tables/blocks/deepslate_imperium_ore.json 5b1d35ef7749092a2048ab38bc74861db42d08d9 data/armourandtoolsmod/loot_tables/blocks/deepslate_rainbow_ore.json 353b1fcc43692ef4d531d28725c0cbae9f21beed data/armourandtoolsmod/loot_tables/blocks/deepslate_ruby_ore.json 5152d7bfc26caa8fbafd7d728a3bde94f17071f1 data/armourandtoolsmod/loot_tables/blocks/deepslate_sapphire_ore.json @@ -12,6 +13,7 @@ ee3c7cea455b43662bb85c65ba097a66fad15e2b data/armourandtoolsmod/loot_tables/bloc 0a1baaef0c26d8186cfebd9b5f7e8a319d14187d data/armourandtoolsmod/loot_tables/blocks/enderite_ore.json baf5c9934dbe9336e2362956ea6223cd4f067fd5 data/armourandtoolsmod/loot_tables/blocks/graphite_block.json 4e4d7f9e13f901fe3ae5ca406313f683dda24fbb data/armourandtoolsmod/loot_tables/blocks/graphite_ore.json +17468a98a420053cfde63911493d9289cffa48f4 data/armourandtoolsmod/loot_tables/blocks/imperium_ore.json e71ceb5931a3484e4792e6c73a0f9ff13d769c6f data/armourandtoolsmod/loot_tables/blocks/ingot_fusion_toll_enhancer.json be352efe18892a6d569480eb2c34423ab7e8f199 data/armourandtoolsmod/loot_tables/blocks/rainbow_block.json 8c9c9a72eb8e8424e527174afee3bee8f54a6c0d data/armourandtoolsmod/loot_tables/blocks/rainbow_ore.json diff --git a/src/generated/resources/.cache/9cedfe5b9b9b8fb51ee0cbcde6ee21cf9da7c57c b/src/generated/resources/.cache/9cedfe5b9b9b8fb51ee0cbcde6ee21cf9da7c57c index e4c8ca1a..fc163805 100644 --- a/src/generated/resources/.cache/9cedfe5b9b9b8fb51ee0cbcde6ee21cf9da7c57c +++ b/src/generated/resources/.cache/9cedfe5b9b9b8fb51ee0cbcde6ee21cf9da7c57c @@ -1,6 +1,7 @@ -// 1.20.1 2023-09-30T23:22:14.940764 Tags for minecraft:block mod id armourandtoolsmod +// 1.20.1 2023-10-12T22:09:59.3123883 Tags for minecraft:block mod id armourandtoolsmod f4e0d28b203a60fd241885a727654636c8762650 data/forge/tags/blocks/deepslate_ores/aqumarine_ores.json 186e50e522fb2ae91c6e315a523523796b105b56 data/forge/tags/blocks/deepslate_ores/graphite_ores.json +08f48b19390eb9e06478f989851d261c8cb384a4 data/forge/tags/blocks/deepslate_ores/imperium_ores.json d66c065dfb98375b77835223afe692a26c7be84b data/forge/tags/blocks/deepslate_ores/rainbow_ores.json cd94fb683ebafe1cbde0ba3a30280d57b587fc34 data/forge/tags/blocks/deepslate_ores/ruby_ores.json 6a274e766194dfaf9c967be14c4b26a4ff637a8b data/forge/tags/blocks/deepslate_ores/sapphire_ores.json @@ -8,6 +9,7 @@ f773a519f0e034a7e3ca24464a8b960396d4da4c data/forge/tags/blocks/needs_gold_tool. 1372356eb4655b6d26d8a5a16aaa3032bbb738d4 data/forge/tags/blocks/ores/aqumarine_ores.json fef5965e3903fc07aa6146bd17e74efd9b313fb6 data/forge/tags/blocks/ores/enderite_ores.json 974c70b44df044135463b300ebed43eee38001b3 data/forge/tags/blocks/ores/graphite_ores.json +e892786d477f668113418b8239abc7bb6395f33f data/forge/tags/blocks/ores/imperium_ores.json fa835a8b8eb217767d6139f02c46edfa27377555 data/forge/tags/blocks/ores/rainbow_ores.json f5b270d5c60fdfc53020be6469026c27bc742f1e data/forge/tags/blocks/ores/ruby_ores.json 47d725a30030287aa216532b38ba1d0774dd627f data/forge/tags/blocks/ores/sapphire_ores.json @@ -17,7 +19,7 @@ b4f0641534858a5001fc966241f11ffc58353dea data/forge/tags/blocks/storage_blocks/a 55c124f845d639b73cb5bffcdcc94bcfd8967966 data/forge/tags/blocks/storage_blocks/rainbow.json bc5ebfcaf115155b63f0817517bdc3efc0934364 data/forge/tags/blocks/storage_blocks/ruby.json 2e755598d83145bf0d52488c9d8e3c41331dccc3 data/forge/tags/blocks/storage_blocks/sapphire.json -ab8d7b5abe400a808fae17129487aaea1824bebf data/minecraft/tags/blocks/mineable/pickaxe.json +a5acd6d8f782164d765c73d2438d0289b32f2bcd data/minecraft/tags/blocks/mineable/pickaxe.json 98eed05f65788348c30e906407f790c6a4d70f32 data/minecraft/tags/blocks/needs_diamond_tool.json -305db57c519bc4cfa07a662c8beeffec12ffac38 data/minecraft/tags/blocks/needs_iron_tool.json +7f6f40bd05ba0003ea6e54eee50655a1d2fc1fcb data/minecraft/tags/blocks/needs_iron_tool.json a9b03e3b99a673d01bb7413cc6092c7a9b5be634 data/minecraft/tags/blocks/needs_stone_tool.json diff --git a/src/generated/resources/.cache/9f61bb65fbe4cfb8a15e0d3253c99409d3dd169b b/src/generated/resources/.cache/9f61bb65fbe4cfb8a15e0d3253c99409d3dd169b index 47d04f44..0678f642 100644 --- a/src/generated/resources/.cache/9f61bb65fbe4cfb8a15e0d3253c99409d3dd169b +++ b/src/generated/resources/.cache/9f61bb65fbe4cfb8a15e0d3253c99409d3dd169b @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-01T16:57:43.5762063 Item Models: armourandtoolsmod +// 1.20.1 2023-10-12T22:09:59.3196167 Item Models: armourandtoolsmod 6fdab53e9321f76ef7edd0a135b6879656abdad7 assets/armourandtoolsmod/models/item/amethyst_axe.json f523d3f594a0d1a51fb553f028ab2b20eee793dd assets/armourandtoolsmod/models/item/amethyst_boots.json 8377e984c59ebdaa220b7d1c0973dfd4653e52fb assets/armourandtoolsmod/models/item/amethyst_chestplate.json @@ -48,6 +48,7 @@ e7a2dce51d378c49e596294d6ea2bf6f8d5bf6a2 assets/armourandtoolsmod/models/item/ra 33b68057db18389d58595a300e616f0e1f848ada assets/armourandtoolsmod/models/item/raw_aqumarine.json e2e4e00dea2145b5ae54560c28a85eae2bf5bed5 assets/armourandtoolsmod/models/item/raw_enderite.json 68070919d55c07e9e09eb39a3a50362475cfcc14 assets/armourandtoolsmod/models/item/raw_graphite.json +3061dcb2768b3fb493283254c3ba51bb39d60f79 assets/armourandtoolsmod/models/item/raw_imperium.json 073845b113c727ef0adce18c38781aa211ab8867 assets/armourandtoolsmod/models/item/raw_rainbow.json 40dd62b983e59172e5640256e298c1ab3704de25 assets/armourandtoolsmod/models/item/raw_ruby.json 7321aefdabda17126533ee833870352ecb756978 assets/armourandtoolsmod/models/item/raw_sapphire.json diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index 3bdf4133..1f7b3356 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,9 +1,10 @@ -// 1.20.1 2023-10-11T21:50:46.5765886 Recipes +// 1.20.1 2023-10-12T22:09:59.3236154 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json b1fa135141f599ea4d7fab4f77cd7aae863f0819 data/armourandtoolsmod/advancements/recipes/building_blocks/enderite_block_recipe.json 1acc3f7f2761775fc7efe033dd5b77393a66ca9d data/armourandtoolsmod/advancements/recipes/building_blocks/graphite_block_recipe.json +ccb320284e7430286cffdffd1a9ce9b6babe48f6 data/armourandtoolsmod/advancements/recipes/building_blocks/ingot_fusion_toll_enhancer_recipe.json c7a9daf7e9793d66f69bdfd53a8e535251b0a75c data/armourandtoolsmod/advancements/recipes/building_blocks/rainbow_block_recipe.json a1191d311fcf166617e619855f1c89f218ed3d0a data/armourandtoolsmod/advancements/recipes/building_blocks/ruby_block_recipe.json 4e2d078faefa50aebd181dcc29d0c0d22e75bff4 data/armourandtoolsmod/advancements/recipes/building_blocks/sapphire_block_recipe.json @@ -44,6 +45,7 @@ c642de905ce8e6b87d8d9c6a776480d5d5335646 data/armourandtoolsmod/advancements/rec 1da9de6c6a5c07dc66b392bb507a437a3a2086b9 data/armourandtoolsmod/advancements/recipes/misc/blasting_aqumarine_trident.json 8b7f09c2641f571163d351d1e7d12d0002fe821a data/armourandtoolsmod/advancements/recipes/misc/blasting_deepslate_aqumarine_ore.json c9f89ed0c1cf85b7d741006f820f59445b6570eb data/armourandtoolsmod/advancements/recipes/misc/blasting_deepslate_graphite_ore.json +94d18b20f86c0520e3132441323981f782ff1af7 data/armourandtoolsmod/advancements/recipes/misc/blasting_deepslate_imperium_ore.json c07cb3c50293b4e7f0e719738657886da0e4f0a2 data/armourandtoolsmod/advancements/recipes/misc/blasting_deepslate_rainbow_ore.json 6347da67981c03ef4dd93c6ba4a452b4abf015e9 data/armourandtoolsmod/advancements/recipes/misc/blasting_deepslate_ruby_ore.json 7fe9ac66d15c9ba799b4e3273e1156af890fe661 data/armourandtoolsmod/advancements/recipes/misc/blasting_deepslate_sapphire_ore.json @@ -63,6 +65,7 @@ ed6863180fbdb2aca431c6bcdb0f6df8afe69409 data/armourandtoolsmod/advancements/rec ee8e188e67a2f84b6c44f9192afb3df90a2dbeec data/armourandtoolsmod/advancements/recipes/misc/blasting_graphite_leggings.json c2713f717ff034d981cc364a316a1d1ba5b193e5 data/armourandtoolsmod/advancements/recipes/misc/blasting_graphite_ore.json e0bc24cbc2dfaf553c81d5df49dae90e26607755 data/armourandtoolsmod/advancements/recipes/misc/blasting_graphite_shield.json +c1037c2bcfe5d85a4a2b5a99af8046b4a07483f7 data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_ore.json 4b741bf870196f2f5e99ab7ea7f0ad5231af6b78 data/armourandtoolsmod/advancements/recipes/misc/blasting_rainbow_boots.json 20388126da52b373ebcc1a33af22ad2427f2e730 data/armourandtoolsmod/advancements/recipes/misc/blasting_rainbow_chestplate.json 0b75836d5abc9865e2c66b363486656fc3f7243a data/armourandtoolsmod/advancements/recipes/misc/blasting_rainbow_helmet.json @@ -72,6 +75,7 @@ cb26f2aa48a3dd77099c07ce7de232bebef9a9aa data/armourandtoolsmod/advancements/rec 0850dae06e25bbf2c1b2945374ae973c1a6b8af6 data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_aqumarine.json 4abd2efebf5520a66b84548d28129c24255e3c12 data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_enderite.json 439470381e3121b18d0a62a08eb8297ed4cbec99 data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_graphite.json +4354d2e08cdac65b77b57e7c75a37aefff86dc8a data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_imperium.json b89be5df3c953a270ea839ca5898bf7c1193539d data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_rainbow.json 86059c216bc6943213702d7695997b010f077d9a data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_ruby.json b7e76846c125f9f68a05d49ebb636b2ac656c6e4 data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_sapphire.json @@ -107,6 +111,7 @@ f9a05422123bfed508fd57ade8ae076d6d3e9f87 data/armourandtoolsmod/advancements/rec 196452c4a9bba2b81c261f0b9c083a847e67dfdc data/armourandtoolsmod/advancements/recipes/misc/smelting_aqumarine_trident.json 9c37b6f168979f96ee24f9143c237395d4b7894e data/armourandtoolsmod/advancements/recipes/misc/smelting_deepslate_aqumarine_ore.json f0b78cc5431a28aa63f0c8ff7c6907ee467f3dde data/armourandtoolsmod/advancements/recipes/misc/smelting_deepslate_graphite_ore.json +a1cf1012000deb960c34558568790dcf6842f2e1 data/armourandtoolsmod/advancements/recipes/misc/smelting_deepslate_imperium_ore.json 76e72325f77b49c8b5d773e2f236aed73defa96d data/armourandtoolsmod/advancements/recipes/misc/smelting_deepslate_rainbow_ore.json 05b817f3113534fae563be099250f596bb340512 data/armourandtoolsmod/advancements/recipes/misc/smelting_deepslate_ruby_ore.json 25496969a81dc5396321fa699ad6ef71a6845593 data/armourandtoolsmod/advancements/recipes/misc/smelting_deepslate_sapphire_ore.json @@ -126,6 +131,7 @@ ab96657c7a924abefeacb0c6aab067361dbd9385 data/armourandtoolsmod/advancements/rec 6d38ce697d71dc070a82b5df079fc55e817db0f5 data/armourandtoolsmod/advancements/recipes/misc/smelting_graphite_leggings.json 82ad6894705e8823f89fcc51b271ced2c718f043 data/armourandtoolsmod/advancements/recipes/misc/smelting_graphite_ore.json 19adb32ab595ae5f70d35594871c85b005916583 data/armourandtoolsmod/advancements/recipes/misc/smelting_graphite_shield.json +58dc85362f1e0e10f0f3ee9147ffeea5eda0ee99 data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_ore.json 862fdef31621aa2292be16dfc763fbbde13a436b data/armourandtoolsmod/advancements/recipes/misc/smelting_rainbow_boots.json 6d6be5cee0e052ce45e8cc5bcb5119ee11886ff4 data/armourandtoolsmod/advancements/recipes/misc/smelting_rainbow_chestplate.json 28d6e51f8e14ee87e470e00b4184cd693a5866cc data/armourandtoolsmod/advancements/recipes/misc/smelting_rainbow_helmet.json @@ -135,6 +141,7 @@ d6491169a6fed068edd6eb2bcbf0d8e7a91e5a52 data/armourandtoolsmod/advancements/rec 152c3c75c2dadd8e80812523316b4143ee1028c9 data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_aqumarine.json e23db98788b0af3cc60a306e55936e15ebb2ccab data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_enderite.json a2afd163fee51f111d2f5cbc9078833cb0503e44 data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_graphite.json +a8c847ec60b7357929a4cabbff1c0e84c8c7de10 data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_imperium.json 51244dfde5aa6d9fed7419f8898a0aca090051ad data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_rainbow.json a8645c8ccdfdb178b2dab19a44bde81133e050d8 data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_ruby.json 64f93f80f3fd7d77b9457a00884713fd799047eb data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_sapphire.json @@ -207,6 +214,7 @@ add1364bea93f082cfbde5ea7691601bcb39c167 data/armourandtoolsmod/recipes/blasting 0664ebaea50346e487b1f1d80e6f64bf83bc30ea data/armourandtoolsmod/recipes/blasting_aqumarine_trident.json 33dda1dab04283c3a1db5ff577ae5f0e67ab6785 data/armourandtoolsmod/recipes/blasting_deepslate_aqumarine_ore.json fa451aadfe0d1733d98c5fdf218737b65ba7977a data/armourandtoolsmod/recipes/blasting_deepslate_graphite_ore.json +1ceb5abed9a96a3149f9eb3fbb6cacd3d1e57b54 data/armourandtoolsmod/recipes/blasting_deepslate_imperium_ore.json 085a3f25fabbe82511cedcdd68fa34b757f3eccc data/armourandtoolsmod/recipes/blasting_deepslate_rainbow_ore.json ec365638e9f2d0c9be0d7d45f058b5985a5f1ff7 data/armourandtoolsmod/recipes/blasting_deepslate_ruby_ore.json dbab236832da5fd5f08b6f1d6180cfe9f8efd6b9 data/armourandtoolsmod/recipes/blasting_deepslate_sapphire_ore.json @@ -226,6 +234,7 @@ d9ef585b752aeda863cdca3e139469359fb53126 data/armourandtoolsmod/recipes/blasting 6979c6ecfd06efa11535896c3c39455f2b70d545 data/armourandtoolsmod/recipes/blasting_graphite_leggings.json d0a2e50b965e216ffe4101faaa5a20b7e7e6227e data/armourandtoolsmod/recipes/blasting_graphite_ore.json 404478e2e1c735cbfd37280e7b6e87ca935df6ac data/armourandtoolsmod/recipes/blasting_graphite_shield.json +de28c31cbda03faee6881e077d26411fa22a3578 data/armourandtoolsmod/recipes/blasting_imperium_ore.json a169e362521aa2c9c066e8a528f92dd202bda6b5 data/armourandtoolsmod/recipes/blasting_rainbow_boots.json 3761490c5e09279ecbe6053bbd81e46430c3e658 data/armourandtoolsmod/recipes/blasting_rainbow_chestplate.json 8251b2695c495f4c51b1de507d5ae5b00d7b93d5 data/armourandtoolsmod/recipes/blasting_rainbow_helmet.json @@ -235,6 +244,7 @@ a065ed2a7a56e9ea420c348d6f8480a7eb378822 data/armourandtoolsmod/recipes/blasting 2df433ab712f2619ac6544628563d43c1e1c598f data/armourandtoolsmod/recipes/blasting_raw_aqumarine.json 6ed3be5bb73f40fb06d4619c025cea285dde2459 data/armourandtoolsmod/recipes/blasting_raw_enderite.json d31238fe257d170f74f7f7708b8c728e6a7e762e data/armourandtoolsmod/recipes/blasting_raw_graphite.json +da6f6d87ee8748bbc580fc27a01c8ea04b309029 data/armourandtoolsmod/recipes/blasting_raw_imperium.json e39c39afebd3ce99c9706304b9cb1b8eb381c8e1 data/armourandtoolsmod/recipes/blasting_raw_rainbow.json fade1b6ad76c4069def6c17886b0a896b37ab71f data/armourandtoolsmod/recipes/blasting_raw_ruby.json a4fe178488bfda3b133388e0e8a7437d80da4f0b data/armourandtoolsmod/recipes/blasting_raw_sapphire.json @@ -280,6 +290,7 @@ adf63b0d9c8b2e333a5e4769a2fc0183f483544e data/armourandtoolsmod/recipes/graphite b790592cbe2e046b1e8169e2fb4a8da1483a8dfb data/armourandtoolsmod/recipes/graphite_shield.json aa31085980f2c7c3e8bad8a4dccb79315eac0102 data/armourandtoolsmod/recipes/imperium_pickaxe.json 9d9c3b5485306909e7c17e86c42d4afe8125c648 data/armourandtoolsmod/recipes/imperium_sword.json +eb7bc1fd278b7b1e16aab1d6068656a0b69c6d36 data/armourandtoolsmod/recipes/ingot_fusion_toll_enhancer_recipe.json dcadccfdd9e219de6e433b1b34cf5c1a20aaee73 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json 0399917d7fdda6f9af410c709805dfb149b2451c data/armourandtoolsmod/recipes/rainbow_block_recipe.json 5caa6184a7c066fac3bbc8e3869ae712171fe202 data/armourandtoolsmod/recipes/rainbow_boots.json @@ -314,6 +325,7 @@ e368772b68e458c259c10eb88b7d15869e726987 data/armourandtoolsmod/recipes/smelting 10f360754f4bfc21b8ca804e66e3b41601e49212 data/armourandtoolsmod/recipes/smelting_aqumarine_trident.json 4f2a03e74af293bb40015a711581026e6723019f data/armourandtoolsmod/recipes/smelting_deepslate_aqumarine_ore.json 24c6afe53017c4a31841a574c4af964fd4bb930f data/armourandtoolsmod/recipes/smelting_deepslate_graphite_ore.json +1499a4e882dba34f8c5d81dcf86d283715436df3 data/armourandtoolsmod/recipes/smelting_deepslate_imperium_ore.json ba5677fbec717e0c287b00ec96352b1976fcba44 data/armourandtoolsmod/recipes/smelting_deepslate_rainbow_ore.json 30d1489fc939d1043d93e8113d57bf540eb39acf data/armourandtoolsmod/recipes/smelting_deepslate_ruby_ore.json b7c6380a58e0367f331a4defccc9ac295ae18336 data/armourandtoolsmod/recipes/smelting_deepslate_sapphire_ore.json @@ -333,6 +345,7 @@ ff327dcaf31c429d8ea405828b42b53bb5409dfb data/armourandtoolsmod/recipes/smelting 92057c8adeb2fb7b55de20cc51a49f68d12bf839 data/armourandtoolsmod/recipes/smelting_graphite_leggings.json 10e97a407c586d2445dbcf0c258755e7218761e0 data/armourandtoolsmod/recipes/smelting_graphite_ore.json 397ad7fe2a5886b07a77b9ee078a282017c72db9 data/armourandtoolsmod/recipes/smelting_graphite_shield.json +4bd9d5766f8408bce46c1ef88e1f7db94bdf4dbd data/armourandtoolsmod/recipes/smelting_imperium_ore.json 18c59f9125fe3f99eafe536af6e5851f2a46f80b data/armourandtoolsmod/recipes/smelting_rainbow_boots.json 4f1606302fe518c5597af87088dbd502f4640331 data/armourandtoolsmod/recipes/smelting_rainbow_chestplate.json a0c5d53f8fc617b57cfd2fb46a61e2df860e889f data/armourandtoolsmod/recipes/smelting_rainbow_helmet.json @@ -342,6 +355,7 @@ a0c5d53f8fc617b57cfd2fb46a61e2df860e889f data/armourandtoolsmod/recipes/smelting 3a2956c7da9f50b32faae0b204eb54512df25d06 data/armourandtoolsmod/recipes/smelting_raw_aqumarine.json d8203ea8d54fa213f251890b3800bafeab5c2421 data/armourandtoolsmod/recipes/smelting_raw_enderite.json a79d0a8b02fc5f8edfbe3192dc50e45789610eec data/armourandtoolsmod/recipes/smelting_raw_graphite.json +150436abb9d1e31737a2ec5effa051264b9d41cf data/armourandtoolsmod/recipes/smelting_raw_imperium.json 52f9bade04ae8b6b2f59d33002b20b48f0496050 data/armourandtoolsmod/recipes/smelting_raw_rainbow.json bc318e30c5c19e3c590c397f0c3c4bc1600ba247 data/armourandtoolsmod/recipes/smelting_raw_ruby.json a7e04556a9cf920ab1640b4f3b0779ea05139e17 data/armourandtoolsmod/recipes/smelting_raw_sapphire.json diff --git a/src/generated/resources/.cache/b051adeca7b8303d1a7d46afb7c4eaf8cfa3a7f5 b/src/generated/resources/.cache/b051adeca7b8303d1a7d46afb7c4eaf8cfa3a7f5 index 3a1bb944..af1351ad 100644 --- a/src/generated/resources/.cache/b051adeca7b8303d1a7d46afb7c4eaf8cfa3a7f5 +++ b/src/generated/resources/.cache/b051adeca7b8303d1a7d46afb7c4eaf8cfa3a7f5 @@ -1,6 +1,7 @@ -// 1.20.1 2023-10-01T16:50:26.1358975 Tags for minecraft:item mod id armourandtoolsmod +// 1.20.1 2023-10-12T22:09:59.3186154 Tags for minecraft:item mod id armourandtoolsmod f4e0d28b203a60fd241885a727654636c8762650 data/forge/tags/items/deepslate_ores/aqumarine_ores.json 186e50e522fb2ae91c6e315a523523796b105b56 data/forge/tags/items/deepslate_ores/graphite_ores.json +08f48b19390eb9e06478f989851d261c8cb384a4 data/forge/tags/items/deepslate_ores/imperium_ores.json d66c065dfb98375b77835223afe692a26c7be84b data/forge/tags/items/deepslate_ores/rainbow_ores.json cd94fb683ebafe1cbde0ba3a30280d57b587fc34 data/forge/tags/items/deepslate_ores/ruby_ores.json 6a274e766194dfaf9c967be14c4b26a4ff637a8b data/forge/tags/items/deepslate_ores/sapphire_ores.json @@ -14,6 +15,7 @@ a9e8b31cf275be39ab498638115ee072f1c88065 data/forge/tags/items/ingots/ruby.json 1372356eb4655b6d26d8a5a16aaa3032bbb738d4 data/forge/tags/items/ores/aqumarine_ores.json fef5965e3903fc07aa6146bd17e74efd9b313fb6 data/forge/tags/items/ores/enderite_ores.json 974c70b44df044135463b300ebed43eee38001b3 data/forge/tags/items/ores/graphite_ores.json +e892786d477f668113418b8239abc7bb6395f33f data/forge/tags/items/ores/imperium_ores.json fa835a8b8eb217767d6139f02c46edfa27377555 data/forge/tags/items/ores/rainbow_ores.json f5b270d5c60fdfc53020be6469026c27bc742f1e data/forge/tags/items/ores/ruby_ores.json 47d725a30030287aa216532b38ba1d0774dd627f data/forge/tags/items/ores/sapphire_ores.json diff --git a/src/generated/resources/.cache/b437fe956183b85bad8f19eb71f021ad5d4a1455 b/src/generated/resources/.cache/b437fe956183b85bad8f19eb71f021ad5d4a1455 index 0ea0e701..7154a2cb 100644 --- a/src/generated/resources/.cache/b437fe956183b85bad8f19eb71f021ad5d4a1455 +++ b/src/generated/resources/.cache/b437fe956183b85bad8f19eb71f021ad5d4a1455 @@ -1,10 +1,11 @@ -// 1.20.1 2023-10-12T09:56:56.1414719 Armour and Tools Mod Blockstates +// 1.20.1 2023-10-12T22:09:59.3306702 Armour and Tools Mod Blockstates 2e7a970f6d2f498e44c8111ab18365eb11feb9ec assets/armourandtoolsmod/blockstates/aqumarine_block.json 54fe09c01a2e09240df74b50d546d52a3f055d6c assets/armourandtoolsmod/blockstates/aqumarine_ore.json 14011b50d9bf8bbaeb041d4da1d2f0c5303ddef7 assets/armourandtoolsmod/blockstates/custom_armour_crafting_table.json 0f7b0db22ffb5c04bb3aaae00ebd07a8a5e7dc38 assets/armourandtoolsmod/blockstates/custom_tool_crafting_table.json 56cac7a7dc1b3cec4831e0489b6dfe8c903ef239 assets/armourandtoolsmod/blockstates/deepslate_aqumarine_ore.json 6634c0b42d6703bfe41629eb8d2ae3aec5d8e53d assets/armourandtoolsmod/blockstates/deepslate_graphite_ore.json +58e8c4ac32b20cf87a4b886b6bab93f5d8519c94 assets/armourandtoolsmod/blockstates/deepslate_imperium_ore.json 4e30728c4657a667559406ef693e49fc8b099f1a assets/armourandtoolsmod/blockstates/deepslate_rainbow_ore.json 3747e8ebc1746317f633e2c899e2d941f094734e assets/armourandtoolsmod/blockstates/deepslate_ruby_ore.json c8512e5a03eec24140e6961b05767d6ef0fb4177 assets/armourandtoolsmod/blockstates/deepslate_sapphire_ore.json @@ -12,6 +13,7 @@ c8512e5a03eec24140e6961b05767d6ef0fb4177 assets/armourandtoolsmod/blockstates/de dd94bac512b66e6bfc7167e1efd6d19e7603cfbd assets/armourandtoolsmod/blockstates/enderite_ore.json 5e08334bf3b4305ed8c8e5bd49e7ddb3181ef482 assets/armourandtoolsmod/blockstates/graphite_block.json 4bedced77b9f7a7387a64bf8343ddb0f38b630c0 assets/armourandtoolsmod/blockstates/graphite_ore.json +b2e20f5a5036e9fb9be6f4b63609c9c4aa1ba371 assets/armourandtoolsmod/blockstates/imperium_ore.json d950e01376c01d6fdc91a8d6de6eb3ae179fb075 assets/armourandtoolsmod/blockstates/ingot_fusion_toll_enhancer.json a7fc4d7c5702aac2d7d8dde4cdf85761bc17b328 assets/armourandtoolsmod/blockstates/rainbow_block.json 2ee63bda3f405985ced49a0bb440757d4604bf50 assets/armourandtoolsmod/blockstates/rainbow_ore.json @@ -25,6 +27,7 @@ abf3538b38a6074395bd2b434de9ceaff8fcf8f7 assets/armourandtoolsmod/models/block/c 17253f7906c2b7f44057bb55b7595b619a541e2d assets/armourandtoolsmod/models/block/custom_tool_crafting_table.json ce344ac7cf91a296e6b373259c1f33c4c37fd7a2 assets/armourandtoolsmod/models/block/deepslate_aqumarine_ore.json cb1cd47ef020a5b2b7d99feb10549348fcaf3087 assets/armourandtoolsmod/models/block/deepslate_graphite_ore.json +22a29840565ef94c3453f0be7fc28c4438c53055 assets/armourandtoolsmod/models/block/deepslate_imperium_ore.json d3e3c3b837a0ae320f97907cbe56f026668bf0ec assets/armourandtoolsmod/models/block/deepslate_rainbow_ore.json 823214b9303d01ca46cfe86e6e8a1fd2c2f7cc5f assets/armourandtoolsmod/models/block/deepslate_ruby_ore.json 128286da08fc8c25dbffe4987f64c6d94bbd7563 assets/armourandtoolsmod/models/block/deepslate_sapphire_ore.json @@ -32,6 +35,7 @@ b07323a775ec3f1763b3c962b5d88c90d99e75a9 assets/armourandtoolsmod/models/block/e 7ae33083e9abb3b737adcadb357b22a965235e11 assets/armourandtoolsmod/models/block/enderite_ore.json d7eebd8671ec4eebb5cca3e052d40e71adb5452d assets/armourandtoolsmod/models/block/graphite_block.json 963578bbc0213efb09abaeb28ef490575858a880 assets/armourandtoolsmod/models/block/graphite_ore.json +6276fea9ecc3de7e639dafbea5abb1f45cd13a93 assets/armourandtoolsmod/models/block/imperium_ore.json f4954b01aaf1b85248d6f52ec350a3ae63bfd9cb assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer.json f4954b01aaf1b85248d6f52ec350a3ae63bfd9cb assets/armourandtoolsmod/models/block/ingot_fusion_toll_enhancer_on.json 70b12befd6c2592923ec2034968ac0f2e25ea4c2 assets/armourandtoolsmod/models/block/rainbow_block.json @@ -46,6 +50,7 @@ c2b636566f927ee09b21b43ecc09ca52cc0a09b4 assets/armourandtoolsmod/models/item/aq 222c2e8476c5855a641b2ea5cd73e7bbfdeb31e8 assets/armourandtoolsmod/models/item/custom_tool_crafting_table.json d5f995b7d1f2e1efb8c548570e7df12eea351ca6 assets/armourandtoolsmod/models/item/deepslate_aqumarine_ore.json 7b80f30b63f3af5968e9ef014c83e0e0c7982016 assets/armourandtoolsmod/models/item/deepslate_graphite_ore.json +cdbeda258c6811ec3f233fecbfe929bb6df78b7a assets/armourandtoolsmod/models/item/deepslate_imperium_ore.json 8c1ee937187b027644772eab504d11a793cfe170 assets/armourandtoolsmod/models/item/deepslate_rainbow_ore.json 2db8dc2d5dac33d833edb3ffb7c3f91d6da03d45 assets/armourandtoolsmod/models/item/deepslate_ruby_ore.json 54ef792b4c0ac90bfa8cdf33e0defb137058d8e5 assets/armourandtoolsmod/models/item/deepslate_sapphire_ore.json @@ -53,6 +58,7 @@ d5f995b7d1f2e1efb8c548570e7df12eea351ca6 assets/armourandtoolsmod/models/item/de 0dcf9c375173535daa54cb002ae8322fa5f21ebb assets/armourandtoolsmod/models/item/enderite_ore.json 40d8fe283ae9334173aa5cb34c3fe2eff59c584a assets/armourandtoolsmod/models/item/graphite_block.json e968896fc4c6ac9c0abff1d23cc576138bdb9e46 assets/armourandtoolsmod/models/item/graphite_ore.json +ee6799e55699527939aecf85402b98b43dcb1bf4 assets/armourandtoolsmod/models/item/imperium_ore.json 16a5fd8223f64c59e32fc4f75dc55a986b03c4df assets/armourandtoolsmod/models/item/ingot_fusion_toll_enhancer.json 241bc326669ed4b6f05d6ccbb37070a46f5d83c8 assets/armourandtoolsmod/models/item/rainbow_block.json 33ba53e3ed9e948a872ab89715acbce1b22957dd assets/armourandtoolsmod/models/item/rainbow_ore.json diff --git a/src/generated/resources/.cache/c622617f6fabf890a00b9275cd5f643584a8a2c8 b/src/generated/resources/.cache/c622617f6fabf890a00b9275cd5f643584a8a2c8 index 901e3eac..a4874d9d 100644 --- a/src/generated/resources/.cache/c622617f6fabf890a00b9275cd5f643584a8a2c8 +++ b/src/generated/resources/.cache/c622617f6fabf890a00b9275cd5f643584a8a2c8 @@ -1,2 +1,2 @@ -// 1.20.1 2023-10-01T16:50:26.1493981 Languages: en_us -f9cb5563ca127b800a6e4df334e07f3117045ab9 assets/armourandtoolsmod/lang/en_us.json +// 1.20.1 2023-10-12T22:09:59.3296691 Languages: en_us +8b0152e07cd1a1ee30bf67cc31642c7f52bea792 assets/armourandtoolsmod/lang/en_us.json diff --git a/src/generated/resources/.cache/e5c5eb35b4ba40351ecb7d9f04c3527f2f5779b0 b/src/generated/resources/.cache/e5c5eb35b4ba40351ecb7d9f04c3527f2f5779b0 index c78bb369..642df838 100644 --- a/src/generated/resources/.cache/e5c5eb35b4ba40351ecb7d9f04c3527f2f5779b0 +++ b/src/generated/resources/.cache/e5c5eb35b4ba40351ecb7d9f04c3527f2f5779b0 @@ -1,4 +1,4 @@ -// 1.20.1 2023-09-24T20:24:31.0467546 Advancements +// 1.20.1 2023-10-12T22:09:59.3341749 Advancements 615aa58042c1c9ffe9d0ce52c4d2ff2fabafceeb data/armourandtoolsmod/advancements/aqumarine_armour.json c646a34402926a2fce2839d07d57bc89bbc36658 data/armourandtoolsmod/advancements/aqumarine_block.json 1640ef0ec6e127c1afe8e6b060ba29e844d3a9e9 data/armourandtoolsmod/advancements/aqumarine_ingot.json @@ -12,6 +12,9 @@ b08601bbad0cc8efe4d3845320f4088038e28d43 data/armourandtoolsmod/advancements/gra b19cf2c2995b5cccb13b120cf7f939e9da8846f0 data/armourandtoolsmod/advancements/graphite_block.json 36250e8d2c72bbd2777714185259135746a5322f data/armourandtoolsmod/advancements/graphite_ingot.json 9adf555b52ffdf629389ea55196ca5cd10282975 data/armourandtoolsmod/advancements/graphite_ore.json +6d78dca81e0426274ca9944db826df140d7558af data/armourandtoolsmod/advancements/imperium_ingot.json +14397bc6ac6b9cdb50cc33b5bffdd40d903c864f data/armourandtoolsmod/advancements/imperium_ore.json +f6a37c07879a2fd2d12fbe264861eb4cb6e50072 data/armourandtoolsmod/advancements/imperium_tools.json 5920445e4112df9049a32cfb9f64a6563f3f21ca data/armourandtoolsmod/advancements/rainbow_armour.json c823856ed4fd1c9cc14082a0e815cda7d7305692 data/armourandtoolsmod/advancements/rainbow_block.json 602389b3a613f86e1ae958a052e0635effb8ef6e data/armourandtoolsmod/advancements/rainbow_ingot.json diff --git a/src/generated/resources/assets/armourandtoolsmod/blockstates/deepslate_imperium_ore.json b/src/generated/resources/assets/armourandtoolsmod/blockstates/deepslate_imperium_ore.json new file mode 100644 index 00000000..784d38df --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/blockstates/deepslate_imperium_ore.json @@ -0,0 +1,7 @@ +{ + "variants": { + "": { + "model": "armourandtoolsmod:block/deepslate_imperium_ore" + } + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/blockstates/imperium_ore.json b/src/generated/resources/assets/armourandtoolsmod/blockstates/imperium_ore.json new file mode 100644 index 00000000..97e70f77 --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/blockstates/imperium_ore.json @@ -0,0 +1,7 @@ +{ + "variants": { + "": { + "model": "armourandtoolsmod:block/imperium_ore" + } + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/lang/en_us.json b/src/generated/resources/assets/armourandtoolsmod/lang/en_us.json index 74a267c4..6df21577 100644 --- a/src/generated/resources/assets/armourandtoolsmod/lang/en_us.json +++ b/src/generated/resources/assets/armourandtoolsmod/lang/en_us.json @@ -67,6 +67,7 @@ "block.armourandtoolsmod.custom_tool_crafting_table": "Custom Tool Crafting Table", "block.armourandtoolsmod.deepslate_aqumarine_ore": "Deepslate Aqumarine Ore", "block.armourandtoolsmod.deepslate_graphite_ore": "Deepslate Graphite Ore", + "block.armourandtoolsmod.deepslate_imperium_ore": "Deepslate Imperium Ore", "block.armourandtoolsmod.deepslate_rainbow_ore": "Deepslate Rainbow Ore", "block.armourandtoolsmod.deepslate_ruby_ore": "Deepslate Ruby Ore", "block.armourandtoolsmod.deepslate_sapphire_ore": "Deepslate Sapphire Ore", @@ -74,6 +75,7 @@ "block.armourandtoolsmod.enderite_ore": "Enderite Ore", "block.armourandtoolsmod.graphite_block": "Graphite Block", "block.armourandtoolsmod.graphite_ore": "Graphite Ore", + "block.armourandtoolsmod.imperium_ore": "Imperium Ore", "block.armourandtoolsmod.ingot_fusion_toll_enhancer": "Ingot Fusion Toll Enhancer", "block.armourandtoolsmod.rainbow_block": "Rainbow Block", "block.armourandtoolsmod.rainbow_ore": "Rainbow Ore", @@ -132,6 +134,7 @@ "item.armourandtoolsmod.raw_aqumarine": "Raw Aqumarine", "item.armourandtoolsmod.raw_enderite": "Raw Enderite", "item.armourandtoolsmod.raw_graphite": "Raw Graphite", + "item.armourandtoolsmod.raw_imperium": "Raw Imperium", "item.armourandtoolsmod.raw_rainbow": "Raw Rainbow", "item.armourandtoolsmod.raw_ruby": "Raw Ruby", "item.armourandtoolsmod.raw_sapphire": "Raw Sapphire", diff --git a/src/generated/resources/assets/armourandtoolsmod/models/block/deepslate_imperium_ore.json b/src/generated/resources/assets/armourandtoolsmod/models/block/deepslate_imperium_ore.json new file mode 100644 index 00000000..b9923dcc --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/block/deepslate_imperium_ore.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:block/cube_all", + "textures": { + "all": "armourandtoolsmod:block/deepslate_imperium_ore" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/models/block/imperium_ore.json b/src/generated/resources/assets/armourandtoolsmod/models/block/imperium_ore.json new file mode 100644 index 00000000..ff041df6 --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/block/imperium_ore.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:block/cube_all", + "textures": { + "all": "armourandtoolsmod:block/imperium_ore" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/models/item/deepslate_imperium_ore.json b/src/generated/resources/assets/armourandtoolsmod/models/item/deepslate_imperium_ore.json new file mode 100644 index 00000000..b66f135c --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/item/deepslate_imperium_ore.json @@ -0,0 +1,3 @@ +{ + "parent": "armourandtoolsmod:block/deepslate_imperium_ore" +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/models/item/imperium_ore.json b/src/generated/resources/assets/armourandtoolsmod/models/item/imperium_ore.json new file mode 100644 index 00000000..60246089 --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/item/imperium_ore.json @@ -0,0 +1,3 @@ +{ + "parent": "armourandtoolsmod:block/imperium_ore" +} \ No newline at end of file diff --git a/src/generated/resources/assets/armourandtoolsmod/models/item/raw_imperium.json b/src/generated/resources/assets/armourandtoolsmod/models/item/raw_imperium.json new file mode 100644 index 00000000..5f09da7b --- /dev/null +++ b/src/generated/resources/assets/armourandtoolsmod/models/item/raw_imperium.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "armourandtoolsmod:item/raw_imperium" + } +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/imperium_ingot.json b/src/generated/resources/data/armourandtoolsmod/advancements/imperium_ingot.json new file mode 100644 index 00000000..621ec00f --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/imperium_ingot.json @@ -0,0 +1,36 @@ +{ + "parent": "armourandtoolsmod:imperium_ore", + "criteria": { + "get_scrap": { + "conditions": { + "items": [ + { + "tag": "forge:ingots/imperium" + } + ] + }, + "trigger": "minecraft:inventory_changed" + } + }, + "display": { + "announce_to_chat": true, + "description": { + "translate": "advancements.armourandtoolsmod.imperium_ingot.description" + }, + "frame": "goal", + "hidden": false, + "icon": { + "item": "armourandtoolsmod:imperium" + }, + "show_toast": true, + "title": { + "translate": "advancements.armourandtoolsmod.imperium_ingot.title" + } + }, + "requirements": [ + [ + "get_scrap" + ] + ], + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/advancements/imperium_ore.json new file mode 100644 index 00000000..b16252f8 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/imperium_ore.json @@ -0,0 +1,36 @@ +{ + "parent": "armourandtoolsmod:root", + "criteria": { + "get_ore": { + "conditions": { + "items": [ + { + "tag": "forge:ores/imperium_ores" + } + ] + }, + "trigger": "minecraft:inventory_changed" + } + }, + "display": { + "announce_to_chat": true, + "description": { + "translate": "advancements.armourandtoolsmod.imperium_ore.description" + }, + "frame": "goal", + "hidden": false, + "icon": { + "item": "armourandtoolsmod:imperium_ore" + }, + "show_toast": true, + "title": { + "translate": "advancements.armourandtoolsmod.imperium_ore.title" + } + }, + "requirements": [ + [ + "get_ore" + ] + ], + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/imperium_tools.json b/src/generated/resources/data/armourandtoolsmod/advancements/imperium_tools.json new file mode 100644 index 00000000..c36528d5 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/imperium_tools.json @@ -0,0 +1,52 @@ +{ + "parent": "armourandtoolsmod:imperium_ingot", + "criteria": { + "imperium_pickaxe": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:imperium_pickaxe" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "imperium_sword": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:imperium_sword" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + } + }, + "display": { + "announce_to_chat": true, + "description": { + "translate": "advancements.armourandtoolsmod.imperium_tools.description" + }, + "frame": "goal", + "hidden": false, + "icon": { + "item": "armourandtoolsmod:imperium_sword", + "nbt": "{Damage:0}" + }, + "show_toast": true, + "title": { + "translate": "advancements.armourandtoolsmod.imperium_tools.title" + } + }, + "requirements": [ + [ + "imperium_sword", + "imperium_pickaxe" + ] + ], + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/building_blocks/ingot_fusion_toll_enhancer_recipe.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/building_blocks/ingot_fusion_toll_enhancer_recipe.json new file mode 100644 index 00000000..a630d59b --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/building_blocks/ingot_fusion_toll_enhancer_recipe.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "minecraft:iron_ingot" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:ingot_fusion_toll_enhancer_recipe" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:ingot_fusion_toll_enhancer_recipe" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_deepslate_imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_deepslate_imperium_ore.json new file mode 100644 index 00000000..ea363cc3 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_deepslate_imperium_ore.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:deepslate_imperium_ore" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:blasting_deepslate_imperium_ore" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:blasting_deepslate_imperium_ore" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_ore.json new file mode 100644 index 00000000..7112e274 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_ore.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:imperium_ore" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:blasting_imperium_ore" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:blasting_imperium_ore" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_imperium.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_imperium.json new file mode 100644 index 00000000..a093240f --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_raw_imperium.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:raw_imperium" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:blasting_raw_imperium" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:blasting_raw_imperium" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_deepslate_imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_deepslate_imperium_ore.json new file mode 100644 index 00000000..1db228cf --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_deepslate_imperium_ore.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:deepslate_imperium_ore" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:smelting_deepslate_imperium_ore" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:smelting_deepslate_imperium_ore" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_ore.json new file mode 100644 index 00000000..5a1dd1d9 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_ore.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:imperium_ore" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:smelting_imperium_ore" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:smelting_imperium_ore" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_imperium.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_imperium.json new file mode 100644 index 00000000..2cc5922d --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_raw_imperium.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:raw_imperium" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:smelting_raw_imperium" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:smelting_raw_imperium" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/deepslate_imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/deepslate_imperium_ore.json new file mode 100644 index 00000000..29e72189 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/deepslate_imperium_ore.json @@ -0,0 +1,50 @@ +{ + "type": "minecraft:block", + "pools": [ + { + "bonus_rolls": 0.0, + "entries": [ + { + "type": "minecraft:alternatives", + "children": [ + { + "type": "minecraft:item", + "conditions": [ + { + "condition": "minecraft:match_tool", + "predicate": { + "enchantments": [ + { + "enchantment": "minecraft:silk_touch", + "levels": { + "min": 1 + } + } + ] + } + } + ], + "name": "armourandtoolsmod:deepslate_imperium_ore" + }, + { + "type": "minecraft:item", + "functions": [ + { + "enchantment": "minecraft:fortune", + "formula": "minecraft:ore_drops", + "function": "minecraft:apply_bonus" + }, + { + "function": "minecraft:explosion_decay" + } + ], + "name": "armourandtoolsmod:raw_imperium" + } + ] + } + ], + "rolls": 1.0 + } + ], + "random_sequence": "armourandtoolsmod:blocks/deepslate_imperium_ore" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/imperium_ore.json new file mode 100644 index 00000000..af420eef --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/loot_tables/blocks/imperium_ore.json @@ -0,0 +1,50 @@ +{ + "type": "minecraft:block", + "pools": [ + { + "bonus_rolls": 0.0, + "entries": [ + { + "type": "minecraft:alternatives", + "children": [ + { + "type": "minecraft:item", + "conditions": [ + { + "condition": "minecraft:match_tool", + "predicate": { + "enchantments": [ + { + "enchantment": "minecraft:silk_touch", + "levels": { + "min": 1 + } + } + ] + } + } + ], + "name": "armourandtoolsmod:imperium_ore" + }, + { + "type": "minecraft:item", + "functions": [ + { + "enchantment": "minecraft:fortune", + "formula": "minecraft:ore_drops", + "function": "minecraft:apply_bonus" + }, + { + "function": "minecraft:explosion_decay" + } + ], + "name": "armourandtoolsmod:raw_imperium" + } + ] + } + ], + "rolls": 1.0 + } + ], + "random_sequence": "armourandtoolsmod:blocks/imperium_ore" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/blasting_deepslate_imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/recipes/blasting_deepslate_imperium_ore.json new file mode 100644 index 00000000..99be0324 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/blasting_deepslate_imperium_ore.json @@ -0,0 +1,9 @@ +{ + "type": "minecraft:blasting", + "cookingtime": 300, + "experience": 0.6, + "ingredient": { + "item": "armourandtoolsmod:deepslate_imperium_ore" + }, + "result": "armourandtoolsmod:imperium" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_ore.json new file mode 100644 index 00000000..8676bd9e --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_ore.json @@ -0,0 +1,9 @@ +{ + "type": "minecraft:blasting", + "cookingtime": 300, + "experience": 0.6, + "ingredient": { + "item": "armourandtoolsmod:imperium_ore" + }, + "result": "armourandtoolsmod:imperium" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/blasting_raw_imperium.json b/src/generated/resources/data/armourandtoolsmod/recipes/blasting_raw_imperium.json new file mode 100644 index 00000000..50607db5 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/blasting_raw_imperium.json @@ -0,0 +1,9 @@ +{ + "type": "minecraft:blasting", + "cookingtime": 300, + "experience": 0.6, + "ingredient": { + "item": "armourandtoolsmod:raw_imperium" + }, + "result": "armourandtoolsmod:imperium" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ingot_fusion_toll_enhancer_recipe.json b/src/generated/resources/data/armourandtoolsmod/recipes/ingot_fusion_toll_enhancer_recipe.json new file mode 100644 index 00000000..01461a08 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ingot_fusion_toll_enhancer_recipe.json @@ -0,0 +1,24 @@ +{ + "type": "minecraft:crafting_shaped", + "category": "building", + "key": { + "A": { + "item": "minecraft:iron_block" + }, + "B": { + "item": "minecraft:iron_ingot" + }, + "C": { + "tag": "minecraft:base_stone_overworld" + } + }, + "pattern": [ + "ABA", + "CBC", + "CBC" + ], + "result": { + "item": "armourandtoolsmod:ingot_fusion_toll_enhancer" + }, + "show_notification": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/smelting_deepslate_imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/recipes/smelting_deepslate_imperium_ore.json new file mode 100644 index 00000000..639c21fb --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/smelting_deepslate_imperium_ore.json @@ -0,0 +1,9 @@ +{ + "type": "minecraft:smelting", + "cookingtime": 300, + "experience": 0.6, + "ingredient": { + "item": "armourandtoolsmod:deepslate_imperium_ore" + }, + "result": "armourandtoolsmod:imperium" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_ore.json new file mode 100644 index 00000000..c3c64141 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_ore.json @@ -0,0 +1,9 @@ +{ + "type": "minecraft:smelting", + "cookingtime": 300, + "experience": 0.6, + "ingredient": { + "item": "armourandtoolsmod:imperium_ore" + }, + "result": "armourandtoolsmod:imperium" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/smelting_raw_imperium.json b/src/generated/resources/data/armourandtoolsmod/recipes/smelting_raw_imperium.json new file mode 100644 index 00000000..a1529ab1 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/smelting_raw_imperium.json @@ -0,0 +1,9 @@ +{ + "type": "minecraft:smelting", + "cookingtime": 300, + "experience": 0.6, + "ingredient": { + "item": "armourandtoolsmod:raw_imperium" + }, + "result": "armourandtoolsmod:imperium" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/worldgen/configured_feature/imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/worldgen/configured_feature/imperium_ore.json new file mode 100644 index 00000000..01991ce4 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/worldgen/configured_feature/imperium_ore.json @@ -0,0 +1,18 @@ +{ + "type": "minecraft:ore", + "config": { + "discard_chance_on_air_exposure": 0.0, + "size": 4, + "targets": [ + { + "state": { + "Name": "armourandtoolsmod:imperium_ore" + }, + "target": { + "block": "minecraft:netherrack", + "predicate_type": "minecraft:block_match" + } + } + ] + } +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/worldgen/placed_feature/imperium_ore.json b/src/generated/resources/data/armourandtoolsmod/worldgen/placed_feature/imperium_ore.json new file mode 100644 index 00000000..00bf7750 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/worldgen/placed_feature/imperium_ore.json @@ -0,0 +1,27 @@ +{ + "feature": "armourandtoolsmod:imperium_ore", + "placement": [ + { + "type": "minecraft:count", + "count": 4 + }, + { + "type": "minecraft:in_square" + }, + { + "type": "minecraft:height_range", + "height": { + "type": "minecraft:uniform", + "max_inclusive": { + "absolute": 50 + }, + "min_inclusive": { + "absolute": -64 + } + } + }, + { + "type": "minecraft:biome" + } + ] +} \ No newline at end of file diff --git a/src/generated/resources/data/forge/tags/blocks/deepslate_ores/imperium_ores.json b/src/generated/resources/data/forge/tags/blocks/deepslate_ores/imperium_ores.json new file mode 100644 index 00000000..7f57287f --- /dev/null +++ b/src/generated/resources/data/forge/tags/blocks/deepslate_ores/imperium_ores.json @@ -0,0 +1,5 @@ +{ + "values": [ + "armourandtoolsmod:deepslate_imperium_ore" + ] +} \ No newline at end of file diff --git a/src/generated/resources/data/forge/tags/blocks/ores/imperium_ores.json b/src/generated/resources/data/forge/tags/blocks/ores/imperium_ores.json new file mode 100644 index 00000000..1aff1254 --- /dev/null +++ b/src/generated/resources/data/forge/tags/blocks/ores/imperium_ores.json @@ -0,0 +1,5 @@ +{ + "values": [ + "armourandtoolsmod:imperium_ore" + ] +} \ No newline at end of file diff --git a/src/generated/resources/data/forge/tags/items/deepslate_ores/imperium_ores.json b/src/generated/resources/data/forge/tags/items/deepslate_ores/imperium_ores.json new file mode 100644 index 00000000..7f57287f --- /dev/null +++ b/src/generated/resources/data/forge/tags/items/deepslate_ores/imperium_ores.json @@ -0,0 +1,5 @@ +{ + "values": [ + "armourandtoolsmod:deepslate_imperium_ore" + ] +} \ No newline at end of file diff --git a/src/generated/resources/data/forge/tags/items/ores/imperium_ores.json b/src/generated/resources/data/forge/tags/items/ores/imperium_ores.json new file mode 100644 index 00000000..1aff1254 --- /dev/null +++ b/src/generated/resources/data/forge/tags/items/ores/imperium_ores.json @@ -0,0 +1,5 @@ +{ + "values": [ + "armourandtoolsmod:imperium_ore" + ] +} \ No newline at end of file diff --git a/src/generated/resources/data/minecraft/tags/blocks/mineable/pickaxe.json b/src/generated/resources/data/minecraft/tags/blocks/mineable/pickaxe.json index d1e31e21..f4b6772a 100644 --- a/src/generated/resources/data/minecraft/tags/blocks/mineable/pickaxe.json +++ b/src/generated/resources/data/minecraft/tags/blocks/mineable/pickaxe.json @@ -12,11 +12,13 @@ "armourandtoolsmod:graphite_ore", "armourandtoolsmod:aqumarine_ore", "armourandtoolsmod:enderite_ore", + "armourandtoolsmod:imperium_ore", "armourandtoolsmod:deepslate_ruby_ore", "armourandtoolsmod:deepslate_rainbow_ore", "armourandtoolsmod:deepslate_sapphire_ore", "armourandtoolsmod:deepslate_graphite_ore", "armourandtoolsmod:deepslate_aqumarine_ore", + "armourandtoolsmod:deepslate_imperium_ore", "armourandtoolsmod:custom_armour_crafting_table", "armourandtoolsmod:custom_tool_crafting_table", "armourandtoolsmod:ingot_fusion_toll_enhancer", diff --git a/src/generated/resources/data/minecraft/tags/blocks/needs_iron_tool.json b/src/generated/resources/data/minecraft/tags/blocks/needs_iron_tool.json index 4fc36c66..0cf50ab7 100644 --- a/src/generated/resources/data/minecraft/tags/blocks/needs_iron_tool.json +++ b/src/generated/resources/data/minecraft/tags/blocks/needs_iron_tool.json @@ -1,7 +1,9 @@ { "values": [ "armourandtoolsmod:ruby_ore", + "armourandtoolsmod:imperium_ore", "armourandtoolsmod:deepslate_ruby_ore", + "armourandtoolsmod:deepslate_imperium_ore", "armourandtoolsmod:ruby_block" ] } \ No newline at end of file diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/BlockInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/BlockInit.kt index e9e19211..e9a29ae6 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/BlockInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/BlockInit.kt @@ -90,6 +90,13 @@ object BlockInit { BlockBehaviour.Properties.copy(Blocks.DIAMOND_ORE).requiresCorrectToolForDrops(), MinableBlockType.DIAMOND_PICKAXE) + val IMPERIUM_ORE = + registerSmeltAbleBlock( + "imperium_ore", + ItemInit.IMPERIUM, + BlockBehaviour.Properties.copy(Blocks.IRON_ORE).requiresCorrectToolForDrops(), + MinableBlockType.IRON_PICKAXE) + // deepslate ores val DEEPSLATE_RUBY_ORE = registerSpecialSmeltAbleBlock( @@ -125,6 +132,13 @@ object BlockInit { .requiresCorrectToolForDrops(), MinableBlockType.DIAMOND_PICKAXE) + val DEEPSLATE_IMPERIUM_ORE = + registerSmeltAbleBlock( + "deepslate_imperium_ore", + ItemInit.IMPERIUM, + BlockBehaviour.Properties.copy(Blocks.DEEPSLATE_IRON_ORE).requiresCorrectToolForDrops(), + MinableBlockType.IRON_PICKAXE) + // blocks val RUBY_BLOCK = registerOreBlock( diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt index bb983099..33475d2b 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt @@ -66,6 +66,8 @@ object ItemInit { ITEMS.registerSmeltableObject("raw_rainbow", RAINBOW) { Item(Item.Properties()) } val RAW_ENDERITE: ObjectHolderDelegate = ITEMS.registerSmeltableObject("raw_enderite", ENDERITE) { Item(Item.Properties()) } + val RAW_IMPERIUM: ObjectHolderDelegate = + ITEMS.registerSmeltableObject("raw_imperium", IMPERIUM) { Item(Item.Properties()) } // armour val AMETHYST_HELMET: ObjectHolderDelegate = diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/TagsInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/TagsInit.kt index 70493c5c..840e5ad9 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/TagsInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/TagsInit.kt @@ -53,6 +53,11 @@ object TagsInit { ResourceLocation.tryParse("forge:ores/enderite_ores")?.let { BlockTags.create(it) } ?: throw Exception("Failed to create tag") + val ORES_IMPERIUM: TagKey = + ResourceLocation.tryParse("forge:ores/imperium_ores")?.let { BlockTags.create(it) } + ?: throw Exception("Failed to create tag") + + // deepslate ores val DEEPSLATE_ORES_RUBY: TagKey = ResourceLocation.tryParse("forge:deepslate_ores/ruby_ores")?.let { BlockTags.create(it) @@ -83,6 +88,13 @@ object TagsInit { } ?: throw Exception("Failed to create tag") + val DEEPSLATE_ORES_IMPERIUM: TagKey = + ResourceLocation.tryParse("forge:deepslate_ores/imperium_ores")?.let { + BlockTags.create(it) + } + ?: throw Exception("Failed to create tag") + + // storage blocks val STORAGE_RUBY = ResourceLocation.tryParse("forge:storage_blocks/ruby")?.let { BlockTags.create(it) } ?: throw Exception("Failed to create tag") @@ -141,6 +153,12 @@ object TagsInit { ResourceLocation.tryParse("forge:ores/enderite_ores") ?: throw Exception("Failed to create tag")) + val ORES_IMPERIUM: TagKey = + ItemTags.create( + ResourceLocation.tryParse("forge:ores/imperium_ores") + ?: throw Exception("Failed to create tag")) + + // deepslate ores val DEEPSLATE_ORES_RUBY: TagKey = ItemTags.create( ResourceLocation.tryParse("forge:deepslate_ores/ruby_ores") @@ -166,6 +184,12 @@ object TagsInit { ResourceLocation.tryParse("forge:deepslate_ores/aqumarine_ores") ?: throw Exception("Failed to create tag")) + val DEEPSLATE_ORES_IMPERIUM: TagKey = + ItemTags.create( + ResourceLocation.tryParse("forge:deepslate_ores/imperium_ores") + ?: throw Exception("Failed to create tag")) + + // storage blocks val STORAGE_RUBY: TagKey = ItemTags.create( ResourceLocation.tryParse("forge:storage_blocks/ruby") @@ -262,5 +286,10 @@ object TagsInit { ItemTags.create( ResourceLocation.tryParse("forge:scraps/enderite") ?: throw Exception("Failed to create tag")) + + val RAW_IMPERIUM: TagKey = + ItemTags.create( + ResourceLocation.tryParse("forge:scraps/imperium") + ?: throw Exception("Failed to create tag")) } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/advancment/Advancements.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/advancment/Advancements.kt index 923351fe..604e0128 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/advancment/Advancements.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/advancment/Advancements.kt @@ -561,5 +561,54 @@ class Advancements : ForgeAdvancementProvider.AdvancementGenerator { .addCriterion("enderite_hoe", getItem(ItemInit.ENDERITE_HOE.get())) .requirements(RequirementsStrategy.OR) .save(consumer, id("enderite_tools")) + + // Imperium + + val imperiumOre = + Advancement.Builder.advancement() + .parent(root) + .display( + BlockInit.IMPERIUM_ORE.get(), + title("imperium_ore"), + description("imperium_ore"), + null, + FrameType.GOAL, + true, + true, + false) + .addCriterion("get_ore", getItem(TagsInit.ItemTagsInit.ORES_IMPERIUM)) + .save(consumer, id("imperium_ore")) + + val imperiumIngot = + Advancement.Builder.advancement() + .parent(imperiumOre) + .display( + ItemInit.IMPERIUM.get(), + title("imperium_ingot"), + description("imperium_ingot"), + null, + FrameType.GOAL, + true, + true, + false) + .addCriterion("get_scrap", getItem(TagsInit.ItemTagsInit.INGOTS_IMPERIUM)) + .save(consumer, id("imperium_ingot")) + + Advancement.Builder.advancement() + .parent(imperiumIngot) + .display( + ItemInit.IMPERIUM_SWORD.get(), + title("imperium_tools"), + description("imperium_tools"), + null, + FrameType.GOAL, + true, + true, + false) + .addCriterion("imperium_sword", getItem(ItemInit.IMPERIUM_SWORD.get())) + .addCriterion("imperium_pickaxe", getItem(ItemInit.IMPERIUM_PICKAXE.get())) + // .addCriterion("imperium_axe", getItem(ItemInit.IMPERIUM_AXE.get())) + .requirements(RequirementsStrategy.OR) + .save(consumer, id("imperium_tools")) } } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/lang/ModEnLangProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/lang/ModEnLangProvider.kt index d0ffb9e2..9b171dce 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/lang/ModEnLangProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/lang/ModEnLangProvider.kt @@ -40,6 +40,7 @@ class ModEnLangProvider(gen: DataGenerator) : ModEnLangProviderSupport(gen, MOD_ addBlock(BlockInit.RAINBOW_ORE, "Rainbow Ore") addBlock(BlockInit.AQUMARINE_ORE, "Aqumarine Ore") addBlock(BlockInit.ENDERITE_ORE, "Enderite Ore") + addBlock(BlockInit.IMPERIUM_ORE, "Imperium Ore") // blocks addBlock(BlockInit.RUBY_BLOCK, "Ruby Block") @@ -55,6 +56,7 @@ class ModEnLangProvider(gen: DataGenerator) : ModEnLangProviderSupport(gen, MOD_ addBlock(BlockInit.DEEPSLATE_GRAPHITE_ORE, "Deepslate Graphite Ore") addBlock(BlockInit.DEEPSLATE_RAINBOW_ORE, "Deepslate Rainbow Ore") addBlock(BlockInit.DEEPSLATE_AQUMARINE_ORE, "Deepslate Aqumarine Ore") + addBlock(BlockInit.DEEPSLATE_IMPERIUM_ORE, "Deepslate Imperium Ore") // custom crafting tables addBlock(BlockInit.CUSTOM_ARMOUR_CRAFTING_TABLE, "Custom Armour Crafting Table") @@ -77,6 +79,7 @@ class ModEnLangProvider(gen: DataGenerator) : ModEnLangProviderSupport(gen, MOD_ addItem(ItemInit.RAW_RAINBOW, "Raw Rainbow") addItem(ItemInit.RAW_AQUMARINE, "Raw Aqumarine") addItem(ItemInit.RAW_ENDERITE, "Raw Enderite") + addItem(ItemInit.RAW_IMPERIUM, "Raw Imperium") // armor addItem(ItemInit.RUBY_HELMET, "Ruby Helmet") diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/loot/ModBlockLootTables.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/loot/ModBlockLootTables.kt index 8082d192..332449bd 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/loot/ModBlockLootTables.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/loot/ModBlockLootTables.kt @@ -50,6 +50,9 @@ class ModBlockLootTables : BlockLootSubProvider(setOf(), FeatureFlags.REGISTRY.a add( BlockInit.ENDERITE_ORE.get(), createOreDrop(BlockInit.ENDERITE_ORE.get(), ItemInit.RAW_ENDERITE.get())) + add( + BlockInit.IMPERIUM_ORE.get(), + createOreDrop(BlockInit.IMPERIUM_ORE.get(), ItemInit.RAW_IMPERIUM.get())) // deepslate ores add( @@ -67,6 +70,9 @@ class ModBlockLootTables : BlockLootSubProvider(setOf(), FeatureFlags.REGISTRY.a add( BlockInit.DEEPSLATE_AQUMARINE_ORE.get(), createOreDrop(BlockInit.DEEPSLATE_AQUMARINE_ORE.get(), ItemInit.RAW_AQUMARINE.get())) + add( + BlockInit.DEEPSLATE_IMPERIUM_ORE.get(), + createOreDrop(BlockInit.DEEPSLATE_IMPERIUM_ORE.get(), ItemInit.RAW_IMPERIUM.get())) // blocks dropSelf(BlockInit.RUBY_BLOCK.get()) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/NormalCraftingTableRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/NormalCraftingTableRecipeProvider.kt index 459f499f..ba225ee0 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/NormalCraftingTableRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/NormalCraftingTableRecipeProvider.kt @@ -26,6 +26,9 @@ import io.github.realyusufismail.realyusufismailcore.recipe.YusufShapelessRecipe import java.util.function.Consumer import net.minecraft.data.recipes.FinishedRecipe import net.minecraft.data.recipes.RecipeCategory +import net.minecraft.tags.BlockTags +import net.minecraft.tags.BlockTags.BASE_STONE_OVERWORLD +import net.minecraft.tags.ItemTags import net.minecraft.world.item.Items import net.minecraft.world.level.block.Blocks @@ -55,6 +58,17 @@ class NormalCraftingTableRecipeProvider( .unlockedBy("has_item", has(Items.IRON_PICKAXE)) .save(pWriter, modId("custom_tool_crafting_table_recipe")) + YusufShapedRecipeBuilder.shaped( + RecipeCategory.BUILDING_BLOCKS, BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()) + .define('A', Blocks.IRON_BLOCK) + .define('B', Items.IRON_INGOT) + .define('C', ItemTags.create(BlockTags.BASE_STONE_OVERWORLD.location)) + .pattern("ABA") + .pattern("CBC") + .pattern("CBC") + .unlockedBy("has_item", has(Items.IRON_INGOT)) + .save(pWriter, modId("ingot_fusion_toll_enhancer_recipe")) + addOreBlockRecipes() } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt index cd76ffcf..b7297513 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt @@ -203,6 +203,8 @@ class ToolCraftingTableRecipeProvider( .save(consumer, modId("amethyst_shovel")) // Imperium Tools + + // TODO: Add support for enchantments CustomToolCraftingTableRecipeBuilder.shaped( CustomToolsCraftingBookCategory.SWORD, RecipeCategory.TOOLS, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModBlockTagsProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModBlockTagsProvider.kt index 4d908cdd..3158da9c 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModBlockTagsProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModBlockTagsProvider.kt @@ -49,6 +49,8 @@ class ModBlockTagsProvider( tag(TagsInit.BlockTagsInit.ORES_GRAPHITE).add(BlockInit.GRAPHITE_ORE.get()) tag(TagsInit.BlockTagsInit.ORES_AQUMARINE).add(BlockInit.AQUMARINE_ORE.get()) tag(TagsInit.BlockTagsInit.ORES_ENDERITE).add(BlockInit.ENDERITE_ORE.get()) + tag(TagsInit.BlockTagsInit.ORES_IMPERIUM).add(BlockInit.IMPERIUM_ORE.get()) + // deepslate ores tag(TagsInit.BlockTagsInit.DEEPSLATE_ORES_RUBY).add(BlockInit.DEEPSLATE_RUBY_ORE.get()) tag(TagsInit.BlockTagsInit.DEEPSLATE_ORES_RAINBOW) @@ -59,6 +61,9 @@ class ModBlockTagsProvider( .add(BlockInit.DEEPSLATE_GRAPHITE_ORE.get()) tag(TagsInit.BlockTagsInit.DEEPSLATE_ORES_AQUMARINE) .add(BlockInit.DEEPSLATE_AQUMARINE_ORE.get()) + tag(TagsInit.BlockTagsInit.DEEPSLATE_ORES_IMPERIUM) + .add(BlockInit.DEEPSLATE_IMPERIUM_ORE.get()) + // storage blocks tag(TagsInit.BlockTagsInit.STORAGE_RUBY).add(BlockInit.RUBY_BLOCK.get()) tag(TagsInit.BlockTagsInit.STORAGE_RAINBOW).add(BlockInit.RAINBOW_BLOCK.get()) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModItemTagsProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModItemTagsProvider.kt index f7c54d93..93efac25 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModItemTagsProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/tags/ModItemTagsProvider.kt @@ -49,6 +49,8 @@ class ModItemTagsProvider( copy(TagsInit.BlockTagsInit.ORES_GRAPHITE, TagsInit.ItemTagsInit.ORES_GRAPHITE) copy(TagsInit.BlockTagsInit.ORES_AQUMARINE, TagsInit.ItemTagsInit.ORES_AQUMARINE) copy(TagsInit.BlockTagsInit.ORES_ENDERITE, TagsInit.ItemTagsInit.ORES_ENDERITE) + copy(TagsInit.BlockTagsInit.ORES_IMPERIUM, TagsInit.ItemTagsInit.ORES_IMPERIUM) + // deepslate ores copy(TagsInit.BlockTagsInit.DEEPSLATE_ORES_RUBY, TagsInit.ItemTagsInit.DEEPSLATE_ORES_RUBY) copy( @@ -63,6 +65,10 @@ class ModItemTagsProvider( copy( TagsInit.BlockTagsInit.DEEPSLATE_ORES_AQUMARINE, TagsInit.ItemTagsInit.DEEPSLATE_ORES_AQUMARINE) + copy( + TagsInit.BlockTagsInit.DEEPSLATE_ORES_IMPERIUM, + TagsInit.ItemTagsInit.DEEPSLATE_ORES_IMPERIUM) + // storage blocks copy(TagsInit.BlockTagsInit.STORAGE_RUBY, TagsInit.ItemTagsInit.STORAGE_RUBY) copy(TagsInit.BlockTagsInit.STORAGE_RAINBOW, TagsInit.ItemTagsInit.STORAGE_RAINBOW) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModBlockStateProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModBlockStateProvider.kt index 5b676bb4..b4c7e1f0 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModBlockStateProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModBlockStateProvider.kt @@ -42,11 +42,17 @@ class ModBlockStateProvider(output: PackOutput, exFileHelper: ExistingFileHelper normalBlock(BlockInit.GRAPHITE_ORE.get()) normalBlock(BlockInit.AQUMARINE_ORE.get()) normalBlock(BlockInit.ENDERITE_ORE.get()) + normalBlock(BlockInit.IMPERIUM_ORE.get()) + + // deepslate ores normalBlock(BlockInit.DEEPSLATE_RUBY_ORE.get()) normalBlock(BlockInit.DEEPSLATE_RAINBOW_ORE.get()) normalBlock(BlockInit.DEEPSLATE_SAPPHIRE_ORE.get()) normalBlock(BlockInit.DEEPSLATE_GRAPHITE_ORE.get()) normalBlock(BlockInit.DEEPSLATE_AQUMARINE_ORE.get()) + normalBlock(BlockInit.DEEPSLATE_IMPERIUM_ORE.get()) + + // blocks normalBlock(BlockInit.RUBY_BLOCK.get()) normalBlock(BlockInit.RAINBOW_BLOCK.get()) normalBlock(BlockInit.SAPPHIRE_BLOCK.get()) @@ -54,6 +60,7 @@ class ModBlockStateProvider(output: PackOutput, exFileHelper: ExistingFileHelper normalBlock(BlockInit.AQUMARINE_BLOCK.get()) normalBlock(BlockInit.ENDERITE_BLOCK.get()) + // other customCraftingTable(BlockInit.CUSTOM_ARMOUR_CRAFTING_TABLE.get()) customCraftingTable(BlockInit.CUSTOM_TOOL_CRAFTING_TABLE.get()) orientableBlock(BlockInit.INGOT_FUSION_TOLL_ENHANCER.get()) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModItemStateProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModItemStateProvider.kt index edb655d9..39ad817b 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModItemStateProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/texture/ModItemStateProvider.kt @@ -52,6 +52,7 @@ class ModItemStateProvider(output: PackOutput, exFileHelper: ExistingFileHelper) item(ItemInit.RAW_AQUMARINE.get()) item(ItemInit.RAW_RAINBOW.get()) item(ItemInit.RAW_ENDERITE.get()) + item(ItemInit.RAW_IMPERIUM.get()) // armour item(ItemInit.AMETHYST_HELMET.get()) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/worldgen/ModConfiguredFeatures.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/worldgen/ModConfiguredFeatures.kt index cf9a3934..bdf4be1a 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/worldgen/ModConfiguredFeatures.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/worldgen/ModConfiguredFeatures.kt @@ -36,11 +36,15 @@ import net.minecraft.world.level.levelgen.structure.templatesystem.TagMatchTest object ModConfiguredFeatures { + // overworld val OVERWORLD_RUBY_ORE = registerKey("ruby_ore") val OVERWORLD_SAPPHIRE_ORE = registerKey("sapphire_ore") val OVERWORLD_GRAPHITE_ORE = registerKey("graphite_ore") val OVERWORLD_AQUMARINE_ORE = registerKey("aqumarine_ore") val OVERWORLD_RAINBOW_ORE = registerKey("rainbow_ore") + val OVERWORLD_IMPERIUM_ORE = registerKey("imperium_ore") + + // end val END_ENDERITE_ORE = registerKey("enderite_ore") fun bootstrap(context: BootstapContext>) { @@ -93,12 +97,18 @@ object ModConfiguredFeatures { OreConfiguration.target( endstoneReplaceables, BlockInit.ENDERITE_ORE.get().defaultBlockState())) + val imperium = + listOf( + OreConfiguration.target( + netherrackReplaceables, BlockInit.IMPERIUM_ORE.get().defaultBlockState())) + register(context, OVERWORLD_RUBY_ORE, Feature.ORE, OreConfiguration(ruby, 4)) register(context, OVERWORLD_SAPPHIRE_ORE, Feature.ORE, OreConfiguration(sapphire, 3)) register(context, OVERWORLD_GRAPHITE_ORE, Feature.ORE, OreConfiguration(graphite, 4)) register(context, OVERWORLD_AQUMARINE_ORE, Feature.ORE, OreConfiguration(aqumarine, 4)) register(context, OVERWORLD_RAINBOW_ORE, Feature.ORE, OreConfiguration(rainbow, 3)) register(context, END_ENDERITE_ORE, Feature.ORE, OreConfiguration(enderite, 4)) + register(context, OVERWORLD_IMPERIUM_ORE, Feature.ORE, OreConfiguration(imperium, 4)) } private fun registerKey(name: String): ResourceKey> { diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/worldgen/ModPlacedFeatures.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/worldgen/ModPlacedFeatures.kt index 1c16cb69..6f29e58d 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/worldgen/ModPlacedFeatures.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/worldgen/ModPlacedFeatures.kt @@ -38,6 +38,7 @@ object ModPlacedFeatures { val AQUMARINE_ORE: ResourceKey = createKey("aqumarine_ore") val RAINBOW_ORE: ResourceKey = createKey("rainbow_ore") val ENDERITE_ORE: ResourceKey = createKey("enderite_ore") + val IMPERIUM_ORE: ResourceKey = createKey("imperium_ore") fun bootstrap(context: BootstapContext) { val configuredFeatures = context.lookup(Registries.CONFIGURED_FEATURE) @@ -54,6 +55,8 @@ object ModPlacedFeatures { configuredFeatures.getOrThrow(ModConfiguredFeatures.OVERWORLD_RAINBOW_ORE) val holder6: Holder> = configuredFeatures.getOrThrow(ModConfiguredFeatures.END_ENDERITE_ORE) + val holder7: Holder> = + configuredFeatures.getOrThrow(ModConfiguredFeatures.OVERWORLD_IMPERIUM_ORE) register( context, @@ -108,6 +111,15 @@ object ModPlacedFeatures { 4, HeightRangePlacement.uniform( VerticalAnchor.absolute(-64), VerticalAnchor.absolute(40)))) + + register( + context, + IMPERIUM_ORE, + holder7, + ModOrePlacement.commonOrePlacement( + 4, + HeightRangePlacement.uniform( + VerticalAnchor.absolute(-64), VerticalAnchor.absolute(50)))) } private fun createKey(name: String): ResourceKey { diff --git a/src/main/resources/assets/armourandtoolsmod/textures/block/deepslate_imperium_ore.png b/src/main/resources/assets/armourandtoolsmod/textures/block/deepslate_imperium_ore.png new file mode 100644 index 0000000000000000000000000000000000000000..783987d26ae1243d9380899dce7ea03ed37573ad GIT binary patch literal 600 zcmV-e0;m0nP)KmE6ox+v43&^2bbwH%!cZJ3QlboHNl;XlDjO^rvtWr# zS+Y2L#KMxvNU(ITVC~YSbKChMAtw_;u}_XHR!WD%hv{v1_ujqtzyG_8>$;mD2vACq zUSSvm&}h`mSrQY5F{P3PKu$_Y7{thDxL=tT27nX)6=tQM=1poLPuBmespMp@4vbLRIUeb z3(l}dsieppA2&CaRWOgFTl_ix0q9`Bbor3a(_b#Ngv-m%07xkjLI5zTRsra`mN|RK z=i%**%H4#n+c5*q0R%z7bTH%f@dm0@-8L`j)vBq`a@qi_vTHraLp?}m*h49WWyO0eWX{jqn`Brg zS54~m15$$};kG&HY|H#+co zVBqO5mrN52eh9)!Py6y%vO#lBp m-(OI#A7I zAHaoz6e^?yFc5f)ECpwmmHfePetwdw>$=%{4?s~Ac<+fZ0$_|G#z+W(JkJvbptWYZ z-I57;nkKyWIOnj|B4Lb4BegCLKU)A! zzZ;A(sIKegd7hc3iTnMY+5ldXmv~VWjN=G^Iv$U+NR-}1NuKAFWtn_2#w4 zLkRTW-?U0$j7j7W0?s+caU_I5jFF-!$fPR3scpGb6#%=w=OlR35JI3;3S#8zugTu~ zXA2@(+!sXv!!V?`m|2!(!m_d~IsB;qGfQMIBZPpp7VmxXBJW-crq>uDMhdU%OpuRYEmQGd~^= zrfEWJ{UU$4y7C=kd|qMpJfjR?wOXYM6H<&Zt+8O@JivOrMr+L@S3j3^P6-_Egs-4xV2fz znJH%%QF+q0XJyKdm0Fx9MkE3NdEXbqfs3+xyzfBMY12WxuZUwSTHRzE7`bXa0CM<( z>OE~SkhR|p1%P;85!O{rGD^l3te<|-@Kd`)tBa8f7T93`V1YIuPOn`60Ne4}-Oh~A x)QqQ`kA3+E; Date: Thu, 12 Oct 2023 22:14:50 +0100 Subject: [PATCH 44/51] Removed statsinti --- .../armourandtoolsmod/ArmourAndToolsMod.kt | 1 - .../armourandtoolsmod/core/init/StatsInit.kt | 47 ------------------- 2 files changed, 48 deletions(-) delete mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/StatsInit.kt diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/ArmourAndToolsMod.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/ArmourAndToolsMod.kt index ddcab5b5..c62c3741 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/ArmourAndToolsMod.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/ArmourAndToolsMod.kt @@ -44,7 +44,6 @@ class ArmourAndToolsMod { EntityTypeInit.ENTITY_TYPES.register(bus) BlockEntityTypeInit.BLOCK_ENTITY_TYPES.register(bus) CreativeModeTabInit.CREATIVE_MODE_TAB.register(bus) - StatsInit.STATS.register(bus) // Register ourselves for server and other game events we are interested in // Register the data generators diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/StatsInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/StatsInit.kt deleted file mode 100644 index 877c1f4d..00000000 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/StatsInit.kt +++ /dev/null @@ -1,47 +0,0 @@ -/* - * Copyright 2023 RealYusufIsmail. - * - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * - * you may not use this file except in compliance with the License. - * - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package io.github.realyusufismail.armourandtoolsmod.core.init - -import io.github.realyusufismail.armourandtoolsmod.ArmourAndToolsMod -import net.minecraft.core.registries.Registries -import net.minecraft.resources.ResourceLocation -import net.minecraft.stats.StatFormatter -import net.minecraft.stats.Stats -import net.minecraftforge.registries.DeferredRegister -import net.minecraftforge.registries.RegistryObject - -object StatsInit { - val STATS = - DeferredRegister.create(Registries.CUSTOM_STAT, ArmourAndToolsMod.MOD_ID) - private val STAT_SETUP: MutableList = mutableListOf() - - private fun makeCustomStat(key: String): RegistryObject { - val resourceLocation: ResourceLocation = ArmourAndToolsMod.getModIdAndName(key) - STAT_SETUP.add(Runnable { Stats.CUSTOM.get(resourceLocation, StatFormatter.DEFAULT) }) - return STATS.register(key) { resourceLocation } - } - - @JvmField - val INTERACT_WITH_FUSION_TOLL_ENHANCER: RegistryObject = - makeCustomStat("interact_with_fusion_toll_enhancer") - - fun init() { - STAT_SETUP.forEach(Runnable::run) - } -} From 8be38cc3574566b080da16ebb47b7f1832484b08 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Thu, 12 Oct 2023 22:41:56 +0100 Subject: [PATCH 45/51] the format of the recipe is messed up --- CHANGELOG.md | 1 + .../armourandtoolsmod/client/ClientSetup.kt | 2 - .../ToolCraftingTableRecipeProvider.kt | 62 +++++++++++++++++++ ...ustomToolCraftingTableJEIRecipeCategory.kt | 29 ++++++--- 4 files changed, 83 insertions(+), 11 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f9975fd7..440ef6fc 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,7 @@ All notable changes to this project will be documented in this file. ### Added Ingot Fusion Enchanter (been in the works for a mont with more than two rewrites) : ### This allows you to upgrade certain items. Currently only works with the MAGMA_STRIKE_PICKAXE. More to come in future. ### Added imperium sword, pickaxe, axe, ingot and ore. More to come in the future. +### Added saphire tool recipes to the tool crafting table. ### Fixed some issues I came across while testing. ## [1.20.1-1.0.5] - 2023-09-26 diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt index 45f972f4..a610d8ed 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/client/ClientSetup.kt @@ -38,8 +38,6 @@ object ClientSetup { event.enqueueWork { registerScreens() } event.enqueueWork { - StatsInit.init() - ItemProperties.register(ItemInit.RUBY_SHIELD.get(), ResourceLocation("blocking")) { stack: ItemStack, _: ClientLevel?, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt index b7297513..845f9b71 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt @@ -93,6 +93,68 @@ class ToolCraftingTableRecipeProvider( .unlockedBy(hasItem, has(TagsInit.ItemTagsInit.INGOTS_RUBY)) .save(consumer, modId("ruby_hoe")) + // SAPPHIRE TOOLS + + CustomToolCraftingTableRecipeBuilder.shaped( + CustomToolsCraftingBookCategory.SWORD, + RecipeCategory.TOOLS, + ItemInit.SAPPHIRE_SWORD.get()) + .define('A', TagsInit.ItemTagsInit.INGOTS_SAPPHIRE) + .define('S', Items.STICK) + .pattern(" A ") + .pattern(" A ") + .pattern(" S ") + .unlockedBy(hasItem, has(TagsInit.ItemTagsInit.INGOTS_SAPPHIRE)) + .save(consumer, modId("sapphire_sword")) + + CustomToolCraftingTableRecipeBuilder.shaped( + CustomToolsCraftingBookCategory.PICKAXE, + RecipeCategory.TOOLS, + ItemInit.SAPPHIRE_PICKAXE.get()) + .define('A', TagsInit.ItemTagsInit.INGOTS_SAPPHIRE) + .define('S', Items.STICK) + .pattern("AAA") + .pattern(" S ") + .pattern(" S ") + .unlockedBy(hasItem, has(TagsInit.ItemTagsInit.INGOTS_SAPPHIRE)) + .save(consumer, modId("sapphire_pickaxe")) + + CustomToolCraftingTableRecipeBuilder.shaped( + CustomToolsCraftingBookCategory.AXE, + RecipeCategory.TOOLS, + ItemInit.SAPPHIRE_AXE.get()) + .define('A', TagsInit.ItemTagsInit.INGOTS_SAPPHIRE) + .define('S', Items.STICK) + .pattern(" AA") + .pattern(" SA") + .pattern(" S ") + .unlockedBy(hasItem, has(TagsInit.ItemTagsInit.INGOTS_SAPPHIRE)) + .save(consumer, modId("sapphire_axe")) + + CustomToolCraftingTableRecipeBuilder.shaped( + CustomToolsCraftingBookCategory.SHOVEL, + RecipeCategory.TOOLS, + ItemInit.SAPPHIRE_SHOVEL.get()) + .define('A', TagsInit.ItemTagsInit.INGOTS_SAPPHIRE) + .define('S', Items.STICK) + .pattern(" A ") + .pattern(" S ") + .pattern(" S ") + .unlockedBy(hasItem, has(TagsInit.ItemTagsInit.INGOTS_SAPPHIRE)) + .save(consumer, modId("sapphire_shovel")) + + CustomToolCraftingTableRecipeBuilder.shaped( + CustomToolsCraftingBookCategory.HOE, + RecipeCategory.TOOLS, + ItemInit.SAPPHIRE_HOE.get()) + .define('A', TagsInit.ItemTagsInit.INGOTS_SAPPHIRE) + .define('S', Items.STICK) + .pattern("AA ") + .pattern(" S ") + .pattern(" S ") + .unlockedBy(hasItem, has(TagsInit.ItemTagsInit.INGOTS_SAPPHIRE)) + .save(consumer, modId("sapphire_hoe")) + // ENDERITE TOOLS CustomToolCraftingTableRecipeBuilder.shaped( CustomToolsCraftingBookCategory.SWORD, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt index 6a04d46a..ee850156 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt @@ -69,15 +69,26 @@ class CustomToolCraftingTableJEIRecipeCategory(private val guiHelper: IGuiHelper recipe: CustomToolCraftingTableRecipe, focuses: IFocusGroup ) { - builder.addSlot(RecipeIngredientRole.INPUT, 30, 16).addIngredients(recipe.ingredients[0]) - builder.addSlot(RecipeIngredientRole.INPUT, 47, 16).addIngredients(recipe.ingredients[1]) - builder.addSlot(RecipeIngredientRole.INPUT, 65, 16).addIngredients(recipe.ingredients[2]) - builder.addSlot(RecipeIngredientRole.INPUT, 30, 34).addIngredients(recipe.ingredients[3]) - builder.addSlot(RecipeIngredientRole.INPUT, 48, 34).addIngredients(recipe.ingredients[4]) - builder.addSlot(RecipeIngredientRole.INPUT, 66, 34).addIngredients(recipe.ingredients[5]) - builder.addSlot(RecipeIngredientRole.INPUT, 30, 52).addIngredients(recipe.ingredients[6]) - builder.addSlot(RecipeIngredientRole.INPUT, 48, 52).addIngredients(recipe.ingredients[7]) - builder.addSlot(RecipeIngredientRole.INPUT, 66, 52).addIngredients(recipe.ingredients[8]) + val ingredients = recipe.ingredients + + // Define variables for each slot + val slots = + listOf( + builder.addSlot(RecipeIngredientRole.INPUT, 30, 16), + builder.addSlot(RecipeIngredientRole.INPUT, 48, 16), + builder.addSlot(RecipeIngredientRole.INPUT, 66, 16), + builder.addSlot(RecipeIngredientRole.INPUT, 30, 34), + builder.addSlot(RecipeIngredientRole.INPUT, 48, 34), + builder.addSlot(RecipeIngredientRole.INPUT, 66, 34), + builder.addSlot(RecipeIngredientRole.INPUT, 30, 52), + builder.addSlot(RecipeIngredientRole.INPUT, 48, 52), + builder.addSlot(RecipeIngredientRole.INPUT, 66, 52)) + + for (i in 0 until minOf(ingredients.size, slots.size)) { + if (!ingredients[i].isEmpty) { + slots[i].addIngredients(ingredients[i]) + } + } builder.addSlot(RecipeIngredientRole.OUTPUT, 124, 34).addItemStack(recipe.result) } From ea355163093f3b242107a063b20a5d8a44419027 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 13 Oct 2023 08:43:32 +0100 Subject: [PATCH 46/51] Added showNotification and HideFlags --- CHANGELOG.md | 3 +- .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 112 ++++++++++-------- .../recipes/tools/sapphire_axe.json | 33 ++++++ .../recipes/tools/sapphire_hoe.json | 33 ++++++ .../recipes/tools/sapphire_pickaxe.json | 33 ++++++ .../recipes/tools/sapphire_shovel.json | 33 ++++++ .../recipes/tools/sapphire_sword.json | 33 ++++++ .../recipes/amethyst_axe.json | 3 +- .../recipes/amethyst_boots.json | 3 +- .../recipes/amethyst_chestplate.json | 3 +- .../recipes/amethyst_helmet.json | 3 +- .../recipes/amethyst_leggings.json | 3 +- .../recipes/amethyst_pickaxe.json | 3 +- .../recipes/amethyst_shovel.json | 3 +- .../recipes/amethyst_sword.json | 3 +- .../recipes/aqumarine_boots.json | 3 +- .../recipes/aqumarine_chestplate.json | 3 +- .../recipes/aqumarine_helmet.json | 3 +- .../recipes/aqumarine_leggings.json | 3 +- .../recipes/aqumarine_shield.json | 14 ++- .../recipes/aqumarine_trident.json | 14 ++- .../recipes/enderite_axe.json | 3 +- .../recipes/enderite_boots.json | 3 +- .../recipes/enderite_chestplate.json | 3 +- .../recipes/enderite_helmet.json | 3 +- .../recipes/enderite_hoe.json | 3 +- .../recipes/enderite_leggings.json | 3 +- .../recipes/enderite_pickaxe.json | 3 +- .../recipes/enderite_shovel.json | 3 +- .../recipes/enderite_sword.json | 3 +- .../recipes/graphite_boots.json | 3 +- .../recipes/graphite_chestplate.json | 3 +- .../recipes/graphite_helmet.json | 3 +- .../recipes/graphite_leggings.json | 3 +- .../recipes/graphite_shield.json | 14 ++- .../recipes/imperium_pickaxe.json | 14 ++- .../recipes/imperium_sword.json | 14 ++- .../recipes/rainbow_boots.json | 3 +- .../recipes/rainbow_chestplate.json | 3 +- .../recipes/rainbow_helmet.json | 3 +- .../recipes/rainbow_leggings.json | 3 +- .../recipes/rainbow_shield.json | 14 ++- .../armourandtoolsmod/recipes/ruby_axe.json | 3 +- .../armourandtoolsmod/recipes/ruby_boots.json | 3 +- .../recipes/ruby_chestplate.json | 3 +- .../recipes/ruby_helmet.json | 3 +- .../armourandtoolsmod/recipes/ruby_hoe.json | 3 +- .../recipes/ruby_leggings.json | 3 +- .../recipes/ruby_pickaxe.json | 3 +- .../recipes/ruby_shield.json | 14 ++- .../recipes/ruby_shovel.json | 3 +- .../armourandtoolsmod/recipes/ruby_sword.json | 3 +- .../recipes/sapphire_axe.json | 21 ++++ .../recipes/sapphire_boots.json | 3 +- .../recipes/sapphire_chestplate.json | 3 +- .../recipes/sapphire_helmet.json | 3 +- .../recipes/sapphire_hoe.json | 21 ++++ .../recipes/sapphire_leggings.json | 3 +- .../recipes/sapphire_pickaxe.json | 21 ++++ .../recipes/sapphire_shield.json | 14 ++- .../recipes/sapphire_shovel.json | 21 ++++ .../recipes/sapphire_sword.json | 21 ++++ .../CustomArmourCraftingTableRecipeBuilder.kt | 50 +++++++- .../CustomToolCraftingTableRecipeBuilder.kt | 56 ++++++++- .../recipe/builder/EnchantmentsAndLevels.kt | 32 +++++ .../ToolCraftingTableRecipeProvider.kt | 3 + ...tomArmourCraftingTableJEIRecipeCategory.kt | 36 +++--- ...ustomToolCraftingTableJEIRecipeCategory.kt | 33 +++--- 68 files changed, 688 insertions(+), 145 deletions(-) create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_axe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_hoe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_pickaxe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_shovel.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_sword.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/sapphire_axe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/sapphire_hoe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/sapphire_pickaxe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/sapphire_shovel.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/sapphire_sword.json create mode 100644 src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/EnchantmentsAndLevels.kt diff --git a/CHANGELOG.md b/CHANGELOG.md index 440ef6fc..56b9f2a3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,7 +8,8 @@ All notable changes to this project will be documented in this file. ### This allows you to upgrade certain items. Currently only works with the MAGMA_STRIKE_PICKAXE. More to come in future. ### Added imperium sword, pickaxe, axe, ingot and ore. More to come in the future. ### Added saphire tool recipes to the tool crafting table. -### Fixed some issues I came across while testing. +### Fixed issue with JEI for custom crafting tables where some recipes were not showing. +### Fixed some other issues I came across while testing. ## [1.20.1-1.0.5] - 2023-09-26 diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index 1f7b3356..5341f441 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-12T22:09:59.3236154 Recipes +// 1.20.1 2023-10-13T08:40:08.7582656 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -188,23 +188,28 @@ e0a2d46e6a562d46dccc42eedcda00b89d3a7cd2 data/armourandtoolsmod/advancements/rec 3209f918eb86bebe3a16a1344863b0247ba31d6e data/armourandtoolsmod/advancements/recipes/tools/ruby_shield.json 8eb669e829e5a81651b5691926c209d16e317be4 data/armourandtoolsmod/advancements/recipes/tools/ruby_shovel.json afaa0f79973970a20fc6ad1a6b628e40e73b2ae7 data/armourandtoolsmod/advancements/recipes/tools/ruby_sword.json +b107aadcab847b199085f9c69083751eb7bf0a0b data/armourandtoolsmod/advancements/recipes/tools/sapphire_axe.json +c0d8469bd06d4576da46e02cc0dc15954ee859a7 data/armourandtoolsmod/advancements/recipes/tools/sapphire_hoe.json +25eca0fc984e510dae3aed27012f60df2b296eb9 data/armourandtoolsmod/advancements/recipes/tools/sapphire_pickaxe.json 406cfeb511bd6a34d4fcf0a30868e5fa7073bd25 data/armourandtoolsmod/advancements/recipes/tools/sapphire_shield.json +895e10ca5f689259a276802e07de278ba6682ead data/armourandtoolsmod/advancements/recipes/tools/sapphire_shovel.json +1296cd3603319a79a10046ebf6b9f0be618f1f9e data/armourandtoolsmod/advancements/recipes/tools/sapphire_sword.json ef7ef1d4b425916d8205de09e00227225687c9de data/armourandtoolsmod/advancements/recipes/tool/magma_strike_pickaxe.json -78da516c72de91179803d7068271bcde9500cee8 data/armourandtoolsmod/recipes/amethyst_axe.json -36968ac2704b6aba42cbae8bd74269a8ca416f6a data/armourandtoolsmod/recipes/amethyst_boots.json -f6ab1e0d36c50e07935b2072de4731f32e2b9c64 data/armourandtoolsmod/recipes/amethyst_chestplate.json -bea7ce15249ba10c57c55d5317f9ef7ba9690bc6 data/armourandtoolsmod/recipes/amethyst_helmet.json -b9fe5e028726e2d8f40af5057827f67b042bfd23 data/armourandtoolsmod/recipes/amethyst_leggings.json -c618893ff6ccca28aec74287c696afc2f7a86756 data/armourandtoolsmod/recipes/amethyst_pickaxe.json -51046fd173379c47970cbe62f4b7d42afd51695b data/armourandtoolsmod/recipes/amethyst_shovel.json -372b46fc4dde30b0f749b8887b9dc279e83826cc data/armourandtoolsmod/recipes/amethyst_sword.json +9cfe0a80df9637e4f0a594063ec9d3da5ae1ea92 data/armourandtoolsmod/recipes/amethyst_axe.json +37c59fcd7e6870869c09b655269118c12b6f58ae data/armourandtoolsmod/recipes/amethyst_boots.json +492c2c6866f720415ef3f69e5cb8019775939919 data/armourandtoolsmod/recipes/amethyst_chestplate.json +b5b33aef5c5fec332d41973c493fc81b43e2376a data/armourandtoolsmod/recipes/amethyst_helmet.json +57b0885c30518800891d6ef03e5a308471b9b57f data/armourandtoolsmod/recipes/amethyst_leggings.json +6067624d32108ef99773bafd255a5538a501c1dc data/armourandtoolsmod/recipes/amethyst_pickaxe.json +89ccba0ac32b5dc269cfcc38a1e6a7969cdd564c data/armourandtoolsmod/recipes/amethyst_shovel.json +98926a8d84ad7159793592a4cd4de67cbb47e696 data/armourandtoolsmod/recipes/amethyst_sword.json 1576f1a4728f4419a491d43ef95bd24c5396b1f5 data/armourandtoolsmod/recipes/aqumarine_block_recipe.json -2694ab0117a105b22ad8538756304a8b1a85177f data/armourandtoolsmod/recipes/aqumarine_boots.json -56c467a68cefbaba0f6fa802ddd58a3a5714aa94 data/armourandtoolsmod/recipes/aqumarine_chestplate.json -bf5789d99692fb32c86d6aec74abdf0d21dfa061 data/armourandtoolsmod/recipes/aqumarine_helmet.json -ba37b1887d6824c88a39f8dd7fae6f9e4caa544a data/armourandtoolsmod/recipes/aqumarine_leggings.json -28c662a1094ddf09d17102824038329b734f484c data/armourandtoolsmod/recipes/aqumarine_shield.json -f8df4ff77f201dad064bbc0de65898c32e2700c7 data/armourandtoolsmod/recipes/aqumarine_trident.json +52a469a10c2bc4ae10c4b8d19b51ca477cf94f96 data/armourandtoolsmod/recipes/aqumarine_boots.json +9dc8543b18e506463e212bf0d53df7b70937259d data/armourandtoolsmod/recipes/aqumarine_chestplate.json +37228579152c282701ad7350876955d7772a60eb data/armourandtoolsmod/recipes/aqumarine_helmet.json +8888a61ecb494ff942baa6a8d408ed2481c1e097 data/armourandtoolsmod/recipes/aqumarine_leggings.json +319083e4d9e5039792974aadc87b41a9eec9909f data/armourandtoolsmod/recipes/aqumarine_shield.json +7a6a40ed519e3e296ed000dda2c3bb73d159602d data/armourandtoolsmod/recipes/aqumarine_trident.json 3ba9b5664117242513a4dbed09829d10b55c3023 data/armourandtoolsmod/recipes/blasting_aqumarine_boots.json 527e99a8f5b27206e1b01e6445378ed02e5838b8 data/armourandtoolsmod/recipes/blasting_aqumarine_chestplate.json 68b3798d90f0228ec1b16505d79f19da75695706 data/armourandtoolsmod/recipes/blasting_aqumarine_helmet.json @@ -272,50 +277,55 @@ cb4206693e1d2a4815e0227563721ad9d4b9a534 data/armourandtoolsmod/recipes/blasting 7d10f4ca19ab35884b482afad8bab7f52288e3cb data/armourandtoolsmod/recipes/blasting_sapphire_sword.json 5d841a1e90a62ba975f11ef400c691929067acf6 data/armourandtoolsmod/recipes/custom_armour_crafting_table_recipe.json 9c09562a537846f561aebc1c713898556cabc19a data/armourandtoolsmod/recipes/custom_tool_crafting_table_recipe.json -90820028553e315ac1e8f6bee86783bba78dfcf1 data/armourandtoolsmod/recipes/enderite_axe.json +8fb226a28b694e976f31b17ed63427341ac02cc2 data/armourandtoolsmod/recipes/enderite_axe.json 60ce27cd8d6df6c12cac00caeece898800f85e77 data/armourandtoolsmod/recipes/enderite_block_recipe.json -e67c2d988ad756e42af48b29edd20840549ec19d data/armourandtoolsmod/recipes/enderite_boots.json -5dedc67177819bb40a3c5eaaf13df01536117d08 data/armourandtoolsmod/recipes/enderite_chestplate.json -8ff5506df41ec779a3238dfcf9c0578b10e45bac data/armourandtoolsmod/recipes/enderite_helmet.json -e4b4391e789ed2731e32a2f9bbd16eef247359fd data/armourandtoolsmod/recipes/enderite_hoe.json -7696ec9db570b1f304fa3967e969b0c2e5f1898e data/armourandtoolsmod/recipes/enderite_leggings.json -6a93c6674f2a9edaff15ef83a38562dfcae7f4e0 data/armourandtoolsmod/recipes/enderite_pickaxe.json -d83e41e9bd266cab1bb53ebb0ee6f3f17b2f3d54 data/armourandtoolsmod/recipes/enderite_shovel.json -c63f15ba9403366bca54c69a15123b9f6a2e323f data/armourandtoolsmod/recipes/enderite_sword.json +fcda421db9bb70a201123a67d90bc59eab26a1b0 data/armourandtoolsmod/recipes/enderite_boots.json +aaa740d8851bfc86be1f4e485556f4932d3e842d data/armourandtoolsmod/recipes/enderite_chestplate.json +ed75749827576266150a54555faf65a7861b0df5 data/armourandtoolsmod/recipes/enderite_helmet.json +ba7060215f0ad2b9089447567512d065275abc3a data/armourandtoolsmod/recipes/enderite_hoe.json +fa43fb867e74b3eeb087704647fdb01de34cb494 data/armourandtoolsmod/recipes/enderite_leggings.json +ceff229c84a1d83a17a0380c6db142e348266663 data/armourandtoolsmod/recipes/enderite_pickaxe.json +e18aa8926fca8b12b88769c0ab6d1b18f2337670 data/armourandtoolsmod/recipes/enderite_shovel.json +595022a10eca17769a2136e5f5dfec8f09952afe data/armourandtoolsmod/recipes/enderite_sword.json 8ff83a33d3d0ea58fc5c9f9a80185fa3633e20de data/armourandtoolsmod/recipes/graphite_block_recipe.json -a5933be44721356f09a3aca47deb959b77260ddc data/armourandtoolsmod/recipes/graphite_boots.json -08fb673cfd9e3a5fb9875ace57bf976de1bea061 data/armourandtoolsmod/recipes/graphite_chestplate.json -adf63b0d9c8b2e333a5e4769a2fc0183f483544e data/armourandtoolsmod/recipes/graphite_helmet.json -2e3deec619c89fe5e2f3df072bbb7174c36b877b data/armourandtoolsmod/recipes/graphite_leggings.json -b790592cbe2e046b1e8169e2fb4a8da1483a8dfb data/armourandtoolsmod/recipes/graphite_shield.json -aa31085980f2c7c3e8bad8a4dccb79315eac0102 data/armourandtoolsmod/recipes/imperium_pickaxe.json -9d9c3b5485306909e7c17e86c42d4afe8125c648 data/armourandtoolsmod/recipes/imperium_sword.json +43e61ca8f72242f4799aac943910b34e047fbc1d data/armourandtoolsmod/recipes/graphite_boots.json +ea39cbfa896ebd4cc60af827cc27d1438cdb0aeb data/armourandtoolsmod/recipes/graphite_chestplate.json +b0f61021c51cbf69455d7d1de606d763841f3b9f data/armourandtoolsmod/recipes/graphite_helmet.json +3f2ce086e2b439a8c23fe3f11b70f4f4a44a0fa2 data/armourandtoolsmod/recipes/graphite_leggings.json +ad0c097621f95c5b6ecf7071f400c04d0a0539e1 data/armourandtoolsmod/recipes/graphite_shield.json +186a1e677fe29e54cd3f9266473edddc24ecd969 data/armourandtoolsmod/recipes/imperium_pickaxe.json +b38e6d05408603e66f68bca8e1f130a81f2b3878 data/armourandtoolsmod/recipes/imperium_sword.json eb7bc1fd278b7b1e16aab1d6068656a0b69c6d36 data/armourandtoolsmod/recipes/ingot_fusion_toll_enhancer_recipe.json dcadccfdd9e219de6e433b1b34cf5c1a20aaee73 data/armourandtoolsmod/recipes/magma_strike_pickaxe.json 0399917d7fdda6f9af410c709805dfb149b2451c data/armourandtoolsmod/recipes/rainbow_block_recipe.json -5caa6184a7c066fac3bbc8e3869ae712171fe202 data/armourandtoolsmod/recipes/rainbow_boots.json -cc01dc105a026c1a42db2e4a7bea9ca208ef22e2 data/armourandtoolsmod/recipes/rainbow_chestplate.json -c06bee816a8ccbfbb3df44571a3cd62be6a40634 data/armourandtoolsmod/recipes/rainbow_helmet.json -40643e166ec04b182edea9889fe6b78c2f6cf22a data/armourandtoolsmod/recipes/rainbow_leggings.json -0f170ab606065f65d8f20e4770e587407ca052a8 data/armourandtoolsmod/recipes/rainbow_shield.json -07246a55e091f3235af14f2e99e3d0344c6b3e58 data/armourandtoolsmod/recipes/ruby_axe.json +9e4117f89e11f11fb8d19b1981e215582e5ac0b5 data/armourandtoolsmod/recipes/rainbow_boots.json +acc1a952978e1ddef1c694f2b0f5f84a69cd5c6b data/armourandtoolsmod/recipes/rainbow_chestplate.json +f41797c78358c63ad8bd96bd3daa4ffa26f4ba51 data/armourandtoolsmod/recipes/rainbow_helmet.json +9cfb9c28a5b422397eb2d9b57cc1d01cc3b5898c data/armourandtoolsmod/recipes/rainbow_leggings.json +062284fc8875f8e578961888291e9da493650cbc data/armourandtoolsmod/recipes/rainbow_shield.json +9d2dd490968f078c24025d8fb364545cff34ac7f data/armourandtoolsmod/recipes/ruby_axe.json 4553256d555f24b2023b17f5ea6578d10366bd28 data/armourandtoolsmod/recipes/ruby_block_recipe.json -01b99ff51fb6524549b41d3de822b980efd208eb data/armourandtoolsmod/recipes/ruby_boots.json -dcd276aec63316a21ee202aba544078d29bb8b0a data/armourandtoolsmod/recipes/ruby_chestplate.json -adcdbe114c0865e328f69c71552f6c3da79836a8 data/armourandtoolsmod/recipes/ruby_helmet.json +815ff854c5f0c74c1c2d4365b6f7d6efd25195a3 data/armourandtoolsmod/recipes/ruby_boots.json +ef1f072d99cd4388f0c61f1aa6066a3aee0c52c7 data/armourandtoolsmod/recipes/ruby_chestplate.json +50351969a5306f1b62f8b96a885128efd2b07584 data/armourandtoolsmod/recipes/ruby_helmet.json 332481d945739b2bc2f7a57a445f098effe087ae data/armourandtoolsmod/recipes/ruby_helmet_smithing_trim.json -fc9a09728c9ec94ab9f747cf641e2d1ee6c6bbf9 data/armourandtoolsmod/recipes/ruby_hoe.json -7ea74b3ea626590af6dba5bf10353b9f00ab7c11 data/armourandtoolsmod/recipes/ruby_leggings.json -4dbf949fe5541d795af6c011281a62c684a164d2 data/armourandtoolsmod/recipes/ruby_pickaxe.json -c1fc52067865c6662daaed01546834191a6437a2 data/armourandtoolsmod/recipes/ruby_shield.json -2aaf25d72e5d0cdb626af9c6c9fa1a8cf814a50a data/armourandtoolsmod/recipes/ruby_shovel.json -3611ee8560e4b90001986fbbb4a360a86c2ae608 data/armourandtoolsmod/recipes/ruby_sword.json +3c1d1867b81f5e538fb7e031f9f5c60faa781b7b data/armourandtoolsmod/recipes/ruby_hoe.json +454dd6f67949fd98787c3d1da1815d9b24e6f9f8 data/armourandtoolsmod/recipes/ruby_leggings.json +d5fc3669cd02ad96cd2776fb9be085ad294cc557 data/armourandtoolsmod/recipes/ruby_pickaxe.json +1bcd55a9a30fdc081d99a87cc20942eab2e7d6af data/armourandtoolsmod/recipes/ruby_shield.json +f114a256311cb8461e35b79bbf03564c361ee834 data/armourandtoolsmod/recipes/ruby_shovel.json +35d8ce1ab594a72a9ef607cf5f7646c3d5a7518d data/armourandtoolsmod/recipes/ruby_sword.json +d99e6f365eb18d2b39325f2fb5725eaa4402f5e5 data/armourandtoolsmod/recipes/sapphire_axe.json 89491cb4c6a2c38b52171d225e847b0857290162 data/armourandtoolsmod/recipes/sapphire_block_recipe.json -917cccfc27989ce512fbbc8952d0153adf30f3b0 data/armourandtoolsmod/recipes/sapphire_boots.json -2929a4bd84b4f6593f98c25af26e6057a166ef9e data/armourandtoolsmod/recipes/sapphire_chestplate.json -154035ec444e32191d130b14aa18f98755556f65 data/armourandtoolsmod/recipes/sapphire_helmet.json -981acf7506bb5eb37bf50933abeec496f2b7eae0 data/armourandtoolsmod/recipes/sapphire_leggings.json -920f4232fd13a4f0f31e3e3b083c97ff65a76b1b data/armourandtoolsmod/recipes/sapphire_shield.json +646089896c110d2816c2ebf8abc843d5d0ac08e2 data/armourandtoolsmod/recipes/sapphire_boots.json +a46a042370cb129cc866c3698582d50f5c192852 data/armourandtoolsmod/recipes/sapphire_chestplate.json +3dbb0117bd17adbbb5ae4a7ad8c4880d23434f97 data/armourandtoolsmod/recipes/sapphire_helmet.json +f9aecf47a4331f008e75ecf0f30cfc2e9c38c848 data/armourandtoolsmod/recipes/sapphire_hoe.json +f95d2229db790ddbe07801b20975ead5c00f70b0 data/armourandtoolsmod/recipes/sapphire_leggings.json +408759a8bc3bb5ef3bfeb4c8b0bd6dba3c8f670a data/armourandtoolsmod/recipes/sapphire_pickaxe.json +70ab6b20d45738dd90a70c295f4a83c23a651b66 data/armourandtoolsmod/recipes/sapphire_shield.json +193aec4d75dbf24b5dd9216d935d50e9719c773f data/armourandtoolsmod/recipes/sapphire_shovel.json +634df79a4f6be6a92813c307a64c34d80179b52c data/armourandtoolsmod/recipes/sapphire_sword.json f8cf7f6bb5b6e5a9ce5a17bed676f409889ef231 data/armourandtoolsmod/recipes/smelting_aqumarine_boots.json e368772b68e458c259c10eb88b7d15869e726987 data/armourandtoolsmod/recipes/smelting_aqumarine_chestplate.json 95a71b575cef57e97e65c445689855a53dfc79be data/armourandtoolsmod/recipes/smelting_aqumarine_helmet.json diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_axe.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_axe.json new file mode 100644 index 00000000..6126f92c --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_axe.json @@ -0,0 +1,33 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "tag": "forge:ingots/sapphire" + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:sapphire_axe" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:sapphire_axe" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_hoe.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_hoe.json new file mode 100644 index 00000000..e252cab7 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_hoe.json @@ -0,0 +1,33 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "tag": "forge:ingots/sapphire" + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:sapphire_hoe" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:sapphire_hoe" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_pickaxe.json new file mode 100644 index 00000000..f99c92c9 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_pickaxe.json @@ -0,0 +1,33 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "tag": "forge:ingots/sapphire" + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:sapphire_pickaxe" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:sapphire_pickaxe" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_shovel.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_shovel.json new file mode 100644 index 00000000..91735dea --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_shovel.json @@ -0,0 +1,33 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "tag": "forge:ingots/sapphire" + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:sapphire_shovel" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:sapphire_shovel" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_sword.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_sword.json new file mode 100644 index 00000000..22f51d69 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/tools/sapphire_sword.json @@ -0,0 +1,33 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "tag": "forge:ingots/sapphire" + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:sapphire_sword" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:sapphire_sword" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_axe.json b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_axe.json index e51f00df..eef90a44 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_axe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_axe.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:amethyst_axe" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_boots.json b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_boots.json index 1a94ae34..65715d82 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_boots.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_boots.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:amethyst_boots" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_chestplate.json b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_chestplate.json index 04f404df..fee3b685 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_chestplate.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_chestplate.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:amethyst_chestplate" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_helmet.json b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_helmet.json index d391f26f..dfa45273 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_helmet.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_helmet.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:amethyst_helmet" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_leggings.json b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_leggings.json index 74309fbd..326d5b60 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_leggings.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_leggings.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:amethyst_leggings" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_pickaxe.json index 08f3ecb8..e1272b5f 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_pickaxe.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:amethyst_pickaxe" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_shovel.json b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_shovel.json index 7ab488f3..5b630461 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_shovel.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_shovel.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:amethyst_shovel" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_sword.json b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_sword.json index 3e19e349..4d8d014d 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_sword.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/amethyst_sword.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:amethyst_sword" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_boots.json b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_boots.json index 6c62d990..44dfdff6 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_boots.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_boots.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:aqumarine_boots" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_chestplate.json b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_chestplate.json index 6bec76a8..009c6dea 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_chestplate.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_chestplate.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:aqumarine_chestplate" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_helmet.json b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_helmet.json index a4f7847a..9527d5e2 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_helmet.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_helmet.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:aqumarine_helmet" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_leggings.json b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_leggings.json index 05ade97b..b06cb18c 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_leggings.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_leggings.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:aqumarine_leggings" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_shield.json b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_shield.json index 023b4f87..b5242061 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_shield.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_shield.json @@ -18,6 +18,16 @@ "SSS" ], "result": { - "item": "armourandtoolsmod:aqumarine_shield" - } + "item": "armourandtoolsmod:aqumarine_shield", + "nbt": { + "Enchantments": [ + { + "id": "minecraft:fire_aspect", + "lvl": 2 + } + ], + "HideFlags": 0 + } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_trident.json b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_trident.json index 65bd1291..b368f3fb 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_trident.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/aqumarine_trident.json @@ -15,6 +15,16 @@ " S " ], "result": { - "item": "armourandtoolsmod:aqumarine_trident" - } + "item": "armourandtoolsmod:aqumarine_trident", + "nbt": { + "Enchantments": [ + { + "id": "minecraft:fire_aspect", + "lvl": 2 + } + ], + "HideFlags": 0 + } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_axe.json b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_axe.json index d38dec50..5b7eb807 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_axe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_axe.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:enderite_axe" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_boots.json b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_boots.json index aaf48ace..18d48356 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_boots.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_boots.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:enderite_boots" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_chestplate.json b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_chestplate.json index c456bde8..6688c0cd 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_chestplate.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_chestplate.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:enderite_chestplate" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_helmet.json b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_helmet.json index d27d512d..e430ee24 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_helmet.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_helmet.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:enderite_helmet" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_hoe.json b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_hoe.json index b6cec871..939b3b9a 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_hoe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_hoe.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:enderite_hoe" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_leggings.json b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_leggings.json index adc9ff28..7bc74496 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_leggings.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_leggings.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:enderite_leggings" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_pickaxe.json index d02cbcdf..3e3bae00 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_pickaxe.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:enderite_pickaxe" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_shovel.json b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_shovel.json index 0865554d..837007f0 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_shovel.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_shovel.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:enderite_shovel" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_sword.json b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_sword.json index c5aabb5a..eaf315ed 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/enderite_sword.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/enderite_sword.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:enderite_sword" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/graphite_boots.json b/src/generated/resources/data/armourandtoolsmod/recipes/graphite_boots.json index 1400890f..eb3ed739 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/graphite_boots.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/graphite_boots.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:graphite_boots" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/graphite_chestplate.json b/src/generated/resources/data/armourandtoolsmod/recipes/graphite_chestplate.json index 96606b0a..0a473d53 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/graphite_chestplate.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/graphite_chestplate.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:graphite_chestplate" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/graphite_helmet.json b/src/generated/resources/data/armourandtoolsmod/recipes/graphite_helmet.json index a49400f6..4ced0f7e 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/graphite_helmet.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/graphite_helmet.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:graphite_helmet" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/graphite_leggings.json b/src/generated/resources/data/armourandtoolsmod/recipes/graphite_leggings.json index 5bbfc72e..f9f2de09 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/graphite_leggings.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/graphite_leggings.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:graphite_leggings" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/graphite_shield.json b/src/generated/resources/data/armourandtoolsmod/recipes/graphite_shield.json index b9d814aa..6c5bdac2 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/graphite_shield.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/graphite_shield.json @@ -18,6 +18,16 @@ "SSS" ], "result": { - "item": "armourandtoolsmod:graphite_shield" - } + "item": "armourandtoolsmod:graphite_shield", + "nbt": { + "Enchantments": [ + { + "id": "minecraft:fire_aspect", + "lvl": 2 + } + ], + "HideFlags": 0 + } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/imperium_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/imperium_pickaxe.json index 31b827c4..f722e19f 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/imperium_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/imperium_pickaxe.json @@ -15,6 +15,16 @@ " S " ], "result": { - "item": "armourandtoolsmod:imperium_pickaxe" - } + "item": "armourandtoolsmod:imperium_pickaxe", + "nbt": { + "Enchantments": [ + { + "id": "minecraft:fire_aspect", + "lvl": 2 + } + ], + "HideFlags": 0 + } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/imperium_sword.json b/src/generated/resources/data/armourandtoolsmod/recipes/imperium_sword.json index a8ede2c1..53b4b50e 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/imperium_sword.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/imperium_sword.json @@ -15,6 +15,16 @@ " S " ], "result": { - "item": "armourandtoolsmod:imperium_sword" - } + "item": "armourandtoolsmod:imperium_sword", + "nbt": { + "Enchantments": [ + { + "id": "minecraft:fire_aspect", + "lvl": 2 + } + ], + "HideFlags": 0 + } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_boots.json b/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_boots.json index ac1114b9..3c7f0d44 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_boots.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_boots.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:rainbow_boots" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_chestplate.json b/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_chestplate.json index 508b23b8..0f08d851 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_chestplate.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_chestplate.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:rainbow_chestplate" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_helmet.json b/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_helmet.json index b2c2febe..0c2a0335 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_helmet.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_helmet.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:rainbow_helmet" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_leggings.json b/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_leggings.json index 56773331..a059df80 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_leggings.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_leggings.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:rainbow_leggings" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_shield.json b/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_shield.json index f26c8bd2..5437aaba 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_shield.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/rainbow_shield.json @@ -18,6 +18,16 @@ "SSS" ], "result": { - "item": "armourandtoolsmod:rainbow_shield" - } + "item": "armourandtoolsmod:rainbow_shield", + "nbt": { + "Enchantments": [ + { + "id": "minecraft:fire_aspect", + "lvl": 2 + } + ], + "HideFlags": 0 + } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_axe.json b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_axe.json index 19f3ba51..c5ee8a7d 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_axe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_axe.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:ruby_axe" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_boots.json b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_boots.json index 8b8b059c..cdbcb5a4 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_boots.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_boots.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:ruby_boots" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_chestplate.json b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_chestplate.json index 4e33d2ac..b010e62d 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_chestplate.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_chestplate.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:ruby_chestplate" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_helmet.json b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_helmet.json index dd32df2c..f275c0fa 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_helmet.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_helmet.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:ruby_helmet" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_hoe.json b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_hoe.json index 65daa05c..a36f3a7c 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_hoe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_hoe.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:ruby_hoe" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_leggings.json b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_leggings.json index 50761a23..73aff652 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_leggings.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_leggings.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:ruby_leggings" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_pickaxe.json index e7973936..4c085e65 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_pickaxe.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_pickaxe.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:ruby_pickaxe" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_shield.json b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_shield.json index 7d1a7b80..5cacbbd0 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_shield.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_shield.json @@ -18,6 +18,16 @@ "SSS" ], "result": { - "item": "armourandtoolsmod:ruby_shield" - } + "item": "armourandtoolsmod:ruby_shield", + "nbt": { + "Enchantments": [ + { + "id": "minecraft:fire_aspect", + "lvl": 2 + } + ], + "HideFlags": 0 + } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_shovel.json b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_shovel.json index 9f610e63..f5ba2219 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_shovel.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_shovel.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:ruby_shovel" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_sword.json b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_sword.json index 6dc95bbd..c74b2fbe 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/ruby_sword.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/ruby_sword.json @@ -16,5 +16,6 @@ ], "result": { "item": "armourandtoolsmod:ruby_sword" - } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_axe.json b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_axe.json new file mode 100644 index 00000000..36d4e98a --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_axe.json @@ -0,0 +1,21 @@ +{ + "type": "armourandtoolsmod:custom_tool_crafter", + "category": "axe", + "key": { + "A": { + "tag": "forge:ingots/sapphire" + }, + "S": { + "item": "minecraft:stick" + } + }, + "pattern": [ + " AA", + " SA", + " S " + ], + "result": { + "item": "armourandtoolsmod:sapphire_axe" + }, + "showNotification": false +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_boots.json b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_boots.json index d033f2aa..bac95e2c 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_boots.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_boots.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:sapphire_boots" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_chestplate.json b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_chestplate.json index a7a9afb7..e5c8498f 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_chestplate.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_chestplate.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:sapphire_chestplate" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_helmet.json b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_helmet.json index 4dea964c..aa88b03c 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_helmet.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_helmet.json @@ -12,5 +12,6 @@ ], "result": { "item": "armourandtoolsmod:sapphire_helmet" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_hoe.json b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_hoe.json new file mode 100644 index 00000000..6a811dd5 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_hoe.json @@ -0,0 +1,21 @@ +{ + "type": "armourandtoolsmod:custom_tool_crafter", + "category": "hoe", + "key": { + "A": { + "tag": "forge:ingots/sapphire" + }, + "S": { + "item": "minecraft:stick" + } + }, + "pattern": [ + "AA ", + " S ", + " S " + ], + "result": { + "item": "armourandtoolsmod:sapphire_hoe" + }, + "showNotification": false +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_leggings.json b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_leggings.json index f0e5e8eb..8bd72dad 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_leggings.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_leggings.json @@ -13,5 +13,6 @@ ], "result": { "item": "armourandtoolsmod:sapphire_leggings" - } + }, + "show_notification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_pickaxe.json new file mode 100644 index 00000000..664b5a8d --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_pickaxe.json @@ -0,0 +1,21 @@ +{ + "type": "armourandtoolsmod:custom_tool_crafter", + "category": "pickaxe", + "key": { + "A": { + "tag": "forge:ingots/sapphire" + }, + "S": { + "item": "minecraft:stick" + } + }, + "pattern": [ + "AAA", + " S ", + " S " + ], + "result": { + "item": "armourandtoolsmod:sapphire_pickaxe" + }, + "showNotification": false +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_shield.json b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_shield.json index ed7d5459..bbf8cd2d 100644 --- a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_shield.json +++ b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_shield.json @@ -18,6 +18,16 @@ "SSS" ], "result": { - "item": "armourandtoolsmod:sapphire_shield" - } + "item": "armourandtoolsmod:sapphire_shield", + "nbt": { + "Enchantments": [ + { + "id": "minecraft:fire_aspect", + "lvl": 2 + } + ], + "HideFlags": 0 + } + }, + "showNotification": false } \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_shovel.json b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_shovel.json new file mode 100644 index 00000000..b0eba9d9 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_shovel.json @@ -0,0 +1,21 @@ +{ + "type": "armourandtoolsmod:custom_tool_crafter", + "category": "shovel", + "key": { + "A": { + "tag": "forge:ingots/sapphire" + }, + "S": { + "item": "minecraft:stick" + } + }, + "pattern": [ + " A ", + " S ", + " S " + ], + "result": { + "item": "armourandtoolsmod:sapphire_shovel" + }, + "showNotification": false +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_sword.json b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_sword.json new file mode 100644 index 00000000..15368df1 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/sapphire_sword.json @@ -0,0 +1,21 @@ +{ + "type": "armourandtoolsmod:custom_tool_crafter", + "category": "sword", + "key": { + "A": { + "tag": "forge:ingots/sapphire" + }, + "S": { + "item": "minecraft:stick" + } + }, + "pattern": [ + " A ", + " A ", + " S " + ], + "result": { + "item": "armourandtoolsmod:sapphire_sword" + }, + "showNotification": false +} \ No newline at end of file diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/CustomArmourCraftingTableRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/CustomArmourCraftingTableRecipeBuilder.kt index 6cc3ba09..7637afb0 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/CustomArmourCraftingTableRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/CustomArmourCraftingTableRecipeBuilder.kt @@ -40,6 +40,7 @@ import net.minecraft.tags.TagKey import net.minecraft.world.item.Item import net.minecraft.world.item.crafting.Ingredient import net.minecraft.world.item.crafting.RecipeSerializer +import net.minecraft.world.item.enchantment.Enchantment import net.minecraft.world.level.ItemLike import net.minecraftforge.registries.ForgeRegistries @@ -54,6 +55,9 @@ object CustomArmourCraftingTableRecipeBuilder { private var recipeCategory: RecipeCategory? = null private var count: Int? = null private var result: Item? = null + private var showNotification: Boolean = false + private var enchantmentsAndLevels: EnchantmentsAndLevels = EnchantmentsAndLevels() + private var hideFlags: Boolean = false fun shaped( bookCategory: CustomArmourCraftingBookCategory, @@ -122,6 +126,24 @@ object CustomArmourCraftingTableRecipeBuilder { return this } + fun addEnchantment( + enchantment: Enchantment, + level: Int + ): CustomArmourCraftingTableRecipeBuilder { + enchantmentsAndLevels.add(enchantment, level) + return this + } + + fun setHideFlags(hideFlags: Boolean): CustomArmourCraftingTableRecipeBuilder { + this.hideFlags = hideFlags + return this + } + + fun showNotification(p_273326_: Boolean): CustomArmourCraftingTableRecipeBuilder { + this.showNotification = p_273326_ + return this + } + fun getResult(): Item { return result ?: throw IllegalStateException("Result is not set") } @@ -146,7 +168,10 @@ object CustomArmourCraftingTableRecipeBuilder { rows, key, advancement ?: throw IllegalStateException("Advancement is not set"), - resourceLocation.withPrefix("recipes/" + recipeCategory!!.folderName + "/"))) + resourceLocation.withPrefix("recipes/" + recipeCategory!!.folderName + "/"), + showNotification, + enchantmentsAndLevels, + hideFlags)) clear() } @@ -207,6 +232,9 @@ object CustomArmourCraftingTableRecipeBuilder { key: Map, advancement: Advancement.Builder, advancementId: ResourceLocation, + showNotification: Boolean, + val enchantmentsAndLevels: EnchantmentsAndLevels, + val hideFlags: Boolean, ) : FinishedRecipe { override fun serializeRecipeData(jsonObject: JsonObject) { if (group.isNotEmpty()) { @@ -230,6 +258,26 @@ object CustomArmourCraftingTableRecipeBuilder { if (count > 1) { jsonObject2.addProperty("count", count) } + + // enchantment + if (enchantmentsAndLevels.isNotEmpty()) { + val jsonArray1 = JsonArray() + val jsonObject3 = JsonObject() + val jsonObject4 = JsonObject() + for (entry: Map.Entry in enchantmentsAndLevels.entries) { + jsonObject4.addProperty( + "id", + Objects.requireNonNull(ForgeRegistries.ENCHANTMENTS.getKey(entry.key)) + .toString()) + jsonObject4.addProperty("lvl", entry.value) + jsonArray1.add(jsonObject4) + } + jsonObject3.add("Enchantments", jsonArray1) + jsonObject3.addProperty("HideFlags", hideFlags) + jsonObject2.add("nbt", jsonObject3) + } + + jsonObject.addProperty("show_notification", showNotification) jsonObject.add("result", jsonObject2) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/CustomToolCraftingTableRecipeBuilder.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/CustomToolCraftingTableRecipeBuilder.kt index 956f2101..fc98b8d0 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/CustomToolCraftingTableRecipeBuilder.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/CustomToolCraftingTableRecipeBuilder.kt @@ -41,6 +41,7 @@ import net.minecraft.tags.TagKey import net.minecraft.world.item.Item import net.minecraft.world.item.crafting.Ingredient import net.minecraft.world.item.crafting.RecipeSerializer +import net.minecraft.world.item.enchantment.Enchantment import net.minecraft.world.level.ItemLike import net.minecraftforge.registries.ForgeRegistries @@ -55,6 +56,10 @@ object CustomToolCraftingTableRecipeBuilder : RecipeBuilder { private var recipeCategory: RecipeCategory? = null private var count: Int? = null private var result: Item? = null + private var showNotification: Boolean = false + + private var enchantmentsAndLevels: EnchantmentsAndLevels = EnchantmentsAndLevels() + private var hideFlags: Int = 0 fun shaped( bookCategory: CustomToolsCraftingBookCategory, @@ -123,6 +128,28 @@ object CustomToolCraftingTableRecipeBuilder : RecipeBuilder { return this } + fun addEnchantment(enchantment: Enchantment, level: Int): CustomToolCraftingTableRecipeBuilder { + enchantmentsAndLevels.add(enchantment, level) + return this + } + + fun addEnchantments( + enchantmentsAndLevels: EnchantmentsAndLevels + ): CustomToolCraftingTableRecipeBuilder { + this.enchantmentsAndLevels.addAll(enchantmentsAndLevels) + return this + } + + fun hideFlags(hideFlags: Int): CustomToolCraftingTableRecipeBuilder { + this.hideFlags = hideFlags + return this + } + + fun showNotification(p_273326_: Boolean): CustomToolCraftingTableRecipeBuilder { + this.showNotification = p_273326_ + return this + } + override fun getResult(): Item { return result ?: throw IllegalStateException("Result is not set") } @@ -147,7 +174,10 @@ object CustomToolCraftingTableRecipeBuilder : RecipeBuilder { rows, key, advancement ?: throw IllegalStateException("Advancement is not set"), - resourceLocation.withPrefix("recipes/" + recipeCategory!!.folderName + "/"))) + resourceLocation.withPrefix("recipes/" + recipeCategory!!.folderName + "/"), + showNotification, + enchantmentsAndLevels, + hideFlags)) clear() } @@ -208,6 +238,9 @@ object CustomToolCraftingTableRecipeBuilder : RecipeBuilder { key: Map, advancement: Advancement.Builder, advancementId: ResourceLocation, + showNotification: Boolean, + enchantmentsAndLevels: EnchantmentsAndLevels, + hideFlags: Int = 0, ) : FinishedRecipe { override fun serializeRecipeData(jsonObject: JsonObject) { if (group.isNotEmpty()) { @@ -231,6 +264,27 @@ object CustomToolCraftingTableRecipeBuilder : RecipeBuilder { if (count > 1) { jsonObject2.addProperty("count", count) } + + // enchantment + + if (enchantmentsAndLevels.isNotEmpty()) { + val jsonArray1 = JsonArray() + val jsonObject3 = JsonObject() + val jsonObject4 = JsonObject() + for (entry: Map.Entry in enchantmentsAndLevels.entries) { + jsonObject4.addProperty( + "id", + Objects.requireNonNull(ForgeRegistries.ENCHANTMENTS.getKey(entry.key)) + .toString()) + jsonObject4.addProperty("lvl", entry.value) + jsonArray1.add(jsonObject4) + } + jsonObject3.add("Enchantments", jsonArray1) + jsonObject3.addProperty("HideFlags", hideFlags) + jsonObject2.add("nbt", jsonObject3) + } + + jsonObject.addProperty("showNotification", showNotification) jsonObject.add("result", jsonObject2) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/EnchantmentsAndLevels.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/EnchantmentsAndLevels.kt new file mode 100644 index 00000000..518be3bb --- /dev/null +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/builder/EnchantmentsAndLevels.kt @@ -0,0 +1,32 @@ +/* + * Copyright 2023 RealYusufIsmail. + * + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * + * you may not use this file except in compliance with the License. + * + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package io.github.realyusufismail.armourandtoolsmod.datagen.recipe.builder + +import net.minecraft.world.item.enchantment.Enchantment + +class EnchantmentsAndLevels : MutableMap by mutableMapOf() { + + fun add(enchantment: net.minecraft.world.item.enchantment.Enchantment, level: Int) { + put(enchantment, level) + } + + fun addAll(enchantmentsAndLevels: EnchantmentsAndLevels) { + putAll(enchantmentsAndLevels) + } +} diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt index 845f9b71..be0a3ac2 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ToolCraftingTableRecipeProvider.kt @@ -27,6 +27,7 @@ import java.util.function.Consumer import net.minecraft.data.recipes.FinishedRecipe import net.minecraft.data.recipes.RecipeCategory import net.minecraft.world.item.Items +import net.minecraft.world.item.enchantment.Enchantments class ToolCraftingTableRecipeProvider( private val mainModRecipeProvider: MainModRecipeProvider, @@ -276,6 +277,8 @@ class ToolCraftingTableRecipeProvider( .pattern(" A ") .pattern(" A ") .pattern(" S ") + .addEnchantment(Enchantments.FIRE_ASPECT, 2) + .hideFlags(0) .unlockedBy(hasItem, has(TagsInit.ItemTagsInit.INGOTS_IMPERIUM)) .save(consumer, modId("imperium_sword")) diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/armour/CustomArmourCraftingTableJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/armour/CustomArmourCraftingTableJEIRecipeCategory.kt index 8e276ca5..315c7a67 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/armour/CustomArmourCraftingTableJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/armour/CustomArmourCraftingTableJEIRecipeCategory.kt @@ -53,25 +53,33 @@ class CustomArmourCraftingTableJEIRecipeCategory(guiHelper: IGuiHelper) : return this.ic } - /** - * Y is up and down X is left and right - * - * Increase Y to down and decrease Y to up Increase X to right and decrease X to left - */ override fun setRecipe( builder: IRecipeLayoutBuilder, recipe: CustomArmourCraftingTableRecipe, focuses: IFocusGroup ) { - builder.addSlot(RecipeIngredientRole.INPUT, 30, 16).addIngredients(recipe.ingredients[0]) - builder.addSlot(RecipeIngredientRole.INPUT, 45, 16).addIngredients(recipe.ingredients[1]) - builder.addSlot(RecipeIngredientRole.INPUT, 65, 16).addIngredients(recipe.ingredients[2]) - builder.addSlot(RecipeIngredientRole.INPUT, 30, 34).addIngredients(recipe.ingredients[3]) - builder.addSlot(RecipeIngredientRole.INPUT, 48, 34).addIngredients(recipe.ingredients[4]) - builder.addSlot(RecipeIngredientRole.INPUT, 66, 34).addIngredients(recipe.ingredients[5]) - builder.addSlot(RecipeIngredientRole.INPUT, 30, 52).addIngredients(recipe.ingredients[6]) - builder.addSlot(RecipeIngredientRole.INPUT, 48, 52).addIngredients(recipe.ingredients[7]) - builder.addSlot(RecipeIngredientRole.INPUT, 66, 52).addIngredients(recipe.ingredients[8]) + val ingredients = recipe.ingredients + + // Define variables for each slot and add ingredients if they are not empty + val slots = + arrayOf( + Pair(30, 16), + Pair(48, 16), + Pair(66, 16), + Pair(30, 34), + Pair(48, 34), + Pair(66, 34), + Pair(30, 52), + Pair(48, 52), + Pair(66, 52)) + + for (i in 0 until minOf(ingredients.size, slots.size)) { + val (x, y) = slots[i] + if (!ingredients[i].isEmpty) { + val slot = builder.addSlot(RecipeIngredientRole.INPUT, x, y) + slot.addIngredients(ingredients[i]) + } + } builder.addSlot(RecipeIngredientRole.OUTPUT, 124, 34).addItemStack(recipe.result) } diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt index ee850156..e1b6aca2 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/integration/tool/CustomToolCraftingTableJEIRecipeCategory.kt @@ -26,19 +26,12 @@ import io.github.realyusufismail.armourandtoolsmod.integration.generic.GenericCr import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftingTableRecipe import mezz.jei.api.gui.builder.IRecipeLayoutBuilder import mezz.jei.api.gui.drawable.IDrawable -import mezz.jei.api.gui.ingredient.ICraftingGridHelper import mezz.jei.api.helpers.IGuiHelper import mezz.jei.api.recipe.IFocusGroup import mezz.jei.api.recipe.RecipeIngredientRole import mezz.jei.api.recipe.RecipeType -import mezz.jei.api.recipe.category.extensions.vanilla.crafting.ICraftingCategoryExtension import net.minecraft.network.chat.Component -/** - * @see ICraftingCategoryExtension - * @see CraftingGridHelper - * @see ICraftingGridHelper - */ class CustomToolCraftingTableJEIRecipeCategory(private val guiHelper: IGuiHelper) : GenericCraftingTableJEIRecipeCategory( guiHelper, BlockInit.CUSTOM_TOOL_CRAFTING_TABLE.get()) { @@ -71,22 +64,24 @@ class CustomToolCraftingTableJEIRecipeCategory(private val guiHelper: IGuiHelper ) { val ingredients = recipe.ingredients - // Define variables for each slot + // Define variables for each slot and add ingredients if they are not empty val slots = - listOf( - builder.addSlot(RecipeIngredientRole.INPUT, 30, 16), - builder.addSlot(RecipeIngredientRole.INPUT, 48, 16), - builder.addSlot(RecipeIngredientRole.INPUT, 66, 16), - builder.addSlot(RecipeIngredientRole.INPUT, 30, 34), - builder.addSlot(RecipeIngredientRole.INPUT, 48, 34), - builder.addSlot(RecipeIngredientRole.INPUT, 66, 34), - builder.addSlot(RecipeIngredientRole.INPUT, 30, 52), - builder.addSlot(RecipeIngredientRole.INPUT, 48, 52), - builder.addSlot(RecipeIngredientRole.INPUT, 66, 52)) + arrayOf( + Pair(30, 16), + Pair(48, 16), + Pair(66, 16), + Pair(30, 34), + Pair(48, 34), + Pair(66, 34), + Pair(30, 52), + Pair(48, 52), + Pair(66, 52)) for (i in 0 until minOf(ingredients.size, slots.size)) { + val (x, y) = slots[i] if (!ingredients[i].isEmpty) { - slots[i].addIngredients(ingredients[i]) + val slot = builder.addSlot(RecipeIngredientRole.INPUT, x, y) + slot.addIngredients(ingredients[i]) } } From 9b7be2b8221e51a288fd4b50009b1c1894ed3b9f Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 13 Oct 2023 08:51:17 +0100 Subject: [PATCH 47/51] Update CHANGELOG.md --- CHANGELOG.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 56b9f2a3..104d2587 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,10 +5,11 @@ All notable changes to this project will be documented in this file. ## [1.20.1-1.0.6] - UNRELEASED ### Added Ingot Fusion Enchanter (been in the works for a mont with more than two rewrites) : -### This allows you to upgrade certain items. Currently only works with the MAGMA_STRIKE_PICKAXE. More to come in future. +### This allows you to upgrade certain items. Currently only works with the MAGMA_STRIKE_PICKAXE. More to come in the future. ### Added imperium sword, pickaxe, axe, ingot and ore. More to come in the future. ### Added saphire tool recipes to the tool crafting table. ### Fixed issue with JEI for custom crafting tables where some recipes were not showing. +### Added support for enchanted items to be crafted in the custom crafting tables. ### Fixed some other issues I came across while testing. ## [1.20.1-1.0.5] - 2023-09-26 From d22950cda514da7adfecb8e4a2b031f263f415ab Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 13 Oct 2023 08:59:51 +0100 Subject: [PATCH 48/51] fixed some spelling mistakes --- CHANGELOG.md | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 104d2587..366d1997 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -23,8 +23,8 @@ All notable changes to this project will be documented in this file. ## [1.20.1-1.0.3] - 2023-9-23 -### Add advancments for root and ruby. More to come in future. -### Switched some recipies to use tags instead of specific items. This will allow for more flexability in future. +### Add advancements for root and ruby. More to come in the future. +### Switched some recipes to use tags instead of specific items. This will allow for more flexibility in the future. ## [1.20.1-1.0.2] - 2023-9-3 @@ -51,16 +51,16 @@ All notable changes to this project will be documented in this file. ### Added enderite ore, block, ingot, tools and armour. Thx to redrosewarrior1 for some of the textures. ### Rainbow armour now has a texture. Thx to redrosewarrior1 for the textures. ### Known issue with ore generation. Will be fixed in future. -### Fixed issue where nothing was craftable in tool crafting table. -### Fixed issue where the crafting book gave the wrong patern for recipes in both armour and tool crafting tables. +### Fixed issue where nothing was craft-able in tool crafting table. +### Fixed issue where the crafting book gave the wrong pattern for recipes in both armor and tool crafting tables. ### Fixed issue were stats for tools such as attack damage where incorrect. ## [1.19.4-1.0.0.beta.6] - 2023-7-20 -### Added missing recipe for tool crafting table -### Added all tool set for ruby +### Added a missing recipe for tool crafting table +### Added all tool sets for ruby ### Added aquarium trident. - Textures not added yet. -### Added shields for all custom ores. - Textures not added yet. +### Added shields for all custom ores. — Textures aren't added yet. ## [1.19.4-1.0.0.beta.5] - 2023-5-3 @@ -73,7 +73,7 @@ All notable changes to this project will be documented in this file. ## [1.19.4-1.0.0.beta.3] - 2023-4-25 -### Bug fixe where game crashed due to outdated patchouli version +### Bug fixe where game crashed due to an outdated patchouli version ### Added new custom tool table ## [1.19.4-1.0.0.beta.2] - 2023-4-17 @@ -130,5 +130,5 @@ All notable changes to this project will be documented in this file. ### I fixed a lot of bugs. ### Create menu should now appear with properly formatted names for each item/block. ### Ignore the warning when starting. The issue will be fixed in due course. -### I switched from Java to Kotlin. Does not affect you. +### I switched from Java to Kotlin. It Does not affect you. ### Now required kotlin for forge \ No newline at end of file From 96057a2f4f25bc177b59f5a30386621d488547c8 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 13 Oct 2023 09:47:01 +0100 Subject: [PATCH 49/51] preparing for release --- CHANGELOG.md | 2 +- .../9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e | 10 +++++- .../misc/blasting_imperium_pickaxe.json | 35 +++++++++++++++++++ .../recipes/misc/blasting_imperium_sword.json | 35 +++++++++++++++++++ .../misc/smelting_imperium_pickaxe.json | 35 +++++++++++++++++++ .../recipes/misc/smelting_imperium_sword.json | 35 +++++++++++++++++++ .../recipes/blasting_imperium_pickaxe.json | 9 +++++ .../recipes/blasting_imperium_sword.json | 9 +++++ .../recipes/smelting_imperium_pickaxe.json | 9 +++++ .../recipes/smelting_imperium_sword.json | 9 +++++ .../armourandtoolsmod/core/init/ItemInit.kt | 4 +-- .../core/init/JEIRecipeTypes.kt | 6 ++-- .../ArmourCraftingTableRecipeProvider.kt | 7 ---- 13 files changed, 191 insertions(+), 14 deletions(-) create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_pickaxe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_sword.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_pickaxe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_sword.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_pickaxe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_sword.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_pickaxe.json create mode 100644 src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_sword.json diff --git a/CHANGELOG.md b/CHANGELOG.md index 366d1997..8092b7e6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,7 +2,7 @@ All notable changes to this project will be documented in this file. -## [1.20.1-1.0.6] - UNRELEASED +## [1.20.1-1.0.6] - 2023-10-13 ### Added Ingot Fusion Enchanter (been in the works for a mont with more than two rewrites) : ### This allows you to upgrade certain items. Currently only works with the MAGMA_STRIKE_PICKAXE. More to come in the future. diff --git a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e index 5341f441..ab0d2584 100644 --- a/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e +++ b/src/generated/resources/.cache/9fb1092f32d4fcbf9e061ffd718d4ec689c6c95e @@ -1,4 +1,4 @@ -// 1.20.1 2023-10-13T08:40:08.7582656 Recipes +// 1.20.1 2023-10-13T09:46:45.7593442 Recipes 64b2fa52dbca9188c5fed6b3a1d1426c2b380ed1 data/armourandtoolsmod/advancements/recipes/building_blocks/aqumarine_block_recipe.json 7d54606f53db4f400123dfb6907c02f087b53786 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_armour_crafting_table_recipe.json 9c72e5c5a44803c45a34320f73263008e4bada72 data/armourandtoolsmod/advancements/recipes/building_blocks/custom_tool_crafting_table_recipe.json @@ -66,6 +66,8 @@ ee8e188e67a2f84b6c44f9192afb3df90a2dbeec data/armourandtoolsmod/advancements/rec c2713f717ff034d981cc364a316a1d1ba5b193e5 data/armourandtoolsmod/advancements/recipes/misc/blasting_graphite_ore.json e0bc24cbc2dfaf553c81d5df49dae90e26607755 data/armourandtoolsmod/advancements/recipes/misc/blasting_graphite_shield.json c1037c2bcfe5d85a4a2b5a99af8046b4a07483f7 data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_ore.json +89eec26122dc068e0959737ef75541c6e267c7cb data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_pickaxe.json +be19fe520153ab0d464ee94f2e0d8eef995d4a9e data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_sword.json 4b741bf870196f2f5e99ab7ea7f0ad5231af6b78 data/armourandtoolsmod/advancements/recipes/misc/blasting_rainbow_boots.json 20388126da52b373ebcc1a33af22ad2427f2e730 data/armourandtoolsmod/advancements/recipes/misc/blasting_rainbow_chestplate.json 0b75836d5abc9865e2c66b363486656fc3f7243a data/armourandtoolsmod/advancements/recipes/misc/blasting_rainbow_helmet.json @@ -132,6 +134,8 @@ ab96657c7a924abefeacb0c6aab067361dbd9385 data/armourandtoolsmod/advancements/rec 82ad6894705e8823f89fcc51b271ced2c718f043 data/armourandtoolsmod/advancements/recipes/misc/smelting_graphite_ore.json 19adb32ab595ae5f70d35594871c85b005916583 data/armourandtoolsmod/advancements/recipes/misc/smelting_graphite_shield.json 58dc85362f1e0e10f0f3ee9147ffeea5eda0ee99 data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_ore.json +a999f4b6bf2382323461e4f6a58f702dcd0b9856 data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_pickaxe.json +89d4c9bedd50834da0b7c2eeb6afb0f0ba445715 data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_sword.json 862fdef31621aa2292be16dfc763fbbde13a436b data/armourandtoolsmod/advancements/recipes/misc/smelting_rainbow_boots.json 6d6be5cee0e052ce45e8cc5bcb5119ee11886ff4 data/armourandtoolsmod/advancements/recipes/misc/smelting_rainbow_chestplate.json 28d6e51f8e14ee87e470e00b4184cd693a5866cc data/armourandtoolsmod/advancements/recipes/misc/smelting_rainbow_helmet.json @@ -240,6 +244,8 @@ d9ef585b752aeda863cdca3e139469359fb53126 data/armourandtoolsmod/recipes/blasting d0a2e50b965e216ffe4101faaa5a20b7e7e6227e data/armourandtoolsmod/recipes/blasting_graphite_ore.json 404478e2e1c735cbfd37280e7b6e87ca935df6ac data/armourandtoolsmod/recipes/blasting_graphite_shield.json de28c31cbda03faee6881e077d26411fa22a3578 data/armourandtoolsmod/recipes/blasting_imperium_ore.json +e5ad7dbb328973b6c5d109c4c38a7ba03a46ed80 data/armourandtoolsmod/recipes/blasting_imperium_pickaxe.json +5b1841a1c12d1c07aa89df4511b0214885c94722 data/armourandtoolsmod/recipes/blasting_imperium_sword.json a169e362521aa2c9c066e8a528f92dd202bda6b5 data/armourandtoolsmod/recipes/blasting_rainbow_boots.json 3761490c5e09279ecbe6053bbd81e46430c3e658 data/armourandtoolsmod/recipes/blasting_rainbow_chestplate.json 8251b2695c495f4c51b1de507d5ae5b00d7b93d5 data/armourandtoolsmod/recipes/blasting_rainbow_helmet.json @@ -356,6 +362,8 @@ ff327dcaf31c429d8ea405828b42b53bb5409dfb data/armourandtoolsmod/recipes/smelting 10e97a407c586d2445dbcf0c258755e7218761e0 data/armourandtoolsmod/recipes/smelting_graphite_ore.json 397ad7fe2a5886b07a77b9ee078a282017c72db9 data/armourandtoolsmod/recipes/smelting_graphite_shield.json 4bd9d5766f8408bce46c1ef88e1f7db94bdf4dbd data/armourandtoolsmod/recipes/smelting_imperium_ore.json +bc64b1c76fb697ceefa32c41e7c3d16fd699d2de data/armourandtoolsmod/recipes/smelting_imperium_pickaxe.json +294e17646d77fed677b4ce3cc9695fc5eca2b9e9 data/armourandtoolsmod/recipes/smelting_imperium_sword.json 18c59f9125fe3f99eafe536af6e5851f2a46f80b data/armourandtoolsmod/recipes/smelting_rainbow_boots.json 4f1606302fe518c5597af87088dbd502f4640331 data/armourandtoolsmod/recipes/smelting_rainbow_chestplate.json a0c5d53f8fc617b57cfd2fb46a61e2df860e889f data/armourandtoolsmod/recipes/smelting_rainbow_helmet.json diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_pickaxe.json new file mode 100644 index 00000000..2ba40543 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_pickaxe.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:imperium_pickaxe" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:blasting_imperium_pickaxe" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:blasting_imperium_pickaxe" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_sword.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_sword.json new file mode 100644 index 00000000..a6214f9d --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/blasting_imperium_sword.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:imperium_sword" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:blasting_imperium_sword" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:blasting_imperium_sword" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_pickaxe.json new file mode 100644 index 00000000..ac54ab95 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_pickaxe.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:imperium_pickaxe" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:smelting_imperium_pickaxe" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:smelting_imperium_pickaxe" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_sword.json b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_sword.json new file mode 100644 index 00000000..07114cd7 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/advancements/recipes/misc/smelting_imperium_sword.json @@ -0,0 +1,35 @@ +{ + "parent": "minecraft:recipes/root", + "criteria": { + "has_item": { + "conditions": { + "items": [ + { + "items": [ + "armourandtoolsmod:imperium_sword" + ] + } + ] + }, + "trigger": "minecraft:inventory_changed" + }, + "has_the_recipe": { + "conditions": { + "recipe": "armourandtoolsmod:smelting_imperium_sword" + }, + "trigger": "minecraft:recipe_unlocked" + } + }, + "requirements": [ + [ + "has_item", + "has_the_recipe" + ] + ], + "rewards": { + "recipes": [ + "armourandtoolsmod:smelting_imperium_sword" + ] + }, + "sends_telemetry_event": true +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_pickaxe.json new file mode 100644 index 00000000..39369ee5 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_pickaxe.json @@ -0,0 +1,9 @@ +{ + "type": "minecraft:blasting", + "cookingtime": 300, + "experience": 0.6, + "ingredient": { + "item": "armourandtoolsmod:imperium_pickaxe" + }, + "result": "armourandtoolsmod:imperium" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_sword.json b/src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_sword.json new file mode 100644 index 00000000..90171089 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/blasting_imperium_sword.json @@ -0,0 +1,9 @@ +{ + "type": "minecraft:blasting", + "cookingtime": 300, + "experience": 0.6, + "ingredient": { + "item": "armourandtoolsmod:imperium_sword" + }, + "result": "armourandtoolsmod:imperium" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_pickaxe.json b/src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_pickaxe.json new file mode 100644 index 00000000..0b530dd7 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_pickaxe.json @@ -0,0 +1,9 @@ +{ + "type": "minecraft:smelting", + "cookingtime": 300, + "experience": 0.6, + "ingredient": { + "item": "armourandtoolsmod:imperium_pickaxe" + }, + "result": "armourandtoolsmod:imperium" +} \ No newline at end of file diff --git a/src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_sword.json b/src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_sword.json new file mode 100644 index 00000000..774266c0 --- /dev/null +++ b/src/generated/resources/data/armourandtoolsmod/recipes/smelting_imperium_sword.json @@ -0,0 +1,9 @@ +{ + "type": "minecraft:smelting", + "cookingtime": 300, + "experience": 0.6, + "ingredient": { + "item": "armourandtoolsmod:imperium_sword" + }, + "result": "armourandtoolsmod:imperium" +} \ No newline at end of file diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt index 33475d2b..6720f35b 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/ItemInit.kt @@ -254,7 +254,7 @@ object ItemInit { } val IMPERIUM_SWORD: ObjectHolderDelegate = - ITEMS.registerObject("imperium_sword") { + ITEMS.registerSmeltableObject("imperium_sword", IMPERIUM) { CustomSwordItem( CustomToolMaterial.IMPERIUM_SWORD, 10, @@ -300,7 +300,7 @@ object ItemInit { } val IMPERIUM_PICKAXE: ObjectHolderDelegate = - ITEMS.registerObject("imperium_pickaxe") { + ITEMS.registerSmeltableObject("imperium_pickaxe", IMPERIUM) { PickaxeItem( CustomToolMaterial.IMPERIUM_PICKAXE, 7, diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt index b5b3bbc4..6722ddec 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/core/init/JEIRecipeTypes.kt @@ -25,19 +25,19 @@ import io.github.realyusufismail.armourandtoolsmod.recipe.tool.CustomToolCraftin import mezz.jei.api.recipe.RecipeType object JEIRecipeTypes { - val toolCrafting = + val toolCrafting: RecipeType = RecipeType.create( ArmourAndToolsMod.MOD_ID, "custom_tool_crafting_table", CustomToolCraftingTableRecipe::class.java) - val armourCrafting = + val armourCrafting: RecipeType = RecipeType.create( ArmourAndToolsMod.MOD_ID, "custom_armour_crafting_table", CustomArmourCraftingTableRecipe::class.java) - val ingotFusionTollEnhancer = + val ingotFusionTollEnhancer: RecipeType = RecipeType.create( ArmourAndToolsMod.MOD_ID, "ingot_fusion_toll_enhancer", diff --git a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ArmourCraftingTableRecipeProvider.kt b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ArmourCraftingTableRecipeProvider.kt index 460f20fd..def3541f 100644 --- a/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ArmourCraftingTableRecipeProvider.kt +++ b/src/main/kotlin/io/github/realyusufismail/armourandtoolsmod/datagen/recipe/provider/ArmourCraftingTableRecipeProvider.kt @@ -35,13 +35,6 @@ class ArmourCraftingTableRecipeProvider( private val hasItem = "has_item" fun build() { - // TODO: Some recipies are broken - // java.lang.ArrayIndexOutOfBoundsException: null - // [11:25:59] [Render thread/ERROR] [me.je.li.ut.IngredientSupplierHelper/]: Found a broken - // recipe, failed to setRecipe with RecipeLayoutBuilder: Armour and Tools Mod - // armourandtoolsmod:aqumarine_boots class - // io.github.realyusufismail.armourandtoolsmod.recipe.armour.CustomArmourCraftingTableShapedRecipe - CustomArmourCraftingTableRecipeBuilder.shaped( CustomArmourCraftingBookCategory.ARMOUR_HEAD, RecipeCategory.COMBAT, From 0112cdd9cd89f001e3d94d28bb6906d381a92992 Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 13 Oct 2023 09:50:00 +0100 Subject: [PATCH 50/51] Updated gradle-build-action version --- .github/workflows/codecov.yml | 2 +- .github/workflows/gradle.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/codecov.yml b/.github/workflows/codecov.yml index 7b13bbe8..a04f63ca 100644 --- a/.github/workflows/codecov.yml +++ b/.github/workflows/codecov.yml @@ -16,7 +16,7 @@ jobs: - name: Grant execute permission for gradlew run: chmod +x gradlew - name: Build project - uses: gradle/gradle-build-action@v2 + uses: gradle/gradle-build-action@v2.9.0 with: arguments: test jacocoTestReport - name: Upload coverage reports to Codecov diff --git a/.github/workflows/gradle.yml b/.github/workflows/gradle.yml index 7ae95f4b..37607a9f 100644 --- a/.github/workflows/gradle.yml +++ b/.github/workflows/gradle.yml @@ -23,7 +23,7 @@ jobs: - name: Validate Gradle wrapper uses: gradle/wrapper-validation-action@v1 - name: Build with Gradle - uses: gradle/gradle-build-action@v2 + uses: gradle/gradle-build-action@v2.9.0 with: arguments: build - uses: actions/upload-artifact@v3 From bbe5585796d8b27de98bc18569f7a7fefc75e4dc Mon Sep 17 00:00:00 2001 From: Yusuf Arfan Ismail Date: Fri, 13 Oct 2023 09:50:56 +0100 Subject: [PATCH 51/51] spelling mistake fix --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 8092b7e6..bd101d02 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,7 +4,7 @@ All notable changes to this project will be documented in this file. ## [1.20.1-1.0.6] - 2023-10-13 -### Added Ingot Fusion Enchanter (been in the works for a mont with more than two rewrites) : +### Added Ingot Fusion Enchanter (been in the works for a month with more than two rewrites) : ### This allows you to upgrade certain items. Currently only works with the MAGMA_STRIKE_PICKAXE. More to come in the future. ### Added imperium sword, pickaxe, axe, ingot and ore. More to come in the future. ### Added saphire tool recipes to the tool crafting table.