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

Custom Keybinds #18

Open
TheKodeToad opened this issue Apr 23, 2023 · 66 comments · May be fixed by #326
Open

Custom Keybinds #18

TheKodeToad opened this issue Apr 23, 2023 · 66 comments · May be fixed by #326
Labels
enhancement New feature or request

Comments

@TheKodeToad
Copy link
Contributor

image

@Vendicated Vendicated added the enhancement New feature or request label May 3, 2023
@makidoll
Copy link

I really love Vencord, it's so nice to use including the better screen sharing support on Linux. But this is the only feature I really wish it had. I wonder if it can be done with a plugin?

@hypevhs
Copy link

hypevhs commented Nov 11, 2023

I'm thinking of leveraging the new PluginNative functionality that was committed to Vencord a few days ago.
It'd expose any keybindable Discord action (but mainly PTT, initially) to the kglobalaccel DBus, allowing users to setup keybinds via KDE systemsettings.

@D3SOX
Copy link
Contributor

D3SOX commented Nov 11, 2023

We already talked about this in the Discord and I think it would probably be better to just implement this in Vesktop using Electron global shortcuts API as this is already cross-platform
This also makes it easier to implement a UI directly inside Discord for it

The only disadvantage is that it wouldn't work for the browser extension this way

@Vendicated
Copy link
Member

Vendicated commented Nov 11, 2023

yes, this should definitely be part of vesktop and not a plugin

either via electron's global shortcut api, or via iohook

the former does not support things like mouse side buttons and has no way to implement PTT, the latter would require a native module

@Curve
Copy link
Member

Curve commented Nov 11, 2023

yes, this should definitely be part of vesktop and not a plugin

either via electron's global shortcut api, or via iohook

the former does not support things like mouse side buttons and has no way to implement PTT, the latter would require a native module

Correct me if I'm wrong but as the latter uses libuiohook I think that it will not support wayland.

I think the electron shortcut API is the right way to go as it is probably the most portable and clean

Edit: Just checked and libuiohook does not support wayland

@RinLovesYou
Copy link

I am working on this. iohook is old and unmaintained. I am using uiohook-naapi to do this. it also uses libuiohook, and it seems wayland support is in the works. Nothing you can do but wait until libuiohook updates for that, but i'll go ahead and keep using it.

@Curve
Copy link
Member

Curve commented Nov 16, 2023

I am working on this. iohook is old and unmaintained. I am using uiohook-naapi to do this. it also uses libuiohook, and it seems wayland support is in the works. Nothing you can do but wait until libuiohook updates for that, but i'll go ahead and keep using it.

Why not use the xdg-desktop-shortcuts? It's way more clean & portable imo (no low level hooking and such)

@RinLovesYou
Copy link

Didn't know about those, I'll look into it

@RinLovesYou
Copy link

Although the question here is, is it beneficial to do this, when we'd need a separate, likely more low-level implementation for windows/mac? from my understanding libuiohook works on all platforms

@Curve
Copy link
Member

Curve commented Nov 17, 2023

Although the question here is, is it beneficial to do this, when we'd need a separate, likely more low-level implementation for windows/mac? from my understanding libuiohook works on all platforms

For windows one could use RegisterHotKey, which allows for less combinations of keys but also comes with less drawbacks, not sure on MacOS though, I'd suspect they also have some sort of system API for hotkeys instead of allowing for low level hooks

Edit: This is a rather difficult topic as all platforms do it differently, I don't think there's any library out there supporting xdg-desktop-shortcuts, Windows' RegisterHotKey and MacOS - I may write one myself soon as I'd need something like this for Soundux anyways

@RinLovesYou
Copy link

RinLovesYou commented Nov 17, 2023

libuiohook may not be using these exact things, but it already supports all these platforms.. why reinvent the wheel? It also seemingly has less limitations than RegisterHotKey

@Curve
Copy link
Member

Curve commented Nov 17, 2023

libuiohook may not be using these exact things, but it already supports all these platforms.. why reinvent the wheel? It also seemingly has less limitations than RegisterHotKey

