X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=taskasaur.c;h=dc90110ed1471d74d14cced772648cb8af96a25e;hb=cb5385b932956072fc14fd6531c45f12c9cc4925;hp=793f0fad7150dc3e5f39717b65343fbf81966c92;hpb=1231bcf06132e735fa69870b7de2898e44efba3b;p=taskasaur.git diff --git a/taskasaur.c b/taskasaur.c index 793f0fa..dc90110 100644 --- a/taskasaur.c +++ b/taskasaur.c @@ -69,16 +69,86 @@ main(int argc, char** argv) 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_EDIT_ITEM: + menu_driver(active_menu, MENU_EDIT); + break; } for (int i = 0; i < boardmenu->menu_count; i++) { render_menu(boardmenu->menu_list[i]); } + } exit_tscurses(); @@ -114,8 +184,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 = (get_selected_item(old_menu) > get_menu_length(new_menu)-1) ? - get_menu_length(new_menu)-1 : get_selected_item(old_menu); + new_pos = min(get_selected_item(old_menu), get_menu_length(new_menu)-1); set_selected_item(new_menu, new_pos); boardmenu->selected = index;