generated from itdominator/Python-With-Gtk-Template
Further FileWidget enhancements
This commit is contained in:
61
src/core/widgets/dialogs/appchooser_widget.py
Normal file
61
src/core/widgets/dialogs/appchooser_widget.py
Normal file
@@ -0,0 +1,61 @@
|
||||
# Python imports
|
||||
|
||||
# Lib imports
|
||||
import gi
|
||||
gi.require_version('Gtk', '3.0')
|
||||
from gi.repository import Gtk
|
||||
|
||||
# Application imports
|
||||
|
||||
|
||||
|
||||
|
||||
class AppchooserWidget:
|
||||
"""docstring for AppchooserWidget."""
|
||||
|
||||
def __init__(self):
|
||||
super(AppchooserWidget, self).__init__()
|
||||
|
||||
_GLADE_FILE = f"{settings.get_ui_widgets_path()}/appchooser_ui.glade"
|
||||
self._builder = Gtk.Builder()
|
||||
self._builder.add_from_file(_GLADE_FILE)
|
||||
|
||||
self._setup_styling()
|
||||
self._setup_signals()
|
||||
self._load_widgets()
|
||||
|
||||
|
||||
def _setup_styling(self):
|
||||
...
|
||||
|
||||
def _setup_signals(self):
|
||||
event_system.subscribe("show_appchooser_menu", self.show_appchooser_menu)
|
||||
event_system.subscribe("hide_appchooser_menu", self.hide_appchooser_menu)
|
||||
event_system.subscribe("run_appchooser_launch", self.run_appchooser_launch)
|
||||
settings.register_signals_to_builder([self,], self._builder)
|
||||
|
||||
def _load_widgets(self):
|
||||
builder = settings.get_builder()
|
||||
|
||||
self._appchooser_menu = self._builder.get_object("appchooser_menu")
|
||||
self._appchooser_widget = self._builder.get_object("appchooser_widget")
|
||||
|
||||
builder.expose_object(f"appchooser_menu", self._appchooser_menu)
|
||||
builder.expose_object(f"appchooser_widget", self._appchooser_widget)
|
||||
|
||||
|
||||
def show_appchooser_menu(self, widget=None, eve=None):
|
||||
response = self._appchooser_menu.run()
|
||||
if response == Gtk.ResponseType.OK:
|
||||
app_info = self._appchooser_widget.get_app_info()
|
||||
event_system.emit("open_with_files", app_info)
|
||||
self.hide_appchooser_menu()
|
||||
if response == Gtk.ResponseType.CANCEL:
|
||||
self.hide_appchooser_menu()
|
||||
|
||||
|
||||
def hide_appchooser_menu(self, widget=None, eve=None):
|
||||
self._appchooser_menu.hide()
|
||||
|
||||
def run_appchooser_launch(self, widget=None, eve=None):
|
||||
self._appchooser_menu.response(Gtk.ResponseType.OK)
|
||||
@@ -103,7 +103,9 @@ class DragArea(Gtk.Fixed):
|
||||
for uri in uris:
|
||||
event_system.emit("set_widget_type", "FileWidget")
|
||||
dynamic_widget = self.add_or_select_widget(x = _x, y = _y)
|
||||
dynamic_widget.set_file(uri)
|
||||
dynamic_widget.get_body().set_file_path(uri)
|
||||
dynamic_widget.save()
|
||||
_y += 85
|
||||
|
||||
|
||||
def _move_callback(self, widget = None, x = None, y = None):
|
||||
|
||||
@@ -52,9 +52,12 @@ class WidgetSelectorGrid(Gtk.Grid):
|
||||
self._register_widget_type(globals()[widget])
|
||||
|
||||
def _register_widget_type(self, Widget):
|
||||
widget = Widget()
|
||||
|
||||
selection = Gtk.EventBox()
|
||||
widget = Widget()
|
||||
ctx = widget.get_style_context()
|
||||
|
||||
ctx.add_class("selection-widget")
|
||||
|
||||
selection.set_above_child(True)
|
||||
selection.add(widget)
|
||||
selection.connect("button-release-event", self._set_widget_type_eve)
|
||||
|
||||
@@ -10,17 +10,63 @@ from gi.repository import Gio
|
||||
from utils.widget_save_load_controller import WidgetSaveLoadController
|
||||
|
||||
|
||||
class FileWidget(WidgetSaveLoadController, Gtk.Box):
|
||||
def __init__(self):
|
||||
super(FileWidget, self).__init__()
|
||||
|
||||
self._file_path = None
|
||||
class FileWidgetException(Exception):
|
||||
...
|
||||
|
||||
|
||||
class FileChooser(Gtk.Dialog):
|
||||
"""docstring for FileChooser."""
|
||||
|
||||
def __init__(self):
|
||||
super(FileChooser, self).__init__()
|
||||
|
||||
self._file_chooser_widget = None
|
||||
|
||||
self._setup_styling()
|
||||
self._setup_signals()
|
||||
self._subscribe_to_events()
|
||||
self._load_widgets()
|
||||
|
||||
self.show_all()
|
||||
|
||||
|
||||
def _setup_styling(self):
|
||||
...
|
||||
|
||||
def _setup_signals(self):
|
||||
...
|
||||
|
||||
def _subscribe_to_events(self):
|
||||
...
|
||||
|
||||
def _load_widgets(self):
|
||||
hbox = self.get_content_area()
|
||||
self._file_chooser_widget = Gtk.FileChooserWidget()
|
||||
self._file_chooser_widget.set_select_multiple(True)
|
||||
|
||||
hbox.add(self._file_chooser_widget)
|
||||
self.add_button("Cancel", 1)
|
||||
self.add_button("Select", 0)
|
||||
|
||||
def get_file_chooser_widget(self):
|
||||
return self._file_chooser_widget
|
||||
|
||||
|
||||
class FileWidget(WidgetSaveLoadController, Gtk.Box):
|
||||
def __init__(self):
|
||||
super(FileWidget, self).__init__()
|
||||
|
||||
self._file_path = None
|
||||
self._file_name = "No File Selected..."
|
||||
self.label = None
|
||||
|
||||
self._setup_styling()
|
||||
self._setup_signals()
|
||||
self._subscribe_to_events()
|
||||
self._load_widgets()
|
||||
self.set_file_path()
|
||||
|
||||
event_system.emit("register_to_query_controller", (self, self.get_query_data))
|
||||
self.show_all()
|
||||
|
||||
@@ -30,7 +76,7 @@ class FileWidget(WidgetSaveLoadController, Gtk.Box):
|
||||
return widget
|
||||
|
||||
def _setup_styling(self):
|
||||
self.set_orientation(0)
|
||||
self.set_orientation(1)
|
||||
|
||||
def _setup_signals(self):
|
||||
self.connect("key-release-event", self._key_released)
|
||||
@@ -39,8 +85,20 @@ class FileWidget(WidgetSaveLoadController, Gtk.Box):
|
||||
...
|
||||
|
||||
def _load_widgets(self):
|
||||
image = Gtk.Image(stock=Gtk.STOCK_MEDIA_PLAY )
|
||||
self.add(image)
|
||||
box = Gtk.Box()
|
||||
eve_box = Gtk.EventBox()
|
||||
image = Gtk.Image(stock = Gtk.STOCK_FILE)
|
||||
self.label = Gtk.Label(self._file_name)
|
||||
|
||||
box.set_orientation(1)
|
||||
eve_box.connect('button-press-event', self._clicked)
|
||||
|
||||
box.add(image)
|
||||
box.add(self.label)
|
||||
eve_box.add(box)
|
||||
self.add(eve_box)
|
||||
eve_box.show_all()
|
||||
|
||||
|
||||
def _key_released(self, widget = None, eve = None):
|
||||
if eve.type == 9:
|
||||
@@ -48,6 +106,20 @@ class FileWidget(WidgetSaveLoadController, Gtk.Box):
|
||||
# pass
|
||||
...
|
||||
|
||||
def _clicked(self, widget = None, eve = None):
|
||||
if eve.button == 1 and eve.type == 5: # NOTE: Left dbl click
|
||||
event_system.emit("open_files", ( [self.get_file_path()], ) )
|
||||
return
|
||||
|
||||
if eve.button == 3 and eve.type == 4: # NOTE: Right click
|
||||
try:
|
||||
self.set_current_file()
|
||||
self.get_parent().save_needed = True
|
||||
except FileWidgetException as e:
|
||||
logger.debug(e)
|
||||
|
||||
return
|
||||
|
||||
def get_query_data(self):
|
||||
return self.get_file_name()
|
||||
|
||||
@@ -64,12 +136,17 @@ class FileWidget(WidgetSaveLoadController, Gtk.Box):
|
||||
self.set_file_path( self.save_collection["data"] )
|
||||
|
||||
|
||||
def set_file_path(self, path):
|
||||
def set_file_path(self, path = settings.get_home_path()):
|
||||
try:
|
||||
self._file_path = Gio.File.new_for_uri(path)
|
||||
except Exception as e:
|
||||
if not self._file_path.get_path():
|
||||
raise FileWidgetException("Not URI based path...")
|
||||
except FileWidgetException as e:
|
||||
self._file_path = Gio.File.new_for_path(path)
|
||||
|
||||
self._file_name = self.get_file_name()
|
||||
self.label.set_label(self._file_name)
|
||||
|
||||
def get_file(self):
|
||||
return self._file_path
|
||||
|
||||
@@ -83,3 +160,16 @@ class FileWidget(WidgetSaveLoadController, Gtk.Box):
|
||||
def get_file_name(self):
|
||||
info = self._file_path.query_info("standard::*", 0, cancellable = None)
|
||||
return info.get_display_name()
|
||||
|
||||
def set_current_file(self):
|
||||
dlg = FileChooser()
|
||||
response = dlg.run()
|
||||
if response == 0:
|
||||
widget = dlg.get_file_chooser_widget()
|
||||
uris = widget.get_uris()
|
||||
if len(uris) == 1:
|
||||
uri = uris[0]
|
||||
|
||||
self.set_file_path(uri)
|
||||
|
||||
dlg.destroy()
|
||||
|
||||
Reference in New Issue
Block a user