refactor: remove InfoBarWidget in favor of plugin-based one

- Replace direct InfoBarWidget with set_info_labels command that emits events to plugins
- Replace mini view widget in favor of plugin-based one
- Add widget registry exposure for code-container and editors-container
- Fix DND mixin exec_with_args call (tuple args issue)
- Add break statements in tabs_widget loops for efficiency
- Add _update_transparency call to BaseContainer
This commit is contained in:
2026-02-25 23:31:31 -06:00
parent bc3fe1eee1
commit e9c0565c04
21 changed files with 139 additions and 32 deletions

View File

@@ -0,0 +1,3 @@
"""
Pligin Module
"""

View File

@@ -0,0 +1,3 @@
"""
Pligin Package
"""

View File

@@ -10,15 +10,17 @@ from gi.repository import Pango
class MiniViewWidget(Map):
class CodeMiniMap(Map):
def __init__(self):
super(MiniViewWidget, self).__init__()
super(CodeMiniMap, self).__init__()
self._setup_styling()
self._setup_signals()
self._subscribe_to_events()
self._load_widgets()
self.show()
def _setup_styling(self):
ctx = self.get_style_context()

View File

@@ -0,0 +1,7 @@
{
"name": "Code MiniMap",
"author": "ITDominator",
"version": "0.0.1",
"support": "",
"requests": {}
}

View File

@@ -0,0 +1,32 @@
# Python imports
# Lib imports
# Application imports
from libs.event_factory import Event_Factory, Code_Event_Types
from plugins.plugin_types import PluginCode
from .code_minimap import CodeMiniMap
code_minimap = CodeMiniMap()
class Plugin(PluginCode):
def __init__(self):
super(Plugin, self).__init__()
def _controller_message(self, event: Code_Event_Types.CodeEvent):
if isinstance(event, Code_Event_Types.FocusedViewEvent):
code_minimap.set_smini_view(event.view)
def load(self):
editors_container = self.requests_ui_element("editors-container")
editors_container.add( code_minimap )
def run(self):
...

View File

@@ -0,0 +1,3 @@
"""
Pligin Module
"""

View File

@@ -0,0 +1,3 @@
"""
Pligin Package
"""

View File

@@ -33,11 +33,7 @@ class InfoBarWidget(Gtk.Box):
...
def _subscribe_to_events(self):
event_system.subscribe("set-info-labels", self._set_info_labels)
event_system.subscribe("set-path-label", self._set_path_label)
event_system.subscribe("set-encoding-label", self._set_encoding_label)
event_system.subscribe("set-line-char-label", self._set_line_char_label)
event_system.subscribe("set-file-type-label", self._set_file_type_label)
...
def _load_widgets(self):
@@ -63,9 +59,9 @@ class InfoBarWidget(Gtk.Box):
def _set_info_labels(
self,
path: Gio.File or str = None,
line_char: str = None,
file_type: str = None,
encoding_type: str = None
line_char: str = None,
file_type: str = None,
encoding_type: str = None
):
self._set_path_label(path)
self._set_line_char_label(line_char)

View File

@@ -0,0 +1,7 @@
{
"name": "Info Bar",
"author": "ITDominator",
"version": "0.0.1",
"support": "",
"requests": {}
}

View File

@@ -0,0 +1,32 @@
# Python imports
# Lib imports
# Application imports
from libs.event_factory import Event_Factory, Code_Event_Types
from plugins.plugin_types import PluginCode
from .info_bar_widget import InfoBarWidget
info_bar_widget = InfoBarWidget()
class Plugin(PluginCode):
def __init__(self):
super(Plugin, self).__init__()
def _controller_message(self, event: Code_Event_Types.CodeEvent):
if isinstance(event, Code_Event_Types.SetInfoLabelsEvent):
info_bar_widget._set_info_labels(*event.info)
def load(self):
header = self.requests_ui_element("header-container")
header.add( info_bar_widget )
def run(self):
...

View File

@@ -29,6 +29,7 @@ class BaseContainer(Gtk.Box):
self.ctx.add_class("base-container")
self.set_orientation(Gtk.Orientation.VERTICAL)
self._update_transparency()
def _setup_signals(self):
...

View File

@@ -6,7 +6,6 @@ gi.require_version('Gtk', '3.0')
from gi.repository import Gtk
# Application imports
from ..widgets.code.info_bar_widget import InfoBarWidget
from .code.code_container import CodeContainer
from ..widgets.save_file_dialog import SaveFileDialog
from ..widgets.controls.open_files_button import OpenFilesButton
@@ -43,9 +42,7 @@ class CenterContainer(Gtk.Box):
def _load_widgets(self):
widget_registery.expose_object("center-container", self)
SaveFileDialog()
OpenFilesButton()
self.add( InfoBarWidget() )
self.add( CodeContainer() )

View File

