Fix indentation
[platform/core/uifw/inputdelegator.git] / src / w-input-selector.cpp
index 307af6d..9536088 100755 (executable)
 #include <dlog.h>
 #include <Eina.h>
 #include <string>
-#include <efl_assist.h>
 #include <vconf.h>
 #include <vconf-keys.h>
+#include <stdint.h>
+#include <system_info.h>
 
-//#include "ui_extension.h"
 #include "w-input-selector.h"
 #include "w-input-template.h"
-#include "w-input-smartreply.h"
 #include "w-input-keyboard.h"
 #include "w-input-stt-ise.h"
 #include "w-input-emoticon.h"
-#include "w-input-stt-tos.h"
 
 #include <stt.h>
 
@@ -41,43 +39,72 @@ using namespace std;
 App_Data* app_data = NULL;
 
 InputKeyboardData g_input_keyboard_data;
+InputTypeData g_input_type_data;
 
 static Elm_Object_Item *it_empty;
 static Elm_Object_Item *it_title;
-static Elm_Object_Item *it_plus;
-static int g_smartreply_current_number = 0;    /* currently loaded smartreply number */
-static unsigned int g_template_current_number = 0;     /* currnetly loaded template number */
+
+static unsigned int g_template_item_size = 0;          /* Current Template item size */
 
 Evas_Coord last_step; // 0 ~ 9 for gesture, 10~11 for rotary
 
+tizen_profile_t _get_tizen_profile()
+{
+       static tizen_profile_t profile = TIZEN_PROFILE_UNKNOWN;
+       if (__builtin_expect(profile != TIZEN_PROFILE_UNKNOWN, 1))
+               return profile;
+
+       char *profileName;
+       system_info_get_platform_string("http://tizen.org/feature/profile", &profileName);
+       switch (*profileName)
+       {
+               case 'm':
+               case 'M':
+                       profile = TIZEN_PROFILE_MOBILE;
+                       break;
+               case 'w':
+               case 'W':
+                       profile = TIZEN_PROFILE_WEARABLE;
+                       break;
+               case 't':
+               case 'T':
+                       profile = TIZEN_PROFILE_TV;
+                       break;
+               case 'i':
+               case 'I':
+                       profile = TIZEN_PROFILE_IVI;
+                       break;
+               default: // common or unknown ==> ALL ARE COMMON.
+                       profile = TIZEN_PROFILE_COMMON;
+       }
+       free(profileName);
+
+       return profile;
+}
+
 void _init_app_data(App_Data* app_data);
 static void _app_language_changed(app_event_info_h event_info, void *user_data);
 
-static char *_genlist_text_set_theme_color(const char *str, const char *code);
-
 Evas_Object* _create_genlist(Evas_Object* parent);
-void _create_genlist_items(void* user_data, bool is_type_reply);
+void _create_genlist_items(void* user_data);
+void _create_header_items(void *user_data);
 void _update_genlist_items(void *user_data);
-void _update_smartreply_items(void *user_data);
-void _update_template_items(void *user_data);
+unsigned int _update_template_items(void *user_data);
 static void _popup_close_cb(void *data, Evas_Object *obj, void *event_info);
 static void _popup_back_cb(void *data, Evas_Object *obj, void *event_info);
-
-
+static void input_type_deinit(void);
 
 void _init_app_data(App_Data* app_data)
 {
-    app_data->win_main = NULL;
-    app_data->layout_main = NULL;
-    app_data->conform = NULL;
-    app_data->naviframe = NULL;
-    app_data->genlist = NULL;
+       app_data->win_main = NULL;
+       app_data->layout_main = NULL;
+       app_data->conform = NULL;
+       app_data->naviframe = NULL;
+       app_data->genlist = NULL;
 
-    app_data->res_path = NULL;
+       app_data->res_path = NULL;
 }
 
-
-
 Evas_Object* load_edj(Evas_Object* parent, const char* file, const char* group)
 {
        Evas_Object* window;
@@ -98,7 +125,6 @@ Evas_Object* load_edj(Evas_Object* parent, const char* file, const char* group)
 
                evas_object_size_hint_weight_set(window, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
        }
-
        return window;
 }
 
@@ -107,8 +133,13 @@ void init_customizing_theme(void)
        string stt_edj_path = get_resource_path();
        string app_edj_path = get_resource_path();
 
-       stt_edj_path = stt_edj_path + STT_EDJ_FILE;
-       app_edj_path = app_edj_path + APP_EDJ_FILE;
+       if (_WEARABLE) {
+               stt_edj_path = stt_edj_path + STT_EDJ_FILE_WEARABLE;
+               app_edj_path = app_edj_path + APP_EDJ_FILE_WEARABLE;
+       } else if (_MOBILE) {
+               stt_edj_path = stt_edj_path + STT_EDJ_FILE_MOBILE;
+               app_edj_path = app_edj_path + APP_EDJ_FILE_MOBILE;
+       }
 
        elm_theme_extension_add(NULL, stt_edj_path.c_str());
        elm_theme_extension_add(NULL, app_edj_path.c_str());
@@ -117,9 +148,9 @@ void init_customizing_theme(void)
 
 static Eina_Bool back_cb(void *data, Elm_Object_Item *it)
 {
-    reply_to_sender_by_callback_for_back();
-    elm_exit();
-    return EINA_FALSE;
+       reply_to_sender_by_callback_for_back();
+       elm_exit();
+       return EINA_FALSE;
 }
 
 static void _stt_clicked_cb(void *data, Evas_Object * obj, void *event_info)
@@ -128,29 +159,10 @@ static void _stt_clicked_cb(void *data, Evas_Object * obj, void *event_info)
 
        PRINTFUNC(DLOG_DEBUG, "");
 
-       if(!ad)
+       if (!ad)
                return;
 
-#if 0
-       bool bAgreed = false;
-       stt_get_user_agreement(&bAgreed);
-       if(!bAgreed){
-#endif
-       if(is_tos_N66_agreed() == EINA_FALSE){
-               if(is_sap_connection() == EINA_TRUE){
-                       ise_show_tos_n66_popup(ad);
-               } else {
-                       launch_bt_connection_popup(ad);
-               }
-       } else {
-               ise_show_stt_popup(ad);
-       }
-}
-
-static void _input_smartreply_notify_cb(void *user_data)
-{
-       ecore_main_loop_iterate();
-       _update_genlist_items((void *)app_data);
+       ise_show_stt_popup(ad);
 }
 
 static void _input_template_notify_cb(void *user_data)
