/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 olive/menu.py

  • Committer: Alexander Belchenko
  • Date: 2006-10-26 13:16:07 UTC
  • mto: (91.1.8 trunk) (66.2.10 trunk)
  • mto: This revision was merged to the branch mainline in revision 107.
  • Revision ID: bialix@ukr.net-20061026131607-fa48887c5a4869a5
olive-gtk: use olive ui factory

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2006 by Szilveszter Farkas (Phanatic) <szilveszter.farkas@gmail.com>
 
2
#
 
3
# This program is free software; you can redistribute it and/or modify
 
4
# it under the terms of the GNU General Public License as published by
 
5
# the Free Software Foundation; either version 2 of the License, or
 
6
# (at your option) any later version.
 
7
#
 
8
# This program is distributed in the hope that it will be useful,
 
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
11
# GNU General Public License for more details.
 
12
#
 
13
# You should have received a copy of the GNU General Public License
 
14
# along with this program; if not, write to the Free Software
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
16
 
 
17
import os.path
 
18
import sys
 
19
 
 
20
try:
 
21
    import pygtk
 
22
    pygtk.require("2.0")
 
23
except:
 
24
    pass
 
25
 
 
26
import gtk
 
27
 
 
28
import bzrlib.errors as errors
 
29
from bzrlib.workingtree import WorkingTree
 
30
 
 
31
from dialog import error_dialog, info_dialog, warning_dialog
 
32
from launch import launch
 
33
from olive import OlivePreferences, DiffWindow
 
34
 
 
35
class OliveMenu:
 
36
    """ This class is responsible for building the context menus. """
 
37
    def __init__(self, path, selected):
 
38
        # Load the UI file
 
39
        from guifiles import UIFILENAME
 
40
 
 
41
        self.uifile = UIFILENAME
 
42
 
 
43
        # Preferences handler
 
44
        self.pref = OlivePreferences()
 
45
        
 
46
        # Set default values
 
47
        self.path = path
 
48
        self.selected = selected
 
49
        
 
50
        # Create the file list context menu
 
51
        self.ui = gtk.UIManager()
 
52
        
 
53
        self.actiongroup = gtk.ActionGroup('context')
 
54
        self.actiongroup.add_actions([('add', gtk.STOCK_ADD,
 
55
                                       _('Add'), None,
 
56
                                       _('Add the selected file'),
 
57
                                       self.add_file),
 
58
                                      ('remove', gtk.STOCK_REMOVE,
 
59
                                       _('Remove'), None,
 
60
                                       _('Remove the selected file'),
 
61
                                       self.remove_file),
 
62
                                      ('open', gtk.STOCK_OPEN,
 
63
                                       _('Open'), None,
 
64
                                       _('Open the selected file'),
 
65
                                       self.open_file),
 
66
                                      ('commit', None,
 
67
                                       _('Commit'), None,
 
68
                                       _('Commit the changes'),
 
69
                                       self.commit),
 
70
                                      ('diff', None,
 
71
                                       _('Diff'), None,
 
72
                                       _('Show the diff of the file'),
 
73
                                       self.diff),
 
74
                                      ('bookmark', None,
 
75
                                       _('Bookmark'), None,
 
76
                                       _('Bookmark current location'),
 
77
                                       self.bookmark),
 
78
                                      ('edit_bookmark', gtk.STOCK_EDIT,
 
79
                                       _('Edit'), None,
 
80
                                       _('Edit the selected bookmark'),
 
81
                                       self.edit_bookmark),
 
82
                                      ('remove_bookmark', gtk.STOCK_REMOVE,
 
83
                                       _('Remove'), None,
 
84
                                       _('Remove the selected bookmark'),
 
85
                                       self.remove_bookmark),
 
86
                                      ('open_folder', gtk.STOCK_OPEN,
 
87
                                       _('Open Folder'), None,
 
88
                                       _('Open bookmark folder in Nautilus'),
 
89
                                       self.open_folder),
 
90
                                      ('diff_selected', None,
 
91
                                       _('Selected...'), None,
 
92
                                       _('Show the differences of the selected file'),
 
93
                                       self.diff_selected),
 
94
                                      ('diff_all', None,
 
95
                                       _('All...'), None,
 
96
                                       _('Show the differences of all files'),
 
97
                                       self.diff_all)
 
98
                                     ])
 
99
        
 
100
        self.ui.insert_action_group(self.actiongroup, 0)
 
101
        self.ui.add_ui_from_file(self.uifile)
 
102
        
 
103
        self.cmenu_right = self.ui.get_widget('/context_right')
 
104
        self.cmenu_left = self.ui.get_widget('/context_left')
 
105
        self.toolbar_diff = self.ui.get_widget('/toolbar_diff')
 
106
        
 
107
        # Set icons
 
108
        # TODO: do it without using deprecated comm
 
109
        #commit_menu = self.ui.get_widget('/context_right/commit')
 
110
        #commit_image = self.comm.menuitem_branch_commit.get_image()
 
111
        #commit_pixbuf = commit_image.get_pixbuf()
 
112
        #commit_icon = gtk.Image()
 
113
        #commit_icon.set_from_pixbuf(commit_pixbuf)
 
114
        #commit_menu.set_image(commit_icon)
 
115
        #diff_menu = self.ui.get_widget('/context_right/diff')
 
