978d35d356
Apply GoDoc comment policy (comments for humans should have a space after the //; machine-readable comments shouldn't) Use strings.ReplaceAll instead of strings.Replace when appropriate Remove if/else chains by replacing them with switches Use short assignment/increment notation Replace single case switches with if statements Combine else and if when appropriate Signed-off-by: Moritz Poldrack <moritz@poldrack.dev> Acked-by: Robin Jarry <robin@jarry.cc>
89 lines
2.3 KiB
Go
89 lines
2.3 KiB
Go
package widgets
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"git.sr.ht/~rjarry/aerc/config"
|
|
"git.sr.ht/~rjarry/aerc/lib/auth"
|
|
"git.sr.ht/~rjarry/aerc/lib/ui"
|
|
"github.com/gdamore/tcell/v2"
|
|
"github.com/mattn/go-runewidth"
|
|
)
|
|
|
|
type AuthInfo struct {
|
|
ui.Invalidatable
|
|
authdetails *auth.Details
|
|
showInfo bool
|
|
uiConfig *config.UIConfig
|
|
}
|
|
|
|
func NewAuthInfo(auth *auth.Details, showInfo bool, uiConfig *config.UIConfig) *AuthInfo {
|
|
return &AuthInfo{authdetails: auth, showInfo: showInfo, uiConfig: uiConfig}
|
|
}
|
|
|
|
func (a *AuthInfo) Draw(ctx *ui.Context) {
|
|
defaultStyle := a.uiConfig.GetStyle(config.STYLE_DEFAULT)
|
|
ctx.Fill(0, 0, ctx.Width(), ctx.Height(), ' ', defaultStyle)
|
|
var text string
|
|
switch {
|
|
case a.authdetails == nil:
|
|
text = "(no header)"
|
|
ctx.Printf(0, 0, defaultStyle, text)
|
|
case a.authdetails.Err != nil:
|
|
style := a.uiConfig.GetStyle(config.STYLE_ERROR)
|
|
text = a.authdetails.Err.Error()
|
|
ctx.Printf(0, 0, style, text)
|
|
default:
|
|
checkBounds := func(x int) bool {
|
|
return x < ctx.Width()
|
|
}
|
|
setResult := func(result auth.Result) (string, tcell.Style) {
|
|
switch result {
|
|
case auth.ResultNone:
|
|
return "none", defaultStyle
|
|
case auth.ResultNeutral:
|
|
return "neutral", a.uiConfig.GetStyle(config.STYLE_WARNING)
|
|
case auth.ResultPolicy:
|
|
return "policy", a.uiConfig.GetStyle(config.STYLE_WARNING)
|
|
case auth.ResultPass:
|
|
return "✓", a.uiConfig.GetStyle(config.STYLE_SUCCESS)
|
|
case auth.ResultFail:
|
|
return "✗", a.uiConfig.GetStyle(config.STYLE_ERROR)
|
|
default:
|
|
return string(result), a.uiConfig.GetStyle(config.STYLE_ERROR)
|
|
}
|
|
}
|
|
x := 1
|
|
for i := 0; i < len(a.authdetails.Results); i++ {
|
|
if checkBounds(x) {
|
|
text, style := setResult(a.authdetails.Results[i])
|
|
if i > 0 {
|
|
text = " " + text
|
|
}
|
|
x += ctx.Printf(x, 0, style, text)
|
|
}
|
|
}
|
|
if a.showInfo {
|
|
infoText := ""
|
|
for i := 0; i < len(a.authdetails.Infos); i++ {
|
|
if i > 0 {
|
|
infoText += ","
|
|
}
|
|
infoText += a.authdetails.Infos[i]
|
|
if reason := a.authdetails.Reasons[i]; reason != "" {
|
|
infoText += reason
|
|
}
|
|
}
|
|
if checkBounds(x) && infoText != "" {
|
|
if trunc := ctx.Width() - x - 3; trunc > 0 {
|
|
text = runewidth.Truncate(infoText, trunc, "…")
|
|
ctx.Printf(x, 0, defaultStyle, fmt.Sprintf(" (%s)", text))
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func (a *AuthInfo) Invalidate() {
|
|
a.DoInvalidate(a)
|
|
}
|