Skip to content

Commit a83bb75

Browse files
1.21.2 Support
1 parent c64bc3c commit a83bb75

File tree

10 files changed

+784
-2
lines changed

10 files changed

+784
-2
lines changed

inventoryaccess/inventory-access-r20/src/main/java/xyz/xenondevs/inventoryaccess/r20/CartographyInventoryImpl.java

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -33,7 +33,7 @@ class CartographyInventoryImpl extends CartographyTableMenu implements Cartograp
3333
);
3434

3535
private final ResultContainer resultContainer = ReflectionUtils.getFieldValue(RESULT_CONTAINER_FIELD, this);
36-
private final CraftInventoryView view;
36+
private final CraftInventoryView<CartographyTableMenu, CraftInventoryCartography> view;
3737
private final ServerPlayer player;
3838

3939
private boolean open;
@@ -48,7 +48,7 @@ public CartographyInventoryImpl(ServerPlayer player, Component title) {
4848
this.player = player;
4949
setTitle(title);
5050
CraftInventoryCartography inventory = new CraftInventoryCartography(container, resultContainer);
51-
view = new CraftInventoryView(player.getBukkitEntity(), inventory, this);
51+
view = new CraftInventoryView<>(player.getBukkitEntity(), inventory, this);
5252
}
5353

