mirror of
https://github.com/bcicen/ctop.git
synced 2024-08-30 18:23:19 +00:00
refactor multiview cursor
This commit is contained in:
parent
e09bcd0272
commit
68d2207cb1
66
grid.go
66
grid.go
@ -8,39 +8,62 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type Grid struct {
|
type Grid struct {
|
||||||
cursorPos uint
|
cursorID string // id of currently selected container
|
||||||
containers *ContainerMap
|
containers []*Container
|
||||||
|
containerMap *ContainerMap
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewGrid() *Grid {
|
func NewGrid() *Grid {
|
||||||
|
containerMap := NewContainerMap()
|
||||||
|
containers := containerMap.Sorted()
|
||||||
return &Grid{
|
return &Grid{
|
||||||
cursorPos: 0,
|
cursorID: containers[0].id,
|
||||||
containers: NewContainerMap(),
|
containers: containers,
|
||||||
|
containerMap: containerMap,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return sorted list of container IDs
|
// Return current cursor index
|
||||||
func (g *Grid) CIDs() []string {
|
func (g *Grid) CursorIdx() int {
|
||||||
var ids []string
|
for n, c := range g.containers {
|
||||||
for _, c := range g.containers.Sorted() {
|
if c.id == g.cursorID {
|
||||||
ids = append(ids, c.id)
|
return n
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
func (g *Grid) CursorUp() {
|
||||||
|
idx := g.CursorIdx()
|
||||||
|
// decrement if possible
|
||||||
|
if idx > 0 {
|
||||||
|
g.cursorID = g.containers[idx-1].id
|
||||||
|
g.RedrawCursor()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (g *Grid) CursorDown() {
|
||||||
|
idx := g.CursorIdx()
|
||||||
|
// increment if possible
|
||||||
|
if idx < (len(g.containers) - 1) {
|
||||||
|
g.cursorID = g.containers[idx+1].id
|
||||||
|
g.RedrawCursor()
|
||||||
}
|
}
|
||||||
return ids
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Redraw the cursor with the currently selected row
|
// Redraw the cursor with the currently selected row
|
||||||
func (g *Grid) Cursor() {
|
func (g *Grid) RedrawCursor() {
|
||||||
for n, c := range g.containers.Sorted() {
|
for _, c := range g.containers {
|
||||||
if uint(n) == g.cursorPos {
|
if c.id == g.cursorID {
|
||||||
c.widgets.name.TextFgColor = ui.ColorDefault
|
c.widgets.name.TextFgColor = ui.ColorDefault
|
||||||
c.widgets.name.TextBgColor = ui.ColorWhite
|
c.widgets.name.TextBgColor = ui.ColorWhite
|
||||||
} else {
|
} else {
|
||||||
c.widgets.name.TextFgColor = ui.ColorWhite
|
c.widgets.name.TextFgColor = ui.ColorWhite
|
||||||
c.widgets.name.TextBgColor = ui.ColorDefault
|
c.widgets.name.TextBgColor = ui.ColorDefault
|
||||||
}
|
}
|
||||||
}
|
|
||||||
ui.Render(ui.Body)
|
ui.Render(ui.Body)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (g *Grid) Redraw() {
|
func (g *Grid) Redraw() {
|
||||||
// reinit body rows
|
// reinit body rows
|
||||||
@ -48,7 +71,7 @@ func (g *Grid) Redraw() {
|
|||||||
// build layout
|
// build layout
|
||||||
ui.Body.AddRows(header())
|
ui.Body.AddRows(header())
|
||||||
|
|
||||||
for _, c := range g.containers.Sorted() {
|
for _, c := range g.containers {
|
||||||
ui.Body.AddRows(c.widgets.MakeRow())
|
ui.Body.AddRows(c.widgets.MakeRow())
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -93,20 +116,14 @@ func Display(g *Grid) bool {
|
|||||||
|
|
||||||
// calculate layout
|
// calculate layout
|
||||||
ui.Body.Align()
|
ui.Body.Align()
|
||||||
g.Cursor()
|
g.RedrawCursor()
|
||||||
ui.Render(ui.Body)
|
ui.Render(ui.Body)
|
||||||
|
|
||||||
ui.Handle("/sys/kbd/<up>", func(ui.Event) {
|
ui.Handle("/sys/kbd/<up>", func(ui.Event) {
|
||||||
if g.cursorPos > 0 {
|
g.CursorUp()
|
||||||
g.cursorPos -= 1
|
|
||||||
g.Cursor()
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
ui.Handle("/sys/kbd/<down>", func(ui.Event) {
|
ui.Handle("/sys/kbd/<down>", func(ui.Event) {
|
||||||
if g.cursorPos < (g.containers.Len() - 1) {
|
g.CursorDown()
|
||||||
g.cursorPos += 1
|
|
||||||
g.Cursor()
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
ui.Handle("/sys/kbd/h", func(ui.Event) {
|
ui.Handle("/sys/kbd/h", func(ui.Event) {
|
||||||
newView = views.Help
|
newView = views.Help
|
||||||
@ -116,6 +133,7 @@ func Display(g *Grid) bool {
|
|||||||
ui.StopLoop()
|
ui.StopLoop()
|
||||||
})
|
})
|
||||||
ui.Handle("/timer/1s", func(e ui.Event) {
|
ui.Handle("/timer/1s", func(e ui.Event) {
|
||||||
|
g.containers = g.containerMap.Sorted() // refresh containers for current sort order
|
||||||
g.Redraw()
|
g.Redraw()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -36,9 +36,7 @@ func (w *Widgets) SetCPU(val int) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (w *Widgets) SetNet(rx int64, tx int64) {
|
func (w *Widgets) SetNet(rx int64, tx int64) {
|
||||||
//w.net.Label = fmt.Sprintf("%s / %s", byteFormat(rx), byteFormat(tx))
|
|
||||||
w.net.Text = fmt.Sprintf("%s / %s", byteFormat(rx), byteFormat(tx))
|
w.net.Text = fmt.Sprintf("%s / %s", byteFormat(rx), byteFormat(tx))
|
||||||
//w.net2.Lines[0].Data = []int{0, 2, 5, 10, 20, 20, 2, 2, 0, 0}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *Widgets) SetMem(val int64, limit int64) {
|
func (w *Widgets) SetMem(val int64, limit int64) {
|
||||||
|
Loading…
Reference in New Issue
Block a user