Add selection ability and cursor movement

This commit is contained in:
2023-02-11 21:58:36 -08:00
parent 2e01847d63
commit c890907cee
3 changed files with 83 additions and 10 deletions

View File

@@ -42,6 +42,7 @@ type model struct {
CommitLogModel CommitLog CommitLogModel CommitLog
HelpModel Help HelpModel Help
quitting bool quitting bool
cursor Cursor
err error err error
} }
@@ -63,6 +64,14 @@ var quitKeys = key.NewBinding(
key.WithHelp("", "press q to quit"), key.WithHelp("", "press q to quit"),
) )
const (
settings Cursor = iota
graph
commitLog
)
type Cursor int
func initialModel() (model, error) { func initialModel() (model, error) {
var m model var m model
var err error var err error
@@ -70,6 +79,7 @@ func initialModel() (model, error) {
if err != nil { if err != nil {
return m, err return m, err
} }
m.cursor = graph
return m, nil return m, nil
} }
@@ -103,15 +113,28 @@ func (m CommitLog) View() string {
func (m Graph) Update(msg tea.Msg) (tea.Model, tea.Cmd) { func (m Graph) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
switch msg := msg.(type) { switch msg := msg.(type) {
case tea.Key: case tea.KeyMsg:
switch msg.String() { switch msg.String() {
case "down":
if m.Selected%7 != 6 {
m.Selected++
}
case "up": case "up":
if m.Selected%7 != 0 {
m.Selected--
}
case "left": case "left":
if m.Selected > 6 { if m.Selected > 6 {
m.Selected -= 7 m.Selected -= 7
} else { } else {
// TODO calculate the square for this day last year // TODO calculate the square for this day last year
} }
case "right":
if m.Selected < 358 {
m.Selected += 7
} else {
// TODO
}
} }
} }
return m, nil return m, nil
@@ -120,7 +143,7 @@ func (m Graph) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
func NewGraph() (Graph, error) { func NewGraph() (Graph, error) {
var m Graph var m Graph
now := time.Now() now := time.Now()
today := now.YearDay() today := now.YearDay() - 1
year := now.Year() year := now.Year()
aName, _ := commits.GetAuthorName() aName, _ := commits.GetAuthorName()
aEmail, _ := commits.GetAuthorEmail() aEmail, _ := commits.GetAuthorEmail()
@@ -137,33 +160,40 @@ func NewGraph() (Graph, error) {
} }
func (m Graph) Init() tea.Cmd { func (m Graph) Init() tea.Cmd {
go func() {
mr := commits.RepoSet(m.Repos)
mr.FrequencyChan(m.Year-1, m.Authors)
}()
return nil return nil
} }
func (m Graph) View() string { func (m Graph) View() string {
mr := commits.RepoSet(m.Repos) mr := commits.RepoSet(m.Repos)
gfreq, _ := mr.FrequencyChan(m.Year, m.Authors) gfreq, _ := mr.FrequencyChan(m.Year, m.Authors)
return gfreq.String() return gfreq.StringSelected(m.Selected)
} }
func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
switch msg := msg.(type) { switch cmd := msg.(type) {
case tea.KeyMsg: case tea.KeyMsg:
if key.Matches(msg, quitKeys) { if key.Matches(cmd, quitKeys) {
m.quitting = true m.quitting = true
return m, tea.Quit return m, tea.Quit
} }
return m, nil
case errMsg: case errMsg:
m.err = msg m.err = cmd
return m, nil return m, nil
default: default:
var cmd tea.Cmd }
switch m.cursor {
case graph:
tmp, cmd := m.GraphModel.Update(msg)
m.GraphModel, _ = tmp.(Graph)
return m, cmd return m, cmd
} }
return m, nil
} }
func (m model) View() string { func (m model) View() string {
@@ -171,7 +201,7 @@ func (m model) View() string {
return m.err.Error() return m.err.Error()
} }
if m.quitting { if m.quitting {
return "\n" return ""
} }
return m.GraphModel.View() return m.GraphModel.View()
} }

View File

@@ -42,6 +42,15 @@ func drawWeekUnicode(c []sc.SimpleColor) string {
return s.String() return s.String()
} }
func GetYearUnicodeSelected(frequencies []int, selected int) string {
squareColors := []sc.SimpleColor{}
min, max := common.MinMax(frequencies)
for _, f := range frequencies {
squareColors = append(squareColors, common.ColorForFrequency(f, min, max))
}
return drawYearUnicodeSelected(squareColors, selected)
}
func GetYearUnicode(frequencies []int) string { func GetYearUnicode(frequencies []int) string {
squareColors := []sc.SimpleColor{} squareColors := []sc.SimpleColor{}
min, max := common.MinMax(frequencies) min, max := common.MinMax(frequencies)
@@ -51,6 +60,36 @@ func GetYearUnicode(frequencies []int) string {
return drawYearUnicode(squareColors) return drawYearUnicode(squareColors)
} }
func drawYearUnicodeSelected(c []sc.SimpleColor, selected int) string {
// o := termenv.NewOutput(os.Stdout)
var s strings.Builder
o := termenv.NewOutput(os.Stdout, termenv.WithProfile(termenv.TrueColor))
weekRows := [7][]sc.SimpleColor{{}}
for i := 0; i < 7; i++ {
weekRows[i] = []sc.SimpleColor{}
}
for i := 0; i < len(c); i++ {
weekRows[i%7] = append(weekRows[i%7], c[i])
}
for i, row := range weekRows {
for w, d := range row {
style := o.String(block).Foreground(termenv.TrueColor.Color(d.ToHex()))
if w*7+i == selected {
style = o.String(block).Foreground(termenv.TrueColor.Color("#FFFFFF"))
// style = style.Background(termenv.TrueColor.Color("#FF0000"))
}
s.WriteString(style.String())
if w == len(row)-1 {
s.WriteString("\n")
} else {
s.WriteString(" ")
}
}
}
return s.String()
}
func drawYearUnicode(c []sc.SimpleColor) string { func drawYearUnicode(c []sc.SimpleColor) string {
// o := termenv.NewOutput(os.Stdout) // o := termenv.NewOutput(os.Stdout)
var s strings.Builder var s strings.Builder

View File

@@ -19,6 +19,10 @@ func NewCommit(Author, Message, Repo, Path string, Added, Deleted, FilesChanged
return ci return ci
} }
func (yf Freq) StringSelected(selected int) string {
return gterm.GetYearUnicodeSelected(yf, selected)
}
func (yf Freq) String() string { func (yf Freq) String() string {
return gterm.GetYearUnicode(yf) return gterm.GetYearUnicode(yf)
} }