make inwin a bit bigger
authorCarsten Haitzler <raster@rasterman.com>
Sun, 25 Jan 2009 23:18:25 +0000 (23:18 +0000)
committerCarsten Haitzler <raster@rasterman.com>
Sun, 25 Jan 2009 23:18:25 +0000 (23:18 +0000)
make list track sub icon/end for deletion and so on.

SVN revision: 38787

data/themes/default.edc
src/lib/elm_list.c

index 88005ec..5eef091 100644 (file)
@@ -4945,8 +4945,8 @@ collections {
         part { name: "elm.swallow.content";
             type: SWALLOW;
            description { state: "default" 0.0;
-               rel1.relative: 0.2 0.2;
-               rel2.relative: 0.8 0.8;
+               rel1.relative: 0.1 0.1;
+               rel2.relative: 0.9 0.9;
            }
         }
       }
index 8ff38fb..7256f5c 100644 (file)
@@ -34,6 +34,10 @@ struct _Item
 static void _del_hook(Evas_Object *obj);
 static void _sizing_eval(Evas_Object *obj);
 static void _on_focus_hook(void *data, Evas_Object *obj);
+static void _changed_size_hints(void *data, Evas *e, Evas_Object *obj, void *event_info);
+static void _sub_del(void *data, Evas_Object *obj, void *event_info);
+
+static void _fix_items(Evas_Object *obj);
 
 static void
 _del_hook(Evas_Object *obj)
@@ -77,6 +81,38 @@ _on_focus_hook(void *data, Evas_Object *obj)
 }
 
 static void
+_changed_size_hints(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+   Widget_Data *wd = elm_widget_data_get(data);
+   _fix_items(data);
+   _sizing_eval(data);
+}
+
+static void 
+_sub_del(void *data, Evas_Object *obj, void *event_info)
+{
+   Widget_Data *wd = elm_widget_data_get(obj);
+   Evas_Object *sub = event_info;
+   Eina_List *l;
+   
+   for (l = wd->items; l; l = l->next)
+     {
+        Item *it = l->data;
+        
+        if ((sub == it->icon) || (sub == it->end))
+          {
+             if (it->icon == sub) it->icon = NULL;
+             if (it->end == sub) it->end = NULL;
+             evas_object_event_callback_del
+               (sub, EVAS_CALLBACK_CHANGED_SIZE_HINTS, _changed_size_hints);
+             _fix_items(obj);
+             _sizing_eval(obj);
+             break;
+          }
+     }
+}
+
+static void
 _mouse_down(void *data, Evas *evas, Evas_Object *obj, void *event_info)
 {
    Item *it = data;
@@ -173,6 +209,18 @@ _item_new(Evas_Object *obj, const char *label, Evas_Object *icon, Evas_Object *e
                                   _mouse_up, it);
    evas_object_size_hint_weight_set(it->base, 1.0, 1.0);
    evas_object_size_hint_align_set(it->base, -1.0, -1.0);
+   if (it->icon)
+     {
+        elm_widget_sub_object_add(obj, it->icon);
+        evas_object_event_callback_add(it->icon, EVAS_CALLBACK_CHANGED_SIZE_HINTS,
+                                       _changed_size_hints, obj);
+     }
+   if (it->end)
+     {
+        elm_widget_sub_object_add(obj, it->end);
+        evas_object_event_callback_add(it->end, EVAS_CALLBACK_CHANGED_SIZE_HINTS,
+                                       _changed_size_hints, obj);
+     }
    return it;
 }
 
@@ -312,6 +360,8 @@ elm_list_add(Evas_Object *parent)
    evas_object_show(wd->box);
 
    wd->mode = ELM_LIST_SCROLL;
+
+   evas_object_smart_callback_add(obj, "sub-object-del", _sub_del, obj);
    
    _sizing_eval(obj);
    return obj;