Uma das coisas que sempre me fascinou é utilitários para o terminal, seja modo cli, bem como, TUI, não é a toa que esse blog tem esse nome 😃 .
E uma das bibliotecas mais maneiras que existe é a Charmbracelet Bubbles.
Já faz alguns anos que eu testo ela, mas esse ano decidi começar aprender de fato, pois apesar de eu fazer muitas coisas, mas com C++, Bubbles é para Go e ainda preciso amadurecer de fato com Golang, eis um dos motivos que criei até essa série aqui no blog, pois eu mesmo irei utilizá-la frequentemente para consultas rápidas! 😎
O Bubbles é uma coleção de componentes TUI que facilita a construção de interfaces no terminal com lógica reativa e visual atrativo.
Ele inclui:
Pra você já ter certeza que ela realmente é incrível, vamos compilar esse exemplo de Textarea com Bubbles:
mkdir textarea
cd textarea
go mod init textarea
go get github.com/charmbracelet/bubbles/textarea
Agora, ainda dentro do seu projeto crie um arquivo, exemplo: main.go
e cole o conteúdo abaixo:
package main
// A simple program demonstrating the textarea component from the Bubbles
// component library.
import (
"fmt"
"log"
"github.com/charmbracelet/bubbles/textarea"
tea "github.com/charmbracelet/bubbletea"
)
func main() {
p := tea.NewProgram(initialModel())
if _, err := p.Run(); err != nil {
log.Fatal(err)
}
}
type errMsg error
type model struct {
textarea textarea.Model
err error
}
func initialModel() model {
ti := textarea.New()
ti.Placeholder = "Once upon a time..."
ti.Focus()
return model{
textarea: ti,
err: nil,
}
}
func (m model) Init() tea.Cmd {
return textarea.Blink
}
func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
var cmds []tea.Cmd
var cmd tea.Cmd
switch msg := msg.(type) {
case tea.KeyMsg:
switch msg.Type {
case tea.KeyEsc:
if m.textarea.Focused() {
m.textarea.Blur()
}
case tea.KeyCtrlC:
return m, tea.Quit
default:
if !m.textarea.Focused() {
cmd = m.textarea.Focus()
cmds = append(cmds, cmd)
}
}
// We handle errors just like any other message
case errMsg:
m.err = msg
return m, nil
}
m.textarea, cmd = m.textarea.Update(msg)
cmds = append(cmds, cmd)
return m, tea.Batch(cmds...)
}
func (m model) View() string {
return fmt.Sprintf(
"Tell me a story.\n\n%s\n\n%s",
m.textarea.View(),
"(ctrl+c to quit)",
) + "\n\n"
}
Compile e rode:
go build main.go
./main
A saída será similar ao gif abaixo. Teste escrevendo alguma coisa, pressionar [enter] cria uma nova linha.
Incrível, né?!
Utilizar módulos Go geralmente é criado uma pasta na raiz do seu usuário, existem arquivos com permissão de sistema, então para remover o diretório, rode:
sudo rm -rf ~/go/
O Bubbles usa a arquitetura Elm: model
, init
, update
, view
e fornece os componentes prontos, basta integrá-los no modelo do Bubble Tea e o exemplo que vimos foi retirado daqui.
Para mais informações, acesse: https://github.com/charmbracelet/bubbles.