tervi

module
v0.0.7 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 6, 2022 License: MIT

README

tervi

Go Reference ci

Terminal UI library for Go

Features

  • Declarative
  • Use Alternative Screen
  • Support 256 Color Code
  • Support Multibyte Characters

Examples

Here is the first one to get you started:

package main

import (
	"github.com/dytlzl/tervi/pkg/color"
	"github.com/dytlzl/tervi/pkg/tui"
)

func main() {
	err := tui.Run(func() *tui.View {
		return tui.VStack(
			tui.HStack(
				tui.VStack(tui.String("Hi!")).
					Title("MESSAGE").
					Border(tui.BorderOptionFGColor(color.RGB(200, 100, 200))),
				tui.Spacer().AbsoluteSize(1, 0),
				tui.InlineStack(
					tui.String(" Red ").BGColor(color.RGB(100, 0, 0)),
					tui.String(" Green ").BGColor(color.RGB(0, 100, 0)),
					tui.String(" Blue ").BGColor(color.RGB(0, 0, 100)),
				).
					Title("BACKGROUND COLOR").
					Border(tui.BorderOptionFGColor(color.RGB(200, 100, 200))),
			),
			tui.HStack(
				tui.String("Red").FGColor(color.RGB(255, 0, 0)),
				tui.String("Green").FGColor(color.RGB(0, 255, 0)),
				tui.String("Blue").FGColor(color.RGB(0, 0, 255)),
			).
				Title("FOREGROUND COLOR").
				Border(tui.BorderOptionFGColor(color.RGB(200, 100, 200))),
		).RelativeSize(10, 10)
	})
	if err != nil {
		panic(err)
	}
}

This example will render the Terminal UI as shown below.

simple example

Directories

Path Synopsis
example
internal
pkg
key
tui

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL