mirror of
https://github.com/taigrr/wtf
synced 2025-01-18 04:03:14 -08:00
Merge pull request #524 from wtfutil/20190804-reorganization
20190804 Reorganization
This commit is contained in:
commit
0bd2d176d8
@ -1,4 +1,4 @@
|
|||||||
package maker
|
package app
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/olebedev/config"
|
"github.com/olebedev/config"
|
@ -9,7 +9,6 @@ import (
|
|||||||
"github.com/radovskyb/watcher"
|
"github.com/radovskyb/watcher"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/cfg"
|
"github.com/wtfutil/wtf/cfg"
|
||||||
"github.com/wtfutil/wtf/maker"
|
|
||||||
"github.com/wtfutil/wtf/utils"
|
"github.com/wtfutil/wtf/utils"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
@ -39,7 +38,7 @@ func NewWtfApp(app *tview.Application, config *config.Config, configFilePath str
|
|||||||
}
|
}
|
||||||
|
|
||||||
wtfApp.app.SetInputCapture(wtfApp.keyboardIntercept)
|
wtfApp.app.SetInputCapture(wtfApp.keyboardIntercept)
|
||||||
wtfApp.widgets = maker.MakeWidgets(wtfApp.app, wtfApp.pages, wtfApp.config)
|
wtfApp.widgets = MakeWidgets(wtfApp.app, wtfApp.pages, wtfApp.config)
|
||||||
wtfApp.display = NewDisplay(wtfApp.widgets, wtfApp.config)
|
wtfApp.display = NewDisplay(wtfApp.widgets, wtfApp.config)
|
||||||
wtfApp.focusTracker = NewFocusTracker(wtfApp.app, wtfApp.widgets, wtfApp.config)
|
wtfApp.focusTracker = NewFocusTracker(wtfApp.app, wtfApp.widgets, wtfApp.config)
|
||||||
wtfApp.validator = NewModuleValidator()
|
wtfApp.validator = NewModuleValidator()
|
||||||
|
@ -4,7 +4,7 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/olebedev/config"
|
"github.com/olebedev/config"
|
||||||
"github.com/wtfutil/wtf/maker"
|
"github.com/wtfutil/wtf/app"
|
||||||
"github.com/wtfutil/wtf/utils"
|
"github.com/wtfutil/wtf/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -18,7 +18,7 @@ func Display(moduleName string, config *config.Config) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func helpFor(moduleName string, config *config.Config) string {
|
func helpFor(moduleName string, config *config.Config) string {
|
||||||
widget := maker.MakeWidget(nil, nil, moduleName, config)
|
widget := app.MakeWidget(nil, nil, moduleName, config)
|
||||||
|
|
||||||
result := ""
|
result := ""
|
||||||
result += utils.StripColorTags(widget.HelpText())
|
result += utils.StripColorTags(widget.HelpText())
|
||||||
|
@ -5,20 +5,21 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
const APIURI = "https://api.bamboohr.com/api/gateway.php"
|
const APIURI = "https://api.bamboohr.com/api/gateway.php"
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ import (
|
|||||||
"math/rand"
|
"math/rand"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
var started = false
|
var started = false
|
||||||
@ -17,7 +17,7 @@ var ok = true
|
|||||||
|
|
||||||
// Widget define wtf widget to register widget later
|
// Widget define wtf widget to register widget later
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.BarGraph
|
view.BarGraph
|
||||||
|
|
||||||
app *tview.Application
|
app *tview.Application
|
||||||
}
|
}
|
||||||
@ -25,7 +25,7 @@ type Widget struct {
|
|||||||
// NewWidget Make new instance of widget
|
// NewWidget Make new instance of widget
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
BarGraph: wtf.NewBarGraph(app, "Sample Bar Graph", settings.common, false),
|
BarGraph: view.NewBarGraph(app, "Sample Bar Graph", settings.common, false),
|
||||||
|
|
||||||
app: app,
|
app: app,
|
||||||
}
|
}
|
||||||
@ -43,13 +43,13 @@ func MakeGraph(widget *Widget) {
|
|||||||
|
|
||||||
//this could come from config
|
//this could come from config
|
||||||
const lineCount = 8
|
const lineCount = 8
|
||||||
var stats [lineCount]wtf.Bar
|
var stats [lineCount]view.Bar
|
||||||
|
|
||||||
barTime := time.Now()
|
barTime := time.Now()
|
||||||
for i := 0; i < lineCount; i++ {
|
for i := 0; i < lineCount; i++ {
|
||||||
barTime = barTime.Add(time.Duration(time.Minute))
|
barTime = barTime.Add(time.Duration(time.Minute))
|
||||||
|
|
||||||
bar := wtf.Bar{
|
bar := view.Bar{
|
||||||
Label: barTime.Format("15:04"),
|
Label: barTime.Format("15:04"),
|
||||||
Percent: rand.Intn(100-5) + 5,
|
Percent: rand.Intn(100-5) + 5,
|
||||||
}
|
}
|
||||||
|
@ -4,11 +4,11 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
*Client
|
*Client
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -16,7 +16,7 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
Client: NewClient(settings.apiKey),
|
Client: NewClient(settings.apiKey),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
|
@ -5,11 +5,11 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
app *tview.Application
|
app *tview.Application
|
||||||
clockColl ClockCollection
|
clockColl ClockCollection
|
||||||
@ -20,7 +20,7 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
app: app,
|
app: app,
|
||||||
settings: settings,
|
settings: settings,
|
||||||
|
@ -6,11 +6,12 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
args []string
|
args []string
|
||||||
cmd string
|
cmd string
|
||||||
@ -20,7 +21,7 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of the widget
|
// NewWidget creates a new instance of the widget
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
args: settings.args,
|
args: settings.args,
|
||||||
cmd: settings.cmd,
|
cmd: settings.cmd,
|
||||||
|
@ -8,7 +8,7 @@ import (
|
|||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
var ok = true
|
var ok = true
|
||||||
@ -18,7 +18,7 @@ const baseURL = "https://bittrex.com/api/v1.1/public/getmarketsummary"
|
|||||||
|
|
||||||
// Widget define wtf widget to register widget later
|
// Widget define wtf widget to register widget later
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
summaryList
|
summaryList
|
||||||
@ -27,7 +27,7 @@ type Widget struct {
|
|||||||
// NewWidget Make new instance of widget
|
// NewWidget Make new instance of widget
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
summaryList: summaryList{},
|
summaryList: summaryList{},
|
||||||
|
@ -8,11 +8,11 @@ import (
|
|||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
device_token string
|
device_token string
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -20,7 +20,7 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
device_token: settings.deviceToken,
|
device_token: settings.deviceToken,
|
||||||
settings: settings,
|
settings: settings,
|
||||||
|
@ -7,12 +7,12 @@ import (
|
|||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/modules/cryptoexchanges/cryptolive/price"
|
"github.com/wtfutil/wtf/modules/cryptoexchanges/cryptolive/price"
|
||||||
"github.com/wtfutil/wtf/modules/cryptoexchanges/cryptolive/toplist"
|
"github.com/wtfutil/wtf/modules/cryptoexchanges/cryptolive/toplist"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Widget define wtf widget to register widget later
|
// Widget define wtf widget to register widget later
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
priceWidget *price.Widget
|
priceWidget *price.Widget
|
||||||
toplistWidget *toplist.Widget
|
toplistWidget *toplist.Widget
|
||||||
@ -22,7 +22,7 @@ type Widget struct {
|
|||||||
// NewWidget Make new instance of widget
|
// NewWidget Make new instance of widget
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
priceWidget: price.NewWidget(settings.priceSettings),
|
priceWidget: price.NewWidget(settings.priceSettings),
|
||||||
toplistWidget: toplist.NewWidget(settings.toplistSettings),
|
toplistWidget: toplist.NewWidget(settings.toplistSettings),
|
||||||
|
@ -4,13 +4,14 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
datadog "github.com/zorkian/go-datadog-api"
|
datadog "github.com/zorkian/go-datadog-api"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
monitors []datadog.Monitor
|
monitors []datadog.Monitor
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -18,8 +19,8 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,7 @@ import (
|
|||||||
|
|
||||||
"github.com/mmcdole/gofeed"
|
"github.com/mmcdole/gofeed"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -22,8 +23,8 @@ type FeedItem struct {
|
|||||||
|
|
||||||
// Widget is the container for RSS and Atom data
|
// Widget is the container for RSS and Atom data
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
stories []*FeedItem
|
stories []*FeedItem
|
||||||
parser *gofeed.Parser
|
parser *gofeed.Parser
|
||||||
@ -33,8 +34,8 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := &Widget{
|
widget := &Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
parser: gofeed.NewParser(),
|
parser: gofeed.NewParser(),
|
||||||
settings: settings,
|
settings: settings,
|
||||||
|
@ -2,11 +2,11 @@ package gcal
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
app *tview.Application
|
app *tview.Application
|
||||||
calEvents []*CalEvent
|
calEvents []*CalEvent
|
||||||
@ -15,7 +15,7 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
app: app,
|
app: app,
|
||||||
settings: settings,
|
settings: settings,
|
||||||
|
@ -8,12 +8,13 @@ import (
|
|||||||
|
|
||||||
glb "github.com/andygrunwald/go-gerrit"
|
glb "github.com/andygrunwald/go-gerrit"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
gerrit *glb.Client
|
gerrit *glb.Client
|
||||||
|
|
||||||
@ -30,8 +31,8 @@ var (
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
Idx: 0,
|
Idx: 0,
|
||||||
|
|
||||||
|
@ -8,6 +8,7 @@ import (
|
|||||||
|
|
||||||
"github.com/gdamore/tcell"
|
"github.com/gdamore/tcell"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -16,9 +17,9 @@ const modalWidth = 80
|
|||||||
const modalHeight = 7
|
const modalHeight = 7
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.MultiSourceWidget
|
view.MultiSourceWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
GitRepos []*GitRepo
|
GitRepos []*GitRepo
|
||||||
|
|
||||||
@ -29,9 +30,9 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
MultiSourceWidget: wtf.NewMultiSourceWidget(settings.common, "repository", "repositories"),
|
MultiSourceWidget: view.NewMultiSourceWidget(settings.common, "repository", "repositories"),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
app: app,
|
app: app,
|
||||||
pages: pages,
|
pages: pages,
|
||||||
|
@ -4,13 +4,13 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.MultiSourceWidget
|
view.MultiSourceWidget
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
GithubRepos []*GithubRepo
|
GithubRepos []*GithubRepo
|
||||||
|
|
||||||
@ -19,9 +19,9 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
MultiSourceWidget: wtf.NewMultiSourceWidget(settings.common, "repository", "repositories"),
|
MultiSourceWidget: view.NewMultiSourceWidget(settings.common, "repository", "repositories"),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -2,14 +2,14 @@ package gitlab
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
glb "github.com/xanzy/go-gitlab"
|
glb "github.com/xanzy/go-gitlab"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.MultiSourceWidget
|
view.MultiSourceWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
GitlabProjects []*GitlabProject
|
GitlabProjects []*GitlabProject
|
||||||
|
|
||||||
@ -26,9 +26,9 @@ func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *
|
|||||||
}
|
}
|
||||||
|
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
MultiSourceWidget: wtf.NewMultiSourceWidget(settings.common, "repository", "repositories"),
|
MultiSourceWidget: view.NewMultiSourceWidget(settings.common, "repository", "repositories"),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
gitlab: gitlab,
|
gitlab: gitlab,
|
||||||
settings: settings,
|
settings: settings,
|
||||||
|
@ -4,13 +4,14 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
// A Widget represents a Gitter widget
|
// A Widget represents a Gitter widget
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
messages []Message
|
messages []Message
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -19,8 +20,8 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -2,18 +2,18 @@ package googleanalytics
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -4,19 +4,20 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
sheets "google.golang.org/api/sheets/v4"
|
sheets "google.golang.org/api/sheets/v4"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -6,12 +6,13 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
stories []Story
|
stories []Story
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -19,8 +20,8 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := &Widget{
|
widget := &Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -4,12 +4,12 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Widget is the container for hibp data
|
// Widget is the container for hibp data
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
accounts []string
|
accounts []string
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -18,7 +18,7 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := &Widget{
|
widget := &Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -9,12 +9,12 @@ import (
|
|||||||
"text/template"
|
"text/template"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Widget widget struct
|
// Widget widget struct
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
result string
|
result string
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -38,7 +38,7 @@ type ipinfo struct {
|
|||||||
// NewWidget constructor
|
// NewWidget constructor
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -8,11 +8,11 @@ import (
|
|||||||
"text/template"
|
"text/template"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
result string
|
result string
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -31,7 +31,7 @@ type ipinfo struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -5,12 +5,13 @@ import (
|
|||||||
"regexp"
|
"regexp"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
view *View
|
view *View
|
||||||
@ -18,8 +19,8 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -4,12 +4,13 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
result *SearchResult
|
result *SearchResult
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -17,8 +18,8 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -7,13 +7,13 @@ import (
|
|||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
log "github.com/wtfutil/wtf/logger"
|
log "github.com/wtfutil/wtf/logger"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
const maxBufferSize int64 = 1024
|
const maxBufferSize int64 = 1024
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
app *tview.Application
|
app *tview.Application
|
||||||
filePath string
|
filePath string
|
||||||
@ -22,7 +22,7 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
app: app,
|
app: app,
|
||||||
filePath: log.LogFilePath(),
|
filePath: log.LogFilePath(),
|
||||||
|
@ -3,6 +3,7 @@ package mercurial
|
|||||||
import (
|
import (
|
||||||
"github.com/gdamore/tcell"
|
"github.com/gdamore/tcell"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -12,9 +13,9 @@ const modalHeight = 7
|
|||||||
|
|
||||||
// A Widget represents a Mercurial widget
|
// A Widget represents a Mercurial widget
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.MultiSourceWidget
|
view.MultiSourceWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
app *tview.Application
|
app *tview.Application
|
||||||
Data []*MercurialRepo
|
Data []*MercurialRepo
|
||||||
@ -25,9 +26,9 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
MultiSourceWidget: wtf.NewMultiSourceWidget(settings.common, "repository", "repositories"),
|
MultiSourceWidget: view.NewMultiSourceWidget(settings.common, "repository", "repositories"),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
app: app,
|
app: app,
|
||||||
pages: pages,
|
pages: pages,
|
||||||
|
@ -9,13 +9,14 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
// A Widget represents an NBA Score widget
|
// A Widget represents an NBA Score widget
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
language string
|
language string
|
||||||
result string
|
result string
|
||||||
@ -27,8 +28,8 @@ var offset = 0
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -4,12 +4,13 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
nr "github.com/yfronto/newrelic"
|
nr "github.com/yfronto/newrelic"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
client *Client
|
client *Client
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -17,7 +18,7 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -5,18 +5,19 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -6,18 +6,19 @@ import (
|
|||||||
|
|
||||||
"github.com/PagerDuty/go-pagerduty"
|
"github.com/PagerDuty/go-pagerduty"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -4,11 +4,11 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
Battery *Battery
|
Battery *Battery
|
||||||
|
|
||||||
@ -17,7 +17,7 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
Battery: NewBattery(),
|
Battery: NewBattery(),
|
||||||
|
|
||||||
|
@ -1,14 +1,15 @@
|
|||||||
package resourceusage
|
package resourceusage
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"code.cloudfoundry.org/bytefmt"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"math"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"code.cloudfoundry.org/bytefmt"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/shirou/gopsutil/cpu"
|
"github.com/shirou/gopsutil/cpu"
|
||||||
"github.com/shirou/gopsutil/mem"
|
"github.com/shirou/gopsutil/mem"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
"math"
|
|
||||||
"time"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var started = false
|
var started = false
|
||||||
@ -16,7 +17,7 @@ var ok = true
|
|||||||
|
|
||||||
// Widget define wtf widget to register widget later
|
// Widget define wtf widget to register widget later
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.BarGraph
|
view.BarGraph
|
||||||
|
|
||||||
app *tview.Application
|
app *tview.Application
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -25,7 +26,7 @@ type Widget struct {
|
|||||||
// NewWidget Make new instance of widget
|
// NewWidget Make new instance of widget
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
BarGraph: wtf.NewBarGraph(app, settings.common.Name, settings.common, false),
|
BarGraph: view.NewBarGraph(app, settings.common.Name, settings.common, false),
|
||||||
|
|
||||||
app: app,
|
app: app,
|
||||||
settings: settings,
|
settings: settings,
|
||||||
@ -46,14 +47,14 @@ func MakeGraph(widget *Widget) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
var stats = make([]wtf.Bar, len(cpuStats)+2)
|
var stats = make([]view.Bar, len(cpuStats)+2)
|
||||||
|
|
||||||
for i, stat := range cpuStats {
|
for i, stat := range cpuStats {
|
||||||
// Stats sometimes jump outside the 0-100 range, possibly due to timing
|
// Stats sometimes jump outside the 0-100 range, possibly due to timing
|
||||||
stat = math.Min(100, stat)
|
stat = math.Min(100, stat)
|
||||||
stat = math.Max(0, stat)
|
stat = math.Max(0, stat)
|
||||||
|
|
||||||
bar := wtf.Bar{
|
bar := view.Bar{
|
||||||
Label: fmt.Sprint(i),
|
Label: fmt.Sprint(i),
|
||||||
Percent: int(stat),
|
Percent: int(stat),
|
||||||
ValueLabel: fmt.Sprintf("%d%%", int(stat)),
|
ValueLabel: fmt.Sprintf("%d%%", int(stat)),
|
||||||
@ -76,7 +77,7 @@ func MakeGraph(widget *Widget) {
|
|||||||
usedMemLabel = usedMemLabel[:len(usedMemLabel)-1]
|
usedMemLabel = usedMemLabel[:len(usedMemLabel)-1]
|
||||||
}
|
}
|
||||||
|
|
||||||
stats[memIndex] = wtf.Bar{
|
stats[memIndex] = view.Bar{
|
||||||
Label: "Mem",
|
Label: "Mem",
|
||||||
Percent: int(memInfo.UsedPercent),
|
Percent: int(memInfo.UsedPercent),
|
||||||
ValueLabel: fmt.Sprintf("%s/%s", usedMemLabel, totalMemLabel),
|
ValueLabel: fmt.Sprintf("%s/%s", usedMemLabel, totalMemLabel),
|
||||||
@ -96,7 +97,7 @@ func MakeGraph(widget *Widget) {
|
|||||||
usedSwapLabel = usedSwapLabel[:len(usedSwapLabel)-1]
|
usedSwapLabel = usedSwapLabel[:len(usedSwapLabel)-1]
|
||||||
}
|
}
|
||||||
|
|
||||||
stats[swapIndex] = wtf.Bar{
|
stats[swapIndex] = view.Bar{
|
||||||
Label: "Swp",
|
Label: "Swp",
|
||||||
Percent: int(swapPercent * 100),
|
Percent: int(swapPercent * 100),
|
||||||
ValueLabel: fmt.Sprintf("%s/%s", usedSwapLabel, totalSwapLabel),
|
ValueLabel: fmt.Sprintf("%s/%s", usedSwapLabel, totalSwapLabel),
|
||||||
|
@ -4,13 +4,14 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
// A Widget represents a Rollbar widget
|
// A Widget represents a Rollbar widget
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
items *Result
|
items *Result
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -19,8 +20,8 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -5,18 +5,18 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -5,13 +5,14 @@ import (
|
|||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/sticreations/spotigopher/spotigopher"
|
"github.com/sticreations/spotigopher/spotigopher"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
// A Widget represents a Spotify widget
|
// A Widget represents a Spotify widget
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
client spotigopher.SpotifyClient
|
client spotigopher.SpotifyClient
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -21,8 +22,8 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
Info: spotigopher.Info{},
|
Info: spotigopher.Info{},
|
||||||
client: spotigopher.NewClient(),
|
client: spotigopher.NewClient(),
|
||||||
|
@ -7,6 +7,7 @@ import (
|
|||||||
"os"
|
"os"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
"github.com/zmb3/spotify"
|
"github.com/zmb3/spotify"
|
||||||
)
|
)
|
||||||
@ -22,8 +23,8 @@ type Info struct {
|
|||||||
|
|
||||||
// Widget is the struct used by all WTF widgets to transfer to the main widget controller
|
// Widget is the struct used by all WTF widgets to transfer to the main widget controller
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
Info
|
Info
|
||||||
|
|
||||||
@ -68,8 +69,8 @@ func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *
|
|||||||
var playerState *spotify.PlayerState
|
var playerState *spotify.PlayerState
|
||||||
|
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
Info: Info{},
|
Info: Info{},
|
||||||
|
|
||||||
|
@ -2,11 +2,11 @@ package status
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
CurrentIcon int
|
CurrentIcon int
|
||||||
|
|
||||||
@ -15,7 +15,7 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
CurrentIcon: 0,
|
CurrentIcon: 0,
|
||||||
|
|
||||||
|
@ -5,11 +5,12 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
Date string
|
Date string
|
||||||
Version string
|
Version string
|
||||||
@ -20,7 +21,7 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, date, version string, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, date, version string, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
Date: date,
|
Date: date,
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ import (
|
|||||||
"github.com/radovskyb/watcher"
|
"github.com/radovskyb/watcher"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/utils"
|
"github.com/wtfutil/wtf/utils"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -22,9 +22,9 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.MultiSourceWidget
|
view.MultiSourceWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
}
|
}
|
||||||
@ -32,9 +32,9 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
MultiSourceWidget: wtf.NewMultiSourceWidget(settings.common, "filePath", "filePaths"),
|
MultiSourceWidget: view.NewMultiSourceWidget(settings.common, "filePath", "filePaths"),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -8,18 +8,21 @@ import (
|
|||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/cfg"
|
"github.com/wtfutil/wtf/cfg"
|
||||||
"github.com/wtfutil/wtf/checklist"
|
"github.com/wtfutil/wtf/checklist"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
"gopkg.in/yaml.v2"
|
"gopkg.in/yaml.v2"
|
||||||
)
|
)
|
||||||
|
|
||||||
const offscreen = -1000
|
const (
|
||||||
const modalWidth = 80
|
offscreen = -1000
|
||||||
const modalHeight = 7
|
modalWidth = 80
|
||||||
|
modalHeight = 7
|
||||||
|
)
|
||||||
|
|
||||||
// A Widget represents a Todo widget
|
// A Widget represents a Todo widget
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
app *tview.Application
|
app *tview.Application
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -31,8 +34,8 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
app: app,
|
app: app,
|
||||||
settings: settings,
|
settings: settings,
|
||||||
|
@ -3,14 +3,14 @@ package todoist
|
|||||||
import (
|
import (
|
||||||
"github.com/darkSasori/todoist"
|
"github.com/darkSasori/todoist"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
// A Widget represents a Todoist widget
|
// A Widget represents a Todoist widget
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.MultiSourceWidget
|
view.MultiSourceWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
projects []*Project
|
projects []*Project
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -19,9 +19,9 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
MultiSourceWidget: wtf.NewMultiSourceWidget(settings.common, "project", "projects"),
|
MultiSourceWidget: view.NewMultiSourceWidget(settings.common, "project", "projects"),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -5,13 +5,13 @@ import (
|
|||||||
|
|
||||||
"github.com/hekmon/transmissionrpc"
|
"github.com/hekmon/transmissionrpc"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Widget is the container for transmission data
|
// Widget is the container for transmission data
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
client *transmissionrpc.Client
|
client *transmissionrpc.Client
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -21,8 +21,8 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -5,12 +5,13 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
builds *Builds
|
builds *Builds
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -18,8 +19,8 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -5,18 +5,18 @@ import (
|
|||||||
|
|
||||||
"github.com/adlio/trello"
|
"github.com/adlio/trello"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -7,13 +7,14 @@ import (
|
|||||||
|
|
||||||
"github.com/dustin/go-humanize"
|
"github.com/dustin/go-humanize"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.MultiSourceWidget
|
view.MultiSourceWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
client *Client
|
client *Client
|
||||||
idx int
|
idx int
|
||||||
@ -23,9 +24,9 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
MultiSourceWidget: wtf.NewMultiSourceWidget(settings.common, "screenName", "screenNames"),
|
MultiSourceWidget: view.NewMultiSourceWidget(settings.common, "screenName", "screenNames"),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
idx: 0,
|
idx: 0,
|
||||||
settings: settings,
|
settings: settings,
|
||||||
|
@ -4,18 +4,18 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
settings *Settings
|
settings *Settings
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -4,12 +4,12 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/view"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Widget contains text info
|
// Widget contains text info
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
teams []OnCallTeam
|
teams []OnCallTeam
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -18,7 +18,7 @@ type Widget struct {
|
|||||||
// NewWidget creates a new widget
|
// NewWidget creates a new widget
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
}
|
}
|
||||||
|
|
||||||
widget.View.SetScrollable(true)
|
widget.View.SetScrollable(true)
|
||||||
|
@ -6,11 +6,12 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
result string
|
result string
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -18,7 +19,7 @@ type Widget struct {
|
|||||||
|
|
||||||
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, false),
|
TextWidget: view.NewTextWidget(app, settings.common, false),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
@ -3,14 +3,15 @@ package weather
|
|||||||
import (
|
import (
|
||||||
owm "github.com/briandowns/openweathermap"
|
owm "github.com/briandowns/openweathermap"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Widget is the container for weather data.
|
// Widget is the container for weather data.
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.MultiSourceWidget
|
view.MultiSourceWidget
|
||||||
wtf.TextWidget
|
view.TextWidget
|
||||||
|
|
||||||
// APIKey string
|
// APIKey string
|
||||||
Data []*owm.CurrentWeatherData
|
Data []*owm.CurrentWeatherData
|
||||||
@ -22,9 +23,9 @@ type Widget struct {
|
|||||||
// NewWidget creates and returns a new instance of the weather Widget
|
// NewWidget creates and returns a new instance of the weather Widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
MultiSourceWidget: wtf.NewMultiSourceWidget(settings.common, "cityid", "cityids"),
|
MultiSourceWidget: view.NewMultiSourceWidget(settings.common, "cityid", "cityids"),
|
||||||
TextWidget: wtf.NewTextWidget(app, settings.common, true),
|
TextWidget: view.NewTextWidget(app, settings.common, true),
|
||||||
|
|
||||||
pages: pages,
|
pages: pages,
|
||||||
settings: settings,
|
settings: settings,
|
||||||
|
@ -5,13 +5,14 @@ import (
|
|||||||
"log"
|
"log"
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/view"
|
||||||
"github.com/wtfutil/wtf/wtf"
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
// A Widget represents a Zendesk widget
|
// A Widget represents a Zendesk widget
|
||||||
type Widget struct {
|
type Widget struct {
|
||||||
wtf.KeyboardWidget
|
view.KeyboardWidget
|
||||||
wtf.ScrollableWidget
|
view.ScrollableWidget
|
||||||
|
|
||||||
result *TicketArray
|
result *TicketArray
|
||||||
settings *Settings
|
settings *Settings
|
||||||
@ -20,8 +21,8 @@ type Widget struct {
|
|||||||
// NewWidget creates a new instance of a widget
|
// NewWidget creates a new instance of a widget
|
||||||
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
|
||||||
widget := Widget{
|
widget := Widget{
|
||||||
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
|
KeyboardWidget: view.NewKeyboardWidget(app, pages, settings.common),
|
||||||
ScrollableWidget: wtf.NewScrollableWidget(app, settings.common, true),
|
ScrollableWidget: view.NewScrollableWidget(app, settings.common, true),
|
||||||
|
|
||||||
settings: settings,
|
settings: settings,
|
||||||
}
|
}
|
||||||
|
112
view/bargraph.go
Normal file
112
view/bargraph.go
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
package view
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"fmt"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/cfg"
|
||||||
|
"github.com/wtfutil/wtf/wtf"
|
||||||
|
)
|
||||||
|
|
||||||
|
//BarGraph defines the data required to make a bar graph
|
||||||
|
type BarGraph struct {
|
||||||
|
maxStars int
|
||||||
|
starChar string
|
||||||
|
|
||||||
|
Base
|
||||||
|
View *tview.TextView
|
||||||
|
}
|
||||||
|
|
||||||
|
// Bar defines a single row in the bar graph
|
||||||
|
type Bar struct {
|
||||||
|
Label string
|
||||||
|
Percent int
|
||||||
|
ValueLabel string
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewBarGraph creates and returns an instance of BarGraph
|
||||||
|
func NewBarGraph(app *tview.Application, name string, commonSettings *cfg.Common, focusable bool) BarGraph {
|
||||||
|
widget := BarGraph{
|
||||||
|
Base: NewBase(app, commonSettings, focusable),
|
||||||
|
|
||||||
|
maxStars: commonSettings.Config.UInt("graphStars", 20),
|
||||||
|
starChar: commonSettings.Config.UString("graphIcon", "|"),
|
||||||
|
}
|
||||||
|
|
||||||
|
widget.View = widget.createView(widget.bordered)
|
||||||
|
|
||||||
|
return widget
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------- Exported Functions -------------------- */
|
||||||
|
|
||||||
|
// BuildBars will build a string of * to represent your data of [time][value]
|
||||||
|
// time should be passed as a int64
|
||||||
|
func (widget *BarGraph) BuildBars(data []Bar) {
|
||||||
|
widget.View.SetText(BuildStars(data, widget.maxStars, widget.starChar))
|
||||||
|
}
|
||||||
|
|
||||||
|
//BuildStars build the string to display
|
||||||
|
func BuildStars(data []Bar, maxStars int, starChar string) string {
|
||||||
|
var buffer bytes.Buffer
|
||||||
|
|
||||||
|
// the number of characters in the longest label
|
||||||
|
var longestLabel int
|
||||||
|
|
||||||
|
//just getting min and max values
|
||||||
|
for _, bar := range data {
|
||||||
|
if len(bar.Label) > longestLabel {
|
||||||
|
longestLabel = len(bar.Label)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// each number = how many stars?
|
||||||
|
var starRatio = float64(maxStars) / 100
|
||||||
|
|
||||||
|
//build the stars
|
||||||
|
for _, bar := range data {
|
||||||
|
//how many stars for this one?
|
||||||
|
var starCount = int(float64(bar.Percent) * starRatio)
|
||||||
|
|
||||||
|
label := bar.ValueLabel
|
||||||
|
if len(label) == 0 {
|
||||||
|
label = fmt.Sprint(bar.Percent)
|
||||||
|
}
|
||||||
|
|
||||||
|
//write the line
|
||||||
|
buffer.WriteString(
|
||||||
|
fmt.Sprintf(
|
||||||
|
"%s%s[[red]%s[white]%s] %s\n",
|
||||||
|
bar.Label,
|
||||||
|
strings.Repeat(" ", longestLabel-len(bar.Label)),
|
||||||
|
strings.Repeat(starChar, starCount),
|
||||||
|
strings.Repeat(" ", maxStars-starCount),
|
||||||
|
label,
|
||||||
|
),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
return buffer.String()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (widget *BarGraph) TextView() *tview.TextView {
|
||||||
|
return widget.View
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------- Unexported Functions -------------------- */
|
||||||
|
|
||||||
|
func (widget *BarGraph) createView(bordered bool) *tview.TextView {
|
||||||
|
view := tview.NewTextView()
|
||||||
|
|
||||||
|
view.SetBackgroundColor(wtf.ColorFor(widget.commonSettings.Colors.Background))
|
||||||
|
view.SetBorder(bordered)
|
||||||
|
view.SetBorderColor(wtf.ColorFor(widget.BorderColor()))
|
||||||
|
view.SetDynamicColors(true)
|
||||||
|
view.SetTitle(widget.ContextualTitle(widget.CommonSettings().Title))
|
||||||
|
view.SetTitleColor(wtf.ColorFor(widget.commonSettings.Colors.Title))
|
||||||
|
view.SetWrap(false)
|
||||||
|
|
||||||
|
return view
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
package wtf
|
package view
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
124
view/base.go
Normal file
124
view/base.go
Normal file
@ -0,0 +1,124 @@
|
|||||||
|
package view
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/cfg"
|
||||||
|
"github.com/wtfutil/wtf/utils"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Base struct {
|
||||||
|
app *tview.Application
|
||||||
|
bordered bool
|
||||||
|
commonSettings *cfg.Common
|
||||||
|
enabled bool
|
||||||
|
focusChar string
|
||||||
|
focusable bool
|
||||||
|
name string
|
||||||
|
quitChan chan bool
|
||||||
|
refreshing bool
|
||||||
|
refreshInterval int
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewBase(app *tview.Application, commonSettings *cfg.Common, focusable bool) Base {
|
||||||
|
base := Base{
|
||||||
|
commonSettings: commonSettings,
|
||||||
|
app: app,
|
||||||
|
bordered: commonSettings.Bordered,
|
||||||
|
enabled: commonSettings.Enabled,
|
||||||
|
focusChar: commonSettings.FocusChar(),
|
||||||
|
focusable: focusable,
|
||||||
|
name: commonSettings.Name,
|
||||||
|
quitChan: make(chan bool),
|
||||||
|
refreshInterval: commonSettings.RefreshInterval,
|
||||||
|
refreshing: false,
|
||||||
|
}
|
||||||
|
return base
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------- Exported Functions -------------------- */
|
||||||
|
|
||||||
|
// Bordered returns whether or not this widget should be drawn with a border
|
||||||
|
func (base *Base) Bordered() bool {
|
||||||
|
return base.bordered
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) BorderColor() string {
|
||||||
|
if base.Focusable() {
|
||||||
|
return base.commonSettings.Colors.BorderFocusable
|
||||||
|
}
|
||||||
|
|
||||||
|
return base.commonSettings.Colors.BorderNormal
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) CommonSettings() *cfg.Common {
|
||||||
|
return base.commonSettings
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) ConfigText() string {
|
||||||
|
return utils.HelpFromInterface(cfg.Common{})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) ContextualTitle(defaultStr string) string {
|
||||||
|
if base.FocusChar() == "" {
|
||||||
|
return fmt.Sprintf(" %s ", defaultStr)
|
||||||
|
}
|
||||||
|
|
||||||
|
return fmt.Sprintf(" %s [darkgray::u]%s[::-][green] ", defaultStr, base.FocusChar())
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) Disable() {
|
||||||
|
base.enabled = false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) Disabled() bool {
|
||||||
|
return !base.enabled
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) Enabled() bool {
|
||||||
|
return base.enabled
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) Focusable() bool {
|
||||||
|
return base.enabled && base.focusable
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) FocusChar() string {
|
||||||
|
return base.focusChar
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) HelpText() string {
|
||||||
|
return fmt.Sprintf("\n There is no help available for widget %s", base.commonSettings.Module.Type)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) Name() string {
|
||||||
|
return base.name
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) QuitChan() chan bool {
|
||||||
|
return base.quitChan
|
||||||
|
}
|
||||||
|
|
||||||
|
// Refreshing returns TRUE if the base is currently refreshing its data, FALSE if it is not
|
||||||
|
func (base *Base) Refreshing() bool {
|
||||||
|
return base.refreshing
|
||||||
|
}
|
||||||
|
|
||||||
|
// RefreshInterval returns how often, in seconds, the base will return its data
|
||||||
|
func (base *Base) RefreshInterval() int {
|
||||||
|
return base.refreshInterval
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) SetFocusChar(char string) {
|
||||||
|
base.focusChar = char
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) Stop() {
|
||||||
|
base.enabled = false
|
||||||
|
base.quitChan <- true
|
||||||
|
}
|
||||||
|
|
||||||
|
func (base *Base) String() string {
|
||||||
|
return base.name
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
package wtf
|
package view
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
@ -7,6 +7,7 @@ import (
|
|||||||
"github.com/gdamore/tcell"
|
"github.com/gdamore/tcell"
|
||||||
"github.com/rivo/tview"
|
"github.com/rivo/tview"
|
||||||
"github.com/wtfutil/wtf/cfg"
|
"github.com/wtfutil/wtf/cfg"
|
||||||
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
type helpItem struct {
|
type helpItem struct {
|
||||||
@ -120,7 +121,7 @@ func (widget *KeyboardWidget) ShowHelp() {
|
|||||||
widget.app.SetFocus(widget.view)
|
widget.app.SetFocus(widget.view)
|
||||||
}
|
}
|
||||||
|
|
||||||
modal := NewBillboardModal(widget.HelpText(), closeFunc)
|
modal := wtf.NewBillboardModal(widget.HelpText(), closeFunc)
|
||||||
|
|
||||||
widget.pages.AddPage("help", modal, false, true)
|
widget.pages.AddPage("help", modal, false, true)
|
||||||
widget.app.SetFocus(modal)
|
widget.app.SetFocus(modal)
|
@ -1,4 +1,4 @@
|
|||||||
package wtf
|
package view
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
@ -1,7 +1,8 @@
|
|||||||
package wtf
|
package view
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/wtfutil/wtf/cfg"
|
"github.com/wtfutil/wtf/cfg"
|
||||||
|
"github.com/wtfutil/wtf/wtf"
|
||||||
)
|
)
|
||||||
|
|
||||||
// MultiSourceWidget is a widget that supports displaying data from multiple sources
|
// MultiSourceWidget is a widget that supports displaying data from multiple sources
|
||||||
@ -89,7 +90,7 @@ func (widget *MultiSourceWidget) loadSources() {
|
|||||||
single := widget.moduleConfig.Config.UString(widget.singular, "")
|
single := widget.moduleConfig.Config.UString(widget.singular, "")
|
||||||
multiple := widget.moduleConfig.Config.UList(widget.plural, empty)
|
multiple := widget.moduleConfig.Config.UList(widget.plural, empty)
|
||||||
|
|
||||||
asStrs := ToStrs(multiple)
|
asStrs := wtf.ToStrs(multiple)
|
||||||
|
|
||||||
if single != "" {
|
if single != "" {
|
||||||
asStrs = append(asStrs, single)
|
asStrs = append(asStrs, single)
|
@ -1,4 +1,4 @@
|
|||||||
package wtf
|
package view
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"strconv"
|
"strconv"
|
||||||
@ -16,7 +16,6 @@ type ScrollableWidget struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func NewScrollableWidget(app *tview.Application, commonSettings *cfg.Common, focusable bool) ScrollableWidget {
|
func NewScrollableWidget(app *tview.Application, commonSettings *cfg.Common, focusable bool) ScrollableWidget {
|
||||||
|
|
||||||
widget := ScrollableWidget{
|
widget := ScrollableWidget{
|
||||||
TextWidget: NewTextWidget(app, commonSettings, focusable),
|
TextWidget: NewTextWidget(app, commonSettings, focusable),
|
||||||
}
|
}
|
||||||
@ -28,6 +27,8 @@ func NewScrollableWidget(app *tview.Application, commonSettings *cfg.Common, foc
|
|||||||
return widget
|
return widget
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* -------------------- Exported Functions -------------------- */
|
||||||
|
|
||||||
func (widget *ScrollableWidget) SetRenderFunction(displayFunc func()) {
|
func (widget *ScrollableWidget) SetRenderFunction(displayFunc func()) {
|
||||||
widget.RenderFunction = displayFunc
|
widget.RenderFunction = displayFunc
|
||||||
}
|
}
|
55
view/text_widget.go
Normal file
55
view/text_widget.go
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
package view
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/rivo/tview"
|
||||||
|
"github.com/wtfutil/wtf/cfg"
|
||||||
|
"github.com/wtfutil/wtf/wtf"
|
||||||
|
)
|
||||||
|
|
||||||
|
// TextWidget defines the data necessary to make a text widget
|
||||||
|
type TextWidget struct {
|
||||||
|
Base
|
||||||
|
View *tview.TextView
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewTextWidget creates and returns an instance of TextWidget
|
||||||
|
func NewTextWidget(app *tview.Application, commonSettings *cfg.Common, focusable bool) TextWidget {
|
||||||
|
widget := TextWidget{
|
||||||
|
Base: NewBase(app, commonSettings, focusable),
|
||||||
|
}
|
||||||
|
|
||||||
|
widget.View = widget.createView(widget.bordered)
|
||||||
|
|
||||||
|
return widget
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------- Exported Functions -------------------- */
|
||||||
|
|
||||||
|
func (widget *TextWidget) TextView() *tview.TextView {
|
||||||
|
return widget.View
|
||||||
|
}
|
||||||
|
|
||||||
|
func (widget *TextWidget) Redraw(title, text string, wrap bool) {
|
||||||
|
widget.app.QueueUpdateDraw(func() {
|
||||||
|
widget.View.Clear()
|
||||||
|
widget.View.SetWrap(wrap)
|
||||||
|
widget.View.SetTitle(widget.ContextualTitle(title))
|
||||||
|
widget.View.SetText(text)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------- Unexported Functions -------------------- */
|
||||||
|
|
||||||
|
func (widget *TextWidget) createView(bordered bool) *tview.TextView {
|
||||||
|
view := tview.NewTextView()
|
||||||
|
|
||||||
|
view.SetBackgroundColor(wtf.ColorFor(widget.commonSettings.Colors.Background))
|
||||||
|
view.SetBorder(bordered)
|
||||||
|
view.SetBorderColor(wtf.ColorFor(widget.BorderColor()))
|
||||||
|
view.SetDynamicColors(true)
|
||||||
|
view.SetTextColor(wtf.ColorFor(widget.commonSettings.Colors.Text))
|
||||||
|
view.SetTitleColor(wtf.ColorFor(widget.commonSettings.Colors.Title))
|
||||||
|
view.SetWrap(false)
|
||||||
|
|
||||||
|
return view
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
package wtf
|
package view
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
197
wtf/bargraph.go
197
wtf/bargraph.go
@ -1,197 +0,0 @@
|
|||||||
package wtf
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"fmt"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
|
||||||
"github.com/wtfutil/wtf/cfg"
|
|
||||||
)
|
|
||||||
|
|
||||||
//BarGraph lets make graphs
|
|
||||||
type BarGraph struct {
|
|
||||||
commonSettings *cfg.Common
|
|
||||||
enabled bool
|
|
||||||
focusable bool
|
|
||||||
key string
|
|
||||||
maxStars int
|
|
||||||
name string
|
|
||||||
quitChan chan bool
|
|
||||||
refreshing bool
|
|
||||||
starChar string
|
|
||||||
|
|
||||||
RefreshInt int
|
|
||||||
View *tview.TextView
|
|
||||||
}
|
|
||||||
|
|
||||||
type Bar struct {
|
|
||||||
Label string
|
|
||||||
Percent int
|
|
||||||
ValueLabel string
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewBarGraph initialize your fancy new graph
|
|
||||||
func NewBarGraph(app *tview.Application, name string, settings *cfg.Common, focusable bool) BarGraph {
|
|
||||||
widget := BarGraph{
|
|
||||||
enabled: settings.Enabled,
|
|
||||||
focusable: focusable,
|
|
||||||
maxStars: settings.Config.UInt("graphStars", 20),
|
|
||||||
name: settings.Title,
|
|
||||||
quitChan: make(chan bool),
|
|
||||||
starChar: settings.Config.UString("graphIcon", "|"),
|
|
||||||
commonSettings: settings,
|
|
||||||
|
|
||||||
RefreshInt: settings.RefreshInterval,
|
|
||||||
}
|
|
||||||
|
|
||||||
widget.View = widget.addView()
|
|
||||||
widget.View.SetChangedFunc(func() {
|
|
||||||
app.Draw()
|
|
||||||
})
|
|
||||||
|
|
||||||
return widget
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) BorderColor() string {
|
|
||||||
if widget.Focusable() {
|
|
||||||
return widget.commonSettings.Colors.BorderFocusable
|
|
||||||
}
|
|
||||||
|
|
||||||
return widget.commonSettings.Colors.BorderNormal
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) CommonSettings() *cfg.Common {
|
|
||||||
return widget.commonSettings
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) Disable() {
|
|
||||||
widget.enabled = false
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) Disabled() bool {
|
|
||||||
return !widget.Enabled()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) Enabled() bool {
|
|
||||||
return widget.enabled
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) Focusable() bool {
|
|
||||||
return widget.enabled && widget.focusable
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) FocusChar() string {
|
|
||||||
return ""
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) Key() string {
|
|
||||||
return widget.key
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) Name() string {
|
|
||||||
return widget.name
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) QuitChan() chan bool {
|
|
||||||
return widget.quitChan
|
|
||||||
}
|
|
||||||
|
|
||||||
// Refreshing returns TRUE if the widget is currently refreshing its data, FALSE if it is not
|
|
||||||
func (widget *BarGraph) Refreshing() bool {
|
|
||||||
return widget.refreshing
|
|
||||||
}
|
|
||||||
|
|
||||||
// RefreshInterval returns how often, in seconds, the widget will return its data
|
|
||||||
func (widget *BarGraph) RefreshInterval() int {
|
|
||||||
return widget.RefreshInt
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) SetFocusChar(char string) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) Stop() {
|
|
||||||
widget.enabled = false
|
|
||||||
widget.quitChan <- true
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) TextView() *tview.TextView {
|
|
||||||
return widget.View
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) HelpText() string {
|
|
||||||
return "No help available for this widget"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *BarGraph) ConfigText() string {
|
|
||||||
return ""
|
|
||||||
}
|
|
||||||
|
|
||||||
// BuildBars will build a string of * to represent your data of [time][value]
|
|
||||||
// time should be passed as a int64
|
|
||||||
func (widget *BarGraph) BuildBars(data []Bar) {
|
|
||||||
widget.View.SetText(BuildStars(data, widget.maxStars, widget.starChar))
|
|
||||||
}
|
|
||||||
|
|
||||||
//BuildStars build the string to display
|
|
||||||
func BuildStars(data []Bar, maxStars int, starChar string) string {
|
|
||||||
var buffer bytes.Buffer
|
|
||||||
|
|
||||||
// the number of characters in the longest label
|
|
||||||
var longestLabel int
|
|
||||||
|
|
||||||
//just getting min and max values
|
|
||||||
for _, bar := range data {
|
|
||||||
|
|
||||||
if len(bar.Label) > longestLabel {
|
|
||||||
longestLabel = len(bar.Label)
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// each number = how many stars?
|
|
||||||
var starRatio = float64(maxStars) / 100
|
|
||||||
|
|
||||||
//build the stars
|
|
||||||
for _, bar := range data {
|
|
||||||
|
|
||||||
//how many stars for this one?
|
|
||||||
var starCount = int(float64(bar.Percent) * starRatio)
|
|
||||||
|
|
||||||
label := bar.ValueLabel
|
|
||||||
if len(label) == 0 {
|
|
||||||
label = fmt.Sprint(bar.Percent)
|
|
||||||
}
|
|
||||||
|
|
||||||
//write the line
|
|
||||||
buffer.WriteString(
|
|
||||||
fmt.Sprintf(
|
|
||||||
"%s%s[[red]%s[white]%s] %s\n",
|
|
||||||
bar.Label,
|
|
||||||
strings.Repeat(" ", longestLabel-len(bar.Label)),
|
|
||||||
strings.Repeat(starChar, starCount),
|
|
||||||
strings.Repeat(" ", maxStars-starCount),
|
|
||||||
label,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
return buffer.String()
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -------------------- Unexported Functions -------------------- */
|
|
||||||
|
|
||||||
func (widget *BarGraph) addView() *tview.TextView {
|
|
||||||
view := tview.NewTextView()
|
|
||||||
|
|
||||||
view.SetBackgroundColor(ColorFor(widget.commonSettings.Colors.Background))
|
|
||||||
view.SetBorder(true)
|
|
||||||
view.SetBorderColor(ColorFor(widget.BorderColor()))
|
|
||||||
view.SetDynamicColors(true)
|
|
||||||
view.SetTitle(widget.Name())
|
|
||||||
view.SetTitleColor(ColorFor(widget.commonSettings.Colors.Title))
|
|
||||||
view.SetWrap(false)
|
|
||||||
|
|
||||||
return view
|
|
||||||
}
|
|
@ -1,161 +0,0 @@
|
|||||||
package wtf
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
|
|
||||||
"github.com/rivo/tview"
|
|
||||||
"github.com/wtfutil/wtf/cfg"
|
|
||||||
"github.com/wtfutil/wtf/utils"
|
|
||||||
)
|
|
||||||
|
|
||||||
type TextWidget struct {
|
|
||||||
bordered bool
|
|
||||||
commonSettings *cfg.Common
|
|
||||||
enabled bool
|
|
||||||
focusable bool
|
|
||||||
focusChar string
|
|
||||||
name string
|
|
||||||
quitChan chan bool
|
|
||||||
refreshing bool
|
|
||||||
refreshInterval int
|
|
||||||
app *tview.Application
|
|
||||||
|
|
||||||
View *tview.TextView
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewTextWidget(app *tview.Application, commonSettings *cfg.Common, focusable bool) TextWidget {
|
|
||||||
widget := TextWidget{
|
|
||||||
commonSettings: commonSettings,
|
|
||||||
|
|
||||||
app: app,
|
|
||||||
bordered: commonSettings.Bordered,
|
|
||||||
enabled: commonSettings.Enabled,
|
|
||||||
focusable: focusable,
|
|
||||||
focusChar: commonSettings.FocusChar(),
|
|
||||||
name: commonSettings.Name,
|
|
||||||
quitChan: make(chan bool),
|
|
||||||
refreshing: false,
|
|
||||||
refreshInterval: commonSettings.RefreshInterval,
|
|
||||||
}
|
|
||||||
|
|
||||||
widget.View = widget.addView()
|
|
||||||
widget.View.SetBorder(widget.bordered)
|
|
||||||
|
|
||||||
return widget
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -------------------- Exported Functions -------------------- */
|
|
||||||
|
|
||||||
// Bordered returns whether or not this widget should be drawn with a border
|
|
||||||
func (widget *TextWidget) Bordered() bool {
|
|
||||||
return widget.bordered
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) BorderColor() string {
|
|
||||||
if widget.Focusable() {
|
|
||||||
return widget.commonSettings.Colors.BorderFocusable
|
|
||||||
}
|
|
||||||
|
|
||||||
return widget.commonSettings.Colors.BorderNormal
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) CommonSettings() *cfg.Common {
|
|
||||||
return widget.commonSettings
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) ConfigText() string {
|
|
||||||
return utils.HelpFromInterface(cfg.Common{})
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) ContextualTitle(defaultStr string) string {
|
|
||||||
if widget.FocusChar() == "" {
|
|
||||||
return fmt.Sprintf(" %s ", defaultStr)
|
|
||||||
}
|
|
||||||
|
|
||||||
return fmt.Sprintf(" %s [darkgray::u]%s[::-][green] ", defaultStr, widget.FocusChar())
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) Disable() {
|
|
||||||
widget.enabled = false
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) Disabled() bool {
|
|
||||||
return !widget.Enabled()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) Enabled() bool {
|
|
||||||
return widget.enabled
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) Focusable() bool {
|
|
||||||
return widget.enabled && widget.focusable
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) FocusChar() string {
|
|
||||||
return widget.focusChar
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) HelpText() string {
|
|
||||||
return fmt.Sprintf("\n There is no help available for widget %s", widget.commonSettings.Module.Type)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) QuitChan() chan bool {
|
|
||||||
return widget.quitChan
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) Name() string {
|
|
||||||
return widget.name
|
|
||||||
}
|
|
||||||
|
|
||||||
// Refreshing returns TRUE if the widget is currently refreshing its data, FALSE if it is not
|
|
||||||
func (widget *TextWidget) Refreshing() bool {
|
|
||||||
return widget.refreshing
|
|
||||||
}
|
|
||||||
|
|
||||||
// RefreshInterval returns how often, in seconds, the widget will return its data
|
|
||||||
func (widget *TextWidget) RefreshInterval() int {
|
|
||||||
return widget.refreshInterval
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) SetFocusChar(char string) {
|
|
||||||
widget.focusChar = char
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) Stop() {
|
|
||||||
widget.enabled = false
|
|
||||||
widget.quitChan <- true
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) String() string {
|
|
||||||
return widget.name
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) TextView() *tview.TextView {
|
|
||||||
return widget.View
|
|
||||||
}
|
|
||||||
|
|
||||||
func (widget *TextWidget) Redraw(title, text string, wrap bool) {
|
|
||||||
widget.app.QueueUpdateDraw(func() {
|
|
||||||
widget.View.Clear()
|
|
||||||
widget.View.SetWrap(wrap)
|
|
||||||
widget.View.SetTitle(widget.ContextualTitle(title))
|
|
||||||
widget.View.SetText(text)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -------------------- Unexported Functions -------------------- */
|
|
||||||
|
|
||||||
func (widget *TextWidget) addView() *tview.TextView {
|
|
||||||
view := tview.NewTextView()
|
|
||||||
|
|
||||||
view.SetBackgroundColor(ColorFor(widget.commonSettings.Colors.Background))
|
|
||||||
view.SetBorderColor(ColorFor(widget.BorderColor()))
|
|
||||||
view.SetTextColor(ColorFor(widget.commonSettings.Colors.Text))
|
|
||||||
view.SetTitleColor(ColorFor(widget.commonSettings.Colors.Title))
|
|
||||||
|
|
||||||
view.SetBorder(true)
|
|
||||||
view.SetDynamicColors(true)
|
|
||||||
view.SetWrap(false)
|
|
||||||
|
|
||||||
return view
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user