refactor(klipper): instance overview dialog can now show printer folder and not only services
Signed-off-by: Dominik Willner <th33xitus@gmail.com>
This commit is contained in:
@@ -8,24 +8,37 @@
|
|||||||
# ======================================================================= #
|
# ======================================================================= #
|
||||||
|
|
||||||
import textwrap
|
import textwrap
|
||||||
from typing import List
|
from enum import Enum, unique
|
||||||
|
from typing import List, Union, Literal
|
||||||
|
|
||||||
from core.instance_manager.base_instance import BaseInstance
|
from core.instance_manager.base_instance import BaseInstance
|
||||||
from core.menus.base_menu import print_back_footer
|
from core.menus.base_menu import print_back_footer
|
||||||
from utils.constants import COLOR_GREEN, RESET_FORMAT, COLOR_YELLOW, COLOR_CYAN
|
from utils.constants import COLOR_GREEN, RESET_FORMAT, COLOR_YELLOW, COLOR_CYAN
|
||||||
|
|
||||||
|
|
||||||
|
@unique
|
||||||
|
class DisplayType(Enum):
|
||||||
|
SERVICE_NAME = "SERVICE_NAME"
|
||||||
|
PRINTER_NAME = "PRINTER_NAME"
|
||||||
|
|
||||||
|
|
||||||
def print_instance_overview(
|
def print_instance_overview(
|
||||||
instances: List[BaseInstance], show_index=False, show_select_all=False
|
instances: List[BaseInstance],
|
||||||
|
display_type: DisplayType = DisplayType.SERVICE_NAME,
|
||||||
|
show_headline=True,
|
||||||
|
show_index=False,
|
||||||
|
show_select_all=False,
|
||||||
):
|
):
|
||||||
headline = f"{COLOR_GREEN}The following Klipper instances were found:{RESET_FORMAT}"
|
dialog = "/=======================================================\\\n"
|
||||||
dialog = textwrap.dedent(
|
if show_headline:
|
||||||
f"""
|
d_type = (
|
||||||
/=======================================================\\
|
"Klipper instances"
|
||||||
|{headline:^64}|
|
if display_type is DisplayType.SERVICE_NAME
|
||||||
|-------------------------------------------------------|
|
else "printer directories"
|
||||||
"""
|
)
|
||||||
)[1:]
|
headline = f"{COLOR_GREEN}The following {d_type} were found:{RESET_FORMAT}"
|
||||||
|
dialog += f"|{headline:^64}|\n"
|
||||||
|
dialog += "|-------------------------------------------------------|\n"
|
||||||
|
|
||||||
if show_select_all:
|
if show_select_all:
|
||||||
select_all = f"{COLOR_YELLOW}a) Select all{RESET_FORMAT}"
|
select_all = f"{COLOR_YELLOW}a) Select all{RESET_FORMAT}"
|
||||||
@@ -33,7 +46,11 @@ def print_instance_overview(
|
|||||||
dialog += "| |\n"
|
dialog += "| |\n"
|
||||||
|
|
||||||
for i, s in enumerate(instances):
|
for i, s in enumerate(instances):
|
||||||
line = f"{COLOR_CYAN}{f'{i})' if show_index else '●'} {s.get_service_file_name()}{RESET_FORMAT}"
|
if display_type is DisplayType.SERVICE_NAME:
|
||||||
|
name = s.get_service_file_name()
|
||||||
|
else:
|
||||||
|
name = s.data_dir
|
||||||
|
line = f"{COLOR_CYAN}{f'{i})' if show_index else '●'} {name}{RESET_FORMAT}"
|
||||||
dialog += f"| {line:<63}|\n"
|
dialog += f"| {line:<63}|\n"
|
||||||
|
|
||||||
print(dialog, end="")
|
print(dialog, end="")
|
||||||
|
|||||||
@@ -62,7 +62,7 @@ def run_klipper_removal(
|
|||||||
def select_instances_to_remove(
|
def select_instances_to_remove(
|
||||||
instances: List[Klipper],
|
instances: List[Klipper],
|
||||||
) -> Union[List[Klipper], None]:
|
) -> Union[List[Klipper], None]:
|
||||||
print_instance_overview(instances, True, True)
|
print_instance_overview(instances, show_index=True, show_select_all=True)
|
||||||
|
|
||||||
options = [str(i) for i in range(len(instances))]
|
options = [str(i) for i in range(len(instances))]
|
||||||
options.extend(["a", "A", "b", "B"])
|
options.extend(["a", "A", "b", "B"])
|
||||||
|
|||||||
@@ -68,7 +68,7 @@ def run_moonraker_removal(
|
|||||||
def select_instances_to_remove(
|
def select_instances_to_remove(
|
||||||
instances: List[Moonraker],
|
instances: List[Moonraker],
|
||||||
) -> Union[List[Moonraker], None]:
|
) -> Union[List[Moonraker], None]:
|
||||||
print_instance_overview(instances, True, True)
|
print_instance_overview(instances, show_index=True, show_select_all=True)
|
||||||
|
|
||||||
options = [str(i) for i in range(len(instances))]
|
options = [str(i) for i in range(len(instances))]
|
||||||
options.extend(["a", "A", "b", "B"])
|
options.extend(["a", "A", "b", "B"])
|
||||||
|
|||||||
Reference in New Issue
Block a user