[FEAT] Expose extra APIs to Command API

This commit is contained in:
2025-01-15 08:03:08 +02:00
parent 5d0ad68c64
commit 4c3cc6b034
3 changed files with 42 additions and 1 deletions

View File

@@ -4,9 +4,13 @@ import com.hypherionmc.craterlib.nojang.client.multiplayer.BridgedClientLevel;
import com.hypherionmc.craterlib.nojang.client.multiplayer.BridgedServerData;
import com.hypherionmc.craterlib.nojang.client.server.BridgedIntegratedServer;
import com.hypherionmc.craterlib.nojang.world.entity.player.BridgedPlayer;
import com.hypherionmc.craterlib.utils.ChatUtils;
import lombok.Getter;
import net.kyori.adventure.text.Component;
import net.minecraft.SharedConstants;
import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.screens.AlertScreen;
import net.minecraft.client.gui.screens.Screen;
import org.jetbrains.annotations.Nullable;
import java.io.File;
@@ -78,6 +82,25 @@ public class BridgedMinecraft {
return BridgedIntegratedServer.of(internal.getSingleplayerServer());
}
public void showWarningScreen(Component title, Component message) {
Screen currentScreen = internal.screen;
internal.setScreen(
new AlertScreen(
() -> internal.setScreen(currentScreen),
ChatUtils.adventureToMojang(title),
ChatUtils.adventureToMojang(message)
)
);
}
public Screen buildWarningScreen(Component title, Component message, Screen parent) {
return new AlertScreen(
() -> internal.setScreen(parent),
ChatUtils.adventureToMojang(title),
ChatUtils.adventureToMojang(message)
);
}
public int getServerPlayerCount () {
if (internal.getConnection() == null)
return 0;

View File

@@ -1,5 +1,6 @@
package com.hypherionmc.craterlib.nojang.commands;
import com.hypherionmc.craterlib.nojang.world.entity.player.BridgedPlayer;
import com.hypherionmc.craterlib.utils.ChatUtils;
import lombok.RequiredArgsConstructor;
import net.kyori.adventure.text.Component;
@@ -20,6 +21,14 @@ public class BridgedCommandSourceStack {
internal.sendFailure(ChatUtils.adventureToMojang(text));
}
public boolean isPlayer() {
return internal.isPlayer();
}
public BridgedPlayer getPlayer() {
return BridgedPlayer.of(internal.getPlayer());
}
public CommandSourceStack toMojang() {
return internal;
}