folder and project command
This commit is contained in:
parent
1448ea627b
commit
9d36a37246
|
@ -37,10 +37,12 @@ func Parse(args []string, conf *configuration.Configuration) (Command, error) {
|
||||||
return NewToday(conf)
|
return NewToday(conf)
|
||||||
case "tomorrow":
|
case "tomorrow":
|
||||||
return NewTomorrow(conf)
|
return NewTomorrow(conf)
|
||||||
|
case "project":
|
||||||
|
return NewProject(conf, cmdArgs)
|
||||||
case "projects":
|
case "projects":
|
||||||
return NewProjects(conf)
|
return NewProjects(conf)
|
||||||
case "list":
|
case "folder":
|
||||||
return NewList(conf, cmdArgs)
|
return NewFolder(conf, cmdArgs)
|
||||||
case "add":
|
case "add":
|
||||||
return NewAdd(conf, cmdArgs)
|
return NewAdd(conf, cmdArgs)
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -0,0 +1,62 @@
|
||||||
|
package command
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"git.ewintr.nl/gte/cmd/cli/format"
|
||||||
|
"git.ewintr.nl/gte/internal/configuration"
|
||||||
|
"git.ewintr.nl/gte/internal/process"
|
||||||
|
"git.ewintr.nl/gte/internal/storage"
|
||||||
|
"git.ewintr.nl/gte/internal/task"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Folder struct {
|
||||||
|
local storage.LocalRepository
|
||||||
|
lister *process.List
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *Folder) Cmd() string { return "folder" }
|
||||||
|
|
||||||
|
func NewFolder(conf *configuration.Configuration, cmdArgs []string) (*Folder, error) {
|
||||||
|
local, err := storage.NewSqlite(conf.Sqlite())
|
||||||
|
if err != nil {
|
||||||
|
return &Folder{}, err
|
||||||
|
}
|
||||||
|
if len(cmdArgs) < 1 {
|
||||||
|
return &Folder{}, ErrInvalidAmountOfArgs
|
||||||
|
}
|
||||||
|
knownFolders := []string{task.FOLDER_NEW, task.FOLDER_PLANNED, task.FOLDER_UNPLANNED}
|
||||||
|
var folder string
|
||||||
|
for _, f := range knownFolders {
|
||||||
|
if strings.ToLower(f) == strings.ToLower(cmdArgs[0]) {
|
||||||
|
folder = f
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if folder == "" {
|
||||||
|
return &Folder{}, ErrUnknownFolder
|
||||||
|
}
|
||||||
|
|
||||||
|
reqs := process.ListReqs{
|
||||||
|
Folder: folder,
|
||||||
|
}
|
||||||
|
lister := process.NewList(local, reqs)
|
||||||
|
|
||||||
|
return &Folder{
|
||||||
|
local: local,
|
||||||
|
lister: lister,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *Folder) Do() string {
|
||||||
|
res, err := f.lister.Process()
|
||||||
|
if err != nil {
|
||||||
|
return format.FormatError(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(res.Tasks) == 0 {
|
||||||
|
return "no tasks here\n"
|
||||||
|
}
|
||||||
|
|
||||||
|
return format.FormatTaskTable(f.local, res.Tasks)
|
||||||
|
}
|
|
@ -0,0 +1,49 @@
|
||||||
|
package command
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"git.ewintr.nl/gte/cmd/cli/format"
|
||||||
|
"git.ewintr.nl/gte/internal/configuration"
|
||||||
|
"git.ewintr.nl/gte/internal/process"
|
||||||
|
"git.ewintr.nl/gte/internal/storage"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Project struct {
|
||||||
|
local storage.LocalRepository
|
||||||
|
lister *process.List
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Project) Cmd() string { return "project" }
|
||||||
|
|
||||||
|
func NewProject(conf *configuration.Configuration, cmdArgs []string) (*Project, error) {
|
||||||
|
local, err := storage.NewSqlite(conf.Sqlite())
|
||||||
|
if err != nil {
|
||||||
|
return &Project{}, err
|
||||||
|
}
|
||||||
|
if len(cmdArgs) < 1 {
|
||||||
|
return &Project{}, ErrInvalidAmountOfArgs
|
||||||
|
}
|
||||||
|
reqs := process.ListReqs{
|
||||||
|
Project: strings.ToLower(cmdArgs[0]),
|
||||||
|
}
|
||||||
|
lister := process.NewList(local, reqs)
|
||||||
|
|
||||||
|
return &Project{
|
||||||
|
local: local,
|
||||||
|
lister: lister,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Project) Do() string {
|
||||||
|
res, err := p.lister.Process()
|
||||||
|
if err != nil {
|
||||||
|
return format.FormatError(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(res.Tasks) == 0 {
|
||||||
|
return "no tasks here\n"
|
||||||
|
}
|
||||||
|
|
||||||
|
return format.FormatTaskTable(p.local, res.Tasks)
|
||||||
|
}
|
Loading…
Reference in New Issue