ServiceRegistrationWindow now support Data form
This commit is contained in:
		
							parent
							
								
									d4e11db8c2
								
							
						
					
					
						commit
						61c64536c8
					
				
					 4 changed files with 199 additions and 165 deletions
				
			
		|  | @ -1114,16 +1114,7 @@ class Connection: | ||||||
| 		resource = iq_obj.getFrom().getResource() | 		resource = iq_obj.getFrom().getResource() | ||||||
| 		self.dispatch('OS_INFO', (jid, resource, client_info, os_info)) | 		self.dispatch('OS_INFO', (jid, resource, client_info, os_info)) | ||||||
| 	 | 	 | ||||||
| 	def _MucOwnerCB(self, con, iq_obj): | 	def parse_data_form(self, node): | ||||||
| 		gajim.log.debug('MucOwnerCB') |  | ||||||
| 		qp = iq_obj.getQueryPayload() |  | ||||||
| 		node = None |  | ||||||
| 		for q in qp: |  | ||||||
| 			if q.getNamespace() == common.xmpp.NS_DATA: |  | ||||||
| 				node = q |  | ||||||
| 		if not node: |  | ||||||
| 			return |  | ||||||
| 		# Parse the form |  | ||||||
| 		dic = {} | 		dic = {} | ||||||
| 		tag = node.getTag('title') | 		tag = node.getTag('title') | ||||||
| 		if tag: | 		if tag: | ||||||
|  | @ -1176,6 +1167,18 @@ class Connection: | ||||||
| 						dic[i]['options'][j]['values'].append(tag.getData()) | 						dic[i]['options'][j]['values'].append(tag.getData()) | ||||||
| 					j += 1 | 					j += 1 | ||||||
| 			i += 1 | 			i += 1 | ||||||
|  | 		return dic | ||||||
|  | 		 | ||||||
|  | 	def _MucOwnerCB(self, con, iq_obj): | ||||||
|  | 		gajim.log.debug('MucOwnerCB') | ||||||
|  | 		qp = iq_obj.getQueryPayload() | ||||||
|  | 		node = None | ||||||
|  | 		for q in qp: | ||||||
|  | 			if q.getNamespace() == common.xmpp.NS_DATA: | ||||||
|  | 				node = q | ||||||
|  | 		if not node: | ||||||
|  | 			return | ||||||
|  | 		dic = self.parse_data_form(node) | ||||||
| 		self.dispatch('GC_CONFIG', (unicode(iq_obj.getFrom()), dic)) | 		self.dispatch('GC_CONFIG', (unicode(iq_obj.getFrom()), dic)) | ||||||
| 
 | 
 | ||||||
| 	def _MucErrorCB(self, con, iq_obj): | 	def _MucErrorCB(self, con, iq_obj): | ||||||
|  | @ -1308,7 +1311,7 @@ class Connection: | ||||||
| 	def _event_dispatcher(self, realm, event, data): | 	def _event_dispatcher(self, realm, event, data): | ||||||
| 		if realm == common.xmpp.NS_REGISTER: | 		if realm == common.xmpp.NS_REGISTER: | ||||||
| 			if event == common.xmpp.features.REGISTER_DATA_RECEIVED: | 			if event == common.xmpp.features.REGISTER_DATA_RECEIVED: | ||||||
| 				# data is (agent, DataFrom) | 				# data is (agent, DataFrom, is_form) | ||||||
| 				if self.new_account_info and\ | 				if self.new_account_info and\ | ||||||
| 				self.new_account_info['hostname'] == data[0]: | 				self.new_account_info['hostname'] == data[0]: | ||||||
| 					#it's a new account | 					#it's a new account | ||||||
|  | @ -1330,7 +1333,12 @@ class Connection: | ||||||
| 					self.dispatch('ACC_OK', (self.name, self.new_account_info)) | 					self.dispatch('ACC_OK', (self.name, self.new_account_info)) | ||||||
| 					self.new_account_info = None | 					self.new_account_info = None | ||||||
| 					return | 					return | ||||||
| 				self.dispatch('REGISTER_AGENT_INFO', (data[0], data[1].asDict())) | 				is_form = data[2] | ||||||
|  | 				if is_form: | ||||||
|  | 					conf = self.parse_data_form(data[1]) | ||||||
|  | 				else: | ||||||
|  | 					conf = data[1].asDict() | ||||||
|  | 				self.dispatch('REGISTER_AGENT_INFO', (data[0], conf, is_form)) | ||||||
| 		elif realm == '': | 		elif realm == '': | ||||||
| 			if event == common.xmpp.transports.DATA_RECEIVED: | 			if event == common.xmpp.transports.DATA_RECEIVED: | ||||||
| 				self.dispatch('STANZA_ARRIVED', unicode(data)) | 				self.dispatch('STANZA_ARRIVED', unicode(data)) | ||||||
|  | @ -1759,11 +1767,17 @@ class Connection: | ||||||
| 			return None | 			return None | ||||||
| 		common.xmpp.features.getRegInfo(self.connection, agent, sync = False) | 		common.xmpp.features.getRegInfo(self.connection, agent, sync = False) | ||||||
| 
 | 
 | ||||||