Low Level Keyboard Hooks are not exactly a good practice imo.

We've been using them in soundux and have faced several issues:

  • Due to their nature, they will not work on Wayland at all

  • Low-Level keyboard hooks require custom logic that is not always the same as that implemented by the system and may confuse users due to subtle differences

  • Especially on Windows, we've encountered several issues:

    • Depending on the implementation, all system input may lag when the application that has the keys hooked lags
    • some anti cheats seem to have issues with this approach and will out right block the hook thus preventing hotkeys from working

If one wants to better integrate with the target system, xdg-desktop-shortcuts is the way to go on Linux imho, as for the other platforms it's up to the developer on which approach he wants to take, but as listed above there are also several disadvantages to low Level Keyboard Hooks on Windows

@hypevhs
Copy link

hypevhs commented Nov 18, 2023

I agree that Linux Vesktop should be using xdg-desktop-portal GlobalShortcuts.
Compared to my previous suggestion, it has the benefit of being Desktop Environment-agnostic. It would also make it compatible with Flakpak, for the folks who use that. The DBus interface is at org.freedesktop.portal.GlobalShortcuts.

It would be nice to have it implemented in Electron as a part of the existing global shortcuts API, then Vesktop could use it and be OS agnostic.
electron/electron#38288

@tuxinal tuxinal linked a pull request Jan 7, 2024 that will close this issue
@tuxinal
Copy link

tuxinal commented Jan 8, 2024

xdg-desktop-portal's globalshortcuts api isn't implemented in most implementations. i don't think it's viable to use.
perhaps we could use libuiohook and for wayland users we could have a way of hooking up a shortcut in their wm to a specific action?

@Curve
Copy link
Member

Curve commented Jan 8, 2024

xdg-desktop-portal's globalshortcuts api isn't implemented in most implementations. i don't think it's viable to use.

I think it would be good practice to adopt this already even though some WMs don't have it implemented already (KDE has already) because it will probably become the standard soon (especially since it's designed to become a standard)

perhaps we could use libuiohook and for wayland users we could have a way of hooking up a shortcut in their wm to a specific action?

This is also not too bad, one could use some sort of cli to trigger certain actions in vesktop - However I don't think it would really be worth the effort especially since we'd probably want to switch to x-d-p implementation once it's more wide spread

@Curve
Copy link
Member

Curve commented Jan 8, 2024

Perhaps I could implement a native module similar to libuiohook which supports x-d-p global shortcuts as well as a X11 Keyboard Hook and Windows either through a LL-Keyboard Hook (and maybe even RegisterHotkey).

I'd need a library like that for personal projects anyways, in case this would be of consideration for Vesktop, are there any preferences on how the API should look like?

@qlum
Copy link

qlum commented Mar 26, 2024

For me personally this would be a great improvement, right now on Wayland I have to choose between having no Push-To-Talk using vencord in browser or via the client, but having working screen capture. Or the default client with no working screen capture and less important no plugins.

As far as I know there is no software solution that allows both push-to-talk and screen capture on Wayland.
In practice for me this means falling back to the default client to talk in voice, be it without good screen capture.

@EntityReborn
Copy link

Could there be an API-based solution for this? Specifically expose some sort of API and allow platform specific applications like AHK to plug into these APIs?

@tuxinal
Copy link

tuxinal commented Apr 12, 2024

if you check out #326 the most recent commit kinda does that. it exposes a cli that can execute different keybinds by code. though i was thinking this would be used as fallback.
plans are being made for better ways to do this but i am really busy with school as of right now and can't really contribute much.

@x86-39
Copy link

x86-39 commented Apr 18, 2024

if you check out #326 the most recent commit kinda does that. it exposes a cli that can execute different keybinds by code. though i was thinking this would be used as fallback. plans are being made for better ways to do this but i am really busy with school as of right now and can't really contribute much.

This looks like a great first step! Does this only work for oneshot keybinds or would this work with push to talk too potentially in the future?

@tuxinal
Copy link

