bug 9876; fix for two progress bars occupy the same space

Moves the popup progress on tree views with filters to the main
window status bar.
This commit is contained in:
prculley 2017-01-03 09:36:41 -06:00 committed by Nick Hall
parent 52846b8e68
commit e24faddabb
2 changed files with 118 additions and 8 deletions

View File

@ -295,6 +295,7 @@ class TreeBaseModel(GObject.GObject, Gtk.TreeModel, BaseModel):
self.prev_handle = None self.prev_handle = None
self.prev_data = None self.prev_data = None
self.uistate = uistate
self.__reverse = (order == Gtk.SortType.DESCENDING) self.__reverse = (order == Gtk.SortType.DESCENDING)
self.scol = scol self.scol = scol
self.nrgroups = nrgroups self.nrgroups = nrgroups
@ -581,13 +582,11 @@ class TreeBaseModel(GObject.GObject, Gtk.TreeModel, BaseModel):
Rebuild the data map for a single Gramps object type, where a filter Rebuild the data map for a single Gramps object type, where a filter
is applied. is applied.
""" """
pmon = progressdlg.ProgressMonitor(progressdlg.GtkProgressDialog, pmon = progressdlg.ProgressMonitor(
popup_time=2) progressdlg.StatusProgress, (self.uistate,), popup_time=2,
status = progressdlg.LongOpStatus(msg=_("Building View"), title=_("Loading items..."))
total_steps=3, interval=1) status_ppl = progressdlg.LongOpStatus(total_steps=items,
pmon.add_op(status) interval=items // 20)
status_ppl = progressdlg.LongOpStatus(msg=_("Loading items..."),
total_steps=items, interval=items//10)
pmon.add_op(status_ppl) pmon.add_op(status_ppl)
self.__total += items self.__total += items
@ -606,7 +605,6 @@ class TreeBaseModel(GObject.GObject, Gtk.TreeModel, BaseModel):
self.__displayed += 1 self.__displayed += 1
status_ppl.end() status_ppl.end()
status.end()
def add_node(self, parent, child, sortkey, handle, add_parent=True, def add_node(self, parent, child, sortkey, handle, add_parent=True,
secondary=False): secondary=False):

View File

@ -591,6 +591,118 @@ class GtkProgressDialog(Gtk.Dialog):
def close(self): def close(self):
self.destroy() self.destroy()
#-------------------------------------------------------------------------
#
# Gramps main status bar Progress indicator
#
#-------------------------------------------------------------------------
class StatusProgress:
"""
A gtk progress in main Gramps window status bar to display the status
of a long running process.
"""
def __init__(self, window_params, title):
"""
:param title: The title to display on the top of the window.
:type title: string
"""
# self.set_title(title)
self.uistate = window_params[0]
self.title = title
self._old_val = -1
self._progress_bars = False
def add(self, long_op_status):
"""
Add a new status object to the statusbar progress.
:param long_op_status: the status object.
:type long_op_status: :class:`.LongOpStatus`
:returns: a key that can be used as the ``pbar_idx`` to the other
methods.
:rtype: int
"""
assert(not self._progress_bars)
self._pbar = self.uistate.progress
self._pbar_max = (long_op_status.get_total_steps() /
long_op_status.get_interval())
self._pbar_index = 0.0
self._pbar.set_fraction(
((100 / float(long_op_status.get_total_steps()) *
float(long_op_status.get_interval()))) / 100.0)
self.uistate.status.push(
self.uistate.status_id, self.title)
self._pbar.show()
return True
def remove(self, pbar_idx):
"""
Remove the specified status object from the progress dialog.
:param pbar_idx: the index as returned from :meth:`add` (not used)
:type pbar_idx: int
"""
self._progress_bars = False
self._pbar.hide()
def step(self, pbar_idx):
"""
Click the progress bar over to the next value. Be paranoid
and insure that it doesn't go over 100%.
:param pbar_idx: the index as returned from :meth:`add` (not used)
:type pbar_idx: int
"""
self._pbar_index = self._pbar_index + 1.0
if self._pbar_index > self._pbar_max:
self._pbar_index = self._pbar_max
try:
val = int(100 * self._pbar_index / self._pbar_max)
except ZeroDivisionError:
val = 0
if val != self._old_val:
self._pbar.set_text("%d%%" % val)
self._pbar.set_fraction(val / 100.0)
self._pbar.old_val = val
self._process_events()
def _process_events(self):
while Gtk.events_pending():
Gtk.main_iteration()
def show(self):
"""
Show the dialog and process any events.
"""
self._pbar.show()
self._process_events()
def hide(self):
"""
Hide the dialog and process any events.
"""
self._pbar.hide()
self.uistate.status.pop(
self.uistate.status_id)
self._process_events()
def _warn(self, x, y):
return True
def close(self):
# self.destroy()
pass
if __name__ == '__main__': if __name__ == '__main__':
def test(a, b): def test(a, b):