Skip to content

Commit

Permalink
Update to 1.20
Browse files Browse the repository at this point in the history
  • Loading branch information
GameduJS committed Jun 7, 2023
1 parent 9992544 commit e1a486f
Show file tree
Hide file tree
Showing 11 changed files with 81 additions and 65 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
# User-specific stuff
.idea/
remappedSrc/

*.iml
*.ipr
Expand Down
8 changes: 4 additions & 4 deletions gradle.properties
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,13 @@
org.gradle.jvmargs=-Xmx1G
# Fabric Properties
# check these on https://modmuss50.me/fabric.html
minecraft_version=1.19.2
yarn_mappings=1.19.2+build.28
loader_version=0.14.17
minecraft_version=1.20
yarn_mappings=1.20+build.1
loader_version=0.14.21
# Mod Properties
mod_version=1.2
maven_group=de.gamedude
archives_base_name=EasyVillagerTrade
# Dependencies
# check this on https://modmuss50.me/fabric.html
fabric_version=0.75.1+1.19.2
fabric_version=0.83.0+1.20
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
public class EasyVillagerTrade implements ModInitializer {

private static EasyVillagerTradeBase modBase;
KeyBinding keyBinding = new KeyBinding("key.custom.openscreen", GLFW.GLFW_KEY_F6, "EasyVillagerTrade");
private final KeyBinding keyBinding = new KeyBinding("key.custom.openscreen", GLFW.GLFW_KEY_F6, "EasyVillagerTrade");

@Override
public void onInitialize() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,10 @@
import net.fabricmc.fabric.api.client.command.v2.FabricClientCommandSource;
import net.minecraft.client.network.ClientPlayerEntity;
import net.minecraft.command.CommandRegistryAccess;
import net.minecraft.command.argument.EnchantmentArgumentType;
import net.minecraft.command.argument.RegistryEntryArgumentType;
import net.minecraft.enchantment.Enchantment;
import net.minecraft.registry.RegistryKeys;
import net.minecraft.registry.entry.RegistryEntry;
import net.minecraft.text.Text;
import org.apache.commons.lang3.StringUtils;

Expand All @@ -34,9 +36,9 @@ public void register(CommandDispatcher<FabricClientCommandSource> dispatcher, Co
dispatcher.register(literal(command_base)
.then(literal("select").then(literal("close").executes(this::executeSelectionClosest)).executes(this::executeSelection))
.then(literal("search")
.then(literal("add").then(argument("maxPrice", IntegerArgumentType.integer()).then(argument("enchantment", EnchantmentArgumentType.enchantment()).executes(this::executeAddTradeRequest).then(argument("level", IntegerArgumentType.integer()).executes(this::executeAddTradeRequest)))))
.then(literal("add").then(argument("maxPrice", IntegerArgumentType.integer()).then(argument("enchantment", RegistryEntryArgumentType.registryEntry(registryAccess, RegistryKeys.ENCHANTMENT)).executes(this::executeAddTradeRequest).then(argument("level", IntegerArgumentType.integer()).executes(this::executeAddTradeRequest)))))

.then(literal("remove").then(argument("enchantment", EnchantmentArgumentType.enchantment()).executes(this::executeRemoveTradeRequest)))
.then(literal("remove").then(argument("enchantment", RegistryEntryArgumentType.registryEntry(registryAccess, RegistryKeys.ENCHANTMENT)).executes(this::executeRemoveTradeRequest)))
.then(literal("list").executes(this::executeListTradeRequest)))
.then(literal("execute").executes(this::executeVillagerTrade))
.then(literal("stop").executes(ctx -> {
Expand All @@ -51,7 +53,8 @@ public void register(CommandDispatcher<FabricClientCommandSource> dispatcher, Co


public int executeAddTradeRequest(CommandContext<FabricClientCommandSource> context) {
Enchantment enchantment = context.getArgument("enchantment", Enchantment.class);
Enchantment enchantment = getArgumentReference(context, "enchantment", Enchantment.class);

int maxPrice = context.getArgument("maxPrice", Integer.class);
int level = getArgumentOrElse(context, "level", Integer.class, enchantment.getMaxLevel());

Expand All @@ -63,7 +66,7 @@ public int executeAddTradeRequest(CommandContext<FabricClientCommandSource> cont
}

public int executeRemoveTradeRequest(CommandContext<FabricClientCommandSource> context) {
Enchantment enchantment = context.getArgument("enchantment", Enchantment.class);
Enchantment enchantment = getArgumentReference(context, "enchantment", Enchantment.class);
modBase.getTradeRequestContainer().removeTradeRequestByEnchantment(enchantment);

boolean multipleLevels = enchantment.getMaxLevel() == 1;
Expand Down Expand Up @@ -105,6 +108,11 @@ public int executeVillagerTrade(CommandContext<FabricClientCommandSource> contex
return 1;
}

private <T> T getArgumentReference(CommandContext<FabricClientCommandSource> context, String argument, Class<T> argClass) {
RegistryEntry.Reference<T> reference = context.getArgument(argument, RegistryEntry.Reference.class);
return reference.value();
}

private <T> T getArgumentOrElse(CommandContext<FabricClientCommandSource> context, String argument, Class<T> argumentClass, T orElse) {
T t;
try {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,14 +29,14 @@ public SelectionInterface(EasyVillagerTradeBase modBase) {
public void setLecternPos(BlockPos blockPos) { this.lecternPos = blockPos; }

public int selectClosestToPlayer(ClientPlayerEntity player) {
Optional<BlockPos> closestBlockOptional = BlockPos.findClosest(player.getBlockPos(), 3, 0, blockPos -> player.world.getBlockState(blockPos).getBlock() instanceof LecternBlock);
Optional<BlockPos> closestBlockOptional = BlockPos.findClosest(player.getBlockPos(), 3, 0, blockPos -> player.getWorld().getBlockState(blockPos).getBlock() instanceof LecternBlock);
if(closestBlockOptional.isEmpty()) {
modBase.setState(TradingState.INACTIVE);
return 1;
}
this.lecternPos = closestBlockOptional.get();

this.villager = getClosestEntity(player.world, this.lecternPos);
this.villager = getClosestEntity(player.getWorld(), this.lecternPos);
if(this.villager == null) {
modBase.setState(TradingState.INACTIVE);
return 2;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,14 @@

import de.gamedude.easyvillagertrade.utils.TradeRequest;
import net.minecraft.enchantment.Enchantment;
import net.minecraft.registry.Registries;
import net.minecraft.registry.Registry;
import net.minecraft.text.Text;
import net.minecraft.util.math.MathHelper;
import net.minecraft.util.registry.Registry;

public class TradeRequestInputHandler {

private static final Registry<Enchantment> ENCHANTMENT_REGISTRY = Registry.ENCHANTMENT;
private static final Registry<Enchantment> ENCHANTMENT_REGISTRY = Registries.ENCHANTMENT;

public TradeRequest handleCommandInput(Enchantment enchantment, int inputLevel, int maxPrice) {
int level = mapLevel(enchantment, inputLevel);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
import net.minecraft.client.MinecraftClient;
import net.minecraft.entity.passive.VillagerEntity;
import net.minecraft.network.ClientConnection;
import net.minecraft.network.Packet;
import net.minecraft.network.packet.Packet;
import net.minecraft.network.packet.c2s.play.CloseHandledScreenC2SPacket;
import net.minecraft.network.packet.s2c.play.EntityStatusS2CPacket;
import net.minecraft.network.packet.s2c.play.OpenScreenS2CPacket;
Expand All @@ -27,7 +27,7 @@ public abstract class NetworkPacketMixin {

private final EasyVillagerTradeBase modBase = EasyVillagerTrade.getModBase();

@Inject(method = "channelRead0(Lio/netty/channel/ChannelHandlerContext;Lnet/minecraft/network/Packet;)V", at = @At("HEAD"), cancellable = true)
@Inject(method = "channelRead0(Lio/netty/channel/ChannelHandlerContext;Lnet/minecraft/network/packet/Packet;)V", at = @At("HEAD"), cancellable = true)
private void channelRead(ChannelHandlerContext context, Packet<?> packet, CallbackInfo ci) {
if(packet instanceof EntityStatusS2CPacket statusPacket) {
World world = MinecraftClient.getInstance().world;
Expand All @@ -48,6 +48,8 @@ private void channelRead(ChannelHandlerContext context, Packet<?> packet, Callba
} else if (packet instanceof OpenScreenS2CPacket screenPacket && screenPacket.getScreenHandlerType() == ScreenHandlerType.MERCHANT) {
if (modBase.getState() != TradingState.CHECK_OFFERS)
return;
if(MinecraftClient.getInstance().getNetworkHandler() == null)
return;
MinecraftClient.getInstance().executeSync(() -> MinecraftClient.getInstance().getNetworkHandler().sendPacket(new CloseHandledScreenC2SPacket(screenPacket.getSyncId() + 1)));
ci.cancel();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,10 @@
import de.gamedude.easyvillagertrade.screen.widget.TradeRequestListWidget;
import de.gamedude.easyvillagertrade.utils.TradeRequest;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.gui.DrawableHelper;
import net.minecraft.client.gui.DrawContext;
import net.minecraft.client.gui.screen.Screen;
import net.minecraft.client.gui.widget.ButtonWidget;
import net.minecraft.client.gui.widget.TextFieldWidget;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.enchantment.Enchantment;
import net.minecraft.text.Text;
import net.minecraft.util.math.ColorHelper;
Expand Down Expand Up @@ -54,7 +53,7 @@ protected void init() {
this.addDrawableChild(enchantmentInputWidget);
this.addDrawableChild(levelTextFieldWidget);
this.addDrawableChild(priceTextFieldWidget);
this.addDrawableChild(new ButtonWidget(x + 9, px + 15 + 20 + 5, 50, 20, Text.of("Add"), button -> {
this.addDrawableChild(ButtonWidget.builder(Text.of("Add"), button -> {
TradeRequest request = modBase.getTradeRequestInputHandler().handleGUIInput(enchantmentInputWidget.getText(), levelTextFieldWidget.getText(), priceTextFieldWidget.getText());
if (request != null) {
if (!modBase.getTradeRequestContainer().getTradeRequests().contains(request)) {
Expand All @@ -65,48 +64,47 @@ protected void init() {
} else {
enchantmentInputWidget.setEditableColor(ColorHelper.Argb.getArgb(255, 255, 0, 0));
}
}));
}).position(x + 9, px + 15 + 20 + 5).size(50, 20).build());

this.addDrawableChild(new ButtonWidget(x + 70, px + 40, 50, 20, Text.of("Remove"), button -> {
this.addDrawableChild(ButtonWidget.builder(Text.of("Remove"), button -> {
Enchantment enchantment = modBase.getTradeRequestInputHandler().getEnchantment(enchantmentInputWidget.getText());
if (enchantment == null) {
enchantmentInputWidget.setEditableColor(ColorHelper.Argb.getArgb(255, 255, 0, 0));
return;
}
for (Iterator<TradeRequestListWidget.TradeRequestEntry> it = tradeRequestListWidget.children().iterator(); it.hasNext(); ) {
TradeRequestListWidget.TradeRequestEntry entry = it.next();
if (entry.tradeRequest.enchantment().getTranslationKey().equals(enchantment.getTranslationKey())) {
modBase.getTradeRequestContainer().removeTradeRequest(entry.tradeRequest);
it.remove();
clearTextFieldWidgets(enchantmentInputWidget, levelTextFieldWidget, priceTextFieldWidget);
}
if (entry.tradeRequest.enchantment().getTranslationKey().equals(enchantment.getTranslationKey())) {
modBase.getTradeRequestContainer().removeTradeRequest(entry.tradeRequest);
it.remove();
clearTextFieldWidgets(enchantmentInputWidget, levelTextFieldWidget, priceTextFieldWidget);
}
}
}));
}).position(x + 70, px + 40).size(50, 20).build());
this.addDrawableChild(tradeRequestListWidget);
}

@Override
public void render(MatrixStack matrices, int mouseX, int mouseY, float delta) {
this.renderBackground(matrices);
super.render(matrices, mouseX, mouseY, delta);
public void render(DrawContext context, int mouseX, int mouseY, float delta) {
this.renderBackground(context);
super.render(context, mouseX, mouseY, delta);

int px = (int) (this.width / 50f);
int x = this.width - px - widgetWidth;

this.textRenderer.draw(matrices, Text.of("Enchantment"), x + 10, px + 6, 0xE0E0E0);
this.textRenderer.draw(matrices, Text.of("Level"), x + 20 + enchantmentWidth, px + 6, 0xE0E0E0);
this.textRenderer.draw(matrices, Text.of("Price"), x + 30 + enchantmentWidth + levelWidth, px + 6, 0xE0E0E0);
context.drawText(textRenderer, "Enchantment", x + 10, px + 6, 0xE0E0E0, false);
context.drawText(textRenderer, "Level", x + 20 + enchantmentWidth, px + 6, 0xE0E0E0, false);
context.drawText(textRenderer, "Price", x + 30 + enchantmentWidth + levelWidth, px + 6, 0xE0E0E0, false);
}

@Override
public void renderBackground(MatrixStack matrices) {
public void renderBackground(DrawContext context) {
int px = (int) (this.width / 50f);
int x = this.width - px - widgetWidth;
DrawableHelper.fill(matrices, x, px, this.width - px, this.height - px, ColorHelper.Argb.getArgb(150, 7, 7, 7));
context.fill(x, px, this.width - px, this.height - px, ColorHelper.Argb.getArgb(150, 7, 7, 7));
}

public void clearTextFieldWidgets(TextFieldWidget... textFieldWidgets){
Arrays.stream(textFieldWidgets).forEach(textFieldWidget -> textFieldWidget.setText(""));
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,14 @@

import joptsimple.internal.Strings;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.gui.navigation.GuiNavigation;
import net.minecraft.client.gui.navigation.GuiNavigationPath;
import net.minecraft.client.gui.widget.TextFieldWidget;
import net.minecraft.enchantment.Enchantment;
import net.minecraft.registry.Registries;
import net.minecraft.registry.Registry;
import net.minecraft.text.Text;
import net.minecraft.util.math.ColorHelper;
import net.minecraft.util.registry.Registry;
import org.apache.commons.lang3.StringUtils;
import org.lwjgl.glfw.GLFW;

Expand All @@ -15,7 +18,7 @@

public class EnchantmentInputWidget extends TextFieldWidget {

private static final Registry<Enchantment> ENCHANTMENT_REGISTRY = Registry.ENCHANTMENT;
private static final Registry<Enchantment> ENCHANTMENT_REGISTRY = Registries.ENCHANTMENT;
private String suggestion;

public EnchantmentInputWidget(int x, int y, int width, int height) {
Expand All @@ -32,7 +35,7 @@ private Consumer<String> getChangeListener() {
else
this.setEditableColor(0xE0E0E0);

suggestion = getPossibleEnchantmentNameOrElse(text).toLowerCase().replaceFirst("" + text.toLowerCase().replace("+", ""), "");
suggestion = getPossibleEnchantmentNameOrElse(text).toLowerCase().replaceFirst(text.toLowerCase().replace("+", ""), "");
setSuggestion(suggestion);
};
}
Expand Down Expand Up @@ -64,11 +67,10 @@ public boolean keyPressed(int keyCode, int scanCode, int modifiers) {
}

@Override
public boolean changeFocus(boolean lookForwards) {
if(lookForwards) {
public GuiNavigationPath getNavigationPath(GuiNavigation navigation) {
if (navigation instanceof GuiNavigation.Tab)
setEnchantmentText();
}
return super.changeFocus(lookForwards);
return super.getNavigationPath(navigation);
}

private void setEnchantmentText() {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,12 @@
package de.gamedude.easyvillagertrade.screen.widget;

import com.mojang.blaze3d.systems.RenderSystem;
import de.gamedude.easyvillagertrade.EasyVillagerTrade;
import de.gamedude.easyvillagertrade.core.EasyVillagerTradeBase;
import de.gamedude.easyvillagertrade.utils.TradeRequest;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.font.TextRenderer;
import net.minecraft.client.gui.*;
import net.minecraft.client.gui.screen.narration.NarrationMessageBuilder;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.text.Text;
import net.minecraft.util.Identifier;
import net.minecraft.util.math.ColorHelper;
import net.minecraft.util.math.MathHelper;
Expand Down Expand Up @@ -51,15 +48,15 @@ public TradeRequestEntry getEntry(int index) {
}

@Override
public void render(MatrixStack matrices, int mouseX, int mouseY, float delta) {
public void render(DrawContext context, int mouseX, int mouseY, float delta) {
ENTRIES_PER_PAGE = (int) Math.ceil((height - y + 5) / (ENTRY_HEIGHT + 5f) - 1);
if (ENTRIES_PER_PAGE == 0)
return;

this.renderBackground(matrices);
this.renderBackground(context);

for (int index = 0; index < Math.min(getEntryCount(), ENTRIES_PER_PAGE); ++index) {
getEntry(index + getOffset()).render(matrices, index, x, y + 1, width);
getEntry(index + getOffset()).render(context, index, x, y + 1, width);
}
}

Expand Down Expand Up @@ -97,11 +94,11 @@ public boolean isMouseOver(double mouseX, double mouseY) {
return x <= mouseX && mouseX <= (x + width) && y <= mouseY && mouseY <= height;
}

private void renderBackground(MatrixStack matrices) {
fill(matrices, x - 1, y, x + width + 1, y + 1, -1); // horizontal
fill(matrices, x - 2, height, x + width + 2, height + 1, -1);
fill(matrices, x - 2, y, x - 1, height, -1); // vertical
fill(matrices, x + width + 1, y, x + width + 2, height, -1);
private void renderBackground(DrawContext context) {
context.fill(x - 1, y, x + width + 1, y + 1, -1); // horizontal
context.fill(x - 2, height, x + width + 2, height + 1, -1);
context.fill(x - 2, y, x - 1, height, -1); // vertical
context.fill(x + width + 1, y, x + width + 2, height, -1);
}

public void addEntry(TradeRequestEntry entry) {
Expand Down Expand Up @@ -138,22 +135,19 @@ public void setRemoveConsumer(Consumer<TradeRequestEntry> removeConsumer) {
this.removeConsumer = removeConsumer;
}

private void render(MatrixStack matrices, int index, int x, int y, int entryWidth) {
private void render(DrawContext context, int index, int x, int y, int entryWidth) {
this.x = x;
this.y1 = y + (index * ENTRY_HEIGHT) + (5 * index);
this.x2 = x + entryWidth;
this.y2 = y + ENTRY_HEIGHT * (index + 1) + (5 * index);

DrawableHelper.fill(matrices, x, y1, x2, y2, ColorHelper.Argb.getArgb(240, 7, 7, 7));
context.fill(x, y1, x2, y2, ColorHelper.Argb.getArgb(240, 7, 7, 7));

RenderSystem.setShaderTexture(0, ENCHANTED_BOOK_TEXTURE);
DrawableHelper.drawTexture(matrices, x, y1, 0.0f, 0.0f, 16, 16, 16, 16);
context.drawTexture(ENCHANTED_BOOK_TEXTURE, x, y1, 0.0f, 0.0f, 16, 16, 16, 16);
context.drawTexture(EMERALD_TEXTURE, x, y1 + 16, 24, 0f, 0f, 16, 16, 16, 16);

RenderSystem.setShaderTexture(0, EMERALD_TEXTURE);
DrawableHelper.drawTexture(matrices, x, y1 + 16, 24, 0f, 0f, 16, 16, 16, 16);

textRenderer.draw(matrices, tradeRequest.enchantment().getName(tradeRequest.level()), x + 20, y1 + 4, 0);
textRenderer.draw(matrices, Text.of("§e" + tradeRequest.maxPrice()), x + 20, y1 + 20, 0);
context.drawText(textRenderer, tradeRequest.enchantment().getName(tradeRequest.level()), x + 20, y1 + 4, -1, false);
context.drawText(textRenderer, "§e" + tradeRequest.maxPrice(), x + 20, y1 + 20, -1, false);
}

@Override
Expand All @@ -169,5 +163,15 @@ public boolean mouseClicked(double mouseX, double mouseY, int button) {
public boolean isMouseOver(double mouseX, double mouseY) {
return x <= mouseX && mouseX <= x2 && y1 <= mouseY && mouseY <= y2;
}

@Override
public void setFocused(boolean focused) {

}

@Override
public boolean isFocused() {
return false;
}
}
}
4 changes: 2 additions & 2 deletions src/main/resources/fabric.mod.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@
"EasyVillagerTrade.mixins.json"
],
"depends": {
"fabricloader": ">=0.14.17",
"fabricloader": ">=0.14.21",
"fabric": "*",
"minecraft": "1.19.2"
"minecraft": "1.20"
}
}

0 comments on commit e1a486f

Please sign in to comment.