From ebf074e5c1fdbc46cdbf3d258af767440d4b90e6 Mon Sep 17 00:00:00 2001
From: Yann Leboulanger <asterix@lagaule.org>
Date: Fri, 22 Jun 2007 17:27:22 +0000
Subject: [PATCH] use FakeDataform widget in search window. fixes #1922

---
 src/search_window.py | 81 +++++++++++++-------------------------------
 1 file changed, 24 insertions(+), 57 deletions(-)

diff --git a/src/search_window.py b/src/search_window.py
index 4c95eef8f6..f3eaddecca 100644
--- a/src/search_window.py
+++ b/src/search_window.py
@@ -19,6 +19,7 @@ from common import xmpp, gajim, dataforms
 
 import gtkgui_helpers
 import dialogs
+import config
 import dataforms_widget
 
 class SearchWindow:
@@ -35,9 +36,6 @@ class SearchWindow:
 		for name in ('label', 'progressbar', 'search_vbox', 'search_button'):
 			self.__dict__[name] = self.xml.get_widget(name)
 
-		self.data_form_widget = dataforms_widget.DataFormWidget()
-		self.table = None
-
 		# displaying the window
 		self.xml.signal_autoconnect(self)
 		self.window.show_all()
@@ -45,10 +43,6 @@ class SearchWindow:
 		self.pulse_id = gobject.timeout_add(80, self.pulse_callback)
 
 		self.is_form = None
-		
-		# for non-dataform forms
-		self.entries = {}
-		self.info = {}
 
 	def request_form(self):
 		gajim.connections[self.account].request_search_fields(self.jid)
@@ -74,15 +68,14 @@ class SearchWindow:
 			self.data_form_widget.data_form.type = 'submit'
 			gajim.connections[self.account].send_search_form(self.jid,
 				self.data_form_widget.data_form, True)
-			self.search_vbox.remove(self.data_form_widget)
 		else:
-			for name in self.entries.keys():
-				self.infos[name] = self.entries[name].get_text().decode('utf-8')
-			if self.infos.has_key('instructions'):
-				del self.infos['instructions']
-			gajim.connections[self.account].send_search_form(self.jid, self.infos,
+			infos = self.data_form_widget.get_infos()
+			if infos.has_key('instructions'):
+				del infos['instructions']
+			gajim.connections[self.account].send_search_form(self.jid, infos,
 				False)
-			self.search_vbox.remove(self.table)
+
+		self.search_vbox.remove(self.data_form_widget)
 
 		self.progressbar.show()
 		self.label.set_text(_('Waiting for results'))
@@ -96,52 +89,26 @@ class SearchWindow:
 		self.progressbar.hide()
 		self.label.hide()
 
-		if not is_form:
-			self.is_form = False
-			self.infos = form
-			nbrow = 0
-			if self.infos.has_key('instructions'):
-				self.label.set_text(self.infos['instructions'])
+		if is_form:
+			self.is_form = True
+			self.data_form_widget = dataforms_widget.DataFormWidget()
+			self.dataform = dataforms.ExtendForm(node = form)
+			self.data_form_widget.set_sensitive(True)
+			try:
+				self.data_form_widget.data_form = self.dataform
+			except dataforms.Error:
+				self.label.set_text(_('Error in received dataform'))
 				self.label.show()
-			self.table = gtk.Table()
-			for name in self.infos.keys():
-				if not name:
-					continue
-				if name == 'instructions':
-					continue
-
-				nbrow = nbrow + 1
-				self.table.resize(rows = nbrow, columns = 2)
-				label = gtk.Label(name.capitalize() + ':')
-				self.table.attach(label, 0, 1, nbrow - 1, nbrow, 0, 0, 0, 0)
-				entry = gtk.Entry()
-				entry.set_activates_default(True)
-				if self.infos[name]:
-					entry.set_text(self.infos[name])
-				if name == 'password':
-					entry.set_visibility(False)
-				self.table.attach(entry, 1, 2, nbrow - 1, nbrow, 0, 0, 0, 0)
-				self.entries[name] = entry
-			self.table.show_all()
-			self.search_vbox.pack_start(self.table)
-			return
-
-		self.dataform = dataforms.ExtendForm(node = form)
-
-		self.data_form_widget.set_sensitive(True)
-		try:
-			self.data_form_widget.data_form = self.dataform
-		except dataforms.Error:
-			self.label.set_text(_('Error in received dataform'))
-			self.label.show()
-			return
-		self.is_form = True
+				return
+			if self.data_form_widget.title:
+				self.window.set_title('%s - Search - Gajim' % \
+					self.data_form_widget.title)
+		else:
+			self.is_form = False
+			self.data_form_widget = config.FakeDataForm(form)
 
+		self.data_form_widget.show_all()
 		self.search_vbox.pack_start(self.data_form_widget)
-		self.data_form_widget.show()
-		if self.data_form_widget.title:
-			self.window.set_title('%s - Search - Gajim' % \
-				self.data_form_widget.title)
 
 	def on_result_arrived(self, form, is_form):
 		if self.pulse_id:
-- 
GitLab