Create branch to develop a basic wrapper for hildon specific widgets
[wifihood] / wifimap / config.py
index f7caad9..0f3b99a 100644 (file)
@@ -5,37 +5,40 @@ import gtk
 try :
     import hildon
 except :
+    import hildongtk
     hildon = False
 
 class Configuration :
 
-    def __init__ ( self ) :
-        self.homedir = None
-        self.dbname = None
-        self.mapsdir , self.mapclass = None , None
-        self.lat , self.lon = 0.0 , 0.0
-        self.zoom = 0
-        self.read()
-
-    def read ( self ) :
-        client = gconf.client_get_default()
-        self.homedir = client.get_string( "/apps/wifihood/basedir" ) or "/home/user/MyDocs"
-        self.dbname = client.get_string( "/apps/wifihood/dbname" ) or "wifiscanner.db"
-        self.mapsdir = client.get_string( "/apps/wifihood/maps" ) or "/home/user/MyDocs/.maps"
-        self.mapclass = client.get_string( "/apps/wifihood/maptype" ) or "OpenStreetMap I"
-        self.lat = client.get_float( "/apps/wifihood/lattitude" ) or client.get_float( "/apps/maemo/maemo-mapper/center_latitude" ) or 40.416
-        self.lon = client.get_float( "/apps/wifihood/longitude" ) or client.get_float( "/apps/maemo/maemo-mapper/center_longitude" ) or -3.683
-        self.zoom = client.get_int( "/apps/wifihood/zoom" ) or client.get_float( "/apps/maemo/maemo-mapper/zoom" ) or 15
+    def __init__ ( self , type ) :
+        self._type = type
+        self._client = gconf.client_get_default()
+        self.homedir = self._client.get_string( "/apps/wifihood/basedir" ) or "/home/user/MyDocs"
+        self.homedir = "/tmp"
+        self.dbname = self._client.get_string( "/apps/wifihood/dbname" ) or "wifiscanner.db"
+        self.mapsdir = self._client.get_string( "/apps/wifihood/maps" ) or "/home/user/MyDocs/.maps"
+        self.mapclass = self._client.get_string( "/apps/wifihood/maptype" ) or "OpenStreetMap I"
+        self.lat = self._client.get_float( "/apps/wifihood/latitude" ) or self._client.get_float( "/apps/maemo/maemo-mapper/center_latitude" ) or 40.416
+        self.lon = self._client.get_float( "/apps/wifihood/longitude" ) or self._client.get_float( "/apps/maemo/maemo-mapper/center_longitude" ) or -3.683
+        if self._type == 'map' :
+            self.zoom = self._client.get_int( "/apps/wifihood/map-zoom" ) or self._client.get_float( "/apps/maemo/maemo-mapper/zoom" ) or 15
+        else :
+            self.zoom = self._client.get_int( "/apps/wifihood/%s-zoom" % self._type ) or 16
+
+    def set_latlon ( self , ( lat , lon ) ) :
+        self._client.set_float( "/apps/wifihood/latitude" , lat )
+        self._client.set_float( "/apps/wifihood/longitude" , lon )
+        self.lat , self.lon = lat , lon
+
+    def set_zoom ( self , zoom ) :
+        self._client.set_int( "/apps/wifihood/%s-zoom" % self._type , zoom )
+        self.zoom = zoom
 
     def save ( self ) :
-        client = gconf.client_get_default()
-        client.set_string( "/apps/wifihood/basedir" , self.homedir )
-        client.set_string( "/apps/wifihood/dbname" , self.dbname )
-        client.set_string( "/apps/wifihood/maps" , self.mapsdir )
-        client.set_string( "/apps/wifihood/maptype" , self.mapclass )
-        client.set_float( "/apps/wifihood/lattitude" , self.lat )
-        client.set_float( "/apps/wifihood/longitude" , self.lon )
-        client.set_int( "/apps/wifihood/zoom" , self.zoom )
+        self._client.set_string( "/apps/wifihood/basedir" , self.homedir )
+        self._client.set_string( "/apps/wifihood/dbname" , self.dbname )
+        self._client.set_string( "/apps/wifihood/maps" , self.mapsdir )
+        self._client.set_string( "/apps/wifihood/maptype" , self.mapclass )
 
 
 class AbstractSettingsWindow :