@@ -9,7 +9,6 @@ from gi.repository import Gtk
from ...widgets.code.code_base import CodeBase
from ...widgets.separator_widget import Separator
from ...widgets.code.mini_view_widget import MiniViewWidget
from .editors_container import EditorsContainer
@@ -48,9 +47,11 @@ class CodeContainer(Gtk.Box):
def _create_editor_widget(self, code_base: CodeBase):
editors_container = Gtk.Box()
widget_registery.expose_object("code-container", self)
widget_registery.expose_object("editors-container", editors_container)
editors_container.add( Separator("separator_left") )
editors_container.add( EditorsContainer(code_base) )
editors_container.add( Separator("separator_right") )
editors_container.add( code_base.get_mini_view_widget() )
return editors_container

View File

@@ -7,7 +7,6 @@ from gi.repository import Gtk
# Application imports
from ..widgets.separator_widget import Separator
from ..widgets.controls.transparency_scale import TransparencyScale
@@ -20,6 +19,8 @@ class HeaderContainer(Gtk.Box):
self._subscribe_to_events()
self._load_widgets()
self.show()
def _setup_styling(self):
self.ctx = self.get_style_context()
@@ -32,13 +33,9 @@ class HeaderContainer(Gtk.Box):
...
def _subscribe_to_events(self):
event_system.subscribe("tggl-top-main-menubar", self.tggl_top_main_menubar)
...
def _load_widgets(self):
widget_registery.expose_object("header-container", self)
self.add( Separator("separator-header", 0) )
self.add( TransparencyScale() )
def tggl_top_main_menubar(self):
self.hide() if self.is_visible() else self.show_all()

View File

@@ -13,8 +13,6 @@ from .controllers.commands_controller import CommandsController
from .controllers.completion_controller import CompletionController
from .controllers.views.source_views_controller import SourceViewsController
from .mini_view_widget import MiniViewWidget
class CodeBase:
@@ -22,7 +20,6 @@ class CodeBase:
super(CodeBase, self).__init__()
self.controller_manager: ControllerManager = ControllerManager()
self.miniview_widget: MiniViewWidget = MiniViewWidget()
self._subscribe_to_events()
self._load_controllers()
@@ -50,9 +47,6 @@ class CodeBase:
def get_tabs_widget(self):
return self.controller_manager["tabs"].get_tabs_widget()
def get_mini_view_widget(self):
return self.miniview_widget
def create_source_view(self):
source_view = self.controller_manager["source_views"].create_source_view()
self.controller_manager["completion"].register_completer(

View File

@@ -47,6 +47,14 @@ class CommandSystem:
...
def set_info_labels(self, data: tuple[str]):
event = Event_Factory.create_event(
"set_info_labels",
info = data
)
self.emit_to("plugins", event)
def get_file(self, view: SourceView):
event = Event_Factory.create_event(
"get_file",

View File

@@ -27,7 +27,6 @@ def execute(
column = iter.get_line_offset()
ftype = file.ftype.get_id() if hasattr(file.ftype, "get_id") else file.ftype
event_system.emit(
"set-info-labels",
view.command.set_info_labels(
(file.fpath, f"{line}:{column}", ftype, file.encoding)
)

View File

@@ -37,4 +37,4 @@ class SourceViewDnDMixin:
if not uris: return
self.command.exec_with_args("dnd_load_files", (self, uris))
self.command.exec_with_args("dnd_load_files", self, uris)

View File

@@ -116,6 +116,8 @@ class TabsWidget(Gtk.Notebook):
self.handler_unblock(self.switch_page_id)
break
def modified_changed(self, buffer):
for page_widget in self.get_children():
tab = self.get_tab_label(page_widget)
@@ -128,12 +130,16 @@ class TabsWidget(Gtk.Notebook):
else:
ctx.remove_class("file-changed")
break
def externally_deleted(self, buffer):
for page_widget in self.get_children():
tab = self.get_tab_label(page_widget)
if not buffer == tab.file.buffer: continue
ctx = tab.label.get_style_context()
ctx.add_class("file-deleted")
break
def close_item(self, menu_item, page_widget):
tab = self.get_tab_label(page_widget)

View File

@@ -6,8 +6,9 @@
from .code_event import CodeEvent
from .register_provider_event import RegisterProviderEvent
from .register_command_event import RegisterCommandEvent
from .file_externally_modified_event import FileExternallyModifiedEvent
from .file_externally_deleted_event import FileExternallyDeletedEvent
from .file_externally_modified_event import FileExternallyModifiedEvent
from .file_externally_deleted_event import FileExternallyDeletedEvent
from .set_info_labels_event import SetInfoLabelsEvent
from .get_new_command_system_event import GetNewCommandSystemEvent
from .request_completion_event import RequestCompletionEvent

View File

@@ -0,0 +1,15 @@
# Python imports
from dataclasses import dataclass, field
# Lib imports
import gi
from gi.repository import Gio
# Application imports
from .code_event import CodeEvent
@dataclass
class SetInfoLabelsEvent(CodeEvent):
info: tuple[str or Gio.File] = None