mirror of
https://github.com/taigrr/wtf
synced 2025-01-18 04:03:14 -08:00
CommandRunner allows you to define a terminal command and arguments, run it on a schedule, and view the output. Examples: ping -3 cisco.com
57 lines
1.1 KiB
Go
57 lines
1.1 KiB
Go
package clocks
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/olebedev/config"
|
|
"github.com/senorprogrammer/wtf/wtf"
|
|
)
|
|
|
|
// Config is a pointer to the global config object
|
|
var Config *config.Config
|
|
|
|
type Widget struct {
|
|
wtf.TextWidget
|
|
|
|
clockColl ClockCollection
|
|
}
|
|
|
|
func NewWidget() *Widget {
|
|
widget := Widget{
|
|
TextWidget: wtf.NewTextWidget(" 🕗 World Clocks ", "clocks", false),
|
|
}
|
|
|
|
widget.clockColl = widget.buildClockCollection(Config.UMap("wtf.mods.clocks.locations"))
|
|
|
|
return &widget
|
|
}
|
|
|
|
/* -------------------- Exported Functions -------------------- */
|
|
|
|
func (widget *Widget) Refresh() {
|
|
if widget.Disabled() {
|
|
return
|
|
}
|
|
|
|
widget.UpdateRefreshedAt()
|
|
widget.View.Clear()
|
|
widget.display(widget.clockColl.Sorted())
|
|
}
|
|
|
|
/* -------------------- Unexported Functions -------------------- */
|
|
|
|
func (widget *Widget) buildClockCollection(locData map[string]interface{}) ClockCollection {
|
|
clockColl := ClockCollection{}
|
|
|
|
for label, locStr := range locData {
|
|
timeLoc, err := time.LoadLocation(locStr.(string))
|
|
if err != nil {
|
|
continue
|
|
}
|
|
|
|
clockColl.Clocks = append(clockColl.Clocks, NewClock(label, timeLoc))
|
|
}
|
|
|
|
return clockColl
|
|
}
|