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