mirror of
https://github.com/taigrr/gico.git
synced 2026-04-02 03:09:07 -07:00
Add selection ability and cursor movement
This commit is contained in:
@@ -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()
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user