seoz pushed a commit to branch master.

commit 86dfea740d9e98bb47cf48e1e965cf58e1b38e7a
Author: Daniel Juyung Seo <[email protected]>
Date:   Tue Sep 10 14:07:17 2013 +0900

    elm_menu.c: chagned menu item object from edje_object to elm_layout for 
further focus support.
---
 src/lib/elm_menu.c | 143 ++++++++++++++++++++++++++---------------------------
 1 file changed, 71 insertions(+), 72 deletions(-)

diff --git a/src/lib/elm_menu.c b/src/lib/elm_menu.c
index bda563d..3dd7ded 100644
--- a/src/lib/elm_menu.c
+++ b/src/lib/elm_menu.c
@@ -71,24 +71,13 @@ _item_disable_hook(Elm_Object_Item *it)
 
    if (elm_widget_item_disabled_get(item))
      {
-        edje_object_signal_emit(VIEW(item), "elm,state,disabled", "elm");
+        elm_layout_signal_emit(VIEW(item), "elm,state,disabled", "elm");
         if (item->submenu.open) _submenu_hide(item);
      }
    else
-     edje_object_signal_emit(VIEW(item), "elm,state,enabled", "elm");
+     elm_layout_signal_emit(VIEW(item), "elm,state,enabled", "elm");
 
-   edje_object_message_signal_process(VIEW(item));
-}
-
-static void
-_item_sizing_eval(Elm_Menu_Item *item)
-{
-   Evas_Coord minw = -1, minh = -1, maxw = -1, maxh = -1;
-
-   if (!item->separator) elm_coords_finger_size_adjust(1, &minw, 1, &minh);
-   edje_object_size_min_restricted_calc(VIEW(item), &minw, &minh, minw, minh);
-   evas_object_size_hint_min_set(VIEW(item), minw, minh);
-   evas_object_size_hint_max_set(VIEW(item), maxw, maxh);
+   edje_object_message_signal_process(elm_layout_edje_get(VIEW(item)));
 }
 
 static void
@@ -101,7 +90,7 @@ _submenu_sizing_eval(Elm_Menu_Item *parent_it)
    ELM_MENU_DATA_GET_OR_RETURN(WIDGET(parent_it), sd);
 
    EINA_LIST_FOREACH(parent_it->submenu.items, l, item)
-     _item_sizing_eval(item);
+     elm_layout_sizing_eval(VIEW(item));
 
    evas_object_geometry_get
      (parent_it->submenu.location, &x_p, &y_p, &w_p, &h_p);
@@ -161,7 +150,7 @@ _sizing_eval(Evas_Object *obj)
    if (!sd->parent) return;
 
    EINA_LIST_FOREACH(sd->items, l, item)
-     _item_sizing_eval(item);
+     elm_layout_sizing_eval(VIEW(item));
 
    evas_object_geometry_get(sd->location, NULL, NULL, &w_p, &h_p);
    evas_object_geometry_get(sd->parent, &x2, &y2, &w2, &h2);
@@ -213,20 +202,22 @@ _elm_menu_smart_theme(Eo *obj, void *_pd, va_list *list)
      {
         EINA_LIST_FOREACH(l, _l, item)
           {
-             edje_object_mirrored_set(VIEW(item), 
elm_widget_mirrored_get(obj));
              ll = eina_list_append(ll, item->submenu.items);
              if (item->separator)
-               elm_widget_theme_object_set
-                 (obj, VIEW(item), "menu", "separator",
-                 elm_widget_style_get(obj));
+               {
+                  if (!elm_layout_theme_set(VIEW(item), "menu", "separator",
+                                            elm_widget_style_get(obj)))
+                    CRITICAL("Failed to set layout!");
+               }
              else if (item->submenu.bx)
                {
                   if (sd->menu_bar && !item->parent) s = "main_menu_submenu";
                   else s = "item_with_submenu";
 
-                  elm_widget_theme_object_set
-                    (obj, VIEW(item), "menu", s,
-                    elm_widget_style_get(obj));
+                  if (!elm_layout_theme_set(VIEW(item), "menu", s,
+                                            elm_widget_style_get(obj)))
+                    CRITICAL("Failed to set layout!");
+
                   elm_object_item_text_set((Elm_Object_Item *)item,
                                            item->label);
                   if (item->icon_str)
@@ -235,9 +226,10 @@ _elm_menu_smart_theme(Eo *obj, void *_pd, va_list *list)
                }
              else
                {
-                  elm_widget_theme_object_set
-                    (obj, VIEW(item), "menu", "item",
-                    elm_widget_style_get(obj));
+                  if (!elm_layout_theme_set(VIEW(item), "menu", "item",
+                                            elm_widget_style_get(obj)))
+                    CRITICAL("Failed to set layout!");
+
                   elm_object_item_text_set((Elm_Object_Item *)item,
                                            item->label);
                   if (item->icon_str)
@@ -245,9 +237,11 @@ _elm_menu_smart_theme(Eo *obj, void *_pd, va_list *list)
                                                 item->icon_str);
                }
              _item_disable_hook((Elm_Object_Item *)item);
+             /* SEOZ
              edje_object_scale_set
                (VIEW(item), elm_widget_scale_get(obj) *
                elm_config_scale_get());
+               */
           }
      }
 
