X-Git-Url: https://git.danieliu.xyz/?p=taskasaur.git;a=blobdiff_plain;f=taskasaur.c;h=c7c224f4d2da1a69a9522bc926efbc72802dcc0e;hp=a679bfba15c396b03299856d17210c32259b2587;hb=HEAD;hpb=a38733c9e166c01710e1732cd6f6354313eb35ea diff --git a/taskasaur.c b/taskasaur.c index a679bfb..c7c224f 100644 --- a/taskasaur.c +++ b/taskasaur.c @@ -5,27 +5,20 @@ #include "headers/utils.h" #include "config.h" -// this is temp -#define MENU_WIDTH 40 +char* boardfile_name = "test_board.md"; -typedef struct BoardMenu { - Menu** menu_list; - int menu_count; - int selected; -} BoardMenu; +void normal_handleinput(BoardMenu* boardmenu, int ch); +void popup_handleinput(BoardMenu* boardmenu, int ch); +void generic_handleinput(Menu* menu, int ch); -BoardMenu* create_board_menu(Board* board); -Board* boardmenu_to_board(BoardMenu* boardmenu); -int set_selected_menu(BoardMenu* boardmenu, int index); +void renderstep(BoardMenu* boardmenu); +void save_to_file(char* filepath, BoardMenu* boardmenu); -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); +void exit_step(BoardMenu* boardmenu); int main(int argc, char** argv) { - char* boardfile_name = "test_board.md"; printf("%c]0;%s - %s%c", '\033', "taskasaur", boardfile_name, '\007'); // need to reset after program exits /* read from todo file */ @@ -39,286 +32,265 @@ main(int argc, char** argv) BoardMenu* boardmenu; boardmenu = create_board_menu(board); - // this is temp - for (int i = 0; i < boardmenu->menu_count; i++) { - render_menu(boardmenu->menu_list[i]); - } - - char ch; - while ((ch = getch()) != BINDING_QUIT) { - - Menu* active_menu; - active_menu = boardmenu->menu_list[boardmenu->selected]; + /* need to render before user presses anything */ + renderstep(boardmenu); - switch (ch) { + int ch; + while (1) { - case BINDING_SCROLL_UP: - menu_driver(active_menu, MENU_UP); - break; - case BINDING_SCROLL_DOWN: - menu_driver(active_menu, MENU_DOWN); - break; - case BINDING_SCROLL_LEFT: - if (boardmenu->selected-1 < 0) break; - set_selected_menu(boardmenu, boardmenu->selected-1); - break; - case BINDING_SCROLL_RIGHT: - if (boardmenu->selected+1 > boardmenu->menu_count-1) break; - set_selected_menu(boardmenu, boardmenu->selected+1); - break; - case BINDING_JUMP_TOP: - menu_driver(active_menu, MENU_TOP); - break; - case BINDING_JUMP_BOTTOM: - menu_driver(active_menu, MENU_BOTTOM); - break; - case BINDING_MOVE_ITEM_UP: - menu_driver(active_menu, MENU_MOVE_UP); - break; - case BINDING_MOVE_ITEM_DOWN: - menu_driver(active_menu, MENU_MOVE_DOWN); - break; - case BINDING_MOVE_ITEM_LEFT: - if (boardmenu->selected-1 < 0) break; - { - Menu* from_menu; - Menu* to_menu; - - from_menu = boardmenu->menu_list[boardmenu->selected], - to_menu = boardmenu->menu_list[boardmenu->selected-1], - - insert_item( - to_menu, - get_menu_item( - from_menu, - get_selected_item(from_menu) - ), - min( - get_selected_item(from_menu), - get_menu_length(to_menu) - ) - ); - delete_item( - from_menu, - get_selected_item(from_menu) - ); - set_selected_menu(boardmenu, boardmenu->selected-1); - } - - break; - case BINDING_MOVE_ITEM_RIGHT: - if (boardmenu->selected >= boardmenu->menu_count-1) break; - // this is legit cpy paste please fix this - { - Menu* from_menu; - Menu* to_menu; - - from_menu = boardmenu->menu_list[boardmenu->selected], - to_menu = boardmenu->menu_list[boardmenu->selected+1], - - insert_item( - to_menu, - get_menu_item( - from_menu, - get_selected_item(from_menu) - ), - min( - get_selected_item(from_menu), - get_menu_length(to_menu) - ) - ); - delete_item( - from_menu, - get_selected_item(from_menu) - ); - set_selected_menu(boardmenu, boardmenu->selected+1); - } - - break; - case BINDING_DELETE_ITEM: - menu_driver(active_menu, MENU_DELETE); - break; - case BINDING_APPEND_ITEM: - menu_driver(active_menu, MENU_APPEND); - break; - case BINDING_INSERT_ABOVE: - menu_driver(active_menu, MENU_INSERT_ABOVE); - break; - case BINDING_INSERT_BELOW: - menu_driver(active_menu, MENU_INSERT_BELOW); - break; - /* case BINDING_MOVE_MENU_LEFT: */ - /* if (boardmenu->selected-1 < 0) break; */ - - /* swap_menu(boardmenu, boardmenu->selected, boardmenu->selected-1); */ - /* boardmenu->selected -= 1; */ - /* set_selected_menu(boardmenu, boardmenu->selected); */ - - /* break; */ - /* case BINDING_MOVE_MENU_RIGHT: */ - /* if (boardmenu->selected >= boardmenu->menu_count-1) break; */ - /* swap_menu(boardmenu, boardmenu->selected, boardmenu->selected+1); */ - /* boardmenu->selected += 1; */ - /* set_selected_menu(boardmenu, boardmenu->selected); */ - - /* break; */ - case BINDING_EDIT_ITEM: - menu_driver(active_menu, MENU_EDIT); - break; - case BINDING_SELECT: - - break; - case BINDING_WRITE: - break; - } + ch = getch(); - for (int i = 0; i < boardmenu->menu_count; i++) { - render_menu(boardmenu->menu_list[i]); + if (boardmenu->popup_open == 0) { + normal_handleinput(boardmenu, ch); + } else { + popup_handleinput(boardmenu, ch); } + renderstep(boardmenu); } + + /* save on exit - this causes weird stuff to happen, maybe it's not given enough time to write before program exits? */ + /* save_to_file(boardfile_name, boardmenu); */ - exit_tscurses(); return 0; } -BoardMenu* -create_board_menu(Board* board) +void +normal_handleinput(BoardMenu* boardmenu, int ch) { - 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; + Menu* active_menu; + active_menu = boardmenu->menu_list[boardmenu->selected]; + + switch (ch) { + + case BINDING_SCROLL_LEFT: + if (boardmenu->selected-1 < 0) break; + set_selected_menu(boardmenu, boardmenu->selected-1); + break; + case BINDING_SCROLL_RIGHT: + if (boardmenu->selected+1 > boardmenu->menu_count-1) break; + set_selected_menu(boardmenu, boardmenu->selected+1); + break; + case BINDING_MOVE_ITEM_LEFT: + if (boardmenu->selected-1 < 0) break; + if (get_menu_length(boardmenu->menu_list[boardmenu->selected]) == 0) break; + { + Menu* from_menu; + Menu* to_menu; + + from_menu = boardmenu->menu_list[boardmenu->selected]; + to_menu = boardmenu->menu_list[boardmenu->selected-1]; + + insert_item( + to_menu, + get_selected_menuitem(from_menu), + min( + get_selected_item(from_menu), + get_menu_length(to_menu) + ) + ); + delete_item( + from_menu, + get_selected_item(from_menu) + ); + set_selected_menu(boardmenu, boardmenu->selected-1); + } + + break; + case BINDING_MOVE_ITEM_RIGHT: + if (boardmenu->selected >= boardmenu->menu_count-1) break; + if (get_menu_length(boardmenu->menu_list[boardmenu->selected]) == 0) break; + // this is legit cpy paste please fix this + { + Menu* from_menu; + Menu* to_menu; + + from_menu = boardmenu->menu_list[boardmenu->selected]; + to_menu = boardmenu->menu_list[boardmenu->selected+1]; + + insert_item( + to_menu, + get_selected_menuitem(from_menu), + min( + get_selected_item(from_menu), + get_menu_length(to_menu) + ) + ); + delete_item( + from_menu, + get_selected_item(from_menu) + ); + set_selected_menu(boardmenu, boardmenu->selected+1); + } + + break; + /* case BINDING_MOVE_MENU_LEFT: */ + /* if (boardmenu->selected-1 < 0) break; */ + + /* swap_menu(boardmenu, boardmenu->selected, boardmenu->selected-1); */ + /* boardmenu->selected -= 1; */ + /* set_selected_menu(boardmenu, boardmenu->selected); */ + + /* break; */ + /* case BINDING_MOVE_MENU_RIGHT: */ + /* if (boardmenu->selected >= boardmenu->menu_count-1) break; */ + /* swap_menu(boardmenu, boardmenu->selected, boardmenu->selected+1); */ + /* boardmenu->selected += 1; */ + /* set_selected_menu(boardmenu, boardmenu->selected); */ + + /* break; */ + case BINDING_SELECT: + { + Menu* sel_menu; + TodoItem* sel_itemdata; + + sel_menu = boardmenu->menu_list[boardmenu->selected]; + sel_itemdata = (TodoItem*)get_menuitem_userdata( + get_menu_item(sel_menu, get_selected_item(sel_menu)) + ); + + /* set mode to popup */ + boardmenu->popupmenu = make_popupmenu(sel_itemdata); + boardmenu->popup_open = 1; + + } + + break; + case BINDING_WRITE: + save_to_file(boardfile_name, boardmenu); + break; + case BINDING_QUIT: + exit_step(boardmenu); + break; + case KEY_RESIZE: + /* ; */ + /* int y, x; */ + /* char out[10]; */ + /* getmaxyx(stdscr, y, x); */ + /* sprintf(out, "%d,%d", y, x); */ + + /* mvprintw(20, 20, out); */ + /* resize_term(y, x); */ + break; + + default: + generic_handleinput(active_menu, ch); - return new_boardmenu; + } } -Board* -boardmenu_to_board(BoardMenu* boardmenu) +void +popup_handleinput(BoardMenu* boardmenu, int ch) { - Board newboard = malloc(sizeof(Board)); - TodoList** todolist_list = malloc(sizeof(TodoList*)); + Menu* popupmenu_menu; - for (int i = 0; i < boardmenu->menu_count; i++) { - Menu* curmenu = boardmenu->menu_list[i]; + popupmenu_menu = boardmenu->popupmenu->menu; - TodoList* new_todolist = malloc(sizeof(TodoList)); - TodoItem** item_list = malloc(sizeof(TodoItem*)); - new_todolist->list_name = get_menu_name(curmenu); - new_todolist->item_count = get_menu_length(curmenu); + switch (ch) { - /* for (int j = 0; j < get_menu_length(curmenu); j++) { */ - - /* } */ + case BINDING_QUIT: + boardmenu->popup_open = 0; + close_popupmenu(popupmenu_menu); + + /* reset screen */ + clear(); + renderstep(boardmenu); + break; - new_todolist->item_list = item_list; + case BINDING_TOGGLE_DONE: + { + SubTask* curitem_data = (SubTask*)get_menuitem_userdata(get_menu_item(popupmenu_menu, get_selected_item(popupmenu_menu))); + curitem_data->done = (curitem_data->done == SubTaskState_todo) ? SubTaskState_done : SubTaskState_todo; + } - } + break; - newboard->todolist_list = todolist_list; - newboard->todolist_count = boardmenu->menu_count; + default: + generic_handleinput(popupmenu_menu, ch); + } +} - return newboard; - +void +generic_handleinput(Menu* menu, int ch) +{ + switch (ch) { + + case BINDING_SCROLL_UP: + menu_driver(menu, MENU_UP); + break; + case BINDING_SCROLL_DOWN: + menu_driver(menu, MENU_DOWN); + break; + case BINDING_JUMP_TOP: + menu_driver(menu, MENU_TOP); + break; + case BINDING_JUMP_BOTTOM: + menu_driver(menu, MENU_BOTTOM); + break; + case BINDING_MOVE_ITEM_UP: + menu_driver(menu, MENU_MOVE_UP); + break; + case BINDING_MOVE_ITEM_DOWN: + menu_driver(menu, MENU_MOVE_DOWN); + break; + case BINDING_DELETE_ITEM: + menu_driver(menu, MENU_DELETE); + break; + case BINDING_APPEND_ITEM: + menu_driver(menu, MENU_APPEND); + break; + case BINDING_INSERT_ABOVE: + menu_driver(menu, MENU_INSERT_ABOVE); + break; + case BINDING_INSERT_BELOW: + menu_driver(menu, MENU_INSERT_BELOW); + break; + case BINDING_EDIT_ITEM: + menu_driver(menu, MENU_EDIT); + break; + } } -int -set_selected_menu(BoardMenu* boardmenu, int index) +void +renderstep(BoardMenu* boardmenu) { - Menu* old_menu; - Menu* new_menu; - int new_pos; - - old_menu = boardmenu->menu_list[boardmenu->selected]; - new_menu = boardmenu->menu_list[index]; + /* render main board menu */ + if (boardmenu->popup_open == 0) { + for (int i = 0; i < boardmenu->menu_count; i++) { - set_menu_focus(old_menu, false); - set_menu_focus(new_menu, true); + Menu* curmenu = boardmenu->menu_list[i]; - /* 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); + render_menu(curmenu); + } - boardmenu->selected = index; + /* render popup if it's open */ + } else { - return 0; -} + // something weird happened, maybe raise error + /* if (boradmenu->popupmenu == NULL) return; */ -MenuItem** -todolist_to_menuitem(TodoItem** item_list, int list_length) -{ - MenuItem** items; + render_menu(boardmenu->popupmenu->menu); + wrefresh(boardmenu->popupmenu->win); - 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; + refresh(); } -Menu** -make_menus(Board* board, int todolist_length) +void +save_to_file(char* filepath, BoardMenu* boardmenu) { + Board* writeboard; + writeboard = boardmenu_to_board(boardmenu); - 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; + begin_write(filepath, writeboard); + free_board(writeboard); } -int -swap_menu(BoardMenu* boardmenu, int src_index, int dest_index) +void +exit_step(BoardMenu* boardmenu) { - /* 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(boardmenu->menu_list, src_index, dest_index); - - return 0; + exit_tscurses(); + exit(0); } -