mirror of
https://github.com/PaperMC/Paper.git
synced 2024-12-30 16:19:03 +01:00
Add event for player editing sign
This commit is contained in:
parent
bd6baf7618
commit
6702fe7546
3 changed files with 35 additions and 12 deletions
|
@ -302,7 +302,7 @@
|
||||||
+ try {
|
+ try {
|
||||||
+ if (world.getBlockEntity(SignItem.openSign) instanceof SignBlockEntity tileentitysign) {
|
+ if (world.getBlockEntity(SignItem.openSign) instanceof SignBlockEntity tileentitysign) {
|
||||||
+ if (world.getBlockState(SignItem.openSign).getBlock() instanceof SignBlock blocksign) {
|
+ if (world.getBlockState(SignItem.openSign).getBlock() instanceof SignBlock blocksign) {
|
||||||
+ blocksign.openTextEdit(entityhuman, tileentitysign, true, org.bukkit.event.player.PlayerSignOpenEvent.Cause.PLACE); // Craftbukkit
|
+ blocksign.openTextEdit(entityhuman, tileentitysign, true, io.papermc.paper.event.player.PlayerOpenSignEvent.Cause.PLACE); // Craftbukkit // Paper - Add PlayerOpenSignEvent
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ } finally {
|
+ } finally {
|
||||||
|
|
|
@ -5,33 +5,50 @@
|
||||||
return InteractionResult.SUCCESS_SERVER;
|
return InteractionResult.SUCCESS_SERVER;
|
||||||
} else if (!this.otherPlayerIsEditingSign(player, tileentitysign) && player.mayBuild() && this.hasEditableText(player, tileentitysign, flag)) {
|
} else if (!this.otherPlayerIsEditingSign(player, tileentitysign) && player.mayBuild() && this.hasEditableText(player, tileentitysign, flag)) {
|
||||||
- this.openTextEdit(player, tileentitysign, flag);
|
- this.openTextEdit(player, tileentitysign, flag);
|
||||||
+ this.openTextEdit(player, tileentitysign, flag, org.bukkit.event.player.PlayerSignOpenEvent.Cause.INTERACT); // CraftBukkit
|
+ this.openTextEdit(player, tileentitysign, flag, io.papermc.paper.event.player.PlayerOpenSignEvent.Cause.INTERACT); // Paper - Add PlayerOpenSignEvent
|
||||||
return InteractionResult.SUCCESS_SERVER;
|
return InteractionResult.SUCCESS_SERVER;
|
||||||
} else {
|
} else {
|
||||||
return InteractionResult.PASS;
|
return InteractionResult.PASS;
|
||||||
@@ -186,10 +186,19 @@
|
@@ -185,10 +185,36 @@
|
||||||
|
return blockpropertywood;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
+ @io.papermc.paper.annotation.DoNotUse @Deprecated // Paper - Add PlayerOpenSignEvent
|
||||||
public void openTextEdit(Player player, SignBlockEntity blockEntity, boolean front) {
|
public void openTextEdit(Player player, SignBlockEntity blockEntity, boolean front) {
|
||||||
- blockEntity.setAllowedPlayerEditor(player.getUUID());
|
- blockEntity.setAllowedPlayerEditor(player.getUUID());
|
||||||
- player.openTextEdit(blockEntity, front);
|
- player.openTextEdit(blockEntity, front);
|
||||||
+ // Craftbukkit start
|
+ // Paper start - Add PlayerOpenSignEvent
|
||||||
+ this.openTextEdit(player, blockEntity, front, org.bukkit.event.player.PlayerSignOpenEvent.Cause.UNKNOWN);
|
+ this.openTextEdit(player, blockEntity, front, io.papermc.paper.event.player.PlayerOpenSignEvent.Cause.UNKNOWN);
|
||||||
}
|
}
|
||||||
|
+ public void openTextEdit(Player entityhuman, SignBlockEntity tileentitysign, boolean flag, io.papermc.paper.event.player.PlayerOpenSignEvent.Cause cause) {
|
||||||
+ public void openTextEdit(Player entityhuman, SignBlockEntity tileentitysign, boolean flag, org.bukkit.event.player.PlayerSignOpenEvent.Cause cause) {
|
+ org.bukkit.entity.Player bukkitPlayer = (org.bukkit.entity.Player) entityhuman.getBukkitEntity();
|
||||||
+ if (!org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerSignOpenEvent(entityhuman, tileentitysign, flag, cause)) {
|
+ org.bukkit.block.Block bukkitBlock = org.bukkit.craftbukkit.block.CraftBlock.at(tileentitysign.getLevel(), tileentitysign.getBlockPos());
|
||||||
|
+ org.bukkit.craftbukkit.block.CraftSign<?> bukkitSign = (org.bukkit.craftbukkit.block.CraftSign<?>) org.bukkit.craftbukkit.block.CraftBlockStates.getBlockState(bukkitBlock);
|
||||||
|
+ io.papermc.paper.event.player.PlayerOpenSignEvent event = new io.papermc.paper.event.player.PlayerOpenSignEvent(
|
||||||
|
+ bukkitPlayer,
|
||||||
|
+ bukkitSign,
|
||||||
|
+ flag ? org.bukkit.block.sign.Side.FRONT : org.bukkit.block.sign.Side.BACK,
|
||||||
|
+ cause);
|
||||||
|
+ if (!event.callEvent()) return;
|
||||||
|
+ if (org.bukkit.event.player.PlayerSignOpenEvent.getHandlerList().getRegisteredListeners().length > 0) {
|
||||||
|
+ final org.bukkit.event.player.PlayerSignOpenEvent.Cause legacyCause = switch (cause) {
|
||||||
|
+ case PLACE -> org.bukkit.event.player.PlayerSignOpenEvent.Cause.PLACE;
|
||||||
|
+ case PLUGIN -> org.bukkit.event.player.PlayerSignOpenEvent.Cause.PLUGIN;
|
||||||
|
+ case INTERACT -> org.bukkit.event.player.PlayerSignOpenEvent.Cause.INTERACT;
|
||||||
|
+ case UNKNOWN -> org.bukkit.event.player.PlayerSignOpenEvent.Cause.UNKNOWN;
|
||||||
|
+ };
|
||||||
|
+ if (!org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerSignOpenEvent(entityhuman, tileentitysign, flag, legacyCause)) {
|
||||||
|
+ // Paper end - Add PlayerOpenSignEvent
|
||||||
+ return;
|
+ return;
|
||||||
+ }
|
+ }
|
||||||
+ // Craftbukkit end
|
+ } // Paper - Add PlayerOpenSignEvent
|
||||||
+ tileentitysign.setAllowedPlayerEditor(entityhuman.getUUID());
|
+ tileentitysign.setAllowedPlayerEditor(entityhuman.getUUID());
|
||||||
+ entityhuman.openTextEdit(tileentitysign, flag);
|
+ entityhuman.openTextEdit(tileentitysign, flag);
|
||||||
+ }
|
+ }
|
||||||
+
|
|
||||||
private boolean otherPlayerIsEditingSign(Player player, SignBlockEntity blockEntity) {
|
private boolean otherPlayerIsEditingSign(Player player, SignBlockEntity blockEntity) {
|
||||||
UUID uuid = blockEntity.getPlayerWhoMayEdit();
|
UUID uuid = blockEntity.getPlayerWhoMayEdit();
|
||||||
|
@@ -199,6 +225,6 @@
|
||||||
@@ -199,6 +208,6 @@
|
|
||||||
@Nullable
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public <T extends BlockEntity> BlockEntityTicker<T> getTicker(Level world, BlockState state, BlockEntityType<T> type) {
|
public <T extends BlockEntity> BlockEntityTicker<T> getTicker(Level world, BlockState state, BlockEntityType<T> type) {
|
||||||
|
|
|
@ -168,9 +168,15 @@ public class CraftSign<T extends SignBlockEntity> extends CraftBlockEntityState<
|
||||||
Preconditions.checkArgument(sign.isPlaced(), "Sign must be placed");
|
Preconditions.checkArgument(sign.isPlaced(), "Sign must be placed");
|
||||||
Preconditions.checkArgument(sign.getWorld() == player.getWorld(), "Sign must be in same world as Player");
|
Preconditions.checkArgument(sign.getWorld() == player.getWorld(), "Sign must be in same world as Player");
|
||||||
|
|
||||||
|
// Paper start - Add PlayerOpenSignEvent
|
||||||
|
io.papermc.paper.event.player.PlayerOpenSignEvent event = new io.papermc.paper.event.player.PlayerOpenSignEvent((Player) player, sign, side, io.papermc.paper.event.player.PlayerOpenSignEvent.Cause.PLUGIN);
|
||||||
|
if (!event.callEvent()) return;
|
||||||
|
if (PlayerSignOpenEvent.getHandlerList().getRegisteredListeners().length > 0) {
|
||||||
|
// Paper end - Add PlayerOpenSignEvent
|
||||||
if (!CraftEventFactory.callPlayerSignOpenEvent(player, sign, side, PlayerSignOpenEvent.Cause.PLUGIN)) {
|
if (!CraftEventFactory.callPlayerSignOpenEvent(player, sign, side, PlayerSignOpenEvent.Cause.PLUGIN)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
} // Paper - Add PlayerOpenSignEvent
|
||||||
|
|
||||||
SignBlockEntity handle = ((CraftSign<?>) sign).getTileEntity();
|
SignBlockEntity handle = ((CraftSign<?>) sign).getTileEntity();
|
||||||
handle.setAllowedPlayerEditor(player.getUniqueId());
|
handle.setAllowedPlayerEditor(player.getUniqueId());
|
||||||
|
|
Loading…
Reference in a new issue