ui: implement packed range setting in config panel
This commit is contained in:
parent
c9810e606e
commit
12217d6fa5
|
@ -267,7 +267,29 @@ class MapChoiceControl(Gtk.HBox, Control):
|
||||||
_write_async(self.sbox.setting, value, self.sbox, key=int(key_choice))
|
_write_async(self.sbox.setting, value, self.sbox, key=int(key_choice))
|
||||||
|
|
||||||
|
|
||||||
class MultipleControl(Control):
|
class MultipleControl(Gtk.ListBox, Control):
|
||||||
|
def __init__(self, sbox, change, button_label='...', delegate=None):
|
||||||
|
super().__init__()
|
||||||
|
self.init(sbox, delegate)
|
||||||
|
self.set_selection_mode(Gtk.SelectionMode.NONE)
|
||||||
|
self.set_no_show_all(True)
|
||||||
|
self._showing = True
|
||||||
|
self.setup(sbox.setting) # set up the data and boxes for the sub-controls
|
||||||
|
btn = Gtk.Button(button_label)
|
||||||
|
btn.set_alignment(1.0, 0.5)
|
||||||
|
btn.connect('clicked', self.toggle_display)
|
||||||
|
self._button = btn
|
||||||
|
hbox = Gtk.HBox(homogeneous=False, spacing=6)
|
||||||
|
hbox.pack_end(change, False, False, 0)
|
||||||
|
hbox.pack_end(btn, False, False, 0)
|
||||||
|
self._header = hbox
|
||||||
|
vbox = Gtk.VBox(homogeneous=False, spacing=6)
|
||||||
|
vbox.pack_start(hbox, True, True, 0)
|
||||||
|
vbox.pack_end(self, True, True, 0)
|
||||||
|
self.vbox = vbox
|
||||||
|
self.toggle_display()
|
||||||
|
_disable_listbox_highlight_bg(self)
|
||||||
|
|
||||||
def layout(self, sbox, label, change, spinner, failed):
|
def layout(self, sbox, label, change, spinner, failed):
|
||||||
self._header.pack_start(label, False, False, 0)
|
self._header.pack_start(label, False, False, 0)
|
||||||
self._header.pack_end(spinner, False, False, 0)
|
self._header.pack_end(spinner, False, False, 0)
|
||||||
|
@ -288,20 +310,15 @@ class MultipleControl(Control):
|
||||||
c.show_all()
|
c.show_all()
|
||||||
|
|
||||||
|
|
||||||
class MultipleToggleControl(Gtk.ListBox, MultipleControl):
|
class MultipleToggleControl(MultipleControl):
|
||||||
def __init__(self, sbox, change, delegate=None):
|
def setup(self, setting):
|
||||||
super().__init__()
|
|
||||||
self.init(sbox, delegate)
|
|
||||||
self.set_selection_mode(Gtk.SelectionMode.NONE)
|
|
||||||
self.set_no_show_all(True)
|
|
||||||
self._showing = True
|
|
||||||
self._label_control_pairs = []
|
self._label_control_pairs = []
|
||||||
for k in sbox.setting._validator.get_options():
|
for k in setting._validator.get_options():
|
||||||
h = Gtk.HBox(homogeneous=False, spacing=0)
|
h = Gtk.HBox(homogeneous=False, spacing=0)
|
||||||
lbl_text = str(k)
|
lbl_text = str(k)
|
||||||
lbl_tooltip = None
|
lbl_tooltip = None
|
||||||
if hasattr(sbox.setting, '_labels'):
|
if hasattr(setting, '_labels'):
|
||||||
l1, l2 = sbox.setting._labels.get(k, (None, None))
|
l1, l2 = setting._labels.get(k, (None, None))
|
||||||
lbl_text = l1 if l1 else lbl_text
|
lbl_text = l1 if l1 else lbl_text
|
||||||
lbl_tooltip = l2 if l2 else lbl_tooltip
|
lbl_tooltip = l2 if l2 else lbl_tooltip
|
||||||
lbl = Gtk.Label(lbl_text)
|
lbl = Gtk.Label(lbl_text)
|
||||||
|
@ -315,20 +332,6 @@ class MultipleToggleControl(Gtk.ListBox, MultipleControl):
|
||||||
lbl.set_margin_left(30)
|
lbl.set_margin_left(30)
|
||||||
self.add(h)
|
self.add(h)
|
||||||
self._label_control_pairs.append((lbl, control))
|
self._label_control_pairs.append((lbl, control))
|
||||||
btn = Gtk.Button('? / ?')
|
|
||||||
btn.set_alignment(1.0, 0.5)
|
|
||||||
btn.connect('clicked', self.toggle_display)
|
|
||||||
self._button = btn
|
|
||||||
hbox = Gtk.HBox(homogeneous=False, spacing=6)
|
|
||||||
hbox.pack_end(change, False, False, 0)
|
|
||||||
hbox.pack_end(btn, False, False, 0)
|
|
||||||
self._header = hbox
|
|
||||||
vbox = Gtk.VBox(homogeneous=False, spacing=6)
|
|
||||||
vbox.pack_start(hbox, True, True, 0)
|
|
||||||
vbox.pack_end(self, True, True, 0)
|
|
||||||
self.vbox = vbox
|
|
||||||
self.toggle_display()
|
|
||||||
_disable_listbox_highlight_bg(self)
|
|
||||||
|
|
||||||
def toggle_notify(self, switch, active):
|
def toggle_notify(self, switch, active):
|
||||||
if switch.get_sensitive():
|
if switch.get_sensitive():
|
||||||
|
@ -354,19 +357,14 @@ class MultipleToggleControl(Gtk.ListBox, MultipleControl):
|
||||||
self._button.set_tooltip_text(b)
|
self._button.set_tooltip_text(b)
|
||||||
|
|
||||||
|
|
||||||
class MultipleRangeControl(Gtk.ListBox, MultipleControl):
|
class MultipleRangeControl(MultipleControl):
|
||||||
def __init__(self, sbox, change, delegate=None):
|
def setup(self, setting):
|
||||||
super().__init__()
|
|
||||||
self.init(sbox, delegate)
|
|
||||||
self.set_selection_mode(Gtk.SelectionMode.NONE)
|
|
||||||
self.set_no_show_all(True)
|
|
||||||
self._showing = True
|
|
||||||
self._items = []
|
self._items = []
|
||||||
for item in sbox.setting._validator.items:
|
for item in setting._validator.items:
|
||||||
lbl_text = str(item)
|
lbl_text = str(item)
|
||||||
lbl_tooltip = None
|
lbl_tooltip = None
|
||||||
if hasattr(sbox.setting, '_labels'):
|
if hasattr(setting, '_labels'):
|
||||||
l1, l2 = sbox.setting._labels.get(int(item), (None, None))
|
l1, l2 = setting._labels.get(int(item), (None, None))
|
||||||
lbl_text = l1 if l1 else lbl_text
|
lbl_text = l1 if l1 else lbl_text
|
||||||
lbl_tooltip = l2 if l2 else lbl_tooltip
|
lbl_tooltip = l2 if l2 else lbl_tooltip
|
||||||
item_lbl = Gtk.Label(lbl_text)
|
item_lbl = Gtk.Label(lbl_text)
|
||||||
|
@ -375,12 +373,12 @@ class MultipleRangeControl(Gtk.ListBox, MultipleControl):
|
||||||
item_lb = Gtk.ListBox()
|
item_lb = Gtk.ListBox()
|
||||||
item_lb.set_selection_mode(Gtk.SelectionMode.NONE)
|
item_lb.set_selection_mode(Gtk.SelectionMode.NONE)
|
||||||
item_lb._sub_items = []
|
item_lb._sub_items = []
|
||||||
for sub_item in sbox.setting._validator.sub_items[item]:
|
for sub_item in setting._validator.sub_items[item]:
|
||||||
h = Gtk.HBox(homogeneous=False, spacing=20)
|
h = Gtk.HBox(homogeneous=False, spacing=20)
|
||||||
lbl_text = str(sub_item)
|
lbl_text = str(sub_item)
|
||||||
lbl_tooltip = None
|
lbl_tooltip = None
|
||||||
if hasattr(sbox.setting, '_labels_sub'):
|
if hasattr(setting, '_labels_sub'):
|
||||||
l1, l2 = sbox.setting._labels_sub.get(str(sub_item), (None, None))
|
l1, l2 = setting._labels_sub.get(str(sub_item), (None, None))
|
||||||
lbl_text = l1 if l1 else lbl_text
|
lbl_text = l1 if l1 else lbl_text
|
||||||
lbl_tooltip = l2 if l2 else lbl_tooltip
|
lbl_tooltip = l2 if l2 else lbl_tooltip
|
||||||
sub_item_lbl = Gtk.Label(lbl_text)
|
sub_item_lbl = Gtk.Label(lbl_text)
|
||||||
|
@ -408,21 +406,6 @@ class MultipleRangeControl(Gtk.ListBox, MultipleControl):
|
||||||
_disable_listbox_highlight_bg(item_lb)
|
_disable_listbox_highlight_bg(item_lb)
|
||||||
self.add(item_lb)
|
self.add(item_lb)
|
||||||
self._items.append(item_lb)
|
self._items.append(item_lb)
|
||||||
btn = Gtk.Button('...')
|
|
||||||
btn.set_alignment(1.0, 0.5)
|
|
||||||
btn.set_alignment(1.0, 0.5)
|
|
||||||
btn.connect('clicked', self.toggle_display)
|
|
||||||
self._button = btn
|
|
||||||
hbox = Gtk.HBox(homogeneous=False, spacing=6)
|
|
||||||
hbox.pack_end(change, False, False, 0)
|
|
||||||
hbox.pack_end(btn, False, False, 0)
|
|
||||||
self._header = hbox
|
|
||||||
vbox = Gtk.VBox(homogeneous=False, spacing=6)
|
|
||||||
vbox.pack_start(hbox, True, True, 0)
|
|
||||||
vbox.pack_end(self, True, True, 0)
|
|
||||||
self.vbox = vbox
|
|
||||||
self.toggle_display()
|
|
||||||
_disable_listbox_highlight_bg(self)
|
|
||||||
|
|
||||||
def changed(self, control, item, sub_item):
|
def changed(self, control, item, sub_item):
|
||||||
if control.get_sensitive():
|
if control.get_sensitive():
|
||||||
|
@ -463,6 +446,57 @@ class MultipleRangeControl(Gtk.ListBox, MultipleControl):
|
||||||
self._button.set_tooltip_text(b)
|
self._button.set_tooltip_text(b)
|
||||||
|
|
||||||
|
|
||||||
|
class PackedRangeControl(MultipleRangeControl):
|
||||||
|
def setup(self, setting):
|
||||||
|
validator = setting._validator
|
||||||
|
self._items = []
|
||||||
|
for item in range(validator.count):
|
||||||
|
h = Gtk.HBox(homogeneous=False, spacing=0)
|
||||||
|
lbl = Gtk.Label(str(validator.keys[item]))
|
||||||
|
control = Gtk.Scale.new_with_range(Gtk.Orientation.HORIZONTAL, validator.min_value, validator.max_value, 1)
|
||||||
|
control.set_round_digits(0)
|
||||||
|
control.set_digits(0)
|
||||||
|
control.connect('value-changed', self.changed, validator.keys[item])
|
||||||
|
h.pack_start(lbl, False, False, 0)
|
||||||
|
h.pack_end(control, True, True, 0)
|
||||||
|
h._setting_item = validator.keys[item]
|
||||||
|
h.control = control
|
||||||
|
lbl.set_alignment(0.0, 0.5)
|
||||||
|
lbl.set_margin_left(30)
|
||||||
|
self.add(h)
|
||||||
|
self._items.append(h)
|
||||||
|
|
||||||
|
def changed(self, control, item):
|
||||||
|
if control.get_sensitive():
|
||||||
|
if hasattr(control, '_timer'):
|
||||||
|
control._timer.cancel()
|
||||||
|
control._timer = _Timer(0.5, lambda: GLib.idle_add(self._write, control, item))
|
||||||
|
control._timer.start()
|
||||||
|
|
||||||
|
def _write(self, control, item):
|
||||||
|
control._timer.cancel()
|
||||||
|
delattr(control, '_timer')
|
||||||
|
new_state = int(control.get_value())
|
||||||
|
if self.sbox.setting._value[int(item)] != new_state:
|
||||||
|
self.sbox.setting._value[int(item)] = new_state
|
||||||
|
_write_async(self.sbox.setting, self.sbox.setting._value[int(item)], self.sbox, key=int(item))
|
||||||
|
|
||||||
|
def set_value(self, value):
|
||||||
|
b = ''
|
||||||
|
n = len(self._items)
|
||||||
|
for h in self._items:
|
||||||
|
item = h._setting_item
|
||||||
|
v = value.get(int(item), None)
|
||||||
|
if v is not None:
|
||||||
|
h.control.set_value(v)
|
||||||
|
else:
|
||||||
|
v = self.sbox.setting._value[int(item)]
|
||||||
|
b += str(item) + ': (' + str(v) + ') '
|
||||||
|
lbl_text = ngettext('%d value', '%d values', n) % n
|
||||||
|
self._button.set_label(lbl_text)
|
||||||
|
self._button.set_tooltip_text(b)
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
|
@ -542,6 +576,8 @@ def _create_sbox(s, device):
|
||||||
control = MultipleToggleControl(sbox, change)
|
control = MultipleToggleControl(sbox, change)
|
||||||
elif s.kind == _SETTING_KIND.multiple_range:
|
elif s.kind == _SETTING_KIND.multiple_range:
|
||||||
control = MultipleRangeControl(sbox, change)
|
control = MultipleRangeControl(sbox, change)
|
||||||
|
elif s.kind == _SETTING_KIND.packed_range:
|
||||||
|
control = PackedRangeControl(sbox, change)
|
||||||
else:
|
else:
|
||||||
if _log.isEnabledFor(_WARNING):
|
if _log.isEnabledFor(_WARNING):
|
||||||
_log.warn('setting %s display not implemented', s.label)
|
_log.warn('setting %s display not implemented', s.label)
|
||||||
|
|
Loading…
Reference in New Issue