2019-10-18 09:48:37 +02:00
|
|
|
package theme
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/fatih/color"
|
|
|
|
"github.com/jesseduffield/gocui"
|
|
|
|
"github.com/spf13/viper"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
// DefaultTextColor is the default text color
|
|
|
|
DefaultTextColor = color.FgWhite
|
2019-10-30 11:23:25 +02:00
|
|
|
// DefaultHiTextColor is the default highlighted text color
|
|
|
|
DefaultHiTextColor = color.FgHiWhite
|
2019-10-18 09:48:37 +02:00
|
|
|
|
|
|
|
// GocuiDefaultTextColor does the same as DefaultTextColor but this one only colors gocui default text colors
|
|
|
|
GocuiDefaultTextColor gocui.Attribute
|
|
|
|
|
|
|
|
// ActiveBorderColor is the border color of the active frame
|
|
|
|
ActiveBorderColor gocui.Attribute
|
|
|
|
|
|
|
|
// InactiveBorderColor is the border color of the inactive active frames
|
|
|
|
InactiveBorderColor gocui.Attribute
|
2020-02-23 02:57:12 +02:00
|
|
|
|
|
|
|
// SelectedLineBgColor is the background color for the selected line
|
|
|
|
SelectedLineBgColor color.Attribute
|
2020-02-23 12:53:30 +02:00
|
|
|
|
2020-05-15 12:43:16 +02:00
|
|
|
// SelectedRangeBgColor is the background color of the selected range of lines
|
|
|
|
SelectedRangeBgColor color.Attribute
|
|
|
|
|
2020-05-13 13:10:00 +02:00
|
|
|
// GocuiSelectedLineBgColor is the background color for the selected line in gocui
|
|
|
|
GocuiSelectedLineBgColor gocui.Attribute
|
|
|
|
|
2020-02-23 12:53:30 +02:00
|
|
|
OptionsFgColor color.Attribute
|
|
|
|
|
|
|
|
OptionsColor gocui.Attribute
|
2020-03-29 05:34:17 +02:00
|
|
|
|
|
|
|
DiffTerminalColor = color.FgMagenta
|
2019-10-18 09:48:37 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// UpdateTheme updates all theme variables
|
|
|
|
func UpdateTheme(userConfig *viper.Viper) {
|
2020-02-23 02:57:12 +02:00
|
|
|
ActiveBorderColor = GetGocuiColor(userConfig.GetStringSlice("gui.theme.activeBorderColor"))
|
|
|
|
InactiveBorderColor = GetGocuiColor(userConfig.GetStringSlice("gui.theme.inactiveBorderColor"))
|
|
|
|
SelectedLineBgColor = GetBgColor(userConfig.GetStringSlice("gui.theme.selectedLineBgColor"))
|
2020-05-15 12:43:16 +02:00
|
|
|
SelectedRangeBgColor = GetBgColor(userConfig.GetStringSlice("gui.theme.selectedRangeBgColor"))
|
2020-05-13 13:10:00 +02:00
|
|
|
GocuiSelectedLineBgColor = GetGocuiColor(userConfig.GetStringSlice("gui.theme.selectedLineBgColor"))
|
2020-02-23 12:53:30 +02:00
|
|
|
OptionsColor = GetGocuiColor(userConfig.GetStringSlice("gui.theme.optionsTextColor"))
|
|
|
|
OptionsFgColor = GetFgColor(userConfig.GetStringSlice("gui.theme.optionsTextColor"))
|
2019-10-18 09:48:37 +02:00
|
|
|
|
|
|
|
isLightTheme := userConfig.GetBool("gui.theme.lightTheme")
|
|
|
|
if isLightTheme {
|
|
|
|
DefaultTextColor = color.FgBlack
|
2019-10-30 11:23:25 +02:00
|
|
|
DefaultHiTextColor = color.FgHiBlack
|
2019-10-18 09:48:37 +02:00
|
|
|
GocuiDefaultTextColor = gocui.ColorBlack
|
|
|
|
} else {
|
|
|
|
DefaultTextColor = color.FgWhite
|
2019-10-30 11:23:25 +02:00
|
|
|
DefaultHiTextColor = color.FgHiWhite
|
2019-10-18 09:48:37 +02:00
|
|
|
GocuiDefaultTextColor = gocui.ColorWhite
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-23 02:57:12 +02:00
|
|
|
// GetAttribute gets the gocui color attribute from the string
|
|
|
|
func GetGocuiAttribute(key string) gocui.Attribute {
|
2019-10-18 09:48:37 +02:00
|
|
|
colorMap := map[string]gocui.Attribute{
|
|
|
|
"default": gocui.ColorDefault,
|
|
|
|
"black": gocui.ColorBlack,
|
|
|
|
"red": gocui.ColorRed,
|
|
|
|
"green": gocui.ColorGreen,
|
|
|
|
"yellow": gocui.ColorYellow,
|
|
|
|
"blue": gocui.ColorBlue,
|
|
|
|
"magenta": gocui.ColorMagenta,
|
|
|
|
"cyan": gocui.ColorCyan,
|
|
|
|
"white": gocui.ColorWhite,
|
|
|
|
"bold": gocui.AttrBold,
|
|
|
|
"reverse": gocui.AttrReverse,
|
|
|
|
"underline": gocui.AttrUnderline,
|
|
|
|
}
|
|
|
|
value, present := colorMap[key]
|
|
|
|
if present {
|
|
|
|
return value
|
|
|
|
}
|
|
|
|
return gocui.ColorWhite
|
|
|
|
}
|
|
|
|
|
2020-02-23 02:57:12 +02:00
|
|
|
// GetFgAttribute gets the color foreground attribute from the string
|
|
|
|
func GetFgAttribute(key string) color.Attribute {
|
|
|
|
colorMap := map[string]color.Attribute{
|
|
|
|
"default": color.FgWhite,
|
|
|
|
"black": color.FgBlack,
|
|
|
|
"red": color.FgRed,
|
|
|
|
"green": color.FgGreen,
|
|
|
|
"yellow": color.FgYellow,
|
|
|
|
"blue": color.FgBlue,
|
|
|
|
"magenta": color.FgMagenta,
|
|
|
|
"cyan": color.FgCyan,
|
|
|
|
"white": color.FgWhite,
|
|
|
|
"bold": color.Bold,
|
|
|
|
"reverse": color.ReverseVideo,
|
|
|
|
"underline": color.Underline,
|
2019-10-18 09:48:37 +02:00
|
|
|
}
|
2020-02-23 02:57:12 +02:00
|
|
|
value, present := colorMap[key]
|
|
|
|
if present {
|
|
|
|
return value
|
|
|
|
}
|
|
|
|
return color.FgWhite
|
2019-10-18 09:48:37 +02:00
|
|
|
}
|
2019-10-19 11:39:18 +02:00
|
|
|
|
2020-02-23 02:57:12 +02:00
|
|
|
// GetBgAttribute gets the color background attribute from the string
|
|
|
|
func GetBgAttribute(key string) color.Attribute {
|
|
|
|
colorMap := map[string]color.Attribute{
|
|
|
|
"default": color.BgWhite,
|
|
|
|
"black": color.BgBlack,
|
|
|
|
"red": color.BgRed,
|
|
|
|
"green": color.BgGreen,
|
|
|
|
"yellow": color.BgYellow,
|
|
|
|
"blue": color.BgBlue,
|
|
|
|
"magenta": color.BgMagenta,
|
|
|
|
"cyan": color.BgCyan,
|
|
|
|
"white": color.BgWhite,
|
|
|
|
"bold": color.Bold,
|
|
|
|
"reverse": color.ReverseVideo,
|
|
|
|
"underline": color.Underline,
|
2019-10-19 11:39:18 +02:00
|
|
|
}
|
|
|
|
value, present := colorMap[key]
|
|
|
|
if present {
|
|
|
|
return value
|
|
|
|
}
|
2020-02-23 02:57:12 +02:00
|
|
|
return color.FgWhite
|
2019-10-19 11:39:18 +02:00
|
|
|
}
|
|
|
|
|
2020-02-23 02:57:12 +02:00
|
|
|
// GetGocuiColor bitwise OR's a list of attributes obtained via the given keys
|
|
|
|
func GetGocuiColor(keys []string) gocui.Attribute {
|
2019-10-19 11:39:18 +02:00
|
|
|
var attribute gocui.Attribute
|
|
|
|
for _, key := range keys {
|
2020-02-23 02:57:12 +02:00
|
|
|
attribute |= GetGocuiAttribute(key)
|
|
|
|
}
|
|
|
|
return attribute
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetColor bitwise OR's a list of attributes obtained via the given keys
|
|
|
|
func GetBgColor(keys []string) color.Attribute {
|
|
|
|
var attribute color.Attribute
|
|
|
|
for _, key := range keys {
|
|
|
|
attribute |= GetBgAttribute(key)
|
|
|
|
}
|
|
|
|
return attribute
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetColor bitwise OR's a list of attributes obtained via the given keys
|
|
|
|
func GetFgColor(keys []string) color.Attribute {
|
|
|
|
var attribute color.Attribute
|
|
|
|
for _, key := range keys {
|
|
|
|
attribute |= GetFgAttribute(key)
|
2019-10-19 11:39:18 +02:00
|
|
|
}
|
|
|
|
return attribute
|
|
|
|
}
|