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 native global menu support (macOS) #644

Merged
merged 1 commit into from
Jul 23, 2024

Conversation

aaronfranke
Copy link
Contributor

@aaronfranke aaronfranke commented Apr 9, 2024

Draft because I used the new Godot 4.3+ API so this will only work with Godot 4.3+. Follow-up to #643.

Screenshot 2024-04-09 at 4 33 47 AM Screenshot 2024-04-09 at 4 34 07 AM Screenshot 2024-04-09 at 4 34 17 AM Screenshot 2024-04-09 at 4 34 29 AM

This is not just about clicking buttons in the menu, it also provides convenient documentation for the user of what actions are available and which have keys available to press.
Screenshot 2024-04-09 at 4 33 14 AM

@MewPurPur
Copy link
Owner

Took a peek today, this seems too hard-coded. The shortcuts are only assigned on tree enter, and they don't seem to account for the user has changing the shortcuts. If necessary, you can add a custom notification for changed shortcuts in Utils.gd and listen to it here, fetching the first shortcut from each action instead.

I don't know the new 4.3 functionality though, maybe that's not possible.

@aaronfranke aaronfranke force-pushed the global-menu branch 2 times, most recently from 37de696 to 3175e02 Compare April 19, 2024 09:42
@MewPurPur
Copy link
Owner

Needs to be updated after #711.

Please check out the TranslationUtils class!

@MewPurPur MewPurPur force-pushed the main branch 2 times, most recently from a26b715 to 59b16bb Compare June 1, 2024 18:37
@MewPurPur
Copy link
Owner

MewPurPur commented Jun 6, 2024

We're on a 4.3 beta now, this can be considered.

(wait, what happened to this PR?)

@aaronfranke
Copy link
Contributor Author

(wait, what happened to this PR?)

It looks like you somehow managed to edit a commit from way back in the history, and force-push, which modified all commits beyond that point too. Don't worry, I can fix it easily, that is, whenever I get around to working on this.

@MewPurPur
Copy link
Owner

Okay, thanks! Yeah, I was doing some weird things to delete a file from the git history (a file which is no longer in the repo or even relevant, but made 80% of its size).

Copy link
Owner

@MewPurPur MewPurPur left a comment

Choose a reason for hiding this comment

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

TranslationUtils.get_shortcut_description() should be used when it can. Also, there's a SHORTCUTS_CHANGED custom notification now - the signal isn't needed. _action_call(action) could also be replaced with ShortcutUtils.fn_call(action).

Could you also replace the remaining tr() calls with TranslationServer.translate() instead? We decided recently to always use this version because it can be used in static functions.

Also open the "update_translations.gd" script to update translations automatically after you're done.

@aaronfranke aaronfranke force-pushed the global-menu branch 2 times, most recently from 09eb23c to 69cb677 Compare July 23, 2024 01:34
@aaronfranke aaronfranke marked this pull request as ready for review July 23, 2024 01:36
@aaronfranke
Copy link
Contributor Author

TranslationUtils.get_shortcut_description() should be used when it can.

Done.

Also, there's a SHORTCUTS_CHANGED custom notification now - the signal isn't needed.

I'm not sure, it doesn't seem the same. Also, isn't a notification worse than a signal? A notification is propagated to everything, while a signal is only propagated to what connects to it.

_action_call(action) could also be replaced with ShortcutUtils.fn_call(action).

I don't think so? ShortcutUtils.fn_call doesn't handle everything.

Could you also replace the remaining tr() calls with TranslationServer.translate() instead?

Done.

Also open the "update_translations.gd" script to update translations automatically after you're done.

Done (and I discarded changes to the po/pot files made before running this script, so the changes to the po/pot files in this PR are purely from the script).



func _setup_menu_items() -> void:
# Included App and Help menus.
Copy link
Owner

Choose a reason for hiding this comment

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

TranslationUtils should be used here to get the translated string of "open_settings". Same for the lines of code below. That way it's ensured that they are the same everywhere.

@MewPurPur
Copy link
Owner

Thanks!

@MewPurPur MewPurPur merged commit 178b45e into MewPurPur:main Jul 23, 2024
2 checks passed
@aaronfranke aaronfranke deleted the global-menu branch July 23, 2024 08:12
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.

2 participants