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