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>
26 #include <minicontrol-monitor.h>
28 #include <notification.h>
29 #include <app_preference.h>
33 #include <tzsh_indicator_service.h>
36 #include <app_manager_product.h>
43 #include "indicator_gui.h"
50 #include "indicator.h"
53 #define GRP_NAME "indicator"
54 #define WIN_TITLE "Illume Indicator"
55 #define VCONF_PHONE_STATUS "memory/startapps/sequence"
57 #define BUS_NAME "org.tizen.system.deviced"
58 #define PATH_NAME "/Org/Tizen/System/DeviceD/Display"
59 #define INTERFACE_NAME BUS_NAME".display"
60 #define MEMBER_NAME "LCDOn"
62 #define MP_APP_ID "org.tizen.music-player-lite"
63 #define FMRADIO_APP_ID "org.tizen.fm-radio-lite"
64 #define VR_APP_ID "org.tizen.voicerecorder-lite"
66 #define STR_ATOM_MV_INDICATOR_GEOMETRY "_E_MOVE_INDICATOR_GEOMETRY"
68 #define HIBERNATION_ENTER_NOTI "HIBERNATION_ENTER"
69 #define HIBERNATION_LEAVE_NOTI "HIBERNATION_LEAVE"
71 #define UNLOCK_ENABLED 0
74 #ifdef HOME_KEY_EMULATION
75 /* Predefine string */
76 #define PROP_HWKEY_EMULATION "_HWKEY_EMULATION"
77 #define KEY_MSG_PREFIX_PRESS "P:"
78 #define KEY_MSG_PREFIX_RELEASE "R:"
79 #define KEY_MSG_PREFIX_PRESS_C "PC"
80 #define KEY_MSG_PREFIX_RELEASE_C "RC"
83 #define KEY_HOME "XF86Phone"
85 #endif /* HOME_KEY_EMULATION */
87 //static E_DBus_Connection *edbus_conn=NULL;
88 //static E_DBus_Signal_Handler *edbus_handler=NULL;
89 static Eina_Bool home_button_pressed = EINA_FALSE;
90 static Eina_Bool show_hide_pressed = EINA_FALSE;
91 Evas_Coord_Point indicator_press_coord = {0,0};
92 Ecore_Timer *clock_timer;
93 int is_transparent = 0;
94 int current_angle = 0;
95 int current_state = 0;
96 static int bFirst_opacity = 1;
98 static struct _s_info {
99 Ecore_Timer *listen_timer;
101 .listen_timer = NULL,
105 static indicator_error_e _start_indicator(void *data);
106 static indicator_error_e _terminate_indicator(void *data);
108 static void _indicator_low_bat_cb(app_event_info_h event_info, void *data);
109 static void _indicator_lang_changed_cb(app_event_info_h event_info, void *data);
110 static void _indicator_region_changed_cb(app_event_info_h event_info, void *data);
111 static void _indicator_window_delete_cb(void *data, Evas_Object * obj, void *event);
112 //static Eina_Bool _indicator_client_message_cb(void *data, int type, void *event);
113 static void _indicator_mouse_down_cb(void *data, Evas * e, Evas_Object * obj, void *event);
114 static void _indicator_mouse_move_cb(void *data, Evas * e, Evas_Object * obj, void *event);
115 static void _indicator_mouse_up_cb(void *data, Evas * e, Evas_Object * obj, void *event);
118 static void _indicator_low_bat_cb(app_event_info_h event_info, void *data)
122 static void _indicator_lang_changed_cb(app_event_info_h event_info, void *data)
124 modules_lang_changed(data);
127 static void _indicator_region_changed_cb(app_event_info_h event_info, void *data)
129 modules_region_changed(data);
132 static void _indicator_window_delete_cb(void *data, Evas_Object * obj, void *event)
136 _terminate_indicator((struct appdata *)data);
139 static void _indicator_notify_pm_state_cb(keynode_t * node, void *data)
141 static int nMove = 0;
142 static int nIndex = 1;
147 if (vconf_get_int(VCONFKEY_PM_STATE, &val) < 0) return;
150 case VCONFKEY_PM_STATE_LCDOFF:
151 if (clock_timer != NULL) {
152 ecore_timer_del(clock_timer);
155 case VCONFKEY_PM_STATE_SLEEP: // lcd off 2
157 nMove = nMove+nIndex;
163 char temp[30] = {0,};
164 sprintf(temp,"indicator.padding.resize.%d",nMove);
165 util_signal_emit(data,temp,"indicator.prog");
167 icon_set_update_flag(0);
168 box_noti_ani_handle(0);
170 case VCONFKEY_PM_STATE_NORMAL:
171 if (!icon_get_update_flag()) {
172 icon_set_update_flag(1);
173 box_noti_ani_handle(1);
174 modules_wake_up(data);
177 case VCONFKEY_PM_STATE_LCDDIM:
183 static void _indicator_power_off_status_cb(keynode_t * node, void *data)
189 if (vconf_get_int(VCONFKEY_SYSMAN_POWER_OFF_STATUS, &val) < 0) return;
192 case VCONFKEY_SYSMAN_POWER_OFF_DIRECT:
193 case VCONFKEY_SYSMAN_POWER_OFF_RESTART:
202 static void _indicator_lock_status_cb(keynode_t * node, void *data)
204 static int lockstate = 0;
205 extern int clock_mode;
210 if (vconf_get_int(VCONFKEY_IDLE_LOCK_STATE, &val) < 0) return;
211 if (val == lockstate) return;
216 case VCONFKEY_IDLE_UNLOCK:
217 if (!clock_mode) util_signal_emit(data,"clock.font.12","indicator.prog");
218 else util_signal_emit(data,"clock.font.24","indicator.prog");
220 case VCONFKEY_IDLE_LOCK:
221 case VCONFKEY_IDLE_LAUNCHING_LOCK:
222 util_signal_emit(data,"clock.invisible","indicator.prog");
230 static void _rotate_window(struct appdata *ad, int new_angle)
234 _D("Indicator angle is %d degree", new_angle);
236 current_angle = new_angle;
241 evas_object_resize(ad->win.win, ad->win.port_w, ad->win.h);
245 evas_object_resize(ad->win.win, ad->win.land_w, ad->win.h);
252 static void _change_opacity(void *data, enum indicator_opacity_mode mode)
254 struct appdata *ad = NULL;
255 const char *signal = NULL;
256 retif(data == NULL, , "Invalid parameter!");
260 if (bFirst_opacity==1) bFirst_opacity = 0;
263 case INDICATOR_OPACITY_OPAQUE:
264 signal = "bg.opaque";
265 ad->opacity_mode = mode;
267 case INDICATOR_OPACITY_TRANSLUCENT:
268 signal = "bg.translucent";
269 ad->opacity_mode = mode;
271 case INDICATOR_OPACITY_TRANSPARENT:
272 signal = "bg.transparent";
273 ad->opacity_mode = mode;
276 _E("unknown mode : %d", mode);
277 signal = "bg.opaque";
278 ad->opacity_mode = INDICATOR_OPACITY_OPAQUE;
282 util_signal_emit_by_win(&(ad->win),signal, "indicator.prog");
285 static void _indicator_quickpanel_changed(void *data, int is_open)
291 if (vconf_get_int(VCONFKEY_IDLE_LOCK_STATE, &val) < 0) return;
292 if (val == VCONFKEY_IDLE_LOCK) return;
297 static Eina_Bool _indicator_client_message_cb(void *data, int type, void *event)
299 Ecore_X_Event_Client_Message *ev = (Ecore_X_Event_Client_Message *) event;
300 struct appdata *ad = NULL;
303 retv_if(data == NULL || event == NULL, ECORE_CALLBACK_RENEW);
304 if (ev->message_type == ECORE_X_ATOM_E_ILLUME_QUICKPANEL_STATE) {
305 if (ev->data.l[0] == ECORE_X_ATOM_E_ILLUME_QUICKPANEL_ON) {
306 _indicator_quickpanel_changed(data, 1);
307 } else if (ev->data.l[0] == ECORE_X_ATOM_E_ILLUME_QUICKPANEL_OFF) {
308 _indicator_quickpanel_changed(data, 0);
312 if (ev->message_type == ECORE_X_ATOM_E_ILLUME_ROTATE_WINDOW_ANGLE) {
314 if(ev->win != ad->active_indi_win) {
315 return ECORE_CALLBACK_RENEW;
317 new_angle = ev->data.l[0];
318 _rotate_window(ad, new_angle);
324 static Eina_Bool _active_indicator_handle(void* data,int type)
328 // Ecore_X_Illume_Indicator_Opacity_Mode illume_opacity = 0;
330 retv_if(!data, EINA_FALSE);
332 struct appdata *ad = (struct appdata *)data;
337 illume_opacity = ecore_x_e_illume_indicator_opacity_get(ad->active_indi_win);
339 switch(illume_opacity) {
340 case ECORE_X_ILLUME_INDICATOR_OPAQUE:
341 trans_mode = INDICATOR_OPACITY_OPAQUE;
343 case ECORE_X_ILLUME_INDICATOR_TRANSLUCENT:
344 trans_mode = INDICATOR_OPACITY_TRANSLUCENT;
346 case ECORE_X_ILLUME_INDICATOR_TRANSPARENT:
347 trans_mode = INDICATOR_OPACITY_TRANSPARENT;
350 trans_mode = INDICATOR_OPACITY_OPAQUE;
354 _change_opacity(ad, trans_mode);
358 util_win_prop_angle_get(ad->active_indi_win, &angle);
359 _rotate_window(ad, angle);
368 static Eina_Bool _property_changed_cb(void *data, int type, void *event)
371 struct appdata *ad = data;
372 Ecore_X_Event_Window_Property *ev = event;
374 retv_if(!ad, ECORE_CALLBACK_PASS_ON);
375 retv_if(!ev, ECORE_CALLBACK_PASS_ON);
377 if (ev->atom == ECORE_X_ATOM_E_ILLUME_ROTATE_WINDOW_ANGLE) {
378 if (ev->win == ad->active_indi_win) {
379 _active_indicator_handle(data, 2);
381 } else if (ev->atom == ECORE_X_ATOM_E_ILLUME_INDICATOR_OPACITY_MODE) {
382 if (ev->win == ad->active_indi_win) {
383 _active_indicator_handle(data, 1);
385 } else if (ev->atom == ad->atom_active) {
388 Ecore_X_Window active_win;
390 ret = ecore_x_window_prop_window_get(ecore_x_window_root_first_get(), ad->atom_active, &(active_win), 1);
392 _E("Count of fetched items : %d", ret);
393 return ECORE_CALLBACK_PASS_ON;
396 if (active_win != ad->active_indi_win) {
397 if (ad->active_indi_win != -1) {
398 ecore_x_window_unsniff(ad->active_indi_win);
399 _D("UNSNIFF API %x", ad->active_indi_win);
401 ad->active_indi_win = active_win;
403 ecore_x_window_sniff(ad->active_indi_win);
406 _active_indicator_handle(data, 1);
407 _active_indicator_handle(data, 2);
410 return ECORE_CALLBACK_PASS_ON;
414 static void _mctrl_monitor_cb(minicontrol_action_e action, const char *name, unsigned int width, unsigned int height, minicontrol_priority_e priority, void *data)
419 modules_minictrl_control(action,name,data);
423 static void _indicator_ecore_evas_msg_parent_handle(Ecore_Evas *ee, int msg_domain, int msg_id, void *data, int size)
427 #ifdef _SUPPORT_SCREEN_READER
428 if (msg_domain == MSG_DOMAIN_CONTROL_ACCESS) {
429 struct appdata *ad = (struct appdata *)ecore_evas_data_get(ee,"indicator_app_data");
433 Elm_Access_Action_Info *action_info;
434 Evas_Object* win = NULL;
439 if (msg_id == ELM_ACCESS_ACTION_ACTIVATE) {
440 elm_access_action(win, action_info->action_type,action_info);
441 } else if (msg_id == ELM_ACCESS_ACTION_HIGHLIGHT_NEXT) {
442 action_info->highlight_cycle = EINA_TRUE;
443 elm_access_action(win,action_info->action_type,action_info);
444 } else if (msg_id == ELM_ACCESS_ACTION_HIGHLIGHT_PREV) {
445 action_info->highlight_cycle = EINA_TRUE;
446 elm_access_action(win,action_info->action_type,action_info);
447 } else if (msg_id == ELM_ACCESS_ACTION_UNHIGHLIGHT) {
448 elm_access_action(win,action_info->action_type,action_info);
449 } else if (msg_id == ELM_ACCESS_ACTION_READ) {
450 elm_access_action(win,action_info->action_type,action_info);
453 #endif /* _SUPPORT_SCREEN_READER */
457 static void on_changed_receive(void *data, DBusMessage *msg)
461 r = dbus_message_is_signal(msg, INTERFACE_NAME, MEMBER_NAME);
464 _D("LCD On handling");
466 if (!icon_get_update_flag()) {
467 icon_set_update_flag(1);
468 box_noti_ani_handle(1);
469 modules_wake_up(data);
473 static void edbus_cleaner(void)
476 _D("already unregistered");
481 e_dbus_signal_handler_del(edbus_conn, edbus_handler);
482 edbus_handler = NULL;
486 e_dbus_connection_close(edbus_conn);
493 static int edbus_listener(void* data)
495 if (edbus_conn != NULL) {
502 edbus_conn = e_dbus_bus_get(DBUS_BUS_SYSTEM);
504 _E("e_dbus_bus_get error");
508 edbus_handler = e_dbus_signal_handler_add(edbus_conn, NULL, PATH_NAME, INTERFACE_NAME, MEMBER_NAME, on_changed_receive, data);
509 if (!edbus_handler) {
510 _E("e_dbus_signal_handler_add error");
518 static void _register_event_handler_both(win_info *win, void *data)
524 ee = ecore_evas_ecore_evas_get(evas_object_evas_get(win->win));
526 evas_object_smart_callback_add(win->win,"delete,request", _indicator_window_delete_cb, data);
527 evas_object_event_callback_add(win->layout, EVAS_CALLBACK_MOUSE_DOWN, _indicator_mouse_down_cb, win);
528 evas_object_event_callback_add(win->layout, EVAS_CALLBACK_MOUSE_MOVE, _indicator_mouse_move_cb, win);
529 evas_object_event_callback_add(win->layout, EVAS_CALLBACK_MOUSE_UP,_indicator_mouse_up_cb, win);
530 ecore_evas_callback_msg_parent_handle_set(ee, _indicator_ecore_evas_msg_parent_handle);
531 ecore_evas_data_set(ee,"indicator_app_data",data);
536 static void _indicator_service_cb(void *data, tzsh_indicator_service_h service, int angle, int opacity)
538 _D("Indicator service callback");
542 static void register_event_handler(void *data)
544 struct appdata *ad = data;
545 // Ecore_Event_Handler *hdl = NULL;
548 ad->active_indi_win = -1;
549 //ad->atom_active = ecore_x_atom_get("_NET_ACTIVE_WINDOW");
550 //ecore_x_window_sniff(ecore_x_window_root_first_get());
552 _register_event_handler_both(&(ad->win),data);
556 if (ad->indicator_service) {
557 tzsh_indicator_service_property_change_cb_set(ad->indicator_service, _indicator_service_cb, NULL);
562 hdl = ecore_event_handler_add(ECORE_X_EVENT_CLIENT_MESSAGE, _indicator_client_message_cb, (void *)ad);
564 ad->evt_handlers = eina_list_append(ad->evt_handlers, hdl);
566 hdl = ecore_event_handler_add(ECORE_X_EVENT_WINDOW_PROPERTY, _property_changed_cb, data);
568 ad->evt_handlers = eina_list_append(ad->evt_handlers, hdl);
570 if (vconf_notify_key_changed(VCONFKEY_PM_STATE, _indicator_notify_pm_state_cb, (void *)ad) != 0) {
571 _E("Fail to set callback for VCONFKEY_PM_STATE");
574 if (vconf_notify_key_changed(VCONFKEY_SYSMAN_POWER_OFF_STATUS, _indicator_power_off_status_cb, (void *)ad) < 0) {
575 _E("Failed to set callback for VCONFKEY_SYSMAN_POWER_OFF_STATUS");
578 if (vconf_notify_key_changed(VCONFKEY_IDLE_LOCK_STATE, _indicator_lock_status_cb, (void *)ad) < 0) {
579 _E("Failed to set callback for VCONFKEY_IDLE_LOCK_STATE");
582 // edbus_listener(data);
585 static void _unregister_event_handler_both(win_info *win)
589 evas_object_smart_callback_del(win->win, "delete-request", _indicator_window_delete_cb);
590 evas_object_event_callback_del(win->layout, EVAS_CALLBACK_MOUSE_DOWN, _indicator_mouse_down_cb);
591 evas_object_event_callback_del(win->layout, EVAS_CALLBACK_MOUSE_MOVE, _indicator_mouse_move_cb);
592 evas_object_event_callback_del(win->layout, EVAS_CALLBACK_MOUSE_UP, _indicator_mouse_up_cb);
595 static int unregister_event_handler(void *data)
597 struct appdata *ad = (struct appdata *)data;
601 _unregister_event_handler_both(&(ad->win));
603 vconf_ignore_key_changed(VCONFKEY_PM_STATE, _indicator_notify_pm_state_cb);
604 vconf_ignore_key_changed(VCONFKEY_SYSMAN_POWER_OFF_STATUS, _indicator_power_off_status_cb);
605 vconf_ignore_key_changed(VCONFKEY_IDLE_LOCK_STATE, _indicator_lock_status_cb);
607 Ecore_Event_Handler *hdl = NULL;
608 EINA_LIST_FREE(ad->evt_handlers, hdl) {
609 if (hdl) ecore_event_handler_del(hdl);
617 static void _create_layout(struct appdata *ad, const char *file, const char *group)
619 ad->win.layout = elm_layout_add(ad->win.win);
620 ret_if(!ad->win.layout);
622 if (EINA_FALSE == elm_layout_file_set(ad->win.layout, file, group)) {
623 _E("Failed to set file of layout");
624 evas_object_del(ad->win.layout);
628 evas_object_size_hint_min_set(ad->win.layout, ad->win.w, ad->win.h);
630 evas_object_size_hint_weight_set(ad->win.layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
631 elm_win_resize_object_add(ad->win.win, ad->win.layout);
632 evas_object_move(ad->win.layout, 0, 0);
633 evas_object_show(ad->win.layout);
636 static void _create_box(win_info *win)
640 /* First, clear layout */
650 static indicator_error_e _tzsh_set(struct appdata* ad)
654 retv_if(!ad, INDICATOR_ERROR_INVALID_PARAMETER);
655 retv_if(!ad->win.win, INDICATOR_ERROR_INVALID_PARAMETER);
657 ad->tzsh = tzsh_create(TZSH_TOOLKIT_TYPE_EFL);
658 retv_if(!ad->tzsh, INDICATOR_ERROR_FAIL);
660 tz_win = elm_win_window_id_get(ad->win.win);
662 tzsh_destroy(ad->tzsh);
663 _E("Failed to get Tizen window");
665 //return INDICATOR_ERROR_FAIL;
666 return INDICATOR_ERROR_NONE;
669 ad->indicator_service = tzsh_indicator_service_create(ad->tzsh, tz_win);
670 if (!ad->indicator_service) {
671 tzsh_destroy(ad->tzsh);
672 _E("Failed to create Tizen window indicator service");
673 return INDICATOR_ERROR_FAIL;
676 return INDICATOR_ERROR_NONE;
679 static void _tzsh_unset(struct appdata *ad)
683 if (ad->indicator_service) {
684 tzsh_indicator_service_destroy(ad->indicator_service);
685 ad->indicator_service = NULL;
689 tzsh_destroy(ad->tzsh);
695 static Eina_Bool _indicator_listen_timer_cb(void* data)
697 win_info *win = data;
699 retv_if(!win, ECORE_CALLBACK_CANCEL);
701 //win = (win_info*)data;
703 if (!elm_win_socket_listen(win->win , INDICATOR_SERVICE_NAME, 0, EINA_FALSE)) {
704 _E("failed to elm_win_socket_listen() %x", win->win);
705 return ECORE_CALLBACK_RENEW;
707 _D("listen success");
708 s_info.listen_timer = NULL;
709 return ECORE_CALLBACK_CANCEL;
713 #define INDICATOR_HEIGHT_TM1 52
714 static void _create_window(struct appdata *ad)
716 Evas_Object *dummy_win = NULL;
720 ad->win.win = elm_win_add(NULL, "indicator", ELM_WIN_SOCKET_IMAGE);
721 ret_if(!(ad->win.win));
723 elm_win_alpha_set(ad->win.win, EINA_TRUE);
725 dummy_win = elm_win_add(NULL, "indicator_dummy", ELM_WIN_BASIC);
727 elm_win_screen_size_get(dummy_win, NULL, NULL, &ad->win.port_w, &ad->win.land_w);
728 evas_object_del(dummy_win);
729 _D("Dummy window w, h (%d, %d)", ad->win.port_w, ad->win.land_w);
731 _E("Critical error. Cannot create dummy window");
734 if (!elm_win_socket_listen(ad->win.win , INDICATOR_SERVICE_NAME, 0, EINA_FALSE)) {
735 _E("Failed 1st to elm_win_socket_listen() %x", ad->win.win);
737 if (s_info.listen_timer != NULL) {
738 ecore_timer_del(s_info.listen_timer);
739 s_info.listen_timer = NULL;
741 s_info.listen_timer = ecore_timer_add(3, _indicator_listen_timer_cb, &(ad->win));
744 elm_win_alpha_set(ad->win.win , EINA_TRUE);
746 elm_win_borderless_set(ad->win.win , EINA_TRUE);
747 evas_object_size_hint_fill_set(ad->win.win , EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
748 evas_object_size_hint_align_set(ad->win.win , 1.0, 0.5);
750 evas_object_resize(ad->win.win, ad->win.port_w, INDICATOR_HEIGHT_TM1);
751 _D("w,h(%d,%d)", ad->win.port_w, INDICATOR_HEIGHT_TM1);
753 evas_object_show(ad->win.win);
757 static void _create_base_gui(void* data)
759 struct appdata *ad = data;
760 Evas_Object *dummy_win = NULL;
764 _D("Start to create base gui");
770 if (INDICATOR_ERROR_NONE != _tzsh_set(ad)) {
771 _E("Failed to set tzsh");
776 ad->win.h = INDICATOR_HEIGHT_TM1;
777 ad->win.w = ad->win.port_w;
778 ad->win.evas = evas_object_evas_get(ad->win.win);
780 _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));
782 _create_layout(ad, EDJ_FILE, GRP_NAME);
783 _create_box(&(ad->win));
787 Evas_Object *rect = evas_object_rectangle_add(ad->win.evas);
789 evas_object_resize(rect, 720, 52);
790 evas_object_color_set(rect, 0, 0, 255, 255);
791 evas_object_show(rect);
792 evas_object_layer_set(rect, -256);
799 static void _init_win_info(void * data)
801 struct appdata *ad = data;
805 memset(&(ad->win),0x00,sizeof(win_info));
808 static void _init_tel_info(void * data)
810 struct appdata *ad = data;
814 memset(&(ad->tel_info), 0x00, sizeof(telephony_info));
817 static indicator_error_e _start_indicator(void *data)
819 retv_if(!data, INDICATOR_ERROR_INVALID_PARAMETER);
821 _init_win_info(data);
822 _init_tel_info(data);
824 /* Create indicator window */
825 _create_base_gui(data);
827 return INDICATOR_ERROR_NONE;
830 static indicator_error_e _terminate_indicator(void *data)
832 struct appdata *ad = data;
834 retv_if(!ad, INDICATOR_ERROR_INVALID_PARAMETER);
837 unregister_event_handler(ad);
839 box_fini(&(ad->win));
842 evas_image_cache_flush(ad->win.evas);
844 if (ad->win.layout) {
845 evas_object_del(ad->win.layout);
846 ad->win.layout = NULL;
850 evas_object_del(ad->win.win);
864 return INDICATOR_ERROR_NONE;
867 static void __indicator_set_showhide_press(int value, int line)
869 show_hide_pressed = value;
872 static void _indicator_mouse_down_cb(void *data, Evas * e, Evas_Object * obj, void *event)
874 win_info *win = (win_info*)data;
875 Evas_Event_Mouse_Down *ev = NULL;
877 retif(data == NULL || event == NULL, , "Invalid parameter!");
880 win->mouse_event.x = ev->canvas.x;
881 win->mouse_event.y = ev->canvas.y;
883 if (ev->button != 1) {
887 #ifdef HOME_KEY_EMULATION
888 if (box_check_indicator_area(win, ev->canvas.x, ev->canvas.y)) {
889 int lock_state = VCONFKEY_IDLE_UNLOCK;
893 /* if (indicator_message_disp_check(win->type) == 1) {
896 ret = vconf_get_int(VCONFKEY_IDLE_LOCK_STATE,&lock_state);
898 if (ret != 0 || lock_state == VCONFKEY_IDLE_LOCK) {
901 ret = vconf_get_int(VCONFKEY_SETAPPL_PSMODE,&ps_state);
903 if (ret != 0 || ps_state == SETTING_PSMODE_EMERGENCY) {
907 if (box_check_home_icon_area(win, ev->canvas.x, ev->canvas.y)) {
909 if (util_check_system_status() == FAIL) {
910 _D("util_check_system_status failed");
913 home_button_pressed = EINA_TRUE;
915 indicator_press_coord.x = ev->canvas.x;
916 indicator_press_coord.y = ev->canvas.y;
923 static void _indicator_mouse_move_cb(void *data, Evas * e, Evas_Object * obj, void *event)
925 Evas_Event_Mouse_Move *ev = NULL;
926 win_info* win = (win_info*)data;
928 retif(data == NULL || event == NULL, , "Invalid parameter!");
932 if (home_button_pressed) {
933 if (!box_check_home_icon_area(win,ev->cur.canvas.x,ev->cur.canvas.y)) {
934 home_button_pressed = FALSE;
938 if (show_hide_pressed == 1) {
939 if (!box_check_more_icon_area(win,ev->cur.canvas.x,ev->cur.canvas.y)) {
940 __indicator_set_showhide_press(EINA_FALSE, __LINE__);
945 static void _indicator_mouse_up_cb(void *data, Evas * e, Evas_Object * obj, void *event)
947 Evas_Event_Mouse_Up *ev = NULL;
948 win_info *win = (win_info *)data;
950 retif(data == NULL || event == NULL, , "Invalid parameter!");
954 #ifdef HOME_KEY_EMULATION
955 if (box_check_indicator_area(win, ev->canvas.x, ev->canvas.y)) {
957 if (box_check_home_icon_area(win, ev->canvas.x, ev->canvas.y)) {
958 if (home_button_pressed == EINA_TRUE) {
959 util_launch_search(win->data);
960 feedback_play_type(FEEDBACK_TYPE_SOUND, FEEDBACK_PATTERN_TAP);
963 } else if (box_check_more_icon_area(win, ev->canvas.x, ev->canvas.y)) {
964 if(show_hide_pressed == EINA_TRUE) {
966 feedback_play_type(FEEDBACK_TYPE_SOUND, FEEDBACK_PATTERN_TAP);
971 home_button_pressed = EINA_FALSE;
972 __indicator_set_showhide_press(EINA_FALSE, __LINE__);
974 #else /* HOME_REMOVE_LONGPRESS */
975 int mouse_up_prio = -1;
976 int mouse_down_prio = -1;
978 if (home_button_pressed == EINA_TRUE) {
979 home_button_pressed = EINA_FALSE;
983 box_get_priority_in_move_area(win,win->mouse_event.x,
985 mouse_up_prio = box_get_priority_in_move_area(win,ev->canvas.x,
988 if (mouse_down_prio > -1 && mouse_up_prio > -1
989 && mouse_down_prio == mouse_up_prio) {
990 switch (mouse_down_prio) {
991 case INDICATOR_PRIORITY_FIXED1:
992 int lock_state = VCONFKEY_IDLE_UNLOCK;
995 lock_ret = vconf_get_int(VCONFKEY_IDLE_LOCK_STATE,
998 /* In Lock Screen, home button don't have to do */
999 if (lock_ret == 0 && lock_state == VCONFKEY_IDLE_LOCK)
1002 char *top_win_name = NULL;
1004 if (util_check_system_status() == FAIL)
1009 #endif /* HOME_KEY_EMULATION */
1010 win->mouse_event.x = 0;
1011 win->mouse_event.y = 0;
1015 static void _app_terminate_cb(app_context_h app_context, app_context_status_e status, void *data)
1017 retif(data == NULL, , "Invalid parameter!");
1018 DBG("_app_terminate_cb");
1019 char *app_id = NULL;
1020 app_context_get_app_id(app_context, &app_id);
1021 if (app_id == NULL) {
1022 ERR("app_id is null!!");
1025 DBG("_app_terminate_cb %s",app_id);
1028 if (status == APP_CONTEXT_STATUS_TERMINATED) {
1029 if (strcmp(MP_APP_ID,app_id) == 0) {
1030 DBG("hide music icon");
1032 } else if(strcmp(FMRADIO_APP_ID,app_id) == 0) {
1033 DBG("hide fm radio icon");
1034 hide_fm_radio_icon();
1035 } else if(strcmp(VR_APP_ID,app_id) == 0) {
1036 DBG("hide voice recorder icon");
1037 hide_voice_recorder_icon();
1046 static void register_app_terminate_cb(void* data)
1048 retif(data == NULL, , "Invalid parameter!");
1049 app_manager_set_app_context_status_cb(_app_terminate_cb, MP_APP_ID, data);
1050 app_manager_set_app_context_status_cb(_app_terminate_cb, FMRADIO_APP_ID, data);
1051 app_manager_set_app_context_status_cb(_app_terminate_cb, VR_APP_ID, data);
1055 static void _signal_handler(int signum, siginfo_t *info, void *unused)
1060 static bool app_create(void *data)
1062 struct appdata *ad = data;
1065 retv_if(!ad, false);
1067 elm_app_base_scale_set(2.6);
1069 /* Signal handler */
1070 struct sigaction act;
1071 memset(&act, 0x00, sizeof(struct sigaction));
1072 act.sa_sigaction = _signal_handler;
1073 act.sa_flags = SA_SIGINFO;
1075 ret = sigemptyset(&act.sa_mask);
1077 _E("Failed to sigemptyset[%s]", strerror(errno));
1079 ret = sigaddset(&act.sa_mask, SIGTERM);
1081 _E("Failed to sigaddset[%s]", strerror(errno));
1083 ret = sigaction(SIGTERM, &act, NULL);
1085 _E("Failed to sigaction[%s]", strerror(errno));
1088 ret = _start_indicator(ad);
1089 if (ret != INDICATOR_ERROR_NONE) {
1090 _D("Failed to create a new window!");
1093 /* Set nonfixed-list size for display */
1094 modules_init_first(ad);
1097 elm_win_activate(ad->win.win);
1099 evas_object_show(ad->win.layout);
1100 evas_object_show(ad->win.win);
1105 static void app_terminate(void *data)
1107 struct appdata *ad = data;
1110 indicator_message_fini();
1111 #ifdef _SUPPORT_SCREEN_READER2
1112 indicator_service_tts_fini(data);
1115 unregister_event_handler(ad);
1117 feedback_deinitialize();
1119 box_fini(&(ad->win));
1120 evas_image_cache_flush(ad->win.evas);
1121 evas_object_del(ad->win.layout);
1122 evas_object_del(ad->win.win);
1124 _D("INDICATOR IS TERMINATED");
1127 static void app_pause(void *data)
1131 static void app_resume(void *data)
1135 static void app_service(app_control_h service, void *data)
1137 struct appdata *ad = data;
1139 _D("INDICATOR IS STARTED");
1141 register_event_handler(ad);
1143 #ifdef _SUPPORT_SCREEN_READER
1144 modules_register_tts(data);
1146 feedback_initialize();
1147 indicator_message_init(data);
1148 if (INDICATOR_ERROR_NONE != ticker_init(ad)) {
1149 _E("Ticker cannot initialize");
1151 #ifdef _SUPPORT_SCREEN_READER2
1152 indicator_service_tts_init(data);
1154 _indicator_lock_status_cb(NULL, data);
1156 register_app_terminate_cb(data);
1160 int main(int argc, char *argv[])
1164 ui_app_lifecycle_callback_s event_callback = {0,};
1165 app_event_handler_h handlers[5] = {NULL, };
1169 _D("Start indicator");
1171 event_callback.create = app_create;
1172 event_callback.terminate = app_terminate;
1173 event_callback.pause = app_pause;
1174 event_callback.resume = app_resume;
1175 event_callback.app_control = app_service;
1177 ui_app_add_event_handler(&handlers[APP_EVENT_LOW_BATTERY], APP_EVENT_LOW_BATTERY, _indicator_low_bat_cb, NULL);
1178 ui_app_add_event_handler(&handlers[APP_EVENT_LANGUAGE_CHANGED], APP_EVENT_LANGUAGE_CHANGED, _indicator_lang_changed_cb, &ad);
1179 ui_app_add_event_handler(&handlers[APP_EVENT_REGION_FORMAT_CHANGED], APP_EVENT_REGION_FORMAT_CHANGED, _indicator_region_changed_cb, NULL);
1181 memset(&ad, 0x0, sizeof(struct appdata));
1183 ret = ui_app_main(argc, argv, &event_callback, &ad);
1184 if (ret != APP_ERROR_NONE) {
1185 _E("app_main() is failed. err = %d", ret);