| 	def register_agent(self, agent, info): | 	def register_agent(self, agent, info, is_form = False): | ||||||
| 		if not self.connection: | 		if not self.connection: | ||||||
| 			return | 			return | ||||||
| 		# FIXME: Blocking | 		if is_form: | ||||||
| 		common.xmpp.features.register(self.connection, agent, info) | 			iq = common.xmpp.Iq('set', common.xmpp.NS_REGISTER, to = agent) | ||||||
|  | 			query = iq.getTag('query') | ||||||
|  | 			self.build_data_from_dict(query, info) | ||||||
|  | 			self.to_be_sent.append(iq) | ||||||
|  | 		else: | ||||||
|  | 			# FIXME: Blocking | ||||||
|  | 			common.xmpp.features.register(self.connection, agent, info) | ||||||
| 
 | 
 | ||||||
| 	def new_account(self, name, config, sync = False): | 	def new_account(self, name, config, sync = False): | ||||||
| 		if sync: | 		if sync: | ||||||
|  | @ -1979,11 +1993,7 @@ class Connection: | ||||||
| 			item.addChild(name = 'reason', payload = reason) | 			item.addChild(name = 'reason', payload = reason) | ||||||
| 		self.to_be_sent.append(iq) | 		self.to_be_sent.append(iq) | ||||||
| 
 | 
 | ||||||
| 	def send_gc_config(self, room_jid, config): | 	def build_data_from_dict(self, query, config): | ||||||
| 		iq = common.xmpp.Iq(typ = 'set', to = room_jid, queryNS =\ |  | ||||||
| 			common.xmpp.NS_MUC_OWNER) |  | ||||||
| 		query = iq.getTag('query') |  | ||||||
| 		# FIXME: should really use XData class |  | ||||||
| 		x = query.setTag(common.xmpp.NS_DATA + ' x', attrs = {'type': 'submit'}) | 		x = query.setTag(common.xmpp.NS_DATA + ' x', attrs = {'type': 'submit'}) | ||||||
| 		i = 0 | 		i = 0 | ||||||
| 		while config.has_key(i): | 		while config.has_key(i): | ||||||
|  | @ -2004,6 +2014,12 @@ class Connection: | ||||||
| 						val = '1' | 						val = '1' | ||||||
| 					tag.setTagData('value', val) | 					tag.setTagData('value', val) | ||||||
| 			i += 1 | 			i += 1 | ||||||
|  | 
 | ||||||
|  | 	def send_gc_config(self, room_jid, config): | ||||||
|  | 		iq = common.xmpp.Iq(typ = 'set', to = room_jid, queryNS =\ | ||||||
|  | 			common.xmpp.NS_MUC_OWNER) | ||||||
|  | 		query = iq.getTag('query') | ||||||
|  | 		self.build_data_from_dict(query, config) | ||||||
| 		self.to_be_sent.append(iq) | 		self.to_be_sent.append(iq) | ||||||
| 
 | 
 | ||||||
