elementary merging.
[framework/uifw/elementary.git] / src / lib / elm_segment_control.c
index 77d4441..cf5ecc8 100644 (file)
@@ -2,6 +2,7 @@
 #include "elm_priv.h"
 
 typedef struct _Widget_Data Widget_Data;
+typedef struct _Elm_Segment_Item Elm_Segment_Item;
 
 struct _Widget_Data
 {
@@ -15,7 +16,7 @@ struct _Widget_Data
 
 struct _Elm_Segment_Item
 {
-   Elm_Widget_Item base;
+   ELM_WIDGET_ITEM;
    Evas_Object *icon;
    const char *label;
    int seg_index;
@@ -78,7 +79,11 @@ _del_hook(Evas_Object *obj)
    wd = elm_widget_data_get(obj);
    if (!wd) return;
 
-   EINA_LIST_FREE(wd->seg_items, it) _item_free(it);
+   EINA_LIST_FREE(wd->seg_items, it)
+     {
+        _item_free(it);
+        elm_widget_item_free(it);
+     }
 
    free(wd);
 }
@@ -105,11 +110,11 @@ _theme_hook(Evas_Object *obj)
 
    EINA_LIST_FOREACH(wd->seg_items, l, it)
      {
-        _elm_theme_object_set(obj, it->base.view, "segment_control",
+        _elm_theme_object_set(obj, VIEW(it), "segment_control",
                               "item", elm_widget_style_get(obj));
-        edje_object_scale_set(it->base.view, elm_widget_scale_get(it->base.view)
+        edje_object_scale_set(VIEW(it), elm_widget_scale_get(VIEW(it))
                               *_elm_config->scale);
-        edje_object_mirrored_set(it->base.view, rtl);
+        edje_object_mirrored_set(VIEW(it), rtl);
      }
 
    _update_list(wd);
@@ -136,8 +141,8 @@ _elm_list_data_get(const Eina_List *list)
 
    if (it) return NULL;
 
-   edje_object_signal_emit(it->base.view, "elm,state,segment,selected", "elm");
-   return it->base.view;
+   edje_object_signal_emit(VIEW(it), "elm,state,segment,selected", "elm");
+   return VIEW(it);
 }
 
 static Eina_Bool
@@ -179,12 +184,8 @@ _item_free(Elm_Segment_Item *it)
    if (wd->selected_item == it) wd->selected_item = NULL;
    if (wd->seg_items) wd->seg_items = eina_list_remove(wd->seg_items, it);
 
-   elm_widget_item_pre_notify_del(it);
-
    if (it->icon) evas_object_del(it->icon);
    if (it->label) eina_stringshare_del(it->label);
-
-   elm_widget_item_del(it);
 }
 
 static void
@@ -197,7 +198,7 @@ _segment_off(Elm_Segment_Item *it)
    wd = elm_widget_item_data_get(it);
    if (!wd) return;
 
-   edje_object_signal_emit(it->base.view, "elm,state,segment,normal", "elm");
+   edje_object_signal_emit(VIEW(it), "elm,state,segment,normal", "elm");
 
    if (wd->selected_item == it) wd->selected_item = NULL;
 }
@@ -215,10 +216,10 @@ _segment_on(Elm_Segment_Item *it)
 
    if (wd->selected_item) _segment_off(wd->selected_item);
 
-   edje_object_signal_emit(it->base.view, "elm,state,segment,selected", "elm");
+   edje_object_signal_emit(VIEW(it), "elm,state,segment,selected", "elm");
 
    wd->selected_item = it;
-   evas_object_smart_callback_call(wd->obj, SIG_CHANGED, (void *)(unsigned long)it->seg_index);
+   evas_object_smart_callback_call(wd->obj, SIG_CHANGED, it);
 }
 
 static void
