X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=taskasaur.c;h=b00d29a5641c547fc0278000624d5d1f45b6ab1d;hb=1efefba2657678809bc2e718f71ea7776495fd5e;hp=2097e63cc1c64bbe110f1c285dc4b867dd463a66;hpb=7c9d33c1eb0eb97911c7d1cd073cb70b53dedf62;p=taskasaur.git diff --git a/taskasaur.c b/taskasaur.c index 2097e63..b00d29a 100644 --- a/taskasaur.c +++ b/taskasaur.c @@ -1,13 +1,263 @@ + #include "headers/parser.h" +#include "headers/render.h" +#include "headers/menu.h" +#include "headers/utils.h" +#include "config.h" + +char* boardfile_name = "test_board.md"; + +void normal_handleinput(BoardMenu* boardmenu, int ch); +void popup_handleinput(BoardMenu* boardmenu, int ch); + +void normal_renderstep(BoardMenu* boardmenu); +void popup_renderstep(BoardMenu* boardmenu); +void save_to_file(char* filepath, BoardMenu* boardmenu); int main(int argc, char** argv) { + printf("%c]0;%s - %s%c", '\033', "taskasaur", boardfile_name, '\007'); // need to reset after program exits + + /* read from todo file */ Board* board; + board = begin_parse(boardfile_name); + /* log_todo(board); */ + + /* init curses */ + init_tscurses(); + + BoardMenu* boardmenu; + boardmenu = create_board_menu(board); - board = begin_parse("test_board.md"); + /* need to render before user presses anything */ + normal_renderstep(boardmenu); - printf("%d\n", board->todolist_count); + int ch; + while ((ch = getch()) != BINDING_QUIT) { + if (boardmenu->popup_open == 0) { + normal_handleinput(boardmenu, ch); + normal_renderstep(boardmenu); + } else { + popup_handleinput(boardmenu, ch); + popup_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; } + +void +normal_handleinput(BoardMenu* boardmenu, int ch) +{ + + Menu* active_menu; + active_menu = boardmenu->menu_list[boardmenu->selected]; + + switch (ch) { + + 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; + 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_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; + 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_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: + { + 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->popup_menu = make_popup_menu(sel_itemdata); + boardmenu->popup_open = 1; + } + + break; + case BINDING_WRITE: + save_to_file(boardfile_name, 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; + } +} + +void +popup_handleinput(BoardMenu* boardmenu, int ch) +{ + Menu* popup_menu; + + popup_menu = boardmenu->popup_menu; + + switch (ch) { + + case BINDING_SCROLL_UP: + menu_driver(popup_menu, MENU_UP); + break; + case BINDING_SCROLL_DOWN: + menu_driver(popup_menu, MENU_DOWN); + break; + } +} + +void +normal_renderstep(BoardMenu* boardmenu) +{ + for (int i = 0; i < boardmenu->menu_count; i++) { + + Menu* curmenu = boardmenu->menu_list[i]; + + /* update the descriptions - maybe not do this here */ + for (int j = 0; j < get_menu_length(curmenu); j++) { + update_menuitem_descrip(get_menu_item(curmenu, j)); + } + + render_menu(curmenu); + } +} + +void +popup_renderstep(BoardMenu* boardmenu) +{ + if (boardmenu->popup_menu == NULL) return; + + render_popup_menu(boardmenu->popup_menu); + +} + +void +save_to_file(char* filepath, BoardMenu* boardmenu) +{ + Board* writeboard; + writeboard = boardmenu_to_board(boardmenu); + + begin_write(filepath, writeboard); + free_board(writeboard); +}