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

Adding hotkey to go to notification event #1707

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

Conversation

sjoblomj
Copy link

Pressing g will go to the position of the latest notification. If the notification window is open, pressing g will go to the position of the currently open notification.

Closes #1539.

@@ -63,6 +63,12 @@ const PostMsg* PostBox::GetMsg(unsigned idx) const
return messages[idx].get();
}

const PostMsg* PostBox::GetCurrentMsg() const
{
unsigned idx = currMsgIdx >= 0 && currMsgIdx < (int) numMessages ? currMsgIdx : numMessages - 1;
Copy link
Member

Choose a reason for hiding this comment

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

Is the possible underflow for numMessages == 0 intended?

Maybe be explicit and do:

if(curMsgIdx < 0 || numMessages == 0)
    return nullptr;

Afterwards you can use static_cast<unsigned>(currMsgIdx) safely instead of the (C-style) cast to int.

Copy link
Author

Choose a reason for hiding this comment

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

It is intended, since GetMsg checks that the index is within bounds and returns nullptr if not. But you're right that it's probably best to be explicit about it. 👍

Copy link
Author

@sjoblomj sjoblomj Oct 15, 2024

Choose a reason for hiding this comment

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

I added a check in a new commit to make sure the index is within bounds. Checking that currMsgIdx < 0 - as you suggest - does not make sense though, since currMsgIdx == -1 whenever the notification window is closed. In that case, we get the the most recent notification (numMessages - 1).

@Flamefire
Copy link
Member

Although the change looks good to me I'm wondering why the existing code doesn't work:

case 'g': // Go to site of event
Msg_ButtonClick(ID_GOTO);
return true;

That should suffice. If it doesn't then I guess the window isn't active anymore so it doesn't get the events. In that case I'm wondering if we should even react on the key event.

From the issue:

In the old settlers [...] would click "n" to open the notification window, "enter" to go to the notification site, then "del" to remove the notification.

If 'g' doesn't work then 'del' wouldn't either and we'd need to fix that too. To handle those (kind of) window-specific events in the desktop is not really "clean" and might lead to issues when another window uses the same key for something. So we should really check if and why it currently does not work and rather fix that. If it is only that the window lost focus due to clicking somewhere else the workaround would simply be to press 'n' again (or click inside the window), but IIRC the window is supposed the get the event first before the desktop, but I'd need to check too.

@sjoblomj
Copy link
Author

Although the change looks good to me I'm wondering why the existing code doesn't work:

case 'g': // Go to site of event
Msg_ButtonClick(ID_GOTO);
return true;

That should suffice. If it doesn't then I guess the window isn't active anymore so it doesn't get the events. In that case I'm wondering if we should even react on the key event.

From the issue:

In the old settlers [...] would click "n" to open the notification window, "enter" to go to the notification site, then "del" to remove the notification.

If 'g' doesn't work then 'del' wouldn't either and we'd need to fix that too. To handle those (kind of) window-specific events in the desktop is not really "clean" and might lead to issues when another window uses the same key for something. So we should really check if and why it currently does not work and rather fix that. If it is only that the window lost focus due to clicking somewhere else the workaround would simply be to press 'n' again (or click inside the window), but IIRC the window is supposed the get the event first before the desktop, but I'd need to check too.

Like you say, the notification window also has a hotkey for g which goes to the position of the currently open message. And like you say, the notification window must be focused for this to work; so if the player has clicked on the game interface or another window, this no longer works.

So, the bigger question would be if the game interface should also have this hotkey or not, regardless of whether the notification window is open, which is what this PR implements. I'm not too familiar with the code, but I suppose it could be hairy to 1) let unfocused windows receive key strokes first, and 2) make sure different unfocused windows don't have the same key binding for different things.

Regardless, the current behavior is a bit of an annoyance, where you'd think pressing g would take you to the position of the event, but it turns out the notification window has lost focus and nothing happens.

As for the question of the other keys: If the del key should also have a similar functionality as g in this PR, I'd argue that there should be checks to make sure the notification window is open (but possibly unfocused) - otherwise it seems like the player could delete messages by mistake, possibly without even realizing it.

@Flamefire
Copy link
Member

So, the bigger question would be if the game interface should also have this hotkey or not, regardless of whether the notification window is open

I don't think it is a good idea to have that jump-to when the window is not open. It might seem quite random, especially as a newer message might have arrived so the jump position is not fully predictable. Of course that might be a feature: Jump to position of latest notification.

the notification window must be focused for this to work; so if the player has clicked on the game interface or another window, this no longer works.

In combination with the above I lean towards that this is supposed to work that way. Are people really having the post window open all the time while doing something else? Pressing "n" and then "g" should always work, so that would only be one additional key press.

Do we have any other windows with hotkeys that exist in the original S2? Then we could test how the behavior with respect to focused windows worked there. Maybe @Spikeone knows more or has suggestions.

@Flamefire
Copy link
Member

Coming back to this:

I tested the original S2 and the behavior is the same as in RttR: When the notification window is focused the "g" key is handle, otherwise not.
So reacting to the hotkey when the window is not focused would be an extension/change in RttR.

The current implementation has still 2 issues:

  • I'm note sure that introducing the concept of a "current message" to the Postbox is a good idea from a design point: The current message is a concept from the view/presentation layer so should IMO be kept there
  • When a message without a location gets shown the "current message" doesn't get updated. This makes the concept a bit unclear and might seem random if the view jumps to the location of a message that isn't currently shown

Idea: On keypress in the desktop try to get the post window (FindNonModalWindow(CGI_POST_OFFICE)) and if there is one relay the whole message/event to that window. That will then handle the keypress as-if it was focused.
That avoids any changes to the "data structure" and automatically makes the behavior of focused or unfocused post window consistent.

What do you think?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Missing hotkey for "Go to notification"
2 participants