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

[DRAFT] Overhaul Keyboard Functionality (For multiple keyboard layouts, and other functionality) #116

Draft
wants to merge 7 commits into
base: dev
Choose a base branch
from

Conversation

williamjohnstone
Copy link

@williamjohnstone williamjohnstone commented Jan 30, 2025

This PR is to introduce functionality for different keyboard mappings.

If you would like your mapping to be included in the initial PR, let me know and I will try my best.

Fixes #30

Store is functioning as expected, adding new layouts should be trivial and easily scalable.

Implementation is different for each function that uses the keyboard (PasteModal vs Typing in the WebRTC window) these will all require their own testing.
@williamjohnstone williamjohnstone changed the title [DRAFT] Early implementation of different keyboard layouts. [DRAFT] Add functionality for multiple keyboard layouts Jan 30, 2025
Nevexo added a commit to Nevexo/jetkvm-kvm that referenced this pull request Jan 30, 2025
Alters ActionBar.tsx to make the CTRL+ALT+DEL button in the Action Bar
PR work again with layered with jetkvm#116 - not pulling into the PR
until jetkvm#116 has been integrated, but the my PR will probably just be
dropped anyway.
Nevexo added a commit to Nevexo/jetkvm-kvm that referenced this pull request Jan 30, 2025
@PrinceJunkie
Copy link

PrinceJunkie commented Feb 1, 2025

Please include German Keyboard Layout

…ted settings.tsx to set the keyboard layout properly.
@williamjohnstone williamjohnstone changed the title [DRAFT] Add functionality for multiple keyboard layouts [DRAFT] Overhaul Keyboard Functionality (For multiple keyboard layouts, and other functionality) Feb 2, 2025
@williamjohnstone
Copy link
Author

williamjohnstone commented Feb 2, 2025

I have found further issues with the way that keyboard functionality is implemented, therefor the scope of work on this PR has been expanded.

I am working on this when I have time, thank you for everyone's continued patience.

@williamjohnstone
Copy link
Author

williamjohnstone commented Feb 2, 2025

This PR will now also resolve #125

…teModal to add more clarity to error message. Begin working on key remapping in WebRTC (working to a reasonable degree).
@stylobille
Copy link

Thank you for your help on this, I can test French keyboard if / when needed :)

… my changes (YAY!).

Also spent 4 hours troubleshooting to find out I didn't realise how useCallback works... :/

Anway, not much longer before work on just the mappings can begin.
@Rhaedyr
Copy link

Rhaedyr commented Feb 5, 2025

I know this may have been referenced, but I have a number of Hyprland systems I would love to use the JetKVM for but being able to use win/hyper key without the OS taking over would be immensely helpful, I would be happy to help test if you get to a testing phase, I might also be able to pitch in if I can find the time as well, Good Luck.

Adding an escape sequence in full screen to exit and send all keystrokes in fullscreen mode to the JetKVM might be a solution. say ctrl+alt+esc to exit fullscreen or the overlay exit button and use current system in windowed mode.

@williamjohnstone
Copy link
Author

williamjohnstone commented Feb 6, 2025

I know this may have been referenced, but I have a number of Hyprland systems I would love to use the JetKVM for but being able to use win/hyper key without the OS taking over would be immensely helpful, I would be happy to help test if you get to a testing phase, I might also be able to pitch in if I can find the time as well, Good Luck.

Adding an escape sequence in full screen to exit and send all keystrokes in fullscreen mode to the JetKVM might be a solution. say ctrl+alt+esc to exit fullscreen or the overlay exit button and use current system in windowed mode.

Yes, working on implementing the Keyboard Web API which should resolve this.

the problem is actually getting the browser to capture the keys, by default they are passed straight to the OS and the browser never sees them, which is why currently they don't function

@craxo
Copy link

craxo commented Feb 6, 2025

Please add support for Norwegian Bokmål:
https://kbdlayout.info/KBDNO/

