Fix issue that Black screen displayed when exiting Voice input screen
[platform/core/uifw/inputdelegator.git] / src / w-input-stt-voice.cpp
index 84348a9..d39c87c 100755 (executable)
 #include <Ecore_IMF.h>
 #include <Ecore.h>
 #include <device/power.h>
-#include <efl_assist.h>
 #include <app_common.h>
 #include <app.h>
+#include <app_preference.h>
 #include <string>
 #include <efl_extension.h>
 #include <feedback.h>
+#include <stdint.h>
 
 #include "Debug.h"
 #include "w-input-selector.h"
-#include "w-input-smartreply.h"
 #include "w-input-stt-voice.h"
 #include "w-input-stt-engine.h"
 #include "w-input-stt-ise.h"
+#include "voice-recorder.h"
 
 using namespace std;
 
@@ -41,7 +42,7 @@ using namespace std;
 #define GRP_PORTRAIT "mic_control"
 
 #define item_append(obj, style, index, cb, udata) \
-               elm_genlist_item_append(obj, &(style), (void *)index, NULL, ELM_GENLIST_ITEM_NONE, cb, udata)
+               elm_genlist_item_append(obj, &(style), (void *)(uintptr_t)index, NULL, ELM_GENLIST_ITEM_NONE, cb, udata)
 
 #define VIRTUAL_TEXT_AREA_FONT_STYLE \
                "DEFAULT='font=Tizen:style=Regular  font_size=32 color=#FFFFFF color_class=AT013 text_class=tizen wrap=mixed align=center' \
@@ -52,8 +53,6 @@ extern VoiceData *my_voicedata;
 
 static bool power_state = false;
 
-static bool bottom_button_access_state = false;
-
 static Evas_Object *radio_gp = NULL;
 Evas_Object *g_setting_window = NULL;
 static Evas_Object *g_setting_naviframe = NULL;
@@ -67,29 +66,10 @@ static Elm_Genlist_Item_Class itc_title;
 static Elm_Genlist_Item_Class itc_1text;
 static Elm_Genlist_Item_Class itc_2text;
 
-static bool g_send_button_clicked = false;
-//accessbility
-static bool g_mic_clicked = false;
-
+static Eina_Bool change_guide_text(void *data);
 static void set_guide_text(VoiceData *vd, const char* text, bool translatable = false);
 
