improve manage bookmark behaviour when copy/pasting room JID. Fixes room jid checking. Fixes #7547

This commit is contained in:
Yann Leboulanger 2013-11-06 22:00:21 +01:00
parent 52a70f34fe
commit f90565c202
1 changed files with 12 additions and 9 deletions

View File

@ -3427,7 +3427,7 @@ class ManageBookmarksWindow:
nick = helpers.parse_resource(nick) nick = helpers.parse_resource(nick)
except helpers.InvalidFormat: except helpers.InvalidFormat:
dialogs.ErrorDialog(_('Invalid nickname'), dialogs.ErrorDialog(_('Invalid nickname'),
_('Character not allowed')) _('Character not allowed'), transient_for=self.window)
self.nick_entry.set_text(model[iter_][6]) self.nick_entry.set_text(model[iter_][6])
return True return True
model[iter_][6] = nick model[iter_][6] = nick
@ -3438,16 +3438,17 @@ class ManageBookmarksWindow:
return return
server = widget.get_text() server = widget.get_text()
if '@' in server: if '@' in server:
dialogs.ErrorDialog(_('Invalid server'), _('Character not allowed')) dialogs.ErrorDialog(_('Invalid server'),
_('Character not allowed'), transient_for=self.window)
widget.set_text(server.replace('@', '')) widget.set_text(server.replace('@', ''))
room_jid = self.room_entry.get_text().strip() + '@' + \ room_jid = self.room_entry.get_text().strip() + '@' + \
server.strip() server.strip()
try: try:
room_jid = helpers.parse_resource(room_jid) room_jid = helpers.parse_jid(room_jid)
except helpers.InvalidFormat as e: except helpers.InvalidFormat as e:
dialogs.ErrorDialog(_('Invalid server'), dialogs.ErrorDialog(_('Invalid server'),
_('Character not allowed')) _('Character not allowed'), transient_for=self.window)
self.server_entry.set_text(model[iter_][2].split('@')[1]) self.server_entry.set_text(model[iter_][2].split('@')[1])
return True return True
model[iter_][2] = room_jid model[iter_][2] = room_jid
@ -3458,16 +3459,18 @@ class ManageBookmarksWindow:
return return
room = widget.get_text() room = widget.get_text()
if '@' in room: if '@' in room:
dialogs.ErrorDialog(_('Invalid server'), _('Character not allowed')) room, server = room.split('@', 1)
widget.set_text(room.replace('@', '')) widget.set_text(room)
if server:
self.server_entry.set_text(server)
self.server_entry.grab_focus()
room_jid = room.strip() + '@' + \ room_jid = room.strip() + '@' + \
self.server_entry.get_text().strip() self.server_entry.get_text().strip()
try: try:
room_jid = helpers.parse_resource(room_jid) room_jid = helpers.parse_jid(room_jid)
except helpers.InvalidFormat: except helpers.InvalidFormat:
dialogs.ErrorDialog(_('Invalid room'), dialogs.ErrorDialog(_('Invalid room'),
_('Character not allowed')) _('Character not allowed'), transient_for=self.window)
self.room_entry.set_text(model[iter_][2].split('@')[0])
return True return True
model[iter_][2] = room_jid model[iter_][2] = room_jid