@@ -43,7 +46,7 @@ class AbstractSettingsWindow :
     def __init__ ( self , config , handler ) :
         self.set_title( "Wifihood Settings" )
 
-        scrollwin = self.MainArea()
+        scrollwin = hildongtk.PannableArea()
         scrollwin.show()
         self.add(scrollwin)
 
@@ -65,7 +68,7 @@ class AbstractSettingsWindow :
         dblabel.show()
         database.attach(dblabel, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
 
-        dbvalue = self.Entry()
+        dbvalue = hildongtk.Entry( gtk.HILDON_SIZE_FINGER_HEIGHT )
         dbvalue.set_text( config.homedir )
         dbvalue.show()
         database.attach(dbvalue, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
@@ -74,7 +77,7 @@ class AbstractSettingsWindow :
         dblabel.show()
         database.attach(dblabel, 0, 1, 1, 2, gtk.EXPAND|gtk.FILL, 0, 0, 5)
 
-        dbvalue = self.Entry()
+        dbvalue = hildongtk.Entry( gtk.HILDON_SIZE_FINGER_HEIGHT )
         dbvalue.set_text( config.dbname )
         dbvalue.show()
         database.attach(dbvalue, 1, 2, 1, 2, gtk.EXPAND|gtk.FILL, 0, 0, 5)
@@ -89,7 +92,7 @@ class AbstractSettingsWindow :
         maps.show()
         mapsframe.add(maps)
 
-        button = self.CheckButton()
+        button = hildongtk.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
         button.set_label( "Use OpenStreet maps" )
         button.set_active( 1 )
         button.show()
@@ -109,12 +112,12 @@ class AbstractSettingsWindow :
         gps.show()
         gpsframe.add(gps)
 
-        button = self.CheckButton()
+        button = hildongtk.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
         button.set_label( "Take initial coordinates from maemo-mapper" )
         button.show()
         gps.attach(button, 0, 2, 0, 1, gtk.EXPAND|gtk.FILL) #, 0, 0, 5)
 
-        button = self.CheckButton()
+        button = hildongtk.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
         button.set_label( "Store changes in coordinates" )
         button.show()
         gps.attach(button, 0, 2, 1, 2, gtk.EXPAND|gtk.FILL) #, 0, 0, 5)
@@ -125,7 +128,7 @@ class AbstractSettingsWindow :
         dataframe.show()
         vbox.pack_start(dataframe, True, True, 0)
 
-        button = self.CheckButton()
+        button = hildongtk.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
         button.set_label( "Write full logfile" )
         button.show()
         dataframe.add(button)
@@ -158,7 +161,7 @@ if hildon :
     def zoomdialog ( self , widget , conf ) :
         newzoom = int( widget.get_selector().get_current_text() )
         if self.handler : self.handler( newzoom )
-        conf.zoom = newzoom
+        conf.set_zoom( newzoom )
 
   class SettingsWindow ( hildon.StackableWindow , AbstractSettingsWindow ) :
 
@@ -174,57 +177,39 @@ if hildon :
         button.connect_object( "value-changed", selector.zoomdialog , button , config )
         return button
 
-    def MainArea ( self ) :
-        return hildon.PannableArea()
-
-    def Entry ( self ) :
-        return hildon.Entry( gtk.HILDON_SIZE_FINGER_HEIGHT )
-
-    def Button ( self , text , value ) :
-        return hildon.Button( gtk.HILDON_SIZE_THUMB_HEIGHT , hildon.BUTTON_ARRANGEMENT_HORIZONTAL , text , "%s" % value )
-
-    def CheckButton ( self ) :
-        return hildon.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
-
 else :
 
-  class ZoomDialog ( gtk.Dialog ) :
+  class ZoomDialog ( hildongtk.TouchSelector ) :
 
-    def __init__ ( self , config , handler , labelsetter=None ) :
-        gtk.Dialog.__init__( self , "Select zoom level",
-                             None,
-                             gtk.DIALOG_MODAL,
-                             ( gtk.STOCK_OK, gtk.RESPONSE_ACCEPT,
-                               gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT
-                               )
-                             )
+    def __init__ ( self , config , handler ) :
+        hildongtk.TouchSelector.__init__( self )
+        self.handler = handler
 
-        zooms = gtk.ListStore(int)
-        combo = gtk.ComboBox( zooms )
+        zooms = gtk.ListStore(str)
 
+        active = index = 0
         for zoom in range(8,19) :
             iter = zooms.append()
             zooms.set( iter , 0 , zoom )
             if zoom == config.zoom :
-                combo.set_active_iter( iter )
+                active = index
+            index += 1
 
-        cell = gtk.CellRendererText()
-        combo.pack_start(cell, True)
-        combo.add_attribute(cell, 'text', 0)
+        column = self.append_text_column( zooms , True )
 
-        self.vbox.pack_start(combo , True, True, 0)
+        # NOTE : with text=True, we must use 1 instead of 0
+        self.set_active( 0 , active )
 
-        self.connect_object( "response", self.response , combo , config , handler , labelsetter )
+    def zoomdialog ( self , widget , conf ) :
+        newzoom = int( widget.get_selector().get_current_text() )
+        if self.handler : self.handler( newzoom )
+        conf.set_zoom( newzoom )
 
-    def response ( self , combo , response  , config , handler , labelsetter ) :
+    def response ( self , widget , response , config ) :
         if response == gtk.RESPONSE_ACCEPT :
-            item = combo.get_active_iter()
-            model = combo.get_model()
-            newzoom = model.get(item,0)[0]
-            if labelsetter : labelsetter( newzoom )
-            if handler : handler( newzoom )
-            config.zoom = newzoom
-        self.destroy()
+            self.zoomdialog( widget , config )
+            widget._build_label()
+        self.hide()
 
   class SettingsWindow ( gtk.Window , AbstractSettingsWindow ) :
 
@@ -232,41 +217,19 @@ else :
         gtk.Window.__init__( self )
         AbstractSettingsWindow.__init__( self , config , handler )
 
-    def MainArea ( self ) :
-        scrollwin = gtk.ScrolledWindow()
-        scrollwin.set_size_request(-1, 260)
-        scrollwin.set_policy(gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
-        return scrollwin
-
-    def Entry ( self ) :
-        return gtk.Entry()
-
-    def Button ( self , label=None ) :
-        return gtk.Button( label )
-
-    def zoomdialog ( self , widget , config , handler ) :
-        dialog = ZoomDialog( config , handler , widget.set_value )
-        dialog.show_all()
-
     def ZoomButton ( self , text , config , handler ) :
-        class _button ( gtk.Button ) :
-            def __init__ ( self , text , value ) :
-                gtk.Button.__init__( self )
-                self._text = text
-                self.set_value( value )
-            def set_value ( self , value ) :
-                self._value = value
-                self.set_label( "%s -- %s" % ( self._text , self._value ) )
-        button = _button( text , config.zoom )
-        button.connect_object( "clicked", self.zoomdialog , button , config , handler )
+        selector = ZoomDialog( config , handler )
+        button = hildongtk.PickerButton( gtk.HILDON_SIZE_AUTO, hildongtk.BUTTON_ARRANGEMENT_VERTICAL)
+        button.set_title( text )
+        button.set_selector( selector )
+#        button.connect_object( "value-changed", selector.zoomdialog , button , config )
+# event does not exists !!!
+        selector.connect_object( "response", selector.response , button , config )
         return button
 
-    def CheckButton ( self ) :
-        return gtk.CheckButton()
-
-config = Configuration()
 
 if __name__ == "__main__" :
+    config = Configuration( 'scanner' )
     window = SettingsWindow( config )
     window.connect("delete_event", gtk.main_quit, None)
     window.show()