@@ -243,8 +244,8 @@ _position_items(Widget_Data *wd)
 
    EINA_LIST_FOREACH(wd->seg_items, l, it)
      {
-        evas_object_move(it->base.view, pos, by);
-        evas_object_resize(it->base.view, wd->item_width, bh);
+        evas_object_move(VIEW(it), pos, by);
+        evas_object_resize(VIEW(it), wd->item_width, bh);
         if (rtl)
           pos -= wd->item_width;
         else
@@ -286,13 +287,13 @@ _mouse_up(void *data, Evas *e __UNUSED__, Evas_Object *obj __UNUSED__,
    if (it == wd->selected_item) return;
 
    ev = event_info;
-   evas_object_geometry_get(it->base.view, &x, &y, &w, &h);
+   evas_object_geometry_get(VIEW(it), &x, &y, &w, &h);
 
    if ((ev->canvas.x >= x) && (ev->output.x <= (x + w)) && (ev->canvas.y >= y)
        && (ev->canvas.y <= (y + h)))
      _segment_on(it);
    else
-     edje_object_signal_emit(it->base.view, "elm,state,segment,normal", "elm");
+     edje_object_signal_emit(VIEW(it), "elm,state,segment,normal", "elm");
 }
 
 static void
@@ -312,7 +313,7 @@ _mouse_down(void *data, Evas *e __UNUSED__, Evas_Object *obj __UNUSED__,
 
    if (it == wd->selected_item) return;
 
-   edje_object_signal_emit(it->base.view, "elm,state,segment,pressed", "elm");
+   edje_object_signal_emit(VIEW(it), "elm,state,segment,pressed", "elm");
 }
 
 static void
@@ -322,20 +323,20 @@ _swallow_item_objects(Elm_Segment_Item *it)
 
    if (it->icon)
      {
-        edje_object_part_swallow(it->base.view, "elm.swallow.icon", it->icon);
-        edje_object_signal_emit(it->base.view, "elm,state,icon,visible", "elm");
+        edje_object_part_swallow(VIEW(it), "elm.swallow.icon", it->icon);
+        edje_object_signal_emit(VIEW(it), "elm,state,icon,visible", "elm");
      }
    else
-     edje_object_signal_emit(it->base.view, "elm,state,icon,hidden", "elm");
+     edje_object_signal_emit(VIEW(it), "elm,state,icon,hidden", "elm");
 
    if (it->label)
      {
-        edje_object_part_text_set(it->base.view, "elm.text", it->label);
-        edje_object_signal_emit(it->base.view, "elm,state,text,visible", "elm");
+        edje_object_part_text_set(VIEW(it), "elm.text", it->label);
+        edje_object_signal_emit(VIEW(it), "elm,state,text,visible", "elm");
      }
    else
-     edje_object_signal_emit(it->base.view, "elm,state,text,hidden", "elm");
-   edje_object_message_signal_process(it->base.view);
+     edje_object_signal_emit(VIEW(it), "elm,state,text,hidden", "elm");
+   edje_object_message_signal_process(VIEW(it));
 }
 
 static void
@@ -354,19 +355,21 @@ _update_list(Widget_Data *wd)
         it->seg_index = 0;
 
         //Set the segment type
