-
-
Notifications
You must be signed in to change notification settings - Fork 183
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: primary cursor should be differentiated #688
Comments
Thanks for this excellent bug report! Currently, Stylix delegates Helix' theming to https://github.com/tinted-theming/base16-helix: Lines 4 to 6 in a2d66f2
Consider patching the upstream theme and then submitting a Stylix PR to update the |
I was wondering how to make the effect. If it helps, I found out how to set the things you want! programs.helix.settings.theme = "my-stylix";
home.file.".config/helix/themes/my-stylix.toml".source = toml.generate "my-stylix.toml" {
# Get the default values fro the stylix config
inherits = "stylix";
# Enter your patches here
# This will become the cursor of the selections
"ui.cursor" = {
fg = "base0B"; # usually it is base0A, but that will be the primary now
modifiers = [ "reversed" ];
};
# This is the color of the primary cursor, i.e., the one you always see
"ui.cursor.primary" = {
fg = "base0A";
modifiers = [ "reversed" ];
};
# Similar thing with the selection color
# Also, you can play with setting the fg to *background*
# And putting the color in the bg variable ;)
# This will become the color of the selections
"ui.selection" = {
fg = "base03"; # It would be base02, but that is the primary now
};
# This is the color of the primary/inline selection where the primary cursor is now
"ui.selection.primary "= {
fg = "base02";
};
# This one is a bonus: the matching element (like a bracket) will be underlined
# I somehow lose track which cursor is mine and which is just a highlight...
"ui.cursor.match" = {
fg = "base0A";
modifiers = [ "underlined" ];
};
}; This will suffice for now, but some of there changes could be implemented upstream too. Maybe I will take a look at it, but since I am not well versed in theming, I am not sure how good the coloring would be 😂 |
i found a somewhat simpler/neater way to override the default the theme: programs.helix = {
# set theme to the one defined below
settings.theme = lib.mkForce "stylix-custom";
themes = {
stylix-custom = {
# inherits styling and pallet from the default stylix helix theme
inherits = "stylix";
# Normal Mode Indicator at the bottom left background base0D with base00 text
"ui.statusline.normal" = { fg = "base00"; bg = "base0D"; };
# Makes the active buffer in the bufferline background base0D, foreground font is bold
"ui.bufferline.active" = { fg = "base00"; bg = "base0D"; modifiers = ["bold"]; };
# Primary selection is base0D
"ui.cursor.primary" = { fg = "base0D"; modifiers = ["reversed"]; };
# Matching brackets/quotes are underlined with color base0A
"ui.cursor.match" = { fg = "base0A"; underline.style = "line"; };
};
};
}; Whenever I have to use home.file (or xdg.configFile) it always feels a little dirty to me lol. Also, I've been trying to think about what would be a reasonable default to patch the upstream theme with would be, but, given how restrictive the spec is, it's difficult to really know. I pretty much always use Base0D for a primary/highlight color (because in my case it's a nice blue), but semantically i don't think that would be valid for a default. Also, one thing I really love about stylix as a project is the ability to just override the aspects you don't like of the default theme. |
In helix, you can have multiple cursors operating on different selections in a file. You can cycle between them and remove selections. At any one time, one of the selections is considered to be primary and you can use keybindings to keep or dismiss it.
For example:
(Dracula_at_night)
(Ayu_dark)
Both these themes give the ability to differentiate between primary and secondary selections (with varying subtlety). They both rely on
ui.cursor
andui.cursor.primary
, andui.selection
andui.selection.primary
being visually distinct.In stylix's helix config
ui.cursor
is defined andui.cursor.primary
is not. Also,ui.selection
andui.selection.primary
are both defined as base02.Here's what that looks like with the stylix config:
(Stylix)
The text was updated successfully, but these errors were encountered: