From 69e9160687886e8dced77f5be81cfb7f64b8c79d Mon Sep 17 00:00:00 2001 From: Digital Studium Date: Thu, 18 Apr 2024 12:58:23 +0300 Subject: [PATCH] Fix coluumns --- kls | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/kls b/kls index 7a32c4e..f267715 100755 --- a/kls +++ b/kls @@ -16,9 +16,9 @@ SCREEN = curses.initscr() # инициализация экрана execute_cmd = lambda command: subprocess.check_output(command, shell=True).decode().rstrip().split("\n") # вывод команды преобразуем в list api_resources_top = ["pods", "services", "deployments", "statefulsets", "daemonsets", "ingresses", "configmaps", "secrets", "persistentvolumes", "persistentvolumeclaims", "nodes", "storageclasses"] api_resources_kubectl = execute_cmd("kubectl api-resources --no-headers --verbs=get | awk '{print $1}'") -MENUS = [Menu("Namespaces", execute_cmd("kubectl get ns --no-headers | awk '{print $1}'"), 0, curses.COLS // 10 * 2), - Menu("API resources", api_resources_top + sorted(list(set(api_resources_kubectl) - set(api_resources_top))), curses.COLS // 10 * 2, curses.COLS // 10 * 3), - Menu("Resources", [], curses.COLS // 10 * 5, curses.COLS - curses.COLS // 10 * 5)] +MENUS = [Menu("Namespaces", execute_cmd("kubectl get ns --no-headers | awk '{print $1}'"), 0, curses.COLS // 6), + Menu("API resources", api_resources_top + sorted(list(set(api_resources_kubectl) - set(api_resources_top))), curses.COLS // 6, curses.COLS // 4), + Menu("Resources", [], curses.COLS // 6 + curses.COLS // 4, curses.COLS - (curses.COLS // 6 + curses.COLS // 4))] SELECTED_MENU = MENUS[0] HELP_TEXT = "q: exit, /: enter filter mode, Esc: exit filter mode, 1: get yaml, 2: describe, 3: edit, 4: pod logs, arrows/TAB: navigation" ROWS_NUMBER = curses.LINES - 9 # максимальное число видимых строк меню, начиная с 0 @@ -26,7 +26,7 @@ ROWS_NUMBER = curses.LINES - 9 # максимальное число видим def update_menu3(): if not MENUS[0].filtered_rows() or not MENUS[1].filtered_rows(): MENUS[2].rows = ["No namespace or API resource selected"] - elif MENUS[1].selected_row() == "pods": MENUS[2].rows = execute_cmd(f"kubectl -n {MENUS[0].selected_row()} get pods --no-headers | awk '{{ printf \"%40s %20s\\n\", $1,$3 }}'") + elif MENUS[1].selected_row() == "pods": MENUS[2].rows = execute_cmd(f"kubectl -n {MENUS[0].selected_row()} get pods --no-headers | awk '{{ printf \"%70s %10s\\n\", $1,$3 }}'") else: MENUS[2].rows = execute_cmd(f"kubectl -n {MENUS[0].selected_row()} get {MENUS[1].selected_row()} --no-headers | awk '{{print $1}}'") if MENUS[2].rows == ['']: MENUS[2].rows = [f"No {MENUS[1].selected_row()} found in {MENUS[0].selected_row()} namespace."] MENUS[2].selected_row_index = 0 # перед перерисовкой сбрасываем выбранную строку на 0 @@ -92,16 +92,17 @@ def catch_input(menu): case _ if filter_mode: handle_selected_with_filter_state(key_pressed, menu) -def main(): +def main(screen): SCREEN.refresh() # не знаю зачем это нужно но без этого не работает SCREEN.keypad(True) # нужно для работы со стрелками curses.set_escdelay(1) # в curses зачем-то сделали задержку на срабатывание Escape, уменьшаем её до 1 милисекунды (до 0 нельзя) curses.curs_set(0) # делаем курсор невидимым + curses.use_default_colors() # не меняем цвет терминала curses.noecho() # не выводим символы вверху - for menu in MENUS: draw_menu(menu) # рисуем основные окна + for menu in MENUS: + draw_menu(menu) # рисуем основные окна draw_row(curses.newwin(3, curses.COLS, curses.LINES - 3, 0), HELP_TEXT, 1, 2) # и окно помощи - while SELECTED_MENU: catch_input(SELECTED_MENU) # если какое-то меню выбрано, перехватываем ввод пользователя + while SELECTED_MENU: + catch_input(SELECTED_MENU) # если какое-то меню выбрано, перехватываем ввод пользователя - -try: main() -finally: curses.endwin() # нужно для нормальной работы терминала после выхода +curses.wrapper(main)