gc now have draw_contact, draw_roster and draw_all_roster functions and they are used to update style, iconset ...
This commit is contained in:
		
							parent
							
								
									99d944dc90
								
							
						
					
					
						commit
						f3eef962c6
					
				
					 4 changed files with 109 additions and 84 deletions
				
			
		|  | @ -486,6 +486,13 @@ class PreferencesWindow: | ||||||
| 	def on_show_status_msgs_in_roster_checkbutton_toggled(self, widget): | 	def on_show_status_msgs_in_roster_checkbutton_toggled(self, widget): | ||||||
| 		self.on_checkbutton_toggled(widget, 'show_status_msgs_in_roster') | 		self.on_checkbutton_toggled(widget, 'show_status_msgs_in_roster') | ||||||
| 		gajim.interface.roster.draw_roster() | 		gajim.interface.roster.draw_roster() | ||||||
|  | 		for account in gajim.connections: | ||||||
|  | 			gcs = gajim.interface.instances[account]['gc'] | ||||||
|  | 			if gcs.has_key('tabbed'): | ||||||
|  | 				gcs['tabbed'].draw_all_roster() | ||||||
|  | 			else: | ||||||
|  | 				for room_jid in gcs: | ||||||
|  | 					gcs[room_jid].draw_all_roster() | ||||||
| 	 | 	 | ||||||
| 	def on_show_avatars_in_roster_checkbutton_toggled(self, widget): | 	def on_show_avatars_in_roster_checkbutton_toggled(self, widget): | ||||||
| 		self.on_checkbutton_toggled(widget, 'show_avatars_in_roster') | 		self.on_checkbutton_toggled(widget, 'show_avatars_in_roster') | ||||||
|  |  | ||||||
|  | @ -301,7 +301,7 @@ class GroupchatWindow(chat.Chat): | ||||||
| 		if not iter: | 		if not iter: | ||||||
| 			return None | 			return None | ||||||
| 		while not fin: | 		while not fin: | ||||||
| 			role_name = model[iter][C_NICK] | 			role_name = model[iter][C_NICK].decode('utf-8') | ||||||
| 			if role == role_name: | 			if role == role_name: | ||||||
| 				return iter | 				return iter | ||||||
| 			iter = model.iter_next(iter) | 			iter = model.iter_next(iter) | ||||||
|  | @ -350,7 +350,6 @@ class GroupchatWindow(chat.Chat): | ||||||
| 
 | 
 | ||||||
| 	def add_contact_to_roster(self, room_jid, nick, show, role, jid, affiliation, status): | 	def add_contact_to_roster(self, room_jid, nick, show, role, jid, affiliation, status): | ||||||
| 		model = self.list_treeview[room_jid].get_model() | 		model = self.list_treeview[room_jid].get_model() | ||||||
| 		image = gajim.interface.roster.jabber_state_images[show] |  | ||||||
| 		resource = '' | 		resource = '' | ||||||
| 		role_name = helpers.get_uf_role(role, plural = True) | 		role_name = helpers.get_uf_role(role, plural = True) | ||||||
| 
 | 
 | ||||||
|  | @ -363,6 +362,38 @@ class GroupchatWindow(chat.Chat): | ||||||
| 			j = '' | 			j = '' | ||||||
| 
 | 
 | ||||||
| 		name = nick | 		name = nick | ||||||
|  | 
 | ||||||
|  | 		role_iter = self.get_role_iter(room_jid, role) | ||||||
|  | 		if not role_iter: | ||||||
|  | 			role_iter = model.append(None, | ||||||
|  | 				(gajim.interface.roster.jabber_state_images['closed'], 'role', role, | ||||||
|  | 				'<b>%s</b>' % role_name)) | ||||||
|  | 		iter = model.append(role_iter, (None, 'contact', nick, name)) | ||||||
|  | 		if not gajim.gc_contacts[self.account][room_jid].has_key(nick): | ||||||
|  | 			gajim.gc_contacts[self.account][room_jid][nick] = \ | ||||||
|  | 				Contact(jid = j, name = nick, show = show, resource = resource, | ||||||
|  | 				role = role, affiliation = affiliation, status = status) | ||||||
|  | 		self.draw_contact(room_jid, nick) | ||||||
|  | 		if nick == self.nicks[room_jid]: # we became online | ||||||
|  | 			self.got_connected(room_jid) | ||||||
|  | 		self.list_treeview[room_jid].expand_row((model.get_path(role_iter)), | ||||||
|  | 			False) | ||||||
|  | 		return iter | ||||||
|  | 
 | ||||||