| 	def gpg_passphrase(self, passphrase): | 	def gpg_passphrase(self, passphrase): | ||||||
|  |  | ||||||
|  | @ -94,14 +94,14 @@ def _ReceivedRegInfo(con, resp, agent): | ||||||
|     if not isResultNode(resp): return |     if not isResultNode(resp): return | ||||||
|     df=resp.getTag('query',namespace=NS_REGISTER).getTag('x',namespace=NS_DATA) |     df=resp.getTag('query',namespace=NS_REGISTER).getTag('x',namespace=NS_DATA) | ||||||
|     if df: |     if df: | ||||||
|         con.Event(NS_REGISTER,REGISTER_DATA_RECEIVED,(agent, DataForm(node=df))) |         con.Event(NS_REGISTER,REGISTER_DATA_RECEIVED,(agent,DataForm(node=df),True)) | ||||||
|         return |         return | ||||||
|     df=DataForm(typ='form') |     df=DataForm(typ='form') | ||||||
|     for i in resp.getQueryPayload(): |     for i in resp.getQueryPayload(): | ||||||
|         if type(i)<>type(iq): pass |         if type(i)<>type(iq): pass | ||||||
|         elif i.getName()=='instructions': df.addInstructions(i.getData()) |         elif i.getName()=='instructions': df.addInstructions(i.getData()) | ||||||
|         else: df.setField(i.getName()).setValue(i.getData()) |         else: df.setField(i.getName()).setValue(i.getData()) | ||||||
|     con.Event(NS_REGISTER,REGISTER_DATA_RECEIVED,(agent, df)) |     con.Event(NS_REGISTER,REGISTER_DATA_RECEIVED,(agent,df,False)) | ||||||
| 
 | 
 | ||||||
| def register(disp,host,info): | def register(disp,host,info): | ||||||
|     """ Perform registration on remote server with provided info. |     """ Perform registration on remote server with provided info. | ||||||
|  |  | ||||||
							
								
								
									
										293
									
								
								src/config.py
									
										
									
									
									
								
							
							
						
						
									
										293
									
								
								src/config.py
									
										
									
									
									
								
							|  | @ -1746,8 +1746,129 @@ class AccountsWindow: | ||||||
| 			self.plugin.windows[account]['account_modification'] = \ | 			self.plugin.windows[account]['account_modification'] = \ | ||||||
| 				AccountModificationWindow(self.plugin, account) | 				AccountModificationWindow(self.plugin, account) | ||||||
| 
 | 
 | ||||||
| #---------- ServiceRegistrationWindow class -------------# | class DataFormWindow: | ||||||
| class ServiceRegistrationWindow: | 	def __init__(self, plugin, account, config): | ||||||
|  | 		self.plugin = plugin | ||||||
|  | 		self.account = account | ||||||
|  | 		self.config = config | ||||||
|  | 		self.xml = gtk.glade.XML(GTKGUI_GLADE, 'data_form_window', APP) | ||||||
|  | 		self.window = self.xml.get_widget('data_form_window') | ||||||
|  | 		self.config_table = self.xml.get_widget('config_table') | ||||||
|  | 		self.fill_table() | ||||||
|  | 		self.xml.signal_autoconnect(self) | ||||||
|  | 		self.window.show_all() | ||||||
|  | 
 | ||||||
|  | 	def on_data_form_window_destroy(self, widget): | ||||||
|  | 		pass | ||||||
|  | 
 | ||||||
|  | 	def on_close_button_clicked(self, widget): | ||||||
|  | 		self.window.destroy() | ||||||
|  | 	 | ||||||
|  | 	def on_checkbutton_toggled(self, widget, index): | ||||||
|  | 		self.config[index]['values'][0] = widget.get_active() | ||||||
|  | 
 | ||||||