tuxinal commented Apr 18, 2024

the older(and now removed) electron api based global shortcut handler didn't at all support push to talk
the current cli doesn't handle pressed and unpressed states tho it should be super easy to add
we are planning better ways to do this. i was thinking the cli could be used as fallback for wayland users. currently the only way to handle keybinds for wayland users is through xdg-desktop-portals which last time i checked didn't really have a mature implentation of this. though it probably has gotten better.

@TheBoctor
Copy link

Strongly in favor of a socket or CLI interface for controlling the push-to-talk up/down events. It could be invaluable as both a stopgap solution and as a fallback, even if it is more of a DIY approach.

This workaround runs as a privileged process (or with the desired device made user-readable) and listens for evdev events on a given device/button, and then forwards a given Xorg key event to XWayland, via libxdo (using the XTEST extension protocol). This is the relatively brittle hack that I currently use to have global PTT support the official client.

it works on Arch for now, but is completely broken on Fedora with GNOME. Fedora (and maybe more distros, in the future) build their gnome-shell/mutter with support for an input emulation library, which consumes the events from XTEST. Every time a GNOME user on Fedora attempts to send simulated events to XWayland, an XDG portal "remote access" dialog pops up. Even when you choose to allow access from this dialog, the events never actually get sent to XWayland and its clients.

If Vesktop had an interface to control the PTT microphone state, I could simply take the existing evdev listener program and bolt it onto that, in place of libxdo. This workaround would not be exclusive to Wayland nor Xorg, and would not require waiting for the XDG Global Shortcuts implementations to land in each DE (and in Electron.)

@AAGaming00
Copy link
Contributor

AAGaming00 commented Apr 21, 2024

just use global shortcuts portal and x11 can cope

allowing external control seems smart tho as a separate option

@TheBoctor
Copy link

just use global shortcuts portal and x11 can cope

allowing external control seems smart tho as a separate option

The thing about the XDG global shortcut protocol, if I'm not mistaken, is that it will still take a while longer for the implementations to appear. Especially outside of rolling distros that follow upstream closely. Even though the protocol/spec itself is complete, and Plasma is said to support it, GNOME and wlroots are still in the design phases of their implementations. (This is absolutely not intended as criticism or impatience; I know these are all volunteer-driven projects, wanting to design things as correctly and maintainably as possible.)

Electron still has its own issue open (linked further up this thread), discussing how best to support the XDG global shortcuts protocol, or whether it can be done transparently in a way that replaces the old global shortcut system. With the external control interface as a stopgap, even once those pieces did fall into place, Vesktop could have a relatively stable option that is entirely compositor/desktop-agnostic, but also separate enough (like you said) that any future changes in Electron would likely not conflict with it.

I do not disagree on anything per se, but only wanted to articulate how/why I believe the external control or CLI would be equally helpful to Xorg and Wayland users in the meantime, regardless of their distro or package versions, and not require waiting for other projects to catch up.

@iiPythonx
Copy link

Might not belong here, but in addition to adding custom keybinds could there also be a feature to disable discord's default keybinds? Ex. disabling CTRL+' to start a group call.

@Sqaaakoi
Copy link

Might not belong here, but in addition to adding custom keybinds could there also be a feature to disable discord's default keybinds? Ex. disabling CTRL+' to start a group call.

with the regular discord client you could create keybinds and leave them unassigned to do this

@krzysiula3000
Copy link

will this be implemented? i really hope it will

@PolisanTheEasyNick
Copy link
Contributor

Can't we do bindings like discord screenaudio?

I will take a look at #609

@tuxinal
Copy link

tuxinal commented May 30, 2024

my pr has a cli for this purpose. i have also added support for keyup/down states in my most recent commit.

@TheBoctor
Copy link

Can't we do bindings like discord screenaudio?

That's dependent on KGlobalAccel, correct?

@PolisanTheEasyNick
Copy link
Contributor

That's dependent on KGlobalAccel, correct?