@@ -272,12 +266,12 @@ _item_text_set_hook(Elm_Object_Item *it,
    eina_stringshare_replace(&item->label, label);
 
    if (label)
-     edje_object_signal_emit(VIEW(item), "elm,state,text,visible", "elm");
+     elm_layout_signal_emit(VIEW(item), "elm,state,text,visible", "elm");
    else
-     edje_object_signal_emit(VIEW(item), "elm,state,text,hidden", "elm");
+     elm_layout_signal_emit(VIEW(item), "elm,state,text,hidden", "elm");
 
-   edje_object_message_signal_process(VIEW(item));
-   edje_object_part_text_set(VIEW(item), "elm.text", label);
+   edje_object_message_signal_process(elm_layout_edje_get(VIEW(item)));
+   elm_layout_text_set(VIEW(item), "elm.text", label);
 
    _sizing_eval(WIDGET(item));
 }
@@ -306,10 +300,8 @@ _item_content_set_hook(Elm_Object_Item *it,
    if (item->content) evas_object_del(item->content);
 
    item->content = content;
-   elm_widget_sub_object_add(WIDGET(item), item->content);
    if (item->content)
-     edje_object_part_swallow
-       (VIEW(item), "elm.swallow.content", item->content);
+     elm_layout_content_set(VIEW(item), "elm.swallow.content", item->content);
 
    _sizing_eval(WIDGET(item));
 }