|  | 	def on_combobox_changed(self, widget, index): | ||||||
|  | 		self.config[index]['values'][0] = self.config[index]['options'][ \ | ||||||
|  | 			widget.get_active()]['values'][0] | ||||||
|  | 
 | ||||||
|  | 	def on_entry_changed(self, widget, index): | ||||||
|  | 		self.config[index]['values'][0] = widget.get_text().decode('utf-8') | ||||||
|  | 
 | ||||||
|  | 	def on_textbuffer_changed(self, widget, index): | ||||||
|  | 		begin, end = widget.get_bounds() | ||||||
|  | 		self.config[index]['values'][0] = widget.get_text(begin, end) | ||||||
|  | 		 | ||||||
|  | 	def fill_table(self): | ||||||
|  | 		if self.config.has_key('title'): | ||||||
|  | 			self.window.set_title(self.config['title']) | ||||||
|  | 		if self.config.has_key('instructions'): | ||||||
|  | 			self.xml.get_widget('instructions_label').set_text( | ||||||
|  | 				self.config['instructions']) | ||||||
|  | 		i = 0 | ||||||
|  | 		while self.config.has_key(i): | ||||||
|  | 			if not self.config[i].has_key('type'): | ||||||
|  | 				i += 1 | ||||||
|  | 				continue | ||||||
|  | 			ctype = self.config[i]['type'] | ||||||
|  | 			if ctype == 'hidden': | ||||||
|  | 				i += 1 | ||||||
|  | 				continue | ||||||
|  | 			nbrows = self.config_table.get_property('n-rows') | ||||||
|  | 			self.config_table.resize(nbrows + 1, 2) | ||||||
|  | 			if self.config[i].has_key('label'): | ||||||
|  | 				label = gtk.Label(self.config[i]['label']) | ||||||
|  | 				label.set_alignment(0.0, 0.5) | ||||||
|  | 				self.config_table.attach(label, 0, 1, nbrows, nbrows + 1,  | ||||||
|  | 					gtk.FILL	| gtk.SHRINK) | ||||||
|  | 			desc = None | ||||||
|  | 			if self.config[i].has_key('desc'): | ||||||
|  | 				desc = self.config[i]['desc'] | ||||||
|  | 			max = 1 | ||||||
|  | 			if ctype == 'boolean': | ||||||
|  | 				widget = gtk.CheckButton(desc, False) | ||||||
|  | 				widget.set_active(self.config[i]['values'][0]) | ||||||
|  | 				widget.connect('toggled', self.on_checkbutton_toggled, i) | ||||||
|  | 				max = 2 | ||||||
|  | 			elif ctype == 'fixed': | ||||||
|  | 				widget = gtk.Label('\n'.join(self.config[i]['values'])) | ||||||
|  | 				widget.set_alignment(0.0, 0.5) | ||||||
|  | 				max = 4 | ||||||
|  | 			elif ctype == 'jid-multi': | ||||||
|  | 				#TODO | ||||||
|  | 				widget = gtk.Label('') | ||||||
|  | 			elif ctype == 'jid-single': | ||||||
|  | 				#TODO | ||||||
|  | 				widget = gtk.Label('') | ||||||
|  | 			elif ctype == 'list-multi': | ||||||
|  | 				#TODO | ||||||
|  | 				widget = gtk.Label('') | ||||||
|  | 			elif ctype == 'list-single': | ||||||
|  | 				widget = gtk.combo_box_new_text() | ||||||
|  | 				widget.connect('changed', self.on_combobox_changed, i) | ||||||
|  | 				index = 0 | ||||||
|  | 				j = 0 | ||||||
|  | 				while self.config[i]['options'].has_key(j): | ||||||
|  | 					if self.config[i]['options'][j]['values'][0] == \ | ||||||
|  | 						self.config[i]['values'][0]: | ||||||
|  | 						index = j | ||||||
|  | 					widget.append_text(self.config[i]['options'][j]['label']) | ||||||
|  | 					j += 1 | ||||||
|  | 				widget.set_active(index) | ||||||
|  | 				max = 3 | ||||||
|  | 			elif ctype == 'text-multi': | ||||||
|  | 				widget = gtk.TextView() | ||||||
|  | 				widget.get_buffer().connect('changed', self.on_textbuffer_changed, \ | ||||||
|  | 					i) | ||||||
|  | 				widget.get_buffer().set_text('\n'.join(self.config[i]['values'])) | ||||||
|  | 				max = 4 | ||||||
|  | 			elif ctype == 'text-private': | ||||||
|  | 				widget = gtk.Entry() | ||||||
|  | 				widget.connect('changed', self.on_entry_changed, i) | ||||||
|  | 				if not self.config[i].has_key('values'): | ||||||
|  | 					self.config[i]['values'] = [''] | ||||||
|  | 				widget.set_text(self.config[i]['values'][0]) | ||||||
|  | 				widget.set_visibility(False) | ||||||
|  | 				max = 3 | ||||||
|  | 			elif ctype == 'text-single': | ||||||
|  | 				widget = gtk.Entry() | ||||||
|  | 				widget.connect('changed', self.on_entry_changed, i) | ||||||
|  | 				if not self.config[i].has_key('values'): | ||||||
|  | 					self.config[i]['values'] = [''] | ||||||
|  | 				max = 3 | ||||||
|  | 			i += 1 | ||||||
|  | 			if max < 4: | ||||||
|  | 				self.config_table.attach(widget, 1, max, | ||||||
|  | 							nbrows, nbrows + 1, | ||||||
|  | 							gtk.FILL | gtk.SHRINK) | ||||||
|  | 				widget = gtk.Label() | ||||||
|  | 				self.config_table.attach(widget, max, 4, | ||||||
|  | 							nbrows, nbrows + 1) | ||||||
|  | 			else: | ||||||
|  | 				self.config_table.attach(widget, 1, max, | ||||||
|  | 							nbrows, nbrows + 1) | ||||||
|  | 		self.config_table.show_all() | ||||||
|  | 
 | ||||||
