forked from Mirrors/bubbletea
ae9ea29c0e | ||
---|---|---|
.github/workflows | ||
examples | ||
.gitignore | ||
LICENSE | ||
README.md | ||
commands.go | ||
commands_unix.go | ||
commands_windows.go | ||
go.mod | ||
go.sum | ||
key.go | ||
logging.go | ||
renderer.go | ||
screen.go | ||
tea.go | ||
tty_unix.go | ||
tty_windows.go |
README.md
Bubble Tea
The fun, functional way to build terminal apps. A Go framework based on The Elm Architecture.
⚠️ This project is a pre-release so the API is subject to change a little. That said, we're using it in production.
Simple example
package main
// A simple program that counts down from 5 and then exits.
import (
"fmt"
"log"
"time"
tea "github.com/charmbracelet/bubbletea"
)
type model int
type tickMsg struct{}
func main() {
p := tea.NewProgram(initialize, update, view, subscriptions)
if err := p.Start(); err != nil {
log.Fatal(err)
}
}
// Return the initial model and initial command
func initialize() (tea.Model, tea.Cmd) {
return 5, tick
}
// Listen for messages and update the model accordingly
func update(msg tea.Msg, mdl tea.Model) (tea.Model, tea.Cmd) {
m, _ := mdl.(model)
switch msg.(type) {
case tickMsg:
m--
if m == 0 {
return m, tea.Quit
}
}
return m, nil
}
// Render to the terminal
func view(mdl tea.Model) string {
m, _ := mdl.(model)
return fmt.Sprintf("Hi. This program will exit in %d seconds...\n", m)
}
// A simple command which Bubble Tea runs asynchronously.
func tick() tea.Msg {
time.Sleep(time.Second)
return tickMsg{}
}
Hungry for more? Totally confused? See the other examples.
Other Resources
- termenv: advanced ANSI style and color support for your terminal applications. Very useful when rendering your views.
- reflow: a collection of ANSI-aware text formatting tools. Also useful for view rendering.
- go-runewidth: functions to get the physical width of runes in terms of cells. Indispensable when working with fullwidth and zero-width characters.
Acknowledgments
Heavily inspired by both The Elm Architecture by Evan Czaplicki et al. and go-tea by TJ Holowaychuk.
License
Part of Charm.
Charm热爱开源!