@@ -488,38 +480,42 @@ _elm_menu_smart_show(Eo *obj EINA_UNUSED, void *_pd, 
va_list *list EINA_UNUSED)
 static void
 _item_obj_create(Elm_Menu_Item *item)
 {
-   VIEW(item) = edje_object_add(evas_object_evas_get(WIDGET(item)));
-   edje_object_mirrored_set(VIEW(item), elm_widget_mirrored_get(WIDGET(item)));
+   VIEW(item) = elm_layout_add(WIDGET(item));
    evas_object_size_hint_weight_set
      (VIEW(item), EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
    evas_object_size_hint_fill_set(VIEW(item), EVAS_HINT_FILL, EVAS_HINT_FILL);
-   elm_widget_theme_object_set
-     (WIDGET(item), VIEW(item), "menu", "item",
-     elm_widget_style_get(WIDGET(item)));
-
-   edje_object_signal_callback_add
-     (VIEW(item), "elm,action,click", "", _menu_item_select_cb, item);
-   edje_object_signal_callback_add
-     (VIEW(item), "elm,action,activate", "", _menu_item_activate_cb, item);
-   edje_object_signal_callback_add
-     (VIEW(item), "elm,action,inactivate", "", _menu_item_inactivate_cb,
-     item);
-   evas_object_show(VIEW(item));
+   if (!elm_layout_theme_set(VIEW(item), "menu", "item",
+                        elm_widget_style_get(WIDGET(item))))
+     CRITICAL("Failed to set layout!");
+   else
+     {
+        elm_layout_signal_callback_add(VIEW(item), "elm,action,click", "",
+                                       _menu_item_select_cb, item);
+        elm_layout_signal_callback_add(VIEW(item), "elm,action,activate", "",
+                                       _menu_item_activate_cb, item);
+        elm_layout_signal_callback_add(VIEW(item), "elm,action,inactivate", "",
+                                       _menu_item_inactivate_cb,
+                                       item);
+        evas_object_show(VIEW(item));
+     }
 }
 
 static void
 _item_separator_obj_create(Elm_Menu_Item *item)
 {
-   VIEW(item) = edje_object_add(evas_object_evas_get(WIDGET(item)));
+   VIEW(item) = elm_layout_add(WIDGET(item));
    evas_object_size_hint_weight_set
      (VIEW(item), EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
    evas_object_size_hint_fill_set(VIEW(item), EVAS_HINT_FILL, EVAS_HINT_FILL);
-   elm_widget_theme_object_set
-     (WIDGET(item), VIEW(item), "menu", "separator",
-     elm_widget_style_get(WIDGET(item)));
-   edje_object_signal_callback_add
-     (VIEW(item), "elm,action,activate", "", _menu_item_activate_cb, item);
-   evas_object_show(VIEW(item));
+   if (!elm_layout_theme_set(VIEW(item), "menu", "separator",
+                             elm_widget_style_get(WIDGET(item))))
+     CRITICAL("Failed to set layout!");
+   else
+     {
+        elm_layout_signal_callback_add
+           (VIEW(item), "elm,action,activate", "", _menu_item_activate_cb, 
item);
+        evas_object_show(VIEW(item));
+     }
 }
 
 static void
@@ -551,23 +547,27 @@ _item_submenu_obj_create(Elm_Menu_Item *item)
      (item->submenu.hv, elm_hover_best_content_location_get
        (item->submenu.hv, ELM_HOVER_AXIS_VERTICAL), item->submenu.bx);
 
-   edje_object_mirrored_set(VIEW(item), elm_widget_mirrored_get(WIDGET(item)));
-
    if (sd->menu_bar && !item->parent)
-     elm_widget_theme_object_set(WIDGET(item), VIEW(item), "menu",
-                                 "main_menu_submenu",
-                                 elm_widget_style_get(WIDGET(item)));
+     {
+        if (!elm_layout_theme_set(VIEW(item), "menu",
+                                  "main_menu_submenu",
+                                  elm_widget_style_get(WIDGET(item))))
+          CRITICAL("Failed to set layout!");
+     }
    else
-     elm_widget_theme_object_set(WIDGET(item), VIEW(item), "menu",
-                                 "item_with_submenu",
-                                 elm_widget_style_get(WIDGET(item)));
+     {
+        if (!elm_layout_theme_set(VIEW(item), "menu",
+                                  "item_with_submenu",
+                                  elm_widget_style_get(WIDGET(item))))
+          CRITICAL("Failed to set layout!");
+     }
 
    elm_object_item_text_set((Elm_Object_Item *)item, item->label);
 
    if (item->icon_str)
      elm_menu_item_icon_name_set((Elm_Object_Item *)item, item->icon_str);
 
-   edje_object_signal_callback_add(VIEW(item), "elm,action,open", "",
+   elm_layout_signal_callback_add(VIEW(item), "elm,action,open", "",
                                    _submenu_open_cb, item);
    evas_object_event_callback_add
      (VIEW(item), EVAS_CALLBACK_MOVE, _item_move_resize_cb, item);
@@ -967,9 +967,8 @@ _item_add(Eo *obj, void *_pd, va_list *list)
    _item_obj_create(subitem);
    elm_object_item_text_set((Elm_Object_Item *)subitem, label);
 
-   elm_widget_sub_object_add(WIDGET(subitem), subitem->content);
-   edje_object_part_swallow
-     (VIEW(subitem), "elm.swallow.content", subitem->content);
+   elm_layout_content_set(VIEW(subitem), "elm.swallow.content",
+                          subitem->content);
 
    if (icon) elm_menu_item_icon_name_set((Elm_Object_Item *)subitem, icon);
 
@@ -1006,12 +1005,12 @@ elm_menu_item_icon_name_set(Elm_Object_Item *it,
         elm_icon_standard_set(item->content, icon)))
      {
         eina_stringshare_replace(&item->icon_str, icon);
-        edje_object_signal_emit(VIEW(item), "elm,state,icon,visible", "elm");
+        elm_layout_signal_emit(VIEW(item), "elm,state,icon,visible", "elm");
      }
    else
-     edje_object_signal_emit(VIEW(item), "elm,state,icon,hidden", "elm");
+     elm_layout_signal_emit(VIEW(item), "elm,state,icon,hidden", "elm");
 
-   edje_object_message_signal_process(VIEW(item));
+   edje_object_message_signal_process(elm_layout_edje_get(VIEW(item)));
    _sizing_eval(WIDGET(item));
 }
 
@@ -1136,15 +1135,15 @@ elm_menu_item_selected_set(Elm_Object_Item *it,
    item->selected = selected;
    if (selected)
      {
-        edje_object_signal_emit(VIEW(item), "elm,state,selected", "elm");
+        elm_layout_signal_emit(VIEW(item), "elm,state,selected", "elm");
         _menu_item_activate_cb(item, NULL, NULL, NULL);
      }
    else
      {
-        edje_object_signal_emit(VIEW(item), "elm,state,unselected", "elm");
+        elm_layout_signal_emit(VIEW(item), "elm,state,unselected", "elm");
         _menu_item_inactivate_cb(item, NULL, NULL, NULL);
      }
-   edje_object_message_signal_process(VIEW(item));
+   edje_object_message_signal_process(elm_layout_edje_get(VIEW(item)));
 }
 
 EAPI Eina_Bool

-- 

------------------------------------------------------------------------------
How ServiceNow helps IT people transform IT departments:
1. Consolidate legacy IT systems to a single system of record for IT
2. Standardize and globalize service processes across IT
3. Implement zero-touch automation to replace manual, redundant tasks
http://pubads.g.doubleclick.net/gampad/clk?id=51271111&iu=/4140/ostg.clktrk

Reply via email to