|  | class ServiceRegistrationWindow(DataFormWindow): | ||||||
| 	'''Class for Service registration window: | 	'''Class for Service registration window: | ||||||
| 	Window that appears when we want to subscribe to a service''' | 	Window that appears when we want to subscribe to a service''' | ||||||
| 	def on_cancel_button_clicked(self, widget): | 	def on_cancel_button_clicked(self, widget): | ||||||
|  | @ -1779,6 +1900,13 @@ class ServiceRegistrationWindow: | ||||||
| 				entry.grab_focus() | 				entry.grab_focus() | ||||||
| 		table.show_all() | 		table.show_all() | ||||||
| 
 | 
 | ||||||
|  | 	def add_transport_to_roster(self): | ||||||
|  | 		user1 = Contact(jid = self.service, name = self.service, | ||||||
|  | 			groups = [_('Transports')], show = 'offline', status = 'offline', | ||||||
|  | 			sub = 'from') | ||||||
|  | 		gajim.contacts[self.account][self.service] = [user1] | ||||||
|  | 		self.plugin.roster.add_contact_to_roster(self.service, self.account) | ||||||
|  | 
 | ||||||
| 	def on_ok_button_clicked(self, widget): | 	def on_ok_button_clicked(self, widget): | ||||||
| 		'''When Ok button is clicked: | 		'''When Ok button is clicked: | ||||||
| 		send registration info to the core''' | 		send registration info to the core''' | ||||||
|  | @ -1789,30 +1917,39 @@ class ServiceRegistrationWindow: | ||||||
| 		if self.infos.has_key('registered'): | 		if self.infos.has_key('registered'): | ||||||
| 			del self.infos['registered'] | 			del self.infos['registered'] | ||||||
| 		else: | 		else: | ||||||
| 			user1 = Contact(jid = self.service, name = self.service, | 			self.add_transport_to_roster() | ||||||
| 			groups = [_('Transports')], show = 'offline', status = 'offline', |  | ||||||
| 			sub = 'from') |  | ||||||
| 			gajim.contacts[self.account][self.service] = [user1] |  | ||||||
| 			self.plugin.roster.add_contact_to_roster(self.service, self.account) |  | ||||||
| 		gajim.connections[self.account].register_agent(self.service, self.infos) | 		gajim.connections[self.account].register_agent(self.service, self.infos) | ||||||
| 		self.window.destroy() | 		self.window.destroy() | ||||||
| 
 | 
 | ||||||