-        edje_object_signal_emit(it->base.view,
+        edje_object_signal_emit(VIEW(it),
                                 "elm,type,segment,single", "elm");
 
         //Set the segment state
         if (wd->selected_item == it)
-          edje_object_signal_emit(it->base.view,
+          edje_object_signal_emit(VIEW(it),
                                   "elm,state,segment,selected", "elm");
         else
-          edje_object_signal_emit(it->base.view,
+          edje_object_signal_emit(VIEW(it),
                                   "elm,state,segment,normal", "elm");
 
         if (elm_widget_disabled_get(wd->obj))
-          edje_object_signal_emit(it->base.view, "elm,state,disabled", "elm");
+          edje_object_signal_emit(VIEW(it), "elm,state,disabled", "elm");
+        else
+          edje_object_signal_emit(VIEW(it), "elm,state,enabled", "elm");
 
         _swallow_item_objects(it);
         return;
@@ -381,35 +384,37 @@ _update_list(Widget_Data *wd)
         if (idx == 0)
           {
              if (rtl)
-               edje_object_signal_emit(it->base.view,
+               edje_object_signal_emit(VIEW(it),
                                        "elm,type,segment,right", "elm");
              else
-               edje_object_signal_emit(it->base.view,
+               edje_object_signal_emit(VIEW(it),
                                        "elm,type,segment,left", "elm");
           }
         else if (idx == (wd->item_count - 1))
           {
              if (rtl)
-               edje_object_signal_emit(it->base.view,
+               edje_object_signal_emit(VIEW(it),
                                        "elm,type,segment,left", "elm");
              else
-               edje_object_signal_emit(it->base.view,
+               edje_object_signal_emit(VIEW(it),
                                        "elm,type,segment,right", "elm");
           }
         else
-          edje_object_signal_emit(it->base.view,
+          edje_object_signal_emit(VIEW(it),
                                   "elm,type,segment,middle", "elm");
 
         //Set the segment state
         if (wd->selected_item == it)
-          edje_object_signal_emit(it->base.view,
+          edje_object_signal_emit(VIEW(it),
                                   "elm,state,segment,selected", "elm");
         else
-          edje_object_signal_emit(it->base.view,
+          edje_object_signal_emit(VIEW(it),
                                   "elm,state,segment,normal", "elm");
 
         if (elm_widget_disabled_get(wd->obj))
-          edje_object_signal_emit(it->base.view, "elm,state,disabled", "elm");
+          edje_object_signal_emit(VIEW(it), "elm,state,disabled", "elm");
+        else
+          edje_object_signal_emit(VIEW(it), "elm,state,enabled", "elm");
 
         _swallow_item_objects(it);
         idx++;
@@ -429,6 +434,86 @@ _item_find(const Evas_Object *obj, int idx)
    return it;
 }
 
+static void
+_item_text_set_hook(Elm_Object_Item *it, const char *part, const char *label)
+{
+   Widget_Data *wd;
+   Elm_Segment_Item *item;
+
+   if (part && strcmp(part, "default")) return;
+
+   item = (Elm_Segment_Item *)it;
+   wd = elm_widget_item_data_get(item);
+   if (!wd) return;
+
+   eina_stringshare_replace(&item->label, label);
+   if (item->label)
+     edje_object_signal_emit(VIEW(item), "elm,state,text,visible", "elm");
+   else
+     edje_object_signal_emit(VIEW(item), "elm,state,text,hidden", "elm");
+   edje_object_message_signal_process(VIEW(item));
+   //label can be NULL also.
+   edje_object_part_text_set(VIEW(item), "elm.text", item->label);
+}
+
+static const char *
+_item_text_get_hook(const Elm_Object_Item *it, const char *part)
+{
+   if (part && strcmp(part, "default")) return NULL;
+   return ((Elm_Segment_Item *)it)->label;
+}
+
+static void
+_item_content_set_hook(Elm_Object_Item *it,
+                       const char *part,
+                       Evas_Object *content)
+{
+   Elm_Segment_Item *item;
+
+   if (part && strcmp(part, "icon")) return;
+
+   item = (Elm_Segment_Item *)it;
+
+   //Remove the existing icon
+   if (item->icon)
+     {
+        edje_object_part_unswallow(VIEW(item), item->icon);
+        evas_object_del(item->icon);
+        item->icon = NULL;
+     }
+   item->icon = content;
+   if (item->icon)
+     {
+        elm_widget_sub_object_add(VIEW(item), item->icon);
+        edje_object_part_swallow(VIEW(item), "elm.swallow.icon", item->icon);
+        edje_object_signal_emit(VIEW(item), "elm,state,icon,visible", "elm");
+     }
+   else
+     edje_object_signal_emit(VIEW(item), "elm,state,icon,hidden", "elm");
+}
+
+static Evas_Object *
+_item_content_get_hook(const Elm_Object_Item *it, const char *part)
+{
+   if (part && strcmp(part, "icon")) return NULL;
+   return ((Elm_Segment_Item *)it)->icon;
+}
+
+static Eina_Bool
+_item_del_pre_hook(Elm_Object_Item *it)
+{
+   Widget_Data *wd;
+   Elm_Segment_Item *item = (Elm_Segment_Item *)it;
+
+   wd = elm_widget_item_data_get(item);
+   if (!wd) return EINA_FALSE;
+
+   _item_free(item);
+   _update_list(wd);
+
+   return EINA_TRUE;
+}
+
 static Elm_Segment_Item*
 _item_new(Evas_Object *obj, Evas_Object *icon, const char *label)
 {
@@ -441,35 +526,40 @@ _item_new(Evas_Object *obj, Evas_Object *icon, const char *label)
    it = elm_widget_item_new(obj, Elm_Segment_Item);
    if (!it) return NULL;
    elm_widget_item_data_set(it, wd);
-
-   it->base.view = edje_object_add(evas_object_evas_get(obj));
-   edje_object_scale_set(it->base.view, elm_widget_scale_get(it->base.view)
+   elm_widget_item_del_pre_hook_set(it, _item_del_pre_hook);
+   elm_widget_item_text_set_hook_set(it, _item_text_set_hook);
+   elm_widget_item_text_get_hook_set(it, _item_text_get_hook);
+   elm_widget_item_content_set_hook_set(it, _item_content_set_hook);
+   elm_widget_item_content_get_hook_set(it, _item_content_get_hook);
+
+   VIEW(it) = edje_object_add(evas_object_evas_get(obj));
+   edje_object_scale_set(VIEW(it), elm_widget_scale_get(VIEW(it))
                          *_elm_config->scale);
-   evas_object_smart_member_add(it->base.view, obj);
-   elm_widget_sub_object_add(obj, it->base.view);
-   evas_object_clip_set(it->base.view, evas_object_clip_get(obj));
+   evas_object_smart_member_add(VIEW(it), obj);
+   elm_widget_sub_object_add(obj, VIEW(it));
+   evas_object_clip_set(VIEW(it), evas_object_clip_get(obj));
 
-   _elm_theme_object_set(obj, it->base.view, "segment_control", "item",
+   _elm_theme_object_set(obj, VIEW(it), "segment_control", "item",
                          elm_object_style_get(obj));
-   edje_object_mirrored_set(it->base.view,
-                            elm_widget_mirrored_get(it->base.widget));
+   edje_object_mirrored_set(VIEW(it),
+                            elm_widget_mirrored_get(WIDGET(it)));
 
    if (label)
      eina_stringshare_replace(&it->label, label);
    if (it->label)
-     edje_object_signal_emit(it->base.view, "elm,state,text,visible", "elm");
+     edje_object_signal_emit(VIEW(it), "elm,state,text,visible", "elm");
    else
-     edje_object_signal_emit(it->base.view, "elm,state,text,hidden", "elm");
-   edje_object_message_signal_process(it->base.view);
-   edje_object_part_text_set(it->base.view, "elm.text", label);
+     edje_object_signal_emit(VIEW(it), "elm,state,text,hidden", "elm");
+   edje_object_message_signal_process(VIEW(it));
+   edje_object_part_text_set(VIEW(it), "elm.text", label);
 
    it->icon = icon;
-   if (it->icon) elm_widget_sub_object_add(it->base.view, it->icon);
-   evas_object_event_callback_add(it->base.view, EVAS_CALLBACK_MOUSE_DOWN,
+   if (it->icon) elm_widget_sub_object_add(VIEW(it), it->icon);
+   evas_object_event_callback_add(VIEW(it), EVAS_CALLBACK_MOUSE_DOWN,
                                   _mouse_down, it);
-   evas_object_event_callback_add(it->base.view, EVAS_CALLBACK_MOUSE_UP,
+   evas_object_event_callback_add(VIEW(it), EVAS_CALLBACK_MOUSE_UP,
                                   _mouse_up, it);
-   evas_object_show(it->base.view);
+   evas_object_show(VIEW(it));
 
    return it;
 }
@@ -514,7 +604,7 @@ elm_segment_control_add(Evas_Object *parent)
    return obj;
 }
 
-EAPI Elm_Segment_Item *
+EAPI Elm_Object_Item *
 elm_segment_control_item_add(Evas_Object *obj, Evas_Object *icon,
                              const char *label)
 {
@@ -531,10 +621,10 @@ elm_segment_control_item_add(Evas_Object *obj, Evas_Object *icon,
    wd->seg_items = eina_list_append(wd->seg_items, it);
    _update_list(wd);
 
-   return it;
+   return (Elm_Object_Item *)it;
 }
 
-EAPI Elm_Segment_Item *
+EAPI Elm_Object_Item *
 elm_segment_control_item_insert_at(Evas_Object *obj, Evas_Object *icon,
                                    const char *label, int idx)
 {
@@ -556,20 +646,13 @@ elm_segment_control_item_insert_at(Evas_Object *obj, Evas_Object *icon,
      wd->seg_items = eina_list_append(wd->seg_items, it);
 
    _update_list(wd);
-   return it;
+   return (Elm_Object_Item *)it;
 }
 
 EAPI void
-elm_segment_control_item_del(Elm_Segment_Item *it)
+elm_segment_control_item_del(Elm_Object_Item *it)
 {
-   ELM_WIDGET_ITEM_WIDTYPE_CHECK_OR_RETURN(it);
-   Widget_Data *wd;
-
-   wd = elm_widget_item_data_get(it);
-   if (!wd) return;
-
-   _item_free(it);
-   _update_list(wd);
+   elm_object_item_del(it);
 }
 
 EAPI void
@@ -584,75 +667,37 @@ elm_segment_control_item_del_at(Evas_Object *obj, int idx)
 
    it = _item_find(obj, idx);
    if (!it) return;
-   _item_free(it);
-   _update_list(wd);
+   elm_object_item_del((Elm_Object_Item *)it);
 }
 
 EAPI const char*
 elm_segment_control_item_label_get(const Evas_Object *obj, int idx)
 {
    ELM_CHECK_WIDTYPE(obj, widtype) NULL;
-   Elm_Segment_Item *it;
-
-   it = _item_find(obj, idx);
+   Elm_Segment_Item *it = _item_find(obj, idx);
    if (it) return it->label;
-
    return NULL;
 }
 
 EAPI void
-elm_segment_control_item_label_set(Elm_Segment_Item* it, const char* label)
+elm_segment_control_item_label_set(Elm_Object_Item* it, const char* label)
 {
-   ELM_WIDGET_ITEM_WIDTYPE_CHECK_OR_RETURN(it);
-   Widget_Data *wd;
-
-   wd = elm_widget_item_data_get(it);
-   if (!wd) return;
-
-   eina_stringshare_replace(&it->label, label);
-   if (it->label)
-     edje_object_signal_emit(it->base.view, "elm,state,text,visible", "elm");
-   else
-     edje_object_signal_emit(it->base.view, "elm,state,text,hidden", "elm");
-   edje_object_message_signal_process(it->base.view);
-   //label can be NULL also.
-   edje_object_part_text_set(it->base.view, "elm.text", it->label);
+   _item_text_set_hook(it, NULL, label);
 }
 
 EAPI Evas_Object *
 elm_segment_control_item_icon_get(const Evas_Object *obj, int idx)
 {
    ELM_CHECK_WIDTYPE(obj, widtype) NULL;
-   Elm_Segment_Item *it;
-
-   it = _item_find(obj, idx);
+   Elm_Segment_Item *it = _item_find(obj, idx);
    if (it) return it->icon;
-
    return NULL;
 }
 
 EAPI void
-elm_segment_control_item_icon_set(Elm_Segment_Item *it, Evas_Object *icon)
+elm_segment_control_item_icon_set(Elm_Object_Item *it, Evas_Object *icon)
 {
-   ELM_WIDGET_ITEM_WIDTYPE_CHECK_OR_RETURN(it);
-
-   //Remove the existing icon
-   if (it->icon)
-     {
-        edje_object_part_unswallow(it->base.view, it->icon);
-        evas_object_del(it->icon);
-        it->icon = NULL;
-     }
-
-   it->icon = icon;
-   if (it->icon)
-     {
-        elm_widget_sub_object_add(it->base.view, it->icon);
-        edje_object_part_swallow(it->base.view, "elm.swallow.icon", it->icon);
-        edje_object_signal_emit(it->base.view, "elm,state,icon,visible", "elm");
-     }
-   else
-     edje_object_signal_emit(it->base.view, "elm,state,icon,hidden", "elm");
+   _item_content_set_hook(it, NULL, icon);
 }
 
 EAPI int
@@ -668,63 +713,55 @@ elm_segment_control_item_count_get(const Evas_Object *obj)
 }
 
 EAPI Evas_Object*
-elm_segment_control_item_object_get(const Elm_Segment_Item *it)
+elm_segment_control_item_object_get(const Elm_Object_Item *it)
 {
-   ELM_WIDGET_ITEM_WIDTYPE_CHECK_OR_RETURN(it, NULL);
-
-   return it->base.view;
+   ELM_OBJ_ITEM_CHECK_OR_RETURN(it, NULL);
+   return VIEW(it);
 }
 
-EAPI Elm_Segment_Item*
+EAPI Elm_Object_Item*
 elm_segment_control_item_selected_get(const Evas_Object *obj)
 {
    ELM_CHECK_WIDTYPE(obj, widtype) NULL;
-   Widget_Data *wd;
-
-   wd = elm_widget_data_get(obj);
+   Widget_Data *wd = elm_widget_data_get(obj);
    if (!wd) return NULL;
-
-   return wd->selected_item;
+   return (Elm_Object_Item *) wd->selected_item;
 }
 
 EAPI void
-elm_segment_control_item_selected_set(Elm_Segment_Item *it, Eina_Bool selected)
+elm_segment_control_item_selected_set(Elm_Object_Item *it, Eina_Bool selected)
 {
-   ELM_WIDGET_ITEM_WIDTYPE_CHECK_OR_RETURN(it);
+   ELM_OBJ_ITEM_CHECK_OR_RETURN(it);
    Widget_Data *wd;
+   Elm_Segment_Item *item = (Elm_Segment_Item *)it;
 
-   wd = elm_widget_item_data_get(it);
+   wd = elm_widget_item_data_get(item);
    if (!wd) return;
 
-   if (it == wd->selected_item)
+   if (item == wd->selected_item)
      {
         //already in selected state.
         if (selected) return;
 
         //unselect case
-        _segment_off(it);
+        _segment_off(item);
      }
    else if (selected)
-     _segment_on(it);
+     _segment_on(item);
 
    return;
 }
 
-EAPI Elm_Segment_Item *
+EAPI Elm_Object_Item *
 elm_segment_control_item_get(const Evas_Object *obj, int idx)
 {
    ELM_CHECK_WIDTYPE(obj, widtype) NULL;
-   Elm_Segment_Item *it;
-
-   it = _item_find(obj, idx);
-
-   return it;
+   return (Elm_Object_Item *) _item_find(obj, idx);
 }
 
 EAPI int
-elm_segment_control_item_index_get(const Elm_Segment_Item *it)
+elm_segment_control_item_index_get(const Elm_Object_Item *it)
 {
-   ELM_WIDGET_ITEM_WIDTYPE_CHECK_OR_RETURN(it, -1);
-
-   return it->seg_index;
+   ELM_OBJ_ITEM_CHECK_OR_RETURN(it, -1);
+   return ((Elm_Segment_Item *)it)->seg_index;
 }