-char *supported_language[13] = {
-               "auto",
-               "de_DE",
-               "en_GB",
-               "en_US",
-               "es_ES",
-               "es_US",
-               "fr_FR",
-               "it_IT",
-               "pt_BR",
-               "ru_RU",
-               "zh_CN",
-               "ja_JP",
-               "ko_KR",
-};
-
-char *supported_language_n66[7] = {
+const char *supported_language[] = {
                 "auto",
                 "en_US",
                 "es_US",
@@ -100,23 +80,7 @@ char *supported_language_n66[7] = {
 };
 
 
-char *disp_lang_array[13] = {
-               "",
-               "Deutsch",
-               "English (United Kingdom)",
-               "English (United States)",
-               "Español (España)",
-               "Español (América Latina)",
-               "Français (France)",
-               "Italiano",
-               "Português (Brasil)",
-               "Pусский",
-               "简体中文",
-               "日本語",
-               "한국어",
-};
-
-char *disp_lang_array_n66[7] = {
+const char *disp_lang_array[] = {
                 "",
                 "English (United States)",
                 "Español (América Latina)",
@@ -126,23 +90,6 @@ char *disp_lang_array_n66[7] = {
                 "한국어",
 };
 
-
-typedef enum {
-       STT_VOICE_AUTO,
-       STT_VOICE_DE_DE,
-       STT_VOICE_EN_GB,
-       STT_VOICE_EN_US,
-       STT_VOICE_ES_ES,
-       STT_VOICE_ES_US,
-       STT_VOICE_FR_FR,
-       STT_VOICE_IT_IT,
-       STT_VOICE_PT_BR,
-       STT_VOICE_RU_RU,
-       STT_VOICE_ZH_CN,
-       STT_VOICE_JA_JP,
-       STT_VOICE_KO_KR
-}STT_VOICE_LANGUAGE_I;
-
 typedef enum {
         STT_VOICE_N66_AUTO,
         STT_VOICE_N66_EN_US,
@@ -165,78 +112,30 @@ typedef enum {
 static void get_stt_default_language(VoiceData *my_voicedata);
 
 
-char* get_lang_label(char lang[])
+const char* get_lang_label(char lang[])
 {
+       const char *str = NULL;
 
-       char *str = NULL;
-
-       if(strcmp(lang, "en_US") == 0)
-               str = disp_lang_array[3];
-
-       else if(strcmp(lang, "ko_KR") == 0)
-               str = disp_lang_array[12];
-
-       else if(strcmp(lang, "de_DE") == 0)
+       if (strcmp (lang, "en_US") == 0)
                str = disp_lang_array[1];
 
-       else if(strcmp(lang, "fr_FR") == 0)
+       else if (strcmp (lang, "ko_KR") == 0)
                str = disp_lang_array[6];
 
-       else if(strcmp(lang, "it_IT") == 0)
-               str = disp_lang_array[7];
-
-       else if(strcmp(lang, "en_GB") == 0)
-               str = disp_lang_array[2];
-
-       else if(strcmp(lang, "ja_JP") == 0)
-               str = disp_lang_array[11];
-
-       else if(strcmp(lang, "zh_CN") == 0)
-               str = disp_lang_array[10];
-
-       else if(strcmp(lang, "ru_RU") == 0)
-               str = disp_lang_array[9];
-
-       else if(strcmp(lang, "pt_BR") == 0)
-               str = disp_lang_array[8];
-
-       else if(strcmp(lang, "es_ES") == 0)
-               str = disp_lang_array[4];
-
-       else if(strcmp(lang, "es_US") == 0)
-               str = disp_lang_array[5];
-
-       else
+       else if (strcmp (lang, "fr_FR") == 0)
                str = disp_lang_array[3];
 
-       return str;
-}
-
-char* get_lang_label_n66(char lang[])
-{
-
-       char *str = NULL;
-
-       if(strcmp(lang, "en_US") == 0)
-               str = disp_lang_array_n66[1];
-
-       else if(strcmp(lang, "ko_KR") == 0)
-               str = disp_lang_array_n66[6];
-
-       else if(strcmp(lang, "fr_FR") == 0)
-               str = disp_lang_array_n66[3];
-
-       else if(strcmp(lang, "ja_JP") == 0)
-               str = disp_lang_array_n66[5];
+       else if (strcmp (lang, "ja_JP") == 0)
+               str = disp_lang_array[5];
 
-       else if(strcmp(lang, "zh_CN") == 0)
-               str = disp_lang_array_n66[4];
+       else if (strcmp (lang, "zh_CN") == 0)
+               str = disp_lang_array[4];
 
-       else if(strcmp(lang, "es_US") == 0)
-               str = disp_lang_array_n66[2];
+       else if (strcmp (lang, "es_US") == 0)
+               str = disp_lang_array[2];
 
        else
-               str = disp_lang_array_n66[1];
+               str = disp_lang_array[1];
 
        return str;
 }
@@ -245,29 +144,26 @@ char* get_lang_label_n66(char lang[])
 static Eina_Bool
 _bring_in_cb(void *data)
 {
-
        if(!data)
                return ECORE_CALLBACK_CANCEL;
 
-       Evas_Coord x, y ,w, h;
+       Evas_Coord x, yw, h;
 
        Evas_Object *scroller = (Evas_Object *)data;
        Evas_Object *inner_layout = NULL;
 
        inner_layout = (Evas_Object *) evas_object_data_get(scroller, "inner_layout");
 
-       evas_object_geometry_get(inner_layout , &x, &y, &w, &h);
+       evas_object_geometry_get(inner_layout, &x, &y, &w, &h);
        elm_scroller_region_bring_in(scroller, x, h, w, h);
 
-       PRINTFUNC(NO_PRINT,"scroller %d %d %d %d",x, y, w, h);
+       PRINTFUNC(NO_PRINT, "scroller %d %d %d %d", x, y, w, h);
 
        return ECORE_CALLBACK_CANCEL;
 }
 
 static inline Evas_Coord get_text_block_size(Evas_Object *obj, std::string text)
 {
-       int calculated_height = 0;
-
        int max_height = 1280;
        int unit_width = 282;
 
@@ -297,12 +193,12 @@ static inline Evas_Coord get_text_block_size(Evas_Object *obj, std::string text)
        if(strbuf) free(strbuf);
        if(tb) evas_object_del(tb);
        if(st) evas_textblock_style_free(st);
-       if(cur) evas_textblock_cursor_free(cur);
+//     if(cur) evas_textblock_cursor_free(cur);
 
        return height;
 }
 
-static Eina_Bool _update_textblock_timer_cb (void *data)
+static Eina_Bool _update_textblock_timer_cb(void *data)
 {
        if(!data)
                return ECORE_CALLBACK_CANCEL;
@@ -312,7 +208,7 @@ static Eina_Bool _update_textblock_timer_cb (void *data)
        voicedata->textblock_timer = NULL;
 
        std::string result_text;
-       for(int i=0;i<voicedata->stt_results.size();i++){
+       for(unsigned int i = 0; i < voicedata->stt_results.size(); i++){
                if(i == voicedata->stt_results.size()-1){
                        result_text += voicedata->stt_results.at(i);
                } else {
@@ -326,7 +222,6 @@ static Eina_Bool _update_textblock_timer_cb (void *data)
        Evas_Object *scroller = NULL;
        Evas_Object *box = NULL;
        Evas_Object *inner_layout = NULL;
-       char *strbuf = NULL;
 
        scroller = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "text_area");
        if(!scroller)
@@ -410,10 +305,9 @@ static Eina_Bool _update_textblock_timer_cb (void *data)
        Evas_Object *panel_layout = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "left_panel_area");
        Evas_Object *panel_left = elm_layout_content_get((Evas_Object *)panel_layout, "elm.swallow.right");
 
-       if(result_text.size()>0){
+       if (result_text.size() > 0) {
                elm_object_signal_emit(panel_left, "elm,state,enabled", "elm");
-       }
-       else {
+       } else {
                elm_object_signal_emit(panel_left, "elm,state,disabled", "elm");
        }
 
@@ -421,7 +315,6 @@ static Eina_Bool _update_textblock_timer_cb (void *data)
 
        if(voicedata->state == STT_STATE_VAL_LISTENING){
                if(voicedata->guide_text_timer != NULL){
-                       PRINTFUNC(DLOG_DEBUG, "Skip hide_guide_text");
                        ecore_timer_del(voicedata->guide_text_timer);
                        voicedata->guide_text_timer = NULL;
                }
@@ -431,15 +324,10 @@ static Eina_Bool _update_textblock_timer_cb (void *data)
        elm_object_signal_emit(inner_layout, "scrolling", "entry");
 
        return ECORE_CALLBACK_CANCEL;
-
-
-
 }
 
-
 void _update_textblock(void *data)
 {
-
        if(!data)
                return;
 
@@ -478,7 +366,6 @@ void voice_get_string(const char *keyValue, _VoiceData *voicedata)
                                voicedata->partial_result = strdup(strbuf);
                        }
                } else { // partial_result is Null so first case
-
                        PRINTFUNC(DLOG_DEBUG, "first push");
                        voicedata->stt_results.push_back(strbuf);
                        voicedata->partial_result = strdup(strbuf);
@@ -493,7 +380,7 @@ void voice_get_string(const char *keyValue, _VoiceData *voicedata)
        PRINTFUNC(DLOG_DEBUG, "ends");
 }
 
-static Eina_Bool _recognition_failure_cb (void *data)
+static Eina_Bool _recognition_failure_cb(void *data)
 {
        if(data) {
                VoiceData *voicedata = (VoiceData *) data;
@@ -507,75 +394,54 @@ static Eina_Bool _recognition_failure_cb (void *data)
 
 void start_by_press(VoiceData *voicedata)
 {
-
-       PRINTFUNC(DLOG_DEBUG,"");
-
+       LOGD("start_by_press ");
        edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1", "background");
-
-       return;
-
 }
 
 static void on_mic_button_press_cb(void *data, Evas_Object *obj, void *event_info)
 {
-
-       PRINTFUNC(NO_PRINT,"");
-
+       LOGD("on_mic_button_press_cb");
        VoiceData *voicedata = (VoiceData *)data;
+       if (!voicedata) return;
 
-       if (elm_config_access_get()){
-               if(     bottom_button_access_state == true){
-                       PRINTFUNC(DLOG_DEBUG,"skip until bottom buttom is being read by accessibility");
-                       return;
+       if (voicedata->sttmanager != NULL &&
+               (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING
+               || voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING)) {
+               try {
+                       voicedata->state = STT_STATE_VAL_INIT;
+                       voicedata->sttmanager->Stop();
+               }
+               catch (is::stt::SttException &e) {
                }
-       }
-
-       edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1","background");
-
-       return;
-}
-
-static char *_left_cue_access_info_cb(void *data, Evas_Object *obj)
-{
-   char text[512];
-
-   snprintf(text, sizeof(text), "%s, %s", gettext(TTS_SEND), gettext(TTS_BUTTON));
-
-   return strdup(text);
-}
-
-static void _left_cue_access_activate_cb(void * data, Evas_Object *part_obj, Elm_Object_Item *item)
-{
 
-    Evas_Object *obj = (Evas_Object *)data;
-    elm_layout_signal_emit(obj, "cue,clicked", "elm");
+               if (voicedata->effector)
+                       voicedata->effector->Stop(true);
 
-    elm_panel_toggle(obj);
+               if (NULL != voicedata->start_timer) {
+                       ecore_timer_del(voicedata->start_timer);
+                       voicedata->start_timer = NULL;
+               }
+               if (NULL != voicedata->guide_text_timer) {
+                       ecore_timer_del(voicedata->guide_text_timer);
+                       voicedata->guide_text_timer = NULL;
+               }
+               if (NULL != voicedata->refresh_timer) {
+                       ecore_timer_del(voicedata->refresh_timer);
+                       voicedata->refresh_timer = NULL;
+               }
+       } else {
+               if (NULL != voicedata->guide_text_timer) {
+                       ecore_timer_del(voicedata->guide_text_timer);
+                       voicedata->guide_text_timer = NULL;
+               }
+               edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1", "background");
+       }
 }
 
 
-static void _send_button_highlighted_cb(void *data, Evas_Object * obj, void *event_info)
-{
-
-       PRINTFUNC(DLOG_DEBUG,"");
-       VoiceData* voicedata = (VoiceData*)data;
-
-       if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
-        voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING)
-               return;
-
-       std::string text = std::string(gettext(TTS_SEND));
-       text = text +" "+ gettext(TTS_BUTTON);
-       if (elm_object_disabled_get(obj))
-               text = text + " " + gettext(TTS_DISABLED);
-
-       elm_access_say(text.c_str());
-}
-
 static Eina_Bool _mic_button_enable_cb(void *data)
 {
-
-       PRINTFUNC(DLOG_DEBUG,"");
+       PRINTFUNC(DLOG_DEBUG, "");
 
        if(!data)
                return ECORE_CALLBACK_CANCEL;
@@ -588,83 +454,35 @@ static Eina_Bool _mic_button_enable_cb(void *data)
 
        elm_object_disabled_set(button, EINA_FALSE);
 
-       if (elm_config_access_get()){
-               bottom_button_access_state = false;
-       }
-
        return ECORE_CALLBACK_CANCEL;
 }
 
-static void _mic_highlighted_cb(void *data, Evas_Object * obj, void *event_info)
-{
-
-       PRINTFUNC(DLOG_DEBUG,"");
-       VoiceData* voicedata = (VoiceData*)data;
-
-   if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
-       voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING)
-          return;
-
-
-       if (elm_config_access_get()){
-               bottom_button_access_state = true;
-       } else {
-               elm_object_disabled_set(voicedata->mic_button, EINA_TRUE);
-       }
-
-
-       if(voicedata->btn_disabling_timer == NULL){
-               ecore_timer_del(voicedata->btn_disabling_timer);
-       }
-       voicedata->btn_disabling_timer = ecore_timer_add(3.0, _mic_button_enable_cb, voicedata);
-
-
-       elm_access_say(gettext(SK_DOUBLE_TAP_TO_SPEAK));
-
-
-
-}
-
-static char *_mic_access_info_cb(void *data, Evas_Object *obj)
-{
-       if (data) return strdup((const char*)data);
-       return NULL;
-}
-
 
 static void on_confirm_button_clicked_cb(void *data, Evas_Object *obj, void *event_info)
 {
-
-       if(g_send_button_clicked == true){
-               PRINTFUNC(DLOG_DEBUG,"skipped seding STT result");
-               return;
-       }
-
-       g_send_button_clicked = true;
-
        if(!data)
                return;
 
        VoiceData* voicedata = (VoiceData*)data;
 
        std::string result_text;
-       for(int i=0;i<voicedata->stt_results.size();i++){
+       for(unsigned int i = 0; i < voicedata->stt_results.size(); i++){
                result_text += voicedata->stt_results.at(i);
                if(i != voicedata->stt_results.size()-1)
                        result_text += " ";
        }
 
-       PRINTFUNC(DLOG_DEBUG,"result_text = %s", result_text.c_str());
-       input_smartreply_send_feedback(result_text.c_str());
+       PRINTFUNC(DLOG_DEBUG, "result_text = %s", result_text.c_str());
 
-       if(app_data->reply_type == REPLY_APP_CONTROL){
-               reply_to_sender_by_appcontrol((void*)app_data, result_text.c_str(), "voice");
-       } else {
-               reply_to_sender_by_callback(result_text.c_str(), "voice");
-               destroy_voice();
-               powerUnlock();
-               elm_exit();
-       }
+       char *filePath = NULL;
+       voice_recorder *vr = _voice_recorder_get_data();
+       if (!vr)
+               filePath = vr->file_path;
+       char *path[] = {filePath, };
+       reply_to_sender_by_callback(result_text.c_str(), "voice", (const char **)path);
+       destroy_voice();
+       powerUnlock();
+       ui_app_exit();
 
        return;
 }
@@ -672,7 +490,7 @@ static void on_confirm_button_clicked_cb(void *data, Evas_Object *obj, void *eve
 static void
 _panel_cue_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
 {
-       PRINTFUNC(DLOG_DEBUG,"left cue clicked!!");
+       PRINTFUNC(DLOG_DEBUG, "left cue clicked!!");
 
        on_confirm_button_clicked_cb(data, NULL, NULL);
 }
@@ -703,9 +521,9 @@ void stt_feedback(FeedbackType type)
                return;
        }
 
-       if(type == VIBRATION_START){
+       if (type == VIBRATION_START){
 //             feedback_play(FEEDBACK_PATTERN_VOICE_START);
-       } else if(type == VIBRATION_STOP){
+       } else if (type == VIBRATION_STOP){
 //             feedback_play(FEEDBACK_PATTERN_VOICE_STOP);
        }
 
@@ -715,7 +533,6 @@ void stt_feedback(FeedbackType type)
                PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
                return;
        }
-
 }
 
 void stt_feedback_deinitialize()
@@ -731,52 +548,48 @@ void stt_feedback_deinitialize()
        return;
 }
 
-
 static Eina_Bool _idler_cb(void *data)
 {
-
        if(!data) return ECORE_CALLBACK_CANCEL;
 
        VoiceData *voicedata = (VoiceData *)data;
 
-       PRINTFUNC(DLOG_DEBUG,"");
+       PRINTFUNC(DLOG_DEBUG, "");
 
 
        if(true == _app_stt_initialize(voicedata)) {
-               PRINTFUNC(NO_PRINT,"_app_stt_initialize None Error");
+               LOGD("_app_stt_initialize None Error");
                voicedata->voicefw_state = 1;
                voicedata->state = STT_STATE_VAL_INIT;
-       }
-       else {
+       } else {
                voicedata->voicefw_state = 0;
-               PRINTFUNC(DLOG_ERROR,"Initialization Fail!<br>Check STT-daemon is running");
+               LOGD("Initialization Fail!<br>Check STT-daemon is running");
        }
 
        Evas_Object *canvas = elm_object_part_content_get(voicedata->layout_main, "EFFECT_BG");
 
-
        is::ui::WInputSttMicEffect *ieffect = new is::ui::WInputSttMicEffect();
-       ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
+       if (ieffect) {
+               ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
 
-       is::ui::MicEffector *effector = new is::ui::MicEffector(canvas, voicedata->layout_main, *ieffect);
-       voicedata->ieffect = ieffect;
-       voicedata->effector= effector;
+               is::ui::MicEffector *effector = new is::ui::MicEffector(canvas, voicedata->layout_main, *ieffect);
+               voicedata->ieffect = ieffect;
+               voicedata->effector = effector;
 
-       ieffect->SetProgressBar(voicedata->progressbar);
-       ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
+               ieffect->SetProgressBar(voicedata->progressbar);
+               ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
+       }
 
        voicedata->mo->Update();
 
        elm_access_highlight_set(voicedata->mic_button);
 
-
        return ECORE_CALLBACK_CANCEL;
 }
 
 
 static Eina_Bool _power_delayed_unlock(void *data){
-
-       PRINTFUNC(DLOG_DEBUG,"POWER Unlock");
+       PRINTFUNC(DLOG_DEBUG, "POWER Unlock");
 
        VoiceData *voicedata = (VoiceData *) data;
        device_power_release_lock(POWER_LOCK_DISPLAY);
@@ -787,39 +600,36 @@ static Eina_Bool _power_delayed_unlock(void *data){
 
 void powerUnlock()
 {
-       PRINTFUNC(DLOG_DEBUG,"POWER Unlock directly.");
+       PRINTFUNC(DLOG_DEBUG, "POWER Unlock directly.");
        device_power_release_lock(POWER_LOCK_DISPLAY);
 }
 
 void powerLock(void *data, bool enable)
 {
-
        int ret = DEVICE_ERROR_NONE;
 
        VoiceData *voicedata = (VoiceData *) data;
 
        if(enable) {
-
                ret = device_power_wakeup(false);
-               PRINTFUNC(DLOG_DEBUG,"LCD Wakeup");
+               PRINTFUNC(DLOG_DEBUG, "LCD Wakeup");
 
                if(ret != DEVICE_ERROR_NONE)
-                       PRINTFUNC(DLOG_ERROR,"LCD Wakeup ERROR =%d",ret);
+                       PRINTFUNC(DLOG_ERROR, "LCD Wakeup ERROR = %d", ret);
 
                ret = device_power_request_lock(POWER_LOCK_DISPLAY, 0);
-               PRINTFUNC(DLOG_DEBUG,"POWER LOCK");
+               PRINTFUNC(DLOG_DEBUG, "POWER LOCK");
                power_state = enable;
 
                if(ret != DEVICE_ERROR_NONE)
-                       PRINTFUNC(DLOG_ERROR,"ERROR =%d",ret);
+                       PRINTFUNC(DLOG_ERROR, "ERROR = %d", ret);
 
                if(voicedata->power_unlock_timer != NULL){
                        ecore_timer_del(voicedata->power_unlock_timer);
                        voicedata->power_unlock_timer = NULL;
-
                }
        } else {
-               PRINTFUNC(DLOG_DEBUG,"POWER Unlock Delayed(5 sec)");
+               PRINTFUNC(DLOG_DEBUG, "POWER Unlock Delayed(5 sec)");
 
                if(voicedata->power_unlock_timer != NULL){
                        ecore_timer_del(voicedata->power_unlock_timer);
@@ -827,29 +637,23 @@ void powerLock(void *data, bool enable)
                }
                voicedata->power_unlock_timer = ecore_timer_add(5.0, _power_delayed_unlock, voicedata);
        }
-
 }
 
+static Eina_Bool change_guide_text(void *data){
+       VoiceData *voicedata = (VoiceData *) data;
+       if (!voicedata) return ECORE_CALLBACK_CANCEL;
 
-static Eina_Bool hide_guide_text(void *data){
-
-
-       if(data) {
-               VoiceData *voicedata = (VoiceData *) data;
-
-               voicedata->guide_text_timer = NULL;
-
-
-               PRINTFUNC(DLOG_ERROR,"");
-               elm_object_part_text_set(voicedata->layout_main, "elm.text", "");
+       stt_state_e state = voicedata->sttmanager->GetCurrent();
+       if (state == STT_STATE_RECORDING || state == STT_STATE_PROCESSING)
+               elm_object_domain_translatable_part_text_set(voicedata->layout_main, "elm.text", PACKAGE, SK_TAP_TO_PAUSE);
 
-       }
        return ECORE_CALLBACK_CANCEL;
 }
 
+
 static void set_guide_text(VoiceData *vd, const char* text, bool translatable)
 {
-       //elm_object_signal_emit(vd->layout_main, "idle,state,text,visible", "elm");
+       elm_object_signal_emit(vd->layout_main, "idle,state,guide_text,bottom", "elm");
 
        if(translatable)
                elm_object_domain_translatable_part_text_set(vd->layout_main, "elm.text", PACKAGE, text);
@@ -858,7 +662,7 @@ static void set_guide_text(VoiceData *vd, const char* text, bool translatable)
 
        if(!strcmp(text, SK_SPEAK_NOW)){
                if(vd->guide_text_timer == NULL)
-                       vd->guide_text_timer = ecore_timer_add(2.0, hide_guide_text, vd);
+                       vd->guide_text_timer = ecore_timer_add(2.0, change_guide_text, vd);
        }
 }
 
@@ -869,31 +673,13 @@ static void set_guide_text(VoiceData *vd, const char* text, bool translatable)
  */
 void set_animation_state(VoiceData *voicedata)
 {
-       PRINTFUNC(DLOG_DEBUG,"");
-
-       PRINTFUNC(DLOG_ERROR, "voicedata->state == %s",
-               voicedata->state == STT_STATE_VAL_INIT ?
-                       "STT_STATE_VAL_INIT" :
-               voicedata->state == STT_STATE_VAL_LISTENING ?
-                       "STT_STATE_VAL_LISTENING" :
-               voicedata->state == STT_STATE_VAL_PREPARE_LISTENING ?
-                       "STT_STATE_VAL_PREPARE_LISTENING" :
-               voicedata->state == STT_STATE_VAL_PROCESSING ?
-                       "STT_STATE_VAL_PROCESSING" :
-               voicedata->state == STT_STATE_VAL_PREPARE_PROCESSING ?
-                       "STT_STATE_VAL_PREPARE_PROCESSING" :
-               voicedata->state == STT_STATE_VAL_TERMINATING ?
-                       "STT_STATE_VAL_TERMINATING" : "STT_STATE_VAL_NOT_RECOGNISED");
-
        if (voicedata->state == STT_STATE_VAL_INIT) {
-
 #if 0
                if (voicedata->sttmanager->GetCurrent() == STT_STATE_READY) {
                        set_guide_text(voicedata, "", false);
                        //_elm_access_say(voicedata->layout_main, _(SK_INIT));
-               }
-               else {
-                       PRINTFUNC(DLOG_DEBUG,"SK_NETWORK_ERROR [%d]", voicedata->sttmanager->GetCurrent());
+               } else {
+                       PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR [%d]", voicedata->sttmanager->GetCurrent());
                        set_guide_text(voicedata, _(SK_NETWORK_ERROR));
                        //_elm_access_say(voicedata->layout_main, _(SK_NETWORK_CONNECTION_ERROR));
                }
@@ -902,30 +688,23 @@ void set_animation_state(VoiceData *voicedata)
                if(voicedata->effector)
                        voicedata->effector->Stop(true);
 
-               set_guide_text(voicedata, "");
+               set_guide_text(voicedata, "Tap mic to speak");
 
-               PRINTFUNC(DLOG_DEBUG,"%d", voicedata->stt_results.size());
                powerLock((void*)voicedata, false);
-       }
-       else if (voicedata->state == STT_STATE_VAL_LISTENING) {
-
+       } else if (voicedata->state == STT_STATE_VAL_LISTENING) {
                set_guide_text(voicedata, SK_SPEAK_NOW, true);
 
                if(voicedata->effector)
                        voicedata->effector->Start();
 
                powerLock((void*)voicedata, true);
-       }
-       else if (voicedata->state == STT_STATE_VAL_PROCESSING) {
-
+       } else if (voicedata->state == STT_STATE_VAL_PROCESSING) {
                set_guide_text(voicedata, "");
                if(voicedata->effector)
                        voicedata->effector->Stop();
 
                stt_feedback(VIBRATION_STOP);
-       }
-       else {
-               PRINTFUNC(DLOG_DEBUG,"SK_NETWORK_ERROR");
+       } else {
                set_guide_text(voicedata, _(SK_RECOGNITION_FAILED));
                //_elm_access_say(voicedata->layout_main, _(SK_RECOGNITION_FAILED));
 
@@ -939,8 +718,6 @@ void set_animation_state(VoiceData *voicedata)
                        voicedata->effector->Stop(true);
 
                voicedata->refresh_timer = ecore_timer_add(2.0, _recognition_failure_cb, voicedata);
-
-               //powerLock((void*)voicedata, false);
        }
 }
 
@@ -948,20 +725,22 @@ void show_error_message(VoiceData *vd, stt_error_e reason)
 {
        if(reason == STT_ERROR_OUT_OF_NETWORK)
        {
-               PRINTFUNC(DLOG_DEBUG,"SK_NETWORK_ERROR");
+               PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
 
                int ancs_connected = 0;
                int ret = 0;
                ret = vconf_get_int("file/private/weconn/ancs_connected", &ancs_connected);
 
                if (ret == 0)
-                       PRINTFUNC(DLOG_ERROR, "ancs connected status : %d" ,ancs_connected);
+                       PRINTFUNC(DLOG_ERROR, "ancs connected status : %d"ancs_connected);
                else
                        PRINTFUNC(DLOG_ERROR, "vconf for ancs connection ERROR - %d", ret);
 
-               if (ancs_connected){
+               if (ancs_connected) {
                        char text[512];
-                       snprintf(text, sizeof(text), _(SK_NETWORK_ERROR_FOR_IOS), _(SK_SAMSUNG_GEAR));
+                       const char *format1 = _(SK_NETWORK_ERROR_FOR_IOS);
+                       const char *format2 = _(SK_SAMSUNG_GEAR);
+                       snprintf(text, sizeof(text), format1, format2);
 
                        show_popup_toast((const char*)text, false);
                } else {
@@ -970,12 +749,12 @@ void show_error_message(VoiceData *vd, stt_error_e reason)
 
                vd->state = STT_STATE_VAL_INIT;
 
-       } else if(reason == STT_ERROR_RECORDER_BUSY) {
-               PRINTFUNC(DLOG_WARN,"STT is used by another application");
+       } else if (reason == STT_ERROR_RECORDER_BUSY) {
+               PRINTFUNC(DLOG_WARN, "STT is used by another application");
                show_popup_toast(_(SK_STT_BUSY), false);
                vd->state = STT_STATE_VAL_INIT;
        } else {
-               PRINTFUNC(DLOG_WARN,"Check error code");
+               PRINTFUNC(DLOG_WARN, "Check error code");
                show_popup_toast(_(SK_STT_BUSY), false);
                vd->state = STT_STATE_VAL_INIT;
        }
@@ -991,25 +770,23 @@ static Eina_Bool _start_timer_cb(void* data)
                        voicedata->sttmanager->Start();
                }
                catch (is::stt::SttException &e) {
-                       PRINTFUNC(DLOG_ERROR, "%s", e.what());
-
-                       if(e.GetEcode() == STT_ERROR_OUT_OF_NETWORK)
+                       if (e.GetEcode() == STT_ERROR_OUT_OF_NETWORK)
                        {
-                               PRINTFUNC(DLOG_DEBUG,"SK_NETWORK_ERROR");
                                set_guide_text(voicedata, _(SK_NETWORK_ERROR));
                                voicedata->state = STT_STATE_VAL_INIT;
-                       } else if(e.GetEcode() == STT_ERROR_RECORDER_BUSY) {
-                               PRINTFUNC(DLOG_WARN,"STT is used by another application");
-                               show_popup_toast(_(SK_STT_BUSY), false);
+                       } else if (e.GetEcode() == STT_ERROR_RECORDER_BUSY) {
+                               set_guide_text(voicedata, _(SK_STT_BUSY));
                                voicedata->state = STT_STATE_VAL_INIT;
                        } else {
-                               PRINTFUNC(DLOG_WARN,"Check error code");
-                               show_popup_toast(_(SK_STT_BUSY), false);
+                               set_guide_text(voicedata, _(SK_STT_BUSY));
                                voicedata->state = STT_STATE_VAL_INIT;
                        }
                }
                voicedata->start_timer = NULL;
        }
+
+       start_voice_recorder();
+
        return ECORE_CALLBACK_CANCEL;
 }
 
@@ -1020,9 +797,11 @@ static Eina_Bool _start_timer_cb(void* data)
 
 void on_initial_anim_press_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
 {
-       PRINTFUNC(NO_PRINT,"");
+       PRINTFUNC(NO_PRINT, "");
 
        VoiceData *vd = (VoiceData *)data;
+       if (vd == NULL)
+               return;
 
        int tempVal = vd->sttmanager->GetCurrent();
        if(tempVal == STT_STATE_CREATED) {
@@ -1034,7 +813,6 @@ void on_initial_anim_press_cb(void *data, Evas_Object *obj, const char *emission
        PRINTFUNC(DLOG_DEBUG, "Ui Voice State : %d", vd->state);
 
        switch(vd->state) {
-
                case STT_STATE_VAL_INIT:
 
                        PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_INIT");
@@ -1069,9 +847,8 @@ void on_initial_anim_press_cb(void *data, Evas_Object *obj, const char *emission
                        catch (is::stt::SttException &e) {
                                PRINTFUNC(DLOG_ERROR, "%s", e.what());
 
-                               if(e.GetEcode() != STT_ERROR_INVALID_STATE)
-                               {
-                                       PRINTFUNC(DLOG_DEBUG,"SK_NETWORK_ERROR");
+                               if(e.GetEcode() != STT_ERROR_INVALID_STATE) {
+                                       PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
                                        set_guide_text(vd, _(SK_RECOGNITION_FAILED));
                                        vd->state = STT_STATE_VAL_INIT;
 
@@ -1090,6 +867,8 @@ void on_initial_anim_press_cb(void *data, Evas_Object *obj, const char *emission
                        catch (is::stt::SttException &e) {
                                PRINTFUNC(DLOG_ERROR, "%s", e.what());
                        }
+                       if (vd->effector)
+                               vd->effector->Stop(true);
 
                        break;
 
@@ -1116,15 +895,14 @@ static inline void ea_naviframe_back(void *data, Evas_Object *obj, void *event_i
                ecore_event_handler_del(g_evt_key_down);
 
        g_evt_key_down = NULL;
-
-       //Hide more option
-       if(g_more_option_layout){
-               if(eext_more_option_opened_get(g_more_option_layout) == EINA_TRUE) {
-                       eext_more_option_opened_set(g_more_option_layout, EINA_FALSE);
+       if (_WEARABLE) {
+               //Hide more option
+               if(g_more_option_layout){
+                       if(eext_more_option_opened_get(g_more_option_layout) == EINA_TRUE) {
+                               eext_more_option_opened_set(g_more_option_layout, EINA_FALSE);
+                       }
                }
        }
-
-
 }
 
 static char *__get_genlist_title_label(void *data, Evas_Object *obj, const char *part)
@@ -1134,40 +912,31 @@ static char *__get_genlist_title_label(void *data, Evas_Object *obj, const char
 
 char *__get_genlist_item_label(void *data, Evas_Object *obj, const char *part)
 {
-       char text[128] = {0,};
+       const int BUF_LEN = 128;
+       char text[BUF_LEN] = {'\0', };
 
        if(!strcmp(part, "elm.text"))
        {
-               if((int)data == 0) {
+               if((uintptr_t)data == 0) {
                        return strdup(_("IDS_VC_BODY_AUTOMATIC"));
-               }
-               else {
+               } else {
                        char *s = NULL;
-                       if(g_is_n66) {
-                               s = (char *)disp_lang_array_n66[(int)data];
-                       } else {
-                               s = (char *)disp_lang_array[(int)data];
-                       }
+                       s = (char *)disp_lang_array[(uintptr_t)data];
 
                        if(s) {
                                char *p = strchr(s, '(');
-                               if(p){
+                               if(p) {
                                        strncpy(text, s, p-s);
-                               }else{
-                                       strncpy(text, s, strlen(s));
+                               } else {
+                                       snprintf(text, BUF_LEN, "%s", s);
                                }
-                       }
-                       else{
-                               strncpy(text, "", strlen(""));
+                       } else {
+                               snprintf(text, BUF_LEN, "%s", "");
                        }
                }
-
                return strdup(text);
-       } else if(!strcmp(part, "elm.text.1")) {
-
-
-               if((int)data == 0) {
-
+       } else if (!strcmp(part, "elm.text.1")) {
+               if ((uintptr_t)data == 0) {
                        char* value = NULL;
                        value = vconf_get_str(VCONFKEY_LANGSET);
                        if (NULL == value) {
@@ -1176,99 +945,69 @@ char *__get_genlist_item_label(void *data, Evas_Object *obj, const char *part)
                        }
                        PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
 
-                       char system_lang[6] = {0,};
+                       char system_lang[6] = {0, };
                        strncpy(system_lang, value , 5);
                        free(value);
 
                        // confirm whether the system language is supported by stt engine or not.
                        // if supported, set the language
                        // otherwise, set language to en_US
-                       if(g_is_n66) {
-                               return strdup(get_lang_label_n66(system_lang));
-                       } else {
-                               return strdup(get_lang_label(system_lang));
-                       }
+                       return strdup(get_lang_label(system_lang));
+
                } else {
                        char *s = NULL;
-                       if(g_is_n66) {
-                               s = (char *)disp_lang_array_n66[(int)data];
-                       } else {
-                               s = (char *)disp_lang_array[(int)data];
-                       }
+                       s = (char *)disp_lang_array[(uintptr_t)data];
 
-                       if(s){
+                       if(s) {
                                char *p = strchr(s, '(');
-                               if(p){
-                                       strncpy(text,p+1,strlen(s)-(p-s)-2);
-                               }else{
-                                       strncpy(text, s, strlen(s));
+                               if(p) {
+                                       strncpy(text, p+1, strlen(s)-(p-s)-2);
+                               } else {
+                                       snprintf(text, BUF_LEN, "%s", s);
                                }
-                       }else{
-                               strncpy(text, "", strlen(""));
+                       } else {
+                               snprintf(text, BUF_LEN, "%s", "");
                        }
                        return strdup(text);
                }
-
        }
-
-
        return NULL;
 }
 
 static Evas_Object *__get_genlist_item_content(void *data, Evas_Object *obj, const char *part)
 {
-       int index = (int)data;
+       int index = (intptr_t)data;
        Evas_Object * content = NULL;
 
-       if (!strcmp(part, "elm.icon")) {
+       if (!strcmp(part, "elm.icon") ||
+           !strcmp(part, "elm.swallow.end")) {
                content = elm_radio_add(obj);
+               elm_object_style_set(content, "list");
                elm_radio_state_value_set(content, index);
                elm_radio_group_add(content, radio_gp);
                evas_object_size_hint_weight_set(content, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
                evas_object_propagate_events_set(content, EINA_TRUE);
                evas_object_size_hint_align_set(content, EVAS_HINT_FILL, EVAS_HINT_FILL);
-               elm_object_style_set(content, "list");
-
-               if (elm_config_access_get())
-                       elm_access_object_unregister(content);
-
        }
        return content;
-
-
 }
 
 static int get_language_value()
 {
-
-
-#if 0
        int lang = 0, ret = 0;
 
        ret = preference_get_int(PREFERENCE_ISE_STT_LANGUAGE, &lang);
-       if(PREFERENCE_ERROR_NONE != ret){
+       if (PREFERENCE_ERROR_NONE != ret) {
                PRINTFUNC(DLOG_ERROR, "preference_get_int error!(%d)", ret);
-               preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, (int)2); //auto
-               lang = 2;
+               preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, STT_VOICE_N66_AUTO); //auto
+               lang = STT_VOICE_N66_AUTO;
        }
-#else
-       int lang = 0, ret = 0;
 
-       ret = vconf_get_int(VCONFKEY_ISE_STT_LANGUAGE, &lang);
-       if (ret !=0) {
-               PRINTFUNC(DLOG_ERROR, "Vconf_get_int error!(%d)", ret);
-       }
-#endif
-       if(g_is_n66) {
-               if(lang < 0 || lang > 6) {
-                       PRINTFUNC(DLOG_WARN, "vconf lang orig(%d) to be 0", lang);
-                       lang = 0;
-               }
-               PRINTFUNC(DLOG_DEBUG, "n66 current language value for stt (%s).", disp_lang_array_n66[lang]);
-       }
-       else {
-               PRINTFUNC(DLOG_DEBUG, "current language value for stt (%s).", disp_lang_array[lang]);
+       if (lang < 0 || lang > (int)(sizeof(supported_language)/sizeof(supported_language[0])-1)) {
+               PRINTFUNC(DLOG_WARN, "vconf lang orig(%d) to be 0", lang);
+               lang = 0;
        }
+       PRINTFUNC(DLOG_DEBUG, "n66 current language value for stt (%s).", disp_lang_array[lang]);
 
        return lang;
 }
@@ -1278,23 +1017,14 @@ static void set_language_value(int type)
        // Add implementation to store language type.
        int ret = 0;
 
-#if 0
        ret = preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, (int)type);
        if(PREFERENCE_ERROR_NONE != ret){
                PRINTFUNC(DLOG_ERROR, "preference_set_int error!(%d)", ret);
        }
 
-#else
-       ret = vconf_set_int(VCONFKEY_ISE_STT_LANGUAGE, (int) type);
-       if (ret != 0) {
-               PRINTFUNC(DLOG_ERROR, "Vconf_set_int error!(%d)", ret);
-               return;
-       }
-#endif
        PRINTFUNC(DLOG_DEBUG, "language type (%d)", type);
 
        // Update string
-
 }
 
 static void get_stt_default_language(VoiceData *my_voicedata)
@@ -1330,7 +1060,7 @@ static void get_stt_default_language(VoiceData *my_voicedata)
                        }
                        PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
 
-                       char system_lang[6] = {0,};
+                       char system_lang[6] = {0, };
                        strncpy(system_lang, value , 5);
                        free(value);
 
@@ -1353,62 +1083,6 @@ static void get_stt_default_language(VoiceData *my_voicedata)
                case STT_VOICE_N66_KO_KR :
                case STT_VOICE_N66_ZH_CN :
                {
-                       my_voicedata->kbd_lang = strdup(supported_language_n66[stt_lang]);
-               }
-               break;
-               default :
-                       my_voicedata->kbd_lang = strdup("en_US");
-                       break;
-               }
-       } else {
-               STT_VOICE_LANGUAGE_I stt_lang;
-               stt_lang = (STT_VOICE_LANGUAGE_I)get_language_value();
-
-               PRINTFUNC(DLOG_DEBUG, "language type (%d)", stt_lang);
-
-               switch(stt_lang) {
-               case STT_VOICE_AUTO :
-               {
-                       stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
-
-                       // get system display language
-                       char* value = NULL;
-                       value = vconf_get_str(VCONFKEY_LANGSET);
-                       if (NULL == value) {
-                               PRINTFUNC(DLOG_ERROR, "Fail to get display language");
-                               return;
-                       }
-                       PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
-
-                       char system_lang[6] = {0,};
-                       strncpy(system_lang, value , 5);
-                       free(value);
-
-                       // confirm whether the system language is supported by stt engine or not.
-                       // if supported, set the language
-                       // otherwise, set language to en_US
-                       if(is_lang_supported_by_stt(system_lang) == TRUE) {
-                               my_voicedata->kbd_lang = strdup(system_lang);
-                               PRINTFUNC(DLOG_DEBUG, "Set auto language (%s)", system_lang);
-                       } else {
-                               my_voicedata->kbd_lang = strdup("en_US");
-                               PRINTFUNC(DLOG_DEBUG, "System language is not supported by STT (%s), en_US will be set", system_lang);
-                       }
-               }
-               break;
-               case STT_VOICE_DE_DE :
-               case STT_VOICE_EN_GB :
-               case STT_VOICE_EN_US :
-               case STT_VOICE_ES_ES :
-               case STT_VOICE_ES_US :
-               case STT_VOICE_FR_FR :
-               case STT_VOICE_IT_IT :
-               case STT_VOICE_JA_JP :
-               case STT_VOICE_KO_KR :
-               case STT_VOICE_RU_RU :
-               case STT_VOICE_ZH_CN :
-               case STT_VOICE_PT_BR :
-               {
                        my_voicedata->kbd_lang = strdup(supported_language[stt_lang]);
                }
                break;
@@ -1419,7 +1093,6 @@ static void get_stt_default_language(VoiceData *my_voicedata)
        }
 
        PRINTFUNC(DLOG_DEBUG, "stt language (%s)", my_voicedata->kbd_lang);
-
 }
 
 static Eina_Bool close_setting_window_idler_cb(void *data)
@@ -1437,12 +1110,11 @@ static void language_set_genlist_radio_cb(void *data, Evas_Object *obj, void *ev
        if(!data) return;
 
        int index = 0;
-       Evas_Object *genlist = (Evas_Object *) data;
 
        Elm_Object_Item * item = (Elm_Object_Item *) event_info;
        if (item) {
                elm_genlist_item_selected_set(item, 0);
-               index = (int)elm_object_item_data_get(item);
+               index = (uintptr_t)elm_object_item_data_get(item);
                elm_genlist_item_update(item);
        }
        set_language_value(index);
@@ -1451,7 +1123,7 @@ static void language_set_genlist_radio_cb(void *data, Evas_Object *obj, void *ev
        ecore_timer_add(0.3, close_setting_window_idler_cb, NULL);
 }
 
-static void language_changed_cb2(void *data, Evas_Object *obj, const char *emission, const char *source)
+static void language_changed_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
 {
        if(!obj) return;
        elm_genlist_realized_items_update(obj);
@@ -1468,43 +1140,10 @@ Eina_Bool _ise_keydown_cb(void *data, int type, void *event)
        return ECORE_CALLBACK_DONE;
 }
 
-char *_language_list_access_info_cb(void *data, Evas_Object *obj)
-{
-       PRINTFUNC(DLOG_DEBUG,"%s", __func__);
-
-       int value;
-       int index;
-       std::string text = std::string(gettext(TTS_RADIO_BUTTON));
-       const Elm_Object_Item *item = (Elm_Object_Item *)data;
-
-       Evas_Object* radio = elm_object_item_part_content_get(item, "elm.icon");
-
-       index = elm_genlist_item_index_get(item);
-
-       if(index == 1) // title
-               return NULL;
-
-
-       value = elm_radio_value_get(radio);
-       //PRINTFUNC(DLOG_DEBUG,"index=%d value = %d", index, value);
-       if(index == value + 2 ){
-               text = text + std::string(" ") + std::string(gettext(TTS_SELECTED));
-       } else {
-               text = text + std::string(" ") + std::string(gettext(TTS_NOT_SELECTED));
-       }
-
-       return strdup(text.c_str());
-}
 
 static void _language_list_item_realized(void *data, Evas_Object *obj, void *event_info) //called when list scrolled
 {
-       PRINTFUNC(DLOG_DEBUG,"%s", __func__);
-       if (elm_config_access_get()) {
-               Elm_Object_Item *item = (Elm_Object_Item *)event_info;
-               Evas_Object *item_access = elm_object_item_access_object_get(item);
-
-               elm_access_info_cb_set(item_access, ELM_ACCESS_CONTEXT_INFO, _language_list_access_info_cb, (void*)item);
-       }
+       PRINTFUNC(DLOG_DEBUG, "%s", __func__);
 }
 
 static Evas_Object *create_language_list(Evas_Object *parent)
@@ -1516,20 +1155,20 @@ static Evas_Object *create_language_list(Evas_Object *parent)
 
        elm_genlist_mode_set(genlist, ELM_LIST_COMPRESS);
        elm_genlist_homogeneous_set(genlist, EINA_TRUE);
-//     uxt_genlist_set_bottom_margin_enabled(genlist, EINA_TRUE);
-
+#ifdef _CIRCLE
        Evas_Object *circle_language_genlist = eext_circle_object_genlist_add(genlist, NULL);
        eext_circle_object_genlist_scroller_policy_set(circle_language_genlist, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
        evas_object_resize(circle_language_genlist, 360, 360);
        evas_object_show(circle_language_genlist);
        eext_rotary_object_event_activated_set(circle_language_genlist, EINA_TRUE);
-
+#else
+       evas_object_show(genlist);
+#endif
        int i = 0;
        int lang_val = 0;
        Elm_Object_Item * item = NULL;
-       Elm_Object_Item * item_title = NULL;
 
-       evas_object_size_hint_weight_set(genlist, EVAS_HINT_EXPAND,EVAS_HINT_EXPAND);
+       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);
 
        radio_gp = elm_radio_add(genlist);
@@ -1541,11 +1180,16 @@ static Evas_Object *create_language_list(Evas_Object *parent)
        itc_title.item_style = "title";
        itc_title.func.text_get = __get_genlist_title_label;
        itc_title.func.content_get = NULL;
-
-       item_title = elm_genlist_item_append(genlist, &itc_title, (void *)-1, NULL, ELM_GENLIST_ITEM_GROUP, NULL, genlist);
+       if (_WEARABLE) {
+               item = elm_genlist_item_append(genlist, &itc_title, (void *)-1, NULL, ELM_GENLIST_ITEM_GROUP, NULL, genlist);
+       }
 
        // 2 line text
-       itc_2text.item_style = "2text.1icon.1/sub1.multiline";
+       if (_WEARABLE) {
+               itc_2text.item_style = "2text.1icon.1/sub1.multiline";
+       } else {
+               itc_2text.item_style = "type1";
+       }
        itc_2text.func.text_get = __get_genlist_item_label;
        itc_2text.func.content_get = __get_genlist_item_content;
 
@@ -1562,80 +1206,63 @@ static Evas_Object *create_language_list(Evas_Object *parent)
        }
 
        // 1 line text
-       itc_1text.item_style = "1text.1icon.1";
+       if (_WEARABLE) {
+               itc_1text.item_style = "1text.1icon.1";
+       } else {
+               itc_1text.item_style = "type1";
+       }
        itc_1text.func.text_get = __get_genlist_item_label;
        itc_1text.func.content_get = __get_genlist_item_content;
 
-       if(g_is_n66) {
-               for (i = 1; i < 7; i++)
-               {
-
-                       char *s = (char *)disp_lang_array_n66[i];
-
-                       if(strchr(s, '(')){
-                               item = item_append(genlist, itc_2text, i, language_set_genlist_radio_cb, genlist);
-                       } else {
-                               item = item_append(genlist, itc_1text, i, language_set_genlist_radio_cb, genlist);
-                       }
-
-                       if(lang_val == i) {
-                               PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
-                               elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
-                       }
+       for (i = 1; i < (long)(sizeof(disp_lang_array)/sizeof(disp_lang_array[0])); i++)
+       {
+               char *s = (char *)disp_lang_array[i];
 
-                       if ( item == NULL ) {
-                               PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
-                               break;
-                       }
+               if(strchr(s, '(')){
+                       item = item_append(genlist, itc_2text, i, language_set_genlist_radio_cb, genlist);
+               } else {
+                       item = item_append(genlist, itc_1text, i, language_set_genlist_radio_cb, genlist);
                }
-       } else {
-               for (i = 1; i < 13; i++)
-               {
 
-                       char *s = (char *)disp_lang_array[i];
-
-                       if(strchr(s, '(')){
-                               item = item_append(genlist, itc_2text, i, language_set_genlist_radio_cb, genlist);
-                       } else {
-                               item = item_append(genlist, itc_1text, i, language_set_genlist_radio_cb, genlist);
-                       }
-
-                       if(lang_val == i) {
-                               PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
-                               elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
-                       }
+               if(lang_val == i) {
+                       PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
+                       elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
+               }
 
-                       if ( item == NULL ) {
-                               PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
-                               break;
-                       }
+               if ( item == NULL ) {
+                       PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
+                       break;
                }
        }
+       Elm_Object_Item *dummy;
+       Elm_Genlist_Item_Class *itc_dummy = elm_genlist_item_class_new();
+       if (itc_dummy) {
+               itc_dummy->item_style = "title";
+               itc_dummy->func.text_get = NULL;
+               itc_dummy->func.content_get = NULL;
+       }
+       dummy = elm_genlist_item_append(genlist, itc_dummy, NULL, NULL, ELM_GENLIST_ITEM_NONE, NULL, NULL);
+       elm_genlist_item_select_mode_set(dummy, ELM_OBJECT_SELECT_MODE_NONE);
 
+       LOGD("before elm_radio_value_set > lang_val = %d", lang_val);
+       radio_gp = elm_radio_add(genlist);
+       elm_radio_state_value_set(radio_gp, lang_val);
        elm_radio_value_set(radio_gp, lang_val);
 
-       elm_object_signal_callback_add(genlist, "elm,system,language,change", "elm", language_changed_cb2, NULL);
-//     eext_rotary_event_callback_set(genlist, _language_list_rotary_cb, NULL);
+       elm_object_signal_callback_add(genlist, "elm,system,language,change", "elm", language_changed_cb, NULL);
        evas_object_smart_callback_add(genlist, "realized", _language_list_item_realized, NULL);
 
-
        g_evt_key_down = ecore_event_handler_add(ECORE_EVENT_KEY_DOWN, _ise_keydown_cb, NULL);
        return genlist;
 }
 
 void create_setting_window(Evas_Object *more_option_layout)
 {
-       Evas_Coord w, h;
-
        Evas_Object *window = NULL;
        Evas_Object *layout = NULL;
        Evas_Object *genlist = NULL;
        Evas_Object *naviframe = NULL;
 
-       Elm_Object_Item *item = NULL;
-
-       const char *str = "mobile";
-
        /**
         * Create full size window
         *
@@ -1647,12 +1274,10 @@ void create_setting_window(Evas_Object *more_option_layout)
        }
 
        elm_win_title_set(window, "voice-input-setting");
-//     ecore_x_window_size_get(ecore_x_window_root_first_get(), &w, &h);
        elm_win_borderless_set(window, EINA_TRUE);
-       evas_object_resize(window, w, h);
+
 
        elm_win_indicator_mode_set(window, ELM_WIN_INDICATOR_HIDE);
-       elm_win_profiles_set(window, &str, 1);
 
        /**
         * Set window theme
@@ -1693,7 +1318,7 @@ void create_setting_window(Evas_Object *more_option_layout)
         * Naviframe
         *
         */
-       naviframe= elm_naviframe_add(layout);
+       naviframe = elm_naviframe_add(layout);
        if (naviframe == NULL){
                PRINTFUNC(DLOG_DEBUG, "create navi_frame failed");
        }
@@ -1707,8 +1332,11 @@ void create_setting_window(Evas_Object *more_option_layout)
         */
        genlist = create_language_list(naviframe);
 
+       const char *item_style = NULL;
+       if (_WEARABLE)
+               item_style = "empty";
        //item = elm_naviframe_item_push(naviframe, "IDS_VC_HEADER_VOICE_INPUT_LANGUAGE", NULL, NULL, genlist, NULL);
-       item = elm_naviframe_item_push(naviframe, NULL, NULL, NULL, genlist, "empty");
+       elm_naviframe_item_push(naviframe, NULL, NULL, NULL, genlist, item_style);
        //elm_object_item_domain_text_translatable_set(item, PACKAGE, EINA_TRUE);
 
        g_setting_window = window;
@@ -1716,52 +1344,6 @@ void create_setting_window(Evas_Object *more_option_layout)
        g_more_option_layout = more_option_layout;
 }
 
-static void language_changed_cb(void *data, Evas_Object * obj, void *event_info)
-{
-       PRINTFUNC(DLOG_DEBUG,"");
-
-       if(!obj) return;
-       if(!data) return;
-
-}
-
-static void get_text_part_width(Evas_Object *window, const char *text, Evas_Coord *calculated_width)
-{
-       if(!window) return;
-       if(!text) return;
-       if(!calculated_width) return;
-
-       Evas_Coord width, height;
-
-       char *strbuf = NULL;
-       Evas_Object *tb = NULL;
-       Evas_Textblock_Style *st = NULL;
-       Evas_Textblock_Cursor *cur = NULL;
-
-       tb = evas_object_textblock_add(evas_object_evas_get(window));
-       evas_object_textblock_legacy_newline_set(tb, EINA_FALSE);
-
-       st = evas_textblock_style_new();
-       evas_textblock_style_set(st, VIRTUAL_TEXT_AREA_FONT_STYLE);
-       evas_object_textblock_style_set(tb, st);
-
-       cur = evas_object_textblock_cursor_new(tb);
-       strbuf = elm_entry_utf8_to_markup(text);
-       evas_object_resize(tb, 360, 47);
-
-       evas_object_textblock_text_markup_set(tb, strbuf);
-       evas_textblock_cursor_format_prepend(cur, "+ wrap=mixed");
-       evas_object_textblock_size_formatted_get(tb, &width, &height);
-       evas_object_resize(tb, width, 47);
-
-       *calculated_width = width;
-
-       if(strbuf) free(strbuf);
-       if(tb) evas_object_del(tb);
-       if(st) evas_textblock_style_free(st);
-       if(cur) evas_textblock_cursor_free(cur);
-}
-
 void _stt_lang_changed_cb(keynode_t *key, void* data)
 {
        PRINTFUNC(DLOG_DEBUG, "");
@@ -1773,12 +1355,11 @@ void _stt_lang_changed_cb(keynode_t *key, void* data)
        vd->mo->Update();
 
        return;
-
 }
 
-static void __done_key_cb( void *data, Evas_Object *obj, void *event_info )
+static void __done_key_cb(void *data, Evas_Object *obj, void *event_info )
 {
-       PRINTFUNC(DLOG_DEBUG,"");
+       PRINTFUNC(DLOG_DEBUG, "");
 
        if(!obj) return;
        if(!data) return;
@@ -1790,7 +1371,6 @@ static void __done_key_cb( void *data, Evas_Object *obj, void *event_info )
 
 static void __stt_detailed_entry_input_panel_event_cb(void *data, Ecore_IMF_Context *imf_context,  int value)
 {
-
        if(!data) return;
 
        VoiceData *voicedata = (VoiceData *)data;
@@ -1800,30 +1380,32 @@ static void __stt_detailed_entry_input_panel_event_cb(void *data, Ecore_IMF_Cont
                elm_naviframe_item_pop(voicedata->naviframe);
                break;
        case ECORE_IMF_INPUT_PANEL_STATE_WILL_SHOW: // 2
-               PRINTFUNC(DLOG_DEBUG,"keypad state will show.");
+               PRINTFUNC(DLOG_DEBUG, "keypad state will show.");
                break;
        case ECORE_IMF_INPUT_PANEL_STATE_SHOW: // 0
-               PRINTFUNC(DLOG_DEBUG,"keypad state show.");
+               PRINTFUNC(DLOG_DEBUG, "keypad state show.");
                break;
        }
 }
 
 static void __stt_detailed_entry_del_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
 {
-
        if (obj) {
                Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(obj);
                ecore_imf_context_input_panel_event_callback_del(imf_context, ECORE_IMF_INPUT_PANEL_STATE_EVENT, __stt_detailed_entry_input_panel_event_cb);
-               PRINTFUNC(DLOG_DEBUG,"input_panel_event_cb is deleted.");
+               PRINTFUNC(DLOG_DEBUG, "input_panel_event_cb is deleted.");
        }
 }
 
 static Evas_Object *create_text_detiled_view(Evas_Object *parent)
 {
-
        string edj_path = get_resource_path();
-       edj_path = edj_path + STT_EDJ_FILE;
-
+       if(_WEARABLE)
+               edj_path = edj_path + STT_EDJ_FILE_WEARABLE;
+       else if (_TV)
+               edj_path = edj_path + STT_EDJ_FILE_TV;
+       else
+               edj_path = edj_path + STT_EDJ_FILE_MOBILE;
        //layout
        Evas_Object *layout = elm_layout_add(parent);
        elm_layout_file_set(layout, edj_path.c_str(), "entry_focused_layout");
@@ -1847,17 +1429,8 @@ static Evas_Object *create_text_detiled_view(Evas_Object *parent)
 
        elm_object_part_content_set(layout, "contents", entry);
        return layout;
-
 }
 
-static Eina_Bool _idler_cb2(void *data)
-{
-       VoiceData *voicedata = (VoiceData *)data;
-
-//     uxt_scroller_set_auto_scroll_enabled(voicedata->scroller, EINA_FALSE);
-
-       return ECORE_CALLBACK_CANCEL;
-}
 
 static Eina_Bool __stt_entry_detailed_view_pop_cb(void *data, Elm_Object_Item *it)
 {
@@ -1886,20 +1459,17 @@ static Eina_Bool __stt_entry_detailed_view_pop_cb(void *data, Elm_Object_Item *i
        elm_entry_entry_set(main_entry, str);
        elm_entry_cursor_pos_set(main_entry, pos);
 
-       int x,y,w,h;
-       elm_entry_cursor_geometry_get(main_entry,&x,&y,&w,&h);
-       PRINTFUNC(DLOG_DEBUG, "%d %d %d %d",x,y,w,h);
+       int x, y, w, h;
+       elm_entry_cursor_geometry_get(main_entry, &x, &y, &w, &h);
+       PRINTFUNC(DLOG_DEBUG, "%d %d %d %d", x, y, w, h);
 
        elm_scroller_region_bring_in(voicedata->scroller, 0, y+h, 300, 168);
 
-       ecore_idler_add(_idler_cb2, voicedata);
-
        return EINA_TRUE;
 }
 
 static void _stt_entry_clicked_cb(void *data, Evas_Object * obj, void *event_info)
 {
-
        PRINTFUNC(DLOG_DEBUG, "");
 
        if(!obj) return;
@@ -1916,7 +1486,6 @@ static void _stt_entry_clicked_cb(void *data, Evas_Object * obj, void *event_inf
        str =  elm_entry_markup_to_utf8(elm_entry_entry_get(obj));
 
        if (str && strlen(str) > 0) {
-
                try {
                        if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
                                voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING) {
@@ -1935,7 +1504,7 @@ static void _stt_entry_clicked_cb(void *data, Evas_Object * obj, void *event_inf
                Evas_Object *detailed_entry = elm_object_part_content_get(ly_detailed_view, "contents");
                elm_entry_entry_set(detailed_entry, str);
                elm_entry_cursor_pos_set(detailed_entry, pos);
-               evas_object_smart_callback_add( detailed_entry, "activated", __done_key_cb, voicedata ); // Register callback for Done key
+               evas_object_smart_callback_add(detailed_entry, "activated", __done_key_cb, voicedata); // Register callback for Done key
 
                Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(detailed_entry);
                ecore_imf_context_input_panel_event_callback_add(imf_context, ECORE_IMF_INPUT_PANEL_STATE_EVENT, __stt_detailed_entry_input_panel_event_cb, voicedata);
@@ -1943,7 +1512,7 @@ static void _stt_entry_clicked_cb(void *data, Evas_Object * obj, void *event_inf
 
                // Navi Push
                Elm_Object_Item *navi_it = elm_naviframe_item_push(voicedata->naviframe, NULL, NULL, NULL, ly_detailed_view, NULL);
-               elm_naviframe_item_pop_cb_set(navi_it, __stt_entry_detailed_view_pop_cb,(void *)voicedata);
+               elm_naviframe_item_pop_cb_set(navi_it, __stt_entry_detailed_view_pop_cb, (void *)voicedata);
                elm_naviframe_item_title_enabled_set(navi_it, EINA_FALSE, EINA_FALSE);
                free(str);
        }
@@ -1954,23 +1523,22 @@ static void _stt_entry_clicked_cb(void *data, Evas_Object * obj, void *event_inf
 
 void activate_circle_scroller_for_stt_textbox(void* data, Eina_Bool bActivate)
 {
-
-       PRINTFUNC(DLOG_DEBUG,"");
+       PRINTFUNC(DLOG_DEBUG, "");
 
        if(!data) return;
        VoiceData *voicedata = (VoiceData *)data;
 
        Evas_Object *scroller = NULL;
-       Evas_Object *circle_scroller = NULL;
-
        scroller = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "text_area");
-       circle_scroller = (Evas_Object *) evas_object_data_get(scroller, "circle");
-       eext_rotary_object_event_activated_set(circle_scroller, bActivate);
+       if (_WEARABLE) {
+               Evas_Object *circle_scroller = NULL;
+               circle_scroller = (Evas_Object *) evas_object_data_get(scroller, "circle");
+               eext_rotary_object_event_activated_set(circle_scroller, bActivate);
+       }
 }
 
 static Evas_Object *create_textblock(void* data)
 {
-
        if(!data) return NULL;
 
        VoiceData *voicedata = (VoiceData *)data;
@@ -1979,11 +1547,15 @@ static Evas_Object *create_textblock(void* data)
        Evas_Object *box = NULL;
        Evas_Object *inner_layout = NULL;
        Evas_Object *entry = NULL;
-       Evas_Object *tb = NULL;
        Evas_Object *circle_scroller = NULL;
 
        string edj_path = get_resource_path();
-       edj_path = edj_path + STT_EDJ_FILE;
+       if(_WEARABLE)
+               edj_path = edj_path + STT_EDJ_FILE_WEARABLE;
+       else if (_TV)
+               edj_path = edj_path + STT_EDJ_FILE_TV;
+       else
+               edj_path = edj_path + STT_EDJ_FILE_MOBILE;
 
        scroller = elm_scroller_add(voicedata->layout_main);
 
@@ -1992,17 +1564,15 @@ static Evas_Object *create_textblock(void* data)
        evas_object_size_hint_align_set(scroller, EVAS_HINT_FILL, EVAS_HINT_FILL);
        evas_object_size_hint_weight_set(scroller, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
 
-//     elm_scroller_page_size_set(scroller, 0, 50);
-//     elm_scroller_page_scroll_limit_set(scroller, 0, 1);
+       elm_scroller_page_size_set(scroller, 0, 50);
+       elm_scroller_page_scroll_limit_set(scroller, 0, 1);
 
        elm_object_scroll_lock_x_set(scroller, EINA_TRUE);
-
-//     uxt_scroller_set_auto_scroll_enabled(scroller, EINA_FALSE);
-
-       circle_scroller = eext_circle_object_scroller_add(scroller, app_data->circle_surface);
-       eext_circle_object_scroller_policy_set(circle_scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
-       eext_rotary_object_event_activated_set(circle_scroller, EINA_TRUE);
-
+       if (_WEARABLE) {
+               circle_scroller = eext_circle_object_scroller_add(scroller, app_data->circle_surface);
+               eext_circle_object_scroller_policy_set(circle_scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
+               eext_rotary_object_event_activated_set(circle_scroller, EINA_TRUE);
+       }
        box = elm_box_add(scroller);
 
        inner_layout = elm_layout_add(scroller);
@@ -2021,7 +1591,7 @@ static Evas_Object *create_textblock(void* data)
 
 #define FORMAT_TEXT_AREA_FONT_STYLE \
        "DEFAULT='font=Tizen:style=Regular font_size=32 color=#%02x%02x%02x%02x text_class=tizen wrap=mixed align=center' newline='br' b='+ font=Tizen:style=Bold'link='+ underline=on underline_color=#%02x%02x%02x%02x'"
-       int a,r,g,b;
+       int a = 0xFF, r = 0xFF, g = 0xFF, b = 0xFF;
        char customStyle[512];
 //     ea_theme_color_get("AT02112", &r, &g, &b, &a, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
        snprintf(customStyle, 512, FORMAT_TEXT_AREA_FONT_STYLE, r, g, b, a, r, g, b, a);
@@ -2041,17 +1611,15 @@ static Evas_Object *create_textblock(void* data)
        evas_object_show(inner_layout);
 
        return scroller;
-
 }
 
 static Evas_Object *create_progressbar(Evas_Object *parent)
 {
-
        Evas_Object *progressbar = NULL;
 
        progressbar = elm_progressbar_add(parent);
        elm_object_style_set(progressbar, "voice_input/process/small");
-       //elm_progressbar_pulse(progressbar, EINA_TRUE);
+       elm_progressbar_pulse(progressbar, EINA_TRUE);
 
        evas_object_size_hint_align_set(progressbar, EVAS_HINT_FILL, EVAS_HINT_FILL);
        evas_object_size_hint_weight_set(progressbar, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
@@ -2061,23 +1629,21 @@ static Evas_Object *create_progressbar(Evas_Object *parent)
        evas_object_show(progressbar);
 
        return progressbar;
+}
 
+static Eina_Bool _custom_back_cb(void *data, Elm_Object_Item *it)
+{
+       PRINTFUNC(DLOG_DEBUG, "");
+       _back_to_genlist_for_selector();
+       return EINA_TRUE;
 }
 
 static Evas_Object *create_fullview(Evas_Object *parent, VoiceData *r_voicedata)
 {
-       PRINTFUNC(NO_PRINT,"");
+       PRINTFUNC(NO_PRINT, "");
 
-       Evas_Object *more_option_layout = NULL;
        Evas_Object *layout_main = NULL;
-       Evas_Object *lang_btn_box = NULL;
-       Evas_Object *lang_btn = NULL;
-       Evas_Object *to = NULL;
-       Evas_Object *ao = NULL;
-
-       char *lang_type_str = NULL;
 
-       int lang_val = 0;
        int is_screen_reader_on = FALSE;
 
        VoiceData *voicedata = r_voicedata;
@@ -2100,47 +1666,45 @@ static Evas_Object *create_fullview(Evas_Object *parent, VoiceData *r_voicedata)
        voicedata->layout_main = layout_main;
 
        string edj_path = get_resource_path();
-       edj_path = edj_path + STT_EDJ_FILE;
+       if(_WEARABLE)
+               edj_path = edj_path + STT_EDJ_FILE_WEARABLE;
+       else if (_TV)
+               edj_path = edj_path + STT_EDJ_FILE_TV;
+       else
+               edj_path = edj_path + STT_EDJ_FILE_MOBILE;
 
        if (vconf_get_bool(VCONFKEY_SETAPPL_ACCESSIBILITY_TTS, &is_screen_reader_on) == -1) {
-               PRINTFUNC(DLOG_ERROR,"Cannot read value of screen reader from vconf");
+               PRINTFUNC(DLOG_ERROR, "Cannot read value of screen reader from vconf");
        }
 
-       evas_object_size_hint_weight_set (layout_main, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
-       evas_object_size_hint_align_set (layout_main, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       evas_object_size_hint_weight_set(layout_main, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(layout_main, EVAS_HINT_FILL, EVAS_HINT_FILL);
 
-       elm_layout_file_set (layout_main, edj_path.c_str(), "mic_control");
+       elm_layout_file_set(layout_main, edj_path.c_str(), "mic_control");
 
-       //elm_object_content_set(parent, layout_main);
+       elm_object_content_set(parent, layout_main);
 
        //Canvas for Cairo effect
        Evas_Object *canvas = evas_object_image_filled_add(evas_object_evas_get(layout_main));
-//     evas_object_image_alpha_set(canvas, EINA_TRUE);
-       evas_object_size_hint_align_set (canvas, EVAS_HINT_FILL, EVAS_HINT_FILL);
-       evas_object_size_hint_weight_set (canvas, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
-       evas_object_move (canvas, 0, 0);
+       evas_object_image_alpha_set(canvas, EINA_TRUE);
+       evas_object_size_hint_align_set(canvas, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       evas_object_size_hint_weight_set(canvas, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_move(canvas, 0, 0);
 
        Evas_Coord CanvasW, CanvasH;
        CanvasW = 360;
        CanvasH = 74;
-       evas_object_image_size_set (canvas, CanvasW, CanvasH);
-       evas_object_resize (canvas, CanvasW, CanvasH);
-       evas_object_size_hint_min_set (canvas, CanvasW, CanvasH);
-       evas_object_show (canvas);
+       evas_object_image_size_set(canvas, CanvasW, CanvasH);
+       evas_object_resize(canvas, CanvasW, CanvasH);
+       evas_object_size_hint_min_set(canvas, CanvasW, CanvasH);
+       evas_object_show(canvas);
 
        elm_object_part_content_set(layout_main, "EFFECT_BG", canvas);
 
-
        // MIC Button
        Evas_Object *m_mic_button = elm_button_add(layout_main);
        elm_object_style_set(m_mic_button, "vic/micbutton");
        elm_object_part_content_set(layout_main, "MIC", m_mic_button);
-       if (elm_config_access_get()){
-               elm_access_info_cb_set(m_mic_button, ELM_ACCESS_INFO, _mic_access_info_cb, NULL);
-               elm_access_info_cb_set(m_mic_button, ELM_ACCESS_TYPE, _mic_access_info_cb, NULL);
-               elm_access_info_cb_set(m_mic_button, ELM_ACCESS_STATE, _mic_access_info_cb, NULL);
-               evas_object_smart_callback_add(m_mic_button, "access,highlighted", _mic_highlighted_cb, voicedata);
-       }
 
        elm_object_disabled_set(m_mic_button, EINA_TRUE);
        evas_object_smart_callback_add(m_mic_button, "clicked", on_mic_button_press_cb, (void *) voicedata);
@@ -2165,22 +1729,8 @@ static Evas_Object *create_fullview(Evas_Object *parent, VoiceData *r_voicedata)
        panel = elm_panel_add(panel_layout);
        elm_panel_orient_set(panel, ELM_PANEL_ORIENT_LEFT);
        elm_layout_theme_set(panel, "panel", "left_confirm", "default");
-       if(app_data->source_app_control){
-               int ret;
-               char *app_id = NULL;
-               ret = app_control_get_extra_data(app_data->source_app_control, "selector_keyboard_app_id", &app_id);
-               if (ret == APP_CONTROL_ERROR_NONE) {
-                       PRINTFUNC(DLOG_DEBUG, "app_id = %s", app_id);
-               }
+       elm_layout_theme_set(panel, "panel", "left_sending", "default");
 
-               if(app_id){
-                       if(!strcmp(app_id, "com.samsung.message.appcontrol.compose")
-                               || !strcmp(app_id, "com.samsung.wemail-send")){
-                               elm_layout_theme_set(panel, "panel", "left_sending", "default");
-                       }
-                       free(app_id);
-               }
-       }
        elm_layout_signal_callback_add(panel, "cue,clicked", "elm", _panel_cue_clicked_cb, (void *) voicedata);
        evas_object_show(panel);
 
@@ -2206,56 +1756,6 @@ static Evas_Object *create_fullview(Evas_Object *parent, VoiceData *r_voicedata)
 
        mo->SetContentLayout(layout_main);
 
-       //accesbility chaining
-       if (elm_config_access_get()) {
-               //right cue
-               Evas_Object *cue_access_right = NULL;
-
-               Evas_Object *panel_right = elm_object_part_content_get(mo->getMoreOptionLayout(), "elm.swallow.right");
-               if (!panel_right) {
-                   PRINTFUNC(DLOG_DEBUG,"panel_right == NULL");
-               }
-               Evas_Object *cue_right = (Evas_Object *)edje_object_part_object_get(elm_layout_edje_get(panel_right), "cue.event");
-               if (!cue_right) {
-                   PRINTFUNC(DLOG_DEBUG,"cue_right == NULL");
-               }
-               Evas_Object *_access_right = elm_access_object_get(cue_right);
-               if (!_access_right){
-                   PRINTFUNC(DLOG_DEBUG,"_access_right == NULL");
-               }
-               cue_access_right = _access_right;
-
-               //left cue
-               Evas_Object *cue_access_left = NULL;
-               Evas_Object *panel_layout = elm_layout_content_get(layout_main, "left_panel_area");
-               Evas_Object *panel_left = elm_layout_content_get(panel_layout, "elm.swallow.right");
-               if (!panel_left) {
-                   PRINTFUNC(DLOG_DEBUG,"panel_left == NULL");
-               }
-               Evas_Object *cue_left = (Evas_Object *)edje_object_part_object_get(elm_layout_edje_get(panel_left), "cue.event");
-               if (!cue_left) {
-                   PRINTFUNC(DLOG_DEBUG,"cue_left == NULL");
-               }
-               Evas_Object *_access_left = elm_access_object_register(cue_left, panel_left);
-               if (!_access_left){
-                   PRINTFUNC(DLOG_DEBUG,"_access_left == NULL");
-               }
-               elm_access_info_cb_set(_access_left, ELM_ACCESS_INFO, _left_cue_access_info_cb, panel_left);
-               elm_access_activate_cb_set(_access_left, _left_cue_access_activate_cb, panel_left);
-
-               cue_access_left = _access_left;
-
-               elm_access_highlight_next_set(m_mic_button, ELM_HIGHLIGHT_DIR_NEXT, cue_access_right);
-               elm_access_highlight_next_set(cue_access_right, ELM_HIGHLIGHT_DIR_PREVIOUS, m_mic_button);
-
-               elm_access_highlight_next_set(cue_access_right, ELM_HIGHLIGHT_DIR_NEXT, cue_access_left);
-               elm_access_highlight_next_set(cue_access_left, ELM_HIGHLIGHT_DIR_PREVIOUS, cue_access_right);
-
-               elm_access_highlight_next_set(cue_access_left, ELM_HIGHLIGHT_DIR_NEXT, m_mic_button);
-               elm_access_highlight_next_set(m_mic_button, ELM_HIGHLIGHT_DIR_PREVIOUS, cue_access_left);
-
-       }
-
        return layout_main;
 }
 
@@ -2266,19 +1766,56 @@ int is_lang_supported_by_stt(char lang[])
        for (index = (sizeof(supported_language) / sizeof(supported_language[0]))-1; index != 0; index--)
        {
                if (!strcmp(lang, supported_language[index])) {
-                       PRINTFUNC(DLOG_DEBUG,"current lang supported (%s)", supported_language[index]);
+                       PRINTFUNC(DLOG_DEBUG, "current lang supported (%s)", supported_language[index]);
                        return TRUE;
                }
        }
 
-       PRINTFUNC(DLOG_DEBUG,"current lang not supported (%s)", lang);
+       PRINTFUNC(DLOG_DEBUG, "current lang not supported (%s)", lang);
 
        return FALSE;
 }
 
+int init_voicedata(VoiceData *r_voicedata)
+{
+       VoiceData *voicedata = (VoiceData *)r_voicedata;
+       if (!voicedata) {
+               return FALSE;
+       }
+
+       voicedata->voicefw_state = 0;
+       voicedata->voicefw_handle = NULL;
+       voicedata->naviframe = NULL;
+       voicedata->layout_main = NULL;
+       voicedata->progressbar = NULL;
+       voicedata->scroller = NULL;
+       voicedata->main_entry = NULL;
+       voicedata->mic_button = NULL;
+       voicedata->state = STT_STATE_VAL_INIT;
+       voicedata->kbd_lang = NULL;
+       voicedata->start_timer = NULL;
+       voicedata->refresh_timer = NULL;
+       voicedata->progressbar_timer = NULL;
+       voicedata->textblock_timer = NULL;
+       voicedata->guide_text_timer = NULL;
+       voicedata->btn_disabling_timer = NULL;
+       voicedata->power_unlock_timer = NULL;
+
+       voicedata->partial_result = NULL;
+       voicedata->result_type = 0;
+       voicedata->disclaimer = 1;
+       voicedata->mo = NULL;
+       voicedata->sttfeedback = NULL;
+       voicedata->sttmanager = NULL;
+       voicedata->ieffect = NULL;
+       voicedata->effector = NULL;
+
+       return TRUE;
+}
+
 int init_voice(Evas_Object *parent, const char *lang, VoiceData *r_voicedata)
 {
-       PRINTFUNC(DLOG_DEBUG,"[init_voice]");
+       PRINTFUNC(DLOG_DEBUG, "[init_voice]");
 
 //     stt_is_samsung_asr(&g_is_n66);
 
@@ -2288,11 +1825,10 @@ int init_voice(Evas_Object *parent, const char *lang, VoiceData *r_voicedata)
        }
 
        if (!parent) {
-               PRINTFUNC(DLOG_ERROR,"Parent is NULL\n");
+               PRINTFUNC(DLOG_ERROR, "Parent is NULL\n");
                return FALSE;
-       }
-       else {
-               PRINTFUNC(NO_PRINT,"Parent is there");
+       } else {
+               PRINTFUNC(NO_PRINT, "Parent is there");
        }
 
        voicedata->voicefw_state = 0;
@@ -2309,7 +1845,7 @@ int init_voice(Evas_Object *parent, const char *lang, VoiceData *r_voicedata)
                voicedata->kbd_lang = strdup("en_US");
        }
 
-       PRINTFUNC(DLOG_DEBUG,"Voice input active language is : %s", voicedata->kbd_lang);
+       PRINTFUNC(DLOG_DEBUG, "Voice input active language is : %s", voicedata->kbd_lang);
 
        voicedata->naviframe = parent;
 
@@ -2317,6 +1853,14 @@ int init_voice(Evas_Object *parent, const char *lang, VoiceData *r_voicedata)
                return FALSE;
        }
 
+       if (NULL != voicedata->textblock_timer) {
+               PRINTFUNC(DLOG_DEBUG, "delete previous textblock");
+               ecore_timer_del(voicedata->textblock_timer);
+               voicedata->textblock_timer = NULL;
+       }
+
+       init_voice_recorder(NULL);
+
        return TRUE;
 }
 
@@ -2327,6 +1871,12 @@ static Eina_Bool init_view(void *data)
        if(voicedata == NULL)
                return ECORE_CALLBACK_CANCEL;
 
+       const char *item_style = NULL;
+       if (_WEARABLE)
+               item_style = "empty";
+       Elm_Object_Item *nf_voice_item = elm_naviframe_item_push(voicedata->naviframe, NULL, NULL, NULL, NULL, item_style);
+       elm_naviframe_item_pop_cb_set(nf_voice_item, _custom_back_cb, NULL);
+
        voicedata->layout_main = create_fullview(voicedata->naviframe, voicedata);
 
        if (voicedata->layout_main) {
@@ -2339,7 +1889,7 @@ static Eina_Bool init_view(void *data)
 
 Evas_Object *show_voice_window(Evas_Object *parent, VoiceData *r_voicedata)
 {
-       PRINTFUNC(NO_PRINT,"[show_voice_window]");
+       PRINTFUNC(NO_PRINT, "[show_voice_window]");
 
        VoiceData *voicedata = (VoiceData *)r_voicedata;
        if (!voicedata) {
@@ -2347,11 +1897,10 @@ Evas_Object *show_voice_window(Evas_Object *parent, VoiceData *r_voicedata)
        }
 
        if (!parent) {
-               PRINTFUNC(NO_PRINT,"Parent is NULL\n");
+               PRINTFUNC(NO_PRINT, "Parent is NULL\n");
                return NULL;
-       }
-       else {
-               PRINTFUNC(NO_PRINT,"Parent is there");
+       } else {
+               PRINTFUNC(NO_PRINT, "Parent is there");
        }
 
        if (NULL != voicedata->layout_main) {
@@ -2383,8 +1932,7 @@ Evas_Object *show_voice_window(Evas_Object *parent, VoiceData *r_voicedata)
 
 
 void on_stt_pause(VoiceData *r_voicedata){
-
-       PRINTFUNC(DLOG_DEBUG,"");
+       PRINTFUNC(DLOG_DEBUG, "");
 
        VoiceData *voicedata = (VoiceData *)r_voicedata;
 
@@ -2399,29 +1947,25 @@ void on_stt_pause(VoiceData *r_voicedata){
                //Hide more option and language settings by interrupt scenario.
                close_setting_window_idler_cb(NULL);
                Evas_Object *mo_layout = voicedata->mo->getMoreOptionLayout();
-               if(mo_layout){
-                       if(eext_more_option_opened_get(mo_layout) == EINA_TRUE) {
-                               eext_more_option_opened_set(mo_layout, EINA_FALSE);
+               if (_WEARABLE) {
+                       if(mo_layout){
+                               if(eext_more_option_opened_get(mo_layout) == EINA_TRUE) {
+                                       eext_more_option_opened_set(mo_layout, EINA_FALSE);
+                               }
                        }
                }
        }
-
-
 }
 
-
 void on_destroy(VoiceData *r_voicedata)
 {
-       PRINTFUNC(NO_PRINT,"");
+       PRINTFUNC(NO_PRINT, "");
 
        VoiceData *voicedata = (VoiceData *)r_voicedata;
 
-       int result = STT_ERROR_NONE;
-
        powerUnlock();
 
        if (NULL != voicedata) {
-
                if (NULL != voicedata->layout_main) {
                        voicedata->layout_main = NULL;
                }