116
        #diff_image = self.comm.menuitem_stats_diff.get_image()
 
117
        #diff_pixbuf = diff_image.get_pixbuf()
 
118
        #diff_icon = gtk.Image()
 
119
        #diff_icon.set_from_pixbuf(diff_pixbuf)
 
120
        #diff_menu.set_image(diff_icon)
 
121
 
 
122
    def right_context_menu(self):
 
123
        return self.cmenu_right
 
124
    
 
125
    def left_context_menu(self):
 
126
        return self.cmenu_left
 
127
    
 
128
    def add_file(self, action):
 
129
        """ Right context menu -> Add """
 
130
        import bzrlib.add
 
131
        
 
132
        # Add only the selected file
 
133
        directory = self.path
 
134
        filename = self.selected
 
135
            
 
136
        if filename is None:
 
137
            error_dialog(_('No file was selected'),
 
138
                         _('Please select a file from the list,\nor choose the other option.'))
 
139
            return
 
140
        
 
141
        try:
 
142
            bzrlib.add.smart_add([os.path.join(directory, filename)])
 
143
        except errors.NotBranchError:
 
144
            error_dialog(_('Directory is not a branch'),
 
145
                         _('You can perform this action only in a branch.'))
 
146
            return
 
147
    
 
148
    def remove_file(self, action):
 
149
        """ Right context menu -> Remove """
 
150
        # Remove only the selected file
 
151
        directory = self.path
 
152
        filename = self.selected
 
153
        
 
154
        if filename is None:
 
155
            error_dialog(_('No file was selected'),
 
156
                         _('Please select a file from the list,\nor choose the other option.'))
 
157
            return
 
158
        
 
159
        try:
 
160
            wt, path = WorkingTree.open_containing(directory + os.sep + filename)
 
161
            wt.remove(path)
 
162
 
 
163
        except errors.NotBranchError:
 
164
            error_dialog(_('Directory is not a branch'),
 
165
                         _('You can perform this action only in a branch.'))
 
166
            return
 
167
        except errors.NotVersionedError:
 
168
            error_dialog(_('File not versioned'),
 
169
                         _('The selected file is not versioned.'))
 
170
            return
 
171
 
 
172
    def open_file(self, action):
 
173
        """ Right context menu -> Open """
 
174
        # Open only the selected file
 
175
        filename = self.selected
 
176
        
 
177
        if filename is None:
 
178
            error_dialog(_('No file was selected'),
 
179
                         _('Please select a file from the list,\nor choose the other option.'))
 
180
            return
 
181
 
 
182
        if filename == '..':
 
183
            # TODO: how to enter a directory?
 
184
            return
 
185
        else:
 
186
            fullpath = self.path + os.sep + filename
 
187
            if os.path.isdir(fullpath):
 
188
                # selected item is an existant directory
 
189
                # TODO: how to enter a directory?
 
190
                return
 
191
            else:
 
192
                launch(fullpath) 
 
193
 
 
194
    def commit(self, action):
 
195
        """ Right context menu -> Commit """
 
196
        from commit import CommitDialog
 
197
        wt, path = WorkingTree.open_containing(self.path)
 
198
        commit = CommitDialog(wt, path)
 
199
        commit.display()
 
200
    
 
201
    def diff(self, action):
 
202
        """ Right context menu -> Diff """
 
203
        try:
 
204
            wt = WorkingTree.open_containing(self.path)[0]
 
205
        except errors.NotBranchError:
 
206
            error_dialog(_('File is not in a branch'),
 
207
                         _('The selected file is not in a branch.'))
 
208
            return
 
209
        
 
210
        window = DiffWindow()
 
211
        parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
 
212
        window.set_diff(wt.branch.nick, wt, parent_tree)
 
213
        window.show()
 
214
    
 
215
    def bookmark(self, action):
 
216
        """ Right context menu -> Bookmark """
 
217
        if self.pref.add_bookmark(self.path):
 
218
            info_dialog(_('Bookmark successfully added'),
 
219
                        _('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
 
220
            self.pref.write()
 
221
        else:
 
222
            warning_dialog(_('Location already bookmarked'),
 
223
                           _('The current directory is already bookmarked.\nSee the left panel for reference.'))
 
224
 
 
225
    def edit_bookmark(self, action):
 
226
        """ Left context menu -> Edit """
 
227
        from bookmark import OliveBookmark
 
228
 
 
229
        if self.selected != None:
 
230
            bookmark = OliveBookmark(self.selected)
 
231
            bookmark.display()
 
232
 
 
233
    def remove_bookmark(self, action):
 
234
        """ Left context menu -> Remove """
 
235
        
 
236
        if self.selected != None:
 
237
            self.pref.remove_bookmark(self.comm.get_selected_left())
 
238
            self.comm.refresh_left()
 
239
    
 
240
    def open_folder(self, action):
 
241
        """ Left context menu -> Open Folder """
 
242
        path = self.selected
 
243
 
 
244
        if path != None:
 
245
            launch(path)
 
246
    
 
247
    def diff_selected(self, action):
 
248
        """ Diff toolbutton -> Selected... """
 
249
        print "DEBUG: not implemented."
 
250
    
 
251
    def diff_all(self, action):
 
252
        """ Diff toolbutton -> All... """
 
253
        from diff import OliveDiff
 
254
        diff = OliveDiff(self.comm)
 
255
        diff.display()