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

Helix keymap #4642

Open
humb1t opened this issue Jul 4, 2023 · 41 comments · May be fixed by #19175
Open

Helix keymap #4642

humb1t opened this issue Jul 4, 2023 · 41 comments · May be fixed by #19175
Labels
enhancement [core label] keymap / key binding Feedback for keyboard shortcuts, key mapping, etc

Comments

@humb1t
Copy link

humb1t commented Jul 4, 2023

I know it can be tricky, but the only reason preventing me from day to day use of zed is Helix with their beautiful system based on keys without mouse, multiple selections and other features.

Will be great to support that and maybe I will try to research possible ways to do so:
https://docs.helix-editor.com/keymap.html

@JosephTLyons JosephTLyons transferred this issue from zed-industries/keymaps Jul 19, 2023
@JosephTLyons JosephTLyons added enhancement [core label] keymap / key binding Feedback for keyboard shortcuts, key mapping, etc labels Jul 19, 2023
@ConradIrwin ConradIrwin mentioned this issue Sep 27, 2023
1 task
@3210jr
Copy link

3210jr commented Jan 1, 2024

Zed is pretty awesome and support for the helix bindings would be nice. Can we do a bounty for someone from the community/core to get this running? I am not so skilled myself 😀.

I can do $100 for anything helix bindings related.

@JosephTLyons
Copy link
Collaborator

JosephTLyons commented Jan 1, 2024

Zed is pretty awesome and support for the helix bindings would be nice. Can we do a bounty for someone from the community/core to get this running? I am not so skilled myself 😀.

I can do $100 for anything helix bindings related.

Hey @3210jr - this is an extremely nice gesture; if I had to guess, I think the biggest blocker isn't that someone doesn't want to do it, it is probably more that at the moment, contributing to keymaps is a bit awkward at the moment. We don't have documentation on what all the contexts are, the source code of Zed is closed (not for much longer 🥳), the keymaps repository is simply a mirror of the internal files in Zed, so changes made to either end have to be manually copied and pasted between repos. It's all just very awkward and sort of hard to do. Someone could still do it for sure, but the process is kind of ugly and not user friendly. I imagine that once we are open source, and once we move keymaps into some sort of user-accessible directory, or plugin system, that we will have a lot more fixes to existing keymaps, and new keymaps in general, coming in.

@JosephTLyons JosephTLyons transferred this issue from zed-industries/community Jan 24, 2024
@nyabinary
Copy link

Zed + Helix would be extremely nice :3

@alphabitserial
Copy link

I would absolutely love to have this. I've been using Helix as my main editor for several months. Having a GUI with the same ergonomics would be fantastic.

@seanchen1991
Copy link

Now that the repository has been open-sourced, what would be a rough outline of adding Helix keymap support? 🙂

@danriedl
Copy link

I would absolutely love to have this. I've been using Helix as my main editor for several months. Having a GUI with the same ergonomics would be fantastic.

I'm in the same spot but have to say, that i'll stick to helix itself.
Tried helix - binding in vscode but still it's not the same experience.

@ascarter
Copy link

@JosephTLyons I think the request here would be to do a modal keymap that is Selection-Action instead of Action-Selection. There are multiple modal editors now (which Helix is probably one of the best) that use this model. If Zed could support it, would be really cool to see.

Another thought long term - NeoVim crew embedded their engine into VS Code. You can run the editor window using NeoVim but within the rest of VS Code. Would be very interesting for Zed to do something like this where another terminal type engine could power the editor. Maybe a chance to get the best of both worlds.

@andreweades
Copy link

I would like to look into this as I use Helix in preference to vim when I can. But how to do it? Is it a complete new mode? Or is it a key-binding hack on vim-mode?

@clo4
Copy link
Contributor

clo4 commented Feb 7, 2024

@andreweades You'd have to introduce a new helix crate to implement some of the actions, and create a new keymap to use the actions. It's distinct enough from Vim that it would probably warrant a new editing mode, because selection->action really is a distinct paradigm from action->motion. But it might be worth taking a step back and instead of just copying the Helix keymap thinking about what it might look like to design a selection->action keymap just for Zed. Most of the infrastructure is already there! Would it feel different from Kakoune and Helix given it's in a GUI editor?

@wmstack
Copy link

wmstack commented Feb 16, 2024

Also I do like the helix bindings but I don't like to retain the selection when returning using insert mode or append mode. I have this mapped in helix a = ['append_mode', 'collapse_selection'] and i = ['insert_mode', 'collapse_selection']. I hope similar bindings can be supported in Zed.

Also vim doesn't really allow you to select the newline character (or the emptiness at the end of the buffer). Helix does. I have a hard time differentiating a whitespace from a newline in helix so I hope the cursor changes colour or something when it is on a newline character.

