1
0
mirror of https://github.com/taigrr/wtf synced 2025-01-18 04:03:14 -08:00

Merge pull request #450 from Seanstoppable/githubmultisource

Make github a multisource widget
This commit is contained in:
Chris Cummer 2019-05-15 06:53:36 -07:00 committed by GitHub
commit 7c1152ac1d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 33 additions and 30 deletions

View File

@ -1,10 +1,12 @@
package github
import (
"fmt"
"os"
"github.com/olebedev/config"
"github.com/wtfutil/wtf/cfg"
"github.com/wtfutil/wtf/wtf"
)
const defaultTitle = "GitHub"
@ -15,7 +17,7 @@ type Settings struct {
apiKey string
baseURL string
enableStatus bool
repositories map[string]interface{}
repositories []string
uploadURL string
username string
}
@ -28,10 +30,25 @@ func NewSettingsFromYAML(name string, ymlConfig *config.Config, globalConfig *co
apiKey: ymlConfig.UString("apiKey", os.Getenv("WTF_GITHUB_TOKEN")),
baseURL: ymlConfig.UString("baseURL", os.Getenv("WTF_GITHUB_BASE_URL")),
enableStatus: ymlConfig.UBool("enableStatus", false),
repositories: ymlConfig.UMap("repositories"),
uploadURL: ymlConfig.UString("uploadURL", os.Getenv("WTF_GITHUB_UPLOAD_URL")),
username: ymlConfig.UString("username"),
}
settings.repositories = parseRepositories(ymlConfig)
return &settings
}
func parseRepositories(ymlConfig *config.Config) []string {
result := []string{}
repositories, err := ymlConfig.Map("repositories")
if err == nil {
for key, value := range repositories {
result = append(result, fmt.Sprintf("%s/%s", value, key))
}
return result
}
result = wtf.ToStrs(ymlConfig.UList("repositories"))
return result
}

View File

@ -1,16 +1,18 @@
package github
import (
"strings"
"github.com/rivo/tview"
"github.com/wtfutil/wtf/wtf"
)
type Widget struct {
wtf.MultiSourceWidget
wtf.KeyboardWidget
wtf.TextWidget
GithubRepos []*GithubRepo
Idx int
app *tview.Application
settings *Settings
@ -19,10 +21,9 @@ type Widget struct {
func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *Widget {
widget := Widget{
KeyboardWidget: wtf.NewKeyboardWidget(app, pages, settings.common),
MultiSourceWidget: wtf.NewMultiSourceWidget(settings.common, "repository", "repositories"),
TextWidget: wtf.NewTextWidget(app, settings.common, true),
Idx: 0,
app: app,
settings: settings,
}
@ -31,6 +32,9 @@ func NewWidget(app *tview.Application, pages *tview.Pages, settings *Settings) *
widget.initializeKeyboardControls()
widget.View.SetInputCapture(widget.InputCapture)
widget.SetDisplayFunction(widget.display)
widget.Sources = widget.settings.repositories
widget.KeyboardWidget.SetView(widget.View)
@ -44,26 +48,6 @@ func (widget *Widget) Refresh() {
repo.Refresh()
}
widget.app.QueueUpdateDraw(func() {
widget.display()
})
}
func (widget *Widget) Next() {
widget.Idx = widget.Idx + 1
if widget.Idx == len(widget.GithubRepos) {
widget.Idx = 0
}
widget.display()
}
func (widget *Widget) Prev() {
widget.Idx = widget.Idx - 1
if widget.Idx < 0 {
widget.Idx = len(widget.GithubRepos) - 1
}
widget.display()
}
@ -73,13 +57,15 @@ func (widget *Widget) HelpText() string {
/* -------------------- Unexported Functions -------------------- */
func (widget *Widget) buildRepoCollection(repoData map[string]interface{}) []*GithubRepo {
func (widget *Widget) buildRepoCollection(repoData []string) []*GithubRepo {
githubRepos := []*GithubRepo{}
for name, owner := range repoData {
for _, repo := range repoData {
split := strings.Split(repo, "/")
owner, name := split[0], split[1]
repo := NewGithubRepo(
name,
owner.(string),
owner,
widget.settings.apiKey,
widget.settings.baseURL,
widget.settings.uploadURL,