SolarFM/src/versions/solarfm-0.0.1/SolarFM/solarfm/core/controller_data.py

163 lines
6.7 KiB
Python
Raw Normal View History

# Python imports
import sys, os, signal
2022-06-11 01:13:57 +00:00
from dataclasses import dataclass
# Lib imports
import gi
2022-10-26 04:27:21 +00:00
gi.require_version('Gtk', '3.0')
from gi.repository import Gtk
from gi.repository import GLib
# Application imports
from shellfm.windows.controller import WindowController
from plugins.plugins_controller import PluginsController
2022-06-11 01:13:57 +00:00
@dataclass(slots=True)
2022-03-07 03:27:47 +00:00
class State:
wid: int = None
tid: int = None
tab: type = None
icon_grid: gi.overrides.Gtk.IconView = None
store: gi.overrides.Gtk.ListStore = None
2022-07-16 07:33:25 +00:00
selected_files: [] = None
to_copy_files: [] = None
to_cut_files: [] = None
2022-10-01 21:04:46 +00:00
warning_alert: type = None
class Controller_Data:
""" Controller_Data contains most of the state of the app at ay given time. It also has some support methods. """
2022-06-11 01:13:57 +00:00
__slots__ = "settings", "builder", "logger", "keybindings", "trashman", "fm_controller", "window", "window1", "window2", "window3", "window4"
def setup_controller_data(self) -> None:
self.builder = settings.get_builder()
self.keybindings = settings.get_keybindings()
2022-03-08 01:18:55 +00:00
self.fm_controller = WindowController()
self.plugins = PluginsController()
2022-03-08 01:18:55 +00:00
self.fm_controller_data = self.fm_controller.get_state_from_file()
self.window = settings.get_main_window()
self.window1 = self.builder.get_object("window_1")
self.window2 = self.builder.get_object("window_2")
self.window3 = self.builder.get_object("window_3")
self.window4 = self.builder.get_object("window_4")
self.message_popup_widget = self.builder.get_object("message_popup_widget")
self.message_text_view = self.builder.get_object("message_text_view")
self.message_buffer = self.builder.get_object("message_buffer")
self.arc_command_buffer = self.builder.get_object("arc_command_buffer")
2022-02-02 05:29:42 +00:00
self.exists_file_rename_bttn = self.builder.get_object("exists_file_rename_bttn")
self.warning_alert = self.builder.get_object("warning_alert")
2022-09-03 01:15:20 +00:00
self.new_file_menu = self.builder.get_object("new_file_menu")
self.edit_file_menu = self.builder.get_object("edit_file_menu")
self.file_exists_dialog = self.builder.get_object("file_exists_dialog")
self.exists_file_label = self.builder.get_object("exists_file_label")
self.exists_file_field = self.builder.get_object("exists_file_field")
2021-12-12 06:03:51 +00:00
self.path_menu = self.builder.get_object("path_menu")
2022-02-02 05:29:42 +00:00
self.path_entry = self.builder.get_object("path_entry")
2021-11-28 04:03:00 +00:00
self.bottom_size_label = self.builder.get_object("bottom_size_label")
self.bottom_file_count_label = self.builder.get_object("bottom_file_count_label")
self.bottom_path_label = self.builder.get_object("bottom_path_label")
self.trash_files_path = f"{GLib.get_user_data_dir()}/Trash/files"
self.trash_info_path = f"{GLib.get_user_data_dir()}/Trash/info"
self.icon_theme = settings.get_icon_theme()
self.notebooks = [self.window1, self.window2, self.window3, self.window4]
self.selected_files = []
self.to_copy_files = []
self.to_cut_files = []
self.soft_update_lock = {}
self.single_click_open = False
self.is_pane1_hidden = False
self.is_pane2_hidden = False
self.is_pane3_hidden = False
self.is_pane4_hidden = False
2022-01-30 00:18:21 +00:00
self.override_drop_dest = None
2021-12-07 07:48:52 +00:00
2022-09-03 01:15:20 +00:00
self.cancel_creation = False
self.skip_edit = False
self.cancel_edit = False
self.ctrl_down = False
self.shift_down = False
self.alt_down = False
self.success_color = settings.get_success_color()
self.warning_color = settings.get_warning_color()
self.error_color = settings.get_error_color()
2022-01-24 16:24:55 +00:00
# sys.excepthook = self.custom_except_hook
2022-01-24 16:24:55 +00:00
self.window.connect("delete-event", self.tear_down)
GLib.unix_signal_add(GLib.PRIORITY_DEFAULT, signal.SIGINT, self.tear_down)
2022-10-23 04:53:33 +00:00
self.window.show()
if settings.is_debug():
self.window.set_interactive_debugging(True)
2022-03-07 03:27:47 +00:00
def get_current_state(self) -> State:
'''
Returns the state info most useful for any given context and action intent.
Parameters:
a (obj): self
Returns:
2022-03-07 03:27:47 +00:00
state (obj): State
'''
2022-03-08 01:18:55 +00:00
state = State()
2022-03-07 03:27:47 +00:00
state.wid, state.tid = self.fm_controller.get_active_wid_and_tid()
2022-03-08 01:18:55 +00:00
state.tab = self.get_fm_window(state.wid).get_tab_by_id(state.tid)
state.icon_grid = self.builder.get_object(f"{state.wid}|{state.tid}|icon_grid")
2022-03-07 03:27:47 +00:00
state.store = state.icon_grid.get_model()
2022-10-01 21:04:46 +00:00
state.warning_alert = self.warning_alert
2022-07-16 07:33:25 +00:00
selected_files = state.icon_grid.get_selected_items()
if selected_files:
state.selected_files = self.format_to_uris(state.store, state.wid, state.tid, selected_files, True)
# if self.to_copy_files:
# state.to_copy_files = self.format_to_uris(state.store, state.wid, state.tid, self.to_copy_files, True)
#
# if self.to_cut_files:
# state.to_cut_files = self.format_to_uris(state.store, state.wid, state.tid, self.to_cut_files, True)
event_system.emit("update_state_info_plugins", state)
2022-03-07 03:27:47 +00:00
return state
def clear_console(self) -> None:
''' Clears the terminal screen. '''
os.system('cls' if os.name == 'nt' else 'clear')
def call_method(self, _method_name: str, data: type = None) -> type:
'''
Calls a method from scope of class.
Parameters:
a (obj): self
b (str): method name to be called
c (*): Data (if any) to be passed to the method.
Note: It must be structured according to the given methods requirements.
Returns:
Return data is that which the calling method gives.
'''
method_name = str(_method_name)
method = getattr(self, method_name, lambda data: f"No valid key passed...\nkey={method_name}\nargs={data}")
return method(data) if data else method()
def has_method(self, obj, name) -> type:
''' Checks if a given method exists. '''
return callable(getattr(obj, name, None))
def clear_children(self, widget: type) -> None:
''' Clear children of a gtk widget. '''
for child in widget.get_children():
widget.remove(child)