|  | 	def draw_contact(self, room_jid, nick, selected=False, focus=False): | ||||||
|  | 		iter = self.get_contact_iter(room_jid, nick) | ||||||
|  | 		if not iter: | ||||||
|  | 			return | ||||||
|  | 		model = self.list_treeview[room_jid].get_model() | ||||||
|  | 		contact = gajim.gc_contacts[self.account][room_jid][nick] | ||||||
|  | 		state_images = gajim.interface.roster.jabber_state_images | ||||||
|  | 		if gajim.awaiting_events[self.account].has_key(room_jid + '/' + nick): | ||||||
|  | 			image = state_images['message'] | ||||||
|  | 		else: | ||||||
|  | 			image = state_images[contact.show] | ||||||
|  | 
 | ||||||
|  | 		name = contact.name | ||||||
|  | 		status = contact.status | ||||||
| 		# add status msg, if not empty, under contact name in the treeview | 		# add status msg, if not empty, under contact name in the treeview | ||||||
| 		if status and gajim.config.get('show_status_msgs_in_roster'): | 		if status and gajim.config.get('show_status_msgs_in_roster'): | ||||||
| 			status = status.strip() | 			status = status.strip() | ||||||
|  | @ -370,26 +401,25 @@ class GroupchatWindow(chat.Chat): | ||||||
| 				status = gtkgui_helpers.reduce_chars_newlines(status, max_lines = 1) | 				status = gtkgui_helpers.reduce_chars_newlines(status, max_lines = 1) | ||||||
| 				colorstring = 'dimgrey' | 				colorstring = 'dimgrey' | ||||||
| 				# escape markup entities and make them small italic and fg color | 				# escape markup entities and make them small italic and fg color | ||||||
| 				#color = gtkgui_helpers._get_fade_color(self.list_treeview[room_jid], | 				color = gtkgui_helpers._get_fade_color(self.list_treeview[room_jid], | ||||||
| 				#	selected) | 					selected, focus) | ||||||
| 				#colorstring = "#%04x%04x%04x" % (color.red, color.green, color.blue) | 				colorstring = "#%04x%04x%04x" % (color.red, color.green, color.blue) | ||||||
| 				name += '\n' '<span size="small" style="italic" foreground="%s">%s</span>'\ | 				name += '\n' '<span size="small" style="italic" foreground="%s">%s</span>'\ | ||||||
| 					% (colorstring, gtkgui_helpers.escape_for_pango_markup(status)) | 					% (colorstring, gtkgui_helpers.escape_for_pango_markup(status)) | ||||||
| 
 | 
 | ||||||
| 		role_iter = self.get_role_iter(room_jid, role) | 		model[iter][C_IMG] = image | ||||||
| 		if not role_iter: | 		model[iter][C_TEXT] = name | ||||||
| 			role_iter = model.append(None, | 
 | ||||||
| 				(gajim.interface.roster.jabber_state_images['closed'], 'role', role, | 	def draw_roster(self, room_jid): | ||||||
| 				'<b>%s</b>' % role_name)) | 		model = self.list_treeview[room_jid].get_model() | ||||||
| 		iter = model.append(role_iter, (image, 'contact', nick, name)) | 		model.clear() | ||||||
| 		gajim.gc_contacts[self.account][room_jid][nick] = \ | 		for nick in gajim.gc_contacts[self.account][room_jid]: | ||||||
| 			Contact(jid = j, name = nick, show = show, resource = resource, | 			contact = gajim.gc_contacts[self.account][room_jid][nick] | ||||||
| 			role = role, affiliation = affiliation, status = status) | 			fjid = contact.jid | ||||||
| 		if nick == self.nicks[room_jid]: # we became online | 			if contact.resource: | ||||||
| 			self.got_connected(room_jid) | 				fjid += '/' + contact.resource | ||||||
| 		self.list_treeview[room_jid].expand_row((model.get_path(role_iter)), | 			self.add_contact_to_roster(room_jid, nick, contact.show, contact.role, | ||||||
| 			False) | 				fjid, contact.affiliation, contact.status) | ||||||
| 		return iter |  | ||||||
| 
 | 
 | ||||||
| 	def get_role(self, room_jid, nick): | 	def get_role(self, room_jid, nick): | ||||||
| 		if gajim.gc_contacts[self.account][room_jid].has_key(nick): | 		if gajim.gc_contacts[self.account][room_jid].has_key(nick): | ||||||
|  | @ -397,30 +427,9 @@ class GroupchatWindow(chat.Chat): | ||||||
| 		else: | 		else: | ||||||
| 			return 'visitor' | 			return 'visitor' | ||||||
| 
 | 
 | ||||||
