improve manage bookmark behaviour when copy/pasting room JID. Fixes room jid checking. Fixes #7547
This commit is contained in:
parent
52a70f34fe
commit
f90565c202
|
@ -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
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue