/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-06-29 16:20:15 UTC
  • mto: This revision was merged to the branch mainline in revision 519.
  • Revision ID: jelmer@samba.org-20080629162015-amhe7xj4cdmup4id
Rename GtkProgressBarStack to GtkWindowProgressBarStack

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
20
19
from linegraph import linegraph, same_branch
21
20
from graphcell import CellRendererGraph
22
21
from treemodel import TreeModel
23
22
from bzrlib.revision import NULL_REVISION
24
23
 
25
 
 
26
24
class TreeView(gtk.VBox):
27
25
 
28
26
    __gproperties__ = {
93
91
                              (gobject.TYPE_PYOBJECT, gobject.TYPE_PYOBJECT)),
94
92
        'tag-added': (gobject.SIGNAL_RUN_FIRST,
95
93
                              gobject.TYPE_NONE,
96
 
                              (gobject.TYPE_STRING, gobject.TYPE_STRING)),
97
 
        'refreshed': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
98
 
                              ())
 
94
                              (gobject.TYPE_STRING, gobject.TYPE_STRING))
99
95
    }
100
96
 
101
97
    def __init__(self, branch, start, maxnum, compact=True):
110
106
        """
111
107
        gtk.VBox.__init__(self, spacing=0)
112
108
 
113
 
        loading_msg_widget = ProgressPanel()
114
 
        if getattr(ui.ui_factory, "set_nested_progress_bar_widget", None) is not None:
115
 
            ui.ui_factory.set_nested_progress_bar_widget(loading_msg_widget.get_progress_bar)
116
 
        self.pack_start(loading_msg_widget, expand=False, fill=True)
117
 
 
118
109
        self.scrolled_window = gtk.ScrolledWindow()
119
110
        self.scrolled_window.set_policy(gtk.POLICY_AUTOMATIC,
120
111
                                        gtk.POLICY_AUTOMATIC)
127
118
        self.iter = None
128
119
        self.branch = branch
129
120
        self.revision = None
130
 
        self.index = {}
131
121
 
132
122
        self.start = start
133
123
        self.maxnum = maxnum
183
173
        """Return revision id of currently selected revision, or None."""
184
174
        return self.get_property('revision')
185
175
 
186
 
    def has_revision_id(self, revision_id):
187
 
        return (revision_id in self.index)
188
 
 
189
176
    def set_revision(self, revision):
190
177
        self.set_property('revision', revision)
191
178
 
282
269
                       should be broken.
283
270
        """
284
271
 
285
 
        self.progress_bar = ui.ui_factory.nested_progress_bar()
286
 
        self.progress_bar.update("Loading ancestry graph", 0, 5)
 
272
        loading_progress = ui.ui_factory.nested_progress_bar()
 
273
        loading_progress.update(msg="Loading ancestry graph", total=5)
287
274
 
288
275
        try:
289
276
            if self.compact:
300
287
                                                            broken_line_length,
301
288
                                                            show_graph,
302
289
                                                            self.mainline_only,
303
 
                                                            self.progress_bar)
 
290
                                                            loading_progress)
304
291
 
305
292
            self.model = TreeModel(self.branch, linegraphdata)
306
293
            self.graph_cell.columns_len = columns_len
317
304
            else:
318
305
                self.set_revision(revision)
319
306
 
320
 
            self.emit('refreshed')
 
307
            self.emit('revisions-loaded')
 
308
 
321
309
            return False
322
310
        finally:
323
 
            self.progress_bar.finished()
 
311
            loading_progress.finished()
324
312
 
325
313
    def construct_treeview(self):
326
314
        self.treeview = gtk.TreeView()
333
321
        if set_tooltip is not None:
334
322
            set_tooltip(treemodel.MESSAGE)
335
323
 
336
 
        self._prev_cursor_path = None
337
324
        self.treeview.connect("cursor-changed",
338
325
                self._on_selection_changed)
339
326
 
405
392
        self.treeview.append_column(self.date_column)
406
393
        
407
394
        return self.treeview
408
 
    
 
395
 
409
396
    def _on_selection_changed(self, treeview):
410
397
        """callback for when the treeview changes."""
411
398
        (path, focus) = treeview.get_cursor()
412
 
        if (path is not None) and (path != self._prev_cursor_path):
413
 
            self._prev_cursor_path = path # avoid emitting twice per click
 
399
        if path is not None:
414
400
            self.iter = self.model.get_iter(path)
415
401
            self.emit('revision-selected')
416
402
 
417
403
    def _on_revision_selected(self, widget, event):
418
 
        from bzrlib.plugins.gtk.revisionmenu import RevisionMenu
 
404
        from bzrlib.plugins.gtk.revisionmenu import RevisionPopupMenu
419
405
        if event.button == 3:
420
 
            menu = RevisionMenu(self.branch.repository, 
 
406
            menu = RevisionPopupMenu(self.branch.repository, 
421
407
                [self.get_revision().revision_id],
422
408
                self.branch)
423
409
            menu.connect('tag-added', lambda w, t, r: self.add_tag(t, r))