Looks like it is. I'm not sure that we can use it directly it TS code, so for implementing this behavior we can write some C++ helper code (?). But here is the question of why if we can use just default custom keybinds and do not complicate the project structure.
discord-screenaudio is already on C++ so using KGlobalAccel is way easier for them.

@Curve
Copy link
Member

Curve commented May 30, 2024

That's dependent on KGlobalAccel, correct?

Looks like it is. I'm not sure that we can use it directly it TS code, so for implementing this behavior we can write some C++ helper code (?). But here is the question of why if we can use just default custom keybinds and do not complicate the project structure.
discord-screenaudio is already on C++ so using KGlobalAccel is way easier for them.

#18 (comment)

@TheBoctor
Copy link

I am not sure if KGlobalAccel supports sending separate key up/down events, either, which are pretty much a requirement for PTT. I would absolutely second the XDG Global Shortcuts module idea, depending on how difficult you think it'd be. Unless bolting on C++ is unacceptably messy and a blocker in its own right. Or unless there's a TS API I'm not aware of, for udev or XDG shortcuts. I have not seen any relevant activity, lately, in upstream Electron.

I can confirm Plasma's global shortcut portal works great. It's exposed in the same System Settings menu seen in the recent screenshot. I've played with it using this example C++/Qt application. Hyprland claims support, too, but I have personally never tried that compositor. GNOME has a contributor actively working on implementing it in the same manner as Plasma (inside their existing keyboard settings.)

@Curve
Copy link
Member

Curve commented May 30, 2024

Unless bolting on C++ is unacceptably messy and a blocker in its own right

Not sure what you mean here, venmic is already written entirely in C++

@TheBoctor
Copy link

Unless bolting on C++ is unacceptably messy and a blocker in its own right

Not sure what you mean here, venmic is already written entirely in C++

That does answer my question (whether the developers are okay with features that would require C++ helpers.) Sorry if it was poorly phrased. I had not seen that there was a separate repo for Pipewire screenshare, so at a glance, it looked like the project could've been aiming for as much pure TypeScript as possible.

@Yumeo0
Copy link

Yumeo0 commented Jun 18, 2024

Just quickly adding that GNOME should support the XDG Global Shortcuts soon enough (hopefully). Here's the open merge request if anyone wants to keep up with it.

@1cadumagalhaes
Copy link

Hey @tuxinal , can I help w something?
I'm very interested in the keybinds, and I also would like to add some things that the discord official client doesn't have (such as toggle noise supression)

@Vendicated Vendicated mentioned this issue Jul 19, 2024
11 tasks
@Damglador

This comment was marked as spam.

@rbutera
Copy link

rbutera commented Aug 25, 2024

are there any workarounds at the moment to enable global push to talk in vesktop?

@TheBoctor
Copy link

are there any workarounds at the moment to enable global push to talk in vesktop?

Does building with #326 or #609 work for your use case?

Alternate/standalone workarounds If not, there are a few projects on GitHub to do this globally, by using the Pipewire API to toggle the entire mic. Push2talk is quite polished, but does not currently support binding mouse buttons. I ended up kludging a C++ equivalent for my personal use case involving mouse buttons and foot pedals. I have been using it for 3 months without problems.

Note that since these evdev+Pipewire approaches don't rely on xdo or portals, they'll work across all X WMs and Wayland compositors. However, the user running the program must belong to the `input` group or be root, so this is not as secure as the XDG portal approach.

@rbutera
Copy link

rbutera commented Aug 27, 2024

are there any workarounds at the moment to enable global push to talk in vesktop?

Does building with #326 or #609 work for your use case?

Alternate/standalone workarounds If not, there are a few projects on GitHub to do this globally, by using the Pipewire API to toggle the entire mic. Push2talk is quite polished, but does not currently support binding mouse buttons. I ended up kludging a C++ equivalent for my personal use case involving mouse buttons and foot pedals. I have been using it for 3 months without problems.

Note that since these evdev+Pipewire approaches don't rely on xdo or portals, they'll work across all X WMs and Wayland compositors. However, the user running the program must belong to the `input` group or be root, so this is not as secure as the XDG portal approach.

