bugfix in subscription request window, also use self.window than widget.get_toplevel() to be faster and cleaner. Pref window catches Escape
This commit is contained in:
		
							parent
							
								
									317f0e0db3
								
							
						
					
					
						commit
						3db4808088
					
				
					 4 changed files with 640 additions and 23 deletions
				
			
		|  | @ -47,6 +47,10 @@ class Preferences_window: | |||
| 	def on_preferences_window_show(self, widget): | ||||
| 		self.notebook.set_current_page(0) | ||||
| 
 | ||||
| 	def on_preferences_window_key_press_event(self, widget, event): | ||||
| 		if event.keyval == gtk.keysyms.Escape: # ESCAPE | ||||
| 			self.window.hide() | ||||
| 
 | ||||
| 	def on_checkbutton_toggled(self, widget, config_name, \ | ||||
| 		change_sensitivity_widgets = None): | ||||
| 		if widget.get_active(): | ||||
|  | @ -857,7 +861,7 @@ class Account_modification_window: | |||
| 	 | ||||
| 	def on_close_button_clicked(self, widget): | ||||
| 		"""When Close button is clicked""" | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 
 | ||||
| 	def on_checkbutton_toggled(self, widget, widgets): | ||||
| 		"""set or unset sensitivity of widgets when widget is toggled""" | ||||
|  | @ -1045,7 +1049,7 @@ class Account_modification_window: | |||
| 				self.plugin.windows['accounts'].init_accounts() | ||||
| 			#refresh roster | ||||
| 			self.plugin.roster.draw_roster() | ||||
| 			widget.get_toplevel().destroy() | ||||
| 			self.window.destroy() | ||||
| 			return | ||||
| 		#if it's a new account | ||||
| 		if name in self.plugin.accounts.keys(): | ||||
|  | @ -1082,7 +1086,7 @@ class Account_modification_window: | |||
| 			self.plugin.windows['accounts'].init_accounts() | ||||
| 		#refresh roster | ||||
| 		self.plugin.roster.draw_roster() | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 
 | ||||
| 	def on_change_password_button_clicked(self, widget): | ||||
| 		dialog = Change_password_dialog(self.plugin, self.account) | ||||
|  | @ -1230,7 +1234,7 @@ class Accounts_window: | |||
| 		del self.plugin.windows['accounts']  | ||||
| 
 | ||||
| 	def on_close_button_clicked(self, widget): | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 
 | ||||
| 	def init_accounts(self): | ||||
| 		"""initialize listStore with existing accounts""" | ||||
|  | @ -1325,7 +1329,7 @@ class Service_registration_window: | |||
| 	Window that appears when we want to subscribe to a service""" | ||||
| 	def on_cancel_button_clicked(self, widget): | ||||
| 		"""When Cancel button is clicked""" | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 		 | ||||
| 	def draw_table(self): | ||||
| 		"""Draw the table in the window""" | ||||
|  | @ -1355,7 +1359,7 @@ class Service_registration_window: | |||
| 		self.plugin.roster.contacts[self.account][self.service] = [user1] | ||||
| 		self.plugin.roster.add_user_to_roster(self.service, self.account) | ||||
| 		self.plugin.send('REG_AGENT', self.account, self.service) | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 	 | ||||
| 	def __init__(self, service, infos, plugin, account): | ||||
| 		self.xml = gtk.glade.XML(GTKGUI_GLADE, 'service_registration_window', APP) | ||||
|  | @ -1563,7 +1567,7 @@ class Service_discovery_window: | |||
| 
 | ||||
| 	def on_close_button_clicked(self, widget): | ||||
| 		"""When Close button is clicked""" | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 		 | ||||
| 	def browse(self, jid): | ||||
| 		"""Send a request to the core to know the available services""" | ||||
|  | @ -1733,7 +1737,7 @@ class Service_discovery_window: | |||
| 			return | ||||
| 		service = model.get_value(iter, 1) | ||||
| 		self.plugin.send('REG_AGENT_INFO', self.account, service) | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 	 | ||||
| 	def on_services_treeview_cursor_changed(self, widget): | ||||
| 		"""When we select a row : | ||||
|  |  | |||
|  | @ -39,12 +39,12 @@ class vcard_information_window: | |||
| 
 | ||||
| 	def on_vcard_information_window_key_press_event(self, widget, event): | ||||
| 		if event.keyval == gtk.keysyms.Escape: # ESCAPE | ||||
| 			widget.destroy() | ||||
| 			self.window.destroy() | ||||
| 
 | ||||
| 	def on_close_button_clicked(self, widget): | ||||
| 		"""Save user's informations and update the roster on the Jabber server""" | ||||
| 		if self.vcard: | ||||
| 			widget.get_toplevel().destroy() | ||||
| 			self.window.destroy() | ||||
| 			return | ||||
| 		#update user.name if it's not "" | ||||
| 		name_entry = self.xml.get_widget('nickname_entry') | ||||
|  | @ -73,7 +73,7 @@ class vcard_information_window: | |||
| 			self.plugin.accounts[self.account] = account_info | ||||
| 			self.plugin.send('CONFIG', None, ('accounts', self.plugin.accounts, \ | ||||
| 				'Gtkgui')) | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 
 | ||||
| 	def set_value(self, entry_name, value): | ||||
| 		try: | ||||
|  | @ -490,7 +490,7 @@ class Add_new_contact_window: | |||
| 
 | ||||
