X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=render.c;h=3779273f55ad6436ddc76ea5c121ad14bceff1cb;hb=2b4885a41163276393cd0fa6eff11e86c613294d;hp=963e0e5863a3d28982761268f0f6ae8e6775e218;hpb=66d3a8f071cbf459f6799581146d4a34ca6e2c7b;p=taskasaur.git diff --git a/render.c b/render.c index 963e0e5..3779273 100644 --- a/render.c +++ b/render.c @@ -3,9 +3,22 @@ #include #include "config.h" +#define POPUP_MENU_PAD_TOP 4 +#define POPUP_MENU_PAD_BOTTOM 2 +#define POPUP_MENU_PAD_LEFT 2 +#define POPUP_MENU_PAD_RIGHT 1 + int init_tscolors(void); int create_todowin(void); +/* menu render callbacks */ +void render_menuitem(Menu* menu, int item_index, int start_y); +int menuitem_height(MenuItem* menuitem); + +void render_popup_menuitem(Menu* menu, int item_index, int start_y); +int popup_menuitem_height(MenuItem* menuitem); + + /* init stuff */ int init_tscurses(void) @@ -45,6 +58,7 @@ init_tscolors(void) init_pair(TS_NONSELECTED, non_selected_color, COLOR_BLACK); init_pair(TS_MENU_SELECTED, menu_selected_color, COLOR_BLACK); init_pair(TS_MENU_NONSELECTED, menu_non_selected_color, COLOR_BLACK); + init_pair(TS_ITEMCOUNT, item_count_color, COLOR_BLACK); return 0; } @@ -84,7 +98,7 @@ create_board_menu(Board* board) new_boardmenu->menu_list = make_menus(board, board->todolist_count); new_boardmenu->menu_count = board->todolist_count; new_boardmenu->selected = 0; - new_boardmenu->popup_menu = NULL; + new_boardmenu->popupmenu = NULL; new_boardmenu->popup_open = 0; return new_boardmenu; @@ -114,6 +128,10 @@ make_menus(Board* board, int todolist_length) set_menu_win(new_menu, win); set_menu_focus(new_menu, i == 0); // make first win focused + /* set menu render callbacks */ + set_menu_renderitem(new_menu, *render_menuitem); + set_menu_itemheight(new_menu, *menuitem_height); + /* refresh */ refresh(); wrefresh(win); @@ -124,6 +142,44 @@ make_menus(Board* board, int todolist_length) return menu_list; } +void +render_menuitem(Menu* menu, int item_index, int start_y) +{ + MenuItem* curitem; + WINDOW* menu_win; + int hlcolor; + + curitem = get_menu_item(menu, item_index); + menu_win = get_menu_win(menu); + + /* color selected item */ + hlcolor = COLOR_PAIR((item_index == get_selected_item(menu) && get_menu_focused(menu) == true) ? TS_SELECTED : TS_NONSELECTED); + wattron(menu_win, hlcolor); + mvwprintw(menu_win, start_y, 0, get_menuitem_title(curitem)); + wattroff(menu_win, hlcolor); + + /* display number of items */ + if (strlen(get_menuitem_descrip(curitem)) > 0) { + wattron(menu_win, COLOR_PAIR(TS_ITEMCOUNT)); + mvwprintw(menu_win, start_y+1, 0, get_menuitem_descrip(curitem)); + wattroff(menu_win, COLOR_PAIR(TS_ITEMCOUNT)); + } + +} + +int +menuitem_height(MenuItem* menuitem) +{ + int lines; + + lines = 1; + if (strlen(get_menuitem_descrip(menuitem)) > 0) { + lines += 1; + } + + return lines; +} + MenuItem** todolist_to_menuitem(TodoItem** item_list, int list_length) { @@ -197,6 +253,13 @@ boardmenu_to_board(BoardMenu* boardmenu) return newboard; } +int +render_board(Board* board) +{ + + return 0; +} + int set_selected_menu(BoardMenu* boardmenu, int index) { @@ -293,46 +356,94 @@ update_menuitem_descrip(MenuItem* menuitem) } /* popup */ -Menu* -make_popup_menu(TodoItem* itemdata) +PopupMenu* +make_popupmenu(TodoItem* itemdata) { + PopupMenu* new_popupmenu; MenuItem** subtask_menuitems; - Menu* new_popup_menu; - WINDOW* popup_win; + Menu* popupmenu_menu; + WINDOW* popupmenu_win; + WINDOW* popupmenu_menu_win; + + new_popupmenu = malloc(sizeof(PopupMenu)); subtask_menuitems = subtasklist_to_menuitem(itemdata->subtask_list, itemdata->subtask_count); - new_popup_menu = create_menu(strdup(""), subtask_menuitems); + popupmenu_menu = create_menu(strdup(""), subtask_menuitems); /* popup win */ int maxheight, maxwidth; getmaxyx(stdscr, maxheight, maxwidth); - popup_win = newwin( + popupmenu_win = newwin( maxheight-2*POPUP_BORDER, maxwidth-2*2*POPUP_BORDER, POPUP_BORDER, POPUP_BORDER*2 ); - box(popup_win, 0, 0); - set_menu_win(new_popup_menu, popup_win); - set_menu_focus(new_popup_menu, 1); + int popup_maxheight, popup_maxwidth; + getmaxyx(popupmenu_win, popup_maxheight, popup_maxwidth); + popupmenu_menu_win = derwin( + popupmenu_win, + popup_maxheight-POPUP_MENU_PAD_TOP-POPUP_MENU_PAD_BOTTOM, + popup_maxwidth-POPUP_MENU_PAD_LEFT-POPUP_MENU_PAD_RIGHT, + POPUP_MENU_PAD_TOP, + POPUP_MENU_PAD_LEFT + ); - return new_popup_menu; -} + set_menu_win(popupmenu_menu, popupmenu_menu_win); + set_menu_focus(popupmenu_menu, 1); + set_menu_renderitem(popupmenu_menu, render_popup_menuitem); + set_menu_itemheight(popupmenu_menu, popup_menuitem_height); + box(popupmenu_win, 0, 0); -int -render_popup_menu(Menu* popup_menu) -{ - WINDOW* popup_win; + /* move this stuff to render phase later? */ + mvwprintw(popupmenu_win, 1, 2, itemdata->item_name); + mvwprintw(popupmenu_win, 2, 2, (strlen(itemdata->description) > 0) ? itemdata->description : "no description"); - popup_win = get_menu_win(popup_menu); - wclear(popup_win); + /* don't forget to free popupmenu after */ + new_popupmenu->win = popupmenu_win; + new_popupmenu->menu = popupmenu_menu; - box(popup_win, 0, 0); + return new_popupmenu; +} - render_menu(popup_menu); +void +render_popup_menuitem(Menu* menu, int item_index, int start_y) +{ + MenuItem* curitem; + WINDOW* menu_win; + int hlcolor; + + curitem = get_menu_item(menu, item_index); + menu_win = get_menu_win(menu); + + /* color selected item */ + hlcolor = COLOR_PAIR((item_index == get_selected_item(menu) && get_menu_focused(menu) == true) ? TS_SELECTED : TS_NONSELECTED); + wattron(menu_win, hlcolor); + + wmove(menu_win, start_y, 0); + /* print subtask done indicator */ + if (strlen(get_menuitem_title(curitem)) > 0) + wprintw( + menu_win, + (((SubTask*)get_menuitem_userdata(curitem))->done == SubTaskState_done) ? "[X] " : "[ ] " + ); + wprintw(menu_win, get_menuitem_title(curitem)); + + wattroff(menu_win, hlcolor); +} - wrefresh(popup_win); +int +popup_menuitem_height(MenuItem* menuitem) +{ + return 1; // account for wrap later +} + +int +render_popupmenu(PopupMenu* popupmenu) +{ + render_menu(popupmenu->menu); + wrefresh(popupmenu->win); return 0; }