I'm embarrassed to admit that my skills aren't that great, but here's my analysis of those PRs:

  1. feat: Add global shortcuts #326 says "i'm using electron's globalShortcuts api here which doesn't have a way to detect tell the difference between keyup and keydown. this means the push to talk/mute/deafen/etc actions don't really work" - therefore I don't think it would work for push to talk!
  2. I feel like a dumbass but I have no idea how I would use feat: Toggle voice status using fifo pipe #609 and setup push to talk in Hyprland. Maybe someone smarter than me can tell me what I could do

@cpiber
Copy link

cpiber commented Aug 27, 2024

@rbutera Since you mention Hyprland: they have support for the pass dispatcher, which you can use. See also hyprwm/Hyprland#2072

@tuxinal
Copy link

tuxinal commented Aug 27, 2024

@rbutera i'm no longer using electron's api

@rbutera
Copy link

rbutera commented Sep 9, 2024

@rbutera Since you mention Hyprland: they have support for the pass dispatcher, which you can use. See also hyprwm/Hyprland#2072

Thanks @cpiber i was able to get discords official push to talk working using the pass dispatcher.

For some reason Vesktop doesnt respond to push to talk even if I'm using that dispatcher. I can bind the key in voice/video but even if Vesktop is focused I can't get my mic to activate.

@tuxinal do you think your work will be relevant to this situation?

I'd really like to use vesktop as my main discord client and this is the last obstacle for me

@tuxinal
Copy link

tuxinal commented Sep 9, 2024

for hyprland specifically we should be able to support it through x-d-p globalshortcuts when it's implemented in venbind: https://wiki.hyprland.org/Configuring/Binds/#dbus-global-shortcuts

but for now you can use my PR and hook up your own keybinds to the current cli

@Oroborius

This comment was marked as spam.

@OrHy3
Copy link

OrHy3 commented Oct 25, 2024

Preface: I don't know sh about the project's structure. I don't even write TypeScript.

In the past few days I've been writing down a keylogger that relies on libevdev. If anyone here is interested in even taking a look, it's there. If you guys prefer to wait for the Portals implementation, fine, but I'm pretty sure Vesktop will need some sort of an abstract interface, even when Portals will be there. I'm proposing this as a temporary solution anyway.

The idea would be to combine it with something like pkexec, since it needs input privileges.

Thoughts?

@lifebound
Copy link

Vesktop didn't want to tackle this because it should be done at the Electron level. Electron didn't want to do it because they are trying to adhere to Chromium as closely as possible. It was submitted as a feature request to the chromium team all the way back in April.

As of Nov 19, a change for GlobalShortcutListeners for Linux was merged into Chromium, so hopefully this will be coming downstream shortly.

@Benj2005
Copy link

Vesktop didn't want to tackle this because it should be done at the Electron level. Electron didn't want to do it because they are trying to adhere to Chromium as closely as possible. It was submitted as a feature request to the chromium team all the way back in April.

As of Nov 19, a change for GlobalShortcutListeners for Linux was merged into Chromium, so hopefully this will be coming downstream shortly.

Relevant Electron PR: electron/electron#44748
Although I'm not sure if Electron have to manually implement the new GlobalShortcutListenerLinux or it just works out of the box.

@Covkie
Copy link
Collaborator

Covkie commented Nov 22, 2024

Electron doesn't support up/down events (needed for PTT) so this is still not usable for Vesktop's needs

@lifebound
Copy link

Isn't the desktop app also built on Electron? How is vanilla Discord handling it, if Electron doesn't support up/down?

@Vendicated
Copy link
Member

Discord uses their own native module written in C++

@mil1i

This comment was marked as off-topic.

@Benj2005

This comment was marked as off-topic.

@Damglador

This comment was marked as off-topic.

@Vencord Vencord locked as off-topic and limited conversation to collaborators Nov 23, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
enhancement New feature or request
Projects
None yet
Development

Successfully merging a pull request may close this issue.