40dab3eaa11382a9f859e9a4d4f7c55dd9b2495a
[platform/core/uifw/inputdelegator.git] / src / w-input-stt-voice.cpp
1 /*
2  * Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  * Licensed under the Apache License, Version 2.0 (the License);
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an AS IS BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #include <stdio.h>
18 #include <Elementary.h>
19 #include <Ecore_IMF.h>
20 #include <Ecore.h>
21 #include <device/power.h>
22 #include <app_common.h>
23 #include <app.h>
24 #include <string>
25 #include <efl_extension.h>
26 #include <feedback.h>
27
28 #include "Debug.h"
29 #include "w-input-selector.h"
30 #include "w-input-stt-voice.h"
31 #include "w-input-stt-engine.h"
32 #include "w-input-stt-ise.h"
33
34 using namespace std;
35
36 #define _EDJ(x)  elm_layout_edje_get(x)
37
38
39 #define GRP_PORTRAIT "mic_control"
40
41 #define item_append(obj, style, index, cb, udata) \
42                 elm_genlist_item_append(obj, &(style), (void *)index, NULL, ELM_GENLIST_ITEM_NONE, cb, udata)
43
44 #define VIRTUAL_TEXT_AREA_FONT_STYLE \
45                 "DEFAULT='font=Tizen:style=Regular  font_size=32 color=#FFFFFF color_class=AT013 text_class=tizen wrap=mixed align=center' \
46                 newline='br' b='+ font=Tizen:style=Bold'link='+ underline=on underline_color=#FFFFFF'"
47
48 extern App_Data* app_data;
49 extern VoiceData *my_voicedata;
50
51 static bool power_state = false;
52
53 static Evas_Object *radio_gp = NULL;
54 Evas_Object *g_setting_window = NULL;
55 static Evas_Object *g_setting_naviframe = NULL;
56 static Evas_Object *g_more_option_layout = NULL;
57
58 static Ecore_Event_Handler *g_evt_key_down = NULL;
59
60 static bool g_is_n66 = true;
61
62 static Elm_Genlist_Item_Class itc_title;
63 static Elm_Genlist_Item_Class itc_1text;
64 static Elm_Genlist_Item_Class itc_2text;
65
66
67 static void set_guide_text(VoiceData *vd, const char* text, bool translatable = false);
68
69 const char *supported_language[7] = {
70                 "auto",
71                 "en_US",
72                 "es_US",
73                 "fr_FR",
74                 "zh_CN",
75                 "ja_JP",
76                 "ko_KR",
77 };
78
79
80 const char *disp_lang_array[7] = {
81                 "",
82                 "English (United States)",
83                 "Español (América Latina)",
84                 "Français (France)",
85                 "简体中文",
86                 "日本語",
87                 "한국어",
88 };
89
90 typedef enum {
91         STT_VOICE_N66_AUTO,
92         STT_VOICE_N66_EN_US,
93         STT_VOICE_N66_ES_US,
94         STT_VOICE_N66_FR_FR,
95         STT_VOICE_N66_ZH_CN,
96         STT_VOICE_N66_JA_JP,
97         STT_VOICE_N66_KO_KR
98 }STT_VOICE_LANGUAGE_N66_I;
99
100 typedef enum {
101         BEEP_SOUND_START,
102         BEEP_SOUND_STOP,
103         VIBRATION_START,
104         VIBRATION_STOP,
105         BEEP_SOUND_TOUCH,
106         WAKEUP_COMMAND,
107 }FeedbackType;
108
109 static void get_stt_default_language(VoiceData *my_voicedata);
110
111
112 const char* get_lang_label(char lang[])
113 {
114         const char *str = NULL;
115
116         if (strcmp (lang, "en_US") == 0)
117                 str = disp_lang_array[1];
118
119         else if (strcmp (lang, "ko_KR") == 0)
120                 str = disp_lang_array[6];
121
122         else if (strcmp (lang, "fr_FR") == 0)
123                 str = disp_lang_array[3];
124
125         else if (strcmp (lang, "ja_JP") == 0)
126                 str = disp_lang_array[5];
127
128         else if (strcmp (lang, "zh_CN") == 0)
129                 str = disp_lang_array[4];
130
131         else if (strcmp (lang, "es_US") == 0)
132                 str = disp_lang_array[2];
133
134         else
135                 str = disp_lang_array[1];
136
137         return str;
138 }
139
140
141 static Eina_Bool
142 _bring_in_cb(void *data)
143 {
144         if(!data)
145                 return ECORE_CALLBACK_CANCEL;
146
147         Evas_Coord x, y, w, h;
148
149         Evas_Object *scroller = (Evas_Object *)data;
150         Evas_Object *inner_layout = NULL;
151
152         inner_layout = (Evas_Object *) evas_object_data_get(scroller, "inner_layout");
153
154         evas_object_geometry_get(inner_layout, &x, &y, &w, &h);
155         elm_scroller_region_bring_in(scroller, x, h, w, h);
156
157         PRINTFUNC(NO_PRINT, "scroller %d %d %d %d", x, y, w, h);
158
159         return ECORE_CALLBACK_CANCEL;
160 }
161
162 static inline Evas_Coord get_text_block_size(Evas_Object *obj, std::string text)
163 {
164         int max_height = 1280;
165         int unit_width = 282;
166
167         Evas_Coord width, height;
168
169         char *strbuf = NULL;
170         Evas_Object *tb = NULL;
171         Evas_Textblock_Style *st = NULL;
172         Evas_Textblock_Cursor *cur = NULL;
173
174         tb = evas_object_textblock_add(evas_object_evas_get(obj));
175         evas_object_textblock_legacy_newline_set(tb, EINA_FALSE);
176
177         st = evas_textblock_style_new();
178         evas_textblock_style_set(st, VIRTUAL_TEXT_AREA_FONT_STYLE);
179         evas_object_textblock_style_set(tb, st);
180
181         cur = evas_object_textblock_cursor_new(tb);
182         strbuf = elm_entry_utf8_to_markup(text.c_str());
183         evas_object_resize(tb, unit_width, max_height);
184
185         evas_object_textblock_text_markup_set(tb, strbuf);
186         evas_textblock_cursor_format_prepend(cur, "+ wrap=mixed");
187     evas_object_textblock_size_formatted_get(tb, &width, &height);
188         evas_object_resize(tb, unit_width, height);
189
190         if(strbuf) free(strbuf);
191         if(tb) evas_object_del(tb);
192         if(st) evas_textblock_style_free(st);
193 //      if(cur) evas_textblock_cursor_free(cur);
194
195         return height;
196 }
197
198 static Eina_Bool _update_textblock_timer_cb(void *data)
199 {
200         if(!data)
201                 return ECORE_CALLBACK_CANCEL;
202
203         VoiceData* voicedata = (VoiceData*)data;
204
205         voicedata->textblock_timer = NULL;
206
207         std::string result_text;
208         for(unsigned int i = 0; i < voicedata->stt_results.size(); i++){
209                 if(i == voicedata->stt_results.size()-1){
210                         result_text += voicedata->stt_results.at(i);
211                 } else {
212                         result_text += voicedata->stt_results.at(i);
213                         result_text += " ";
214                 }
215         }
216
217         Evas_Object *rect = NULL;
218         Evas_Object *entry = NULL;
219         Evas_Object *scroller = NULL;
220         Evas_Object *box = NULL;
221         Evas_Object *inner_layout = NULL;
222
223         scroller = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "text_area");
224         if(!scroller)
225         {
226                 PRINTFUNC(DLOG_ERROR, "failed to get scroller");
227                 return ECORE_CALLBACK_CANCEL;
228         }
229
230         box = elm_object_content_get(scroller);
231         if(!box)
232         {
233                 PRINTFUNC(DLOG_ERROR, "failed to get box");
234                 return ECORE_CALLBACK_CANCEL;
235         }
236
237         inner_layout = (Evas_Object *) evas_object_data_get(scroller, "inner_layout");
238         if(!inner_layout)
239         {
240                 PRINTFUNC(DLOG_ERROR, "failed to get inner_layout");
241                 return ECORE_CALLBACK_CANCEL;
242         }
243
244         entry = elm_layout_content_get(inner_layout, "elm.swallow.content");
245         if(!entry)
246         {
247                 PRINTFUNC(DLOG_ERROR, "failed to get entry");
248                 return ECORE_CALLBACK_CANCEL;
249         }
250
251         Evas_Object *top = (Evas_Object *) evas_object_data_get(box, "top_padding");
252         Evas_Object *bottom = (Evas_Object *) evas_object_data_get(box, "bottom_padding");
253
254         if(top) {
255                 elm_box_unpack(box, top);
256                 evas_object_del(top);
257                 top = NULL;
258         }
259         if(bottom) {
260                 elm_box_unpack(box, bottom);
261                 evas_object_del(bottom);
262                 bottom = NULL;
263         }
264
265         Evas_Coord height = get_text_block_size(box, result_text);
266
267 //      if(height < 173) {
268         {
269                 int text_area_height = 360-102; // screen H - bottom button H
270                 int top_height = ((text_area_height - height) / 2);
271                 if(top_height < 120) top_height = 120; // Top fade area H
272
273                 int bottom_height = (text_area_height - top_height - height);
274                 if(bottom_height < 1) bottom_height = 0;
275
276                 PRINTFUNC(SECURE_DEBUG, "str : %s", result_text.c_str());
277                 PRINTFUNC(DLOG_DEBUG, "height : %d", height);
278                 PRINTFUNC(DLOG_DEBUG, "top_height : %d", top_height);
279                 PRINTFUNC(DLOG_DEBUG, "bottom_height : %d", bottom_height);
280
281                 rect = evas_object_rectangle_add(evas_object_evas_get(box));
282                 evas_object_color_set(rect, 0, 0, 0, 100);
283                 evas_object_size_hint_weight_set(rect, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
284                 evas_object_size_hint_min_set(rect, 282, top_height);
285                 evas_object_show(rect);
286
287                 elm_box_pack_before(box, rect, inner_layout);
288                 evas_object_data_set(box, "top_padding", (void *) rect);
289
290                 rect = evas_object_rectangle_add(evas_object_evas_get(box));
291                 evas_object_color_set(rect, 0, 0, 0, 100);
292                 evas_object_size_hint_weight_set(rect, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
293                 evas_object_size_hint_min_set(rect, 282, bottom_height);
294                 evas_object_show(rect);
295
296                 elm_box_pack_end(box, rect);
297                 evas_object_data_set(box, "bottom_padding", (void *) rect);
298         }
299
300         elm_entry_entry_set(entry, result_text.c_str());
301
302         Evas_Object *panel_layout = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "left_panel_area");
303         Evas_Object *panel_left = elm_layout_content_get((Evas_Object *)panel_layout, "elm.swallow.right");
304
305         if (result_text.size() > 0) {
306                 elm_object_signal_emit(panel_left, "elm,state,enabled", "elm");
307         } else {
308                 elm_object_signal_emit(panel_left, "elm,state,disabled", "elm");
309         }
310
311         elm_object_signal_emit((Evas_Object *)voicedata->layout_main, "idle,state,guide_text,bottom", "elm");
312
313         if(voicedata->state == STT_STATE_VAL_LISTENING){
314                 if(voicedata->guide_text_timer != NULL){
315                         PRINTFUNC(DLOG_DEBUG, "Skip hide_guide_text");
316                         ecore_timer_del(voicedata->guide_text_timer);
317                         voicedata->guide_text_timer = NULL;
318                 }
319                 set_guide_text(voicedata, SK_TAP_TO_PAUSE, true);
320         }
321
322         elm_object_signal_emit(inner_layout, "scrolling", "entry");
323
324         return ECORE_CALLBACK_CANCEL;
325 }
326
327 void _update_textblock(void *data)
328 {
329         if(!data)
330                 return;
331
332         VoiceData *voicedata = (VoiceData *) data;
333
334         if(voicedata->textblock_timer == NULL){
335                 voicedata->textblock_timer = ecore_timer_add(1.0, _update_textblock_timer_cb, voicedata);
336         } else {
337                 PRINTFUNC(DLOG_DEBUG, "skip : the timer is not expired.");
338         }
339
340         return;
341 }
342
343 void voice_get_string(const char *keyValue, _VoiceData *voicedata)
344 {
345         if(!voicedata)
346                 return;
347
348         char* strbuf = NULL;
349
350         strbuf = elm_entry_utf8_to_markup(keyValue);
351
352         PRINTFUNC(DLOG_DEBUG, "text : %s, voicedata->partial_result=%s", strbuf, voicedata->partial_result);
353
354         if(strbuf){
355                 if(voicedata->partial_result){ // partial_result is not Null so replace
356                         if(strcmp(voicedata->partial_result, strbuf)){
357                                 // different replace
358                                 PRINTFUNC(DLOG_DEBUG, "different replace");
359
360                                 voicedata->stt_results.pop_back();
361                                 voicedata->stt_results.push_back(strbuf);
362
363                                 free(voicedata->partial_result);
364                                 voicedata->partial_result = strdup(strbuf);
365                         }
366                 } else { // partial_result is Null so first case
367                         PRINTFUNC(DLOG_DEBUG, "first push");
368                         voicedata->stt_results.push_back(strbuf);
369                         voicedata->partial_result = strdup(strbuf);
370                 }
371         }
372
373         _update_textblock(voicedata);
374
375         if(strbuf)
376                 free(strbuf);
377
378         PRINTFUNC(DLOG_DEBUG, "ends");
379 }
380
381 static Eina_Bool _recognition_failure_cb(void *data)
382 {
383         if(data) {
384                 VoiceData *voicedata = (VoiceData *) data;
385
386                 voicedata->state = STT_STATE_VAL_INIT;
387                 set_animation_state(voicedata);
388                 voicedata->refresh_timer = NULL;
389         }
390         return ECORE_CALLBACK_CANCEL;
391 }
392
393 void start_by_press(VoiceData *voicedata)
394 {
395         PRINTFUNC(DLOG_DEBUG, "");
396
397         edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1", "background");
398
399         return;
400 }
401
402 static void on_mic_button_press_cb(void *data, Evas_Object *obj, void *event_info)
403 {
404         PRINTFUNC(NO_PRINT, "");
405
406         VoiceData *voicedata = (VoiceData *)data;
407         edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1", "background");
408
409         return;
410 }
411
412
413 static Eina_Bool _mic_button_enable_cb(void *data)
414 {
415         PRINTFUNC(DLOG_DEBUG, "");
416
417         if(!data)
418                 return ECORE_CALLBACK_CANCEL;
419
420         VoiceData* voicedata = (VoiceData*)data;
421
422         voicedata->btn_disabling_timer = NULL;
423
424         Evas_Object *button = (Evas_Object *)voicedata->mic_button;
425
426         elm_object_disabled_set(button, EINA_FALSE);
427
428         return ECORE_CALLBACK_CANCEL;
429 }
430
431
432 static void on_confirm_button_clicked_cb(void *data, Evas_Object *obj, void *event_info)
433 {
434         if(!data)
435                 return;
436
437         VoiceData* voicedata = (VoiceData*)data;
438
439         std::string result_text;
440         for(unsigned int i = 0; i < voicedata->stt_results.size(); i++){
441                 result_text += voicedata->stt_results.at(i);
442                 if(i != voicedata->stt_results.size()-1)
443                         result_text += " ";
444         }
445
446         PRINTFUNC(DLOG_DEBUG, "result_text = %s", result_text.c_str());
447
448         reply_to_sender_by_callback(result_text.c_str(), "voice");
449         destroy_voice();
450         powerUnlock();
451         elm_exit();
452
453         return;
454 }
455
456 static void
457 _panel_cue_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
458 {
459         PRINTFUNC(DLOG_DEBUG, "left cue clicked!!");
460
461         on_confirm_button_clicked_cb(data, NULL, NULL);
462 }
463
464
465
466 void stt_feedback_initialize()
467 {
468         int ret = 0;
469
470         ret = feedback_initialize();
471         if(ret != 0)
472         {
473                 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
474                 return;
475         }
476         return;
477 }
478
479 void stt_feedback(FeedbackType type)
480 {
481         int ret;
482
483         ret = feedback_initialize();
484         if(ret != 0)
485         {
486                 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
487                 return;
488         }
489
490         if (type == VIBRATION_START){
491 //              feedback_play(FEEDBACK_PATTERN_VOICE_START);
492         } else if (type == VIBRATION_STOP){
493 //              feedback_play(FEEDBACK_PATTERN_VOICE_STOP);
494         }
495
496         ret = feedback_deinitialize();
497         if(ret != 0)
498         {
499                 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
500                 return;
501         }
502 }
503
504 void stt_feedback_deinitialize()
505 {
506         int ret = 0;
507
508         ret = feedback_deinitialize();
509         if(ret != 0)
510         {
511                 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
512                 return;
513         }
514         return;
515 }
516
517 static Eina_Bool _idler_cb(void *data)
518 {
519         if(!data) return ECORE_CALLBACK_CANCEL;
520
521         VoiceData *voicedata = (VoiceData *)data;
522
523         PRINTFUNC(DLOG_DEBUG, "");
524
525
526         if(true == _app_stt_initialize(voicedata)) {
527                 PRINTFUNC(NO_PRINT, "_app_stt_initialize None Error");
528                 voicedata->voicefw_state = 1;
529                 voicedata->state = STT_STATE_VAL_INIT;
530         } else {
531                 voicedata->voicefw_state = 0;
532                 PRINTFUNC(DLOG_ERROR, "Initialization Fail!<br>Check STT-daemon is running");
533         }
534
535         Evas_Object *canvas = elm_object_part_content_get(voicedata->layout_main, "EFFECT_BG");
536
537
538         is::ui::WInputSttMicEffect *ieffect = new is::ui::WInputSttMicEffect();
539         ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
540
541         is::ui::MicEffector *effector = new is::ui::MicEffector(canvas, voicedata->layout_main, *ieffect);
542         voicedata->ieffect = ieffect;
543         voicedata->effector = effector;
544
545         ieffect->SetProgressBar(voicedata->progressbar);
546         ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
547
548         voicedata->mo->Update();
549
550         elm_access_highlight_set(voicedata->mic_button);
551
552
553         return ECORE_CALLBACK_CANCEL;
554 }
555
556
557 static Eina_Bool _power_delayed_unlock(void *data){
558         PRINTFUNC(DLOG_DEBUG, "POWER Unlock");
559
560         VoiceData *voicedata = (VoiceData *) data;
561         device_power_release_lock(POWER_LOCK_DISPLAY);
562         voicedata->power_unlock_timer = NULL;
563
564         return ECORE_CALLBACK_CANCEL;
565 }
566
567 void powerUnlock()
568 {
569         PRINTFUNC(DLOG_DEBUG, "POWER Unlock directly.");
570         device_power_release_lock(POWER_LOCK_DISPLAY);
571 }
572
573 void powerLock(void *data, bool enable)
574 {
575         int ret = DEVICE_ERROR_NONE;
576
577         VoiceData *voicedata = (VoiceData *) data;
578
579         if(enable) {
580                 ret = device_power_wakeup(false);
581                 PRINTFUNC(DLOG_DEBUG, "LCD Wakeup");
582
583                 if(ret != DEVICE_ERROR_NONE)
584                         PRINTFUNC(DLOG_ERROR, "LCD Wakeup ERROR = %d", ret);
585
586                 ret = device_power_request_lock(POWER_LOCK_DISPLAY, 0);
587                 PRINTFUNC(DLOG_DEBUG, "POWER LOCK");
588                 power_state = enable;
589
590                 if(ret != DEVICE_ERROR_NONE)
591                         PRINTFUNC(DLOG_ERROR, "ERROR = %d", ret);
592
593                 if(voicedata->power_unlock_timer != NULL){
594                         ecore_timer_del(voicedata->power_unlock_timer);
595                         voicedata->power_unlock_timer = NULL;
596                 }
597         } else {
598                 PRINTFUNC(DLOG_DEBUG, "POWER Unlock Delayed(5 sec)");
599
600                 if(voicedata->power_unlock_timer != NULL){
601                         ecore_timer_del(voicedata->power_unlock_timer);
602                         voicedata->power_unlock_timer = NULL;
603                 }
604                 voicedata->power_unlock_timer = ecore_timer_add(5.0, _power_delayed_unlock, voicedata);
605         }
606 }
607
608
609 static Eina_Bool hide_guide_text(void *data){
610         if(data) {
611                 VoiceData *voicedata = (VoiceData *) data;
612
613                 voicedata->guide_text_timer = NULL;
614
615
616                 PRINTFUNC(DLOG_ERROR, "");
617                 elm_object_part_text_set(voicedata->layout_main, "elm.text", "");
618         }
619         return ECORE_CALLBACK_CANCEL;
620 }
621
622 static void set_guide_text(VoiceData *vd, const char* text, bool translatable)
623 {
624         //elm_object_signal_emit(vd->layout_main, "idle,state,text,visible", "elm");
625
626         if(translatable)
627                 elm_object_domain_translatable_part_text_set(vd->layout_main, "elm.text", PACKAGE, text);
628         else
629                 elm_object_part_text_set(vd->layout_main, "elm.text", text);
630
631         if(!strcmp(text, SK_SPEAK_NOW)){
632                 if(vd->guide_text_timer == NULL)
633                         vd->guide_text_timer = ecore_timer_add(2.0, hide_guide_text, vd);
634         }
635 }
636
637 /**
638  * @brief - function to send the signal to edc
639  *               to change the animation as per stt state
640  * @param - Ug data
641  */
642 void set_animation_state(VoiceData *voicedata)
643 {
644         PRINTFUNC(DLOG_DEBUG, "");
645
646         PRINTFUNC(DLOG_ERROR, "voicedata->state == %s",
647                 voicedata->state == STT_STATE_VAL_INIT ?
648                         "STT_STATE_VAL_INIT" :
649                 voicedata->state == STT_STATE_VAL_LISTENING ?
650                         "STT_STATE_VAL_LISTENING" :
651                 voicedata->state == STT_STATE_VAL_PREPARE_LISTENING ?
652                         "STT_STATE_VAL_PREPARE_LISTENING" :
653                 voicedata->state == STT_STATE_VAL_PROCESSING ?
654                         "STT_STATE_VAL_PROCESSING" :
655                 voicedata->state == STT_STATE_VAL_PREPARE_PROCESSING ?
656                         "STT_STATE_VAL_PREPARE_PROCESSING" :
657                 voicedata->state == STT_STATE_VAL_TERMINATING ?
658                         "STT_STATE_VAL_TERMINATING" : "STT_STATE_VAL_NOT_RECOGNISED");
659
660         if (voicedata->state == STT_STATE_VAL_INIT) {
661 #if 0
662                 if (voicedata->sttmanager->GetCurrent() == STT_STATE_READY) {
663                         set_guide_text(voicedata, "", false);
664                         //_elm_access_say(voicedata->layout_main, _(SK_INIT));
665                 } else {
666                         PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR [%d]", voicedata->sttmanager->GetCurrent());
667                         set_guide_text(voicedata, _(SK_NETWORK_ERROR));
668                         //_elm_access_say(voicedata->layout_main, _(SK_NETWORK_CONNECTION_ERROR));
669                 }
670 #endif
671
672                 if(voicedata->effector)
673                         voicedata->effector->Stop(true);
674
675                 set_guide_text(voicedata, "");
676
677                 PRINTFUNC(DLOG_DEBUG, "%d", voicedata->stt_results.size());
678                 powerLock((void*)voicedata, false);
679         } else if (voicedata->state == STT_STATE_VAL_LISTENING) {
680                 set_guide_text(voicedata, SK_SPEAK_NOW, true);
681
682                 if(voicedata->effector)
683                         voicedata->effector->Start();
684
685                 powerLock((void*)voicedata, true);
686         } else if (voicedata->state == STT_STATE_VAL_PROCESSING) {
687                 set_guide_text(voicedata, "");
688                 if(voicedata->effector)
689                         voicedata->effector->Stop();
690
691                 stt_feedback(VIBRATION_STOP);
692         } else {
693                 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
694                 set_guide_text(voicedata, _(SK_RECOGNITION_FAILED));
695                 //_elm_access_say(voicedata->layout_main, _(SK_RECOGNITION_FAILED));
696
697                 voicedata->state = STT_STATE_VAL_NOT_RECOGNISED;
698
699                 if(voicedata->refresh_timer) {
700                         ecore_timer_del(voicedata->refresh_timer);
701                 }
702
703                 if(voicedata->effector)
704                         voicedata->effector->Stop(true);
705
706                 voicedata->refresh_timer = ecore_timer_add(2.0, _recognition_failure_cb, voicedata);
707
708                 //powerLock((void*)voicedata, false);
709         }
710 }
711
712 void show_error_message(VoiceData *vd, stt_error_e reason)
713 {
714         if(reason == STT_ERROR_OUT_OF_NETWORK)
715         {
716                 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
717
718                 int ancs_connected = 0;
719                 int ret = 0;
720                 ret = vconf_get_int("file/private/weconn/ancs_connected", &ancs_connected);
721
722                 if (ret == 0)
723                         PRINTFUNC(DLOG_ERROR, "ancs connected status : %d", ancs_connected);
724                 else
725                         PRINTFUNC(DLOG_ERROR, "vconf for ancs connection ERROR - %d", ret);
726
727                 if (ancs_connected) {
728                         char text[512];
729                         const char *format1 = _(SK_NETWORK_ERROR_FOR_IOS);
730                         const char *format2 = _(SK_SAMSUNG_GEAR);
731                         snprintf(text, sizeof(text), format1, format2);
732
733                         show_popup_toast((const char*)text, false);
734                 } else {
735                         set_guide_text(vd, _(SK_NETWORK_ERROR));
736                 }
737
738                 vd->state = STT_STATE_VAL_INIT;
739
740         } else if (reason == STT_ERROR_RECORDER_BUSY) {
741                 PRINTFUNC(DLOG_WARN, "STT is used by another application");
742                 show_popup_toast(_(SK_STT_BUSY), false);
743                 vd->state = STT_STATE_VAL_INIT;
744         } else {
745                 PRINTFUNC(DLOG_WARN, "Check error code");
746                 show_popup_toast(_(SK_STT_BUSY), false);
747                 vd->state = STT_STATE_VAL_INIT;
748         }
749 }
750
751 static Eina_Bool _start_timer_cb(void* data)
752 {
753         if(data) {
754                 VoiceData *voicedata = (VoiceData *) data;
755
756                 try {
757                         voicedata->state = STT_STATE_VAL_PREPARE_LISTENING;
758                         voicedata->sttmanager->Start();
759                 }
760                 catch (is::stt::SttException &e) {
761                         PRINTFUNC(DLOG_ERROR, "%s", e.what());
762
763                         if (e.GetEcode() == STT_ERROR_OUT_OF_NETWORK)
764                         {
765                                 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
766                                 set_guide_text(voicedata, _(SK_NETWORK_ERROR));
767                                 voicedata->state = STT_STATE_VAL_INIT;
768                         } else if (e.GetEcode() == STT_ERROR_RECORDER_BUSY) {
769                                 PRINTFUNC(DLOG_WARN, "STT is used by another application");
770                                 show_popup_toast(_(SK_STT_BUSY), false);
771                                 voicedata->state = STT_STATE_VAL_INIT;
772                         } else {
773                                 PRINTFUNC(DLOG_WARN, "Check error code");
774                                 show_popup_toast(_(SK_STT_BUSY), false);
775                                 voicedata->state = STT_STATE_VAL_INIT;
776                         }
777                 }
778                 voicedata->start_timer = NULL;
779         }
780         return ECORE_CALLBACK_CANCEL;
781 }
782
783 /**
784  * @brief - cancel button press callback for cross button
785  * @param -
786  */
787
788 void on_initial_anim_press_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
789 {
790         PRINTFUNC(NO_PRINT, "");
791
792         VoiceData *vd = (VoiceData *)data;
793
794         int tempVal = vd->sttmanager->GetCurrent();
795         if(tempVal == STT_STATE_CREATED) {
796                 PRINTFUNC(DLOG_WARN, "IGNORE TOUCH event before STT READY. STT is preparing", vd->state);
797                 return;
798         }
799
800         PRINTFUNC(DLOG_DEBUG, "SttManager State : %d", vd->sttmanager->GetCurrent());
801         PRINTFUNC(DLOG_DEBUG, "Ui Voice State : %d", vd->state);
802
803         switch(vd->state) {
804                 case STT_STATE_VAL_INIT:
805
806                         PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_INIT");
807                         get_stt_default_language(vd);
808                         vd->sttmanager->SetLanguage(std::string(vd->kbd_lang));
809
810                         stt_feedback(VIBRATION_START);
811
812                         if(vd->start_timer) {
813                                 ecore_timer_del(vd->start_timer);
814                                 vd->start_timer = NULL;
815                         }
816
817                         vd->start_timer = ecore_timer_add(0.0, _start_timer_cb, vd);
818                         break;
819
820                 case STT_STATE_VAL_LISTENING :
821                         PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_LISTENING");
822                         try {
823                                 vd->state = STT_STATE_VAL_PREPARE_PROCESSING;
824                                 vd->sttmanager->Stop();
825
826                                 /**
827                                  * Cuased touch reponse time, it can be called to stop animator.
828                                  *
829                                  */
830                                 set_guide_text(vd, "");
831
832                                 if(vd->effector)
833                                         vd->effector->Stop();
834                         }
835                         catch (is::stt::SttException &e) {
836                                 PRINTFUNC(DLOG_ERROR, "%s", e.what());
837
838                                 if(e.GetEcode() != STT_ERROR_INVALID_STATE) {
839                                         PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
840                                         set_guide_text(vd, _(SK_RECOGNITION_FAILED));
841                                         vd->state = STT_STATE_VAL_INIT;
842
843                                         if(vd->effector)
844                                                 vd->effector->Stop(true);
845                                 }
846                         }
847                         break;
848
849                 case STT_STATE_VAL_PROCESSING:
850                         PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_PROCESSING");
851                         try {
852                                 //vd->state = STT_STATE_VAL_PREPARE_CANCEL;
853                                 vd->sttmanager->Cancel();
854                         }
855                         catch (is::stt::SttException &e) {
856                                 PRINTFUNC(DLOG_ERROR, "%s", e.what());
857                         }
858
859                         break;
860
861                 case STT_STATE_VAL_NOT_RECOGNISED:
862                         PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_NOT_RECOGNISED");
863                         vd->state = STT_STATE_VAL_INIT ;
864                         break;
865                 default:
866                         PRINTFUNC(DLOG_DEBUG, "default [%d]", vd->state);
867                         break;
868         }
869 }
870
871 static inline void ea_naviframe_back(void *data, Evas_Object *obj, void *event_info)
872 {
873         if(!data) return;
874
875         evas_object_del((Evas_Object *) data);
876
877         g_setting_window = NULL;
878         g_setting_naviframe = NULL;
879
880         if(g_evt_key_down)
881                 ecore_event_handler_del(g_evt_key_down);
882
883         g_evt_key_down = NULL;
884
885         //Hide more option
886         if(g_more_option_layout){
887                 if(eext_more_option_opened_get(g_more_option_layout) == EINA_TRUE) {
888                         eext_more_option_opened_set(g_more_option_layout, EINA_FALSE);
889                 }
890         }
891 }
892
893 static char *__get_genlist_title_label(void *data, Evas_Object *obj, const char *part)
894 {
895         return strdup(_("WDS_VOICE_OPT_LANGUAGE_ABB"));
896 }
897
898 char *__get_genlist_item_label(void *data, Evas_Object *obj, const char *part)
899 {
900         char text[128] = {0, };
901
902         if(!strcmp(part, "elm.text"))
903         {
904                 if((int)data == 0) {
905                         return strdup(_("IDS_VC_BODY_AUTOMATIC"));
906                 } else {
907                         char *s = NULL;
908                         s = (char *)disp_lang_array[(int)data];
909
910                         if(s) {
911                                 char *p = strchr(s, '(');
912                                 if(p) {
913                                         strncpy(text, s, p-s);
914                                 } else {
915                                         strncpy(text, s, strlen(s));
916                                 }
917                         } else {
918                                 strncpy(text, "", strlen(""));
919                         }
920                 }
921                 return strdup(text);
922         } else if (!strcmp(part, "elm.text.1")) {
923                 if ((int)data == 0) {
924                         char* value = NULL;
925                         value = vconf_get_str(VCONFKEY_LANGSET);
926                         if (NULL == value) {
927                                 PRINTFUNC(DLOG_ERROR, "Fail to get display language");
928                                 return NULL;
929                         }
930                         PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
931
932                         char system_lang[6] = {0, };
933                         strncpy(system_lang, value , 5);
934                         free(value);
935
936                         // confirm whether the system language is supported by stt engine or not.
937                         // if supported, set the language
938                         // otherwise, set language to en_US
939                         return strdup(get_lang_label(system_lang));
940
941                 } else {
942                         char *s = NULL;
943                         s = (char *)disp_lang_array[(int)data];
944
945                         if(s) {
946                                 char *p = strchr(s, '(');
947                                 if(p) {
948                                         strncpy(text, p+1, strlen(s)-(p-s)-2);
949                                 } else {
950                                         strncpy(text, s, strlen(s));
951                                 }
952                         } else {
953                                 strncpy(text, "", strlen(""));
954                         }
955                         return strdup(text);
956                 }
957         }
958         return NULL;
959 }
960
961 static Evas_Object *__get_genlist_item_content(void *data, Evas_Object *obj, const char *part)
962 {
963         int index = (int)data;
964         Evas_Object * content = NULL;
965
966         if (!strcmp(part, "elm.icon")) {
967                 content = elm_radio_add(obj);
968                 elm_radio_state_value_set(content, index);
969                 elm_radio_group_add(content, radio_gp);
970                 evas_object_size_hint_weight_set(content, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
971                 evas_object_propagate_events_set(content, EINA_TRUE);
972                 evas_object_size_hint_align_set(content, EVAS_HINT_FILL, EVAS_HINT_FILL);
973                 elm_object_style_set(content, "list");
974         }
975         return content;
976 }
977
978 static int get_language_value()
979 {
980 #if 1
981         int lang = 0, ret = 0;
982
983         ret = preference_get_int(PREFERENCE_ISE_STT_LANGUAGE, &lang);
984         if(PREFERENCE_ERROR_NONE != ret){
985                 PRINTFUNC(DLOG_ERROR, "preference_get_int error!(%d)", ret);
986                 preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, (int)2); //auto
987                 lang = 2;
988         }
989 #else
990         int lang = 0, ret = 0;
991
992         ret = vconf_get_int(VCONFKEY_ISE_STT_LANGUAGE, &lang);
993         if (ret !=0) {
994                 PRINTFUNC(DLOG_ERROR, "Vconf_get_int error!(%d)", ret);
995         }
996 #endif
997         if(g_is_n66) {
998                 if(lang < 0 || lang > 6) {
999                         PRINTFUNC(DLOG_WARN, "vconf lang orig(%d) to be 0", lang);
1000                         lang = 0;
1001                 }
1002                 PRINTFUNC(DLOG_DEBUG, "n66 current language value for stt (%s).", disp_lang_array[lang]);
1003         }
1004
1005         return lang;
1006 }
1007
1008 static void set_language_value(int type)
1009 {
1010         // Add implementation to store language type.
1011         int ret = 0;
1012
1013 #if 1
1014         ret = preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, (int)type);
1015         if(PREFERENCE_ERROR_NONE != ret){
1016                 PRINTFUNC(DLOG_ERROR, "preference_set_int error!(%d)", ret);
1017         }
1018
1019 #else
1020         ret = vconf_set_int(VCONFKEY_ISE_STT_LANGUAGE, (int) type);
1021         if (ret != 0) {
1022                 PRINTFUNC(DLOG_ERROR, "Vconf_set_int error!(%d)", ret);
1023                 return;
1024         }
1025 #endif
1026         PRINTFUNC(DLOG_DEBUG, "language type (%d)", type);
1027
1028         // Update string
1029 }
1030
1031 static void get_stt_default_language(VoiceData *my_voicedata)
1032 {
1033         if(!my_voicedata) {
1034                 PRINTFUNC(DLOG_ERROR, "my_voicedata NULL");
1035                 return;
1036         }
1037
1038         if(my_voicedata->kbd_lang) {
1039                 free(my_voicedata->kbd_lang);
1040                 my_voicedata->kbd_lang = NULL;
1041         }
1042
1043
1044         if(g_is_n66) {
1045                 STT_VOICE_LANGUAGE_N66_I stt_lang;
1046                 stt_lang = (STT_VOICE_LANGUAGE_N66_I)get_language_value();
1047
1048                 PRINTFUNC(DLOG_DEBUG, "language type (%d)", stt_lang);
1049
1050                 switch(stt_lang) {
1051                 case STT_VOICE_N66_AUTO :
1052                 {
1053                         stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
1054
1055                         // get system display language
1056                         char* value = NULL;
1057                         value = vconf_get_str(VCONFKEY_LANGSET);
1058                         if (NULL == value) {
1059                                 PRINTFUNC(DLOG_ERROR, "Fail to get display language");
1060                                 return;
1061                         }
1062                         PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
1063
1064                         char system_lang[6] = {0, };
1065                         strncpy(system_lang, value , 5);
1066                         free(value);
1067
1068                         // confirm whether the system language is supported by stt engine or not.
1069                         // if supported, set the language
1070                         // otherwise, set language to en_US
1071                         if(is_lang_supported_by_stt(system_lang) == TRUE) {
1072                                 my_voicedata->kbd_lang = strdup(system_lang);
1073                                 PRINTFUNC(DLOG_DEBUG, "Set auto language (%s)", system_lang);
1074                         } else {
1075                                 my_voicedata->kbd_lang = strdup("en_US");
1076                                 PRINTFUNC(DLOG_DEBUG, "System language is not supported by STT (%s), en_US will be set", system_lang);
1077                         }
1078                 }
1079                 break;
1080                 case STT_VOICE_N66_EN_US :
1081                 case STT_VOICE_N66_ES_US :
1082                 case STT_VOICE_N66_FR_FR :
1083                 case STT_VOICE_N66_JA_JP :
1084                 case STT_VOICE_N66_KO_KR :
1085                 case STT_VOICE_N66_ZH_CN :
1086                 {
1087                         my_voicedata->kbd_lang = strdup(supported_language[stt_lang]);
1088                 }
1089                 break;
1090                 default :
1091                         my_voicedata->kbd_lang = strdup("en_US");
1092                         break;
1093                 }
1094         }
1095
1096         PRINTFUNC(DLOG_DEBUG, "stt language (%s)", my_voicedata->kbd_lang);
1097 }
1098
1099 static Eina_Bool close_setting_window_idler_cb(void *data)
1100 {
1101         if(g_setting_window && g_setting_naviframe) {
1102                 ea_naviframe_back(g_setting_window, g_setting_naviframe, NULL);
1103         }
1104
1105         return ECORE_CALLBACK_CANCEL;
1106 }
1107
1108 static void language_set_genlist_radio_cb(void *data, Evas_Object *obj, void *event_info)
1109 {
1110         PRINTFUNC(DLOG_DEBUG, "");
1111         if(!data) return;
1112
1113         int index = 0;
1114
1115         Elm_Object_Item * item = (Elm_Object_Item *) event_info;
1116         if (item) {
1117                 elm_genlist_item_selected_set(item, 0);
1118                 index = (int)elm_object_item_data_get(item);
1119                 elm_genlist_item_update(item);
1120         }
1121         set_language_value(index);
1122
1123         elm_radio_value_set(radio_gp, index);
1124         ecore_timer_add(0.3, close_setting_window_idler_cb, NULL);
1125 }
1126
1127 static void language_changed_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
1128 {
1129         if(!obj) return;
1130         elm_genlist_realized_items_update(obj);
1131 }
1132
1133 Eina_Bool _ise_keydown_cb(void *data, int type, void *event)
1134 {
1135         PRINTFUNC(DLOG_DEBUG, "");
1136         if(type == ECORE_EVENT_KEY_DOWN && g_setting_window && g_setting_naviframe) {
1137                 PRINTFUNC(DLOG_DEBUG, "window will be deleted.");
1138                 ea_naviframe_back(g_setting_window, g_setting_naviframe, NULL);
1139         }
1140
1141         return ECORE_CALLBACK_DONE;
1142 }
1143
1144
1145 static void _language_list_item_realized(void *data, Evas_Object *obj, void *event_info) //called when list scrolled
1146 {
1147         PRINTFUNC(DLOG_DEBUG, "%s", __func__);
1148 }
1149
1150 static Evas_Object *create_language_list(Evas_Object *parent)
1151 {
1152         if(!parent) return NULL;
1153
1154         Evas_Object *genlist = elm_genlist_add(parent);
1155         if (!genlist) return NULL;
1156
1157         elm_genlist_mode_set(genlist, ELM_LIST_COMPRESS);
1158         elm_genlist_homogeneous_set(genlist, EINA_TRUE);
1159 //      uxt_genlist_set_bottom_margin_enabled(genlist, EINA_TRUE);
1160
1161         Evas_Object *circle_language_genlist = eext_circle_object_genlist_add(genlist, NULL);
1162         eext_circle_object_genlist_scroller_policy_set(circle_language_genlist, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
1163         evas_object_resize(circle_language_genlist, 360, 360);
1164         evas_object_show(circle_language_genlist);
1165         eext_rotary_object_event_activated_set(circle_language_genlist, EINA_TRUE);
1166
1167         int i = 0;
1168         int lang_val = 0;
1169         Elm_Object_Item * item = NULL;
1170
1171         evas_object_size_hint_weight_set(genlist, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1172         evas_object_size_hint_align_set(genlist, EVAS_HINT_FILL, EVAS_HINT_FILL);
1173
1174         radio_gp = elm_radio_add(genlist);
1175         elm_radio_state_value_set(radio_gp, -1);
1176
1177         lang_val = get_language_value();
1178
1179         //Title
1180         itc_title.item_style = "title";
1181         itc_title.func.text_get = __get_genlist_title_label;
1182         itc_title.func.content_get = NULL;
1183
1184         item = elm_genlist_item_append(genlist, &itc_title, (void *)-1, NULL, ELM_GENLIST_ITEM_GROUP, NULL, genlist);
1185
1186         // 2 line text
1187         itc_2text.item_style = "2text.1icon.1/sub1.multiline";
1188         itc_2text.func.text_get = __get_genlist_item_label;
1189         itc_2text.func.content_get = __get_genlist_item_content;
1190
1191
1192         item = item_append(genlist, itc_2text, (void *)0, language_set_genlist_radio_cb, genlist); // AUTO
1193
1194         if(lang_val == i) {
1195                 PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
1196                 elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
1197         }
1198
1199         if ( item == NULL ) {
1200                 PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
1201         }
1202
1203         // 1 line text
1204         itc_1text.item_style = "1text.1icon.1";
1205         itc_1text.func.text_get = __get_genlist_item_label;
1206         itc_1text.func.content_get = __get_genlist_item_content;
1207
1208         if(g_is_n66) {
1209                 for (i = 1; i < 7; i++)
1210                 {
1211                         char *s = (char *)disp_lang_array[i];
1212
1213                         if(strchr(s, '(')){
1214                                 item = item_append(genlist, itc_2text, i, language_set_genlist_radio_cb, genlist);
1215                         } else {
1216                                 item = item_append(genlist, itc_1text, i, language_set_genlist_radio_cb, genlist);
1217                         }
1218
1219                         if(lang_val == i) {
1220                                 PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
1221                                 elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
1222                         }
1223
1224                         if ( item == NULL ) {
1225                                 PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
1226                                 break;
1227                         }
1228                 }
1229         }
1230
1231         elm_radio_value_set(radio_gp, lang_val);
1232
1233         elm_object_signal_callback_add(genlist, "elm,system,language,change", "elm", language_changed_cb, NULL);
1234 //      eext_rotary_event_callback_set(genlist, _language_list_rotary_cb, NULL);
1235         evas_object_smart_callback_add(genlist, "realized", _language_list_item_realized, NULL);
1236
1237
1238         g_evt_key_down = ecore_event_handler_add(ECORE_EVENT_KEY_DOWN, _ise_keydown_cb, NULL);
1239         return genlist;
1240 }
1241
1242 void create_setting_window(Evas_Object *more_option_layout)
1243 {
1244         Evas_Object *window = NULL;
1245         Evas_Object *layout = NULL;
1246         Evas_Object *genlist = NULL;
1247         Evas_Object *naviframe = NULL;
1248
1249         /**
1250          * Create full size window
1251          *
1252          */
1253         window = elm_win_add(NULL, "voice-input-setting", ELM_WIN_BASIC);
1254         if(!window) {
1255                 PRINTFUNC(DLOG_DEBUG, "it's fail to create window.");
1256                 return;
1257         }
1258
1259         elm_win_title_set(window, "voice-input-setting");
1260         elm_win_borderless_set(window, EINA_TRUE);
1261
1262
1263         elm_win_indicator_mode_set(window, ELM_WIN_INDICATOR_HIDE);
1264
1265         /**
1266          * Set window theme
1267          *
1268          */
1269 //      ea_theme_style_set(EA_THEME_STYLE_DEFAULT);
1270 //      ea_theme_changeable_ui_enabled_set(EINA_TRUE);
1271
1272         /**
1273          * Create layout for language list
1274          *
1275          */
1276         layout = elm_layout_add(window);
1277         if (layout) {
1278                 elm_layout_theme_set(layout, "layout", "application", "default");
1279                 evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1280                 evas_object_show(layout);
1281                 elm_win_resize_object_add(window, layout);
1282         }
1283
1284         /**
1285          * Set Window rotation
1286          *
1287          */
1288         if (elm_win_wm_rotation_supported_get(window)) {
1289                 const int rots[4] = { 0, 90, 180, 270 };
1290                 elm_win_wm_rotation_available_rotations_set(window, rots, 4);
1291         }
1292
1293         /**
1294          * Activate and show window
1295          *
1296          */
1297         elm_win_activate(window);
1298         evas_object_show(window);
1299
1300         /**
1301          * Naviframe
1302          *
1303          */
1304         naviframe = elm_naviframe_add(layout);
1305         if (naviframe == NULL){
1306                 PRINTFUNC(DLOG_DEBUG, "create navi_frame failed");
1307         }
1308
1309 //      ea_object_event_callback_add(naviframe, EA_CALLBACK_BACK, ea_naviframe_back, window);
1310         elm_object_part_content_set(layout, "elm.swallow.content", naviframe);
1311
1312         /**
1313          * Push language list
1314          *
1315          */
1316         genlist = create_language_list(naviframe);
1317
1318         //item = elm_naviframe_item_push(naviframe, "IDS_VC_HEADER_VOICE_INPUT_LANGUAGE", NULL, NULL, genlist, NULL);
1319         elm_naviframe_item_push(naviframe, NULL, NULL, NULL, genlist, "empty");
1320         //elm_object_item_domain_text_translatable_set(item, PACKAGE, EINA_TRUE);
1321
1322         g_setting_window = window;
1323         g_setting_naviframe = naviframe;
1324         g_more_option_layout = more_option_layout;
1325 }
1326
1327 void _stt_lang_changed_cb(keynode_t *key, void* data)
1328 {
1329         PRINTFUNC(DLOG_DEBUG, "");
1330         if(!data) return;
1331
1332         VoiceData *vd = (VoiceData *) data;
1333         get_stt_default_language(vd);
1334         vd->sttmanager->SetLanguage(std::string(vd->kbd_lang));
1335         vd->mo->Update();
1336
1337         return;
1338 }
1339
1340 static void __done_key_cb(void *data, Evas_Object *obj, void *event_info )
1341 {
1342         PRINTFUNC(DLOG_DEBUG, "");
1343
1344         if(!obj) return;
1345         if(!data) return;
1346
1347         VoiceData *voicedata = (VoiceData *)data;
1348
1349         elm_naviframe_item_pop(voicedata->naviframe);
1350 }
1351
1352 static void __stt_detailed_entry_input_panel_event_cb(void *data, Ecore_IMF_Context *imf_context,  int value)
1353 {
1354         if(!data) return;
1355
1356         VoiceData *voicedata = (VoiceData *)data;
1357
1358         switch (value) {
1359         case ECORE_IMF_INPUT_PANEL_STATE_HIDE: // 1
1360                 elm_naviframe_item_pop(voicedata->naviframe);
1361                 break;
1362         case ECORE_IMF_INPUT_PANEL_STATE_WILL_SHOW: // 2
1363                 PRINTFUNC(DLOG_DEBUG, "keypad state will show.");
1364                 break;
1365         case ECORE_IMF_INPUT_PANEL_STATE_SHOW: // 0
1366                 PRINTFUNC(DLOG_DEBUG, "keypad state show.");
1367                 break;
1368         }
1369 }
1370
1371 static void __stt_detailed_entry_del_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
1372 {
1373         if (obj) {
1374                 Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(obj);
1375                 ecore_imf_context_input_panel_event_callback_del(imf_context, ECORE_IMF_INPUT_PANEL_STATE_EVENT, __stt_detailed_entry_input_panel_event_cb);
1376                 PRINTFUNC(DLOG_DEBUG, "input_panel_event_cb is deleted.");
1377         }
1378 }
1379
1380 static Evas_Object *create_text_detiled_view(Evas_Object *parent)
1381 {
1382         string edj_path = get_resource_path();
1383         edj_path = edj_path + STT_EDJ_FILE;
1384
1385         //layout
1386         Evas_Object *layout = elm_layout_add(parent);
1387         elm_layout_file_set(layout, edj_path.c_str(), "entry_focused_layout");
1388         evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1389         evas_object_size_hint_align_set(layout, EVAS_HINT_FILL, EVAS_HINT_FILL);
1390         evas_object_show(layout);
1391
1392         //entry
1393         Evas_Object *entry = elm_entry_add(parent);
1394         evas_object_size_hint_weight_set(entry, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1395         evas_object_size_hint_align_set(entry, EVAS_HINT_FILL, EVAS_HINT_FILL);
1396 //      ea_entry_selection_back_event_allow_set(entry, EINA_TRUE);
1397         elm_entry_context_menu_disabled_set(entry, EINA_TRUE);
1398         elm_entry_select_allow_set(entry, EINA_FALSE);
1399 //      elm_entry_cursor_handler_disabled_set(entry, EINA_TRUE);
1400         elm_entry_single_line_set(entry, EINA_TRUE);
1401         elm_entry_scrollable_set(entry, EINA_TRUE);
1402         elm_entry_input_panel_return_key_type_set(entry, ELM_INPUT_PANEL_RETURN_KEY_TYPE_DONE);
1403
1404         evas_object_show(entry);
1405
1406         elm_object_part_content_set(layout, "contents", entry);
1407         return layout;
1408 }
1409
1410
1411 static Eina_Bool __stt_entry_detailed_view_pop_cb(void *data, Elm_Object_Item *it)
1412 {
1413         PRINTFUNC(DLOG_DEBUG, "");
1414
1415         if(!data) return EINA_FALSE;
1416
1417         VoiceData *voicedata = (VoiceData *)data;
1418
1419         Evas_Object *main_entry = (Evas_Object *)voicedata->main_entry;
1420         Evas_Object *detailed_layout = elm_object_item_part_content_get(it, "elm.swallow.content");
1421         Evas_Object *detailed_entry = elm_object_part_content_get(detailed_layout, "contents");
1422
1423         const char *str = NULL;
1424
1425         int pos = 0;
1426         pos = elm_entry_cursor_pos_get(detailed_entry);
1427         PRINTFUNC(DLOG_DEBUG, "pos = %d", pos);
1428
1429         str =  elm_entry_entry_get(detailed_entry);
1430
1431         voicedata->stt_results.clear();
1432         voicedata->stt_results.push_back(str);
1433
1434 //      uxt_scroller_set_auto_scroll_enabled(voicedata->scroller, EINA_TRUE);
1435         elm_entry_entry_set(main_entry, str);
1436         elm_entry_cursor_pos_set(main_entry, pos);
1437
1438         int x, y, w, h;
1439         elm_entry_cursor_geometry_get(main_entry, &x, &y, &w, &h);
1440         PRINTFUNC(DLOG_DEBUG, "%d %d %d %d", x, y, w, h);
1441
1442         elm_scroller_region_bring_in(voicedata->scroller, 0, y+h, 300, 168);
1443
1444         return EINA_TRUE;
1445 }
1446
1447 static void _stt_entry_clicked_cb(void *data, Evas_Object * obj, void *event_info)
1448 {
1449         PRINTFUNC(DLOG_DEBUG, "");
1450
1451         if(!obj) return;
1452         if(!data) return;
1453
1454         VoiceData *voicedata = (VoiceData *)data;
1455
1456         char *str = NULL;
1457
1458         int pos = 0;
1459         pos = elm_entry_cursor_pos_get(obj);
1460         PRINTFUNC(DLOG_DEBUG, "pos = %d", pos);
1461
1462         str =  elm_entry_markup_to_utf8(elm_entry_entry_get(obj));
1463
1464         if (str && strlen(str) > 0) {
1465                 try {
1466                         if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
1467                                 voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING) {
1468                                 voicedata->sttmanager->Cancel();
1469                                 PRINTFUNC(DLOG_DEBUG, "stt entry clicked callback during STT recording and processing");
1470                                 //return;
1471                         }
1472                 }
1473                 catch(is::stt::SttException &e) {
1474                         PRINTFUNC(DLOG_ERROR, "%s", e.what());
1475                 }
1476
1477
1478                 Evas_Object *ly_detailed_view = create_text_detiled_view(voicedata->naviframe);
1479                 // Set text
1480                 Evas_Object *detailed_entry = elm_object_part_content_get(ly_detailed_view, "contents");
1481                 elm_entry_entry_set(detailed_entry, str);
1482                 elm_entry_cursor_pos_set(detailed_entry, pos);
1483                 evas_object_smart_callback_add(detailed_entry, "activated", __done_key_cb, voicedata); // Register callback for Done key
1484
1485                 Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(detailed_entry);
1486                 ecore_imf_context_input_panel_event_callback_add(imf_context, ECORE_IMF_INPUT_PANEL_STATE_EVENT, __stt_detailed_entry_input_panel_event_cb, voicedata);
1487                 evas_object_event_callback_add(detailed_entry, EVAS_CALLBACK_DEL, __stt_detailed_entry_del_cb, NULL);
1488
1489                 // Navi Push
1490                 Elm_Object_Item *navi_it = elm_naviframe_item_push(voicedata->naviframe, NULL, NULL, NULL, ly_detailed_view, NULL);
1491                 elm_naviframe_item_pop_cb_set(navi_it, __stt_entry_detailed_view_pop_cb, (void *)voicedata);
1492                 elm_naviframe_item_title_enabled_set(navi_it, EINA_FALSE, EINA_FALSE);
1493                 free(str);
1494         }
1495
1496         return;
1497 }
1498
1499
1500 void activate_circle_scroller_for_stt_textbox(void* data, Eina_Bool bActivate)
1501 {
1502         PRINTFUNC(DLOG_DEBUG, "");
1503
1504         if(!data) return;
1505         VoiceData *voicedata = (VoiceData *)data;
1506
1507         Evas_Object *scroller = NULL;
1508         Evas_Object *circle_scroller = NULL;
1509
1510         scroller = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "text_area");
1511         circle_scroller = (Evas_Object *) evas_object_data_get(scroller, "circle");
1512         eext_rotary_object_event_activated_set(circle_scroller, bActivate);
1513 }
1514
1515 static Evas_Object *create_textblock(void* data)
1516 {
1517         if(!data) return NULL;
1518
1519         VoiceData *voicedata = (VoiceData *)data;
1520
1521         Evas_Object *scroller = NULL;
1522         Evas_Object *box = NULL;
1523         Evas_Object *inner_layout = NULL;
1524         Evas_Object *entry = NULL;
1525         Evas_Object *circle_scroller = NULL;
1526
1527         string edj_path = get_resource_path();
1528         edj_path = edj_path + STT_EDJ_FILE;
1529
1530         scroller = elm_scroller_add(voicedata->layout_main);
1531
1532         elm_scroller_loop_set(scroller, EINA_FALSE, EINA_FALSE);
1533
1534         evas_object_size_hint_align_set(scroller, EVAS_HINT_FILL, EVAS_HINT_FILL);
1535         evas_object_size_hint_weight_set(scroller, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1536
1537         elm_scroller_page_size_set(scroller, 0, 50);
1538         elm_scroller_page_scroll_limit_set(scroller, 0, 1);
1539
1540         elm_object_scroll_lock_x_set(scroller, EINA_TRUE);
1541
1542 //      uxt_scroller_set_auto_scroll_enabled(scroller, EINA_FALSE);
1543
1544         circle_scroller = eext_circle_object_scroller_add(scroller, app_data->circle_surface);
1545         eext_circle_object_scroller_policy_set(circle_scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
1546         eext_rotary_object_event_activated_set(circle_scroller, EINA_TRUE);
1547
1548         box = elm_box_add(scroller);
1549
1550         inner_layout = elm_layout_add(scroller);
1551         elm_layout_file_set(inner_layout, edj_path.c_str(), "layout_textblock");
1552         evas_object_size_hint_weight_set(inner_layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1553
1554         elm_object_signal_callback_add(inner_layout, "do_scroll", "entry",
1555                 [](void *data, Evas_Object *obj, const char* signal, const char* e)
1556                 {
1557                         _bring_in_cb((void *) data);
1558                 }, (void *) scroller);
1559
1560         entry = elm_entry_add(inner_layout);
1561         voicedata->main_entry = entry;
1562         elm_entry_editable_set(entry, EINA_FALSE);
1563
1564 #define FORMAT_TEXT_AREA_FONT_STYLE \
1565         "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'"
1566         int a = 0xFF, r = 0xFF, g = 0xFF, b = 0xFF;
1567         char customStyle[512];
1568 //      ea_theme_color_get("AT02112", &r, &g, &b, &a, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
1569         snprintf(customStyle, 512, FORMAT_TEXT_AREA_FONT_STYLE, r, g, b, a, r, g, b, a);
1570
1571         elm_entry_text_style_user_push(entry, customStyle);
1572
1573         evas_object_smart_callback_add(entry, "clicked", _stt_entry_clicked_cb, voicedata);
1574
1575         elm_object_part_content_set(inner_layout, "elm.swallow.content", entry);
1576
1577         elm_box_pack_end(box, inner_layout);
1578
1579         elm_object_content_set(scroller, box);
1580         evas_object_data_set(scroller, "inner_layout", (void *) inner_layout);
1581         evas_object_data_set(scroller, "circle", (void *) circle_scroller);
1582         evas_object_show(scroller);
1583         evas_object_show(inner_layout);
1584
1585         return scroller;
1586 }
1587
1588 static Evas_Object *create_progressbar(Evas_Object *parent)
1589 {
1590         Evas_Object *progressbar = NULL;
1591
1592         progressbar = elm_progressbar_add(parent);
1593         elm_object_style_set(progressbar, "voice_input/process/small");
1594         elm_progressbar_pulse(progressbar, EINA_TRUE);
1595
1596         evas_object_size_hint_align_set(progressbar, EVAS_HINT_FILL, EVAS_HINT_FILL);
1597         evas_object_size_hint_weight_set(progressbar, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1598
1599 //      ea_theme_object_color_replace(progressbar, "B065L6", "AO012");
1600
1601         evas_object_show(progressbar);
1602
1603         return progressbar;
1604 }
1605
1606 static Evas_Object *create_fullview(Evas_Object *parent, VoiceData *r_voicedata)
1607 {
1608         PRINTFUNC(NO_PRINT, "");
1609
1610         Evas_Object *layout_main = NULL;
1611
1612         int is_screen_reader_on = FALSE;
1613
1614         VoiceData *voicedata = r_voicedata;
1615
1616         /**
1617          * add app_default_layout
1618          *
1619          */
1620         MoreOption* mo = new MoreOption(parent, voicedata);
1621         mo->Create();
1622
1623         voicedata->mo = mo;
1624
1625
1626         layout_main = elm_layout_add(mo->getMoreOptionLayout());
1627
1628         if (!layout_main)
1629                 return NULL;
1630
1631         voicedata->layout_main = layout_main;
1632
1633         string edj_path = get_resource_path();
1634         edj_path = edj_path + STT_EDJ_FILE;
1635
1636         if (vconf_get_bool(VCONFKEY_SETAPPL_ACCESSIBILITY_TTS, &is_screen_reader_on) == -1) {
1637                 PRINTFUNC(DLOG_ERROR, "Cannot read value of screen reader from vconf");
1638         }
1639
1640         evas_object_size_hint_weight_set(layout_main, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1641         evas_object_size_hint_align_set(layout_main, EVAS_HINT_FILL, EVAS_HINT_FILL);
1642
1643         elm_layout_file_set(layout_main, edj_path.c_str(), "mic_control");
1644
1645         elm_object_content_set(parent, layout_main);
1646
1647         //Canvas for Cairo effect
1648         Evas_Object *canvas = evas_object_image_filled_add(evas_object_evas_get(layout_main));
1649         evas_object_image_alpha_set(canvas, EINA_TRUE);
1650         evas_object_size_hint_align_set(canvas, EVAS_HINT_FILL, EVAS_HINT_FILL);
1651         evas_object_size_hint_weight_set(canvas, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1652         evas_object_move(canvas, 0, 0);
1653
1654         Evas_Coord CanvasW, CanvasH;
1655         CanvasW = 360;
1656         CanvasH = 74;
1657         evas_object_image_size_set(canvas, CanvasW, CanvasH);
1658         evas_object_resize(canvas, CanvasW, CanvasH);
1659         evas_object_size_hint_min_set(canvas, CanvasW, CanvasH);
1660         evas_object_show(canvas);
1661
1662         elm_object_part_content_set(layout_main, "EFFECT_BG", canvas);
1663
1664
1665         // MIC Button
1666         Evas_Object *m_mic_button = elm_button_add(layout_main);
1667         elm_object_style_set(m_mic_button, "vic/micbutton");
1668         elm_object_part_content_set(layout_main, "MIC", m_mic_button);
1669
1670         elm_object_disabled_set(m_mic_button, EINA_TRUE);
1671         evas_object_smart_callback_add(m_mic_button, "clicked", on_mic_button_press_cb, (void *) voicedata);
1672
1673         voicedata->mic_button = m_mic_button;
1674
1675         if(voicedata->btn_disabling_timer == NULL){
1676                 voicedata->btn_disabling_timer = ecore_timer_add(2.0, _mic_button_enable_cb, voicedata);
1677         }
1678
1679 //      ecore_idler_add(_idler_cb, voicedata);
1680         ecore_timer_add(0.6, _idler_cb, voicedata);
1681
1682         // Confirm panel layout
1683         Evas_Object *panel_layout;
1684         panel_layout = elm_layout_add(layout_main);
1685         elm_layout_theme_set(panel_layout, "layout", "drawer", "panel");
1686         evas_object_show(panel_layout);
1687
1688         // Confirm panel
1689         Evas_Object *panel;
1690         panel = elm_panel_add(panel_layout);
1691         elm_panel_orient_set(panel, ELM_PANEL_ORIENT_LEFT);
1692         elm_layout_theme_set(panel, "panel", "left_confirm", "default");
1693         elm_layout_theme_set(panel, "panel", "left_sending", "default");
1694
1695         elm_layout_signal_callback_add(panel, "cue,clicked", "elm", _panel_cue_clicked_cb, (void *) voicedata);
1696         evas_object_show(panel);
1697
1698         elm_object_part_content_set(panel_layout, "elm.swallow.right", panel);
1699         elm_object_part_content_set(layout_main, "left_panel_area", panel_layout);
1700
1701         elm_object_signal_emit(panel, "elm,state,disabled", "elm");
1702         elm_panel_toggle(panel);
1703
1704
1705         // Textblock
1706         Evas_Object *scroller = create_textblock(voicedata);
1707         elm_object_part_content_set(layout_main, "text_area", scroller);
1708         voicedata->scroller = scroller;
1709
1710         // Progress Bar
1711         Evas_Object *progress_bar = create_progressbar(layout_main);
1712         elm_object_part_content_set(layout_main, "PROGRESS_BAR", progress_bar);
1713         voicedata->progressbar = progress_bar;
1714
1715         // add callback
1716         elm_object_signal_callback_add(layout_main, "idle,state,pulse,visible", "", on_initial_anim_press_cb, voicedata);
1717
1718         mo->SetContentLayout(layout_main);
1719
1720         return layout_main;
1721 }
1722
1723 int is_lang_supported_by_stt(char lang[])
1724 {
1725         /* to check if the language is supported by stt */
1726         int index;
1727         for (index = (sizeof(supported_language) / sizeof(supported_language[0]))-1; index != 0; index--)
1728         {
1729                 if (!strcmp(lang, supported_language[index])) {
1730                         PRINTFUNC(DLOG_DEBUG, "current lang supported (%s)", supported_language[index]);
1731                         return TRUE;
1732                 }
1733         }
1734
1735         PRINTFUNC(DLOG_DEBUG, "current lang not supported (%s)", lang);
1736
1737         return FALSE;
1738 }
1739
1740 int init_voice(Evas_Object *parent, const char *lang, VoiceData *r_voicedata)
1741 {
1742         PRINTFUNC(DLOG_DEBUG, "[init_voice]");
1743
1744 //      stt_is_samsung_asr(&g_is_n66);
1745
1746         VoiceData *voicedata = (VoiceData *)r_voicedata;
1747         if (!voicedata) {
1748                 return FALSE;
1749         }
1750
1751         if (!parent) {
1752                 PRINTFUNC(DLOG_ERROR, "Parent is NULL\n");
1753                 return FALSE;
1754         } else {
1755                 PRINTFUNC(NO_PRINT, "Parent is there");
1756         }
1757
1758         voicedata->voicefw_state = 0;
1759
1760         /* Set Voice Language */
1761         if(voicedata->kbd_lang){
1762                 free(voicedata->kbd_lang);
1763                 voicedata->kbd_lang = NULL;
1764         }
1765
1766         //stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
1767         get_stt_default_language(voicedata);
1768         if(NULL == voicedata->kbd_lang || FALSE == is_lang_supported_by_stt(voicedata->kbd_lang)) {
1769                 voicedata->kbd_lang = strdup("en_US");
1770         }
1771
1772         PRINTFUNC(DLOG_DEBUG, "Voice input active language is : %s", voicedata->kbd_lang);
1773
1774         voicedata->naviframe = parent;
1775
1776         if (NULL == voicedata->naviframe) {
1777                 return FALSE;
1778         }
1779
1780         if (NULL != voicedata->textblock_timer) {
1781                 PRINTFUNC(DLOG_DEBUG, "delete previous textblock");
1782                 ecore_timer_del(voicedata->textblock_timer);
1783                 voicedata->textblock_timer = NULL;
1784         }
1785
1786         return TRUE;
1787 }
1788
1789 static Eina_Bool init_view(void *data)
1790 {
1791         VoiceData *voicedata = (VoiceData *)data;
1792
1793         if(voicedata == NULL)
1794                 return ECORE_CALLBACK_CANCEL;
1795
1796         voicedata->layout_main = create_fullview(voicedata->naviframe, voicedata);
1797
1798         if (voicedata->layout_main) {
1799                 evas_object_show(voicedata->layout_main);
1800         }
1801
1802         return ECORE_CALLBACK_CANCEL;
1803 }
1804
1805
1806 Evas_Object *show_voice_window(Evas_Object *parent, VoiceData *r_voicedata)
1807 {
1808         PRINTFUNC(NO_PRINT, "[show_voice_window]");
1809
1810         VoiceData *voicedata = (VoiceData *)r_voicedata;
1811         if (!voicedata) {
1812                 return NULL;
1813         }
1814
1815         if (!parent) {
1816                 PRINTFUNC(NO_PRINT, "Parent is NULL\n");
1817                 return NULL;
1818         } else {
1819                 PRINTFUNC(NO_PRINT, "Parent is there");
1820         }
1821
1822         if (NULL != voicedata->layout_main) {
1823                 PRINTFUNC(DLOG_DEBUG, "delete previous layout");
1824                 evas_object_del((voicedata)->layout_main);
1825                 (voicedata)->layout_main = NULL;
1826         }
1827
1828         if (NULL != voicedata->effector) {
1829                 PRINTFUNC(DLOG_DEBUG, "delete previous effect");
1830                 delete (voicedata->effector);
1831                 (voicedata)->effector = NULL;
1832         }
1833
1834         if (NULL != voicedata->ieffect) {
1835                 PRINTFUNC(DLOG_DEBUG, "delete previous ieffect");
1836                 delete (voicedata->ieffect);
1837                 voicedata->ieffect = NULL;
1838         }
1839
1840         if(voicedata->mo) {
1841                 delete voicedata->mo;
1842                 voicedata->mo = NULL;
1843         }
1844
1845         init_view((void *)voicedata);
1846         return voicedata->layout_main;
1847 }
1848
1849
1850 void on_stt_pause(VoiceData *r_voicedata){
1851         PRINTFUNC(DLOG_DEBUG, "");
1852
1853         VoiceData *voicedata = (VoiceData *)r_voicedata;
1854
1855         if(voicedata){
1856                 try{
1857                         //voicedata->state = STT_STATE_VAL_PREPARE_CANCEL;
1858                         voicedata->sttmanager->Cancel();
1859                 }catch(is::stt::SttException &e){
1860                         PRINTFUNC(DLOG_ERROR, "reason : %s", e.what());
1861                 }
1862
1863                 //Hide more option and language settings by interrupt scenario.
1864                 close_setting_window_idler_cb(NULL);
1865                 Evas_Object *mo_layout = voicedata->mo->getMoreOptionLayout();
1866                 if(mo_layout){
1867                         if(eext_more_option_opened_get(mo_layout) == EINA_TRUE) {
1868                                 eext_more_option_opened_set(mo_layout, EINA_FALSE);
1869                         }
1870                 }
1871         }
1872 }
1873
1874 void on_destroy(VoiceData *r_voicedata)
1875 {
1876         PRINTFUNC(NO_PRINT, "");
1877
1878         VoiceData *voicedata = (VoiceData *)r_voicedata;
1879
1880         powerUnlock();
1881
1882         if (NULL != voicedata) {
1883                 if (NULL != voicedata->layout_main) {
1884                         voicedata->layout_main = NULL;
1885                 }
1886
1887                 if (NULL != voicedata->naviframe) {
1888                         voicedata->naviframe = NULL;
1889                 }
1890
1891                 if (NULL != voicedata->start_timer) {
1892                         ecore_timer_del(voicedata->start_timer);
1893                         voicedata->start_timer = NULL;
1894                 }
1895
1896                 if (NULL != voicedata->refresh_timer) {
1897                         ecore_timer_del(voicedata->refresh_timer);
1898                         voicedata->refresh_timer = NULL;
1899                 }
1900
1901                 if (NULL != voicedata->progressbar_timer) {
1902                         ecore_timer_del(voicedata->progressbar_timer);
1903                         voicedata->progressbar_timer = NULL;
1904                         elm_progressbar_pulse(voicedata->progressbar, EINA_FALSE);
1905                 }
1906
1907                 if (NULL != voicedata->textblock_timer) {
1908                         ecore_timer_del(voicedata->textblock_timer);
1909                         voicedata->textblock_timer = NULL;
1910                 }
1911
1912                 if (NULL != voicedata->guide_text_timer) {
1913                         ecore_timer_del(voicedata->guide_text_timer);
1914                         voicedata->guide_text_timer = NULL;
1915                 }
1916
1917                 if (NULL != voicedata->btn_disabling_timer) {
1918                         ecore_timer_del(voicedata->btn_disabling_timer);
1919                         voicedata->btn_disabling_timer = NULL;
1920                 }
1921
1922                 if (NULL != voicedata->power_unlock_timer) {
1923                         ecore_timer_del(voicedata->power_unlock_timer);
1924                         voicedata->power_unlock_timer = NULL;
1925                 }
1926
1927                 if(voicedata->kbd_lang) {
1928                         free(voicedata->kbd_lang);
1929                         voicedata->kbd_lang = NULL;
1930                 }
1931
1932                 if(voicedata->ieffect) {
1933                         delete voicedata->ieffect;
1934                         voicedata->ieffect = NULL;
1935                 }
1936
1937                 if(voicedata->effector) {
1938                         delete voicedata->effector;
1939                         voicedata->effector = NULL;
1940                 }
1941
1942                 if(voicedata->mo) {
1943                         delete voicedata->mo;
1944                         voicedata->mo = NULL;
1945                 }
1946
1947                 if(voicedata->sttmanager) {
1948                         delete voicedata->sttmanager;
1949                         voicedata->sttmanager = NULL;
1950                 }
1951
1952                 if(voicedata->sttfeedback) {
1953                         delete voicedata->sttfeedback;
1954                         voicedata->sttfeedback = NULL;
1955                 }
1956
1957                 free(voicedata);
1958         }
1959 }
1960
1961
1962