X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=render.c;h=7db2db36adf9eb87d0d32c7e948c43217cf62ef8;hb=1efefba2657678809bc2e718f71ea7776495fd5e;hp=657b8c6ddd4127a28860628c28c647e76f7e1988;hpb=bcb6f1950bfd2867df61d5c93aa73b73e093edbc;p=taskasaur.git diff --git a/render.c b/render.c index 657b8c6..7db2db3 100644 --- a/render.c +++ b/render.c @@ -84,6 +84,8 @@ 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->popup_open = 0; return new_boardmenu; } @@ -129,7 +131,12 @@ todolist_to_menuitem(TodoItem** item_list, int list_length) items = malloc((list_length+1)*sizeof(MenuItem*)); for (int i = 0; i < list_length; i++) { - items[i] = create_menuitem(item_list[i]->item_name); + MenuItem* new_menuitem; + new_menuitem = create_menuitem(item_list[i]->item_name); + /* using same struct, careful if it gets freed */ + set_menuitem_userdata(new_menuitem, item_list[i]); + + items[i] = new_menuitem; } items[list_length] = 0; //null terminate @@ -155,14 +162,25 @@ boardmenu_to_board(BoardMenu* boardmenu) for (int j = 0; j < get_menu_length(curmenu); j++) { MenuItem* curmenuitem = get_menu_item(curmenu, j); + TodoItem* itemdata = get_menuitem_userdata(curmenuitem); TodoItem* new_todoitem = malloc(sizeof(TodoItem)); + SubTask** new_subtask_list = malloc(itemdata->subtask_count*sizeof(SubTask*)); new_todoitem->item_name = strdup(get_menuitem_title(curmenuitem)); - new_todoitem->description = strdup(get_menuitem_descrip(curmenuitem)); - new_todoitem->due = strdup(""); //TEMP! - new_todoitem->subtask_list = malloc(0); //TEMP! - new_todoitem->subtask_count = 0; //TEMP! + new_todoitem->description = strdup(itemdata->description); + new_todoitem->due = strdup(itemdata->due); + new_todoitem->subtask_count = itemdata->subtask_count; + for (int k = 0; k < itemdata->subtask_count; k++) { + SubTask* new_subtask = malloc(sizeof(SubTask)); + + new_subtask->subtask_name = itemdata->subtask_list[k]->subtask_name; + new_subtask->done = itemdata->subtask_list[k]->done; + + new_subtask_list[k] = new_subtask; + } + + new_todoitem->subtask_list = new_subtask_list; new_item_list[j] = new_todoitem; } @@ -195,6 +213,7 @@ set_selected_menu(BoardMenu* boardmenu, int index) /* also try to jump to a similar position if possible */ /* rn theres a bug if old menu is empty */ new_pos = min(get_selected_item(old_menu), get_menu_length(new_menu)-1); + if (new_pos < 0) new_pos = 0; set_selected_item(new_menu, new_pos); boardmenu->selected = index; @@ -227,14 +246,116 @@ swap_menu(BoardMenu* boardmenu, int src_index, int dest_index) return 0; } +/* menuitem */ +int +update_menuitem_descrip(MenuItem* menuitem) +{ /* need to do something about colored text */ + + TodoItem* item_data; + char* new_descrip; + + item_data = (TodoItem*)get_menuitem_userdata(menuitem); + new_descrip = strdup(""); + + if (strlen(item_data->description) > 0) { + /* strcat(new_descrip, "☰ "); */ + strcat(new_descrip, "# "); + } + if (strlen(item_data->due) > 0) { + strcat(new_descrip, item_data->due); + strcat(new_descrip, " "); + } + if (item_data->subtask_count > 0) { + + int tasks_complete = 0; + for (int i = 0; i < item_data->subtask_count; i++) { + if (item_data->subtask_list[i]->done == SubTaskState_done) { + tasks_complete += 1; + } + } + + /* [, # done, /, # total, ], null */ + char subtask_done[4]; // assume there wont be more than 999 subtasks (possibly danger?) + snprintf(subtask_done, 4, "%d", tasks_complete); + int substask_len = 1+item_data->subtask_count+1+strlen(subtask_done)+1+1; + char subtask_text[substask_len]; + sprintf(subtask_text, "[%s/%d]", subtask_done, item_data->subtask_count); + strcat(new_descrip, subtask_text); + } + + /* free old string */ + if (strlen(new_descrip) > 0) { + free(get_menuitem_descrip(menuitem)); + set_menuitem_descrip(menuitem, new_descrip); + } + + return 0; +} + /* popup */ -WINDOW* -create_popup_win() +Menu* +make_popup_menu(TodoItem* itemdata) { - return NULL; + MenuItem** subtask_menuitems; + Menu* new_popup_menu; + WINDOW* popup_win; + + subtask_menuitems = subtasklist_to_menuitem(itemdata->subtask_list, itemdata->subtask_count); + new_popup_menu = create_menu(strdup(""), subtask_menuitems); + + /* popup win */ + int maxheight, maxwidth; + getmaxyx(stdscr, maxheight, maxwidth); + popup_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); + + return new_popup_menu; } +int +render_popup_menu(Menu* popup_menu) +{ + WINDOW* popup_win; + + popup_win = get_menu_win(popup_menu); + wclear(popup_win); + + /* box(popup_win, 0, 0); */ + render_menu(popup_menu); + + wrefresh(popup_win); + + return 0; +} + +/* this is copy paste of other, prob abstract */ +MenuItem** +subtasklist_to_menuitem(SubTask** subtask_list, int list_length) +{ + MenuItem** items; + + items = malloc((list_length+1)*sizeof(MenuItem*)); + for (int i = 0; i < list_length; i++) { + MenuItem* new_menuitem; + new_menuitem = create_menuitem(subtask_list[i]->subtask_name); + /* using same struct, careful if it gets freed */ + set_menuitem_userdata(new_menuitem, subtask_list[i]); + + items[i] = new_menuitem; + } + + items[list_length] = 0; //null terminate + return items; +} +/* helpers */ int ungetstr(char* str) {