| 	def on_cancel_button_clicked(self, widget): | ||||
| 		"""When Cancel button is clicked""" | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 
 | ||||
| 	def on_subscribe_button_clicked(self, widget): | ||||
| 		"""When Subscribe button is clicked""" | ||||
|  | @ -510,7 +510,7 @@ class Add_new_contact_window: | |||
| 			nickname) | ||||
| 		if self.xml.get_widget('auto_authorize_checkbutton').get_active(): | ||||
| 			self.plugin.send('AUTH', self.account, jid) | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 		 | ||||
| 	def fill_jid(self): | ||||
| 		protocol_combobox = self.xml.get_widget('protocol_combobox') | ||||
|  | @ -633,6 +633,7 @@ class Error_dialog: | |||
| class subscription_request_window: | ||||
| 	def __init__(self, plugin, jid, text, account): | ||||
| 		xml = gtk.glade.XML(GTKGUI_GLADE, 'subscription_request_window', APP) | ||||
| 		self.window = xml.get_widget('subscription_request_window') | ||||
| 		self.plugin = plugin | ||||
| 		self.jid = jid | ||||
| 		self.account = account | ||||
|  | @ -646,19 +647,19 @@ class subscription_request_window: | |||
| 	window that appears when a user wants to add us to his/her roster""" | ||||
| 	def on_close_button_clicked(self, widget): | ||||
| 		"""When Close button is clicked""" | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 		 | ||||
| 	def on_authorize_button_clicked(self, widget): | ||||
| 		"""Accept the request""" | ||||
| 		self.plugin.send('AUTH', self.account, self.jid) | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 		if not self.plugin.roster.contacts[self.account].has_key(self.jid): | ||||
| 			Add_new_contact_window(self.plugin, self.account, self.jid) | ||||
| 	 | ||||
| 	def on_deny_button_clicked(self, widget): | ||||
| 		"""refuse the request""" | ||||
| 		self.plugin.send('DENY', self.account, self.jid) | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 
 | ||||
| class Join_groupchat_window: | ||||
| 	def __init__(self, plugin, account, server='', room = ''): | ||||
|  | @ -705,7 +706,7 @@ class Join_groupchat_window: | |||
| 
 | ||||
| 	def on_cancel_button_clicked(self, widget): | ||||
| 		"""When Cancel button is clicked""" | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 
 | ||||
| 	def on_join_button_clicked(self, widget): | ||||
| 		"""When Join button is clicked""" | ||||
|  | @ -725,7 +726,7 @@ class Join_groupchat_window: | |||
| 		self.plugin.send('GC_JOIN', self.account, (nickname, room, server, \ | ||||
| 			password)) | ||||
| 			 | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 
 | ||||
| class New_message_dialog: | ||||
| 	def __init__(self, plugin, account): | ||||
|  | @ -755,7 +756,7 @@ class New_message_dialog: | |||
| 
 | ||||
| 	def on_cancel_button_clicked(self, widget): | ||||
| 		"""When Cancel button is clicked""" | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 
 | ||||
| 	def on_chat_button_clicked(self, widget): | ||||
| 		"""When Chat button is clicked""" | ||||
|  | @ -779,7 +780,7 @@ class New_message_dialog: | |||
| 		self.plugin.windows[self.account]['chats'][jid].window.present() | ||||
| 		#FIXME: PROBLEM WITH FOCUS | ||||
| 		 | ||||
| 		widget.get_toplevel().destroy() | ||||
| 		self.window.destroy() | ||||
| 
 | ||||
| class Change_password_dialog: | ||||
| 	def __init__(self, plugin, account): | ||||
|  | @ -850,6 +851,9 @@ class Popup_window: | |||
| 		 | ||||
| 		xml.signal_autoconnect(self) | ||||
| 		close_button.connect('clicked', self.on_close_button_clicked, window_height) | ||||
| 		 | ||||
| 		#FIXME: don't steal focus. not sure how to do ti | ||||
| 		# set_focus_on_map(False) [pygtk26 only doesn't solve it!] | ||||
| 		self.window.show_all() | ||||
| 
 | ||||
| 		gobject.timeout_add(5000, self.on_timeout, window_height) | ||||
|  |  | |||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -401,6 +401,13 @@ class plugin: | |||
| 				if not self.windows[account]['chats'].has_key(jid) and \ | ||||
| 					not self.queues[account].has_key(jid) and \ | ||||
| 											not self.config['autopopup']: | ||||
| 					#DOES NOT ALWAYS WORK WHY? | ||||
| 					#I control nkour@lagaule in jabber | ||||
| 					# have nkour@lagaul in nkour@jabber.org | ||||
| 					#go online from psi in lagaule | ||||
| 					#gajim doesn't give a shit | ||||
| 					# WHY? same with offline | ||||
| 					# new message works | ||||
| 					instance = Popup_window(self, 'Contact Online', jid ) | ||||
| 					self.roster.popup_windows.append(instance) | ||||
| 			elif old_show > 1 and statuss.index(user1.show) < 2 and \ | ||||
|  | @ -927,7 +934,7 @@ class plugin: | |||
| 												#2:autoaway and use sleeper | ||||
| 												#3:autoxa and use sleeper | ||||
| 			self.send('ASK_ROSTER', a, self.queueIN) | ||||
| 		#in pygtk2.4 FIXME: (nk) WHAT DO YOU MEAN? | ||||
| 
 | ||||
| 		iconset = self.config['iconset'] | ||||
| 		if not iconset: | ||||
| 			iconset = 'sun' | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue