mirror of
https://github.com/taigrr/wtf
synced 2025-01-18 04:03:14 -08:00
Add Display as a concept to separate setup from rendering a bit more
This commit is contained in:
parent
55be452120
commit
6bbefb3fb9
46
wtf.go
46
wtf.go
@ -54,38 +54,6 @@ var (
|
|||||||
|
|
||||||
/* -------------------- Functions -------------------- */
|
/* -------------------- Functions -------------------- */
|
||||||
|
|
||||||
func addToGrid(grid *tview.Grid, widget wtf.Wtfable) {
|
|
||||||
if widget.Disabled() {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
grid.AddItem(
|
|
||||||
widget.TextView(),
|
|
||||||
widget.Top(),
|
|
||||||
widget.Left(),
|
|
||||||
widget.Height(),
|
|
||||||
widget.Width(),
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
false,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Grid stores all the widgets onscreen (like an HTML table)
|
|
||||||
func buildGrid(modules []wtf.Wtfable) *tview.Grid {
|
|
||||||
grid := tview.NewGrid()
|
|
||||||
grid.SetColumns(wtf.ToInts(Config.UList("wtf.grid.columns"))...)
|
|
||||||
grid.SetRows(wtf.ToInts(Config.UList("wtf.grid.rows"))...)
|
|
||||||
grid.SetBorder(false)
|
|
||||||
|
|
||||||
for _, module := range modules {
|
|
||||||
addToGrid(grid, module)
|
|
||||||
go wtf.Schedule(module)
|
|
||||||
}
|
|
||||||
|
|
||||||
return grid
|
|
||||||
}
|
|
||||||
|
|
||||||
func disableAllWidgets() {
|
func disableAllWidgets() {
|
||||||
for _, widget := range Widgets {
|
for _, widget := range Widgets {
|
||||||
widget.Disable()
|
widget.Disable()
|
||||||
@ -165,8 +133,8 @@ func watchForConfigChanges(app *tview.Application, configFlag string, grid *tvie
|
|||||||
disableAllWidgets()
|
disableAllWidgets()
|
||||||
makeWidgets(app, pages)
|
makeWidgets(app, pages)
|
||||||
initializeFocusTracker(app)
|
initializeFocusTracker(app)
|
||||||
grid = buildGrid(Widgets)
|
display := wtf.NewDisplay(Widgets)
|
||||||
pages.AddPage("grid", grid, true, true)
|
pages.AddPage("grid", display.Grid, true, true)
|
||||||
case err := <-watch.Error:
|
case err := <-watch.Error:
|
||||||
log.Fatalln(err)
|
log.Fatalln(err)
|
||||||
case <-watch.Closed:
|
case <-watch.Closed:
|
||||||
@ -311,20 +279,18 @@ func main() {
|
|||||||
makeWidgets(app, pages)
|
makeWidgets(app, pages)
|
||||||
initializeFocusTracker(app)
|
initializeFocusTracker(app)
|
||||||
|
|
||||||
grid := buildGrid(Widgets)
|
display := wtf.NewDisplay(Widgets)
|
||||||
pages.AddPage("grid", grid, true, true)
|
pages.AddPage("grid", display.Grid, true, true)
|
||||||
app.SetInputCapture(keyboardIntercept)
|
app.SetInputCapture(keyboardIntercept)
|
||||||
|
|
||||||
grid.SetBackgroundColor(wtf.ColorFor(Config.UString("wtf.colors.background", "black")))
|
|
||||||
|
|
||||||
// Loop in a routine to redraw the screen
|
// Loop in a routine to redraw the screen
|
||||||
go redrawApp(app)
|
go redrawApp(app)
|
||||||
go watchForConfigChanges(app, cmdFlags.Config, grid, pages)
|
go watchForConfigChanges(app, cmdFlags.Config, display.Grid, pages)
|
||||||
|
|
||||||
if err := app.SetRoot(pages, true).Run(); err != nil {
|
if err := app.SetRoot(pages, true).Run(); err != nil {
|
||||||
fmt.Printf("An error occurred: %v\n", err)
|
fmt.Printf("An error occurred: %v\n", err)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
wtf.Log("running!")
|
wtf.Log("Running!")
|
||||||
}
|
}
|
||||||
|
56
wtf/display.go
Normal file
56
wtf/display.go
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
package wtf
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/rivo/tview"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Display struct {
|
||||||
|
Grid *tview.Grid
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewDisplay(widgets []Wtfable) *Display {
|
||||||
|
display := Display{
|
||||||
|
Grid: tview.NewGrid(),
|
||||||
|
}
|
||||||
|
|
||||||
|
display.build(widgets)
|
||||||
|
display.Grid.SetBackgroundColor(
|
||||||
|
ColorFor(
|
||||||
|
Config.UString("wtf.colors.background", "black"),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
|
||||||
|
return &display
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------- Unexported Functions -------------------- */
|
||||||
|
|
||||||
|
func (display *Display) add(widget Wtfable) {
|
||||||
|
if widget.Disabled() {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
display.Grid.AddItem(
|
||||||
|
widget.TextView(),
|
||||||
|
widget.Top(),
|
||||||
|
widget.Left(),
|
||||||
|
widget.Height(),
|
||||||
|
widget.Width(),
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
false,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (display *Display) build(widgets []Wtfable) *tview.Grid {
|
||||||
|
display.Grid.SetColumns(ToInts(Config.UList("wtf.grid.columns"))...)
|
||||||
|
display.Grid.SetRows(ToInts(Config.UList("wtf.grid.rows"))...)
|
||||||
|
display.Grid.SetBorder(false)
|
||||||
|
|
||||||
|
for _, widget := range widgets {
|
||||||
|
display.add(widget)
|
||||||
|
go Schedule(widget)
|
||||||
|
}
|
||||||
|
|
||||||
|
return display.Grid
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user