TUI components for Bubble Tea 🫧
Go to file
2021-07-26 12:41:37 -04:00
.github/workflows Update linter config 2021-07-12 03:10:31 +02:00
paginator Fix godocs for various types and functions 2021-03-12 02:06:30 +01:00
progress Use Harmonica to animate progress bar 2021-07-26 12:41:37 -04:00
spinner Fix typo in a spinner comment 2021-06-02 10:49:43 -04:00
textinput Ensure that textinputs can only receive their own blink messages 2021-06-02 10:49:43 -04:00
viewport Keep y-offset in bounds when setting content 2021-04-19 19:47:50 -04:00
.gitignore Initial commit. Add .gitignore 2020-01-18 10:56:08 -05:00
.golangci.yml Update linter config 2021-07-12 03:10:31 +02:00
bubbles.go Rename to Bubbles + copy over components from Bubble Tea + remove examples 2020-05-25 20:08:37 -04:00
go.mod Update go-runewidth to v0.0.13 2021-07-26 12:41:37 -04:00
go.sum Update go-runewidth to v0.0.13 2021-07-26 12:41:37 -04:00
LICENSE Add README and LICENSE 2020-01-27 21:29:52 -05:00
README.md Update footer in README for consistency with newer Charm repos 2021-06-02 10:49:43 -04:00

Bubbles

The Bubbles Logo

Latest Release GoDoc Build Status Go ReportCard

Some components for Bubble Tea applications.

These components are used in production in Glow and Charm.

Spinner

Spinner Example

A spinner, useful for indicating that some kind an operation is happening. There are a couple default ones, but you can also pass your own ”frames.”

Text Input

Text Input Example

A text input field, akin to an <input type="text"> in HTML. Supports unicode, pasting, in-place scrolling when the value exceeds the width of the element and the common, and many customization options.

Progress

Progressbar Example

A simple, customizable progress meter. Supports solid and gradient fills. The empty and filled runes can be set to whatever you'd like. The percentage readout is customizable and can also be omitted entirely.

Paginator

Paginator Example

A component for handling pagination logic and optionally drawing pagination UI. Supports "dot-style" pagination (similar to what you might see on iOS) and numeric page numbering, but you could also just use this component for the logic and visualize pagination however you like.

This component is used in Glow to browse documents and Charm to browse SSH keys.

Viewport

Viewport Example

A viewport for vertically scrolling content. Optionally includes standard pager keybindings and mouse wheel support. A high performance mode is available for applications which make use of the alternate screen buffer.

This component is well complimented with Reflow for ANSI-aware indenting and text wrapping.

License

MIT


Part of Charm.

The Charm logo

Charm热爱开源 • Charm loves open source