From 83ebace2268fa0a70d90a0f58bddaf8ad3df2fed Mon Sep 17 00:00:00 2001 From: Matthias Date: Sat, 24 Aug 2024 08:34:45 +0200 Subject: [PATCH] fix: avoid 1st crash on "settings" view --- ftui/ftui_screens.py | 15 ++++----------- 1 file changed, 4 insertions(+), 11 deletions(-) diff --git a/ftui/ftui_screens.py b/ftui/ftui_screens.py index deb797b..55cd64f 100644 --- a/ftui/ftui_screens.py +++ b/ftui/ftui_screens.py @@ -1,4 +1,3 @@ - from datetime import datetime, timezone from pathlib import Path @@ -39,7 +38,6 @@ class DashboardScreen(Screen): - timers = {} COLLAP_FUNC_MAP = { @@ -153,8 +151,8 @@ def _render_open_trade_data(self, data, trading_mode="spot"): f"{round(v['Open Rate'], 3)}", f"{v['Current Rate']}", fth.red_or_green(float(v["Stop %"])), - fth.red_or_green(float(v['Max %']), justify='left'), - fth.red_or_green(float(v['Profit %']), justify='right'), + fth.red_or_green(float(v["Max %"]), justify="left"), + fth.red_or_green(float(v["Profit %"]), justify="right"), fth.red_or_green(float(v["Profit"]), justify="left"), str(v["Dur."]).split(".")[0].replace("0 days ", ""), f"{v['S/L']}", @@ -483,7 +481,6 @@ def toggle_collapsible(self, event: Collapsible.Toggled) -> None: class MainBotScreen(Screen): - timers = {} TAB_FUNC_MAP = { @@ -531,7 +528,6 @@ def compose(self) -> ComposeResult: yield PlotextPlot(id="bot-chart", classes="bg-static-default") with TabbedContent(initial="open-trades-tab"): - with TabPane("Open Trades", id="open-trades-tab"): yield Static(id="open-trades-table", classes="bg-static-default") @@ -821,7 +817,7 @@ def _render_open_trade_summary(self, ftuic): t["has_open_orders"] if "has_open_orders" in t else (t["open_order_id"] is not None) ) - num_orders = len(t['orders']) if 'orders' in t else 0 + num_orders = len(t["orders"]) if "orders" in t else 0 suff = "" if open_orders and t["close_rate_requested"] is None: @@ -1322,7 +1318,6 @@ def debug(self, msg): class SettingsScreen(Screen): - timers = {} def compose(self) -> ComposeResult: @@ -1377,14 +1372,13 @@ def update_settings(self, s): for server in s[setting]: t = Checkbox( f"{server['name']} [{server['ip']}:{server['port']}]", - server["enabled"], + server.get("enabled", True), ) c.mount(t) settings_left.mount(c) class HelpScreen(Screen): - timers = {} help_file_path = Path(__file__).parent / "md" / "help.md" @@ -1473,7 +1467,6 @@ def compose(self) -> ComposeResult: yield Static("[Esc] to close") def build_trade_info(self, trade_info): - main_text = ( f"[b]Trade Id : {self.trade_id}\n" f"[b]Pair : {trade_info['pair']}\n"