Compare commits
2 Commits
254d74bdb4
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
1ec5072ef4 | ||
|
|
3acff6618c |
52
bubbletea.go
52
bubbletea.go
@@ -68,7 +68,7 @@ func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
|
||||
|
||||
case "enter":
|
||||
if m.addTask {
|
||||
AddNewTask(m)
|
||||
AddNewTask(&m)
|
||||
m.addTask = false
|
||||
m.textinput.Reset()
|
||||
}
|
||||
@@ -76,13 +76,16 @@ func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
|
||||
// The "enter" key and the spacebar (a literal space) toggle
|
||||
// the selected state for the item that the cursor is pointing at.
|
||||
case " ":
|
||||
_, ok := m.selected[m.cursor]
|
||||
if ok {
|
||||
delete(m.selected, m.cursor)
|
||||
|
||||
if !m.addTask {
|
||||
if m.todos[m.cursor].done {
|
||||
m.todos[m.cursor].done = false
|
||||
} else {
|
||||
m.selected[m.cursor] = struct{}{}
|
||||
m.todos[m.cursor].done = true
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -91,7 +94,7 @@ func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
|
||||
return m, cmd
|
||||
}
|
||||
|
||||
func AddNewTask(m model) {
|
||||
func AddNewTask(m *model) {
|
||||
t := todo{
|
||||
name: m.textinput.Value(),
|
||||
done: false,
|
||||
@@ -108,24 +111,32 @@ func (m model) View() string {
|
||||
s := ""
|
||||
currentList := []todo{}
|
||||
|
||||
s += "GOTD\n"
|
||||
s += "GOTD\n\n"
|
||||
|
||||
switch m.tab {
|
||||
case 0:
|
||||
s += "Inbox"
|
||||
inboxFilter := func(t todo) bool { return t.isInbox }
|
||||
currentList = filter(m.todos, inboxFilter)
|
||||
// s += "Inbox"
|
||||
taskFilter := func(t todo) bool { return t.isInbox }
|
||||
currentList = filter(m.todos, taskFilter)
|
||||
case 1:
|
||||
s += "Today"
|
||||
// s += "Today"
|
||||
taskFilter := func(t todo) bool { return t.startdate == int(midnightToUnix()) || t.deadline == int(midnightToUnix()) }
|
||||
currentList = filter(m.todos, taskFilter)
|
||||
case 2:
|
||||
s += "Tomorrow"
|
||||
// s += "Tomorrow"
|
||||
// 86400 seconds in 24h, add it on to today's midnight for tomorrow's midnight
|
||||
taskFilter := func(t todo) bool { return t.startdate == int(midnightToUnix()) + 86400 || t.deadline == int(midnightToUnix()) + 86400}
|
||||
currentList = filter(m.todos, taskFilter)
|
||||
case 3:
|
||||
s += "Scheduled"
|
||||
// s += "Scheduled"
|
||||
taskFilter := func(t todo) bool { return t.startdate != -1 }
|
||||
currentList = filter(m.todos, taskFilter)
|
||||
case 4:
|
||||
s += "Anytime"
|
||||
// s += "Anytime"
|
||||
taskFilter := func(t todo) bool { return t.startdate == -1 }
|
||||
currentList = filter(m.todos, taskFilter)
|
||||
}
|
||||
|
||||
s += "\n\n"
|
||||
|
||||
// Iterate over our choices
|
||||
for i, value := range currentList {
|
||||
@@ -138,14 +149,19 @@ func (m model) View() string {
|
||||
|
||||
// Is this choice selected?
|
||||
checked := " " // not selected
|
||||
if _, ok := m.selected[i]; ok {
|
||||
checked = "x" // selected!
|
||||
// if _, ok := m.selected[i]; ok {
|
||||
// checked = "x" // selected!
|
||||
// }
|
||||
if value.done {
|
||||
checked = "x"
|
||||
}
|
||||
|
||||
// Render the row
|
||||
s += fmt.Sprintf("%s [%s] %s\n", cursor, checked, value)
|
||||
s += fmt.Sprintf("%s [%s] %s\n", cursor, checked, value.name)
|
||||
}
|
||||
|
||||
s += "\n\n"
|
||||
|
||||
// render tab bar
|
||||
for i, v := range []string{"Inbox", "Today", "Tomorrow", "Scheduled", "Anytime"} {
|
||||
if i == m.tab {
|
||||
|
||||
@@ -2,6 +2,7 @@ package main
|
||||
|
||||
import (
|
||||
"os"
|
||||
"time"
|
||||
"os/exec"
|
||||
"runtime"
|
||||
)
|
||||
@@ -15,6 +16,12 @@ func filter[T any](ss []T, test func(T) bool) (ret []T) {
|
||||
return
|
||||
}
|
||||
|
||||
func midnightToUnix() int64 {
|
||||
now := time.Now()
|
||||
midnight := time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
|
||||
return midnight.Unix()
|
||||
}
|
||||
|
||||
func clearTerminal() {
|
||||
var cmd *exec.Cmd
|
||||
if runtime.GOOS == "windows" {
|
||||
|
||||
Reference in New Issue
Block a user