@WarrenAdams8

This comment was marked as spam.

@andreweades
Copy link

@clo4 Good point. I use a custom Helix keymap as some of my muscle memory from VIM does not translate well. I try to limit the amount of mousing as after 30+ years of mousing I have RSI in my shoulder so I like editors that have VIM and now Helix keys. I think selection->action makes a lot of sense so I would love to see it in Zed at some point and would not mind contributing when I have time.

@wmstack
Copy link

wmstack commented Mar 3, 2024

@JosephTLyons I wonder why this is not in the top ranking issues? It has more votes than a lot of the ones I see there. Is it because it doesn't neatly fit into one of the categories? Maybe it should be in the vim section.

@JosephTLyons
Copy link
Collaborator

@JosephTLyons I wonder why this is not in the top ranking issues? It has more votes than a lot of the ones I see there. Is it because it doesn't neatly fit into one of the categories? Maybe it should be in the vim section.

This would only be included on the top-ranking issues report if it had more likes than the item at the bottom of the enhancement section (Git in-line blame indicators - 81 👍).

ConradIrwin pushed a commit that referenced this issue Mar 21, 2024
This PR is a bit of a shot in the dark. I'm not sure if this will be
acceptable and I understand if it gets rejected.

I've been trying to integrate Zed as my daily driver and the key
bindings have been a major hurdle for me. Mostly due to the
windows/linux keybindings being messed up, but also me wanting to have
more chained key bindings similar to helix or common in custom neovim
configurations.