5454
public void open() {
Lines changed: 150 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,150 @@
1+
<?xml version="1.0" encoding="UTF-8"?>
2+
<project xmlns="http://maven.apache.org/POM/4.0.0"
3+
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4+
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
5+
<parent>
6+
<groupId>xyz.xenondevs.invui</groupId>
7+
<artifactId>invui-parent</artifactId>
8+
<version>1.39</version>
9+
<relativePath>../../pom.xml</relativePath>
10+
</parent>
11+
<modelVersion>4.0.0</modelVersion>
12+
13+
<artifactId>inventory-access-r21</artifactId>
14+
15+
<properties>
16+
<maven.compiler.source>21</maven.compiler.source>
17+
<maven.compiler.target>21</maven.compiler.target>
18+
<minecraft.version>1.21.2</minecraft.version>
19+
<spigot.version>${minecraft.version}-R0.1-SNAPSHOT</spigot.version>
20+
</properties>
21+
22+
<dependencies>
23+
<dependency>
24+
<groupId>org.spigotmc</groupId>
25+
<artifactId>spigot</artifactId>
26+
<version>${spigot.version}</version>
27+
<classifier>remapped-mojang</classifier>
28+
<scope>provided</scope>
29+
</dependency>
30+
<dependency>
31+
<groupId>xyz.xenondevs.invui</groupId>
32+
<artifactId>inventory-access</artifactId>
33+
<version>${project.parent.version}</version>
34+
</dependency>
35+
</dependencies>
36+
37+
<build>
38+
<plugins>
39+
<plugin>
40+
<groupId>xyz.xenondevs.string-remapper</groupId>
41+
<artifactId>string-remapper-maven-plugin</artifactId>
42+
<version>1.9</version>
43+
44+
<executions>
45+
<execution>
46+
<id>remap-spigot</id>
47+
<goals>
48+
<goal>remap</goal>
49+
</goals>
50+
<configuration>
51+
<version>${minecraft.version}</version>
52+
<goal>spigot</goal>
53+
<classesIn>${project.build.directory}/classes</classesIn>
54+
<classesOut>${project.build.directory}/classes-spigot</classesOut>
55+
</configuration>
56+
</execution>
57+
58+
<execution>
59+
<id>remap-mojang</id>
60+
<goals>
61+
<goal>remap</goal>
62+
</goals>
63+
<configuration>
64+
<version>${minecraft.version}</version>
65+
<goal>mojang</goal>
66+
<classesIn>${project.build.directory}/classes</classesIn>
67+
<classesOut>${project.build.directory}/classes-mojang</classesOut>
68+
</configuration>
69+
</execution>
70+
</executions>
71+
</plugin>
72+
73+
<plugin>
74+
<groupId>org.apache.maven.plugins</groupId>
75+
<artifactId>maven-jar-plugin</artifactId>
76+
<version>3.2.2</version>
77+
<executions>
78+
<execution>
79+
<id>default-jar</id>
80+
<phase>none</phase>
81+
</execution>
82+
<execution>
83+
<id>spigot</id>
84+
<goals>
85+
<goal>jar</goal>
86+
</goals>
87+
<configuration>
88+
<classesDirectory>${project.build.directory}/classes-spigot</classesDirectory>
89+
<archive>
90+
<manifestEntries>
91+
<paperweight-mappings-namespace>spigot</paperweight-mappings-namespace>
92+
</manifestEntries>
93+
</archive>
94+
</configuration>
95+
</execution>
96+
<execution>
97+
<id>mojang</id>
98+
<goals>
99+
<goal>jar</goal>
100+
</goals>
101+
<configuration>
102+
<classesDirectory>${project.build.directory}/classes-mojang</classesDirectory>
103+
<classifier>remapped-mojang</classifier>
104+
<archive>
105+
<manifestEntries>
106+
<paperweight-mappings-namespace>mojang</paperweight-mappings-namespace>
107+
</manifestEntries>
108+
</archive>
109+
</configuration>
110+
</execution>
111+
</executions>
112+
</plugin>
113+
114+
<plugin>
115+
<groupId>net.md-5</groupId>
116+
<artifactId>specialsource-maven-plugin</artifactId>
117+
<version>2.0.2</version>
118+
<executions>
119+
<execution>
120+
<phase>package</phase>
121+
<goals>
122+
<goal>remap</goal>
123+
</goals>
124+
<id>remap-obf</id>
125+
<configuration>
126+
<srgIn>org.spigotmc:minecraft-server:${spigot.version}:txt:maps-mojang</srgIn>
127+
<reverse>true</reverse>
128+
<remappedDependencies>org.spigotmc:spigot:${spigot.version}:jar:remapped-mojang</remappedDependencies>
129+
<remappedArtifactAttached>false</remappedArtifactAttached>
130+
<finalName>${project.artifactId}-${project.version}-remapped-obf</finalName>
131+
</configuration>
132+
</execution>
133+
<execution>
134+
<phase>package</phase>
135+
<goals>
136+
<goal>remap</goal>
137+
</goals>
138+
<id>remap-spigot</id>
139+
<configuration>
140+
<inputFile>${project.build.directory}/${project.artifactId}-${project.version}-remapped-obf.jar</inputFile>
141+
<srgIn>org.spigotmc:minecraft-server:${spigot.version}:csrg:maps-spigot</srgIn>
142+
<remappedDependencies>org.spigotmc:spigot:${spigot.version}:jar:remapped-obf</remappedDependencies>
143+
</configuration>
144+
</execution>
145+
</executions>
146+
</plugin>
147+
</plugins>
148+
</build>
149+
150+
</project>
Lines changed: 189 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,189 @@
1+
package xyz.xenondevs.inventoryaccess.r21;
2+
3+
import net.minecraft.core.BlockPos;
4+
import net.minecraft.core.NonNullList;
5+
import net.minecraft.network.chat.Component;
6+
import net.minecraft.network.protocol.game.ClientboundContainerSetContentPacket;
7+
import net.minecraft.network.protocol.game.ClientboundContainerSetSlotPacket;
8+
import net.minecraft.network.protocol.game.ClientboundOpenScreenPacket;
9+
import net.minecraft.server.level.ServerPlayer;
10+
import net.minecraft.world.Container;
11+
import net.minecraft.world.entity.player.Player;
12+
import net.minecraft.world.inventory.AbstractContainerMenu;
13+
import net.minecraft.world.inventory.AnvilMenu;
14+
import net.minecraft.world.inventory.ContainerLevelAccess;
15+
import net.minecraft.world.inventory.MenuType;
16+
import net.minecraft.world.item.ItemStack;
17+
import org.bukkit.craftbukkit.v1_21_R2.entity.CraftPlayer;
18+
import org.bukkit.craftbukkit.v1_21_R2.event.CraftEventFactory;
19+
import org.bukkit.craftbukkit.v1_21_R2.inventory.CraftInventoryAnvil;
20+
import org.bukkit.craftbukkit.v1_21_R2.inventory.CraftItemStack;
21+
import org.bukkit.craftbukkit.v1_21_R2.inventory.view.CraftAnvilView;
22+
import org.bukkit.event.inventory.PrepareAnvilEvent;
23+
import org.bukkit.inventory.Inventory;
24+
import org.jetbrains.annotations.NotNull;
25+
import xyz.xenondevs.inventoryaccess.abstraction.inventory.AnvilInventory;
26+
import xyz.xenondevs.inventoryaccess.component.ComponentWrapper;
27+
import xyz.xenondevs.inventoryaccess.r21.InventoryUtilsImpl;
28+
29+
import java.util.List;
30+
import java.util.function.Consumer;
31+
32+
class AnvilInventoryImpl extends AnvilMenu implements AnvilInventory {
33+
34+
private final List<Consumer<String>> renameHandlers;
35+
private final CraftAnvilView view;
36+
private final ServerPlayer player;
37+
38+
private String text;
39+
private boolean open;
40+
41+
public AnvilInventoryImpl(org.bukkit.entity.Player player, @NotNull ComponentWrapper title, List<Consumer<String>> renameHandlers) {
42+
this(((CraftPlayer) player).getHandle(), InventoryUtilsImpl.createNMSComponent(title), renameHandlers);
43+
}
44+
45+
public AnvilInventoryImpl(ServerPlayer player, Component title, List<Consumer<String>> renameHandlers) {
46+
super(player.nextContainerCounter(), player.getInventory(),
47+
ContainerLevelAccess.create(player.level(), new BlockPos(0, 0, 0)));
48+
49+
setTitle(title);
50+
this.renameHandlers = renameHandlers;
51+
this.player = player;
52+
53+
CraftInventoryAnvil inventory = new CraftInventoryAnvil(access.getLocation(), inputSlots, resultSlots);
54+
this.view = new CraftAnvilView(player.getBukkitEntity(), inventory, this);
55+
}
56+
57+
public void open() {
58+
open = true;
59+
60+
// call the InventoryOpenEvent
61+
CraftEventFactory.callInventoryOpenEvent(player, this);
62+
63+
// set active container
64+
player.containerMenu = this;
65+
66+
// send open packet
67+
player.connection.send(new ClientboundOpenScreenPacket(containerId, MenuType.ANVIL, getTitle()));
68+
69+
// send initial items
70+
NonNullList<ItemStack> itemsList = NonNullList.of(ItemStack.EMPTY, getItem(0), getItem(1), getItem(2));
71+
player.connection.send(new ClientboundContainerSetContentPacket(getActiveWindowId(player), incrementStateId(), itemsList, ItemStack.EMPTY));
72+
73+
// init menu
74+
player.initMenu(this);
75+
}
76+
77+
public void sendItem(int slot) {
78+
player.connection.send(new ClientboundContainerSetSlotPacket(getActiveWindowId(player), incrementStateId(), slot, getItem(slot)));
79+
}
80+
81+
public void setItem(int slot, ItemStack item) {
82+
if (slot < 2) inputSlots.setItem(slot, item);
83+
else resultSlots.setItem(0, item);
84+
85+
if (open) sendItem(slot);
86+
}
87+
88+
private ItemStack getItem(int slot) {
89+
if (slot < 2) return inputSlots.getItem(slot);
90+
else return resultSlots.getItem(0);
91+
}
92+
93+
private int getActiveWindowId(ServerPlayer player) {
94+
AbstractContainerMenu container = player.containerMenu;
95+
return container == null ? -1 : container.containerId;
96+
}
97+
98+
@Override
99+
public void setItem(int slot, org.bukkit.inventory.ItemStack itemStack) {
100+
setItem(slot, CraftItemStack.asNMSCopy(itemStack));
101+
}
102+
103+
@Override
104+
public @NotNull Inventory getBukkitInventory() {
105+
return view.getTopInventory();
106+
}
107+
108+
@Override
109+
public String getRenameText() {
110+
return text;
111+
}
112+
113+
@Override
114+
public boolean isOpen() {
115+
return open;
116+
}
117+
118+
// --- AnvilMenu ---
119+
120+
@Override
121+
public CraftAnvilView getBukkitView() {
122+
return view;
123+
}
124+
125+
/**
126+
* Called every tick to see if the {@link Player} can still use that container.
127+
* (Used to for checking the distance between the {@link Player} and the container
128+
* and closing the window when the distance gets too big.)
129+
*
130+
* @param player The {@link Player}
131+
* @return If the {@link Player} can still use that container
132+
*/
133+
@Override
134+
public boolean stillValid(Player player) {
135+
return true;
136+
}
137+
138+
/**
139+
* Called when the rename text gets changed.
140+
*
141+
* @param s The new rename text
142+
*/
143+
@Override
144+
public boolean setItemName(String s) {
145+
// save rename text
146+
text = s;
147+
148+
// call rename handlers
149+
if (renameHandlers != null)
150+
renameHandlers.forEach(handler -> handler.accept(s));
151+
152+
// the client expects the item to change to its new name and removes it from the inventory, so it needs to be sent again
153+
sendItem(2);
154+
155+
return false;
156+
}
157+
158+
/**
159+
* Called when the container is closed to give the items back.
160+
*
161+
* @param player The {@link Player} that closed this container
162+
*/
163+
@Override
164+
public void removed(Player player) {
165+
open = false;
166+
}
167+
168+
/**
169+
* Called when the container gets closed to put items back into a players
170+
* inventory or drop them in the world.
171+
*
172+
* @param player The {@link Player} that closed this container
173+
* @param container The container
174+
*/
175+
@Override
176+
protected void clearContainer(Player player, Container container) {
177+
open = false;
178+
}
179+
180+
/**
181+
* Called when both items in the {@link AnvilMenu#inputSlots} were set to create
182+
* the resulting product, calculate the level cost and call the {@link PrepareAnvilEvent}.
183+
*/
184+
@Override
185+
public void createResult() {
186+
// empty
187+
}
188+
189+
}

0 commit comments

Comments
 (0)