2021-07-09 09:42:44 +02:00
|
|
|
package process
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"git.ewintr.nl/gte/internal/storage"
|
|
|
|
"git.ewintr.nl/gte/internal/task"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
ErrInvalidReqs = errors.New("could not make sense of requirements")
|
|
|
|
ErrListProcess = errors.New("could not fetch task list")
|
|
|
|
)
|
|
|
|
|
|
|
|
// ListReqs specifies the requirements in AND fashion for a list of tasks
|
|
|
|
type ListReqs struct {
|
|
|
|
Due task.Date
|
|
|
|
IncludeBefore bool
|
2021-08-09 06:46:13 +02:00
|
|
|
Folder string
|
|
|
|
Project string
|
2021-07-09 09:42:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (lr ListReqs) Valid() bool {
|
2021-08-09 06:46:13 +02:00
|
|
|
switch {
|
|
|
|
case lr.Folder != "":
|
|
|
|
return true
|
|
|
|
case lr.Project != "":
|
|
|
|
return true
|
|
|
|
case !lr.Due.IsZero():
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
return false
|
2021-07-09 09:42:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// List finds all tasks that satisfy the given requirements
|
|
|
|
type List struct {
|
|
|
|
local storage.LocalRepository
|
|
|
|
reqs ListReqs
|
|
|
|
}
|
|
|
|
|
|
|
|
type ListResult struct {
|
|
|
|
Tasks []*task.Task
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewList(local storage.LocalRepository, reqs ListReqs) *List {
|
|
|
|
return &List{
|
|
|
|
local: local,
|
|
|
|
reqs: reqs,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l *List) Process() (*ListResult, error) {
|
|
|
|
if !l.reqs.Valid() {
|
|
|
|
return &ListResult{}, ErrInvalidReqs
|
|
|
|
}
|
|
|
|
|
2021-08-09 06:46:13 +02:00
|
|
|
folders := []string{task.FOLDER_NEW, task.FOLDER_PLANNED, task.FOLDER_UNPLANNED}
|
|
|
|
if l.reqs.Folder != "" {
|
|
|
|
folders = []string{l.reqs.Folder}
|
|
|
|
}
|
|
|
|
|
|
|
|
var potentialTasks []*task.Task
|
|
|
|
for _, folder := range folders {
|
|
|
|
folderTasks, err := l.local.FindAllInFolder(folder)
|
|
|
|
if err != nil {
|
|
|
|
return &ListResult{}, fmt.Errorf("%w: %v", ErrListProcess, err)
|
|
|
|
}
|
|
|
|
for _, ft := range folderTasks {
|
|
|
|
potentialTasks = append(potentialTasks, ft)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if l.reqs.Due.IsZero() && l.reqs.Project == "" {
|
|
|
|
return &ListResult{
|
|
|
|
Tasks: potentialTasks,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
if l.reqs.Project != "" {
|
|
|
|
var projectTasks []*task.Task
|
|
|
|
for _, pt := range potentialTasks {
|
|
|
|
if pt.Project == l.reqs.Project {
|
|
|
|
projectTasks = append(projectTasks, pt)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
potentialTasks = projectTasks
|
|
|
|
}
|
|
|
|
|
|
|
|
if l.reqs.Due.IsZero() {
|
|
|
|
return &ListResult{
|
|
|
|
Tasks: potentialTasks,
|
|
|
|
}, nil
|
2021-07-09 09:42:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
dueTasks := []*task.Task{}
|
|
|
|
for _, t := range potentialTasks {
|
|
|
|
switch {
|
2021-08-09 06:46:13 +02:00
|
|
|
case t.Due.IsZero():
|
|
|
|
// skip
|
2021-07-09 09:42:44 +02:00
|
|
|
case t.Due.Equal(l.reqs.Due):
|
|
|
|
dueTasks = append(dueTasks, t)
|
|
|
|
case l.reqs.IncludeBefore && l.reqs.Due.After(t.Due):
|
|
|
|
dueTasks = append(dueTasks, t)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return &ListResult{
|
|
|
|
Tasks: dueTasks,
|
|
|
|
}, nil
|
|
|
|
}
|