4 * Copyright (c) 2000 - 2015 Samsung Electronics Co., Ltd. All rights reserved.
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
24 #include <app_manager.h>
27 #include <notification.h>
28 #include <app_preference.h>
32 #include <tzsh_indicator_service.h>
34 #include <vconf/vconf-internal-idle-lock-keys.h>
40 #include "indicator_gui.h"
46 #include "indicator.h"
49 #define GRP_NAME "indicator"
50 #define WIN_TITLE "Illume Indicator"
51 #define VCONF_PHONE_STATUS "memory/startapps/sequence"
53 #define BUS_NAME "org.tizen.system.deviced"
54 #define PATH_NAME "/Org/Tizen/System/DeviceD/Display"
55 #define INTERFACE_NAME BUS_NAME".display"
56 #define MEMBER_NAME "LCDOn"
58 #define MP_APP_ID "org.tizen.music-player-lite"
59 #define FMRADIO_APP_ID "org.tizen.fm-radio-lite"
60 #define VR_APP_ID "org.tizen.voicerecorder-lite"
62 #define STR_ATOM_MV_INDICATOR_GEOMETRY "_E_MOVE_INDICATOR_GEOMETRY"
64 #define HIBERNATION_ENTER_NOTI "HIBERNATION_ENTER"
65 #define HIBERNATION_LEAVE_NOTI "HIBERNATION_LEAVE"
67 #define UNLOCK_ENABLED 0
70 #ifdef HOME_KEY_EMULATION
71 /* Predefine string */
72 #define PROP_HWKEY_EMULATION "_HWKEY_EMULATION"
73 #define KEY_MSG_PREFIX_PRESS "P:"
74 #define KEY_MSG_PREFIX_RELEASE "R:"
75 #define KEY_MSG_PREFIX_PRESS_C "PC"
76 #define KEY_MSG_PREFIX_RELEASE_C "RC"
79 #define KEY_HOME "XF86Phone"
81 #endif /* HOME_KEY_EMULATION */
83 //static E_DBus_Connection *edbus_conn=NULL;
84 //static E_DBus_Signal_Handler *edbus_handler=NULL;
85 static Eina_Bool home_button_pressed = EINA_FALSE;
86 static Eina_Bool show_hide_pressed = EINA_FALSE;
87 Evas_Coord_Point indicator_press_coord = {0,0};
88 Ecore_Timer *clock_timer;
89 int is_transparent = 0;
90 int current_angle = 0;
91 int current_state = 0;
93 static int bFirst_opacity = 1;
96 static struct _s_info {
97 Ecore_Timer *listen_timer;
103 static indicator_error_e _start_indicator(void *data);
104 static indicator_error_e _terminate_indicator(void *data);
106 static void _indicator_low_bat_cb(app_event_info_h event_info, void *data);
107 static void _indicator_lang_changed_cb(app_event_info_h event_info, void *data);
108 static void _indicator_region_changed_cb(app_event_info_h event_info, void *data);
109 static void _indicator_window_delete_cb(void *data, Evas_Object * obj, void *event);
110 //static Eina_Bool _indicator_client_message_cb(void *data, int type, void *event);
111 static void _indicator_mouse_down_cb(void *data, Evas * e, Evas_Object * obj, void *event);
112 static void _indicator_mouse_move_cb(void *data, Evas * e, Evas_Object * obj, void *event);
113 static void _indicator_mouse_up_cb(void *data, Evas * e, Evas_Object * obj, void *event);
116 static void _indicator_low_bat_cb(app_event_info_h event_info, void *data)
120 static void _indicator_lang_changed_cb(app_event_info_h event_info, void *data)
122 modules_lang_changed(data);
125 static void _indicator_region_changed_cb(app_event_info_h event_info, void *data)
127 modules_region_changed(data);
130 static void _indicator_window_delete_cb(void *data, Evas_Object * obj, void *event)
134 _terminate_indicator((struct appdata *)data);
137 static void _indicator_notify_pm_state_cb(keynode_t * node, void *data)
139 static int nMove = 0;
140 static int nIndex = 1;
145 if (vconf_get_int(VCONFKEY_PM_STATE, &val) < 0) return;
148 case VCONFKEY_PM_STATE_LCDOFF:
149 if (clock_timer != NULL) {
150 ecore_timer_del(clock_timer);
153 case VCONFKEY_PM_STATE_SLEEP: // lcd off 2
155 nMove = nMove+nIndex;
161 char temp[30] = {0,};
162 sprintf(temp,"indicator.padding.resize.%d",nMove);
163 util_signal_emit(data,temp,"indicator.prog");
165 icon_set_update_flag(0);
166 box_noti_ani_handle(0);
168 case VCONFKEY_PM_STATE_NORMAL:
169 if (!icon_get_update_flag()) {
170 icon_set_update_flag(1);
171 box_noti_ani_handle(1);
172 modules_wake_up(data);
175 case VCONFKEY_PM_STATE_LCDDIM:
181 static void _indicator_power_off_status_cb(keynode_t * node, void *data)
187 if (vconf_get_int(VCONFKEY_SYSMAN_POWER_OFF_STATUS, &val) < 0) return;
190 case VCONFKEY_SYSMAN_POWER_OFF_DIRECT:
191 case VCONFKEY_SYSMAN_POWER_OFF_RESTART:
200 static void _indicator_lock_status_cb(keynode_t * node, void *data)
202 static int lockstate = 0;
203 extern int clock_mode;
208 if (vconf_get_int(VCONFKEY_IDLE_LOCK_STATE, &val) < 0) return;
209 if (val == lockstate) return;
214 case VCONFKEY_IDLE_UNLOCK:
215 if (!clock_mode) util_signal_emit(data,"clock.font.12","indicator.prog");
216 else util_signal_emit(data,"clock.font.24","indicator.prog");
218 case VCONFKEY_IDLE_LOCK:
219 case VCONFKEY_IDLE_LAUNCHING_LOCK:
220 util_signal_emit(data,"clock.invisible","indicator.prog");
229 static void _rotate_window(struct appdata *ad, int new_angle)
233 _D("Indicator angle is %d degree", new_angle);
235 current_angle = new_angle;
240 evas_object_resize(ad->win.win, ad->win.port_w, ad->win.h);
244 evas_object_resize(ad->win.win, ad->win.land_w, ad->win.h);
253 static void _change_opacity(void *data, enum indicator_opacity_mode mode)
255 struct appdata *ad = NULL;
256 const char *signal = NULL;
257 retif(data == NULL, , "Invalid parameter!");
261 if (bFirst_opacity==1) bFirst_opacity = 0;
264 case INDICATOR_OPACITY_OPAQUE:
265 signal = "bg.opaque";
266 ad->opacity_mode = mode;
268 case INDICATOR_OPACITY_TRANSLUCENT:
269 signal = "bg.translucent";
270 ad->opacity_mode = mode;
272 case INDICATOR_OPACITY_TRANSPARENT:
273 signal = "bg.transparent";
274 ad->opacity_mode = mode;
277 _E("unknown mode : %d", mode);
278 signal = "bg.opaque";
279 ad->opacity_mode = INDICATOR_OPACITY_OPAQUE;
283 util_signal_emit_by_win(&(ad->win),signal, "indicator.prog");
288 static void _indicator_quickpanel_changed(void *data, int is_open)
294 if (vconf_get_int(VCONFKEY_IDLE_LOCK_STATE, &val) < 0) return;
295 if (val == VCONFKEY_IDLE_LOCK) return;
300 static Eina_Bool _indicator_client_message_cb(void *data, int type, void *event)
302 Ecore_X_Event_Client_Message *ev = (Ecore_X_Event_Client_Message *) event;
303 struct appdata *ad = NULL;
306 retv_if(data == NULL || event == NULL, ECORE_CALLBACK_RENEW);
307 if (ev->message_type == ECORE_X_ATOM_E_ILLUME_QUICKPANEL_STATE) {
308 if (ev->data.l[0] == ECORE_X_ATOM_E_ILLUME_QUICKPANEL_ON) {
309 _indicator_quickpanel_changed(data, 1);
310 } else if (ev->data.l[0] == ECORE_X_ATOM_E_ILLUME_QUICKPANEL_OFF) {
311 _indicator_quickpanel_changed(data, 0);
315 if (ev->message_type == ECORE_X_ATOM_E_ILLUME_ROTATE_WINDOW_ANGLE) {
317 if(ev->win != ad->active_indi_win) {
318 return ECORE_CALLBACK_RENEW;
320 new_angle = ev->data.l[0];
321 _rotate_window(ad, new_angle);
327 /* this function will be reused */
329 static Eina_Bool _active_indicator_handle(void* data,int type)
333 // Ecore_X_Illume_Indicator_Opacity_Mode illume_opacity = 0;
335 retv_if(!data, EINA_FALSE);
337 struct appdata *ad = (struct appdata *)data;
341 illume_opacity = ecore_x_e_illume_indicator_opacity_get(ad->active_indi_win);
343 switch(illume_opacity) {
344 case ECORE_X_ILLUME_INDICATOR_OPAQUE:
345 trans_mode = INDICATOR_OPACITY_OPAQUE;
347 case ECORE_X_ILLUME_INDICATOR_TRANSLUCENT:
348 trans_mode = INDICATOR_OPACITY_TRANSLUCENT;
350 case ECORE_X_ILLUME_INDICATOR_TRANSPARENT:
351 trans_mode = INDICATOR_OPACITY_TRANSPARENT;
354 trans_mode = INDICATOR_OPACITY_OPAQUE;
358 _change_opacity(ad, trans_mode);
362 util_win_prop_angle_get(ad->active_indi_win, &angle);
363 _rotate_window(ad, angle);
373 /* this function will be reused */
375 static Eina_Bool _property_changed_cb(void *data, int type, void *event)
377 struct appdata *ad = data;
378 Ecore_X_Event_Window_Property *ev = event;
380 retv_if(!ad, ECORE_CALLBACK_PASS_ON);
381 retv_if(!ev, ECORE_CALLBACK_PASS_ON);
383 if (ev->atom == ECORE_X_ATOM_E_ILLUME_ROTATE_WINDOW_ANGLE) {
384 if (ev->win == ad->active_indi_win) {
385 _active_indicator_handle(data, 2);
387 } else if (ev->atom == ECORE_X_ATOM_E_ILLUME_INDICATOR_OPACITY_MODE) {
388 if (ev->win == ad->active_indi_win) {
389 _active_indicator_handle(data, 1);
391 } else if (ev->atom == ad->atom_active) {
394 Ecore_X_Window active_win;
396 ret = ecore_x_window_prop_window_get(ecore_x_window_root_first_get(), ad->atom_active, &(active_win), 1);
398 _E("Count of fetched items : %d", ret);
399 return ECORE_CALLBACK_PASS_ON;
402 if (active_win != ad->active_indi_win) {
403 if (ad->active_indi_win != -1) {
404 ecore_x_window_unsniff(ad->active_indi_win);
405 _D("UNSNIFF API %x", ad->active_indi_win);
407 ad->active_indi_win = active_win;
409 ecore_x_window_sniff(ad->active_indi_win);
412 _active_indicator_handle(data, 1);
413 _active_indicator_handle(data, 2);
416 return ECORE_CALLBACK_PASS_ON;
421 static void _mctrl_monitor_cb(minicontrol_action_e action, const char *name, unsigned int width, unsigned int height, minicontrol_priority_e priority, void *data)
426 modules_minictrl_control(action,name,data);
430 static void _indicator_ecore_evas_msg_parent_handle(Ecore_Evas *ee, int msg_domain, int msg_id, void *data, int size)
434 #ifdef _SUPPORT_SCREEN_READER
435 if (msg_domain == MSG_DOMAIN_CONTROL_ACCESS) {
436 struct appdata *ad = (struct appdata *)ecore_evas_data_get(ee,"indicator_app_data");
440 Elm_Access_Action_Info *action_info;
441 Evas_Object* win = NULL;
446 if (msg_id == ELM_ACCESS_ACTION_ACTIVATE) {
447 elm_access_action(win, action_info->action_type,action_info);
448 } else if (msg_id == ELM_ACCESS_ACTION_HIGHLIGHT_NEXT) {
449 action_info->highlight_cycle = EINA_TRUE;
450 elm_access_action(win,action_info->action_type,action_info);
451 } else if (msg_id == ELM_ACCESS_ACTION_HIGHLIGHT_PREV) {
452 action_info->highlight_cycle = EINA_TRUE;
453 elm_access_action(win,action_info->action_type,action_info);
454 } else if (msg_id == ELM_ACCESS_ACTION_UNHIGHLIGHT) {
455 elm_access_action(win,action_info->action_type,action_info);
456 } else if (msg_id == ELM_ACCESS_ACTION_READ) {
457 elm_access_action(win,action_info->action_type,action_info);
460 #endif /* _SUPPORT_SCREEN_READER */
464 static void on_changed_receive(void *data, DBusMessage *msg)
468 r = dbus_message_is_signal(msg, INTERFACE_NAME, MEMBER_NAME);
471 _D("LCD On handling");
473 if (!icon_get_update_flag()) {
474 icon_set_update_flag(1);
475 box_noti_ani_handle(1);
476 modules_wake_up(data);
480 static void edbus_cleaner(void)
483 _D("already unregistered");
488 e_dbus_signal_handler_del(edbus_conn, edbus_handler);
489 edbus_handler = NULL;
493 e_dbus_connection_close(edbus_conn);
500 static int edbus_listener(void* data)
502 if (edbus_conn != NULL) {
509 edbus_conn = e_dbus_bus_get(DBUS_BUS_SYSTEM);
511 _E("e_dbus_bus_get error");
515 edbus_handler = e_dbus_signal_handler_add(edbus_conn, NULL, PATH_NAME, INTERFACE_NAME, MEMBER_NAME, on_changed_receive, data);
516 if (!edbus_handler) {
517 _E("e_dbus_signal_handler_add error");
525 static void _register_event_handler_both(win_info *win, void *data)
531 ee = ecore_evas_ecore_evas_get(evas_object_evas_get(win->win));
533 evas_object_smart_callback_add(win->win,"delete,request", _indicator_window_delete_cb, data);
534 evas_object_event_callback_add(win->layout, EVAS_CALLBACK_MOUSE_DOWN, _indicator_mouse_down_cb, win);
535 evas_object_event_callback_add(win->layout, EVAS_CALLBACK_MOUSE_MOVE, _indicator_mouse_move_cb, win);
536 evas_object_event_callback_add(win->layout, EVAS_CALLBACK_MOUSE_UP,_indicator_mouse_up_cb, win);
537 ecore_evas_callback_msg_parent_handle_set(ee, _indicator_ecore_evas_msg_parent_handle);
538 ecore_evas_data_set(ee,"indicator_app_data",data);
543 static void _indicator_service_cb(void *data, tzsh_indicator_service_h service, int angle, int opacity)
545 _D("Indicator service callback");
549 static void register_event_handler(void *data)
551 struct appdata *ad = data;
552 // Ecore_Event_Handler *hdl = NULL;
555 ad->active_indi_win = -1;
556 //ad->atom_active = ecore_x_atom_get("_NET_ACTIVE_WINDOW");
557 //ecore_x_window_sniff(ecore_x_window_root_first_get());
559 _register_event_handler_both(&(ad->win),data);
563 if (ad->indicator_service) {
564 tzsh_indicator_service_property_change_cb_set(ad->indicator_service, _indicator_service_cb, NULL);
569 hdl = ecore_event_handler_add(ECORE_X_EVENT_CLIENT_MESSAGE, _indicator_client_message_cb, (void *)ad);
571 ad->evt_handlers = eina_list_append(ad->evt_handlers, hdl);
573 hdl = ecore_event_handler_add(ECORE_X_EVENT_WINDOW_PROPERTY, _property_changed_cb, data);
575 ad->evt_handlers = eina_list_append(ad->evt_handlers, hdl);
577 if (vconf_notify_key_changed(VCONFKEY_PM_STATE, _indicator_notify_pm_state_cb, (void *)ad) != 0) {
578 _E("Fail to set callback for VCONFKEY_PM_STATE");
581 if (vconf_notify_key_changed(VCONFKEY_SYSMAN_POWER_OFF_STATUS, _indicator_power_off_status_cb, (void *)ad) < 0) {
582 _E("Failed to set callback for VCONFKEY_SYSMAN_POWER_OFF_STATUS");
585 if (vconf_notify_key_changed(VCONFKEY_IDLE_LOCK_STATE, _indicator_lock_status_cb, (void *)ad) < 0) {
586 _E("Failed to set callback for VCONFKEY_IDLE_LOCK_STATE");
589 // edbus_listener(data);
592 static void _unregister_event_handler_both(win_info *win)
596 evas_object_smart_callback_del(win->win, "delete-request", _indicator_window_delete_cb);
597 evas_object_event_callback_del(win->layout, EVAS_CALLBACK_MOUSE_DOWN, _indicator_mouse_down_cb);
598 evas_object_event_callback_del(win->layout, EVAS_CALLBACK_MOUSE_MOVE, _indicator_mouse_move_cb);
599 evas_object_event_callback_del(win->layout, EVAS_CALLBACK_MOUSE_UP, _indicator_mouse_up_cb);
602 static int unregister_event_handler(void *data)
604 struct appdata *ad = (struct appdata *)data;
608 _unregister_event_handler_both(&(ad->win));
610 vconf_ignore_key_changed(VCONFKEY_PM_STATE, _indicator_notify_pm_state_cb);
611 vconf_ignore_key_changed(VCONFKEY_SYSMAN_POWER_OFF_STATUS, _indicator_power_off_status_cb);
612 vconf_ignore_key_changed(VCONFKEY_IDLE_LOCK_STATE, _indicator_lock_status_cb);
614 Ecore_Event_Handler *hdl = NULL;
615 EINA_LIST_FREE(ad->evt_handlers, hdl) {
616 if (hdl) ecore_event_handler_del(hdl);
624 static void _create_layout(struct appdata *ad, const char *file, const char *group)
626 ad->win.layout = elm_layout_add(ad->win.win);
627 ret_if(!ad->win.layout);
629 if (EINA_FALSE == elm_layout_file_set(ad->win.layout, file, group)) {
630 _E("Failed to set file of layout");
631 evas_object_del(ad->win.layout);
635 evas_object_size_hint_min_set(ad->win.layout, ad->win.w, ad->win.h);
637 evas_object_size_hint_weight_set(ad->win.layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
638 elm_win_resize_object_add(ad->win.win, ad->win.layout);
639 evas_object_move(ad->win.layout, 0, 0);
640 evas_object_show(ad->win.layout);
643 static void _create_box(win_info *win)
647 /* First, clear layout */
657 static indicator_error_e _tzsh_set(struct appdata* ad)
661 retv_if(!ad, INDICATOR_ERROR_INVALID_PARAMETER);
662 retv_if(!ad->win.win, INDICATOR_ERROR_INVALID_PARAMETER);
664 ad->tzsh = tzsh_create(TZSH_TOOLKIT_TYPE_EFL);
665 retv_if(!ad->tzsh, INDICATOR_ERROR_FAIL);
667 tz_win = elm_win_window_id_get(ad->win.win);
669 tzsh_destroy(ad->tzsh);
670 _E("Failed to get Tizen window");
672 //return INDICATOR_ERROR_FAIL;
673 return INDICATOR_ERROR_NONE;
676 ad->indicator_service = tzsh_indicator_service_create(ad->tzsh, tz_win);
677 if (!ad->indicator_service) {
678 tzsh_destroy(ad->tzsh);
679 _E("Failed to create Tizen window indicator service");
680 return INDICATOR_ERROR_FAIL;
683 return INDICATOR_ERROR_NONE;
686 static void _tzsh_unset(struct appdata *ad)
690 if (ad->indicator_service) {
691 tzsh_indicator_service_destroy(ad->indicator_service);
692 ad->indicator_service = NULL;
696 tzsh_destroy(ad->tzsh);
702 static Eina_Bool _indicator_listen_timer_cb(void* data)
704 win_info *win = data;
706 retv_if(!win, ECORE_CALLBACK_CANCEL);
708 //win = (win_info*)data;
710 if (!elm_win_socket_listen(win->win , INDICATOR_SERVICE_NAME, 0, EINA_FALSE)) {
711 _E("failed to elm_win_socket_listen() %x", win->win);
712 return ECORE_CALLBACK_RENEW;
714 _D("listen success");
715 s_info.listen_timer = NULL;
716 return ECORE_CALLBACK_CANCEL;
720 #define INDICATOR_HEIGHT_TM1 52
721 static void _create_window(struct appdata *ad)
723 Evas_Object *dummy_win = NULL;
727 ad->win.win = elm_win_add(NULL, "indicator", ELM_WIN_SOCKET_IMAGE);
728 ret_if(!(ad->win.win));
730 elm_win_alpha_set(ad->win.win, EINA_TRUE);
732 dummy_win = elm_win_add(NULL, "indicator_dummy", ELM_WIN_BASIC);
734 elm_win_screen_size_get(dummy_win, NULL, NULL, &ad->win.port_w, &ad->win.land_w);
735 evas_object_del(dummy_win);
736 _D("Dummy window w, h (%d, %d)", ad->win.port_w, ad->win.land_w);
738 _E("Critical error. Cannot create dummy window");
741 if (!elm_win_socket_listen(ad->win.win , INDICATOR_SERVICE_NAME, 0, EINA_FALSE)) {
742 _E("Failed 1st to elm_win_socket_listen() %x", ad->win.win);
744 if (s_info.listen_timer != NULL) {
745 ecore_timer_del(s_info.listen_timer);
746 s_info.listen_timer = NULL;
748 s_info.listen_timer = ecore_timer_add(3, _indicator_listen_timer_cb, &(ad->win));
751 elm_win_alpha_set(ad->win.win , EINA_TRUE);
753 elm_win_borderless_set(ad->win.win , EINA_TRUE);
754 evas_object_size_hint_fill_set(ad->win.win , EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
755 evas_object_size_hint_align_set(ad->win.win , 1.0, 0.5);
757 evas_object_resize(ad->win.win, ad->win.port_w, INDICATOR_HEIGHT_TM1);
758 _D("w,h(%d,%d)", ad->win.port_w, INDICATOR_HEIGHT_TM1);
760 evas_object_show(ad->win.win);
764 static void _create_base_gui(void* data)
766 struct appdata *ad = data;
770 _D("Start to create base gui");
776 if (INDICATOR_ERROR_NONE != _tzsh_set(ad)) {
777 _E("Failed to set tzsh");
782 ad->win.h = INDICATOR_HEIGHT_TM1;
783 ad->win.w = ad->win.port_w;
784 ad->win.evas = evas_object_evas_get(ad->win.win);
786 _D("win_size = Original(%d, %d), Scaled(%lf, %lf)", ad->win.port_w, ad->win.h, ELM_SCALE_SIZE(ad->win.port_w), ELM_SCALE_SIZE(ad->win.h));
788 _create_layout(ad, util_get_res_file_path(EDJ_FILE), GRP_NAME);
789 _create_box(&(ad->win));
793 Evas_Object *rect = evas_object_rectangle_add(ad->win.evas);
795 evas_object_resize(rect, 720, 52);
796 evas_object_color_set(rect, 0, 0, 255, 255);
797 evas_object_show(rect);
798 evas_object_layer_set(rect, -256);
805 static void _init_win_info(void * data)
807 struct appdata *ad = data;
811 memset(&(ad->win),0x00,sizeof(win_info));
814 static void _init_tel_info(void * data)
816 struct appdata *ad = data;
820 memset(&(ad->tel_info), 0x00, sizeof(telephony_info));
823 static indicator_error_e _start_indicator(void *data)
825 retv_if(!data, INDICATOR_ERROR_INVALID_PARAMETER);
827 _init_win_info(data);
828 _init_tel_info(data);
830 /* Create indicator window */
831 _create_base_gui(data);
833 return INDICATOR_ERROR_NONE;
836 static indicator_error_e _terminate_indicator(void *data)
838 struct appdata *ad = data;
840 retv_if(!ad, INDICATOR_ERROR_INVALID_PARAMETER);
843 unregister_event_handler(ad);
845 box_fini(&(ad->win));
848 evas_image_cache_flush(ad->win.evas);
850 if (ad->win.layout) {
851 evas_object_del(ad->win.layout);
852 ad->win.layout = NULL;
856 evas_object_del(ad->win.win);
870 return INDICATOR_ERROR_NONE;
873 static void __indicator_set_showhide_press(int value, int line)
875 show_hide_pressed = value;
878 static void _indicator_mouse_down_cb(void *data, Evas * e, Evas_Object * obj, void *event)
880 win_info *win = (win_info*)data;
881 Evas_Event_Mouse_Down *ev = NULL;
883 retif(data == NULL || event == NULL, , "Invalid parameter!");
886 win->mouse_event.x = ev->canvas.x;
887 win->mouse_event.y = ev->canvas.y;
889 if (ev->button != 1) {
893 #ifdef HOME_KEY_EMULATION
894 if (box_check_indicator_area(win, ev->canvas.x, ev->canvas.y)) {
895 int lock_state = VCONFKEY_IDLE_UNLOCK;
899 /* if (indicator_message_disp_check(win->type) == 1) {
902 ret = vconf_get_int(VCONFKEY_IDLE_LOCK_STATE,&lock_state);
904 if (ret != 0 || lock_state == VCONFKEY_IDLE_LOCK) {
907 ret = vconf_get_int(VCONFKEY_SETAPPL_PSMODE,&ps_state);
909 if (ret != 0 || ps_state == SETTING_PSMODE_EMERGENCY) {
913 if (box_check_home_icon_area(win, ev->canvas.x, ev->canvas.y)) {
915 if (util_check_system_status() == FAIL) {
916 _D("util_check_system_status failed");
919 home_button_pressed = EINA_TRUE;
921 indicator_press_coord.x = ev->canvas.x;
922 indicator_press_coord.y = ev->canvas.y;
929 static void _indicator_mouse_move_cb(void *data, Evas * e, Evas_Object * obj, void *event)
931 Evas_Event_Mouse_Move *ev = NULL;
932 win_info* win = (win_info*)data;
934 retif(data == NULL || event == NULL, , "Invalid parameter!");
938 if (home_button_pressed) {
939 if (!box_check_home_icon_area(win,ev->cur.canvas.x,ev->cur.canvas.y)) {
940 home_button_pressed = false;
944 if (show_hide_pressed == 1) {
945 if (!box_check_more_icon_area(win,ev->cur.canvas.x,ev->cur.canvas.y)) {
946 __indicator_set_showhide_press(EINA_FALSE, __LINE__);
951 static void _indicator_mouse_up_cb(void *data, Evas * e, Evas_Object * obj, void *event)
953 Evas_Event_Mouse_Up *ev = NULL;
954 win_info *win = (win_info *)data;
956 retif(data == NULL || event == NULL, , "Invalid parameter!");
960 #ifdef HOME_KEY_EMULATION
961 if (box_check_indicator_area(win, ev->canvas.x, ev->canvas.y)) {
963 if (box_check_home_icon_area(win, ev->canvas.x, ev->canvas.y)) {
964 if (home_button_pressed == EINA_TRUE) {
965 util_launch_search(win->data);
966 feedback_play_type(FEEDBACK_TYPE_SOUND, FEEDBACK_PATTERN_TAP);
969 } else if (box_check_more_icon_area(win, ev->canvas.x, ev->canvas.y)) {
970 if(show_hide_pressed == EINA_TRUE) {
972 feedback_play_type(FEEDBACK_TYPE_SOUND, FEEDBACK_PATTERN_TAP);
977 home_button_pressed = EINA_FALSE;
978 __indicator_set_showhide_press(EINA_FALSE, __LINE__);
980 #else /* HOME_REMOVE_LONGPRESS */
981 int mouse_up_prio = -1;
982 int mouse_down_prio = -1;
985 if (home_button_pressed == EINA_TRUE) {
986 home_button_pressed = EINA_FALSE;
990 box_get_priority_in_move_area(win,win->mouse_event.x,
992 mouse_up_prio = box_get_priority_in_move_area(win,ev->canvas.x,
995 if (mouse_down_prio > -1 && mouse_up_prio > -1
996 && mouse_down_prio == mouse_up_prio) {
997 switch (mouse_down_prio) {
998 case INDICATOR_PRIORITY_FIXED1:
999 lock_state = VCONFKEY_IDLE_UNLOCK;
1002 lock_ret = vconf_get_int(VCONFKEY_IDLE_LOCK_STATE,
1005 /* In Lock Screen, home button don't have to do */
1006 if (lock_ret == 0 && lock_state == VCONFKEY_IDLE_LOCK)
1009 if (util_check_system_status() == FAIL)
1014 #endif /* HOME_KEY_EMULATION */
1015 win->mouse_event.x = 0;
1016 win->mouse_event.y = 0;
1020 static void _app_terminate_cb(app_context_h app_context, app_context_status_e status, void *data)
1022 retif(data == NULL, , "Invalid parameter!");
1023 DBG("_app_terminate_cb");
1024 char *app_id = NULL;
1025 app_context_get_app_id(app_context, &app_id);
1026 if (app_id == NULL) {
1027 ERR("app_id is null!!");
1030 DBG("_app_terminate_cb %s",app_id);
1033 if (status == APP_CONTEXT_STATUS_TERMINATED) {
1034 if (strcmp(MP_APP_ID,app_id) == 0) {
1035 DBG("hide music icon");
1037 } else if(strcmp(FMRADIO_APP_ID,app_id) == 0) {
1038 DBG("hide fm radio icon");
1039 hide_fm_radio_icon();
1040 } else if(strcmp(VR_APP_ID,app_id) == 0) {
1041 DBG("hide voice recorder icon");
1042 hide_voice_recorder_icon();
1051 static void register_app_terminate_cb(void* data)
1053 retif(data == NULL, , "Invalid parameter!");
1054 app_manager_set_app_context_status_cb(_app_terminate_cb, MP_APP_ID, data);
1055 app_manager_set_app_context_status_cb(_app_terminate_cb, FMRADIO_APP_ID, data);
1056 app_manager_set_app_context_status_cb(_app_terminate_cb, VR_APP_ID, data);
1060 static void _signal_handler(int signum, siginfo_t *info, void *unused)
1065 static bool app_create(void *data)
1067 struct appdata *ad = data;
1070 retv_if(!ad, false);
1072 elm_app_base_scale_set(2.6);
1074 /* Signal handler */
1075 struct sigaction act;
1076 memset(&act, 0x00, sizeof(struct sigaction));
1077 act.sa_sigaction = _signal_handler;
1078 act.sa_flags = SA_SIGINFO;
1080 ret = sigemptyset(&act.sa_mask);
1082 _E("Failed to sigemptyset[%s]", strerror(errno));
1084 ret = sigaddset(&act.sa_mask, SIGTERM);
1086 _E("Failed to sigaddset[%s]", strerror(errno));
1088 ret = sigaction(SIGTERM, &act, NULL);
1090 _E("Failed to sigaction[%s]", strerror(errno));
1093 ret = _start_indicator(ad);
1094 if (ret != INDICATOR_ERROR_NONE) {
1095 _D("Failed to create a new window!");
1098 /* Set nonfixed-list size for display */
1099 modules_init_first(ad);
1102 elm_win_activate(ad->win.win);
1104 evas_object_show(ad->win.layout);
1105 evas_object_show(ad->win.win);
1110 static void app_terminate(void *data)
1112 struct appdata *ad = data;
1115 indicator_message_fini();
1116 #ifdef _SUPPORT_SCREEN_READER2
1117 indicator_service_tts_fini(data);
1120 unregister_event_handler(ad);
1122 feedback_deinitialize();
1124 box_fini(&(ad->win));
1125 evas_image_cache_flush(ad->win.evas);
1126 evas_object_del(ad->win.layout);
1127 evas_object_del(ad->win.win);
1129 _D("INDICATOR IS TERMINATED");
1132 static void app_pause(void *data)
1136 static void app_resume(void *data)
1140 static void app_service(app_control_h service, void *data)
1142 struct appdata *ad = data;
1144 _D("INDICATOR IS STARTED");
1146 register_event_handler(ad);
1148 #ifdef _SUPPORT_SCREEN_READER
1149 modules_register_tts(data);
1151 feedback_initialize();
1152 indicator_message_init(data);
1153 if (INDICATOR_ERROR_NONE != ticker_init(ad)) {
1154 _E("Ticker cannot initialize");
1156 #ifdef _SUPPORT_SCREEN_READER2
1157 indicator_service_tts_init(data);
1159 _indicator_lock_status_cb(NULL, data);
1161 register_app_terminate_cb(data);
1165 int main(int argc, char *argv[])
1169 ui_app_lifecycle_callback_s event_callback = {0,};
1170 app_event_handler_h handlers[5] = {NULL, };
1174 _D("Start indicator");
1176 event_callback.create = app_create;
1177 event_callback.terminate = app_terminate;
1178 event_callback.pause = app_pause;
1179 event_callback.resume = app_resume;
1180 event_callback.app_control = app_service;
1182 ui_app_add_event_handler(&handlers[APP_EVENT_LOW_BATTERY], APP_EVENT_LOW_BATTERY, _indicator_low_bat_cb, NULL);
1183 ui_app_add_event_handler(&handlers[APP_EVENT_LANGUAGE_CHANGED], APP_EVENT_LANGUAGE_CHANGED, _indicator_lang_changed_cb, &ad);
1184 ui_app_add_event_handler(&handlers[APP_EVENT_REGION_FORMAT_CHANGED], APP_EVENT_REGION_FORMAT_CHANGED, _indicator_region_changed_cb, NULL);
1186 memset(&ad, 0x0, sizeof(struct appdata));
1188 ret = ui_app_main(argc, argv, &event_callback, &ad);
1189 if (ret != APP_ERROR_NONE) {
1190 _E("app_main() is failed. err = %d", ret);