| 	def update_state_images(self): | 	def draw_all_roster(self): | ||||||
| 		roster = gajim.interface.roster |  | ||||||
| 		for room_jid in self.list_treeview: | 		for room_jid in self.list_treeview: | ||||||
| 			model = self.list_treeview[room_jid].get_model() | 			self.draw_roster(room_jid) | ||||||
| 			role_iter = model.get_iter_root() |  | ||||||
| 			if not role_iter: |  | ||||||
| 				continue |  | ||||||
| 			while role_iter: |  | ||||||
| 				user_iter = model.iter_children(role_iter) |  | ||||||
| 				if not user_iter: |  | ||||||
| 					continue |  | ||||||
| 				while user_iter: |  | ||||||
| 					nick = model[user_iter][C_NICK].decode('utf-8') |  | ||||||
| 					show = gajim.gc_contacts[self.account][room_jid][nick].show |  | ||||||
| 					state_images = roster.get_appropriate_state_images(room_jid) |  | ||||||
| 					# We can't have FT events in gc, so if we have events, it's messages |  | ||||||
| 					if gajim.awaiting_events[self.account].has_key(room_jid + '/'\ |  | ||||||
| 						+ nick): |  | ||||||
| 						image = state_images['message'] |  | ||||||
| 					else: |  | ||||||
| 						image = state_images[show] |  | ||||||
| 					model[user_iter][C_IMG] = image |  | ||||||
| 					user_iter = model.iter_next(user_iter) |  | ||||||
| 				role_iter = model.iter_next(role_iter) |  | ||||||
| 
 | 
 | ||||||
| 	def chg_contact_status(self, room_jid, nick, show, status, role, affiliation, | 	def chg_contact_status(self, room_jid, nick, show, status, role, affiliation, | ||||||
| 		jid, reason, actor, statusCode, new_nick, account): | 		jid, reason, actor, statusCode, new_nick, account): | ||||||
|  | @ -431,7 +440,6 @@ class GroupchatWindow(chat.Chat): | ||||||
| 			role = 'visitor' | 			role = 'visitor' | ||||||
| 		if not affiliation: | 		if not affiliation: | ||||||
| 			affiliation = 'none' | 			affiliation = 'none' | ||||||
| 		model = self.list_treeview[room_jid].get_model() |  | ||||||
| 		if show in ('offline', 'error'): | 		if show in ('offline', 'error'): | ||||||
| 			if statusCode == '307': | 			if statusCode == '307': | ||||||
| 				if actor is None: # do not print 'kicked by None' | 				if actor is None: # do not print 'kicked by None' | ||||||
|  | @ -485,11 +493,7 @@ class GroupchatWindow(chat.Chat): | ||||||
| 					c.show = show | 					c.show = show | ||||||
| 					c.affiliation = affiliation | 					c.affiliation = affiliation | ||||||
| 					c.status = status | 					c.status = status | ||||||
| #					self.draw_contact(room_jid, nick) | 					self.draw_contact(room_jid, nick) | ||||||
| 					roster = gajim.interface.roster |  | ||||||
| 					state_images = roster.get_appropriate_state_images(jid) |  | ||||||
| 					image = state_images[show] |  | ||||||
| 					model[iter][C_IMG] = image |  | ||||||
| 		if (time.time() - self.room_creation[room_jid]) > 30 and \ | 		if (time.time() - self.room_creation[room_jid]) > 30 and \ | ||||||
| 				nick != self.nicks[room_jid] and statusCode != '303': | 				nick != self.nicks[room_jid] and statusCode != '303': | ||||||
| 			if show == 'offline': | 			if show == 'offline': | ||||||
|  | @ -1301,43 +1305,47 @@ current room topic.') % command, room_jid) | ||||||
| 		message_textview.set_sensitive(False) | 		message_textview.set_sensitive(False) | ||||||
| 		self.xmls[room_jid].get_widget('send_button').set_sensitive(False) | 		self.xmls[room_jid].get_widget('send_button').set_sensitive(False) | ||||||
| 		 | 		 | ||||||
| 	def iter_contact_rows(self): | 	def iter_contact_rows(self, room_jid): | ||||||
| 		'''iterate over all contact rows in the tree model''' | 		'''iterate over all contact rows in the tree model''' | ||||||
| 		return # FIXME: impl | 		model = self.list_treeview[room_jid].get_model() | ||||||
| 		model = self.tree.get_model() | 		role_iter = model.get_iter_root() | ||||||
| 		account_iter = model.get_iter_root() | 		while role_iter: | ||||||
| 		while account_iter: | 			contact_iter = model.iter_children(role_iter) | ||||||
| 			group_iter = model.iter_children(account_iter) | 			while contact_iter: | ||||||
| 			while group_iter: | 				yield model[contact_iter] | ||||||
| 				contact_iter = model.iter_children(group_iter) | 				contact_iter = model.iter_next(contact_iter) | ||||||
| 				while contact_iter: | 			role_iter = model.iter_next(role_iter) | ||||||
| 					yield model[contact_iter] |  | ||||||
| 					contact_iter = model.iter_next(contact_iter) |  | ||||||
| 				group_iter = model.iter_next(group_iter) |  | ||||||
| 			account_iter = model.iter_next(account_iter) |  | ||||||
| 
 | 
 | ||||||
