package format import ( "errors" "fmt" "sort" "strings" "ewintr.nl/gte/internal/task" ) var ( ErrFieldAlreadyUsed = errors.New("field was already used") ) func FormatError(err error) string { return fmt.Sprintf("could not perform command.\n\nerror: %s\n", err.Error()) } func FormatTaskTable(tasks []*task.LocalTask) string { if len(tasks) == 0 { return "no tasks to display\n" } sort.Sort(task.ByDefault(tasks)) var output string for _, t := range tasks { var projectStr, updateStr string if t.LocalStatus == task.STATUS_UPDATED { updateStr = " *" } if t.Folder != task.FOLDER_NEW { projectStr = fmt.Sprintf(" (%s)", t.Project) } output += fmt.Sprintf("%d%s\t%s\t%s%s\n", t.LocalId, updateStr, t.Due.String(), t.Action, projectStr) } return fmt.Sprintf("%s\n", output) } func FormatTask(t *task.LocalTask) string { output := fmt.Sprintf(`folder: %s action: %s project: %s due: %s `, t.Folder, t.Action, t.Project, t.Due.String()) if t.IsRecurrer() { output += fmt.Sprintf("recur:%s", t.Recur.String()) } return fmt.Sprintf("%s\n", output) } func ParseTaskFieldArgs(args []string) (*task.LocalUpdate, error) { lu := &task.LocalUpdate{} action, fields := []string{}, []string{} for _, f := range args { split := strings.SplitN(f, ":", 2) if len(split) == 2 { switch split[0] { case "project": if lu.Project != "" { return &task.LocalUpdate{}, fmt.Errorf("%w: %s", ErrFieldAlreadyUsed, task.FIELD_PROJECT) } lu.Project = split[1] fields = append(fields, task.FIELD_PROJECT) case "due": if !lu.Due.IsZero() { return &task.LocalUpdate{}, fmt.Errorf("%w: %s", ErrFieldAlreadyUsed, task.FIELD_DUE) } lu.Due = task.NewDateFromString(split[1]) fields = append(fields, task.FIELD_DUE) } } else { if len(f) > 0 { action = append(action, f) } } } if len(action) > 0 { lu.Action = strings.Join(action, " ") fields = append(fields, task.FIELD_ACTION) } lu.Fields = fields return lu, nil }