| 	def __init__(self, service, infos, plugin, account): | 	def on_apply_button_clicked(self, widget): | ||||||
| 		self.xml = gtk.glade.XML(GTKGUI_GLADE,	'service_registration_window', APP) | 		# We press apply button of the FormDataWindow | ||||||
|  | 		if self.infos.has_key('registered'): | ||||||
|  | 			del self.infos['registered'] | ||||||
|  | 		else: | ||||||
|  | 			self.add_transport_to_roster() | ||||||
|  | 		gajim.connections[self.account].register_agent(self.service, self.infos, | ||||||
|  | 			True) # True is for is_form | ||||||
|  | 		self.window.destroy() | ||||||
|  | 
 | ||||||
|  | 	def __init__(self, service, infos, plugin, account, is_form): | ||||||
| 		self.service = service | 		self.service = service | ||||||
| 		self.infos = infos | 		self.infos = infos | ||||||
| 		self.plugin = plugin | 		self.plugin = plugin | ||||||
| 		self.account = account | 		self.account = account | ||||||
| 		self.window = self.xml.get_widget('service_registration_window') | 		if is_form: | ||||||
| 		if infos.has_key('registered'): | 			DataFormWindow.__init__(self, plugin, account, infos) | ||||||
| 			self.window.set_title(_('Edit %s' % service)) |  | ||||||
| 		else: | 		else: | ||||||
| 			self.window.set_title(_('Register to %s' % service)) | 			self.xml = gtk.glade.XML(GTKGUI_GLADE,	'service_registration_window', APP) | ||||||
| 		self.xml.get_widget('label').set_text(infos['instructions']) | 			self.window = self.xml.get_widget('service_registration_window') | ||||||
| 		self.entries = {} | 			if infos.has_key('registered'): | ||||||
| 		self.draw_table() | 				self.window.set_title(_('Edit %s' % service)) | ||||||
| 		self.xml.signal_autoconnect(self) | 			else: | ||||||
| 		self.window.show_all() | 				self.window.set_title(_('Register to %s' % service)) | ||||||
|  | 			self.xml.get_widget('label').set_text(infos['instructions']) | ||||||
|  | 			self.entries = {} | ||||||
|  | 			self.draw_table() | ||||||
|  | 			self.xml.signal_autoconnect(self) | ||||||
|  | 			self.window.show_all() | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| #---------- ManageEmoticonsWindow class -------------# | #---------- ManageEmoticonsWindow class -------------# | ||||||
|  | @ -2333,126 +2470,6 @@ _('Without a connection, you can not browse available services')).get_response() | ||||||
| 		self.browse(server_address) | 		self.browse(server_address) | ||||||
| 		self.plugin.save_config() | 		self.plugin.save_config() | ||||||
| 
 | 
 | ||||||
| class DataFormWindow: |  | ||||||
| 	def __init__(self, plugin, account, config): |  | ||||||
| 		self.plugin = plugin |  | ||||||
| 		self.account = account |  | ||||||
| 		self.config = config |  | ||||||
| 		self.xml = gtk.glade.XML(GTKGUI_GLADE, 'data_form_window', APP) |  | ||||||
| 		self.window = self.xml.get_widget('data_form_window') |  | ||||||
| 		self.config_table = self.xml.get_widget('config_table') |  | ||||||
| 		self.fill_table() |  | ||||||
| 		self.xml.signal_autoconnect(self) |  | ||||||
| 		self.window.show_all() |  | ||||||
| 
 |  | ||||||
