Support to delegate various MIME types to caller as like voice recording
[platform/core/uifw/inputdelegator.git] / src / w-input-emoticon.cpp
index f0c64f2..4bd585b 100755 (executable)
  * limitations under the License.
  */
 
+#include <app.h>
 #include <app_preference.h>
 #include <Elementary.h>
 #include <string>
 #include <vector>
+#include <stdint.h>
 
 #include <vconf.h>
 #include <vconf-keys.h>
@@ -363,7 +365,7 @@ void set_recent_emoticons(vector <int> &emoticon_list, int val)
 
 static void _emoticon_item_clicked_cb(void *data, Evas_Object * obj, void *event_info)
 {
-    int index = (int)data;
+    int index = (uintptr_t)data;
 
     PRINTFUNC(DLOG_DEBUG, "index = %d", index);
 
@@ -374,13 +376,13 @@ static void _emoticon_item_clicked_cb(void *data, Evas_Object * obj, void *event
     const Eina_Unicode unicode_event[2] = { (Eina_Unicode)emoticon_info[index].code, 0 };
     char* utf_8 = eina_unicode_unicode_to_utf8(unicode_event, &length);
 
-    reply_to_sender_by_callback((const char*)utf_8, "emoticon");
+    reply_to_sender_by_callback((const char*)utf_8, "emoticon", NULL);
 
     PRINTFUNC(SECURE_DEBUG, "[%d]%s", index, utf_8);
     if (utf_8)
         free(utf_8);
 
-    elm_exit();
+    ui_app_exit();
 }
 
 Evas_Object* get_emoticon_button(Evas_Object* parent, int index){
@@ -402,7 +404,7 @@ Evas_Object* get_emoticon_button(Evas_Object* parent, int index){
 
      evas_object_layer_set(btn, 32000);
 
-     evas_object_smart_callback_add(btn, "clicked", _emoticon_item_clicked_cb, (void *)index);
+     evas_object_smart_callback_add(btn, "clicked", _emoticon_item_clicked_cb, (void *)(uintptr_t)index);
 
      return btn;
 }
@@ -421,13 +423,13 @@ Evas_Object* get_recent_emoticon_button(Evas_Object* parent, int index){
      char* utf_8 = eina_unicode_unicode_to_utf8(unicode_event, &length);
      elm_object_part_text_set(btn, "elm.text", utf_8);
 
-     evas_object_data_set(btn, "index", (void*) recent_emoji_list.at(index));
+     evas_object_data_set(btn, "index", (void*)(uintptr_t) recent_emoji_list.at(index));
 
      if (utf_8)
          free(utf_8);
 
      evas_object_layer_set(btn, 32000);
-     evas_object_smart_callback_add(btn, "clicked", _emoticon_item_clicked_cb, (void*) recent_emoji_list.at(index));
+     evas_object_smart_callback_add(btn, "clicked", _emoticon_item_clicked_cb, (void*)(uintptr_t) recent_emoji_list.at(index));
 
      return btn;
 }
@@ -460,7 +462,7 @@ static void _emoticon_gl_content_unswallowed_cb(void *data, Evas_Object *obj, vo
 
 //      PRINTFUNC(DLOG_DEBUG,"%s - stype[%s]", __func__, itc->item_style);
     if (!strcmp(itc->item_style, "3button_flat")) {
-        int index = (int)elm_object_item_data_get(it);
+        int index = (uintptr_t)elm_object_item_data_get(it);
         //PRINTFUNC(DLOG_DEBUG,"it = %p", it);
         PRINTFUNC(DLOG_DEBUG, "index = %d %d %d", index, index+1, index+2);
 
@@ -474,7 +476,7 @@ static void _emoticon_gl_content_unswallowed_cb(void *data, Evas_Object *obj, vo
             emoticon_contents_pool[index+2].used = 0;
         }
     } else if (!strcmp(itc->item_style, "3button_flat_recent")) {
-        unsigned int index = (int)elm_object_item_data_get(it);
+        unsigned int index = (uintptr_t)elm_object_item_data_get(it);
         //PRINTFUNC(DLOG_DEBUG,"index = %d",index);
 
         if (index < recent_emoji_list.size()) {
@@ -492,7 +494,7 @@ static void _emoticon_gl_content_unswallowed_cb(void *data, Evas_Object *obj, vo
 static Evas_Object * __emoticon_gl_recent_content_get(void *data, Evas_Object *obj, const char *part)
 {
     if (is_content_reuse_on) {
-        unsigned int index = (unsigned int)data;
+        unsigned int index = (uintptr_t)data;
         int new_index = 0;
 
     //PRINTFUNC(DLOG_DEBUG,"%s %d", part, index);
@@ -518,7 +520,7 @@ static Evas_Object * __emoticon_gl_recent_content_get(void *data, Evas_Object *o
             return btn;
         }
     } else {
-        unsigned int index = (unsigned int)data;
+        unsigned int index = (uintptr_t)data;
         int new_index = 0;
 
     //    PRINTFUNC(DLOG_DEBUG,"%s %d", part, index);
@@ -548,7 +550,7 @@ static Evas_Object * __emoticon_gl_emoticon_content_get(void *data, Evas_Object
     //PRINTFUNC(DLOG_DEBUG,"%s", __func__);
 
     if (is_content_reuse_on) {
-        int index = (int)data;
+        int index = (uintptr_t)data;
         int new_index = 0;
 
         if (!strcmp(part, "elm.icon.1") || (!strcmp(part, "elm.icon.2")) || (!strcmp(part, "elm.icon.3"))) {
@@ -575,7 +577,7 @@ static Evas_Object * __emoticon_gl_emoticon_content_get(void *data, Evas_Object
             const Eina_Unicode unicode_event[2] = { (Eina_Unicode)emoticon_info[new_index].code, 0 };
             char* utf_8 = eina_unicode_unicode_to_utf8(unicode_event, &length);
             elm_object_part_text_set(btn, "elm.text", utf_8);
-            evas_object_data_set(btn, "index", (void*)new_index);
+            evas_object_data_set(btn, "index", (void*)(uintptr_t)new_index);
 
             if (utf_8)
                 free(utf_8);
@@ -588,7 +590,7 @@ static Evas_Object * __emoticon_gl_emoticon_content_get(void *data, Evas_Object
             return btn;
         }
     } else {
-        int index = (int)data;
+        int index = (uintptr_t)data;
         int new_index = 0;
 
         if (!strcmp(part, "elm.icon.1") ||  (!strcmp(part, "elm.icon.2")) ||  (!strcmp(part, "elm.icon.3"))) {
@@ -722,7 +724,7 @@ static Eina_Bool _lazy_loader_cb_for_items(void *data)
     int i;
     for (i = loading_done_for_item; i < loading_top; i++ ) {
         if (i%3 == 0)
-            elm_genlist_item_append(gl, itc_emoticon, (void*)i, NULL, ELM_GENLIST_ITEM_NONE, NULL, (void *)i);
+            elm_genlist_item_append(gl, itc_emoticon, (void*)(uintptr_t)i, NULL, ELM_GENLIST_ITEM_NONE, NULL, (void *)(uintptr_t)i);
     }
 
     loading_done_for_item = loading_top;
@@ -739,7 +741,7 @@ void _create_reusable_contents(Evas_Object *gl){
 
     for (i = 0; i < INITAL_ITEM_UNIT; i++ ) {
         if (i%3 == 0)
-            elm_genlist_item_append(gl, itc_emoticon, (void*)i, NULL, ELM_GENLIST_ITEM_NONE, NULL, (void *)i);
+            elm_genlist_item_append(gl, itc_emoticon, (void*)(uintptr_t)i, NULL, ELM_GENLIST_ITEM_NONE, NULL, (void *)(uintptr_t)i);
     }
 
     lazy_loading_timer_for_items = ecore_timer_add(0.1, _lazy_loader_cb_for_items, (void *)gl);
@@ -756,16 +758,20 @@ Evas_Object* _create_emoticon_genlist(void* data)
     if (NULL == genlist)
         return NULL;
 
-    Evas_Object* circle_object_genlist = eext_circle_object_genlist_add(genlist, ad->circle_surface);
-    eext_circle_object_genlist_scroller_policy_set(circle_object_genlist, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
-    evas_object_data_set(genlist, "circle", (void *) circle_object_genlist);
-    eext_rotary_object_event_activated_set(circle_object_genlist, EINA_TRUE);
-
+    if (_WEARABLE) {
+        Evas_Object* circle_object_genlist = eext_circle_object_genlist_add(genlist, ad->circle_surface);
+        eext_circle_object_genlist_scroller_policy_set(circle_object_genlist, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
+        evas_object_data_set(genlist, "circle", (void *) circle_object_genlist);
+        eext_rotary_object_event_activated_set(circle_object_genlist, EINA_TRUE);
+    }
     evas_object_size_hint_weight_set(genlist, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
     evas_object_size_hint_align_set(genlist, EVAS_HINT_FILL, EVAS_HINT_FILL);
     evas_object_show(genlist);
 
-    Elm_Object_Item *nf_emoticon_item = elm_naviframe_item_push(ad->naviframe, NULL, NULL, NULL, genlist, "empty");
+    const char *item_style = NULL;
+    if (_WEARABLE)
+        item_style = "empty";
+    Elm_Object_Item *nf_emoticon_item = elm_naviframe_item_push(ad->naviframe, NULL, NULL, NULL, genlist, item_style);
 
     elm_naviframe_item_pop_cb_set(nf_emoticon_item, _custom_back_cb2, ad);
 
@@ -842,7 +848,7 @@ void _update_emoticon_items(void *data)
 
         for (i=0;i < recent_emoji_list.size();i=i+3)
         {
-            it = elm_genlist_item_append(gl, itc_recent, (void*)i, NULL, ELM_GENLIST_ITEM_NONE, NULL, (void *)i);
+            it = elm_genlist_item_append(gl, itc_recent, (void*)(uintptr_t)i, NULL, ELM_GENLIST_ITEM_NONE, NULL, (void *)(uintptr_t)i);
         }
     }
 
@@ -857,7 +863,7 @@ void _update_emoticon_items(void *data)
     } else {
         // Emoticons
         for (i=0;i< EMOTICON_CNT;i=i+3) {
-            it = elm_genlist_item_append(gl, itc_emoticon, (void*)i, NULL, ELM_GENLIST_ITEM_NONE, NULL, (void *)i);
+            it = elm_genlist_item_append(gl, itc_emoticon, (void*)(uintptr_t)i, NULL, ELM_GENLIST_ITEM_NONE, NULL, (void *)(uintptr_t)i);
             it_last = it;
         }
         elm_genlist_item_class_free(itc_emoticon);