diff options
| author | Chris Lumens <clumens@redhat.com> | 2010-02-02 13:16:40 -0500 |
|---|---|---|
| committer | Chris Lumens <clumens@redhat.com> | 2010-02-03 16:07:46 -0500 |
| commit | 8a87de5f8573e4d800c02b99c09762e44f5666cd (patch) | |
| tree | e1b0a1a4cbcdf8ece61de82025ac617da661253e /iw | |
| parent | 47c44d34c747016ad046a073f4c88f5b94c5b198 (diff) | |
| download | anaconda-8a87de5f8573e4d800c02b99c09762e44f5666cd.tar.gz anaconda-8a87de5f8573e4d800c02b99c09762e44f5666cd.tar.xz anaconda-8a87de5f8573e4d800c02b99c09762e44f5666cd.zip | |
Fix a variety of filtering UI problems caused by switching models around.
(1) The filtered model is no longer the top-level so anywhere we want to call
refilter, we need to dig down and get the child, which happens to be the
filtered model.
(2) Similarly, we can only call get_text on the child of a ComboBoxEntry because
that's the entry part.
(3) Populate all search drop-downs when the containing hbox is realized, not
some complicated setup where each individual item is selected.
Diffstat (limited to 'iw')
| -rw-r--r-- | iw/filter_gui.py | 42 |
1 files changed, 29 insertions, 13 deletions
diff --git a/iw/filter_gui.py b/iw/filter_gui.py index 3dda8f6eb..c259802ac 100644 --- a/iw/filter_gui.py +++ b/iw/filter_gui.py @@ -183,10 +183,12 @@ class MPathCallbacks(FilteredCallbacks): self.interconnectEntry = self.xml.get_widget("mpathInterconnectEntry") self.IDEntry = self.xml.get_widget("mpathIDEntry") - self.vendorEntry.connect("changed", lambda entry: self.model.refilter()) - self.vendorEntry.connect("realize", self._populateUI) - self.interconnectEntry.connect("changed", lambda entry: self.model.refilter()) - self.IDEntry.connect("changed", lambda entry: self.model.refilter()) + self.mpathFilterHBox = self.xml.get_widget("mpathFilterHBox") + self.mpathFilterHBox.connect("realize", self._populateUI) + + self.vendorEntry.connect("changed", lambda entry: self.model.get_model().refilter()) + self.interconnectEntry.connect("changed", lambda entry: self.model.get_model().refilter()) + self.IDEntry.connect("changed", lambda entry: self.model.get_model().refilter()) def addToUI(self, tuple): if not tuple[VENDOR_COL] in self._vendors: @@ -213,18 +215,30 @@ class MPathCallbacks(FilteredCallbacks): return True def _populateUI(self, widget): + cell = gtk.CellRendererText() + self._vendors.sort() self.vendorEntry.set_model(gtk.ListStore(gobject.TYPE_STRING)) + self.vendorEntry.pack_start(cell) + self.vendorEntry.add_attribute(cell, 'text', 0) + for v in self._vendors: self.vendorEntry.append_text(v) + self.vendorEntry.show_all() + self._interconnects.sort() self.interconnectEntry.set_model(gtk.ListStore(gobject.TYPE_STRING)) + self.interconnectEntry.pack_start(cell) + self.interconnectEntry.add_attribute(cell, 'text', 0) + for i in self._interconnects: self.interconnectEntry.append_text(i) + self.interconnectEntry.show_all() + def _visible_by_vendor(self, model, iter, view): - entered = self.vendorEntry.get_text() + entered = self.vendorEntry.get_child().get_text() return model.get_value(iter, VENDOR_COL).find(entered) != -1 def _visible_by_interconnect(self, model, iter, view): @@ -251,10 +265,12 @@ class OtherCallbacks(MPathCallbacks): self.interconnectEntry = self.xml.get_widget("otherInterconnectEntry") self.IDEntry = self.xml.get_widget("otherIDEntry") - self.vendorEntry.connect("changed", lambda entry: self.model.refilter()) - self.vendorEntry.connect("realize", self._populateUI) - self.interconnectEntry.connect("changed", lambda entry: self.model.refilter()) - self.IDEntry.connect("changed", lambda entry: self.model.refilter()) + self.otherFilterHBox = self.xml.get_widget("otherFilterHBox") + self.otherFilterHBox.connect("realize", self._populateUI) + + self.vendorEntry.connect("changed", lambda entry: self.model.get_model().refilter()) + self.interconnectEntry.connect("changed", lambda entry: self.model.get_model().refilter()) + self.IDEntry.connect("changed", lambda entry: self.model.get_model().refilter()) def isMember(self, info): return info and isOther(info) @@ -277,10 +293,10 @@ class SearchCallbacks(FilteredCallbacks): # When these entries are changed, we need to redo the filtering. # If we don't do filter-as-you-type, we'd need a Search/Clear button. - self.portEntry.connect("changed", lambda entry: self.model.refilter()) - self.targetEntry.connect("changed", lambda entry: self.model.refilter()) - self.LUNEntry.connect("changed", lambda entry: self.model.refilter()) - self.IDEntry.connect("changed", lambda entry: self.model.refilter()) + self.portEntry.connect("changed", lambda entry: self.model.get_model().refilter()) + self.targetEntry.connect("changed", lambda entry: self.model.get_model().refilter()) + self.LUNEntry.connect("changed", lambda entry: self.model.get_model().refilter()) + self.IDEntry.connect("changed", lambda entry: self.model.get_model().refilter()) def isMember(self, info): return True |
