efl_ui_pan: implement content interface
authorMarcel Hollerbach <mail@marcel-hollerbach.de>
Thu, 24 Jan 2019 13:09:42 +0000 (14:09 +0100)
committerTaehyub Kim <taehyub.kim@samsung.com>
Thu, 31 Jan 2019 02:05:19 +0000 (11:05 +0900)
the last two functions for the content interface have been missing.
Now the pan object can also unset and set new content

ref T5719

Reviewed-by: Cedric BAIL <cedric.bail@free.fr>
Differential Revision: https://phab.enlightenment.org/D7757

src/lib/elementary/efl_ui_pan.c
src/lib/elementary/efl_ui_pan.eo

index 062e94c..b84e0ba 100644 (file)
@@ -156,14 +156,7 @@ _efl_ui_pan_efl_content_content_set(Evas_Object *obj, Efl_Ui_Pan_Data *psd, Evas
    if (content == psd->content) return EINA_TRUE;
    if (psd->content)
      {
-        efl_canvas_group_member_del(obj, psd->content);
-        evas_object_event_callback_del_full
-          (psd->content, EVAS_CALLBACK_DEL, _efl_ui_pan_content_del_cb, obj);
-        evas_object_event_callback_del_full
-          (psd->content, EVAS_CALLBACK_RESIZE, _efl_ui_pan_content_resize_cb,
-          obj);
-        psd->content = NULL;
-        psd->content_w = psd->content_h = psd->px = psd->py = 0;
+        efl_content_unset(obj);
      }
    if (!content) goto end;
 
@@ -189,6 +182,30 @@ end:
    return EINA_TRUE;
 }
 
+EOLIAN static Efl_Gfx_Entity*
+_efl_ui_pan_efl_content_content_get(const Eo *obj EINA_UNUSED, Efl_Ui_Pan_Data *pd)
+{
+   return pd->content;
+}
+
+EOLIAN static Efl_Gfx_Entity*
+_efl_ui_pan_efl_content_content_unset(Eo *obj EINA_UNUSED, Efl_Ui_Pan_Data *pd)
+{
+   Efl_Gfx_Stack *old_content = pd->content;
+
+   efl_canvas_group_member_del(obj, pd->content);
+   evas_object_event_callback_del_full
+     (pd->content, EVAS_CALLBACK_DEL, _efl_ui_pan_content_del_cb, obj);
+   evas_object_event_callback_del_full
+     (pd->content, EVAS_CALLBACK_RESIZE, _efl_ui_pan_content_resize_cb,
+     obj);
+   pd->content = NULL;
+   pd->content_w = pd->content_h = pd->px = pd->py = 0;
+   efl_event_callback_call(obj, EFL_UI_PAN_EVENT_CONTENT_CHANGED, NULL);
+
+   return old_content;
+}
+
 EOLIAN static void
 _efl_ui_pan_efl_canvas_group_group_calculate(Eo *obj EINA_UNUSED, Efl_Ui_Pan_Data *psd)
 {
index bd47b60..907d50b 100644 (file)
@@ -43,7 +43,8 @@ class Efl.Ui.Pan extends Efl.Canvas.Group implements Efl.Content
       Efl.Gfx.Entity.visible { set; }
       Efl.Gfx.Entity.position { set; }
       Efl.Gfx.Entity.size { set; }
-      Efl.Content.content { set; }
+      Efl.Content.content { set; get; }
+      Efl.Content.content_unset;
       Efl.Canvas.Group.group_calculate;
    }
    events {