-
Notifications
You must be signed in to change notification settings - Fork 8
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
[Feature request] Sort tinty list #74
Comments
Have you tried using |
I tried The main point is to have some ways to call |
I've got shell alias I wrote which may be of some value to you but I can't speak to how it would interact with vim/neovim as I do not use a base16 theme in my editor. As you can see, this also doesn't "see" any custom themes you have have setup.
Though not perfect, you can build upon the above by adding one or more excludes by way of
It's not perfect as we're filtering based on theme name rather than the variant. That said, it may provide a starting place for something more robust. Perhaps a more mature version would add add an additional keybinding to dump the selected scheme into a excludes file which would be used instead of the hard-coded string... |
Something worth mentioning (maybe this will solve your needs), we have a gallery page which is created by rendering the theme in vim and then converting that to html, so you can preview themes, albeit with static content: https://tinted-theming.github.io/base16-gallery/ |
The gallery is really nice but please note that it has the same issue than the original issue: it is sorted by alphabetical order as opposed to an ordering like from dark background to light background. Sorting by name is useful when you know already what you are looking for. But when someone looks for a new theme, sorting based on colours or background darkness would probably be much more useful. PS: a dark background in the gallery would probably help to highlight each individual themes. |
I still need to add to tinty, but I've created a PR which adds a "group by variant" and "darkmode" feature: tinted-theming/tinted-gallery#11 |
@JamyGolden Curious if you've considered providing a machine-readable list result in the form of JSON e.g. $ tinty list --json
#Output:
[
{
"key": "base16-3024",
"scheme_data": {
"author": "Jan T. Sott (http://github.com/idleberg)",
"name": "3024",
"palette": {
"base00": "#090300",
"base01": "#3a3432",
"base02": "#4a4543",
"base03": "#5c5855",
"base04": "#807d7c",
"base05": "#a5a2a2",
"base06": "#d6d5d4",
"base07": "#f7f7f7",
"base08": "#db2d20",
"base09": "#e8bbd0",
"base0A": "#fded02",
"base0B": "#01a252",
"base0C": "#b5e4f4",
"base0D": "#01a0e4",
"base0E": "#a16a94",
"base0F": "#cdab53"
},
"system": "base16",
"variant": "dark"
},
"palette": { ... },
},
...
] This way, OP & others are enabled to sculpt & use the data as they'd like (e.g. sort, and use the colors how they see fit). # Sorts by variant, light then dark:
tinty list --json | jq 'sort_by(.scheme_data.variant) | reverse'
# Filter "dark" variants only:
tinty list --json | jq '.[] | select(.scheme_data.variant == "dark")'
# Sort by luminance:
tinty list --json | jq '.[] | select(_my_luminance_jq_fn(.palette.base00.hex))' ...you get the gist. I have a very rough POC that does it: https://github.com/tinted-theming/tinty/compare/main...bezhermoso:tinty:list-json?expand=1 |
I can definitely see it being useful, I like the idea! Create a PR when you're ready with it 😄 |
@JamyGolden #94 :) |
Is your feature request related to a problem? Please describe.
I am using the following command to preview themes in my terminal:
The list is ordered alphabetically, meaning that themes like
base16-atelier-estuary
andbase16-atelier-estuary-light
are next to each other. When browsing, switching from a light theme to a dark theme is quite violent for the eyes, making the browsing experience pretty bad.Describe the solution you'd like
A way to sort the themes, from dark background to light background for example, would fix this issue.
A command like:
would also be quite nice.
Describe alternatives you've considered
The text was updated successfully, but these errors were encountered: