Crie lindas Interfaces para o Terminal com essa lib Go

🫧 Sua experiência com TUI será elevada a outra dimensão!


Crie lindas Interfaces para o Terminal com essa lib Go


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:

  • Spinners (atividade)
  • Text input e textarea
  • Progress bar
  • Paginator
  • Viewport (rolagem de conteúdo)
  • Listas filtráveis/paginadas
  • File picker
  • Timer / Stopwatch
  • Mini help
  • Gerenciamento de keybindings


Utilização

Pra você já ter certeza que ela realmente é incrível, vamos compilar esse exemplo de Textarea com Bubbles:

01. Crie um projeto básico e inicie um módulo

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.

Textarea Charmbracelet Bubbles

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.


go series-go tui cli


Compartilhe


Nosso canal no Youtube

Inscreva-se


Marcos Oliveira

Marcos Oliveira

Desenvolvedor de software
https://github.com/terroo


Crie Aplicativos Gráficos para Linux e Windows com C++

Aprenda C++ Moderno e crie Games, Programas CLI, GUI e TUI de forma fácil.

Saiba Mais

Receba as novidades no seu e-mail!

Após cadastro e confirmação do e-mail, enviaremos semanalmente resumos e também sempre que houver novidades por aqui para que você mantenha-se atualizado!