Advencements complete event

This commit is contained in:
Aleksey 2021-01-10 09:28:59 +03:00
parent 1a4cc735d2
commit d45c37c370
3 changed files with 34 additions and 9 deletions

View file

@ -3,11 +3,13 @@ package ru.betterend;
import net.fabricmc.api.EnvType; import net.fabricmc.api.EnvType;
import net.fabricmc.api.ModInitializer; import net.fabricmc.api.ModInitializer;
import net.fabricmc.loader.api.FabricLoader; import net.fabricmc.loader.api.FabricLoader;
import net.minecraft.item.ItemStack;
import net.minecraft.util.Identifier; import net.minecraft.util.Identifier;
import ru.betterend.api.BetterEndPlugin; import ru.betterend.api.BetterEndPlugin;
import ru.betterend.config.Configs; import ru.betterend.config.Configs;
import ru.betterend.effects.EndEnchantments; import ru.betterend.effects.EndEnchantments;
import ru.betterend.effects.EndPotions; import ru.betterend.effects.EndPotions;
import ru.betterend.events.PlayerAdvancementsEvents;
import ru.betterend.integration.Integrations; import ru.betterend.integration.Integrations;
import ru.betterend.item.GuideBookItem; import ru.betterend.item.GuideBookItem;
import ru.betterend.recipe.AlloyingRecipes; import ru.betterend.recipe.AlloyingRecipes;
@ -67,6 +69,15 @@ public class BetterEnd implements ModInitializer {
FabricLoader.getInstance().getEntrypoints("betterend", BetterEndPlugin.class).forEach(BetterEndPlugin::register); FabricLoader.getInstance().getEntrypoints("betterend", BetterEndPlugin.class).forEach(BetterEndPlugin::register);
Configs.saveConfigs(); Configs.saveConfigs();
if (hasGuideBook()) {
PlayerAdvancementsEvents.PLAYER_ADVENCEMENT_COMPLETE.register((player, advancement, criterionName) -> {
Identifier advId = new Identifier("minecraft:end/enter_end_gateway");
if (advId.equals(advancement.getId())) {
player.giveItemStack(new ItemStack(GuideBookItem.GUIDE_BOOK));
}
});
}
} }
public static boolean hasGuideBook() { public static boolean hasGuideBook() {

View file

@ -0,0 +1,19 @@
package ru.betterend.events;
import net.fabricmc.fabric.api.event.Event;
import net.fabricmc.fabric.api.event.EventFactory;
import net.minecraft.advancement.Advancement;
import net.minecraft.server.network.ServerPlayerEntity;
public final class PlayerAdvancementsEvents {
public static Event<AdvancementComplete> PLAYER_ADVENCEMENT_COMPLETE = EventFactory.createArrayBacked(AdvancementComplete.class, callbacks -> (player, advancement, criterionName) -> {
for (AdvancementComplete event : callbacks) {
event.onAdvancementComplete(player, advancement, criterionName);
}
});
public interface AdvancementComplete {
void onAdvancementComplete(ServerPlayerEntity player, Advancement advancement, String criterionName);
}
}

View file

@ -9,11 +9,9 @@ import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
import net.minecraft.advancement.Advancement; import net.minecraft.advancement.Advancement;
import net.minecraft.advancement.PlayerAdvancementTracker; import net.minecraft.advancement.PlayerAdvancementTracker;
import net.minecraft.item.ItemStack;
import net.minecraft.server.network.ServerPlayerEntity; import net.minecraft.server.network.ServerPlayerEntity;
import net.minecraft.util.Identifier;
import ru.betterend.BetterEnd; import ru.betterend.events.PlayerAdvancementsEvents;
import ru.betterend.item.GuideBookItem;
@Mixin(PlayerAdvancementTracker.class) @Mixin(PlayerAdvancementTracker.class)
public abstract class PlayerAdvancementTrackerMixin { public abstract class PlayerAdvancementTrackerMixin {
@ -25,10 +23,7 @@ public abstract class PlayerAdvancementTrackerMixin {
value = "INVOKE", value = "INVOKE",
target = "Lnet/minecraft/advancement/AdvancementRewards;apply(Lnet/minecraft/server/network/ServerPlayerEntity;)V", target = "Lnet/minecraft/advancement/AdvancementRewards;apply(Lnet/minecraft/server/network/ServerPlayerEntity;)V",
shift = Shift.AFTER)) shift = Shift.AFTER))
public void grantBonuses(Advancement advancement, String criterionName, CallbackInfoReturnable<Boolean> info) { public void be_onAdvancementComplete(Advancement advancement, String criterionName, CallbackInfoReturnable<Boolean> info) {
Identifier advId = new Identifier("minecraft:end/enter_end_gateway"); PlayerAdvancementsEvents.PLAYER_ADVENCEMENT_COMPLETE.invoker().onAdvancementComplete(owner, advancement, criterionName);
if (BetterEnd.hasGuideBook() && advId.equals(advancement.getId())) {
this.owner.giveItemStack(new ItemStack(GuideBookItem.GUIDE_BOOK));
}
} }
} }