/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/rename.py

  • Committer: Jasper Groenewegen
  • Date: 2008-07-27 12:01:40 UTC
  • mfrom: (576.3.2 improve-merge)
  • mto: This revision was merged to the branch mainline in revision 579.
  • Revision ID: colbrac@xs4all.nl-20080727120140-1agdlzkc9fumjk5f
Merge merge dialog improvements

Show diffs side-by-side

added added

removed removed

Lines of Context:
23
23
    pass
24
24
 
25
25
import gtk
26
 
import gtk.glade
27
26
 
28
27
import bzrlib.errors as errors
29
28
from bzrlib.workingtree import WorkingTree
30
29
 
31
 
from errors import show_bzr_error
 
30
from bzrlib.plugins.gtk import _i18n
32
31
from bzrlib.plugins.gtk.dialog import error_dialog
33
 
from guifiles import GLADEFILENAME
34
 
 
35
 
 
36
 
class OliveRename:
 
32
from bzrlib.plugins.gtk.errors import show_bzr_error
 
33
 
 
34
 
 
35
class RenameDialog(gtk.Dialog):
37
36
    """ Display the Rename dialog and perform the needed actions. """
38
 
    def __init__(self, wt, wtpath, selected=[]):
39
 
        """ Initialize the Rename dialog. """
40
 
        self.glade = gtk.glade.XML(GLADEFILENAME, 'window_rename')
41
 
        
42
 
        self.window = self.glade.get_widget('window_rename')
43
 
        self.entry = self.glade.get_widget('entry_rename')
44
 
        
45
 
        # Dictionary for signal_autoconnect
46
 
        dic = { "on_button_rename_rename_clicked": self.rename,
47
 
                "on_button_rename_cancel_clicked": self.close }
48
 
        
49
 
        # Connect the signals to the handlers
50
 
        self.glade.signal_autoconnect(dic)
51
 
        
 
37
    
 
38
    def __init__(self, wt, wtpath, selected=None, parent=None):
 
39
        """ Initialize the Rename file dialog. """
 
40
        gtk.Dialog.__init__(self, title="Olive - Rename files",
 
41
                                  parent=parent,
 
42
                                  flags=0,
 
43
                                  buttons=(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL))
 
44
        
 
45
        # Get arguments
52
46
        self.wt = wt
53
47
        self.wtpath = wtpath
54
48
        self.selected = selected
55
49
        
56
 
    def display(self):
57
 
        """ Display the Rename dialog. """
 
50
        # Create widgets
 
51
        self._hbox = gtk.HBox()
 
52
        self._label_rename_to = gtk.Label(_i18n("Rename to"))
 
53
        self._entry = gtk.Entry()
 
54
        self._button_rename = gtk.Button(_i18n("_Rename"))
 
55
        self._button_rename_icon = gtk.Image()
 
56
        self._button_rename_icon.set_from_stock(gtk.STOCK_APPLY, gtk.ICON_SIZE_BUTTON)
 
57
        self._button_rename.set_image(self._button_rename_icon)
 
58
        
 
59
        self._entry.connect('activate', self._on_rename_clicked)
 
60
        self._button_rename.connect('clicked', self._on_rename_clicked)
 
61
        
 
62
        # Set text
58
63
        if self.selected is not None:
59
 
            self.entry.set_text(self.selected)
60
 
        
61
 
        self.window.show_all()
62
 
 
 
64
            self._entry.set_text(self.selected)
 
65
        
 
66
        # Add widgets to dialog
 
67
        self.vbox.add(self._hbox)
 
68
        self._hbox.add(self._label_rename_to)
 
69
        self._hbox.add(self._entry)
 
70
        self._hbox.set_spacing(5)
 
71
        self.action_area.pack_end(self._button_rename)
 
72
        
 
73
        self.vbox.show_all()
 
74
        
63
75
    @show_bzr_error
64
 
    def rename(self, widget):
 
76
    def _on_rename_clicked(self, widget):
65
77
        # Get entry
66
78
        old_filename = self.selected
67
 
        new_filename = self.entry.get_text()
 
79
        new_filename = self._entry.get_text()
68
80
            
69
81
        if old_filename is None:
70
 
            error_dialog(_('No file was selected'),
71
 
                         _('Please select a file from the list to proceed.'))
 
82
            error_dialog(_i18n('No file was selected'),
 
83
                         _i18n('Please select a file from the list to proceed.'))
72
84
            return
73
85
        
74
86
        if new_filename == "":
75
 
            error_dialog(_('Filename not given'),
76
 
                         _('Please specify a new name for the file.'))
 
87
            error_dialog(_i18n('Filename not given'),
 
88
                         _i18n('Please specify a new name for the file.'))
77
89
            return
78
90
        
79
91
        source = os.path.join(self.wtpath, old_filename)
84
96
        wt2, path2 = WorkingTree.open_containing(self.wt.abspath(source))
85
97
 
86
98
        if wt1.basedir != wt2.basedir:
87
 
            error_dialog(_('Not the same branch'),
88
 
                         _('The destination is not in the same branch.'))
 
99
            error_dialog(_i18n('Not the same branch'),
 
100
                         _i18n('The destination is not in the same branch.'))
89
101
            return
90
102
        wt1.rename_one(source, destination)
91
 
        self.close()
92
 
    
93
 
    def close(self, widget=None):
94
 
        self.window.destroy()
 
103
        
 
104
        self.response(gtk.RESPONSE_OK)