Nevexo added a commit to Nevexo/jetkvm-kvm that referenced this pull request Feb 11, 2025
Alters ActionBar.tsx to make the CTRL+ALT+DEL button in the Action Bar
PR work again with layered with jetkvm#116 - not pulling into the PR
until jetkvm#116 has been integrated, but the my PR will probably just be
dropped anyway.
Nevexo added a commit to Nevexo/jetkvm-kvm that referenced this pull request Feb 11, 2025
Nevexo added a commit to Nevexo/jetkvm-kvm that referenced this pull request Feb 11, 2025
Alters ActionBar.tsx to make the CTRL+ALT+DEL button in the Action Bar
PR work again with layered with jetkvm#116 - not pulling into the PR
until jetkvm#116 has been integrated, but the my PR will probably just be
dropped anyway.
Nevexo added a commit to Nevexo/jetkvm-kvm that referenced this pull request Feb 11, 2025
@CLAassistant
Copy link

CLAassistant commented Feb 13, 2025

CLA assistant check
All committers have signed the CLA.

@williamjohnstone
Copy link
Author

Just wanted to post an update, to let everyone know I haven't abandoned this, just difficult to find the time to work on it currently.

@Nevexo
Copy link
Contributor

Nevexo commented Feb 24, 2025

Just wanted to post an update, to let everyone know I haven't abandoned this, just difficult to find the time to work on it currently.

Never worry about this, we're all incredibly thankful for the time you do spend on it.
Thanks!

…dded functionality to disable keyboard mapping.
@williamjohnstone
Copy link
Author

@PrinceJunkie German keyboard layout added, the first of a few I have planned.

@Nevexo Can you pull these changes into the upcoming jetkvm-next release? I'm keen to get some people testing as I don't have access to different keyboards.

I plan to now add many layouts first, to get main functionality working for as many as possible.

Then I will move onto adding support for the full screen keyboard API to capture keys like the super key while in fullscreen.

Then finally I will add support for the virtual keyboard with mappings

@Nevexo
Copy link
Contributor

Nevexo commented Feb 25, 2025

@Nevexo Can you pull these changes into the upcoming jetkvm-next release? I'm keen to get some people testing as I don't have access to different keyboards.

Will do, I'll get it out ASAP.

@timothystewart6
Copy link
Contributor

timothystewart6 commented Feb 26, 2025

@williamjohnstone this does not seem to resolve #125 You mention it here in your comment but I have tested this branch on my own fork and it didn't seem to have any effect on capturing hotkeys. #116 (comment)

@timothystewart6
Copy link
Contributor

Hopped on a call with @williamjohnstone and tested everything.

TLDR; Everything works and it was most likely my cable (3rd party USB C to USB A cable, not the one that ships 🤦)

  • Properly captures Hotkeys (ctrl + ctrl 1-4 and long with ctrl + ctrl arrow keys)
  • Also tested meta keys.
    • Using a mac and sending a commmand key sends the Windows Key
    • Works in both fullscreen and non fullscreen
    • Also works with key combos Windows + R opens run

Thank you!

@netinto
Copy link

netinto commented Mar 4, 2025

Please support Korean Layout.

https://kbdlayout.info/kbdkor

@toxic0berliner
Copy link

Was going to start tinkering when I saw you already did all the hard work, 🙏 thanks 👍
Looking forward to seeing it merged

@n-gerber
Copy link

Thank you very much.
Please add support for the swiss german layout.
Looking forward for it.

@williamjohnstone
Copy link
Author

I will not be adding any further keyboard layouts. Currently have UK, UK (Apple), US, German, and Spanish. It is too time consuming to add every layout and is taking time away from working on functionality. Therefor in the next week or so, I will complete the functionality of my changes, and finalise the Spanish layout. Then I will look to merge. The community can then add their own mappings as this is a trivial process.

I can assist in the mappings if people are having issues, but do not want to dedicate any more time to working on these mappings myself.

@timothystewart6
Copy link
Contributor

I agree. Once this is done it will provide a good pattern for adding more!

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.

Can't write/paste certain special characters using key combinations