I think having a `None` base keymap would allow someone to more easily
implement a new base keymap (#4642) and would make my daily use of Zed a
little nicer 😅.

Also I am aware that there would need to be a little more work done in
this PR for the other base keymaps such as 'atom' since they assume the
'default' (vscode) base keymaps are loaded. I'm happy to do that work if
a 'none' base keymap is acceptable.

Release Notes:

- Added ability to specify no base keymap which allows for full
keybinding customization
pjlast pushed a commit to pjlast/zed that referenced this issue Mar 26, 2024
This PR is a bit of a shot in the dark. I'm not sure if this will be
acceptable and I understand if it gets rejected.

I've been trying to integrate Zed as my daily driver and the key
bindings have been a major hurdle for me. Mostly due to the
windows/linux keybindings being messed up, but also me wanting to have
more chained key bindings similar to helix or common in custom neovim
configurations.

I think having a `None` base keymap would allow someone to more easily
implement a new base keymap (zed-industries#4642) and would make my daily use of Zed a
little nicer 😅.

Also I am aware that there would need to be a little more work done in
this PR for the other base keymaps such as 'atom' since they assume the
'default' (vscode) base keymaps are loaded. I'm happy to do that work if
a 'none' base keymap is acceptable.

Release Notes:

- Added ability to specify no base keymap which allows for full
keybinding customization
@blufony blufony mentioned this issue Apr 28, 2024
6 tasks
@zoedsoupe
Copy link

i would love to have helix support inside zed 💜

how i could contribute to achieve this new crate? i'm not the very best rust developer but i think i can mimic the vim crate somehow and do some tweaks to achieve selection->action mode.

@ConradIrwin
Copy link
Member

@zoedsoupe There's some work at #11130, but the original author is unable to keep working on it. If you'd like to start working on that branch that would be very appreciated!

We decided to stay in the same crate as vim for now (because that way we can re-use all the mode tracking, registers, marks, test support, etc.). once we have something more close to usable we can revisit that decision if necessary.

@Suyashtnt
Copy link

I wonder how feasible it would be to embed the helix core into zed and use that for not just helix emulation but just straight up full helix support. Similar to how neovide does it for nvim

@sameoldlab
Copy link

AFAIK it is not possible now because helix does not have a splitting feature helix-editor/helix#312 @Suyashtnt. Based on the issue's title, Kakoune does have a client-server model? If that worked it'd also mean slightly different keymaps, and no support for the Helix -> Zed windows user.

But it might be worth taking a step back and instead of just copying the Helix keymap thinking about what it might look like to design a selection->action keymap just for Zed. Most of the infrastructure is already there! Would it feel different from Kakoune and Helix given it's in a GUI editor?

@ConradIrwin
Copy link
Member

We would prefer to build helix on top of our existing CRDTs so that extensions, collaboration, etc. work properly.

@ericpko
Copy link

ericpko commented Jun 11, 2024

I know this isn't a solution, but here are my settings.json and keymap.json files in case anyone searching for this topic wants a quick fix. It's not exactly like helix of course, but decently close. I added as many keymappings from here as possible.

I've been using this for about a week and I like it, for now. I would still love to see an actual helix integration into Zed.
keymap.json
settings.json

@jabcross
Copy link

Great keymap. There are some inconsistencies but it's a great start!

One thing I noticed right away is that the basic word motions (like e and b) don't create selections, so you can't delete until the end of the word with e d in normal mode for instance. % also doesn't select the whole file, etc.

What do you say of creating a repository and working on this collaboratively?

@garthtrickett
Copy link

garthtrickett commented Jun 22, 2024

here are a few more ontop of @ericpko 's

      "n": "vim::PreviousWordStart",
      "b": ["workspace::SendKeystrokes", "v n"],
      "w": ["workspace::SendKeystrokes", "v e"],
      "ctrl-v": "editor::Paste",
      "shift-u": "editor::Redo", 
      "d": "vim::DeleteRight",
      "x": "editor::SelectLine"
 

@noahfraiture
Copy link

noahfraiture commented Jul 10, 2024

Hello,
I created the repository to let everyone give some to be the closest possible https://github.com/noahfraiture/zed-helix.git
@jabcross @garthtrickett @ericpko Currently I put your recommendation and I'm working on it

It would be great if it was possible to have the settings in multiple files, because currently it's pretty much impossible to directly use this repo as zed configuration file since we all have different preferences

@luccahuguet
Copy link

Hello, I created the repository to let everyone give some to be the closest possible https://github.com/noahfraiture/zed-helix.git @jabcross @garthtrickett @ericpko Currently I put your recommendation and I'm working on it

It would be great if it was possible to have the settings in multiple files, because currently it's pretty much impossible to directly use this repo as zed configuration file since we all have different preferences

loved using this, you saved my a$$, ty!

@jabcross
Copy link

Hello, I created the repository to let everyone give some to be the closest possible https://github.com/noahfraiture/zed-helix.git @jabcross @garthtrickett @ericpko Currently I put your recommendation and I'm working on it

It would be great if it was possible to have the settings in multiple files, because currently it's pretty much impossible to directly use this repo as zed configuration file since we all have different preferences

Maybe we should have a generator script that generates a file based on a couple questions, kind of like Powerlevel 10k

@adriangalilea
Copy link

Hello, I created the repository to let everyone give some to be the closest possible https://github.com/noahfraiture/zed-helix.git @jabcross @garthtrickett @ericpko Currently I put your recommendation and I'm working on it
It would be great if it was possible to have the settings in multiple files, because currently it's pretty much impossible to directly use this repo as zed configuration file since we all have different preferences

Maybe we should have a generator script that generates a file based on a couple questions, kind of like Powerlevel 10k

As an alternative proposal, if one could point to the helix config file and translated it to zed, that way every-time you make a change in one both change. A piedra-rosetta of sorts, may be overkill and overcomplicated, but I think it would be the comfiest.

@smltr
Copy link

smltr commented Jul 14, 2024

This might be a bit out there, but has the idea of using modal editors within a terminal tab been discussed? You can currently open a terminal tab right next to a file tab, type hx 'filename' and use helix within Zed. If there were a way to just default to opening files in a terminal with a command, that might be an interesting way to easily get helix editing within the greater Zed environment. I have only played around with this, but if it were a built in feature where I could still easily add my files to LLM context I think it might just do it for me. Also could be a hotkey to switch between views? Just thinking out loud here, want to make sure this idea is at least mentioned.

@jabcross
Copy link

This might be a bit out there, but has the idea of using modal editors within a terminal tab been discussed? You can currently open a terminal tab right next to a file tab, type hx 'filename' and use helix within Zed. If there were a way to just default to opening files in a terminal with a command, that might be an interesting way to easily get helix editing within the greater Zed environment. I have only played around with this, but if it were a built in feature where I could still easily add my files to LLM context I think it might just do it for me. Also could be a hotkey to switch between views? Just thinking out loud here, want to make sure this idea is at least mentioned.

Quite frankly that seems a little pointless to me. The whole point of this would be being able to use zed's future extension ecosystem, including things that the terminal can't support like multiple concurrent font sizes (for type hints and such), smooth scrolling etc. If I want to use helix directly, what would be the benefit of using it in an integrated terminal instead of in an external one?

@smltr
Copy link

smltr commented Aug 20, 2024

This might be a bit out there, but has the idea of using modal editors within a terminal tab been discussed? You can currently open a terminal tab right next to a file tab, type hx 'filename' and use helix within Zed. If there were a way to just default to opening files in a terminal with a command, that might be an interesting way to easily get helix editing within the greater Zed environment. I have only played around with this, but if it were a built in feature where I could still easily add my files to LLM context I think it might just do it for me. Also could be a hotkey to switch between views? Just thinking out loud here, want to make sure this idea is at least mentioned.

Quite frankly that seems a little pointless to me. The whole point of this would be being able to use zed's future extension ecosystem, including things that the terminal can't support like multiple concurrent font sizes (for type hints and such), smooth scrolling etc. If I want to use helix directly, what would be the benefit of using it in an integrated terminal instead of in an external one?

I believe you’re right, it probably doesn’t make sense to consider this. I was thinking as someone who has been trying to pick up helix, it would be nice to have a file browser and integrated LLM assistant on top of the helix editor. But there would be too much else missing from this experience.

@jabcross
Copy link

LLM

Just so you know, there is a fork of Helix that implements support for Copilot, while the plugin support isn't ready. https://github.com/AlexanderDickie/helix/tree/copilot

And for the file browser, you can always use tmux and one of the ranger variants. But the existing file picker is pretty good too.

@hamzahmalik101
Copy link

Does anyone know of a way to rebind movement in zed? Here's what I have in helix:

[keys.normal]
# Replacing hjkl keybinds
n = "move_char_left"
o = "move_char_right"
i = "move_line_up"
e = "move_line_down"

@ConradIrwin
Copy link
Member

@hamzahmalik101 https://zed.dev/docs/key-bindings and https://zed.dev/docs/vim should get you started

@nabby27
Copy link

nabby27 commented Aug 30, 2024

Zed is pretty awesome and support for the helix bindings would be nice. Can we do a bounty for someone from the community/core to get this running? I am not so skilled myself 😀.

I can do $100 for anything helix bindings related.

I feel the same way, I think Zed is fantastic and I would like to see this issue resolved! I just created a $100 bounty on Opire, if anyone wants to join and add more money to the bounty that would be great. I love the project and this way I can contribute my two cents.

@alphabitserial
Copy link

Does anyone know of a way to rebind movement in zed? Here's what I have in helix:

[keys.normal]
# Replacing hjkl keybinds
n = "move_char_left"
o = "move_char_right"
i = "move_line_up"
e = "move_line_down"

Wow, another Workman layout user! Small world!

@thiagomajesk
Copy link

I don't know what the current state of this issue is but I'm particularly interested in having a mechanism where you can configure your own set of keybindings for modal editing (be it Vim, Helix, Kakoune, or something else).

Maybe this belongs to an extension, but having native support would be a killer feature. Don't get me wrong, I think Helix modal editing is great, but I wish that some of the default keybindings were more consistent (there's a huge thread about keymaps on the Helix repository discussing some of the decisions and they don't seem inclined to change any of it).

If we get that and a TUI equivalent interface like in: #7493 it would be perfect 😚👌

@oliverpool
Copy link
Contributor

a mechanism where you can configure your own set of keybindings for modal editing

@thiagomajesk did you have a look at @noahfraiture keymap.json? https://github.com/noahfraiture/zed-helix

It should help get you started.

@thiagomajesk
Copy link

thiagomajesk commented Sep 18, 2024

@oliverpool, does this actually work? How can I test it? (It looks like I missed some Zed updates 😅). From what I'm reading this is built on top of the native Vim support which might be a little limiting, but it's a good start.

I think I would still love to see Zed support modal editing in a generic way and then build both Vim and Helix keybindings on top of native Zed commands. Do you know if this is something maintainers are looking into?

@noahfraiture
Copy link

@thiagomajesk It's a simple configuration file that you need to add to your setup. However, to be honest, it isn't very effective due to the differences between Vim and Helix motion.

Several people want Helix motion to be implemented, and only @maan2003 has done significant work to make it happen. There has been a new PR #17575 because the previous one was too extensive for a single person to handle, and no one had the courage to continue it.

This new PR should be merged soon, and then everyone will be free to make improvements, as it doesn’t aim to be a complete integration of Helix into Zed.

@jerabaul29
Copy link

One thing that would be very useful / helpful is, if possible, to support the full range of commands from helix - not just the text navigation and editing, but also stuff like the "goto mode", "window mode", "space mode", etc, so it is possible to fully use Zed including menus, different tabs and panes, only with the keyboard. But I understand this may be a big ask though :) .

@TeriyakiBomb
Copy link

I’ve fallen for helix bindings, but there are still things missing from helix and I prefer gui apps. This would probably be enough to prompt me to move to Zed.

@hajarrashidi
Copy link

I have paused my use of Zed because I need to improve my Helix skills. I hope there will soon be keybindings for Helix in Zed

@wmstack wmstack linked a pull request Oct 14, 2024 that will close this issue
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement [core label] keymap / key binding Feedback for keyboard shortcuts, key mapping, etc
Projects
None yet
Development

Successfully merging a pull request may close this issue.