From ebbfacad13b699713273c44c1fdaeae2a3d9a971 Mon Sep 17 00:00:00 2001 From: ChunEon Park Date: Wed, 14 Mar 2012 13:03:38 +0000 Subject: [PATCH] elementary/ctxpopup - support more common apis elm_object_signal_emit elm_object_signal_callback_add elm_object_signal_callback_del SVN revision: 69336 --- legacy/elementary/src/lib/elc_ctxpopup.c | 45 ++++++++++++++++++++++++ legacy/elementary/src/lib/elc_ctxpopup.h | 5 +++ 2 files changed, 50 insertions(+) diff --git a/legacy/elementary/src/lib/elc_ctxpopup.c b/legacy/elementary/src/lib/elc_ctxpopup.c index 425081bc07..6a6fb74aaf 100644 --- a/legacy/elementary/src/lib/elc_ctxpopup.c +++ b/legacy/elementary/src/lib/elc_ctxpopup.c @@ -140,6 +140,10 @@ static void _content_del(void *data, static void _list_del(Widget_Data *wd); static void _list_new(Evas_Object *obj); static void _remove_items(Widget_Data * wd); +static void _disable_hook(Evas_Object *obj); +static void _signal_emit_hook(Evas_Object *obj, const char *emission, const char *source); +static void _signal_callback_add_hook(Evas_Object *obj, const char *emission, const char *source, Edje_Signal_Cb func_cb, void *data); +static void _signal_callback_del_hook(Evas_Object *obj, const char *emission, const char *source, Edje_Signal_Cb func_cb, void *data); static const char SIG_DISMISSED[] = "dismissed"; @@ -1295,6 +1299,43 @@ _item_del_pre_hook(Elm_Object_Item *it) return EINA_TRUE; } +static void +_disable_hook(Evas_Object *obj) +{ + Eina_List *l; + Elm_Object_Item *it; + + Widget_Data *wd = elm_widget_data_get(obj); + if (!wd) return; + + EINA_LIST_FOREACH(wd->items, l, it) + elm_object_item_disabled_set(it, elm_widget_disabled_get(obj)); +} + +static void +_signal_emit_hook(Evas_Object *obj, const char *emission, const char *source) +{ + Widget_Data *wd = elm_widget_data_get(obj); + if (!wd) return; + edje_object_signal_emit(wd->base, emission, source); +} + +static void +_signal_callback_add_hook(Evas_Object *obj, const char *emission, const char *source, Edje_Signal_Cb func_cb, void *data) +{ + Widget_Data *wd = elm_widget_data_get(obj); + if (!wd) return; + edje_object_signal_callback_add(wd->base, emission, source, func_cb, data); +} + +static void +_signal_callback_del_hook(Evas_Object *obj, const char *emission, const char *source, Edje_Signal_Cb func_cb, void *data) +{ + Widget_Data *wd = elm_widget_data_get(obj); + if (!wd) return; + edje_object_signal_callback_del_full(wd->base, emission, source, func_cb, data); +} + EAPI Evas_Object * elm_ctxpopup_add(Evas_Object *parent) { @@ -1316,6 +1357,10 @@ elm_ctxpopup_add(Evas_Object *parent) elm_widget_content_set_hook_set(obj, _content_set_hook); elm_widget_content_unset_hook_set(obj, _content_unset_hook); elm_widget_content_get_hook_set(obj, _content_get_hook); + elm_widget_disable_hook_set(obj, _disable_hook); + elm_widget_signal_emit_hook_set(obj, _signal_emit_hook); + elm_widget_signal_callback_add_hook_set(obj, _signal_callback_add_hook); + elm_widget_signal_callback_del_hook_set(obj, _signal_callback_del_hook); //Background wd->bg = edje_object_add(e); diff --git a/legacy/elementary/src/lib/elc_ctxpopup.h b/legacy/elementary/src/lib/elc_ctxpopup.h index 8695bda034..bb5934a6bb 100644 --- a/legacy/elementary/src/lib/elc_ctxpopup.h +++ b/legacy/elementary/src/lib/elc_ctxpopup.h @@ -29,9 +29,14 @@ * @li "default" - Title label in the title area * * Supported elm_object common APIs. + * @li elm_object_disabled_set + * @li elm_object_disabled_get * @li elm_object_part_content_set * @li elm_object_part_content_get * @li elm_object_part_content_unset + * @li elm_object_signal_emit + * @li elm_object_signal_callback_add + * @li elm_object_signal_callback_del * * Supported elm_object_item common APIs. * @li elm_object_item_disabled_set