Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ttytm/bartender

Customizable progress indicators for V terminal applications.
https://github.com/ttytm/bartender

cli customizable gluten-free progress progress-bar progressbar terminal v vlang

Last synced: about 1 month ago
JSON representation

Customizable progress indicators for V terminal applications.

Awesome Lists containing this project

README

        

# bartender

> Customizable bars for v term apps.

![smooth](https://user-images.githubusercontent.com/34311583/228962398-a7db6cea-3be3-4a21-ae95-a78f9e587a9c.gif)

## Getting started

Install via `v` cli

- From source

```
v install --git https://github.com/tobealive/bartender
```

```v
import bartender
```

- As vpm module

```
v install tobealive.bartender
```

```v
import tobealive.bartender
```

## Usage examples

- Simple bars

```v
// Default bar
mut b := Bar{}
for _ in 0 .. b.iters {
b.progress()
}

// Customized bar
mut b2 := Bar{
width: 60
runes: BarRunes{
progress: `#`
indicator: `❯`
remaining: `-`
}
pre: '|'
post: Affix{
pending: '| Loading...'
finished: '| Done!'
}
}
for _ in 0 .. b2.iters {
b2.progress()
}
```

- Smooth bar themes

```v
mut b := SmoothBar{
theme: Theme.pull // Default = Theme.push
}
for _ in 0 .. b.iters {
b.progress()
}

b2 = SmoothBar{
theme: ThemeVariant{.pull, .drain}
}
for _ in 0 .. b2.iters {
b2.progress()
}

// Customized smooth bar
mut b3 := SmoothBar{
theme: Theme.split
width: 80
pre: '│'
post: fn (b SmoothBar) (string, string) {
return '│ Saving... ${b.pct()}% ${term.blue(b.eta(20))}', '│ Saved!'
}
}
b3.colorize(.cyan)
for _ in 0 .. b3.iters {
b3.progress()
}
```

- Bar Reader for `io` operations.

```v
// Returns an `io.BufferedReader` that displays a progressing bar when used in a reader operation.
pub fn (b Bar) reader(reader io.Reader, size u64) &io.BufferedReader
```

```v
mut src_file := os.open(src_file_path)!
mut dst_file := os.create(dst_file_path)!

bar := bartender.Bar{}
mut bar_reader := bar.reader(src_file, os.file_size(src_file_path))
io.cp(mut bar_reader, mut dst_file)!
```

### Run examples

Extended and executable examples can be found in the `examples` directory.

```
v run examples/.v
```

## Showcase

Simple bar  Toggle visibility...

![simple](https://user-images.githubusercontent.com/34311583/228962887-dbc76f93-4c82-43ed-95a1-964851fe3617.gif)

Color and style customizations.  Toggle visibility...

![colors](https://user-images.githubusercontent.com/34311583/228962409-a5d9b3cb-b6d2-4b34-a2db-305249e95c82.gif)

Smooth bars.  Toggle visibility...

![download](https://user-images.githubusercontent.com/34311583/228962385-2fd9e185-81a5-481a-aa9c-6101405bf64a.gif)

## Disclaimer

Until a stable version 1.0 is available, new features will be introduced, existing ones may change,
or breaking changes may occur in minor(`0..*`) versions.

## Outlook

Below are some of the things to look forward to.

- [x] Reader Interface
- [x] Multiline (Smooth Bar Split Themes are not supported yet)
- [x] Time Remaining
- [ ] Dynamic adjustment on term resize for all variants (basic width detection works)
- [ ] Extend visuals & customizability

## Anowledgements

- [Waqar144/progressbar][10] inspired the start of project.
- [console-rs/indicatif][20] serves as inspiration for further development.
- [ArtemkaKun/v-project-basement][30] served as a base for CI scripts and issue templates

[10]: https://github.com/Waqar144/progressbar
[20]: https://github.com/console-rs/indicatif
[30]: https://github.com/ArtemkaKun/v-project-basement