BUGFIX : store current GPS only if not using mapper, even in case that configuration...
[wifihood] / wifiscanner / wifimap / config.py
1
2 import gconf
3
4 import gtk
5 try :
6     import hildon
7 except :
8     hildon = False
9
10 class Configuration :
11
12     def __init__ ( self , type ) :
13         self._type = type
14         self.read()
15
16     def read ( self ) :
17         client = gconf.client_get_default()
18
19         self.homedir = client.get_string( "/apps/wifihood/basedir" ) or "/home/user/MyDocs"
20         self.dbname = client.get_string( "/apps/wifihood/dbname" ) or "wifiscanner.db"
21         self.mapsdir = client.get_string( "/apps/wifihood/maps" ) or "/home/user/MyDocs/.maps"
22         self.mapclass = client.get_string( "/apps/wifihood/maptype" ) or "OpenStreetMap I"
23
24         self.scan_period = client.get_float( "/apps/wifihood/scan-period" ) or 5
25
26         self.store_log = client.get_bool( "/apps/wifihood/store-logfile" )
27
28         self.use_mapper = client.get_bool( "/apps/wifihood/use-mapper" )
29         self.store_gps = client.get_bool( "/apps/wifihood/store-gps" )
30         if self.use_mapper :
31             # FIXME : This will reset the stored default
32             self.lat = client.get_float( "/apps/maemo/maemo-mapper/center_latitude" )
33             self.lon = client.get_float( "/apps/maemo/maemo-mapper/center_longitude" )
34             self.zoom = client.get_int( "/apps/maemo/maemo-mapper/zoom" )
35         else :
36             self.lat = client.get_float( "/apps/wifihood/latitude" )
37             self.lon = client.get_float( "/apps/wifihood/longitude" )
38             self.zoom = client.get_int( "/apps/wifihood/map-zoom" )
39
40         if self._type == 'scanner' :
41             self.zoom = client.get_int( "/apps/wifihood/%s-zoom" % self._type )
42
43         if self.lat == 0.0 and self.lon == 0.0 :
44             self.lat , self.lon = 40.416 , -3.683
45         if self.zoom == 0 :
46             self.zoom = 15
47
48     def set_latlon ( self , ( lat , lon ) ) :
49         if self.store_gps and not self.use_mapper :
50             client = gconf.client_get_default()
51             client.set_float( "/apps/wifihood/latitude" , lat )
52             client.set_float( "/apps/wifihood/longitude" , lon )
53         self.lat , self.lon = lat , lon
54
55     def set_zoom ( self , zoom ) :
56         if self._type == 'scanner' or ( self.store_gps and not self.use_mapper ) :
57             client = gconf.client_get_default()
58             client.set_int( "/apps/wifihood/%s-zoom" % self._type , zoom )
59         self.zoom = zoom
60
61     def save ( self , widget=None ) :
62         """Saves all the editable configuration elements"""
63
64         client = gconf.client_get_default()
65         client.set_string( "/apps/wifihood/basedir" , self.homedir )
66         client.set_string( "/apps/wifihood/dbname" , self.dbname )
67
68         client.set_float( "/apps/wifihood/scan-period" , self.scan_period )
69         client.set_bool( "/apps/wifihood/store-logfile" , self.store_log )
70         client.set_bool( "/apps/wifihood/use-mapper" , self.use_mapper )
71         client.set_bool( "/apps/wifihood/store-gps" , self.store_gps )
72
73         client.set_int( "/apps/wifihood/%s-zoom" % self._type , self.zoom )
74
75 class AbstractSettingsWindow :
76
77     def __init__ ( self , config , handler ) :
78         self.set_title( "Wifihood Settings" )
79
80         scrollwin = self.MainArea()
81         scrollwin.show()
82         self.add(scrollwin)
83
84         vbox = gtk.VBox(False, 0)
85         vbox.show()
86         scrollwin.add_with_viewport( vbox )
87
88
89         dbframe = gtk.Frame( label="Database" )
90         dbframe.set_label_align(0 , 0.1)
91         dbframe.show()
92         vbox.pack_start(dbframe, True, True, 0)
93
94         database = gtk.Table(2, 2, False)
95         database.show()
96         dbframe.add(database)
97
98         dblabel = gtk.Label( "Home directory" )
99         dblabel.show()
100         database.attach(dblabel, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
101
102         dbvalue = self.Entry()
103         dbvalue.connect( "changed" , self.entry_cb , config , "basedir" )
104         dbvalue.set_text( config.homedir )
105         dbvalue.show()
106         database.attach(dbvalue, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
107
108         dblabel = gtk.Label( "Database name" )
109         dblabel.show()
110         database.attach(dblabel, 0, 1, 1, 2, gtk.EXPAND|gtk.FILL, 0, 0, 5)
111
112         dbvalue = self.Entry()
113         dbvalue.connect( "changed" , self.entry_cb , config , "dbname" )
114         dbvalue.set_text( config.dbname )
115         dbvalue.show()
116         database.attach(dbvalue, 1, 2, 1, 2, gtk.EXPAND|gtk.FILL, 0, 0, 5)
117
118
119         mapsframe = gtk.Frame( label="Maps" )
120         mapsframe.set_label_align(0 , 0.1)
121         mapsframe.show()
122         vbox.pack_start(mapsframe, True, True, 0)
123
124         maps = gtk.Table(2, 2, False)
125         maps.show()
126         mapsframe.add(maps)
127
128         button = self.CheckButton()
129         button.set_label( "Use OpenStreet maps" )
130         button.set_active( 1 )
131         button.show()
132         maps.attach(button, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
133
134         zoomlevel = self.ZoomButton( "Zoom level" , config , handler )
135         zoomlevel.show()
136         maps.attach(zoomlevel, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
137
138
139         gpsframe = gtk.Frame( label="Coordinates" )
140         gpsframe.set_label_align(0 , 0.1)
141         gpsframe.show()
142         vbox.pack_start(gpsframe, True, True, 0)
143
144         gps = gtk.Table(2, 2, False)
145         gps.show()
146         gpsframe.add(gps)
147
148         button = self.CheckButton()
149         button.set_label( "Take initial coordinates from maemo-mapper" )
150         button.connect( "toggled" , self.checkbutton_cb , config , "use_mapper" )
151         button.set_active( config.use_mapper )
152         button.show()
153         gps.attach(button, 0, 2, 0, 1, gtk.EXPAND|gtk.FILL) #, 0, 0, 5)
154
155         button = self.CheckButton()
156         button.set_label( "Store changes in coordinates" )
157         button.connect( "toggled" , self.checkbutton_cb , config , "store_gps" )
158         button.set_active( config.store_gps )
159         button.show()
160         gps.attach(button, 0, 2, 1, 2, gtk.EXPAND|gtk.FILL) #, 0, 0, 5)
161
162
163         dataframe = gtk.Frame( label="Data gathering" )
164         dataframe.set_label_align(0 , 0.1)
165         dataframe.show()
166         vbox.pack_start(dataframe, True, True, 0)
167
168         datatable = gtk.Table(2, 2, False)
169         datatable.show()
170         dataframe.add(datatable)
171
172         scanlabel = gtk.Label( "Scanning interval" )
173         scanlabel.show()
174         datatable.attach(scanlabel, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL)
175
176         scanvalue = self.Entry()
177         scanvalue.connect( "changed" , self.float_cb , config , "scan-period" )
178         scanvalue.set_text( "%s" % config.scan_period )
179         scanvalue.show()
180         datatable.attach(scanvalue, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL)
181
182         button = self.CheckButton()
183         button.set_label( "Write full logfile" )
184         button.connect( "toggled" , self.checkbutton_cb , config , "store_log" )
185         button.set_active( config.store_log )
186         button.show()
187         datatable.attach(button, 0, 2, 1, 2, gtk.EXPAND|gtk.FILL)
188
189         self.show()
190
191     def entry_cb ( self , entry , config , keyword ) :
192         config.__dict__[ keyword ] = entry.get_text()
193
194     def float_cb ( self , entry , config , keyword ) :
195         config.__dict__[ keyword ] = float( entry.get_text() )
196
197     def int_cb ( self , entry , config , keyword , scale=1 ) :
198         config.__dict__[ keyword ] = int( scale * float( entry.get_text() ) )
199
200     def checkbutton_cb ( self , button , config , keyword ) :
201         config.__dict__[ keyword ] = button.get_active()
202
203 if hildon :
204
205   class ZoomDialog ( hildon.TouchSelector ) :
206
207     def __init__ ( self , config , handler ) :
208         hildon.TouchSelector.__init__( self )
209         self.handler = handler
210
211         zooms = gtk.ListStore(str)
212
213         active = index = 0
214         for zoom in range(8,19) :
215             iter = zooms.append()
216             zooms.set( iter , 0 , "%2d" % zoom )
217             if zoom == config.zoom :
218                 active = index
219             index += 1
220
221         column = self.append_text_column( zooms , True )
222
223         # NOTE : with text=True, we must use 1 instead of 0
224         self.set_active( 0 , active )
225
226     def zoomdialog ( self , widget , conf ) :
227         newzoom = int( widget.get_selector().get_current_text() )
228         if self.handler : self.handler( newzoom )
229         conf.set_zoom( newzoom )
230
231   class SettingsWindow ( hildon.StackableWindow , AbstractSettingsWindow ) :
232
233     def __init__ ( self , config , handler=None ) :
234         hildon.StackableWindow.__init__( self )
235         AbstractSettingsWindow.__init__( self , config , handler )
236
237     def ZoomButton ( self , text , config , handler ) :
238         selector = ZoomDialog( config , handler )
239         button = hildon.PickerButton( gtk.HILDON_SIZE_AUTO, hildon.BUTTON_ARRANGEMENT_VERTICAL)
240         button.set_title( text )
241         button.set_selector( selector )
242         button.connect_object( "value-changed", selector.zoomdialog , button , config )
243         return button
244
245     def MainArea ( self ) :
246         return hildon.PannableArea()
247
248     def Entry ( self ) :
249         return hildon.Entry( gtk.HILDON_SIZE_FINGER_HEIGHT )
250
251     def Button ( self , text , value ) :
252         return hildon.Button( gtk.HILDON_SIZE_THUMB_HEIGHT , hildon.BUTTON_ARRANGEMENT_HORIZONTAL , text , "%s" % value )
253
254     def CheckButton ( self ) :
255         return hildon.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
256
257 else :
258
259   class ZoomDialog ( gtk.Dialog ) :
260
261     def __init__ ( self , config , handler , labelsetter=None ) :
262         gtk.Dialog.__init__( self , "Select zoom level",
263                              None,
264                              gtk.DIALOG_MODAL,
265                              ( gtk.STOCK_OK, gtk.RESPONSE_ACCEPT,
266                                gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT
267                                )
268                              )
269
270         zooms = gtk.ListStore(int)
271         combo = gtk.ComboBox( zooms )
272
273         for zoom in range(8,19) :
274             iter = zooms.append()
275             zooms.set( iter , 0 , zoom )
276             if zoom == config.zoom :
277                 combo.set_active_iter( iter )
278
279         cell = gtk.CellRendererText()
280         combo.pack_start(cell, True)
281         combo.add_attribute(cell, 'text', 0)
282
283         self.vbox.pack_start(combo , True, True, 0)
284
285         self.connect_object( "response", self.response , combo , config , handler , labelsetter )
286
287     def response ( self , combo , response  , config , handler , labelsetter ) :
288         if response == gtk.RESPONSE_ACCEPT :
289             item = combo.get_active_iter()
290             model = combo.get_model()
291             newzoom = model.get(item,0)[0]
292             if labelsetter : labelsetter( newzoom )
293             if handler : handler( newzoom )
294             config.set_zoom( newzoom )
295         self.destroy()
296
297   class SettingsWindow ( gtk.Window , AbstractSettingsWindow ) :
298
299     def __init__ ( self , config , handler=None ) :
300         gtk.Window.__init__( self )
301         AbstractSettingsWindow.__init__( self , config , handler )
302         self.connect("unrealize", config.save )
303
304     def MainArea ( self ) :
305         scrollwin = gtk.ScrolledWindow()
306         scrollwin.set_size_request(-1, 290)
307         scrollwin.set_policy(gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
308         return scrollwin
309
310     def Entry ( self ) :
311         return gtk.Entry()
312
313     def Button ( self , label=None ) :
314         return gtk.Button( label )
315
316     def zoomdialog ( self , widget , config , handler ) :
317         dialog = ZoomDialog( config , handler , widget.set_value )
318         dialog.show_all()
319
320     def ZoomButton ( self , text , config , handler ) :
321         class _button ( gtk.Button ) :
322             def __init__ ( self , text , value ) :
323                 gtk.Button.__init__( self )
324                 self._text = text
325                 self.set_value( value )
326             def set_value ( self , value ) :
327                 self._value = value
328                 self.set_label( "%s -- %s" % ( self._text , self._value ) )
329         button = _button( text , config.zoom )
330         button.connect_object( "clicked", self.zoomdialog , button , config , handler )
331         return button
332
333     def CheckButton ( self ) :
334         return gtk.CheckButton()
335
336 if __name__ == "__main__" :
337     config = Configuration( 'scanner' )
338     window = SettingsWindow( config )
339     window.connect("delete_event", gtk.main_quit, None)
340     window.show()
341     gtk.main()