2020-05-14 02:03:13 +00:00
|
|
|
import logging
|
2020-06-25 01:56:17 +00:00
|
|
|
from tkinter import OptionMenu, Button
|
2020-05-19 03:11:58 +00:00
|
|
|
from typing import List, Callable
|
2020-05-14 02:03:13 +00:00
|
|
|
import threading
|
|
|
|
|
2020-06-25 01:22:39 +00:00
|
|
|
from ttkthemes import ThemedTk
|
|
|
|
|
2020-06-01 12:58:18 +00:00
|
|
|
from fishy.engine.event_handler import EngineEventHandler
|
2020-06-25 16:39:05 +00:00
|
|
|
from fishy.gui import config_top
|
2020-05-19 03:11:58 +00:00
|
|
|
from fishy.gui.funcs import GUIFuncs
|
2020-05-14 02:03:13 +00:00
|
|
|
from . import main_gui
|
|
|
|
from .log_config import GUIStreamHandler
|
|
|
|
from fishy.helper import Config
|
|
|
|
|
|
|
|
|
|
|
|
class GUI:
|
2020-06-01 12:58:18 +00:00
|
|
|
def __init__(self, config: Config, get_engine: Callable[[], EngineEventHandler]):
|
2020-05-14 02:03:13 +00:00
|
|
|
"""
|
|
|
|
:param config: used to get and set configuration settings
|
|
|
|
"""
|
2020-05-19 03:11:58 +00:00
|
|
|
self.funcs = GUIFuncs(self)
|
|
|
|
self.get_engine = get_engine
|
|
|
|
|
2020-05-14 02:03:13 +00:00
|
|
|
self._config = config
|
|
|
|
self._start_restart = False
|
|
|
|
self._destroyed = True
|
|
|
|
self._log_strings = []
|
2020-05-19 03:11:58 +00:00
|
|
|
self._function_queue: List[Callable] = []
|
2020-05-14 02:03:13 +00:00
|
|
|
self._bot_running = False
|
|
|
|
|
|
|
|
# UI items
|
2020-06-25 01:22:39 +00:00
|
|
|
self._root: ThemedTk = None
|
2020-05-14 02:03:13 +00:00
|
|
|
self._console = None
|
|
|
|
self._start_button = None
|
|
|
|
self._notify = None
|
|
|
|
self._notify_check = None
|
2020-06-25 01:56:17 +00:00
|
|
|
self._engine_select: OptionMenu = None
|
|
|
|
self._config_button: Button = None
|
2020-06-25 16:39:05 +00:00
|
|
|
self._engine_var = None
|
2020-05-14 02:03:13 +00:00
|
|
|
|
|
|
|
self._thread = threading.Thread(target=self.create, args=())
|
|
|
|
|
|
|
|
root_logger = logging.getLogger('')
|
|
|
|
root_logger.setLevel(logging.DEBUG)
|
|
|
|
logging.getLogger('urllib3').setLevel(logging.WARNING)
|
|
|
|
new_console = GUIStreamHandler(self)
|
|
|
|
root_logger.addHandler(new_console)
|
|
|
|
|
2020-05-19 03:11:58 +00:00
|
|
|
@property
|
|
|
|
def engine(self):
|
2020-06-01 12:58:18 +00:00
|
|
|
return self.get_engine()
|
2020-05-19 03:11:58 +00:00
|
|
|
|
2020-06-25 16:39:05 +00:00
|
|
|
@property
|
|
|
|
def engines(self):
|
|
|
|
engines = {
|
|
|
|
"Semi Fisher": [lambda: config_top.start_semifisher_config(self), self.engine.toggle_semifisher],
|
|
|
|
}
|
|
|
|
|
|
|
|
if self._config.get('debug', False):
|
|
|
|
engines["Full-Auto Fisher"] = [lambda: config_top.start_fullfisher_config(self),
|
|
|
|
self.engine.toggle_fullfisher]
|
|
|
|
return engines
|
|
|
|
|
2020-05-14 02:03:13 +00:00
|
|
|
def create(self):
|
|
|
|
main_gui._create(self)
|
|
|
|
|
|
|
|
def start(self):
|
|
|
|
self._thread.start()
|
|
|
|
|
2020-05-19 03:11:58 +00:00
|
|
|
def _clear_function_queue(self):
|
|
|
|
while len(self._function_queue) > 0:
|
|
|
|
func = self._function_queue.pop(0)
|
|
|
|
func()
|
|
|
|
|
|
|
|
def call_in_thread(self, func: Callable):
|
|
|
|
self._function_queue.append(func)
|
2020-06-25 01:22:39 +00:00
|
|
|
|
|
|
|
def _get_start_stop_text(self):
|
|
|
|
return "STOP (F9)" if self._bot_running else "START (F9)"
|