we can now see and modify reason in ban list
This commit is contained in:
		
							parent
							
								
									da1226df62
								
							
						
					
					
						commit
						3e68f5c86d
					
				
					 2 changed files with 38 additions and 7 deletions
				
			
		|  | @ -1345,12 +1345,20 @@ class Connection: | |||
| 	def _MucAdminCB(self, con, iq_obj): | ||||
| 		gajim.log.debug('MucAdminCB') | ||||
| 		items = iq_obj.getTag('query', namespace = common.xmpp.NS_MUC_ADMIN).getTags('item') | ||||
| 		list = [] | ||||
| 		list = {} | ||||
| 		affiliation = '' | ||||
| 		for item in items: | ||||
| 			if item.has_attr('jid') and item.has_attr('affiliation'): | ||||
| 				jid = item.getAttr('jid') | ||||
| 				affiliation = item.getAttr('affiliation') | ||||
| 				list.append(item.getAttr('jid')) | ||||
| 				list[jid] = {'affiliation': affiliation} | ||||
| 				if item.has_attr('nick'): | ||||
| 					list[jid]['nick'] = item.getAttr('nick') | ||||
| 				if item.has_attr('role'): | ||||
| 					list[jid]['role'] = item.getAttr('role') | ||||
| 				reason = item.getTagData('reason') | ||||
| 				if reason: | ||||
| 					list[jid]['reason'] = reason | ||||
| 
 | ||||
| 		self.dispatch('GC_AFFILIATION', (self.get_full_jid(iq_obj), affiliation, list)) | ||||
| 
 | ||||
|  | @ -2385,7 +2393,10 @@ class Connection: | |||
| 			common.xmpp.NS_MUC_ADMIN) | ||||
| 		item = iq.getTag('query') | ||||
| 		for jid in list: | ||||
| 			item.addChild('item', {'jid': jid, 'affiliation': list[jid]}) | ||||
| 			item_tag = item.addChild('item', {'jid': jid, | ||||
| 				'affiliation': list[jid]['affiliation']}) | ||||
| 			if list[jid].has_key('reason') and list[jid]['reason']: | ||||
| 				item_tag.setTagData('reason', list[jid]['reason']) | ||||
| 		self.to_be_sent.append(iq) | ||||
| 	 | ||||
| 	def get_affiliation_list(self, room_jid, affiliation): | ||||
|  |  | |||
|  | @ -1881,14 +1881,22 @@ class GroupchatConfigWindow(DataFormWindow): | |||
| 			self.remove_button[affiliation].connect('clicked', self.on_remove_button_clicked, affiliation) | ||||
| 			bb.pack_start(self.remove_button[affiliation]) | ||||
| 
 | ||||
| 			liststore = gtk.ListStore(str) | ||||
| 			liststore = gtk.ListStore(str, str) # Jid, reason | ||||
| 			self.affiliation_treeview[affiliation] = gtk.TreeView(liststore) | ||||
| 			self.affiliation_treeview[affiliation].set_headers_visible(False) | ||||
| 			self.affiliation_treeview[affiliation].connect('cursor-changed', self.on_affiliation_treeview_cursor_changed, affiliation) | ||||
| 			renderer = gtk.CellRendererText() | ||||
| 			col = gtk.TreeViewColumn(_('JID'), renderer) | ||||
| 			col.add_attribute(renderer, 'text', 0) | ||||
| 			self.affiliation_treeview[affiliation].append_column(col) | ||||
| 
 | ||||
| 			if affiliation == 'outcast': | ||||
| 				renderer = gtk.CellRendererText() | ||||
| 				renderer.set_property('editable', True) | ||||
| 				renderer.connect('edited', self.on_cell_edited) | ||||
| 				col = gtk.TreeViewColumn(_('Reason'), renderer) | ||||
| 				col.add_attribute(renderer, 'text', 1) | ||||
| 				self.affiliation_treeview[affiliation].append_column(col) | ||||
| 
 | ||||
| 			sw = gtk.ScrolledWindow() | ||||
| 			sw.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_NEVER) | ||||
| 			sw.add(self.affiliation_treeview[affiliation]) | ||||
|  | @ -1898,6 +1906,12 @@ class GroupchatConfigWindow(DataFormWindow): | |||
| 
 | ||||
| 		add_on_vbox.show_all()  | ||||
| 
 | ||||
| 	def on_cell_edited(self, cell, path, new_text): | ||||
| 		model = self.affiliation_treeview['outcast'].get_model() | ||||
| 		new_text = new_text.decode('utf-8') | ||||
| 		iter = model.get_iter(path) | ||||
| 		model[iter][1] = new_text | ||||
| 
 | ||||
| 	def on_add_button_clicked(self, widget, affiliation): | ||||
| 		if affiliation == 'outcast': | ||||
| 			title = _('Banning...') | ||||
|  | @ -1944,7 +1958,10 @@ class GroupchatConfigWindow(DataFormWindow): | |||
| 		tv = self.affiliation_treeview[affiliation] | ||||
| 		model = tv.get_model() | ||||
| 		for jid in list: | ||||
| 			model.append((jid,)) | ||||
| 			reason = '' | ||||
| 			if list[jid].has_key('reason'): | ||||
| 				reason = list[jid]['reason'] | ||||
| 			model.append((jid,reason)) | ||||
| 
 | ||||
| 	def on_data_form_window_destroy(self, widget): | ||||
| 		del gajim.interface.instances[self.account]['gc_config'][self.room_jid] | ||||
|  | @ -1956,7 +1973,10 @@ class GroupchatConfigWindow(DataFormWindow): | |||
| 			model = self.affiliation_treeview[affiliation].get_model() | ||||
| 			iter = model.get_iter_first() | ||||
| 			while iter: | ||||
| 				list[model[iter][0]] = affiliation | ||||
| 				jid = model[iter][0].decode('utf-8') | ||||
| 				list[jid] = {'affiliation': affiliation} | ||||
| 				if affiliation == 'outcast': | ||||
| 					list[jid]['reason'] = model[iter][1].decode('utf-8') | ||||
| 				iter = model.iter_next(iter) | ||||
| 			for jid in self.removed_jid[affiliation]: | ||||
| 				list[jid] = 'none' | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue