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

Added recordings of examples to the readme #258

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

FelixSelter
Copy link

When programmers search for a great library they often find multiple and need to decide which one is worth being used. A good readme showing the possibilities of a library helps them to quickly identify if it matches their situation. Forcing them to download the library and to run the examples is unnecessarily annoying

When programmers search for a great library they often find multiple and need to decide which one is worth being used.
A good readme showing the possibilities of a library helps them to quickly identify if it matches their situation.
Forcing them to download the library and to run the examples is unnecessarily anoying
@pksunkara
Copy link
Collaborator

Is linking to screenshots in https://github.com/termapps/enquirer enough?

@FelixSelter
Copy link
Author

Seems like enquirer has not an example for every possible dialog. Also Its somewhat a different tool. I do not see any reason to not create a few more svgs for this repo. The advantage is you know which example produced them. People might not even get that dialouger is a library if they see this enquirer specific syntax. Is there anything wrong with the recordings? Because the onlyproblem I see are a few more bytes github has to store somewhere.

@pksunkara
Copy link
Collaborator

I guess, I am trying to figure out what exactly are we trying to provide with these gifs? Examples? Or comprehensive behavior showcase? Or something else?

@FelixSelter
Copy link
Author

My intention was to show examples of all possible dialogs that this library helps to create. Therefore anyone looking at the readme knows if the library fits his usecase without downloading everything and running the examples himself. You can quickly get an overview about all possibilities and investigate in what you need.

@pksunkara
Copy link
Collaborator

all possible dialogs that this library helps to create.

about all possibilities and investigate in what you need.

Yeah, but since the dialogs can have different behaviors based on different options, are you talking about just one behavior as a gif for each dialog or each behavior for each dialog in the gif?

@FelixSelter
Copy link
Author

I personally would prefer one gif for every dialogue showing all behaviours of that single dialogue. Maybe they could even be generated automatically?

@pksunkara
Copy link
Collaborator

I personally would prefer one gif for every dialogue showing all behaviors of that single dialogue.

Each dialogue can have a lot of different behaviors.

Maybe they could even be generated automatically

And yes, they would need to be generated automatically. Otherwise, it's not scalable.

@FelixSelter
Copy link
Author

I guess this is at least a temporary start

@joshka
Copy link

joshka commented May 24, 2023

I came across this library just now. It's quite neat, and I had the same exact thought that it needs examples to get an idea of what this looks like. I cloned a copy and was wowed enough by the examples to make use of it immediately, but if I hadn't I probably would have never done so.

Regarding putting a large amount of examples on the readme itself, perhaps it would be worth showing a small static example of each of the prompts, and having these more in depth examples on a seperate examples doc.

Regarding formatting (see preview), I'd suggest replacing the markdown for the svgs with img tags to be able to specify a width for each example. Also consider finding a way to get rid of the noise at the top of each example.

P.s. what's the tool you're using to create the SVGs? I've used Asciinema for this sort of thing in the past, which I find is nice because it comes with the ability to pause / scrub the demo, but this is still pretty cool for things that don't need that as much (and that renders automatically on gh).

@pksunkara
Copy link
Collaborator

https://github.com/marionebl/svg-term-cli is what I use normally.

@FelixSelter
Copy link
Author

I used term2svg. Getting rid of the noise can be done easily. term2svg files can also be edited with ascinema edit if you are using this tool. Maybe I can work on this in a week but I have very limited time at the moment

@FelixSelter
Copy link
Author

@pksunkara Can you give me an example of one dialogue and what you would expect to be generated.

joshka added a commit to joshka/dialoguer that referenced this pull request Dec 30, 2024
- Add a readme.rs example
- Use VHS to generate the output gifs
- Adds a script to generate and publish all the gifs in one go
- Images are published to VHS rather than committed to the repo to avoid
  bloating the repo size

See <https://github.com/charmbracelet/vhs> for more info on VHS

Alternative to: console-rs#258
@joshka
Copy link

joshka commented Dec 30, 2024

I created an alternative to this PR that gets rid of all the terminal cruft, leaving just the relevant output: #317. Direct link to view the README: https://github.com/console-rs/dialoguer/blob/a9428d4e6601949112fe2194b9ae64c70d8d6f99/README.md.

The output images are scripted using VHS making them repeatable / tweakable as needed.

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.

3 participants