mirror of
https://github.com/taigrr/wtf
synced 2025-01-18 04:03:14 -08:00
Output from 'dep status': PROJECT CONSTRAINT VERSION REVISION LATEST PKGS USED cloud.google.com/go v0.23.0 v0.23.0 0fd7230 v0.23.0 1 github.com/briandowns/openweathermap ^0.11.0 0.11 1b87579 0.11 1 github.com/gdamore/encoding branch master branch master b23993c b23993c 1 github.com/gdamore/tcell ^1.0.0 v1.0.0 061d51a v1.0.0 2 github.com/go-test/deep ^1.0.1 v1.0.1 6592d9c v1.0.1 1 github.com/golang/protobuf v1.1.0 v1.1.0 b4deda0 v1.1.0 1 github.com/google/go-github branch master branch master 2ae5df7 2ae5df7 1 github.com/google/go-querystring branch master branch master 53e6ce1 53e6ce1 1 github.com/jessevdk/go-flags ^1.4.0 v1.4.0 c6ca198 v1.4.0 1 github.com/lucasb-eyer/go-colorful v1.0 v1.0 345fbb3 v1.0 1 github.com/mattn/go-runewidth v0.0.2 v0.0.2 9e777a8 v0.0.2 1 github.com/olebedev/config branch master branch master 9a10d05 9a10d05 1 github.com/radovskyb/watcher ^1.0.2 v1.0.2 6145e14 v1.0.2 1 github.com/rivo/tview branch master branch master 71ecf1f 71ecf1f 1 github.com/yfronto/newrelic branch master branch master f7fa0c6 f7fa0c6 1 golang.org/x/net branch master branch master 1e49130 1e49130 2 golang.org/x/oauth2 branch master branch master 1e0a3fa 1e0a3fa 5 golang.org/x/text v0.3.0 v0.3.0 f21a4df v0.3.0 5 google.golang.org/api branch master branch master 00e3bb8 00e3bb8 4 google.golang.org/appengine v1.0.0 v1.0.0 150dc57 v1.0.0 10 gopkg.in/yaml.v2 ^2.2.1 v2.2.1 5420a8b v2.2.1 1 See https://golang.github.io/dep/docs/daily-dep.html
249 lines
5.8 KiB
Go
249 lines
5.8 KiB
Go
package tview
|
|
|
|
import (
|
|
"github.com/gdamore/tcell"
|
|
)
|
|
|
|
// page represents one page of a Pages object.
|
|
type page struct {
|
|
Name string // The page's name.
|
|
Item Primitive // The page's primitive.
|
|
Resize bool // Whether or not to resize the page when it is drawn.
|
|
Visible bool // Whether or not this page is visible.
|
|
}
|
|
|
|
// Pages is a container for other primitives often used as the application's
|
|
// root primitive. It allows to easily switch the visibility of the contained
|
|
// primitives.
|
|
//
|
|
// See https://github.com/rivo/tview/wiki/Pages for an example.
|
|
type Pages struct {
|
|
*Box
|
|
|
|
// The contained pages.
|
|
pages []*page
|
|
|
|
// We keep a reference to the function which allows us to set the focus to
|
|
// a newly visible page.
|
|
setFocus func(p Primitive)
|
|
|
|
// An optional handler which is called whenever the visibility or the order of
|
|
// pages changes.
|
|
changed func()
|
|
}
|
|
|
|
// NewPages returns a new Pages object.
|
|
func NewPages() *Pages {
|
|
p := &Pages{
|
|
Box: NewBox(),
|
|
}
|
|
p.focus = p
|
|
return p
|
|
}
|
|
|
|
// SetChangedFunc sets a handler which is called whenever the visibility or the
|
|
// order of any visible pages changes. This can be used to redraw the pages.
|
|
func (p *Pages) SetChangedFunc(handler func()) *Pages {
|
|
p.changed = handler
|
|
return p
|
|
}
|
|
|
|
// AddPage adds a new page with the given name and primitive. If there was
|
|
// previously a page with the same name, it is overwritten. Leaving the name
|
|
// empty may cause conflicts in other functions.
|
|
//
|
|
// Visible pages will be drawn in the order they were added (unless that order
|
|
// was changed in one of the other functions). If "resize" is set to true, the
|
|
// primitive will be set to the size available to the Pages primitive whenever
|
|
// the pages are drawn.
|
|
func (p *Pages) AddPage(name string, item Primitive, resize, visible bool) *Pages {
|
|
for index, pg := range p.pages {
|
|
if pg.Name == name {
|
|
p.pages = append(p.pages[:index], p.pages[index+1:]...)
|
|
break
|
|
}
|
|
}
|
|
p.pages = append(p.pages, &page{Item: item, Name: name, Resize: resize, Visible: visible})
|
|
if p.changed != nil {
|
|
p.changed()
|
|
}
|
|
if p.HasFocus() {
|
|
p.Focus(p.setFocus)
|
|
}
|
|
return p
|
|
}
|
|
|
|
// AddAndSwitchToPage calls AddPage(), then SwitchToPage() on that newly added
|
|
// page.
|
|
func (p *Pages) AddAndSwitchToPage(name string, item Primitive, resize bool) *Pages {
|
|
p.AddPage(name, item, resize, true)
|
|
p.SwitchToPage(name)
|
|
return p
|
|
}
|
|
|
|
// RemovePage removes the page with the given name.
|
|
func (p *Pages) RemovePage(name string) *Pages {
|
|
hasFocus := p.HasFocus()
|
|
for index, page := range p.pages {
|
|
if page.Name == name {
|
|
p.pages = append(p.pages[:index], p.pages[index+1:]...)
|
|
if page.Visible && p.changed != nil {
|
|
p.changed()
|
|
}
|
|
break
|
|
}
|
|
}
|
|
if hasFocus {
|
|
p.Focus(p.setFocus)
|
|
}
|
|
return p
|
|
}
|
|
|
|
// HasPage returns true if a page with the given name exists in this object.
|
|
func (p *Pages) HasPage(name string) bool {
|
|
for _, page := range p.pages {
|
|
if page.Name == name {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
// ShowPage sets a page's visibility to "true" (in addition to any other pages
|
|
// which are already visible).
|
|
func (p *Pages) ShowPage(name string) *Pages {
|
|
for _, page := range p.pages {
|
|
if page.Name == name {
|
|
page.Visible = true
|
|
if p.changed != nil {
|
|
p.changed()
|
|
}
|
|
break
|
|
}
|
|
}
|
|
if p.HasFocus() {
|
|
p.Focus(p.setFocus)
|
|
}
|
|
return p
|
|
}
|
|
|
|
// HidePage sets a page's visibility to "false".
|
|
func (p *Pages) HidePage(name string) *Pages {
|
|
for _, page := range p.pages {
|
|
if page.Name == name {
|
|
page.Visible = false
|
|
if p.changed != nil {
|
|
p.changed()
|
|
}
|
|
break
|
|
}
|
|
}
|
|
if p.HasFocus() {
|
|
p.Focus(p.setFocus)
|
|
}
|
|
return p
|
|
}
|
|
|
|
// SwitchToPage sets a page's visibility to "true" and all other pages'
|
|
// visibility to "false".
|
|
func (p *Pages) SwitchToPage(name string) *Pages {
|
|
for _, page := range p.pages {
|
|
if page.Name == name {
|
|
page.Visible = true
|
|
} else {
|
|
page.Visible = false
|
|
}
|
|
}
|
|
if p.changed != nil {
|
|
p.changed()
|
|
}
|
|
if p.HasFocus() {
|
|
p.Focus(p.setFocus)
|
|
}
|
|
return p
|
|
}
|
|
|
|
// SendToFront changes the order of the pages such that the page with the given
|
|
// name comes last, causing it to be drawn last with the next update (if
|
|
// visible).
|
|
func (p *Pages) SendToFront(name string) *Pages {
|
|
for index, page := range p.pages {
|
|
if page.Name == name {
|
|
if index < len(p.pages)-1 {
|
|
p.pages = append(append(p.pages[:index], p.pages[index+1:]...), page)
|
|
}
|
|
if page.Visible && p.changed != nil {
|
|
p.changed()
|
|
}
|
|
break
|
|
}
|
|
}
|
|
if p.HasFocus() {
|
|
p.Focus(p.setFocus)
|
|
}
|
|
return p
|
|
}
|
|
|
|
// SendToBack changes the order of the pages such that the page with the given
|
|
// name comes first, causing it to be drawn first with the next update (if
|
|
// visible).
|
|
func (p *Pages) SendToBack(name string) *Pages {
|
|
for index, pg := range p.pages {
|
|
if pg.Name == name {
|
|
if index > 0 {
|
|
p.pages = append(append([]*page{pg}, p.pages[:index]...), p.pages[index+1:]...)
|
|
}
|
|
if pg.Visible && p.changed != nil {
|
|
p.changed()
|
|
}
|
|
break
|
|
}
|
|
}
|
|
if p.HasFocus() {
|
|
p.Focus(p.setFocus)
|
|
}
|
|
return p
|
|
}
|
|
|
|
// HasFocus returns whether or not this primitive has focus.
|
|
func (p *Pages) HasFocus() bool {
|
|
for _, page := range p.pages {
|
|
if page.Item.GetFocusable().HasFocus() {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
// Focus is called by the application when the primitive receives focus.
|
|
func (p *Pages) Focus(delegate func(p Primitive)) {
|
|
if delegate == nil {
|
|
return // We cannot delegate so we cannot focus.
|
|
}
|
|
p.setFocus = delegate
|
|
var topItem Primitive
|
|
for _, page := range p.pages {
|
|
if page.Visible {
|
|
topItem = page.Item
|
|
}
|
|
}
|
|
if topItem != nil {
|
|
delegate(topItem)
|
|
}
|
|
}
|
|
|
|
// Draw draws this primitive onto the screen.
|
|
func (p *Pages) Draw(screen tcell.Screen) {
|
|
p.Box.Draw(screen)
|
|
for _, page := range p.pages {
|
|
if !page.Visible {
|
|
continue
|
|
}
|
|
if page.Resize {
|
|
x, y, width, height := p.GetInnerRect()
|
|
page.Item.SetRect(x, y, width, height)
|
|
}
|
|
page.Item.Draw(screen)
|
|
}
|
|
}
|