@@ -158,18 +170,16 @@ static void _input_template_notify_cb(void *user_data)
        _update_genlist_items((void *)app_data);
 }
 
-
 static void _emoticon_clicked_cb(void *data, Evas_Object * obj, void *event_info)
 {
        App_Data* ad = (App_Data*)data;
 
        PRINTFUNC(DLOG_DEBUG, "");
 
-       if(!ad)
+       if (!ad)
                return;
 
-//     ise_show_emoticon_popup(ad);
-       ise_show_emoticon_popup_rotary(ad);
+       ise_show_emoticon_list(ad);
 }
 
 static void _keyboard_clicked_cb(void *data, Evas_Object * obj, void *event_info)
@@ -184,97 +194,144 @@ static void _keyboard_clicked_cb(void *data, Evas_Object * obj, void *event_info
        input_keyboard_launch(ad->win_main, data);
 }
 
-static void __bt_connection_result_cb(app_control_h request, app_control_h reply, app_control_result_e result, void *user_data)
-{
-       char *val = NULL;
-
-       if (reply == NULL) {
-               PRINTFUNC(DLOG_ERROR, "service_h is NULL");
-               return;
-       }
-
-       app_control_get_extra_data(reply, "__BT_CONNECTION__", &val);
-       if (val) {
-               if ( strcmp(val, "Connected") == 0 ) {
-                       PRINTFUNC(DLOG_ERROR, "BT Connected");
-               } else {
-                       PRINTFUNC(DLOG_ERROR, "BT Not Connected");
-               }
-               free(val);
-       }
-}
-
-
-static void __ise_smartreply_gl_sel(void *data, Evas_Object *obj, void *event_info)
+static void __ise_template_gl_sel(void *data, Evas_Object *obj, void *event_info)
 {
-       App_Data* app_data = (App_Data*) data;
        Elm_Object_Item *item = (Elm_Object_Item *) event_info;
+       int index = 0;
 
        if (item) {
                elm_genlist_item_selected_set(item, EINA_FALSE);
 
-               int index = (unsigned int) elm_object_item_data_get(item);
+               index = (uintptr_t) elm_object_item_data_get(item);
+               const std::vector<TemplateData>  template_list = input_template_get_list();
 
-               char *reply = input_smartreply_get_nth_item(index);
-               if (reply) {
-                       input_smartreply_send_feedback(reply);
-                       reply_to_sender_by_callback(reply, "smartreply");
-                       free(reply);
+               if (index < (int)template_list.size()) {
+                       reply_to_sender_by_callback(gettext(template_list[index].text.c_str()), "template");
                        elm_exit();
                }
        }
 }
 
-static void __ise_template_add_gl_sel(void *data, Evas_Object *obj, void *event_info)
+static char * __ise_template_gl_text_get(void *data, Evas_Object *obj, const char *part)
 {
-       App_Data* app_data = (App_Data*) data;
-       Elm_Object_Item *item = (Elm_Object_Item *) event_info;
+       if (!strcmp(part, "elm.text")) {
+               unsigned int index = (uintptr_t)data;
+               const std::vector<TemplateData>  template_list = input_template_get_list();
 
-       if (item) {
-               elm_genlist_item_selected_set(item, EINA_FALSE);
+               if (index < template_list.size()) {
+                       if (template_list[index].use_gettext) {
+                               return strdup(gettext(template_list[index].text.c_str()));
+                       } else {
+                               Eina_Strbuf *buf = NULL;
+                               const char *str = NULL;
+                               char *markup = NULL;
 
-               if(is_sap_connection() == EINA_TRUE){
-                       // Show toast popup
-                       show_popup_toast(gettext("WDS_IME_TPOP_ADD_TEMPLATE_ON_YOUR_PHONE_ABB"), true);
-
-                       // send message to Host
-                       app_control_h appctrl;
-                       app_control_create(&appctrl);
-                       app_control_set_app_id(appctrl, "com.samsung.w-manager-service");
-                       app_control_add_extra_data(appctrl, "type", "gm_setting");
-                       app_control_add_extra_data(appctrl, "data/setting_menu", "texttemplate_setting");
-                       app_control_send_launch_request(appctrl, NULL, NULL);
-                       app_control_destroy(appctrl);
-               } else {
-                       app_control_h app_control;
-                       app_control_create(&app_control);
-                       app_control_set_app_id(app_control, "com.samsung.bt-connection-popup");
-                       app_control_add_extra_data(app_control, "msg", "perform");
-                       app_control_send_launch_request(app_control, __bt_connection_result_cb, NULL);
-                       app_control_destroy(app_control);
+                               buf = eina_strbuf_new();
+                               if (buf) {
+                                       eina_strbuf_append(buf, template_list[index].text.c_str());
+                                       eina_strbuf_replace_all(buf, "\n", "");
+                                       eina_strbuf_replace_all(buf, "\r", "");
+
+                                       str = eina_strbuf_string_get(buf);
+
+                                       if (str) {
+                                               markup = elm_entry_utf8_to_markup(str);
+                                       }
+                                       eina_strbuf_free(buf);
+                               }
+                               return markup;
+                       }
                }
        }
+       return NULL;
 }
 
-static void __ise_template_gl_sel(void *data, Evas_Object *obj, void *event_info)
+static Evas_Object * __ise_gl_2button_content_get(void *data, Evas_Object *obj, const char *part)
 {
-       App_Data* app_data = (App_Data*) data;
-       Elm_Object_Item *item = (Elm_Object_Item *) event_info;
-       int index = 0;
+       char *first_input_type = *(g_input_type_data.input_type_array + 0);
+       char *second_input_type = *(g_input_type_data.input_type_array + 1);
 
-       if (item) {
-               elm_genlist_item_selected_set(item, EINA_FALSE);
+       if (!strcmp(part, "elm.icon.1") ||  (!strcmp(part, "elm.icon.2"))) {
+               Evas_Object* btn = elm_button_add(obj);
+               evas_object_size_hint_weight_set(btn, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+               evas_object_size_hint_align_set(btn, EVAS_HINT_FILL, EVAS_HINT_FILL);
 
-               index = (unsigned int) elm_object_item_data_get(item);
-               const std::vector<TemplateData>  template_list = input_template_get_list();
+               Evas_Object* ic = elm_image_add(btn);
+               elm_image_resizable_set(ic, EINA_TRUE, EINA_TRUE);
+               string path = get_resource_path();
+               if (_WEARABLE)
+                       path = path + "wearable/";
+               else
+                       path = path + "mobile/";
 
-               //@ToDo : should call reply function when any template string is selected and confirmed.
-               // Here reply string will be template_list[index].text.c_str();
-               if( index < template_list.size()) {
-                       reply_to_sender_by_callback(gettext(template_list[index].text.c_str()), "template");
-                       elm_exit();
+               if (!strcmp(part, "elm.icon.1")) {
+                       string path_ic;
+                       if (!strcmp(first_input_type, "input_voice")) {
+                               elm_object_style_set(btn, "ime_button_stt");
+                               path_ic = path + "images/w_mode_stt_ic.png";
+                       } else if (!strcmp(first_input_type, "input_emoticon")) {
+                               elm_object_style_set(btn, "ime_button_emoticon");
+                               path_ic = path + "images/Delta_w_mode_emoticon_ic.png";
+                       } else if (!strcmp(first_input_type, "input_keyboard")) {
+                               elm_object_style_set(btn, "ime_button_keyboard");
+                               path_ic = path + "images/w_mode_keyboard_ic.png";
+                               evas_object_propagate_events_set(btn, EINA_FALSE);
+                       }
+                       elm_image_file_set(ic, path_ic.c_str(), NULL);
+                       elm_object_content_set(btn, ic);
+                       evas_object_layer_set(btn, 32000);
+               } else if (!strcmp(part, "elm.icon.2")){
+                       string path_ic;
+                       if (!strcmp(second_input_type, "input_voice")) {
+                               elm_object_style_set(btn, "ime_button_stt");
+                               path_ic = path + "images/w_mode_stt_ic.png";
+                       } else if (!strcmp(second_input_type, "input_emoticon")) {
+                               elm_object_style_set(btn, "ime_button_emoticon");
+                               path_ic = path + "images/Delta_w_mode_emoticon_ic.png";
+                       } else if (!strcmp(second_input_type, "input_keyboard")) {
+                               elm_object_style_set(btn, "ime_button_keyboard");
+                               path_ic = path + "images/w_mode_keyboard_ic.png";
+                               evas_object_propagate_events_set(btn, EINA_FALSE);
+                       }
+                       elm_image_file_set(ic, path_ic.c_str(), NULL);
+                       elm_object_content_set(btn, ic);
+                       evas_object_layer_set(btn, 32000);
+               }
+               return btn;
+       } else if (!strcmp(part, "elm.icon.1.touch_area") ||  (!strcmp(part, "elm.icon.2.touch_area"))) {
+               Evas_Object* btn = elm_button_add(obj);
+               elm_object_style_set(btn, "touch_area");
+               evas_object_size_hint_weight_set(btn, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+               evas_object_size_hint_align_set(btn, EVAS_HINT_FILL, EVAS_HINT_FILL);
+               string path = get_resource_path();
+               if (!strcmp(part, "elm.icon.1.touch_area")) {
+                       evas_object_layer_set(btn, 32000);
+                       if (!strcmp(first_input_type, "input_voice")) {
+                               evas_object_smart_callback_add(btn, "clicked", _stt_clicked_cb, app_data);
+                       } else if (!strcmp(first_input_type, "input_emoticon")) {
+                               evas_object_smart_callback_add(btn, "clicked", _emoticon_clicked_cb, app_data);
+                       } else if (!strcmp(first_input_type, "input_keyboard")) {
+                               evas_object_propagate_events_set(btn, EINA_FALSE);
+                               evas_object_smart_callback_add(btn, "clicked", _keyboard_clicked_cb, app_data);
+                       }
+               } else if (!strcmp(part, "elm.icon.2.touch_area")){
+                       evas_object_layer_set(btn, 32000);
+                       if (!strcmp(second_input_type, "input_voice")) {
+                               evas_object_smart_callback_add(btn, "clicked", _stt_clicked_cb, app_data);
+                       } else if (!strcmp(second_input_type, "input_emoticon")) {
+                               evas_object_smart_callback_add(btn, "clicked", _emoticon_clicked_cb, app_data);
+                       } else if (!strcmp(second_input_type, "input_keyboard")) {
+                               evas_object_propagate_events_set(btn, EINA_FALSE);
+                               evas_object_smart_callback_add(btn, "clicked", _keyboard_clicked_cb, app_data);
+                       }
                }
+               return btn;
+       } else if (!strcmp(part, "base")) {
+               Evas_Object* btn = elm_button_add(obj);
+               elm_object_style_set(btn, "ime_transparent");
+               return btn;
        }
+       return NULL;
 }
 
 static Evas_Object * __ise_gl_3button_content_get(void *data, Evas_Object *obj, const char *part)
@@ -286,22 +343,27 @@ static Evas_Object * __ise_gl_3button_content_get(void *data, Evas_Object *obj,
                Evas_Object* ic = elm_image_add(btn);
                elm_image_resizable_set(ic, EINA_TRUE, EINA_TRUE);
                string path = get_resource_path();
+               if (_WEARABLE)
+                       path = path + "wearable/";
+               else
+                       path = path + "mobile/";
+
                if (!strcmp(part, "elm.icon.1")) {
-                       elm_object_style_set(btn, "anchor");
+                       elm_object_style_set(btn, "ime_button_stt");
                        string path_ic = path + "images/w_mode_stt_ic.png";
                        elm_image_file_set(ic, path_ic.c_str(), NULL);
                        elm_object_content_set(btn, ic);
                        evas_object_layer_set(btn, 32000);
 
                } else if (!strcmp(part, "elm.icon.2")){
-                       elm_object_style_set(btn, "anchor");
+                       elm_object_style_set(btn, "ime_button_emoticon");
                        string path_ic = path + "images/Delta_w_mode_emoticon_ic.png";
                        elm_image_file_set(ic, path_ic.c_str(), NULL);
                        elm_object_content_set(btn, ic);
                        evas_object_layer_set(btn, 32000);
 
                } else if (!strcmp(part, "elm.icon.3")){
-                       elm_object_style_set(btn, "anchor");
+                       elm_object_style_set(btn, "ime_button_keyboard");
                        string path_ic = path + "images/w_mode_keyboard_ic.png";
                        elm_image_file_set(ic, path_ic.c_str(), NULL);
                        elm_object_content_set(btn, ic);
@@ -338,99 +400,6 @@ static Evas_Object * __ise_gl_3button_content_get(void *data, Evas_Object *obj,
        return NULL;
 }
 
-static char * __ise_smartreply_gl_text_get(void *data, Evas_Object *obj, const char *part)
-{
-       if(!strcmp(part, "elm.text")) {
-               int index;
-               char *reply = NULL;
-
-               index = (int)data;
-               if (index < 0)
-                       return NULL;
-
-               reply = input_smartreply_get_nth_item(index);
-               if (reply == NULL)
-                       return NULL;
-
-               /* Set hightlight color on first 3 smartreply items */
-               if (index < 3) {
-                       char *colored = _genlist_text_set_theme_color(reply, "AT0113");
-
-                       if (colored == NULL) {
-                               return reply;
-                       } else {
-                               free(reply);
-                               return colored;
-                       }
-               }
-
-               return reply;
-       }
-       return NULL;
-}
-
-static char * __ise_template_gl_text_get(void *data, Evas_Object *obj, const char *part)
-{
-       if(!strcmp(part, "elm.text")) {
-               unsigned int index = (unsigned int)data;
-               const std::vector<TemplateData>  template_list = input_template_get_list();
-
-               if(index < template_list.size()) {
-                       if(template_list[index].use_gettext) {
-                               return strdup(gettext(template_list[index].text.c_str()));
-                       } else {
-                               Eina_Strbuf *buf = NULL;
-                               const char *str = NULL;
-                               char *markup = NULL;
-
-                               buf = eina_strbuf_new();
-                               if(buf) {
-                                       eina_strbuf_append(buf, template_list[index].text.c_str());
-                                       eina_strbuf_replace_all(buf, "\n", "");
-                                       eina_strbuf_replace_all(buf, "\r", "");
-
-                                       str = eina_strbuf_string_get(buf);
-
-                                       if (str) {
-                                               markup = elm_entry_utf8_to_markup(str);
-                                       }
-                                       eina_strbuf_free(buf);
-                               }
-
-                               return markup;
-                       }
-               }
-       }
-       return NULL;
-}
-
-static char * __ise_addtemplate_gl_text_get(void *data, Evas_Object *obj, const char *part)
-{
-       if(!strcmp(part, "elm.text")) {
-               return(strdup(gettext("WDS_IME_MBODY_ADD_TEMPLATE_ABB")));
-       }
-       return NULL;
-}
-
-static Evas_Object * __ise_gl_1button_content_get(void *data, Evas_Object *obj, const char *part)
-{
-       if (!strcmp(part, "elm.icon")) {
-               Evas_Object* btn = elm_button_add(obj);
-               evas_object_size_hint_weight_set(btn, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
-               evas_object_size_hint_align_set(btn, EVAS_HINT_FILL, EVAS_HINT_FILL);
-               Evas_Object* ic = elm_image_add(btn);
-               elm_image_resizable_set(ic, EINA_TRUE, EINA_TRUE);
-               string path = get_resource_path();
-               elm_object_style_set(btn, "ime_button_template");
-               string path_ic = path + "/images/w_list_add_ic.png";
-               elm_image_file_set(ic, path_ic.c_str(), NULL);
-               elm_object_content_set(btn, ic);
-               evas_object_layer_set(btn, 32000);
-
-               return btn;
-       }
-       return NULL;
-}
 
 static void __ise_gl_lang_changed(void *data, Evas_Object *obj, void *event_info)
 {
@@ -438,49 +407,9 @@ static void __ise_gl_lang_changed(void *data, Evas_Object *obj, void *event_info
        elm_genlist_realized_items_update(obj);
 }
 
-
-static char *_genlist_text_set_theme_color(const char *str, const char *code)
-{
-       int r, g, b, a;
-       Eina_Strbuf *buf = NULL;
-       char *colored = NULL;
-
-       if (code == NULL)
-               return NULL;
-
-       buf = eina_strbuf_new();
-       if (buf == NULL) {
-               PRINTFUNC(DLOG_ERROR, "Can not get create strbuf");
-               return NULL;
-       }
-
-//     ea_theme_color_get(code,
-//                     &r, &g, &b, &a,
-//                     NULL, NULL, NULL, NULL,
-//                     NULL, NULL, NULL, NULL);
-
-       eina_strbuf_append_printf(buf, "<color=#%02x%02x%02x%02x>%s</color>",
-                       r, g, b, a, str);
-
-       colored = eina_strbuf_string_steal(buf);
-
-       eina_strbuf_free(buf);
-
-       return colored;
-}
-
-
-static void _app_control_send_reply_cb(app_control_h request, app_control_h reply,
-                                               app_control_result_e result, void *user_data)
-{
-               PRINTFUNC(DLOG_DEBUG, "");
-               reply_to_sender_by_callback(NULL, NULL);
-               elm_exit();
-}
-
 void set_source_caller_app_id(app_control_h app_control)
 {
-       if(!app_control){
+       if (!app_control){
                PRINTFUNC(DLOG_ERROR, "can't get app_control");
                return;
        }
@@ -488,7 +417,7 @@ void set_source_caller_app_id(app_control_h app_control)
        char *caller = NULL;
        app_control_get_caller(app_data->source_app_control, &caller);
 
-       if(caller){
+       if (caller){
                PRINTFUNC(DLOG_DEBUG, "caller = %s", caller);
                app_control_add_extra_data(app_control, "caller_appid", caller);
                free(caller);
@@ -501,11 +430,11 @@ void reply_to_sender_by_callback(const char *value, const char *type)
 
        app_control_h app_control;
 
-       if(app_control_create(&app_control) == 0) {
+       if (app_control_create(&app_control) == 0) {
                int ret;
 
                if (value)
-                       app_control_add_extra_data(app_control, "selected_context", value);
+                       app_control_add_extra_data(app_control, APP_CONTROL_DATA_TEXT, value);
 
                if (type)
                        app_control_add_extra_data(app_control, "reply_type", type);
@@ -528,7 +457,7 @@ void reply_to_sender_by_callback_for_back()
 
        app_control_h app_control;
 
-       if(app_control_create(&app_control) == 0) {
+       if (app_control_create(&app_control) == 0) {
                int ret;
 
                app_control_add_extra_data(app_control, "back_to_composer", "yes");
@@ -545,7 +474,7 @@ void reply_to_sender_by_callback_for_back()
 
 char* get_resource_path()
 {
-       if(NULL == app_data->res_path) {
+       if (NULL == app_data->res_path) {
                app_data->res_path = app_get_resource_path();
                PRINTFUNC(DLOG_INFO, "set resource path = %s", app_data->res_path);
        }
@@ -554,7 +483,7 @@ char* get_resource_path()
 
 char* get_shared_resource_path()
 {
-       if(NULL == app_data->shared_res_path) {
+       if (NULL == app_data->shared_res_path) {
                app_data->shared_res_path = app_get_shared_resource_path();
                PRINTFUNC(DLOG_INFO, "set shared resource path = %s", app_data->shared_res_path);
        }
@@ -562,10 +491,10 @@ char* get_shared_resource_path()
 }
 
 void show_gl_focus(Eina_Bool bVisible){
-       if(app_data->genlist == NULL)
+       if (app_data->genlist == NULL)
                return;
 
-       if(bVisible == EINA_TRUE){
+       if (bVisible == EINA_TRUE){
                elm_object_signal_emit(app_data->genlist, "elm,state,focus_bg,enable", "elm");
                //elm_layout_theme_set(app_data->genlist, "genlist", "base", "focus_bg");
                //elm_object_signal_emit(app_data->genlist, "elm,state,focus_bg,show", "elm");
@@ -589,12 +518,16 @@ void show_popup_toast(const char *text, bool check_img)
 
        if (check_img) {
                string path = get_resource_path();
+               if (_WEARABLE)
+                       path = path + "wearable/";
+               else
+                       path = path + "mobile/";
                string path_ic = path + "/images/toast_check_icon.png";
                Evas_Object * img = elm_image_add(popup);
                elm_image_file_set(img, path_ic.c_str(), NULL);
                elm_object_part_content_set(popup, "toast,icon", img);
        }
-       if(text) {
+       if (text) {
                elm_object_part_text_set(popup, "elm.text", text);
        }
 
@@ -608,7 +541,7 @@ void show_popup_toast(const char *text, bool check_img)
 
 static void _popup_close_cb(void *data, Evas_Object *obj, void *event_info)
 {
-       if(obj){
+       if (obj){
                evas_object_hide(obj);
                evas_object_del(obj);
        }
@@ -616,7 +549,7 @@ static void _popup_close_cb(void *data, Evas_Object *obj, void *event_info)
 
 static void _popup_back_cb(void *data, Evas_Object *obj, void *event_info)
 {
-       if(obj)
+       if (obj)
                elm_popup_dismiss(obj);
 }
 
@@ -625,17 +558,17 @@ void _back_to_genlist_for_selector()
 {
        PRINTFUNC(DLOG_DEBUG, "");
 
-       if(!app_data) return;
+       if (!app_data) return;
 
-       if(app_data->app_type == APP_TYPE_STT || app_data->app_type == APP_TYPE_EMOTICON){
+       if (app_data->app_type == APP_TYPE_STT || app_data->app_type == APP_TYPE_EMOTICON){
                PRINTFUNC(DLOG_DEBUG, "launched as STT/EMOTICON mode, So exit here.");
                reply_to_sender_by_callback(NULL, NULL);
                elm_exit();
        }
-
-       Evas_Object *circle_genlist = (Evas_Object *) evas_object_data_get(app_data->genlist, "circle");
-
-       eext_rotary_object_event_activated_set(circle_genlist, EINA_TRUE);
+       if (_WEARABLE) {
+               Evas_Object *circle_genlist = (Evas_Object *) evas_object_data_get(app_data->genlist, "circle");
+               eext_rotary_object_event_activated_set(circle_genlist, EINA_TRUE);
+       }
 }
 
 static void _item_realized(void *data, Evas_Object *obj, void *event_info) //called when list scrolled
@@ -646,17 +579,16 @@ static void _item_realized(void *data, Evas_Object *obj, void *event_info) //cal
 Evas_Object* _create_genlist(Evas_Object* navi)
 {
        Evas_Object* genlist = elm_genlist_add(navi);
-       if(NULL == genlist)
+       if (NULL == genlist)
                return NULL;
 
        elm_genlist_mode_set(genlist, ELM_LIST_COMPRESS);
-       elm_genlist_scroller_policy_set(genlist, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_OFF);
-
-       Evas_Object* circle_object_genlist = eext_circle_object_genlist_add(genlist, app_data->circle_surface);
-       eext_circle_object_genlist_scroller_policy_set(circle_object_genlist, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_OFF);
-       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, app_data->circle_surface);
+               eext_circle_object_genlist_scroller_policy_set(circle_object_genlist, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_OFF);
+               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);
 
@@ -682,8 +614,8 @@ Evas_Object* _create_genlist(Evas_Object* navi)
 
 static void _item_position_changed_cb(void *data, Evas_Object *obj, void *event_info)
 {
-       if(!obj) return;
-       if(!data) return;
+       if (!obj) return;
+       if (!data) return;
 
        Evas_Object *genlist = (Evas_Object *)obj;
        Elm_Object_Item *gen_item = (Elm_Object_Item *)data;
@@ -720,20 +652,17 @@ _main_menu_title_text_get(void *data, Evas_Object *obj, const char *part)
        return strdup(buf);
 }
 
-void _create_genlist_items(void* user_data, bool is_type_reply)
+void _create_genlist_items(void* user_data)
 {
-       LOGD("[psw] _create_genlist_items");
-
        App_Data* app_data = (App_Data*) user_data;
 
-       if(NULL == app_data->genlist) {
+       if (NULL == app_data->genlist) {
                app_data->genlist = _create_genlist(app_data->naviframe);
-               if(NULL == app_data->genlist)
+               if (NULL == app_data->genlist)
                return;
        }
 
        elm_genlist_clear(app_data->genlist);
-       g_smartreply_current_number = 0;        /* reset previous smartreply size to 0 */
 
        Elm_Genlist_Item_Class * itc0 = elm_genlist_item_class_new();
        itc0->item_style = "title";
@@ -743,12 +672,19 @@ void _create_genlist_items(void* user_data, bool is_type_reply)
        itc0->func.del = NULL;
 
        Elm_Genlist_Item_Class * itc1 = elm_genlist_item_class_new();
-       itc1->item_style = "3button";
-       itc1->func.text_get = NULL;
-       itc1->func.content_get = __ise_gl_3button_content_get;
-       itc1->func.state_get = NULL;
-       itc1->func.del = NULL;
-
+       if (g_input_type_data.input_type_array_len == 2){
+               itc1->item_style = "2button_flat";
+               itc1->func.text_get = NULL;
+               itc1->func.content_get = __ise_gl_2button_content_get;
+               itc1->func.state_get = NULL;
+               itc1->func.del = NULL;
+       } else {
+               itc1->item_style = "3button_flat";
+               itc1->func.text_get = NULL;
+               itc1->func.content_get = __ise_gl_3button_content_get;
+               itc1->func.state_get = NULL;
+               itc1->func.del = NULL;
+       }
 
        // dummy title for empty space
        it_empty = elm_genlist_item_append(app_data->genlist, itc0,
@@ -756,34 +692,15 @@ void _create_genlist_items(void* user_data, bool is_type_reply)
                        ELM_GENLIST_ITEM_NONE,
                        NULL, NULL);
 
-       if (!is_type_reply) {
-               // 3 Buttons
-               it_title = elm_genlist_item_append(app_data->genlist, itc1,
-                               NULL, NULL,
-                               ELM_GENLIST_ITEM_NONE,
-                               NULL, NULL);
-
-               elm_genlist_item_select_mode_set(it_title, ELM_OBJECT_SELECT_MODE_NONE);
-       }
-       if (input_smartreply_is_enabled() == false) {
-               _update_template_items(app_data);
-               if(g_template_current_number > 0) {
-                       Evas_Object *circle_genlist = (Evas_Object *) evas_object_data_get(app_data->genlist, "circle");
-                       eext_circle_object_genlist_scroller_policy_set(circle_genlist,
-                                       ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
-               }
-       } else {
-               // dummy title for bottom
-               Elm_Object_Item *dummy;
-
-               dummy = elm_genlist_item_append(app_data->genlist, itc0,
-                               NULL, NULL,
-                               ELM_GENLIST_ITEM_NONE,
-                               NULL, NULL);
+       // 3 Buttons
+       it_title = elm_genlist_item_append(app_data->genlist, itc1,
+                       NULL, NULL,
+                       ELM_GENLIST_ITEM_NONE,
+                       NULL, NULL);
 
-               elm_genlist_item_select_mode_set(dummy, ELM_OBJECT_SELECT_MODE_NONE);
-       }
+       elm_genlist_item_select_mode_set(it_title, ELM_OBJECT_SELECT_MODE_NONE);
 
+       g_template_item_size = _update_template_items(app_data);
 
        Elm_Object_Item *item = elm_genlist_item_next_get(it_title);
        elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
@@ -794,185 +711,90 @@ void _create_genlist_items(void* user_data, bool is_type_reply)
        elm_genlist_item_class_free(itc1);
 }
 
-void _update_genlist_items(void *user_data)
+void _create_header_items(void *user_data)
 {
-       int len = 0;
+       Elm_Genlist_Item_Class * itc0 = elm_genlist_item_class_new();
+       itc0->item_style = "title";
+       itc0->func.text_get = NULL;
+       itc0->func.content_get = NULL;
+       itc0->func.state_get = NULL;
+       itc0->func.del = NULL;
 
-       if (input_smartreply_is_enabled())
-               len = input_smartreply_get_reply_num();
+       Elm_Genlist_Item_Class * itc1 = elm_genlist_item_class_new();
+       if (g_input_type_data.input_type_array_len == 2) {
+               itc1->item_style = "2button_flat";
+               itc1->func.text_get = NULL;
+               itc1->func.content_get = __ise_gl_2button_content_get;
+               itc1->func.state_get = NULL;
+               itc1->func.del = NULL;
+       } else {
+               itc1->item_style = "3button_flat";
+               itc1->func.text_get = NULL;
+               itc1->func.content_get = __ise_gl_3button_content_get;
+               itc1->func.state_get = NULL;
+               itc1->func.del = NULL;
+       }
 
-       if (g_smartreply_current_number != len)
-               _update_smartreply_items(user_data);
+       // dummy title for empty space
+       it_empty = elm_genlist_item_append(app_data->genlist, itc0,
+                               NULL, NULL,
+                               ELM_GENLIST_ITEM_NONE,
+                               NULL, NULL);
 
-       _update_template_items(user_data);
+       // 3 Buttons
+       it_title = elm_genlist_item_append(app_data->genlist, itc1,
+                                                       NULL, NULL,
+                                                       ELM_GENLIST_ITEM_NONE,
+                                                       NULL, NULL);
 
-       g_smartreply_current_number = len;
+       elm_genlist_item_select_mode_set(it_title, ELM_OBJECT_SELECT_MODE_NONE);
 
-       if (g_smartreply_current_number > 0 || g_template_current_number > 0) {
-               Evas_Object *circle_genlist = (Evas_Object *) evas_object_data_get(app_data->genlist, "circle");
-               eext_circle_object_genlist_scroller_policy_set(circle_genlist,
-                                                       ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
-       }
+       elm_genlist_item_class_free(itc0);
+       elm_genlist_item_class_free(itc1);
 }
 
-void _update_smartreply_items(void *user_data)
+void _update_genlist_items(void *user_data)
 {
-       App_Data* app_data;
-
-       Elm_Object_Item *first;
-       Elm_Object_Item *menu;
-       Elm_Object_Item *pos;
-
-       int len = 0;
-       int i = 0;
-
-       app_data = (App_Data *)user_data;
-
-       if (app_data == NULL) {
-               PRINTFUNC(DLOG_ERROR, "Can not get app_data");
-               return;
-       }
-
-       if (app_data->genlist == NULL) {
-               /* smartreply will update when genlist is exist only */
-               PRINTFUNC(DLOG_ERROR, "Can not get getlist");
-               return;
-       }
-
-       if (input_smartreply_is_enabled())
-               len = input_smartreply_get_reply_num();
-
-       if (g_smartreply_current_number == len)
-               return;
-
-       first = elm_genlist_first_item_get(app_data->genlist);
-       menu = elm_genlist_item_next_get(first);
-
-       /* Remove current smartreply list */
-       pos = elm_genlist_item_next_get(menu);
-       for (i = 0; i < g_smartreply_current_number; i++) {
-               Elm_Object_Item *next;
-
-               if (pos == NULL)
-                       break;
-
-               next = elm_genlist_item_next_get(pos);
-               elm_object_item_del(pos);
-               pos = next;
-       }
-
-       /* Append newly added smartreply list */
-       if (len > 0) {
-               Elm_Genlist_Item_Class *itc;
-
-               itc = elm_genlist_item_class_new();
-
-               itc->item_style = "1text";
-               itc->func.text_get = __ise_smartreply_gl_text_get;
-               itc->func.content_get = NULL;
-               itc->func.state_get = NULL;
-               itc->func.del = NULL;
-
-               pos = menu;
-               for (i = 0; i < len; i++) {
-                       pos = elm_genlist_item_insert_after(app_data->genlist,
-                                                       itc,
-                                                       (void *)i,
-                                                       NULL,
-                                                       pos,
-                                                       ELM_GENLIST_ITEM_NONE,
-                                                       __ise_smartreply_gl_sel,
-                                                       app_data);
-               }
+       elm_genlist_clear(app_data->genlist);
 
-               if (menu)
-                       elm_genlist_item_show(menu, ELM_GENLIST_ITEM_SCROLLTO_TOP);
+       _create_header_items(user_data);
 
-               elm_genlist_item_class_free(itc);
-       }
+       g_template_item_size = _update_template_items(user_data);
 
-       g_smartreply_current_number = len;
+       /* Update genlist item position */
+       Elm_Object_Item *item = elm_genlist_item_next_get(it_title);
+       elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
 }
 
-
-void _update_template_items(void *user_data)
+unsigned int _update_template_items(void *user_data)
 {
        App_Data* app_data;
 
        Elm_Object_Item *first;
-       Elm_Object_Item *menu;
-       Elm_Object_Item *pos;
-       Elm_Object_Item *template_pos;
 
-       unsigned int template_len = 0;
        unsigned int i = 0;
+       unsigned int item_size = 0;
 
        app_data = (App_Data *)user_data;
 
        if (app_data == NULL) {
                PRINTFUNC(DLOG_ERROR, "Can not get app_data");
-               return;
+               return item_size;
        }
 
        if (app_data->genlist == NULL) {
                /* smartreply will update when genlist is exist only */
                PRINTFUNC(DLOG_ERROR, "Can not get getlist");
-               return;
+               return item_size;
        }
 
-       if (app_data->app_type == APP_TYPE_REPLY) {
-               menu = elm_genlist_first_item_get(app_data->genlist);
-       } else {
-               first = elm_genlist_first_item_get(app_data->genlist);
-               menu = elm_genlist_item_next_get(first);
-       }
-
-       pos = menu;
-       /* move to smartreply next if it need */
-       if (input_smartreply_is_enabled()) {
-               int smartreply_len = 0;
-
-               smartreply_len = input_smartreply_get_reply_num();
-               if (smartreply_len > 0) {
-                       int j = 0;
-
-                       for (j = 0; j < smartreply_len; j++) {
-                               if (pos == NULL)
-                                       break;
-
-                               pos = elm_genlist_item_next_get(pos);
-                       }
-               }
-       }
-
-       /* Remove Current template list */
-       template_pos = elm_genlist_item_next_get(pos);
-       for (i = 0 ; i < g_template_current_number; i++) {
-               Elm_Object_Item *next;
-
-               if (template_pos == NULL) {
-                       PRINTFUNC(DLOG_ERROR, "Template mismatched, iter : %d, current num: %d",
-                                       i, g_template_current_number);
-                       break;
-               }
-
-               next = elm_genlist_item_next_get(template_pos);
-               elm_object_item_del(template_pos);
-               template_pos = next;
-       }
-
-       /* Remove Add or dummpy button */
-       if(template_pos) {
-               Elm_Object_Item *next;
-
-               next = elm_genlist_item_next_get(template_pos);
-               elm_object_item_del(template_pos);
-               template_pos = next;
-       }
+       first = elm_genlist_first_item_get(app_data->genlist);
+       if (first == NULL)
+               return 0;
+       elm_genlist_item_next_get(first);
 
        /* Append New Template list */
        const std::vector<TemplateData> template_list = input_template_get_list();
-       template_len = 0;
 
        if (template_list.size() > 0) {
                Elm_Genlist_Item_Class *itc;
@@ -986,77 +808,21 @@ void _update_template_items(void *user_data)
                itc->func.del = NULL;
 
                for (i = 0; i < template_list.size(); i++) {
-                       bool matched = false;
-
-                       if(!template_list[i].use_gettext) {
-                               int smartreply_len = 0;
-                               int j = 0;
-
-                               smartreply_len = input_smartreply_get_reply_num();
-                               for (j = 0; j < smartreply_len; j++) {
-                                       char *reply = NULL;
-
-                                       reply = input_smartreply_get_nth_item(j);
-                                       if (reply) {
-                                               if (!strcmp(reply, template_list[i].text.c_str())) {
-                                                       matched = true;
-                                                       free(reply);
-                                                       break;
-                                               }
-                                               free(reply);
-                                       }
-                               }
-                       }
-
-                       if (matched == false) {
-                               pos = elm_genlist_item_insert_after(app_data->genlist,
-                                               itc,
-                                               (void *)i,
-                                               NULL,
-                                               pos,
-                                               ELM_GENLIST_ITEM_NONE,
-                                               __ise_template_gl_sel,
-                                               app_data);
-                               template_len++;
-                       }
+                       elm_genlist_item_append(app_data->genlist,
+                                       itc,
+                                       (void *)(uintptr_t)i,
+                                       NULL,
+                                       ELM_GENLIST_ITEM_NONE,
+                                       __ise_template_gl_sel,
+                                       app_data);
+                       item_size++;
                }
-
-               elm_genlist_item_class_free(itc);
-       }
-
-
-       // template add button (+)
-/*     if (!input_template_is_user_template()) {
-               Elm_Genlist_Item_Class *itc;
-
-               itc = elm_genlist_item_class_new();
-
-               itc->item_style = "1text.1icon";
-               itc->func.text_get = __ise_addtemplate_gl_text_get;;
-               itc->func.content_get = __ise_gl_1button_content_get;
-               itc->func.state_get = NULL;
-               itc->func.del = NULL;
-
-
-               pos = elm_genlist_item_insert_after(app_data->genlist,
-                               itc,
-                               NULL,
-                               NULL,
-                               pos,
-                               ELM_GENLIST_ITEM_NONE,
-                               __ise_template_add_gl_sel,
-                               app_data);
-
                elm_genlist_item_class_free(itc);
        }
-*/
-       if (menu)
-               elm_genlist_item_show(menu, ELM_GENLIST_ITEM_SCROLLTO_TOP);
 
-       g_template_current_number = template_len;
+       return item_size;
 }
 
-
 bool _app_create(void* user_data)
 {
        int width = 1000, height = 1000;
@@ -1101,9 +867,10 @@ bool _app_create(void* user_data)
        evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
 
        conform = elm_conformant_add(window);
-       surface = eext_circle_surface_conformant_add(conform);
-       evas_object_size_hint_weight_set(conform, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       if (_WEARABLE)
+               surface = eext_circle_surface_conformant_add(conform);
 
+       evas_object_size_hint_weight_set(conform, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
 
        elm_win_resize_object_add(window, conform);
        elm_object_content_set(conform, layout);
@@ -1131,31 +898,38 @@ bool _app_create(void* user_data)
 void _app_service(app_control_h service, void* user_data)
 {
        int ret;
-       bool b_ret;
        char *context = NULL;
+       char **input_type_array = NULL;
+       int input_type_array_len = -1;
+       bool is_extra_data_array = false;
 
        app_control_clone(&(app_data->source_app_control), service);
        app_data->reply_type = REPLY_APP_NORMAL;
 
-    bool is_type_reply = false;
-       ret = app_control_get_extra_data(service, APP_CONTROL_DATA_INPUT_TYPE, &context);
-       if (ret == APP_CONTROL_ERROR_NONE) {
-               if (!strcmp(context, "input_voice")) {
-                       app_data->app_type = APP_TYPE_STT;
-                       _stt_clicked_cb((void *)app_data, NULL, NULL);
-                       goto ACTIVATE;
-               } else if (!strcmp(context, "input_emoticon")) {
-                       app_data->app_type = APP_TYPE_EMOTICON;
-                       _emoticon_clicked_cb((void *)app_data, NULL, NULL);
-                       goto ACTIVATE;
-        } else if (!strcmp(context, "input_keyboard")) {
-                       app_data->app_type = APP_TYPE_KEYBOARD;
-                       input_keyboard_init(service);
-                       _keyboard_clicked_cb((void *)app_data, NULL, NULL);
-                       goto ACTIVATE;
-               } else if (!strcmp(context, "input_reply")) {
-                       app_data->app_type = APP_TYPE_REPLY;
-            is_type_reply = true;
+       ret = app_control_is_extra_data_array(service, APP_CONTROL_DATA_INPUT_TYPE, &is_extra_data_array);
+       if ( is_extra_data_array == true) {
+               ret = app_control_get_extra_data_array(service, APP_CONTROL_DATA_INPUT_TYPE, &input_type_array, &input_type_array_len);
+               g_input_type_data.input_type_array = input_type_array;
+               g_input_type_data.input_type_array_len = input_type_array_len;
+       } else {
+               ret = app_control_get_extra_data(service, APP_CONTROL_DATA_INPUT_TYPE, &context);
+               if (ret == APP_CONTROL_ERROR_NONE) {
+                       if (!strcmp(context, "input_voice")) {
+                               app_data->app_type = APP_TYPE_STT;
+                               _stt_clicked_cb((void *)app_data, NULL, NULL);
+                               goto ACTIVATE;
+                       } else if (!strcmp(context, "input_emoticon")) {
+                               app_data->app_type = APP_TYPE_EMOTICON;
+                               _emoticon_clicked_cb((void *)app_data, NULL, NULL);
+                               goto ACTIVATE;
+                       } else if (!strcmp(context, "input_keyboard")) {
+                               app_data->app_type = APP_TYPE_KEYBOARD;
+                               input_keyboard_init(service);
+                               _keyboard_clicked_cb((void *)app_data, NULL, NULL);
+                               goto ACTIVATE;
+                       } else if (!strcmp(context, "input_reply")) {
+                               app_data->app_type = APP_TYPE_REPLY;
+                       }
                }
        }
 
@@ -1164,22 +938,15 @@ void _app_service(app_control_h service, void* user_data)
 
        input_keyboard_init(service);
 
-//     input_smartreply_init(service);
-//     input_smartreply_set_notify(_input_smartreply_notify_cb, NULL);
-
-//     if (input_smartreply_is_enabled())
-//             input_smartreply_get_reply_async();
-
-
        input_template_init(service);
        input_template_set_notify(_input_template_notify_cb,  NULL);
 
-       _create_genlist_items(app_data, is_type_reply);
+       _create_genlist_items(app_data);
 
 ACTIVATE :
        elm_win_activate(app_data->win_main);
 
-       if(context)
+       if (context)
                free(context);
 }
 
@@ -1200,21 +967,22 @@ void _app_terminate(void* user_data)
        App_Data* app_data = NULL;
        app_data = (App_Data*)user_data;
 
-       if(app_data->genlist){
+       if (app_data->genlist){
                evas_object_smart_callback_del(app_data->genlist, "elm,item,position,changed", _item_position_changed_cb);
        }
 
-       if(app_data->res_path)
+       if (app_data->res_path)
                free(app_data->res_path);
 
-       if(app_data->shared_res_path)
+       if (app_data->shared_res_path)
                free(app_data->shared_res_path);
 
        input_keyboard_deinit();
-       input_smartreply_deinit();
 
        input_template_unset_notify();
        input_template_deinit();
+
+       input_type_deinit();
 }
 
 static int init_i18n(const char *domain, const char *dir, char *lang_str)
@@ -1257,9 +1025,24 @@ static void _app_language_changed(app_event_info_h event_info, void *user_data)
        }
 }
 
+void input_type_deinit(void)
+{
+       int i = 0;
+       char **data_array = NULL;
 
+       data_array = g_input_type_data.input_type_array;
+       if (data_array) {
+               for (i = 0; i < g_input_type_data.input_type_array_len; i++) {
+                       if (*(data_array + i))
+                               free(*(data_array + i));
+               }
+               free(data_array);
+       }
+       g_input_type_data.input_type_array = NULL;
+       g_input_type_data.input_type_array_len = 0;
+}
 
-int main(int argc, char* argv[])
+EXPORTED int main(int argc, char* argv[])
 {
        App_Data app_data = {0, };
        ui_app_lifecycle_callback_s event_callback = {0, };