Small refactoring

This commit is contained in:
itdominator 2021-11-29 20:42:14 -06:00
parent f3adf09249
commit f5d2fc86f1

View File

@ -27,11 +27,9 @@ class WidgetFileActionMixin:
view.set_dir_watcher(dir_watcher) view.set_dir_watcher(dir_watcher)
def dir_watch_updates(self, file_monitor, file, other_file=None, eve_type=None, data=None): def dir_watch_updates(self, file_monitor, file, other_file=None, eve_type=None, data=None):
if eve_type == Gio.FileMonitorEvent.CREATED or \ if eve_type in [Gio.FileMonitorEvent.CREATED, Gio.FileMonitorEvent.DELETED,
eve_type == Gio.FileMonitorEvent.DELETED or \ Gio.FileMonitorEvent.RENAMED, Gio.FileMonitorEvent.MOVED_IN,
eve_type == Gio.FileMonitorEvent.RENAMED or \ Gio.FileMonitorEvent.MOVED_OUT]:
eve_type == Gio.FileMonitorEvent.MOVED_IN or \
eve_type == Gio.FileMonitorEvent.MOVED_OUT:
wid, tid = data[0].split("|") wid, tid = data[0].split("|")
notebook = self.builder.get_object(f"window_{wid}") notebook = self.builder.get_object(f"window_{wid}")
view = self.get_fm_window(wid).get_view_by_id(tid) view = self.get_fm_window(wid).get_view_by_id(tid)
@ -65,34 +63,34 @@ class WidgetFileActionMixin:
fname_field.set_text("") fname_field.set_text("")
def open_files(self):
def get_current_state(self):
wid, tid = self.window_controller.get_active_data() wid, tid = self.window_controller.get_active_data()
view = self.get_fm_window(wid).get_view_by_id(tid) view = self.get_fm_window(wid).get_view_by_id(tid)
iconview = self.builder.get_object(f"{wid}|{tid}|iconview") iconview = self.builder.get_object(f"{wid}|{tid}|iconview")
store = iconview.get_model() store = iconview.get_model()
return wid, tid, view, iconview, store
def open_files(self):
wid, tid, view, iconview, store = self.get_current_state()
uris = self.format_to_uris(store, wid, tid, self.selected_files, True) uris = self.format_to_uris(store, wid, tid, self.selected_files, True)
for file in uris: for file in uris:
view.open_file_locally(file) view.open_file_locally(file)
def open_with_files(self, appchooser_widget):
wid, tid = self.window_controller.get_active_data()
view = self.get_fm_window(wid).get_view_by_id(tid)
iconview = self.builder.get_object(f"{wid}|{tid}|iconview")
store = iconview.get_model()
uris = self.format_to_uris(store, wid, tid, self.selected_files)
def open_with_files(self, appchooser_widget):
wid, tid, view, iconview, store = self.get_current_state()
uris = self.format_to_uris(store, wid, tid, self.selected_files)
file = Gio.File.new_for_uri(uris[0]) file = Gio.File.new_for_uri(uris[0])
app_info = appchooser_widget.get_app_info() app_info = appchooser_widget.get_app_info()
app_info.launch([file], None) app_info.launch([file], None)
def rename_files(self): def rename_files(self):
rename_label = self.builder.get_object("file_to_rename_label") rename_label = self.builder.get_object("file_to_rename_label")
rename_input = self.builder.get_object("new_rename_fname") rename_input = self.builder.get_object("new_rename_fname")
wid, tid = self.window_controller.get_active_data() wid, tid, view, iconview, store = self.get_current_state()
view = self.get_fm_window(wid).get_view_by_id(tid)
iconview = self.builder.get_object(f"{wid}|{tid}|iconview")
store = iconview.get_model()
uris = self.format_to_uris(store, wid, tid, self.to_rename_files) uris = self.format_to_uris(store, wid, tid, self.to_rename_files)
# The rename button hides the rename dialog box which lets the loop continue. # The rename button hides the rename dialog box which lets the loop continue.
@ -116,21 +114,17 @@ class WidgetFileActionMixin:
rname_to = rename_input.get_text().strip() rname_to = rename_input.get_text().strip()
target = f"file://{view.get_current_directory()}/{rname_to}" target = f"file://{view.get_current_directory()}/{rname_to}"
print(target)
self.handle_file([uri], "edit", target) self.handle_file([uri], "edit", target)
self.show_edit_file_menu() self.show_edit_file_menu()
self.skip_edit = False self.skip_edit = False
self.cancel_edit = False self.cancel_edit = False
self.hide_new_file_menu() self.hide_new_file_menu()
self.to_rename_files.clear() self.to_rename_files.clear()
def archive_files(self, archiver_dialogue): def archive_files(self, archiver_dialogue):
wid, tid = self.window_controller.get_active_data() wid, tid, view, iconview, store = self.get_current_state()
iconview = self.builder.get_object(f"{wid}|{tid}|iconview")
store = iconview.get_model()
paths = self.format_to_uris(store, wid, tid, self.selected_files) paths = self.format_to_uris(store, wid, tid, self.selected_files)
save_target = archiver_dialogue.get_filename(); save_target = archiver_dialogue.get_filename();
@ -145,16 +139,12 @@ class WidgetFileActionMixin:
def cut_files(self): def cut_files(self):
wid, tid = self.window_controller.get_active_data() wid, tid, view, iconview, store = self.get_current_state()
iconview = self.builder.get_object(f"{wid}|{tid}|iconview")
store = iconview.get_model()
uris = self.format_to_uris(store, wid, tid, self.selected_files) uris = self.format_to_uris(store, wid, tid, self.selected_files)
self.to_cut_files = uris self.to_cut_files = uris
def copy_files(self): def copy_files(self):
wid, tid = self.window_controller.get_active_data() wid, tid, view, iconview, store = self.get_current_state()
iconview = self.builder.get_object(f"{wid}|{tid}|iconview")
store = iconview.get_model()
uris = self.format_to_uris(store, wid, tid, self.selected_files) uris = self.format_to_uris(store, wid, tid, self.selected_files)
self.to_copy_files = uris self.to_copy_files = uris
@ -175,18 +165,12 @@ class WidgetFileActionMixin:
self.handle_file(files, "move", target) self.handle_file(files, "move", target)
def delete_files(self): def delete_files(self):
wid, tid = self.window_controller.get_active_data() wid, tid, view, iconview, store = self.get_current_state()
iconview = self.builder.get_object(f"{wid}|{tid}|iconview")
view = self.get_fm_window(wid).get_view_by_id(tid)
store = iconview.get_model()
uris = self.format_to_uris(store, wid, tid, self.selected_files) uris = self.format_to_uris(store, wid, tid, self.selected_files)
self.handle_file(uris, "delete") self.handle_file(uris, "delete")
def trash_files(self): def trash_files(self):
wid, tid = self.window_controller.get_active_data() wid, tid, view, iconview, store = self.get_current_state()
iconview = self.builder.get_object(f"{wid}|{tid}|iconview")
view = self.get_fm_window(wid).get_view_by_id(tid)
store = iconview.get_model()
uris = self.format_to_uris(store, wid, tid, self.selected_files) uris = self.format_to_uris(store, wid, tid, self.selected_files)
self.handle_file(uris, "trash") self.handle_file(uris, "trash")