| 	def _on_list_treeview_style_set(self, treeview, style): | 	def on_list_treeview_style_set(self, treeview, style): | ||||||
| 		'''When style (theme) changes, redraw all contacts''' | 		'''When style (theme) changes, redraw all contacts''' | ||||||
| 		return # FIXME: impl | 		# Get the room_jid from treeview | ||||||
| 		for contact in self.iter_contact_rows(): | 		for room_jid in self.list_treeview: | ||||||
| 			self.draw_contact(contact[C_JID], contact[C_ACCOUNT]) | 			if self.list_treeview[room_jid] == treeview: | ||||||
|  | 				break | ||||||
|  | 		for contact in self.iter_contact_rows(room_jid): | ||||||
|  | 			nick = contact[C_NICK].decode('utf-8') | ||||||
|  | 			self.draw_contact(room_jid, nick) | ||||||
| 
 | 
 | ||||||
| 	def _on_list_treeview_selection_changed(self, selection): | 	def on_list_treeview_selection_changed(self, selection): | ||||||
| 		return # FIXME: impl |  | ||||||
| 		model, selected_iter = selection.get_selected() | 		model, selected_iter = selection.get_selected() | ||||||
|  | 		# get room_jid from model | ||||||
|  | 		for room_jid in self.list_treeview: | ||||||
|  | 			mod = self.list_treeview[room_jid].get_model() | ||||||
|  | 			if model == mod: | ||||||
|  | 				break | ||||||
| 		if self._last_selected_contact is not None: | 		if self._last_selected_contact is not None: | ||||||
| 			# update unselected row | 			# update unselected row | ||||||
| 			jid, account = self._last_selected_contact | 			room_jid, nick = self._last_selected_contact | ||||||
| 			self.draw_contact(jid, account) | 			self.draw_contact(room_jid, nick) | ||||||
| 		if selected_iter is None: | 		if selected_iter is None: | ||||||
| 			self._last_selected_contact = None | 			self._last_selected_contact = None | ||||||
| 			return | 			return | ||||||
| 		contact = model[selected_iter] | 		contact = model[selected_iter] | ||||||
| 		self._last_selected_contact = (contact[C_JID], contact[C_ACCOUNT]) | 		nick = contact[C_NICK].decode('utf-8') | ||||||
|  | 		self._last_selected_contact = (room_jid, nick) | ||||||
| 		if contact[C_TYPE] != 'contact': | 		if contact[C_TYPE] != 'contact': | ||||||
| 			return | 			return | ||||||
| 		self.draw_contact(contact[C_JID], contact[C_ACCOUNT], selected=True) | 		self.draw_contact(room_jid, nick, selected=True, focus=True) | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| 	def new_room(self, room_jid, nick): | 	def new_room(self, room_jid, nick): | ||||||
| 		self.names[room_jid] = room_jid.split('@')[0] | 		self.names[room_jid] = room_jid.split('@')[0] | ||||||
|  | @ -1355,8 +1363,8 @@ current room topic.') % command, room_jid) | ||||||
| 		list_treeview = self.list_treeview[room_jid] = self.xmls[room_jid].get_widget( | 		list_treeview = self.list_treeview[room_jid] = self.xmls[room_jid].get_widget( | ||||||
| 			'list_treeview') | 			'list_treeview') | ||||||
| 		list_treeview.get_selection().connect('changed', | 		list_treeview.get_selection().connect('changed', | ||||||
| 			self._on_list_treeview_selection_changed) | 			self.on_list_treeview_selection_changed) | ||||||
| 		list_treeview.connect('style-set', self._on_list_treeview_style_set) | 		list_treeview.connect('style-set', self.on_list_treeview_style_set) | ||||||
| 		self._last_selected_contact = None # None or holds jid, account tupple | 		self._last_selected_contact = None # None or holds jid, account tupple | ||||||
| 		 | 		 | ||||||
| 		self.subject_tooltip[room_jid] = gtk.Tooltips() | 		self.subject_tooltip[room_jid] = gtk.Tooltips() | ||||||
|  | @ -1490,7 +1498,6 @@ current room topic.') % command, room_jid) | ||||||
| 			if typ == 'contact': | 			if typ == 'contact': | ||||||
| 				account = self.account | 				account = self.account | ||||||
| 
 | 
 | ||||||