| 	def on_data_form_window_destroy(self, widget): |  | ||||||
| 		pass |  | ||||||
| 
 |  | ||||||
| 	def on_close_button_clicked(self, widget): |  | ||||||
| 		self.window.destroy() |  | ||||||
| 	 |  | ||||||
| 	def on_checkbutton_toggled(self, widget, index): |  | ||||||
| 		self.config[index]['values'][0] = widget.get_active() |  | ||||||
| 
 |  | ||||||
| 	def on_combobox_changed(self, widget, index): |  | ||||||
| 		self.config[index]['values'][0] = self.config[index]['options'][ \ |  | ||||||
| 			widget.get_active()]['values'][0] |  | ||||||
| 
 |  | ||||||
| 	def on_entry_changed(self, widget, index): |  | ||||||
| 		self.config[index]['values'][0] = widget.get_text().decode('utf-8') |  | ||||||
| 
 |  | ||||||
| 	def on_textbuffer_changed(self, widget, index): |  | ||||||
| 		begin, end = widget.get_bounds() |  | ||||||
| 		self.config[index]['values'][0] = widget.get_text(begin, end) |  | ||||||
| 		 |  | ||||||
| 	def fill_table(self): |  | ||||||
| 		if self.config.has_key('title'): |  | ||||||
| 			self.window.set_title(self.config['title']) |  | ||||||
| 		if self.config.has_key('instructions'): |  | ||||||
| 			self.xml.get_widget('instructions_label').set_text( |  | ||||||
| 				self.config['instructions']) |  | ||||||
| 		i = 0 |  | ||||||
| 		while self.config.has_key(i): |  | ||||||
| 			if not self.config[i].has_key('type'): |  | ||||||
| 				i += 1 |  | ||||||
| 				continue |  | ||||||
| 			ctype = self.config[i]['type'] |  | ||||||
| 			if ctype == 'hidden': |  | ||||||
| 				i += 1 |  | ||||||
| 				continue |  | ||||||
| 			nbrows = self.config_table.get_property('n-rows') |  | ||||||
| 			self.config_table.resize(nbrows + 1, 2) |  | ||||||
| 			if self.config[i].has_key('label'): |  | ||||||
| 				label = gtk.Label(self.config[i]['label']) |  | ||||||
| 				label.set_alignment(0.0, 0.5) |  | ||||||
| 				self.config_table.attach(label, 0, 1, nbrows, nbrows + 1,  |  | ||||||
| 					gtk.FILL	| gtk.SHRINK) |  | ||||||
| 			desc = None |  | ||||||
| 			if self.config[i].has_key('desc'): |  | ||||||
| 				desc = self.config[i]['desc'] |  | ||||||
| 			max = 1 |  | ||||||
| 			if ctype == 'boolean': |  | ||||||
| 				widget = gtk.CheckButton(desc, False) |  | ||||||
| 				widget.set_active(self.config[i]['values'][0]) |  | ||||||
| 				widget.connect('toggled', self.on_checkbutton_toggled, i) |  | ||||||
| 				max = 2 |  | ||||||
| 			elif ctype == 'fixed': |  | ||||||
| 				widget = gtk.Label('\n'.join(self.config[i]['values'])) |  | ||||||
| 				widget.set_alignment(0.0, 0.5) |  | ||||||
| 				max = 4 |  | ||||||
| 			elif ctype == 'jid-multi': |  | ||||||
| 				#TODO |  | ||||||
| 				widget = gtk.Label('') |  | ||||||
| 			elif ctype == 'jid-single': |  | ||||||
| 				#TODO |  | ||||||
| 				widget = gtk.Label('') |  | ||||||
| 			elif ctype == 'list-multi': |  | ||||||
| 				#TODO |  | ||||||
| 				widget = gtk.Label('') |  | ||||||
| 			elif ctype == 'list-single': |  | ||||||
| 				widget = gtk.combo_box_new_text() |  | ||||||
| 				widget.connect('changed', self.on_combobox_changed, i) |  | ||||||
| 				index = 0 |  | ||||||
| 				j = 0 |  | ||||||
| 				while self.config[i]['options'].has_key(j): |  | ||||||
| 					if self.config[i]['options'][j]['values'][0] == \ |  | ||||||
| 						self.config[i]['values'][0]: |  | ||||||
| 						index = j |  | ||||||
| 					widget.append_text(self.config[i]['options'][j]['label']) |  | ||||||
| 					j += 1 |  | ||||||
| 				widget.set_active(index) |  | ||||||
| 				max = 3 |  | ||||||
| 			elif ctype == 'text-multi': |  | ||||||
| 				widget = gtk.TextView() |  | ||||||
| 				widget.get_buffer().connect('changed', self.on_textbuffer_changed, \ |  | ||||||
| 					i) |  | ||||||
| 				widget.get_buffer().set_text('\n'.join(self.config[i]['values'])) |  | ||||||
| 				max = 4 |  | ||||||
| 			elif ctype == 'text-private': |  | ||||||
| 				widget = gtk.Entry() |  | ||||||
| 				widget.connect('changed', self.on_entry_changed, i) |  | ||||||
| 				widget.set_text(self.config[i]['values'][0]) |  | ||||||
| 				widget.set_visibility(False) |  | ||||||
| 				max = 3 |  | ||||||
| 			elif ctype == 'text-single': |  | ||||||
| 				widget = gtk.Entry() |  | ||||||
| 				widget.connect('changed', self.on_entry_changed, i) |  | ||||||
| 				widget.set_text(self.config[i]['values'][0]) |  | ||||||
| 				max = 3 |  | ||||||
| 			i += 1 |  | ||||||
| 			if max < 4: |  | ||||||
| 				self.config_table.attach(widget, 1, max, |  | ||||||
| 							nbrows, nbrows + 1, |  | ||||||
| 							gtk.FILL | gtk.SHRINK) |  | ||||||
| 				widget = gtk.Label() |  | ||||||
| 				self.config_table.attach(widget, max, 4, |  | ||||||
| 							nbrows, nbrows + 1) |  | ||||||
| 			else: |  | ||||||
| 				self.config_table.attach(widget, 1, max, |  | ||||||
| 							nbrows, nbrows + 1) |  | ||||||
| 		self.config_table.show_all() |  | ||||||
| 
 |  | ||||||
