+#ifdef HAVE_CONFIG_H
+# include "elementary_config.h"
+#endif
+
+#define ELM_INTERFACE_ATSPI_ACCESSIBLE_PROTECTED
+
#include <Elementary.h>
+
#include "elm_priv.h"
#include "elm_widget_plug.h"
-EAPI const char ELM_PLUG_SMART_NAME[] = "elm_plug";
+#define MY_CLASS ELM_PLUG_CLASS
+
+#define MY_CLASS_NAME "Elm_Plug"
+#define MY_CLASS_NAME_LEGACY "elm_plug"
static const char PLUG_KEY[] = "__Plug_Ecore_Evas";
static const char SIG_CLICKED[] = "clicked";
-static const char SIG_IMAGE_DELETED[] = "image.deleted";
+static const char SIG_IMAGE_DELETED[] = "image,deleted";
+static const char SIG_IMAGE_RESIZED[] = "image,resized";
+//TIZEN_ONLY(20150205): Added for indicator
static const char SIG_MESSAGE_RECEIVED[] = "message.received";
+//
static const Evas_Smart_Cb_Description _smart_callbacks[] = {
{SIG_CLICKED, ""},
{SIG_IMAGE_DELETED, ""},
+ //TIZNE_ONLY(20150205): Added for indicator
{SIG_MESSAGE_RECEIVED, ""},
+ //
+ {SIG_IMAGE_RESIZED, "ii"},
{NULL, NULL}
};
-EVAS_SMART_SUBCLASS_NEW
- (ELM_PLUG_SMART_NAME, _elm_plug, Elm_Plug_Smart_Class,
- Elm_Widget_Smart_Class, elm_widget_smart_class_get, _smart_callbacks);
-
static void
-_sizing_eval(Evas_Object *obj __UNUSED__)
+_sizing_eval(Evas_Object *obj EINA_UNUSED)
{
//Evas_Coord minw = -1, minh = -1, maxw = -1, maxh = -1;
static void
_elm_plug_disconnected(Ecore_Evas *ee)
{
- Evas_Object *plug = NULL;
-
- if (!ee) return;
- plug = ecore_evas_data_get(ee, PLUG_KEY);
- if (!plug) return;
+ Evas_Object *plug = ecore_evas_data_get(ee, PLUG_KEY);
+ EINA_SAFETY_ON_NULL_RETURN(plug);
evas_object_smart_callback_call(plug, SIG_IMAGE_DELETED, NULL);
+ /* TODO: was a typo. Deprecated, remove in future releases: */
+ evas_object_smart_callback_call(plug, "image.deleted", NULL);
+}
+
+static void
+_elm_plug_resized(Ecore_Evas *ee)
+{
+ Evas_Coord_Size size = {0, 0};
+ Evas_Object *plug = ecore_evas_data_get(ee, PLUG_KEY);
+ EINA_SAFETY_ON_NULL_RETURN(plug);
+
+ ecore_evas_geometry_get(ee, NULL, NULL, &(size.w), &(size.h));
+ evas_object_smart_callback_call(plug, SIG_IMAGE_RESIZED, &size);
+}
+
+EOLIAN static Eina_Bool
+_elm_plug_elm_widget_on_focus(Eo *obj, void *sd EINA_UNUSED)
+{
+ Eina_Bool int_ret = EINA_FALSE;
+
+ ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd, EINA_FALSE);
+
+ eo_do_super(obj, MY_CLASS, int_ret = elm_obj_widget_on_focus());
+ if (!int_ret) return EINA_FALSE;
+
+ if (elm_widget_focus_get(obj))
+ {
+ evas_object_focus_set(wd->resize_obj, EINA_TRUE);
+ }
+ else
+ {
+ evas_object_focus_set(wd->resize_obj, EINA_FALSE);
+ }
+
+ return EINA_TRUE;
}
-static Eina_Bool
-_elm_plug_smart_theme(Evas_Object *obj)
+EOLIAN static Eina_Bool
+_elm_plug_elm_widget_theme_apply(Eo *obj, void *sd EINA_UNUSED)
{
- if (!_elm_plug_parent_sc->theme(obj)) return EINA_FALSE;
+ Eina_Bool int_ret = EINA_FALSE;
+ eo_do_super(obj, MY_CLASS, int_ret = elm_obj_widget_theme_apply());
+ if (!int_ret) return EINA_FALSE;
_sizing_eval(obj);
return EINA_TRUE;
}
-static Eina_Bool
-_access_action_release_cb(void *data __UNUSED__,
- Evas_Object *obj __UNUSED__,
- Elm_Access_Action_Info *action_info __UNUSED__)
+static void
+_on_mouse_up(void *data,
+ Evas *e EINA_UNUSED,
+ Evas_Object *obj EINA_UNUSED,
+ void *event_info)
{
- return EINA_FALSE;
+ Evas_Event_Mouse_Up *ev = event_info;
+
+ if (ev->button != 1) return;
+ if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) return;
+
+ evas_object_smart_callback_call(data, SIG_CLICKED, NULL);
}
+EOLIAN static void
+_elm_plug_evas_object_smart_add(Eo *obj, void *sd EINA_UNUSED)
+{
+ Evas_Object *p_obj;
+ Ecore_Evas *ee;
+ ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd);
+
+ eo_do_super(obj, MY_CLASS, evas_obj_smart_add());
+ elm_widget_sub_object_parent_add(obj);
+
+ ee = ecore_evas_ecore_evas_get(evas_object_evas_get(obj));
+ if (!ee) return;
+
+ p_obj = ecore_evas_extn_plug_new(ee);
+ if (!p_obj) return;
+
+ elm_widget_resize_object_set(obj, p_obj, EINA_TRUE);
+
+ evas_object_event_callback_add
+ (wd->resize_obj, EVAS_CALLBACK_MOUSE_UP, _on_mouse_up,
+ obj);
+
+ elm_widget_can_focus_set(obj, EINA_FALSE);
+ _sizing_eval(obj);
+}
+
+EAPI Evas_Object *
+elm_plug_add(Evas_Object *parent)
+{
+ EINA_SAFETY_ON_NULL_RETURN_VAL(parent, NULL);
+ Evas_Object *obj = eo_add(MY_CLASS, parent);
+ return obj;
+}
+
+EOLIAN static void
+_elm_plug_eo_base_constructor(Eo *obj, void *sd EINA_UNUSED)
+{
+ eo_do_super(obj, MY_CLASS, eo_constructor());
+ eo_do(obj,
+ evas_obj_type_set(MY_CLASS_NAME_LEGACY),
+ evas_obj_smart_callbacks_descriptions_set(_smart_callbacks),
+ elm_interface_atspi_accessible_role_set(ELM_ATSPI_ROLE_IMAGE));
+}
+
+EOLIAN static Evas_Object*
+_elm_plug_image_object_get(Eo *obj, void *sd EINA_UNUSED)
+{
+ ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd, NULL);
+ return wd->resize_obj;
+}
+
+////////////////////////////////////////////////////////////////////////////////
+//TIZEN_ONLY(20150205): its for handle ecore_evas msg.
static void
_elm_plug_ecore_evas_msg_handle(Ecore_Evas *ee, int msg_domain, int msg_id, void *data, int size)
{
- Evas_Object *plug, *parent;
+ Evas_Object *plug;
Elm_Plug_Message pm;
if (!data) return;
- DBG("Elm plug receive msg from socket ee=%p msg_domain=%x msg_id=%x size=%d", ee, msg_domain, msg_id, size);
//get plug object form ee
plug = (Evas_Object *)ecore_evas_data_get(ee, PLUG_KEY);
ELM_PLUG_CHECK(plug);
evas_object_smart_callback_call(plug, SIG_MESSAGE_RECEIVED, &pm);
- /* get message from parent */
+//FIXME: Below codes for accessbility feature. its not need yet.
+/*
if (msg_domain == MSG_DOMAIN_CONTROL_ACCESS)
{
if (msg_id == ELM_ACCESS_ACTION_HIGHLIGHT_NEXT ||
ELM_WIDGET_DATA_GET(parent, sd);
if (sd->highlight_root)
{
- /* change highlight root */
plug = parent;
break;
}
- plug = parent;
- parent = elm_widget_parent_get(parent);
+ plug = parent;
+ parent = elm_widget_parent_get(parent);
}
while (parent);
if (msg_id == ELM_ACCESS_ACTION_HIGHLIGHT_NEXT)
- _elm_access_highlight_cycle(plug, ELM_ACCESS_ACTION_HIGHLIGHT_NEXT);
+ _elm_access_highlight_cycle(plug, ELM_ACCESS_ACTION_HIGHLIGHT_NEXT);
else
- _elm_access_highlight_cycle(plug, ELM_ACCESS_ACTION_HIGHLIGHT_PREV);
+ _elm_access_highlight_cycle(plug, ELM_ACCESS_ACTION_HIGHLIGHT_PREV);
}
}
+*/
}
+////////////////////////////////////////////////////////////////////////////////
-static void
-_on_mouse_up(void *data,
- Evas *e __UNUSED__,
- Evas_Object *obj __UNUSED__,
- void *event_info __UNUSED__)
-{
- evas_object_smart_callback_call(data, SIG_CLICKED, NULL);
-}
-
-static void
-_elm_plug_smart_add(Evas_Object *obj)
-{
- EVAS_SMART_DATA_ALLOC(obj, Elm_Plug_Smart_Data);
-
- _elm_plug_parent_sc->base.add(obj);
-}
-
-static Ecore_Evas*
-_elm_plug_ecore_evas_get(Evas_Object *obj)
-{
- Ecore_Evas *ee = NULL;
- Evas_Object *plug_img = NULL;
-
- ELM_PLUG_CHECK(obj) NULL;
-
- plug_img = elm_plug_image_object_get(obj);
- if (!plug_img) return NULL;
-
- ee = ecore_evas_object_ecore_evas_get(plug_img);
- return ee;
-}
-
-static Eina_Bool
-_elm_plug_smart_activate(Evas_Object *obj, Elm_Activate act)
-{
- Ecore_Evas *ee = NULL;
- Elm_Access_Action_Info *action_info = NULL;
- int msg_id = ELM_ACCESS_ACTION_FIRST;
-
- ee = _elm_plug_ecore_evas_get(obj);
- if (!ee) return EINA_FALSE;
-
- switch (act)
- {
- case ELM_ACTIVATE_DEFAULT:
- msg_id = ELM_ACCESS_ACTION_ACTIVATE;
- break;
-
- case ELM_ACTIVATE_UP:
- msg_id = ELM_ACCESS_ACTION_UP;
- break;
-
- case ELM_ACTIVATE_DOWN:
- msg_id = ELM_ACCESS_ACTION_DOWN;
- break;
-
- default:
- return EINA_FALSE;
- }
-
- if (msg_id == ELM_ACCESS_ACTION_FIRST) return EINA_FALSE;
-
- action_info = calloc(1, sizeof(Elm_Access_Action_Info));
- action_info->action_type = msg_id;
-
- ecore_evas_msg_parent_send(ee, MSG_DOMAIN_CONTROL_ACCESS,
- msg_id, action_info, sizeof(Elm_Access_Action_Info));
-
- free(action_info);
- return EINA_TRUE;
-}
-
-static void
-_elm_plug_smart_set_user(Elm_Plug_Smart_Class *sc)
-{
- ELM_WIDGET_CLASS(sc)->base.add = _elm_plug_smart_add;
-
- ELM_WIDGET_CLASS(sc)->theme = _elm_plug_smart_theme;
- ELM_WIDGET_CLASS(sc)->activate = _elm_plug_smart_activate;
-}
-
-EAPI const Elm_Plug_Smart_Class *
-elm_plug_smart_class_get(void)
-{
- static Elm_Plug_Smart_Class _sc =
- ELM_PLUG_SMART_CLASS_INIT_NAME_VERSION(ELM_PLUG_SMART_NAME);
- static const Elm_Plug_Smart_Class *class = NULL;
-
- if (class) return class;
-
- _elm_plug_smart_set(&_sc);
- class = &_sc;
-
- return class;
-}
-
-static Eina_Bool
-_access_action_highlight_next_cb(void *data __UNUSED__,
- Evas_Object *obj,
- Elm_Access_Action_Info *action_info)
-{
- Ecore_Evas *ee = NULL;
-
- ee = _elm_plug_ecore_evas_get(obj);
- if (!ee) return EINA_TRUE;
-
- ecore_evas_msg_parent_send(ee, MSG_DOMAIN_CONTROL_ACCESS,
- action_info->action_type,
- action_info, sizeof(Elm_Access_Action_Info));
- return EINA_TRUE;
-}
-
-static Eina_Bool
-_access_action_cb(void *data __UNUSED__,
- Evas_Object *obj,
- Elm_Access_Action_Info *action_info)
-{
- Evas_Coord_Point pos = {0, 0};
- Ecore_Evas *ee = NULL;
-
- ee = _elm_plug_ecore_evas_get(obj);
- if (!ee) return EINA_FALSE;
-
- if (action_info->action_type == ELM_ACCESS_ACTION_HIGHLIGHT)
- {
- elm_access_action_cb_set(obj, ELM_ACCESS_ACTION_HIGHLIGHT_NEXT,
- _access_action_highlight_next_cb, NULL);
- elm_access_action_cb_set(obj, ELM_ACCESS_ACTION_HIGHLIGHT_PREV,
- _access_action_highlight_next_cb, NULL);
- }
- else if (action_info->action_type == ELM_ACCESS_ACTION_READ ||
- action_info->action_type == ELM_ACCESS_ACTION_OVER ||
- action_info->action_type == ELM_ACCESS_ACTION_SCROLL ||
- action_info->action_type == ELM_ACCESS_ACTION_MOUSE)
- {
- evas_object_geometry_get(obj, &pos.x, &pos.y, NULL, NULL);
- action_info->x = action_info->x - pos.x;
- action_info->y = action_info->y - pos.y;
- }
-
- ecore_evas_msg_parent_send(ee, MSG_DOMAIN_CONTROL_ACCESS,
- action_info->action_type,
- action_info, sizeof(Elm_Access_Action_Info));
-
- if (action_info->action_type == ELM_ACCESS_ACTION_SCROLL)
- return EINA_FALSE;
-
- return EINA_TRUE;
-}
-
-EAPI Evas_Object *
-elm_plug_add(Evas_Object *parent)
-{
- Evas_Object *obj;
- Evas_Object *p_obj;
- Ecore_Evas *ee;
-
- EINA_SAFETY_ON_NULL_RETURN_VAL(parent, NULL);
-
- obj = elm_widget_add(_elm_plug_smart_class_new(), parent);
- if (!obj) return NULL;
-
- if (!elm_widget_sub_object_add(parent, obj))
- ERR("could not add %p as sub object of %p", obj, parent);
-
- ELM_PLUG_DATA_GET(obj, sd);
- ELM_WIDGET_DATA_GET(obj, wsd);
-
- ee = ecore_evas_ecore_evas_get(evas_object_evas_get(obj));
- if (ee)
- {
- p_obj = ecore_evas_extn_plug_new(ee);
- elm_widget_resize_object_set(obj, p_obj, EINA_TRUE);
- }
-
- evas_object_event_callback_add
- (wsd->resize_obj, EVAS_CALLBACK_MOUSE_UP, _on_mouse_up, obj);
-
- elm_widget_can_focus_set(obj, EINA_FALSE);
- _sizing_eval(obj);
-
- _elm_access_object_register(obj, ELM_WIDGET_DATA(sd)->resize_obj);
- elm_access_action_cb_set(obj, ELM_ACCESS_ACTION_HIGHLIGHT,
- _access_action_cb, NULL);
- elm_access_action_cb_set(obj, ELM_ACCESS_ACTION_UNHIGHLIGHT,
- _access_action_cb, NULL);
- elm_access_action_cb_set(obj, ELM_ACCESS_ACTION_READ,
- _access_action_cb, NULL);
- elm_access_action_cb_set(obj, ELM_ACCESS_ACTION_OVER,
- _access_action_cb, NULL);
- elm_access_action_cb_set(obj, ELM_ACCESS_ACTION_SCROLL,
- _access_action_cb, NULL);
- elm_access_action_cb_set(obj, ELM_ACCESS_ACTION_MOUSE,
- _access_action_cb, NULL);
-
- //Tizen Only: This should be removed when eo is applied.
- wsd->on_create = EINA_FALSE;
-
- return obj;
-}
-
-EAPI Evas_Object *
-elm_plug_image_object_get(const Evas_Object *obj)
-{
- ELM_PLUG_CHECK(obj) NULL;
- ELM_PLUG_DATA_GET(obj, sd);
-
- return ELM_WIDGET_DATA(sd)->resize_obj;
-}
-
-EAPI Eina_Bool
-elm_plug_connect(Evas_Object *obj,
- const char *svcname,
- int svcnum,
- Eina_Bool svcsys)
+EOLIAN static Eina_Bool
+_elm_plug_connect(Eo *obj, void *sd EINA_UNUSED, const char *svcname, int svcnum, Eina_Bool svcsys)
{
Evas_Object *plug_img = NULL;
ecore_evas_data_set(ee, PLUG_KEY, obj);
ecore_evas_callback_delete_request_set(ee, _elm_plug_disconnected);
+ ////////////////////////////////////////////////////////////////////////
+ //TIZEN_ONLY(20150205): Added for indicator operation.
ecore_evas_callback_msg_handle_set(ee, _elm_plug_ecore_evas_msg_handle);
+ ////////////////////////////////////////////////////////////////////////
+ ecore_evas_callback_resize_set(ee, _elm_plug_resized);
+
return EINA_TRUE;
}
- else
- return EINA_FALSE;
+
+ return EINA_FALSE;
}
-EAPI Eina_Bool
-elm_plug_msg_send(Evas_Object *obj,
- int msg_domain,
- int msg_id,
- void *data, int size)
+EOLIAN static void
+_elm_plug_class_constructor(Eo_Class *klass)
{
- Ecore_Evas *ee = NULL;
- Evas_Object *plug_img = NULL;
-
- ELM_PLUG_CHECK(obj) EINA_FALSE;
-
- plug_img = elm_plug_image_object_get(obj);
- if (!plug_img) return EINA_FALSE;
-
- ee = ecore_evas_object_ecore_evas_get(plug_img);
- if (!ee) return EINA_FALSE;
- ecore_evas_msg_parent_send(ee, msg_domain, msg_id, data, size);
- return EINA_TRUE;
+ evas_smart_legacy_type_register(MY_CLASS_NAME_LEGACY, klass);
}
+
+#include "elm_plug.eo.c"