X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=taskasaur.c;h=bdc72f57720b14672ae0c1c3e18833853cfd58e2;hb=bcb6f1950bfd2867df61d5c93aa73b73e093edbc;hp=c8fd8e6159a5aa88fe13a17b13186d3ae06197c2;hpb=a5efc91e9cfa40607a2064b8662047788a246ab1;p=taskasaur.git diff --git a/taskasaur.c b/taskasaur.c index c8fd8e6..bdc72f5 100644 --- a/taskasaur.c +++ b/taskasaur.c @@ -8,44 +8,166 @@ int main(int argc, char** argv) { - char ch; - /* Board* board; */ - /* board = begin_parse("test_board.md"); */ + 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 */ + Board* board; + board = begin_parse(boardfile_name); /* log_todo(board); */ /* init curses */ init_tscurses(); - MenuItem** item_list = malloc(6*sizeof(MenuItem*)); - for (int i = 0; i < 5; i++) { - item_list[i] = create_menuitem("Many of you are probably feeling a little sad."); - } - item_list[5] = 0; + BoardMenu* boardmenu; + boardmenu = create_board_menu(board); - Menu* menu = create_menu(item_list); - render_menu(menu); + // 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]; + switch (ch) { case BINDING_SCROLL_UP: - menu_driver(menu, MENU_UP); + menu_driver(active_menu, MENU_UP); break; case BINDING_SCROLL_DOWN: - menu_driver(menu, MENU_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(menu, MENU_TOP); + menu_driver(active_menu, MENU_TOP); break; case BINDING_JUMP_BOTTOM: - menu_driver(menu, MENU_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: + { + Board* writeboard; + writeboard = boardmenu_to_board(boardmenu); + + begin_write(boardfile_name, writeboard); + free_board(writeboard); + } + break; } - render_menu(menu); - } + for (int i = 0; i < boardmenu->menu_count; i++) { + render_menu(boardmenu->menu_list[i]); + } + } exit_tscurses(); return 0;