Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add API for client-side signs #11903

Open
wants to merge 3 commits into
base: main
Choose a base branch
from
Open

Conversation

Sytm
Copy link
Contributor

@Sytm Sytm commented Jan 4, 2025

Allows using the editing of signs that are not placed on the server as text-input without meddling with packets.

Original: #9786

@Sytm Sytm requested a review from a team as a code owner January 4, 2025 13:13
@NoahvdAa NoahvdAa added the type: feature Request for a new Feature. label Jan 4, 2025
@lynxplay lynxplay force-pushed the client-side-sign-hf branch from fd457fc to 3e064ce Compare January 12, 2025 21:11
* Called when a client attempts to modify a sign, but the location at which the sign should be edited
* has not yet been checked for the existence of a real sign.
* <p>
* Cancelling this event will prevent further processing of the sign change, but needs further handling
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In regards to this, is there a point in us just resending the block?
Usage of this event would always be with "ephemeral" signs.

Leaving this up to plugin developers feels pretty meh.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I also pondered about doing it that way, but at the end I thought the event should just report back that the player tried to edit a sign and minimize other side effects.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I mean, it's unchecked, and so I generally expect it to be a lot more 'dumb' in terms of how it interacts. I feel that such low level events are always going to be kinda meh

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Well I would not mind it if this event was low level on purely client side signs.
But the fact that this is also called for actual in-world signs makes this pretty annoying/easy to fuck up potentially leaving normal signs out of sync.

Could potentially have some cancel overload that allows passing some RESEND flag?

* <p>
* The sign must only be placed locally for the player, which can be done with {@link #sendBlockChange(Location, BlockData)} and {@link #sendBlockUpdate(Location, TileState)}.
* A side-effect of this is that normal events, like {@link org.bukkit.event.block.SignChangeEvent} will not be called (unless there is an actual sign in the world).
* </p>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it should be noted that the fake sign needs to be within 9 blocks of the player.
(It's block interaction range + 4).

If it's too far away, the sign will immediately close.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type: feature Request for a new Feature.
Projects
Status: PR Party candidate
Development

Successfully merging this pull request may close these issues.

8 participants