| 				img = model[iter][C_IMG] |  | ||||||
| 				if self.tooltip.timeout == 0 or self.tooltip.id != props[0]: | 				if self.tooltip.timeout == 0 or self.tooltip.id != props[0]: | ||||||
| 					self.tooltip.id = row | 					self.tooltip.id = row | ||||||
| 					nick = model[iter][C_NICK].decode('utf-8') | 					nick = model[iter][C_NICK].decode('utf-8') | ||||||
|  |  | ||||||
|  | @ -583,6 +583,14 @@ class RosterWindow: | ||||||
| 	def change_roster_style(self, option): | 	def change_roster_style(self, option): | ||||||
| 		model = self.tree.get_model() | 		model = self.tree.get_model() | ||||||
| 		model.foreach(self._change_style, option) | 		model.foreach(self._change_style, option) | ||||||
|  | 		# update gc's roster | ||||||
|  | 		for account in gajim.connections: | ||||||
|  | 			gcs = gajim.interface.instances[account]['gc'] | ||||||
|  | 			if gcs.has_key('tabbed'): | ||||||
|  | 				gcs['tabbed'].draw_all_roster() | ||||||
|  | 			else: | ||||||
|  | 				for room_jid in gcs: | ||||||
|  | 					gcs[room_jid].draw_all_roster() | ||||||
| 
 | 
 | ||||||
| 	def draw_roster(self): | 	def draw_roster(self): | ||||||
| 		'''Clear and draw roster''' | 		'''Clear and draw roster''' | ||||||
|  | @ -2142,9 +2150,12 @@ _('If "%s" accepts this request you will know his or her status.') %jid) | ||||||
| 				if jid != 'tabbed': | 				if jid != 'tabbed': | ||||||
| 					gajim.interface.instances[account]['chats'][jid].set_state_image(jid) | 					gajim.interface.instances[account]['chats'][jid].set_state_image(jid) | ||||||
| 			# Update opened groupchat windows | 			# Update opened groupchat windows | ||||||
| 			for jid in gajim.interface.instances[account]['gc']: | 			gcs = gajim.interface.instances[account]['gc'] | ||||||
| 				if jid != 'tabbed': | 			if gcs.has_key('tabbed'): | ||||||
| 					gajim.interface.instances[account]['gc'][jid].update_state_images() | 				gcs['tabbed'].draw_all_roster() | ||||||
|  | 			else: | ||||||
|  | 				for room_jid in gcs: | ||||||
|  | 					gcs[room_jid].draw_all_roster() | ||||||
| 		self.update_status_combobox() | 		self.update_status_combobox() | ||||||
| 
 | 
 | ||||||
| 	def repaint_themed_widgets(self): | 	def repaint_themed_widgets(self): | ||||||
|  |  | ||||||
|  | @ -838,7 +838,7 @@ class TabbedChatWindow(chat.Chat): | ||||||
| 		room_jid = jid.split('/', 1)[0] | 		room_jid = jid.split('/', 1)[0] | ||||||
| 		gcs = gajim.interface.instances[self.account]['gc'] | 		gcs = gajim.interface.instances[self.account]['gc'] | ||||||
| 		if gcs.has_key(room_jid): | 		if gcs.has_key(room_jid): | ||||||
| 			gcs[room_jid].update_state_images() | 			gcs[room_jid].draw_all_roster() | ||||||
| 			typ = 'pm' | 			typ = 'pm' | ||||||
| 
 | 
 | ||||||
| 		gajim.interface.roster.draw_contact(jid, self.account) | 		gajim.interface.roster.draw_contact(jid, self.account) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue