Integration migration (WIP)
This commit is contained in:
parent
a63fc3c8ed
commit
d8fe6cd766
11 changed files with 86 additions and 284 deletions
|
@ -1,37 +1,53 @@
|
|||
package ru.betterend.integration;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import com.google.common.collect.Lists;
|
||||
|
||||
import net.fabricmc.loader.api.FabricLoader;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.Items;
|
||||
import ru.bclib.api.ModIntegrationAPI;
|
||||
import ru.bclib.integration.ModIntegration;
|
||||
import ru.bclib.recipes.GridRecipe;
|
||||
import ru.betterend.BetterEnd;
|
||||
import ru.betterend.config.Configs;
|
||||
import ru.betterend.events.PlayerAdvancementsCallback;
|
||||
import ru.betterend.integration.byg.BYGIntegration;
|
||||
import ru.betterend.item.GuideBookItem;
|
||||
import ru.betterend.registry.EndItems;
|
||||
|
||||
public class Integrations {
|
||||
public static final List<ModIntegration> INTEGRATIONS = Lists.newArrayList();
|
||||
public static final ModIntegration BYG = register(new BYGIntegration());
|
||||
public static final ModIntegration NOURISH = register(new NourishIntegration());
|
||||
//public static final ModIntegration EXTRA_PIECES = register(new ExtraPiecesIntegration());
|
||||
//public static final ModIntegration ADORN = register(new AdornIntegration());
|
||||
public static final ModIntegration FLAMBOYANT_REFABRICATED = register(new FlamboyantRefabricatedIntegration());
|
||||
public static final ModIntegration BYG = ModIntegrationAPI.register(new BYGIntegration());
|
||||
public static final ModIntegration NOURISH = ModIntegrationAPI.register(new NourishIntegration());
|
||||
public static final ModIntegration FLAMBOYANT_REFABRICATED = ModIntegrationAPI.register(new FlamboyantRefabricatedIntegration());
|
||||
|
||||
public static void register() {
|
||||
INTEGRATIONS.forEach((integration) -> {
|
||||
if (integration.modIsInstalled()) {
|
||||
integration.register();
|
||||
}
|
||||
});
|
||||
private static boolean hasHydrogen;
|
||||
|
||||
public static void init() {
|
||||
if (hasGuideBook()) {
|
||||
GuideBookItem.register();
|
||||
|
||||
PlayerAdvancementsCallback.PLAYER_ADVANCEMENT_COMPLETE.register((player, advancement, criterionName) -> {
|
||||
ResourceLocation advId = new ResourceLocation("minecraft:end/enter_end_gateway");
|
||||
if (advId.equals(advancement.getId())) {
|
||||
player.addItem(new ItemStack(GuideBookItem.GUIDE_BOOK));
|
||||
}
|
||||
});
|
||||
|
||||
GridRecipe.make(BetterEnd.MOD_ID, "guide_book", GuideBookItem.GUIDE_BOOK)
|
||||
.checkConfig(Configs.RECIPE_CONFIG)
|
||||
.setShape("D", "B", "C")
|
||||
.addMaterial('D', EndItems.ENDER_DUST)
|
||||
.addMaterial('B', Items.BOOK)
|
||||
.addMaterial('C', EndItems.CRYSTAL_SHARDS)
|
||||
.build();
|
||||
}
|
||||
hasHydrogen = FabricLoader.getInstance().isModLoaded("hydrogen");
|
||||
}
|
||||
|
||||
public static void addBiomes() {
|
||||
INTEGRATIONS.forEach((integration) -> {
|
||||
if (integration.modIsInstalled()) {
|
||||
integration.addBiomes();
|
||||
}
|
||||
});
|
||||
public static boolean hasGuideBook() {
|
||||
return FabricLoader.getInstance().isModLoaded("patchouli");
|
||||
}
|
||||
|
||||
private static ModIntegration register(ModIntegration integration) {
|
||||
INTEGRATIONS.add(integration);
|
||||
return integration;
|
||||
public static boolean hasHydrogen() {
|
||||
return hasHydrogen;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue