/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz

« back to all changes in this revision

Viewing changes to branchview/treeview.py

  • Committer: Jelmer Vernooij
  • Date: 2008-07-31 01:55:07 UTC
  • mto: (580.2.1 gtk.gloom)
  • mto: This revision was merged to the branch mainline in revision 581.
  • Revision ID: jelmer@samba.org-20080731015507-tarukc7r26ud7twu
Avoid making assumptions about a branch being a loom until we've checked.

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
from bzrlib import ui
17
17
 
18
18
from bzrlib.plugins.gtk import _i18n
 
19
from bzrlib.plugins.gtk.ui import GtkProgressBar, ProgressPanel
19
20
from linegraph import linegraph, same_branch
20
21
from graphcell import CellRendererGraph
21
22
from treemodel import TreeModel
22
23
from bzrlib.revision import NULL_REVISION
23
24
 
 
25
 
24
26
class TreeView(gtk.VBox):
25
27
 
26
28
    __gproperties__ = {
106
108
        """
107
109
        gtk.VBox.__init__(self, spacing=0)
108
110
 
 
111
        loading_msg_widget = ProgressPanel()
 
112
        if getattr(ui.ui_factory, "set_nested_progress_bar_widget", None) is not None:
 
113
            ui.ui_factory.set_nested_progress_bar_widget(loading_msg_widget.get_progress_bar)
 
114
        self.pack_start(loading_msg_widget, expand=False, fill=True)
 
115
 
109
116
        self.scrolled_window = gtk.ScrolledWindow()
110
117
        self.scrolled_window.set_policy(gtk.POLICY_AUTOMATIC,
111
118
                                        gtk.POLICY_AUTOMATIC)
269
276
                       should be broken.
270
277
        """
271
278
 
272
 
        loading_progress = ui.ui_factory.nested_progress_bar()
273
 
        loading_progress.update(msg="Loading ancestry graph", total=5)
 
279
        self.progress_bar = ui.ui_factory.nested_progress_bar()
 
280
        self.progress_bar.update("Loading ancestry graph", 0, 5)
274
281
 
275
282
        try:
276
283
            if self.compact:
287
294
                                                            broken_line_length,
288
295
                                                            show_graph,
289
296
                                                            self.mainline_only,
290
 
                                                            loading_progress)
 
297
                                                            self.progress_bar)
291
298
 
292
299
            self.model = TreeModel(self.branch, linegraphdata)
293
300
            self.graph_cell.columns_len = columns_len
306
313
 
307
314
            return False
308
315
        finally:
309
 
            loading_progress.finished()
 
316
            self.progress_bar.finished()
310
317
 
311
318
    def construct_treeview(self):
312
319
        self.treeview = gtk.TreeView()
319
326
        if set_tooltip is not None:
320
327
            set_tooltip(treemodel.MESSAGE)
321
328
 
 
329
        self._prev_cursor_path = None
322
330
        self.treeview.connect("cursor-changed",
323
331
                self._on_selection_changed)
324
332
 
390
398
        self.treeview.append_column(self.date_column)
391
399
        
392
400
        return self.treeview
393
 
 
 
401
    
394
402
    def _on_selection_changed(self, treeview):
395
403
        """callback for when the treeview changes."""
396
404
        (path, focus) = treeview.get_cursor()
397
 
        if path is not None:
 
405
        if (path is not None) and (path != self._prev_cursor_path):
 
406
            self._prev_cursor_path = path # avoid emitting twice per click
398
407
            self.iter = self.model.get_iter(path)
399
408
            self.emit('revision-selected')
400
409
 
401
410
    def _on_revision_selected(self, widget, event):
402
 
        from bzrlib.plugins.gtk.revisionmenu import RevisionPopupMenu
 
411
        from bzrlib.plugins.gtk.revisionmenu import RevisionMenu
403
412
        if event.button == 3:
404
 
            menu = RevisionPopupMenu(self.branch.repository, 
 
413
            menu = RevisionMenu(self.branch.repository, 
405
414
                [self.get_revision().revision_id],
406
415
                self.branch)
407
416
            menu.connect('tag-added', lambda w, t, r: self.add_tag(t, r))