macros: allow reverse sorting

This commit is contained in:
alfrix 2022-05-09 17:32:50 -03:00 committed by Alfredo Monclus
parent 21633b9302
commit 53bc6f25ff

@ -2,7 +2,7 @@ import gi
import logging import logging
gi.require_version("Gtk", "3.0") gi.require_version("Gtk", "3.0")
from gi.repository import Gdk, Gtk, Pango from gi.repository import Gdk, Gtk, GLib, Pango
from ks_includes.screen_panel import ScreenPanel from ks_includes.screen_panel import ScreenPanel
@ -14,6 +14,8 @@ class MacroPanel(ScreenPanel):
_ = self.lang.gettext _ = self.lang.gettext
self.macros = {} self.macros = {}
self.loaded_macros = [] self.loaded_macros = []
self.sort_char = ["", ""]
self.sort_reverse = False
# Create a scroll window for the macros # Create a scroll window for the macros
scroll = Gtk.ScrolledWindow() scroll = Gtk.ScrolledWindow()
@ -26,23 +28,35 @@ class MacroPanel(ScreenPanel):
self.labels['macros'] = Gtk.Grid() self.labels['macros'] = Gtk.Grid()
scroll.add(self.labels['macros']) scroll.add(self.labels['macros'])
sort = Gtk.Label(_("Sort:"))
sort.set_hexpand(False)
self.sort_lbl = _("Name")
self.sort_btn = self._gtk.Button(self.sort_lbl + self.sort_char[0], "color1")
self.sort_btn.connect("clicked", self.change_sort)
self.sort_btn.set_hexpand(True)
#adjust = self._gtk.ButtonImage('fine-tune', '', "color2", 1, Gtk.PositionType.LEFT, False)
sbox = Gtk.HBox()
sbox.set_vexpand(False)
sbox.pack_start(sort, False, False, 5)
sbox.pack_start(self.sort_btn, True, True, 5)
#sbox.pack_start(adjust, True, True, 5)
# Create a box to contain all of the above # Create a box to contain all of the above
box = Gtk.Box(orientation=Gtk.Orientation.VERTICAL, spacing=0) box = Gtk.VBox()
box.set_vexpand(True) box.set_vexpand(True)
box.pack_start(sbox, False, False, 0)
box.pack_start(scroll, True, True, 0) box.pack_start(scroll, True, True, 0)
self.content.add(box) self.content.add(box)
def activate(self): def activate(self):
self.unload_gcode_macros() self.reload_macros()
self.load_gcode_macros()
def add_gcode_macro(self, macro): def add_gcode_macro(self, macro):
# Support for hiding macros by name # Support for hiding macros by name
if macro.startswith("_"): if macro.startswith("_"):
return return
frame = Gtk.Frame()
frame.get_style_context().add_class("frame-item")
name = Gtk.Label() name = Gtk.Label()
name.set_markup("<big><b>%s</b></big>" % (macro)) name.set_markup("<big><b>%s</b></big>" % (macro))
@ -53,33 +67,32 @@ class MacroPanel(ScreenPanel):
name.set_line_wrap(True) name.set_line_wrap(True)
name.set_line_wrap_mode(Pango.WrapMode.WORD_CHAR) name.set_line_wrap_mode(Pango.WrapMode.WORD_CHAR)
open = self._gtk.ButtonImage("resume", None, "color3") btn = self._gtk.ButtonImage("resume", None, "color3")
open.connect("clicked", self.run_gcode_macro, macro) btn.connect("clicked", self.run_gcode_macro, macro)
open.set_hexpand(False) btn.set_hexpand(False)
open.set_halign(Gtk.Align.END) btn.set_halign(Gtk.Align.END)
labels = Gtk.Box(orientation=Gtk.Orientation.VERTICAL) labels = Gtk.VBox()
labels.add(name) labels.add(name)
dev = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=5) dev = Gtk.HBox(spacing=5)
dev.set_hexpand(True)
dev.set_vexpand(False)
dev.add(labels) dev.add(labels)
dev.add(open) dev.add(btn)
frame = Gtk.Frame()
frame.get_style_context().add_class("frame-item")
frame.add(dev) frame.add(dev)
self.macros[macro] = { self.macros[macro] = {
"row": frame "row": frame
} }
macros = sorted(self.macros) macros = sorted(self.macros, reverse=self.sort_reverse, key=str.casefold)
pos = macros.index(macro) pos = macros.index(macro)
self.loaded_macros.append(macro) self.loaded_macros.append(macro)
self.labels['macros'].insert_row(pos) self.labels['macros'].insert_row(pos)
self.labels['macros'].attach(self.macros[macro]['row'], 0, pos, 1, 1) self.labels['macros'].attach(self.macros[macro]['row'], 0, pos, 1, 1)
self.labels['macros'].show_all()
def load_gcode_macros(self): def load_gcode_macros(self):
macros = self._screen.printer.get_gcode_macros() macros = self._screen.printer.get_gcode_macros()
@ -95,16 +108,22 @@ class MacroPanel(ScreenPanel):
if (section_name not in self._config.get_config().sections() or if (section_name not in self._config.get_config().sections() or
self._config.get_config().getboolean(section_name, macro.lower(), fallback=True)): self._config.get_config().getboolean(section_name, macro.lower(), fallback=True)):
self.add_gcode_macro(macro) self.add_gcode_macro(macro)
self.labels['macros'].show_all()
def run_gcode_macro(self, widget, macro): def run_gcode_macro(self, widget, macro):
self._screen._ws.klippy.gcode_script(macro) self._screen._ws.klippy.gcode_script(macro)
def unload_gcode_macros(self): def change_sort(self, widget):
section_name = "displayed_macros %s" % self._screen.connected_printer self.sort_reverse ^= True
for macro in self.loaded_macros: if self.sort_reverse:
if (section_name in self._config.get_config().sections() and self.sort_btn.set_label(self.sort_lbl + self.sort_char[1])
not self._config.get_config().getboolean(section_name, macro.lower(), fallback=True)): else:
macros = sorted(self.macros) self.sort_btn.set_label(self.sort_lbl + self.sort_char[0])
pos = macros.index(macro) self.sort_btn.show()
self.labels['macros'].remove_row(pos)
self.labels['macros'].show_all() GLib.idle_add(self.reload_macros)
def reload_macros(self):
self.labels['macros'].remove_column(0)
self.loaded_macros = []
self.load_gcode_macros()