X-Git-Url: https://git.danieliu.xyz/?p=taskasaur.git;a=blobdiff_plain;f=taskasaur.c;h=bdc72f57720b14672ae0c1c3e18833853cfd58e2;hp=d3b8ba8b82b62a279a39f9a9e6791131d8ecbdd1;hb=bcb6f1950bfd2867df61d5c93aa73b73e093edbc;hpb=b1a5da51ad170de714ed6b0b7a566f867cde6c16 diff --git a/taskasaur.c b/taskasaur.c index d3b8ba8..bdc72f5 100644 --- a/taskasaur.c +++ b/taskasaur.c @@ -5,23 +5,6 @@ #include "headers/utils.h" #include "config.h" -// this is temp -#define MENU_WIDTH 40 - -typedef struct BoardMenu { - Menu** menu_list; - int menu_count; - int selected; -} BoardMenu; - -BoardMenu* create_board_menu(Board* board); -Board* boardmenu_to_board(BoardMenu* boardmenu); -int set_selected_menu(BoardMenu* boardmenu, int index); - -MenuItem** todolist_to_menuitem(TodoItem** item_list, int list_length); -Menu** make_menus(Board* board, int todolist_length); -int swap_menu(BoardMenu* boardmenu, int src_index, int dest_index); - int main(int argc, char** argv) { @@ -190,157 +173,3 @@ main(int argc, char** argv) return 0; } -BoardMenu* -create_board_menu(Board* board) -{ - BoardMenu* new_boardmenu; - - new_boardmenu = malloc(sizeof(BoardMenu)); - - new_boardmenu->menu_list = make_menus(board, board->todolist_count); - new_boardmenu->menu_count = board->todolist_count; - new_boardmenu->selected = 0; - - return new_boardmenu; -} - -Board* -boardmenu_to_board(BoardMenu* boardmenu) -{ // STRINGS are sharing the same address as the one in MENU - // and MENUITEM, this may break something if u free this board - // consider copying the string - - Board* newboard = malloc(sizeof(Board)); - TodoList** new_todolist_list = malloc(sizeof(TodoList*)); - - for (int i = 0; i < boardmenu->menu_count; i++) { - Menu* curmenu = boardmenu->menu_list[i]; - - TodoList* new_todolist = malloc(sizeof(TodoList)); - TodoItem** new_item_list = malloc(sizeof(TodoItem*)); - new_todolist->list_name = strdup(get_menu_name(curmenu)); - new_todolist->item_count = get_menu_length(curmenu); - - for (int j = 0; j < get_menu_length(curmenu); j++) { - MenuItem* curmenuitem = get_menu_item(curmenu, j); - - TodoItem* new_todoitem = malloc(sizeof(TodoItem)); - - 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_item_list[j] = new_todoitem; - } - - new_todolist->item_list = new_item_list; - new_todolist_list[i] = new_todolist; - - } - - newboard->board_name = strdup(""); - newboard->todolist_list = new_todolist_list; - newboard->todolist_count = boardmenu->menu_count; - - return newboard; - -} - -int -set_selected_menu(BoardMenu* boardmenu, int index) -{ - Menu* old_menu; - Menu* new_menu; - int new_pos; - - old_menu = boardmenu->menu_list[boardmenu->selected]; - new_menu = boardmenu->menu_list[index]; - - set_menu_focus(old_menu, false); - set_menu_focus(new_menu, true); - - /* 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); - set_selected_item(new_menu, new_pos); - - boardmenu->selected = index; - - return 0; -} - -MenuItem** -todolist_to_menuitem(TodoItem** item_list, int list_length) -{ - MenuItem** items; - - items = malloc((list_length+1)*sizeof(MenuItem*)); - for (int i = 0; i < list_length; i++) { - items[i] = create_menuitem(item_list[i]->item_name); - } - - items[list_length] = 0; //null terminate - return items; -} - -Menu** -make_menus(Board* board, int todolist_length) -{ - - Menu** menu_list; - - menu_list = malloc(todolist_length*sizeof(Menu*)); - - for (int i = 0; i < todolist_length; i++) { - - /* read from parsed */ - TodoList* todo_list = board->todolist_list[i]; - MenuItem** item_list = todolist_to_menuitem(todo_list->item_list, todo_list->item_count); - - Menu* new_menu = create_menu(todo_list->list_name, item_list); - - /* make window */ - WINDOW* win = newwin(20, MENU_WIDTH, 1, 1+MENU_WIDTH*i); - box(win, 0, 0); - - /* some menu settings */ - set_menu_win(new_menu, win); - set_menu_focus(new_menu, i == 0); // make first win focused - - /* refresh */ - refresh(); - wrefresh(win); - - menu_list[i] = new_menu; - } - - return menu_list; -} - -int -swap_menu(BoardMenu* boardmenu, int src_index, int dest_index) -{ - /* reposition menus */ - mvwin(get_menu_win(boardmenu->menu_list[src_index]), - 1, 1+MENU_WIDTH*dest_index - ); - mvwin(get_menu_win(boardmenu->menu_list[dest_index]), - 1, 1+MENU_WIDTH*src_index - ); - refresh(); - wrefresh(get_menu_win(boardmenu->menu_list[src_index])); - wrefresh(get_menu_win(boardmenu->menu_list[dest_index])); - /* wclear(get_menu_win(boardmenu->menu_list[src_index])); */ - /* wclear(get_menu_win(boardmenu->menu_list[dest_index])); */ - /* touchwin(get_menu_win(boardmenu->menu_list[src_index])); */ - /* touchwin(get_menu_win(boardmenu->menu_list[dest_index])); */ - clear(); - - /* swap in array */ - ar_swap_item((void*)boardmenu->menu_list, src_index, dest_index); - - return 0; -} -