forked from Mirrors/bubbletea
Let's start a README
This commit is contained in:
parent
c15b863c39
commit
7c7c8f7c86
|
@ -0,0 +1,69 @@
|
||||||
|
# Tea 茶
|
||||||
|
|
||||||
|
The fun, stateful way to build terminal apps. A Go framework based on [The Elm
|
||||||
|
Architecture][elm].
|
||||||
|
|
||||||
|
## Simple example
|
||||||
|
|
||||||
|
```go
|
||||||
|
package main
|
||||||
|
|
||||||
|
// A simple program that counts down from 5 and then exits.
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"log"
|
||||||
|
"time"
|
||||||
|
"github.com/charmbracelet/tea"
|
||||||
|
)
|
||||||
|
|
||||||
|
type model int
|
||||||
|
|
||||||
|
type tickMsg struct{}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
err := tea.NewProgram(model(5), update, view, []tea.Sub{tick}).Start()
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func update(msg tea.Msg, mdl tea.Model) (tea.Model, tea.Cmd) {
|
||||||
|
m, _ := mdl.(model)
|
||||||
|
|
||||||
|
switch msg.(type) {
|
||||||
|
case tickMsg:
|
||||||
|
m -= 1
|
||||||
|
if m <= 0 {
|
||||||
|
return m, tea.Quit
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return m, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func view(mdl tea.Model) string {
|
||||||
|
m, _ := mdl.(model)
|
||||||
|
return fmt.Sprintf("Hi. This program will exit in %d seconds...\n", m)
|
||||||
|
}
|
||||||
|
|
||||||
|
func tick(_ tea.Model) tea.Msg {
|
||||||
|
time.Sleep(time.Second)
|
||||||
|
return tickMsg{}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Hungry for more? See the [other examples][examples].
|
||||||
|
|
||||||
|
[examples]: https://github.com/charmbracelet/tea/examples
|
||||||
|
|
||||||
|
## Credit
|
||||||
|
|
||||||
|
Heavily inspired by both [The Elm Architecture][elm] by Evan Czaplicki et al.,
|
||||||
|
and [go-tea][gotea] by TJ Holowaychuk.
|
||||||
|
|
||||||
|
[elm]: https://elm-lang.org
|
||||||
|
[gotea]: https://github.com/tj/go-tea
|
||||||
|
|
||||||
|
***
|
||||||
|
|
||||||
|
Part of [Charm](https://charm.sh). For more info see `ssh charm.sh`. Charm热爱开源!
|
Loading…
Reference in New Issue