hoversel working.
authorCarsten Haitzler <raster@rasterman.com>
Tue, 16 Dec 2008 00:15:34 +0000 (00:15 +0000)
committerCarsten Haitzler <raster@rasterman.com>
Tue, 16 Dec 2008 00:15:34 +0000 (00:15 +0000)
SVN revision: 38161

data/themes/default.edc
src/lib/Elementary.h
src/lib/elc_hoversel.c

index ae8941c..a89479a 100644 (file)
@@ -419,6 +419,7 @@ collections {
              tag:  "br" "\n";
              tag:  "hilight" "+ font=Sans:style=Bold";
              tag:  "b" "+ font=Sans:style=Bold";
+             tag:  "tab" "\t";
           }
        }
       parts {
@@ -2757,7 +2758,7 @@ collections {
       }
       programs {
         program { name: "end";
-           signal: "mouse,down,1";
+           signal: "mouse,up,1";
            source: "base";
            action: SIGNAL_EMIT "elm,action,dismiss" "";
         }
@@ -3079,7 +3080,7 @@ collections {
       }
       programs {
         program { name: "end";
-           signal: "mouse,down,1";
+           signal: "mouse,up,1";
            source: "base";
            action: SIGNAL_EMIT "elm,action,dismiss" "";
         }
@@ -3362,7 +3363,7 @@ collections {
       }
       programs {
         program { name: "end";
-           signal: "mouse,down,1";
+           signal: "mouse,up,1";
            source: "base";
            action: SIGNAL_EMIT "elm,action,dismiss" "";
         }
index 53b8805..bf26e43 100644 (file)
@@ -312,6 +312,21 @@ extern "C" {
     * "clicked" - the user clicked the icon
     */
 
+   typedef enum _Elm_Icon_Type
+     {
+        ELM_ICON_NONE,
+        ELM_ICON_FILE,
+        ELM_ICON_STANDARD
+     } Elm_Icon_Type;
+   typedef struct _Elm_Hoversel_Item Elm_Hoversel_Item;
+   EAPI Evas_Object *elm_hoversel_add(Evas_Object *parent);
+   EAPI void         elm_hoversel_hover_parent_set(Evas_Object *obj, Evas_Object *parent);
+   EAPI void         elm_hoversel_label_set(Evas_Object *obj, const char *label);
+   EAPI void         elm_hoversel_icon_set(Evas_Object *obj, Evas_Object *icon);
+   EAPI void         elm_hoversel_hover_end(Evas_Object *obj);
+   EAPI Elm_Hoversel_Item *elm_hoversel_item_add(Evas_Object *obj, const char *label, const char *icon_file, Elm_Icon_Type icon_type, void (*func) (void *data, Evas_Object *obj, void *event_info), const void *data);
+   EAPI void         elm_hoversel_item_del(Elm_Hoversel_Item *item);
+              
   ////////////////////////////////////////////////////////////////////////////
  /// FIXME: TODO LIST ///////////////////////////////////////////////////////
 ////////////////////////////////////////////////////////////////////////////
index 60923fe..d863121 100644 (file)
@@ -2,12 +2,23 @@
 #include "elm_priv.h"
 
 typedef struct _Widget_Data Widget_Data;
+typedef struct _Item Item;
 
 struct _Widget_Data
 {
    Evas_Object *btn, *hover;
    Evas_Object *hover_parent;
-   const char *hover_style;
+   Evas_List *items;
+};
+
+struct _Item
+{
+   Evas_Object *obj;
+   const char *label;
+   const char *icon_file;
+   Elm_Icon_Type icon_type;
+   void (*func) (void *data, Evas_Object *obj, void *event_info);
+   const void *data;
 };
 
 static void _del_pre_hook(Evas_Object *obj);
@@ -27,7 +38,7 @@ static void
 _del_hook(Evas_Object *obj)
 {
    Widget_Data *wd = elm_widget_data_get(obj);
-   if (wd->hover_style) eina_stringshare_del(wd->hover_style);
+   elm_hoversel_hover_end(obj);
    free(wd);
 }
 
@@ -56,10 +67,20 @@ _hover_clicked(void *data, Evas_Object *obj, void *event_info)
 }
 
 static void
+_item_clicked(void *data, Evas_Object *obj, void *event_info)
+{
+   Item *it = data;
+   Evas_Object *obj2 = it->obj;
+   if (it->func) it->func(it->data, obj2, NULL);
+   elm_hoversel_hover_end(obj2);
+}
+
+static void
 _button_clicked(void *data, Evas_Object *obj, void *event_info)
 {
    Widget_Data *wd = elm_widget_data_get(data);
    Evas_Object *bt, *bx, *ic;
+   Eina_List *l;
    wd->hover = elm_hover_add(data);
    elm_hover_style_set(wd->hover, "hoversel_vertical");
    evas_object_smart_callback_add(wd->hover, "clicked", _hover_clicked, data);
@@ -69,15 +90,20 @@ _button_clicked(void *data, Evas_Object *obj, void *event_info)
    bx = elm_box_add(wd->hover);
    elm_box_homogenous_set(bx, 1);
    
-   bt = elm_button_add(wd->hover);
-   elm_button_style_set(bt, "hoversel_vertical_entry");
-   elm_button_label_set(bt, "Forward");
-   evas_object_size_hint_weight_set(bt, 1.0, 0.0);
-   evas_object_size_hint_align_set(bt, -1.0, -1.0);
-   elm_box_pack_end(bx, bt);
-   evas_object_show(bt);
-   
-   // FIXME: fill.
+   for (l = wd->items; l; l = l->next)
+     {
+        Item *it = l->data;
+        bt = elm_button_add(wd->hover);
+        elm_button_style_set(bt, "hoversel_vertical_entry");
+        elm_button_label_set(bt, it->label);
+// FIXME: add icon        
+//        elm_button_icon_set(bt, it->icon_file);
+        evas_object_size_hint_weight_set(bt, 1.0, 0.0);
+        evas_object_size_hint_align_set(bt, -1.0, -1.0);
+        elm_box_pack_end(bx, bt);
+        evas_object_smart_callback_add(bt, "clicked", _item_clicked, it);
+        evas_object_show(bt);
+     }
 
    elm_hover_content_set
      (wd->hover,
@@ -152,21 +178,30 @@ elm_hoversel_hover_end(Evas_Object *obj)
    wd->hover = NULL;
 }
 
-EAPI void * // FIXME: return some sort of handle other than void *
-elm_hoversel_item_add(Evas_Object *obj, const char *label, const char *icon_file, int icon_type, void (*func) (void *data, Evas_Object *obj, void *event_into), const void *data)
+EAPI Elm_Hoversel_Item *
+elm_hoversel_item_add(Evas_Object *obj, const char *label, const char *icon_file, Elm_Icon_Type icon_type, void (*func) (void *data, Evas_Object *obj, void *event_info), const void *data)
 {
    Widget_Data *wd = elm_widget_data_get(obj);
-   // FIXME: implement
+   Item *it = calloc(1, sizeof(Item));
+   if (!it) return NULL;
+   wd->items = eina_list_append(wd->items, it);
+   it->obj = obj;
+   it->label = eina_stringshare_add(label);
+   it->icon_file = eina_stringshare_add(icon_file);
+   it->icon_type = icon_type;
+   it->func = func;
+   it->data = data;
+   return (Elm_Hoversel_Item *)it;
 }
 
 EAPI void
-elm_hoversel_item_del(void *item)
-{
-   // FIXME: implement
-}
-
-EAPI void
-elm_hoversel_item_enabled_set(void *item, Evas_Bool enabled)
-{
-   // FIXME: implement
+elm_hoversel_item_del(Elm_Hoversel_Item *item)
+{
+   Item *it = (Item *)item;
+   Widget_Data *wd = elm_widget_data_get(it->obj);
+   wd->items = eina_list_remove(wd->items, it);
+   eina_stringshare_del(it->label);
+   eina_stringshare_del(it->icon_file);
+   free(it);
+   // FIXME: if hover up - this will be bad and break
 }