clan-core/pkgs/clan-vm-manager/clan_vm_manager/app.py

99 lines
2.8 KiB
Python
Raw Normal View History

2023-11-25 00:55:01 +00:00
#!/usr/bin/env python3
import logging
from typing import Any, ClassVar
2023-12-16 12:03:10 +00:00
2023-11-25 00:55:01 +00:00
import gi
2023-12-16 12:03:10 +00:00
from clan_vm_manager import assets
gi.require_version("Gtk", "4.0")
gi.require_version("Adw", "1")
2024-01-02 04:54:19 +00:00
from clan_cli.custom_logger import setup_logging
from gi.repository import Adw, Gdk, Gio, Gtk
2023-12-16 12:03:10 +00:00
from clan_vm_manager.models.interfaces import ClanConfig
from clan_vm_manager.models.use_join import GLib, GObject
from clan_vm_manager.models.use_vms import VMS
from .windows.main_window import MainWindow
2023-12-16 11:52:10 +00:00
log = logging.getLogger(__name__)
2023-11-28 17:19:01 +00:00
class MainApplication(Adw.Application):
__gsignals__: ClassVar = {
"join_request": (GObject.SignalFlags.RUN_FIRST, None, [str]),
}
def __init__(self, *args: Any, **kwargs: Any) -> None:
super().__init__(
*args,
flags=Gio.ApplicationFlags.HANDLES_COMMAND_LINE,
**kwargs,
)
self.add_main_option(
"debug",
ord("d"),
GLib.OptionFlags.NONE,
GLib.OptionArg.NONE,
"enable debug mode",
None,
2023-12-30 10:14:45 +00:00
)
2024-02-07 05:03:12 +00:00
self.win: Adw.ApplicationWindow | None = None
self.connect("shutdown", self.on_shutdown)
2024-02-07 05:03:12 +00:00
self.connect("activate", self.show_window)
2023-12-30 10:14:45 +00:00
def do_command_line(self, command_line: Any) -> int:
options = command_line.get_options_dict()
# convert GVariantDict -> GVariant -> dict
options = options.end().unpack()
if "debug" in options:
setup_logging("DEBUG", root_log_name=__name__.split(".")[0])
else:
setup_logging("INFO", root_log_name=__name__.split(".")[0])
log.debug("Debug logging enabled")
args = command_line.get_arguments()
self.activate()
if len(args) > 1:
log.debug(f"Join request: {args[1]}")
uri = args[1]
self.emit("join_request", uri)
return 0
def on_shutdown(self, app: Gtk.Application) -> None:
log.debug("Shutting down")
VMS.use().kill_all()
2023-11-28 17:19:01 +00:00
2023-11-30 12:42:15 +00:00
def do_activate(self) -> None:
2024-02-07 05:03:12 +00:00
self.show_window()
def show_window(self, app: Any = None) -> None:
if not self.win:
self.init_style()
self.win = MainWindow(config=ClanConfig(initial_view="list"))
2024-02-07 05:03:12 +00:00
self.win.set_application(self)
icon_path = assets.loc / "clan_black.png"
self.win.set_default_icon_name(str(icon_path))
2024-02-07 05:03:12 +00:00
self.win.present()
2023-11-28 17:19:01 +00:00
# TODO: For css styling
2023-11-30 12:42:15 +00:00
def init_style(self) -> None:
resource_path = assets.loc / "style.css"
log.debug(f"Style css path: {resource_path}")
css_provider = Gtk.CssProvider()
css_provider.load_from_path(str(resource_path))
Gtk.StyleContext.add_provider_for_display(
Gdk.Display.get_default(),
css_provider,
Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION,
)