bubbles/README.md

80 lines
2.9 KiB
Markdown
Raw Normal View History

2020-07-30 02:24:09 +03:00
Bubbles
=======
2020-01-28 05:29:52 +03:00
2020-10-19 07:08:19 +03:00
[![Latest Release](https://img.shields.io/github/release/charmbracelet/bubbles.svg)](https://github.com/charmbracelet/bubbles/releases)
[![Build Status](https://github.com/charmbracelet/bubbles/workflows/build/badge.svg)](https://github.com/charmbracelet/bubbles/actions)
[![Go ReportCard](http://goreportcard.com/badge/charmbracelet/bubbles)](http://goreportcard.com/report/charmbracelet/bubbles)
[![GoDoc](https://godoc.org/github.com/golang/gddo?status.svg)](https://pkg.go.dev/github.com/charmbracelet/bubbles)
2020-01-28 05:29:52 +03:00
2020-08-01 02:11:13 +03:00
Some components for [Bubble Tea](https://github.com/charmbracelet/bubbletea) applications.
2020-07-30 02:24:09 +03:00
These components are used in production in [Glow][glow] and [Charm][charm].
2020-07-17 21:01:48 +03:00
2020-10-06 20:25:46 +03:00
[glow]: https://github.com/charmbracelet/glow
[charm]: https://github.com/charmbracelet/charm
2020-07-29 23:34:01 +03:00
2020-07-17 21:01:48 +03:00
## Spinner
2020-07-30 02:20:41 +03:00
<img src="https://stuff.charm.sh/bubbles-examples/spinner.gif" width="400" alt="Spinner Example">
2020-07-29 23:34:01 +03:00
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.”
* [Example code](https://github.com/charmbracelet/tea/tree/master/examples/spinner/main.go)
2020-07-29 23:34:01 +03:00
2020-07-17 21:01:48 +03:00
## Text Input
2020-07-30 02:20:41 +03:00
<img src="https://stuff.charm.sh/bubbles-examples/textinput.gif" width="400" alt="Text Input Example">
2020-07-29 23:34:01 +03:00
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.
* [Example code, one field](https://github.com/charmbracelet/tea/tree/master/examples/textinput/main.go)
* [Example code, many fields](https://github.com/charmbracelet/tea/tree/master/examples/textinput/main.go)
2020-07-29 23:34:01 +03:00
2020-07-17 21:01:48 +03:00
## Paginator
2020-07-30 02:20:41 +03:00
<img src="https://stuff.charm.sh/bubbles-examples/pagination.gif" width="200" alt="Paginator Example">
2020-07-17 21:01:48 +03:00
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.
2020-07-17 21:01:48 +03:00
2020-07-29 23:34:01 +03:00
This component is used in [Glow][glow] to browse documents and [Charm][charm] to
browse SSH keys.
2020-07-17 21:01:48 +03:00
## Viewport
2020-07-30 02:20:41 +03:00
<img src="https://stuff.charm.sh/bubbles-examples/viewport.gif" width="600" alt="Viewport Example">
2020-07-29 23:34:01 +03:00
A viewport for vertically scrolling content. Optionally includes standard
2020-07-17 21:01:48 +03:00
pager keybindings and mouse wheel support. A high performance mode is available
2020-07-29 23:34:01 +03:00
for applications which make use of the alterate screen buffer.
* [Example code](https://github.com/charmbracelet/tea/tree/master/examples/pager/main.go)
2020-07-29 23:34:01 +03:00
2020-10-19 06:56:55 +03:00
This component is well complimented with [Reflow][reflow] for ANSI-aware
2020-07-29 23:34:01 +03:00
indenting and text wrapping.
[reflow]: https://github.com/muesli/reflow
2020-01-28 05:29:52 +03:00
## License
[MIT](https://github.com/charmbracelet/teaparty/raw/master/LICENSE)
2020-07-29 23:34:01 +03:00
***
A [Charm](https://charm.sh) project.
<img alt="the Charm logo" src="https://stuff.charm.sh/charm-badge.jpg" width="400">
Charm热爱开源!