| #---------- GroupchatConfigWindow class -------------# |  | ||||||
| class GroupchatConfigWindow(DataFormWindow): | class GroupchatConfigWindow(DataFormWindow): | ||||||
| 	'''GroupchatConfigWindow class''' | 	'''GroupchatConfigWindow class''' | ||||||
| 	def __init__(self, plugin, account, room_jid, config): | 	def __init__(self, plugin, account, room_jid, config): | ||||||
|  |  | ||||||
|  | @ -561,9 +561,10 @@ class Interface: | ||||||
| 				array[2], array[3]) | 				array[2], array[3]) | ||||||
| 
 | 
 | ||||||
| 	def handle_event_register_agent_info(self, account, array): | 	def handle_event_register_agent_info(self, account, array): | ||||||
| 		#('AGENT_INFO', account, (agent, infos)) | 		#('REGISTER_AGENT_INFO', account, (agent, infos, is_form)) | ||||||
| 		if array[1].has_key('instructions'): | 		if array[1].has_key('instructions'): | ||||||
| 			config.ServiceRegistrationWindow(array[0], array[1], self, account) | 			config.ServiceRegistrationWindow(array[0], array[1], self, account, | ||||||
|  | 				array[2]) | ||||||
| 		else: | 		else: | ||||||
| 			dialogs.ErrorDialog(_('Contact with "%s" cannot be established'\ | 			dialogs.ErrorDialog(_('Contact with "%s" cannot be established'\ | ||||||
| % array[0]), _('Check your connection or try again later.')).get_response() | % array[0]), _('Check your connection or try again later.')).get_response() | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue