X-Git-Url: http://pileus.org/git/?p=lackey;a=blobdiff_plain;f=views%2Ftodo.c;h=8ab6c9cb36537624d25b1a9a3b2860a76b1041be;hp=27fdfcd93a871ba967a86166a2943d62b7409baa;hb=73c73a83c246975dd04df36b94cb381d315dc2ad;hpb=ef789a1e6c0fa2262690f7c19824d2829f1e2a3f diff --git a/views/todo.c b/views/todo.c index 27fdfcd..8ab6c9c 100644 --- a/views/todo.c +++ b/views/todo.c @@ -1,16 +1,16 @@ /* - * Copyright (C) 2012 Andy Spencer - * + * Copyright (C) 2012-2013 Andy Spencer + * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. - * + * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. - * + * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ @@ -24,40 +24,44 @@ /* Static data */ static WINDOW *win; +static int line; +static int rows; static int show_new = 1; static int show_started = 1; -static int show_finished = 1; +static int show_finished = 0; /* Helper functions */ -static int print_todos(WINDOW *win, int y, todo_t *todos, status_t low, status_t high) +static int print_todos(WINDOW *win, int row, todo_t *todos, status_t low, status_t high) { int n = 0; for (todo_t *cur = todos; cur; cur = cur->next) if (low <= cur->status && cur->status <= high) - todo_line(win, cur, y+n++, 2, COLS-2, 1); + todo_line(win, cur, row+n++, 4, COLS-4, SHOW_DETAILS); return n; } -static int print_group(WINDOW *win, int y, todo_t *todos, +static int print_group(WINDOW *win, int row, todo_t *todos, int show, const char *label, status_t low, status_t high) { int n = 1; /* Label */ - mvwprintw(win, y, 0, "%s", label); + wattron(win, A_BOLD); + mvwprintw(win, row, 0, "%s", label); + wattroff(win, A_BOLD); /* Todos */ if (show) - n = print_todos(win, y+1, todos, low, high); + n = print_todos(win, row+1, todos, low, high); /* Status */ if (!show) - mvwprintw(win, y+1, 4, "[hidden]"); + mvwprintw(win, row+1, 4, "[hidden]"); if (n == 0) - mvwprintw(win, y+1, 4, "[no tasks]"); + mvwprintw(win, row+1, 4, "[no tasks]"); - return y+1+MAX(n,1)+1; + return row+1+MAX(n,1)+1; } /* Todo init */ @@ -74,32 +78,39 @@ void todo_size(int rows, int cols) /* Todo draw */ void todo_draw(void) { - int y = 0; + int row = -line; - y = print_group(win, y, TODOS, + row = print_group(win, row, TODOS, show_new, "New Tasks", NEW, NEW); - y = print_group(win, y, TODOS, + row = print_group(win, row, TODOS, show_started, "Started Tasks", NEW+1, DONE-1); - y = print_group(win, y, TODOS, + row = print_group(win, row, TODOS, show_finished, "Finished Tasks", DONE, DONE); + + rows = row+line-1; } /* Todo run */ int todo_run(int key, mmask_t btn, int row, int col) { - int ref = 0; + int scroll = 0, ref = 0; switch (key) { + case 'g': ref = 1; scroll = -line; break; + case 'G': ref = 1; scroll = rows; break; + case 'j': ref = 1; scroll = 1; break; + case 'k': ref = 1; scroll = -1; break; case 'n': ref = 1; show_new ^= 1; break; case 's': ref = 1; show_started ^= 1; break; case 'f': ref = 1; show_finished ^= 1; break; } + line = CLAMP(line+scroll, 0, rows-1); if (ref) { werase(win); todo_draw(); wrefresh(win); } - return 0; + return ref; }