all, completed and verbose flags for ls

This commit is contained in:
fiplox 2022-09-10 21:09:13 +02:00
parent 019fc93c06
commit 3bbb21dfc5
2 changed files with 31 additions and 5 deletions

View File

@ -37,13 +37,30 @@ Cobra is a CLI library for Go that empowers applications.
This application is a tool to generate the needed files This application is a tool to generate the needed files
to quickly create a Cobra application.`, to quickly create a Cobra application.`,
Run: func(cmd *cobra.Command, args []string) { Run: func(cmd *cobra.Command, args []string) {
todos := getAllTodos() var todos []Todo
all, err := cmd.Flags().GetBool("all")
errPanic(err, "")
comp, err := cmd.Flags().GetBool("completed")
errPanic(err, "")
verbose, err := cmd.Flags().GetBool("verbose")
errPanic(err, "")
if all {
todos = getAllTodos()
} else if comp {
todos = getDoneTodos()
} else {
todos = getUnDoneTodos()
}
ws, err := unix.IoctlGetWinsize(int(os.Stdin.Fd()), unix.TIOCGWINSZ) ws, err := unix.IoctlGetWinsize(int(os.Stdin.Fd()), unix.TIOCGWINSZ)
errPanic(err, "failed to determine terminal width") errPanic(err, "failed to determine terminal width")
cols := int(ws.Col) cols := int(ws.Col)
t := table.NewWriter() t := table.NewWriter()
t.SetOutputMirror(os.Stdout) t.SetOutputMirror(os.Stdout)
if verbose {
t.AppendHeader(table.Row{"#", "Description", "Due date", "Completed", "Created at"})
} else {
t.AppendHeader(table.Row{"#", "Description", "Due date", "Completed"}) t.AppendHeader(table.Row{"#", "Description", "Due date", "Completed"})
}
for _, todo := range todos { for _, todo := range todos {
date := todo.DueDate.Format("02/01/2006 15:04") date := todo.DueDate.Format("02/01/2006 15:04")
d := time.Time{} d := time.Time{}
@ -58,8 +75,12 @@ to quickly create a Cobra application.`,
if todo.IsDone { if todo.IsDone {
comp = '✓' comp = '✓'
} }
if verbose {
t.AppendRow([]interface{}{todo.ID, desc, date, string(comp), todo.CreatedAt.Format("02/01/2006 15:04")})
} else {
t.AppendRow([]interface{}{todo.ID, desc, date, string(comp)}) t.AppendRow([]interface{}{todo.ID, desc, date, string(comp)})
} }
}
t.SetStyle(table.StyleLight) t.SetStyle(table.StyleLight)
t.SetAllowedRowLength(cols) t.SetAllowedRowLength(cols)
t.SetColumnConfigs([]table.ColumnConfig{ t.SetColumnConfigs([]table.ColumnConfig{
@ -80,4 +101,8 @@ func insertNth(s string, n int) string {
func init() { func init() {
rootCmd.AddCommand(lsCmd) rootCmd.AddCommand(lsCmd)
lsCmd.Flags().BoolP("all", "a", false, "show all todos")
lsCmd.Flags().BoolP("completed", "c", false, "show all completed todos")
lsCmd.Flags().BoolP("verbose", "v", false, "show all fields of todos")
lsCmd.MarkFlagsMutuallyExclusive("all", "completed")
} }

View File

@ -97,6 +97,7 @@ func getAllTodos() []Todo {
return todos return todos
} }
// getDoneTodos returns all completed todos.
func getDoneTodos() []Todo { func getDoneTodos() []Todo {
db := openDB() db := openDB()
var todos []Todo var todos []Todo
@ -106,11 +107,11 @@ func getDoneTodos() []Todo {
return todos return todos
} }
// getDoneTodos returns all uncompleted todos.
func getUnDoneTodos() []Todo { func getUnDoneTodos() []Todo {
db := openDB() db := openDB()
var todos []Todo var todos []Todo
res := db.Where(&Todo{IsDone: false}).Find(&todos) res := db.Where("is_done = ?", false).Find(&todos)
errPanic(res.Error, "failed to get all todos") errPanic(res.Error, "failed to get all todos")
return todos return todos